@usage tag now works in module comments; annotations were borked

This commit is contained in:
steve donovan 2011-09-19 13:34:01 +02:00
parent 2b54ad1627
commit 40330487b0
4 changed files with 24 additions and 10 deletions

View File

@ -90,6 +90,15 @@ return [==[
# elseif module then -- module documentation # elseif module then -- module documentation
<p>$(M(module.summary,module))</p> <p>$(M(module.summary,module))</p>
<p>$(M(module.description,module))</p> <p>$(M(module.description,module))</p>
# if module.usage then
# local li,il = use_li(module.usage)
<h3>Usage:</h3>
<ul>
# for usage in iter(module.usage) do
$(li)<pre class="example">$(usage)</pre>$(il)
# end -- for
</ul>
# end -- if usage
# if not ldoc.no_summary then # if not ldoc.no_summary then
# -- bang out the tables of item types for this module (e.g Functions, Tables, etc) # -- bang out the tables of item types for this module (e.g Functions, Tables, etc)

View File

@ -58,7 +58,7 @@ ModuleMap:add_kind('function','Functions','Parameters')
ModuleMap:add_kind('table','Tables','Fields') ModuleMap:add_kind('table','Tables','Fields')
ModuleMap:add_kind('field','Fields') ModuleMap:add_kind('field','Fields')
ModuleMap:add_kind('lfunction','Local Functions','Parameters') ModuleMap:add_kind('lfunction','Local Functions','Parameters')
ModuleMap:add_kind('annotation','Annotations') ModuleMap:add_kind('annotation','Issues')
class.ProjectMap(KindMap) class.ProjectMap(KindMap)

View File

@ -73,13 +73,16 @@ known_tags._annotation_tags = {
local acount = 1 local acount = 1
function doc.expand_annotation_item (tags, last_item) function doc.expand_annotation_item (tags, last_item)
local tag, value = next(tags) if tags.summary ~= '' then return false end
for tag, value in pairs(tags) do
if known_tags._annotation_tags[tag] then if known_tags._annotation_tags[tag] then
tags.class = 'annotation' tags.class = 'annotation'
tags.summary = value tags.summary = value
local item_name = last_item and last_item.tags.name or '?' local item_name = last_item and last_item.tags.name or '?'
tags.name = item_name..'-'..tag..acount tags.name = item_name..'-'..tag..acount
acount = acount + 1 acount = acount + 1
return true
end
end end
end end

View File

@ -16,7 +16,8 @@ local tnext, append = lexer.skipws, table.insert
-- a pattern particular to LuaDoc tag lines: the line must begin with @TAG, -- a pattern particular to LuaDoc tag lines: the line must begin with @TAG,
-- followed by the value, which may extend over several lines. -- followed by the value, which may extend over several lines.
local luadoc_tag = '^%s*@(%a+)%s(.+)' local luadoc_tag = '^%s*@(%a+)'
local luadoc_tag_value = luadoc_tag..'(.*)'
-- assumes that the doc comment consists of distinct tag lines -- assumes that the doc comment consists of distinct tag lines
function parse_tags(text) function parse_tags(text)
@ -25,7 +26,7 @@ function parse_tags(text)
local tag_items = {} local tag_items = {}
local follows local follows
while line do while line do
local tag,rest = line:match(luadoc_tag) local tag,rest = line:match(luadoc_tag_value)
follows, line = tools.grab_while_not(lines,luadoc_tag) follows, line = tools.grab_while_not(lines,luadoc_tag)
append(tag_items,{tag, rest .. '\n' .. follows}) append(tag_items,{tag, rest .. '\n' .. follows})
end end
@ -56,6 +57,7 @@ local function extract_tags (s)
tag = Item.check_tag(tags,tag) tag = Item.check_tag(tags,tag)
value = strip(value) value = strip(value)
local old_value = tags[tag] local old_value = tags[tag]
if old_value then if old_value then
if type(old_value)=='string' then tags[tag] = List{old_value} end if type(old_value)=='string' then tags[tag] = List{old_value} end
tags[tag]:append(value) tags[tag]:append(value)