fixes issue #62: keep LuaDoc compatibility, unless not_luadoc is explicitly set

This commit is contained in:
steve donovan 2013-05-09 13:28:39 +02:00
parent ac5c5f2c65
commit cf7b8e3a9a
3 changed files with 23 additions and 6 deletions

View File

@ -185,7 +185,8 @@ local ldoc_contents = {
'alias','add_language_extension','new_type','add_section', 'tparam_alias', 'alias','add_language_extension','new_type','add_section', 'tparam_alias',
'file','project','title','package','format','output','dir','ext', 'topics', 'file','project','title','package','format','output','dir','ext', 'topics',
'one','style','template','description','examples', 'pretty', 'charset', 'plain', 'one','style','template','description','examples', 'pretty', 'charset', 'plain',
'readme','all','manual_url', 'ignore', 'colon','boilerplate','merge', 'wrap', 'readme','all','manual_url', 'ignore', 'colon',
'boilerplate','merge', 'wrap', 'not_luadoc',
'no_return_or_parms','no_summary','full_description','backtick_references', 'custom_see_handler', 'no_return_or_parms','no_summary','full_description','backtick_references', 'custom_see_handler',
} }
ldoc_contents = tablex.makeset(ldoc_contents) ldoc_contents = tablex.makeset(ldoc_contents)
@ -361,6 +362,7 @@ setup_package_base()
override 'colon' override 'colon'
override 'merge' override 'merge'
override 'not_luadoc'
if type(args.file) == 'table' then if type(args.file) == 'table' then
-- this can only be set from config file so we can assume it's already read -- this can only be set from config file so we can assume it's already read

View File

@ -388,14 +388,21 @@ function Item:add_to_description (rest)
end end
end end
function Item:trailing_warning (kind,tag,rest)
if type(rest)=='string' and #rest > 0 then
Item.warning(self,kind.." tag: '"..tag..'" has trailing text; use no_luadoc=true\n'..rest)
end
end
function Item:set_tag (tag,value) function Item:set_tag (tag,value)
local ttype = known_tags[tag] local ttype = known_tags[tag]
local args = self.file.args
if ttype == TAG_MULTI or ttype == TAG_MULTI_LINE then -- value is always a List! if ttype == TAG_MULTI or ttype == TAG_MULTI_LINE then -- value is always a List!
if getmetatable(value) ~= List then if getmetatable(value) ~= List then
value = List{value} value = List{value}
end end
if ttype ~= TAG_MULTI_LINE then if ttype ~= TAG_MULTI_LINE and args.not_luadoc then
local last = value[#value] local last = value[#value]
if type(last) == 'string' and last:match '\n' then if type(last) == 'string' and last:match '\n' then
local line,rest = last:match('([^\n]+)(.*)') local line,rest = last:match('([^\n]+)(.*)')
@ -417,12 +424,20 @@ function Item:set_tag (tag,value)
if value == nil then self:error("Tag without value: "..tag) end if value == nil then self:error("Tag without value: "..tag) end
local id, rest = tools.extract_identifier(value) local id, rest = tools.extract_identifier(value)
self.tags[tag] = id self.tags[tag] = id
if args.not_luadoc then
self:add_to_description(rest) self:add_to_description(rest)
else
self:trailing_warning('id',tag,rest)
end
elseif ttype == TAG_SINGLE then elseif ttype == TAG_SINGLE then
self.tags[tag] = value self.tags[tag] = value
elseif ttype == TAG_FLAG then elseif ttype == TAG_FLAG then
self.tags[tag] = true self.tags[tag] = true
if args.not_luadoc then
self:add_to_description(value) self:add_to_description(value)
else
self:trailing_warning('flag',tag,value)
end
else else
Item.warning(self,"unknown tag: '"..tag.."' "..tostring(ttype)) Item.warning(self,"unknown tag: '"..tag.."' "..tostring(ttype))
end end

View File

@ -1,8 +1,8 @@
------------ ------------
-- Yet another module. -- Yet another module.
-- @module four
-- Description can continue after simple tags, if you -- Description can continue after simple tags, if you
-- like -- like - but to keep backwards compatibility, say 'not_luadoc=true'
-- @module four
-- @author bob, james -- @author bob, james
-- @license MIT -- @license MIT
-- @copyright InfoReich 2013 -- @copyright InfoReich 2013