LDoc2tl/ldoc/prettify.lua

66 lines
1.7 KiB
Lua
Raw Normal View History

2011-07-10 19:10:53 +02:00
-- Making Lua source code look pretty.
-- A simple scanner based prettifier, which scans comments for @{ref} and code
-- for known modules and functions.
-- A module reference to an example `test-fun.lua` would look like
-- `@{example:test-fun}`.
local List = require 'pl.List'
2011-07-10 19:10:53 +02:00
local lexer = require 'ldoc.lexer'
local globals = require 'ldoc.builtin.globals'
local tnext = lexer.skipws
2011-07-10 19:10:53 +02:00
local prettify = {}
local escaped_chars = {
['&'] = '&',
['<'] = '&lt;',
['>'] = '&gt;',
}
local escape_pat = '[&<>]'
local function escape(str)
return (str:gsub(escape_pat,escaped_chars))
end
local function span(t,val)
return ('<span class="%s">%s</span>'):format(t,val)
end
local spans = {keyword=true,number=true,string=true,comment=true,global=true}
2011-07-10 19:10:53 +02:00
2011-09-19 14:22:18 +02:00
function prettify.lua (fname, code, initial_lineno)
2011-07-10 19:10:53 +02:00
local res = List()
res:append '<pre>\n'
2012-03-23 13:21:43 +01:00
initial_lineno = initial_lineno or 0
2011-07-10 19:10:53 +02:00
local tok = lexer.lua(code,{},{})
local error_reporter = {
warning = function (self,msg)
2011-09-19 14:22:18 +02:00
io.stderr:write(fname..':'..tok:lineno()+initial_lineno..': '..msg,'\n')
end
}
2011-07-10 19:10:53 +02:00
local t,val = tok()
2011-07-11 09:34:18 +02:00
if not t then return nil,"empty file" end
2011-07-10 19:10:53 +02:00
while t do
val = escape(val)
if globals.functions[val] or globals.tables[val] then
t = 'global'
end
2011-07-10 19:10:53 +02:00
if spans[t] then
if t == 'comment' then -- may contain @{ref}
val = prettify.resolve_inline_references(val,error_reporter)
end
2011-07-10 19:10:53 +02:00
res:append(span(t,val))
else
res:append(val)
end
t,val = tok()
end
local last = res[#res]
if last:match '\n$' then
res[#res] = last:gsub('\n+','')
end
2011-07-10 19:10:53 +02:00
return res:join ()
end
return prettify