refactoring language-specific stuff out of main parser loop
This commit is contained in:
parent
a31d590e50
commit
1aa717e993
33
ldoc.lua
33
ldoc.lua
|
@ -123,7 +123,6 @@ end
|
||||||
local function extract_tags (s)
|
local function extract_tags (s)
|
||||||
if s:match '^%s*$' then return {} end
|
if s:match '^%s*$' then return {} end
|
||||||
local preamble,tag_items = parse_tags(s)
|
local preamble,tag_items = parse_tags(s)
|
||||||
|
|
||||||
local strip = tools.strip
|
local strip = tools.strip
|
||||||
local summary,description = preamble:match('^(.-[%.?])%s(.+)')
|
local summary,description = preamble:match('^(.-[%.?])%s(.+)')
|
||||||
if not summary then summary = preamble end
|
if not summary then summary = preamble end
|
||||||
|
@ -179,6 +178,17 @@ function Lang:finalize()
|
||||||
self.empty_comment_ = self.start_comment_..'%s*$'
|
self.empty_comment_ = self.start_comment_..'%s*$'
|
||||||
end
|
end
|
||||||
|
|
||||||
|
function Lang:search_for_token (tok,type,value,t,v)
|
||||||
|
while t and not (t == type and v == value) do
|
||||||
|
if t == 'comment' and self:start_comment(v) then return nil,t,v end
|
||||||
|
t,v = tnext(tok)
|
||||||
|
end
|
||||||
|
return t ~= nil,t,v
|
||||||
|
end
|
||||||
|
|
||||||
|
function Lang:parse_function_header (tok,toks)
|
||||||
|
end
|
||||||
|
|
||||||
class.Lua(Lang)
|
class.Lua(Lang)
|
||||||
|
|
||||||
function Lua:_init()
|
function Lua:_init()
|
||||||
|
@ -201,12 +211,9 @@ end
|
||||||
-- we should go back and process it. Likewise, module(...) also means
|
-- we should go back and process it. Likewise, module(...) also means
|
||||||
-- that we must infer the module name.
|
-- that we must infer the module name.
|
||||||
function Lua:find_module(tok,t,v)
|
function Lua:find_module(tok,t,v)
|
||||||
while t and not (t == 'iden' and v == 'module') do
|
local res
|
||||||
if t == 'comment' and self:start_comment(v) then return nil,t,v end
|
res,t,v = self:search_for_token(tok,'iden','module',t,v)
|
||||||
--print(t,v)
|
if not res then return nil,t,v end
|
||||||
t,v = tnext(tok)
|
|
||||||
end
|
|
||||||
if not t then return nil end
|
|
||||||
t,v = tnext(tok)
|
t,v = tnext(tok)
|
||||||
if t == '(' then t,v = tnext(tok) end
|
if t == '(' then t,v = tnext(tok) end
|
||||||
if t == 'string' then -- explicit name, cool
|
if t == 'string' then -- explicit name, cool
|
||||||
|
@ -220,6 +227,12 @@ 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)
|
||||||
|
local name = tools.get_fun_name(tok)
|
||||||
|
local formal_args = tools.get_parameters(toks)
|
||||||
|
return name,formal_args
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
local lua = Lua()
|
local lua = Lua()
|
||||||
|
|
||||||
|
@ -337,12 +350,10 @@ local function parse_file(fname,lang)
|
||||||
-- if we did bump into a doc comment, then we can continue parsing it
|
-- if we did bump into a doc comment, then we can continue parsing it
|
||||||
end
|
end
|
||||||
|
|
||||||
-- end of a group of comments (may be just one)
|
-- end of a block of document comments
|
||||||
if ldoc_comment and tags then
|
if ldoc_comment and tags then
|
||||||
-- ldoc block
|
|
||||||
if fun_follows then -- parse the function definition
|
if fun_follows then -- parse the function definition
|
||||||
tags.name = tools.get_fun_name(tok)
|
tags.name, tags.formal_args = lang:parse_function_header(tok,toks)
|
||||||
tags.formal_args = tools.get_parameters(toks)
|
|
||||||
tags.class = 'function'
|
tags.class = 'function'
|
||||||
end
|
end
|
||||||
if tags.name then
|
if tags.name then
|
||||||
|
|
Loading…
Reference in New Issue