Merge pull request #26 from geoffleyland/master

Missing requires; makefile; parameter descriptions; html
This commit is contained in:
Steve J Donovan 2012-11-01 22:36:24 -07:00
commit 649f91b816
7 changed files with 93 additions and 25 deletions

View File

@ -19,6 +19,7 @@
local class = require 'pl.class' local class = require 'pl.class'
local app = require 'pl.app' local app = require 'pl.app'
local path = require 'pl.path' local path = require 'pl.path'
local dir = require 'pl.dir'
local utils = require 'pl.utils' local utils = require 'pl.utils'
local List = require 'pl.List' local List = require 'pl.List'
local stringx = require 'pl.stringx' local stringx = require 'pl.stringx'

View File

@ -432,7 +432,7 @@ function Item:finish()
-- if available as the authoritative list, and warn if there's an inconsistency. -- if available as the authoritative list, and warn if there's an inconsistency.
if self.formal_args then if self.formal_args then
local fargs = self.formal_args local fargs = self.formal_args
if #fargs ~= 1 then if #fargs ~= 0 then
local pnames, pcomments = names, comments local pnames, pcomments = names, comments
names, comments = List(),List() names, comments = List(),List()
local varargs = fargs[#fargs] == '...' local varargs = fargs[#fargs] == '...'

View File

@ -98,15 +98,32 @@ function html.generate_output(ldoc, args, project)
end end
function ldoc.typename (tp) function ldoc.typename (tp)
if not tp then return '' end if not tp or tp == '' then return '' end
return (tp:gsub('%a[%w_%.]*',function(name) local optional
local tp2 = tp:match("%?|?(.*)")
if tp2 then
optional = true
tp = tp2
end
local types = {}
for name in tp:gmatch("[^|]+") do
local ref,err = markup.process_reference(name) local ref,err = markup.process_reference(name)
if ref then if ref then
return ('<a href="%s">%s</a> '):format(ldoc.href(ref),name) types[#types+1] = ('<a class="type" href="%s">%s</a>'):format(ldoc.href(ref),name)
else else
return '<strong>'..name..'</strong> ' types[#types+1] = '<span class="type">'..name..'</span>'
end end
end)) end
local names = table.concat(types, ", ", 1, math.max(#types-1, 1))
if #types > 1 then names = names.." or "..types[#types] end
if optional then
if names ~= '' then
names = "optional "..names
else
names = "optional"
end
end
return names
end end
local module_template,err = utils.readfile (path.join(args.template,ldoc.templ)) local module_template,err = utils.readfile (path.join(args.template,ldoc.templ))

View File

@ -73,6 +73,11 @@ body {
} }
code, tt { font-family: monospace; } code, tt { font-family: monospace; }
span.parameter { font-family:monospace; }
span.parameter:after { content:":"; }
span.types:before { content:"("; }
span.types:after { content:")"; }
.type { font-weight: bold; font-style:italic }
body, p, td, th { font-size: .95em; line-height: 1.2em;} body, p, td, th { font-size: .95em; line-height: 1.2em;}

View File

@ -140,8 +140,12 @@ return [==[
<h3>$(module.kinds:type_of(item).subnames):</h3> <h3>$(module.kinds:type_of(item).subnames):</h3>
<ul> <ul>
# for p in iter(item.params) do # for p in iter(item.params) do
<li><span class="parameter">$(p)</span>
# local tp = ldoc.typename(item:type_of_param(p)) # local tp = ldoc.typename(item:type_of_param(p))
<li><code><em>$(p)</em></code>: $(tp)$(M(item.params[p],item))</li> # if tp ~= '' then
<span class="types">$(tp)</span>
# end
$(M(item.params[p],item))</li>
# end -- for # end -- for
</ul> </ul>
# end -- if params # end -- if params
@ -161,8 +165,12 @@ return [==[
<h3>Returns:</h3> <h3>Returns:</h3>
<ol> <ol>
# for i,r in ldoc.ipairs(item.ret) do # for i,r in ldoc.ipairs(item.ret) do
$(li)
# local tp = ldoc.typename(item:type_of_ret(i)) # local tp = ldoc.typename(item:type_of_ret(i))
$(li)$(tp)$(M(r,item))$(il) # if tp ~= '' then
<span class="types">$(tp)</span>
# end
$(M(r,item))$(il)
# end -- for # end -- for
</ol> </ol>
# end -- if returns # end -- if returns

View File

@ -6,6 +6,7 @@ local class = require 'pl.class'
local List = require 'pl.List' local List = require 'pl.List'
local path = require 'pl.path' local path = require 'pl.path'
local utils = require 'pl.utils' local utils = require 'pl.utils'
local tablex = require 'pl.tablex'
local tools = {} local tools = {}
local M = tools local M = tools
local append = table.insert local append = table.insert
@ -279,37 +280,49 @@ function M.get_parameters (tok,endtoken,delim)
local function set_comment (idx,tok) local function set_comment (idx,tok)
local text = value_of(tok):gsub('%s*$','') local text = value_of(tok):gsub('%s*$','')
args.comments[args[idx]] = text local current_comment = args.comments[args[idx]]
if current_comment then
text = text:match("%s*%-%-+%s*(.*)")
args.comments[args[idx]] = current_comment .. " " .. text
else
args.comments[args[idx]] = text
end
end end
for i = 1,#ltl do for i = 1,#ltl do
--print('check',i,ltl[i],#ltl[i]) --print('check',i,ltl[i],#ltl[i])
local tl = ltl[i] local tl = ltl[i]
if #tl > 0 then if #tl > 0 then
if type_of(tl[1]) == 'comment' then for j = 1, #tl - 1 do
if i > 1 then set_comment(i-1,tl[1]) end if type_of(tl[j]) ~= "comment" then
if #tl > 1 then return nil, "Couldn't parse function arguments"
args:append(value_of(tl[2])) end
set_comment(i-1,tl[j])
end end
else if type_of(tl[#tl]) ~= "iden" and type_of(tl[#tl]) ~= "..." then
args:append(value_of(tl[1])) return nil, "Couldn't parse function arguments"
end end
if i == #ltl then args:append(value_of(tl[#tl]))
local last_tok = tl[#tl] if i == #ltl then
if #tl > 1 and type_of(last_tok) == 'comment' then local last_tok = tl[#tl]
set_comment(i,last_tok) if #tl > 1 and type_of(last_tok) == 'comment' then
set_comment(i,last_tok)
end
end end
end
end end
end end
if next(args.comments) then -- we had argument comments if #args == 1 or next(args.comments) then -- we had argument comments
-- but the last one may be outside the parens! (Geoff style) -- but the last one may be outside the parens! (Geoff style)
local n = #args local n = #args
if not args.comments[n] then if not args.comments[n] then
local t = {tok()} while true do
if type_of(t) == 'comment' then local t = {tok()}
set_comment(n,t) if type_of(t) == 'comment' then
set_comment(n,t)
else
break
end
end end
end end
end end

24
makefile Normal file
View File

@ -0,0 +1,24 @@
LUA= $(shell echo `which lua`)
LUA_BINDIR= $(shell echo `dirname $(LUA)`)
LUA_PREFIX= $(shell echo `dirname $(LUA_BINDIR)`)
LUA_SHAREDIR=$(LUA_PREFIX)/share/lua/5.1
ldoc:
install: install_parts
echo "lua $(LUA_SHAREDIR)/ldoc.lua \$$*" > $(LUA_BINDIR)/ldoc
chmod +x $(LUA_BINDIR)/ldoc
install_luajit: install_parts
echo "luajit $(LUA_SHAREDIR)/ldoc.lua \$$*" > $(LUA_BINDIR)/ldoc
chmod +x $(LUA_BINDIR)/ldoc
install_parts:
mkdir -p $(LUA_SHAREDIR)
cp ldoc.lua $(LUA_SHAREDIR)
cp -r ldoc $(LUA_SHAREDIR)
uninstall:
-rm $(LUA_SHAREDIR)/ldoc.lua
-rm -r $(LUA_SHAREDIR)/ldoc
-rm $(LUA_BINDIR)/ldoc