table fields and their descriptions can be extracted from Lua table definitions

This commit is contained in:
steve donovan 2011-04-17 19:01:57 +02:00
parent 1aa717e993
commit de1a2b11ba
4 changed files with 50 additions and 10 deletions

View File

@ -186,9 +186,13 @@ function Lang:search_for_token (tok,type,value,t,v)
return t ~= nil,t,v return t ~= nil,t,v
end end
function Lang:parse_function_header (tok,toks) function Lang:parse_function_header (tags,tok,toks)
end end
function Lang:parse_extra (tags,tok,toks)
end
class.Lua(Lang) class.Lua(Lang)
function Lua:_init() function Lua:_init()
@ -227,10 +231,20 @@ function Lua:function_follows(t,v)
return t == 'keyword' and v == 'function' return t == 'keyword' and v == 'function'
end end
function Lua:parse_function_header (tok,toks) function Lua:parse_function_header (tags,tok,toks)
local name = tools.get_fun_name(tok) tags.name = tools.get_fun_name(tok)
local formal_args = tools.get_parameters(toks) tags.formal_args = tools.get_parameters(toks)
return name,formal_args tags.class = 'function'
end
function Lua:parse_extra (tags,tok,toks)
if tags.class == 'table' and not tags.fields then
local res,t,v = self:search_for_token(tok,'{','{',tok())
if not res then return nil,t,v end
tags.formal_args = tools.get_parameters(toks,'}',function(s)
return s == ',' or s == ';'
end)
end
end end
@ -353,8 +367,9 @@ local function parse_file(fname,lang)
-- end of a block of document comments -- end of a block of document comments
if ldoc_comment and tags then if ldoc_comment and tags then
if fun_follows then -- parse the function definition if fun_follows then -- parse the function definition
tags.name, tags.formal_args = lang:parse_function_header(tok,toks) lang:parse_function_header(tags,tok,toks)
tags.class = 'function' else
lang:parse_extra(tags,tok,toks)
end end
if tags.name then if tags.name then
F:new_item(tags,lineno()).inferred = fun_follows F:new_item(tags,lineno()).inferred = fun_follows

View File

@ -400,6 +400,14 @@ function lexer.get_separated_list(tok,endtoken,delim)
return t == endtoken return t == endtoken
end end
end end
local is_delim
if type(delim) == 'function' then
is_delim = delim
else
is_delim = function(t)
return t == delim
end
end
local token,value local token,value
while true do while true do
token,value=tok() token,value=tok()
@ -418,7 +426,7 @@ function lexer.get_separated_list(tok,endtoken,delim)
else else
tappend(tl,')') tappend(tl,')')
end end
elseif token == delim and level == 1 then elseif level == 1 and is_delim(token) then
append(parm_values,tl) -- a new parm append(parm_values,tl) -- a new parm
tl = {} tl = {}
else else

17
tests/simple/tables.lua Normal file
View File

@ -0,0 +1,17 @@
------------
-- A module containing tables.
-- Shows how Lua table definitions can be conveniently parsed.
-- @alias M
local tables = {}
local M = tables
--- first table
-- @table one
M.one = {
A = 1, -- alpha
B = 2; -- beta
}
return M

View File

@ -199,10 +199,10 @@ local function value_of (tok) return tok[2] end
-- following the arguments. ldoc will use these in addition to explicit -- following the arguments. ldoc will use these in addition to explicit
-- param tags. -- param tags.
function M.get_parameters (tok) function M.get_parameters (tok,endtoken,delim)
local args = List() local args = List()
args.comments = {} args.comments = {}
local ltl = lexer.get_separated_list(tok) local ltl = lexer.get_separated_list(tok,endtoken,delim)
if #ltl[1] == 0 then return args end -- no arguments if #ltl[1] == 0 then return args end -- no arguments