Support used-defined keywords (in prettified code).
This commit is contained in:
parent
4ab5f07d84
commit
3313e78b44
|
@ -1275,6 +1275,9 @@ function tagged with a certain tag:
|
||||||
- `no_space_before_args` set to `true` if you do not want a space between a function's name and its arguments.
|
- `no_space_before_args` set to `true` if you do not want a space between a function's name and its arguments.
|
||||||
- `template_escape` overrides the usual '#' used for Lua code in templates.
|
- `template_escape` overrides the usual '#' used for Lua code in templates.
|
||||||
This needs to be changed if the output format is Markdown, for instance.
|
This needs to be changed if the output format is Markdown, for instance.
|
||||||
|
- `user_keywords` A list of keywords that will be marked in "prettified" code. Useful if
|
||||||
|
you want to display your own functions in a special way. Each keyword may be styled differently
|
||||||
|
(using CSS). Only works when `pretty` is set to 'lua' (the default).
|
||||||
|
|
||||||
_Available functions are:_
|
_Available functions are:_
|
||||||
|
|
||||||
|
|
4
ldoc.lua
4
ldoc.lua
|
@ -233,7 +233,7 @@ local ldoc_contents = {
|
||||||
'no_return_or_parms','no_summary','full_description','backtick_references', 'custom_see_handler',
|
'no_return_or_parms','no_summary','full_description','backtick_references', 'custom_see_handler',
|
||||||
'no_space_before_args','parse_extra','no_lua_ref','sort_modules','use_markdown_titles',
|
'no_space_before_args','parse_extra','no_lua_ref','sort_modules','use_markdown_titles',
|
||||||
'unqualified', 'custom_display_name_handler', 'kind_names', 'custom_references',
|
'unqualified', 'custom_display_name_handler', 'kind_names', 'custom_references',
|
||||||
'dont_escape_underscore','global_lookup','prettify_files','convert_opt'
|
'dont_escape_underscore','global_lookup','prettify_files','convert_opt', 'user_keywords',
|
||||||
}
|
}
|
||||||
ldoc_contents = tablex.makeset(ldoc_contents)
|
ldoc_contents = tablex.makeset(ldoc_contents)
|
||||||
|
|
||||||
|
@ -504,7 +504,7 @@ end
|
||||||
-- (this also will initialize the code prettifier used)
|
-- (this also will initialize the code prettifier used)
|
||||||
override ('format','plain')
|
override ('format','plain')
|
||||||
override 'pretty'
|
override 'pretty'
|
||||||
ldoc.markup = markup.create(ldoc, args.format,args.pretty)
|
ldoc.markup = markup.create(ldoc, args.format, args.pretty, ldoc.user_keywords)
|
||||||
|
|
||||||
------ 'Special' Project-level entities ---------------------------------------
|
------ 'Special' Project-level entities ---------------------------------------
|
||||||
-- Examples and Topics do not contain code to be processed for doc comments.
|
-- Examples and Topics do not contain code to be processed for doc comments.
|
||||||
|
|
|
@ -304,6 +304,7 @@ pre .number { color: #f8660d; }
|
||||||
pre .operator { color: #2239a8; font-weight: bold; }
|
pre .operator { color: #2239a8; font-weight: bold; }
|
||||||
pre .preprocessor, pre .prepro { color: #a33243; }
|
pre .preprocessor, pre .prepro { color: #a33243; }
|
||||||
pre .global { color: #800080; }
|
pre .global { color: #800080; }
|
||||||
|
pre .user-keyword { color: #800080; }
|
||||||
pre .prompt { color: #558817; }
|
pre .prompt { color: #558817; }
|
||||||
pre .url { color: #272fc2; text-decoration: underline; }
|
pre .url { color: #272fc2; text-decoration: underline; }
|
||||||
]==]
|
]==]
|
||||||
|
|
|
@ -312,6 +312,7 @@ pre .number { color: #f8660d; }
|
||||||
pre .operator { color: #2239a8; font-weight: bold; }
|
pre .operator { color: #2239a8; font-weight: bold; }
|
||||||
pre .preprocessor, pre .prepro { color: #a33243; }
|
pre .preprocessor, pre .prepro { color: #a33243; }
|
||||||
pre .global { color: #800080; }
|
pre .global { color: #800080; }
|
||||||
|
pre .user-keyword { color: #800080; }
|
||||||
pre .prompt { color: #558817; }
|
pre .prompt { color: #558817; }
|
||||||
pre .url { color: #272fc2; text-decoration: underline; }
|
pre .url { color: #272fc2; text-decoration: underline; }
|
||||||
]]
|
]]
|
||||||
|
|
|
@ -280,6 +280,7 @@ pre .number { color: #f8660d; }
|
||||||
pre .operator { color: #2239a8; font-weight: bold; }
|
pre .operator { color: #2239a8; font-weight: bold; }
|
||||||
pre .preprocessor, pre .prepro { color: #a33243; }
|
pre .preprocessor, pre .prepro { color: #a33243; }
|
||||||
pre .global { color: #800080; }
|
pre .global { color: #800080; }
|
||||||
|
pre .user-keyword { color: #800080; }
|
||||||
pre .prompt { color: #558817; }
|
pre .prompt { color: #558817; }
|
||||||
pre .url { color: #272fc2; text-decoration: underline; }
|
pre .url { color: #272fc2; text-decoration: underline; }
|
||||||
]==]
|
]==]
|
||||||
|
|
|
@ -303,6 +303,7 @@ pre .number { color: #f8660d; }
|
||||||
pre .operator { color: #2239a8; font-weight: bold; }
|
pre .operator { color: #2239a8; font-weight: bold; }
|
||||||
pre .preprocessor, pre .prepro { color: #a33243; }
|
pre .preprocessor, pre .prepro { color: #a33243; }
|
||||||
pre .global { color: #800080; }
|
pre .global { color: #800080; }
|
||||||
|
pre .user-keyword { color: #800080; }
|
||||||
pre .prompt { color: #558817; }
|
pre .prompt { color: #558817; }
|
||||||
pre .url { color: #272fc2; text-decoration: underline; }
|
pre .url { color: #272fc2; text-decoration: underline; }
|
||||||
]]
|
]]
|
||||||
|
|
|
@ -319,7 +319,7 @@ local function get_processor(ldoc, format)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
function markup.create (ldoc, format, pretty)
|
function markup.create (ldoc, format, pretty, user_keywords)
|
||||||
local processor
|
local processor
|
||||||
markup.plain = true
|
markup.plain = true
|
||||||
if format == 'backtick' then
|
if format == 'backtick' then
|
||||||
|
@ -329,6 +329,7 @@ function markup.create (ldoc, format, pretty)
|
||||||
backtick_references = ldoc.backtick_references
|
backtick_references = ldoc.backtick_references
|
||||||
global_context = ldoc.package and ldoc.package .. '.'
|
global_context = ldoc.package and ldoc.package .. '.'
|
||||||
prettify.set_prettifier(pretty)
|
prettify.set_prettifier(pretty)
|
||||||
|
prettify.set_user_keywords(user_keywords)
|
||||||
|
|
||||||
markup.process_reference = function(name,istype)
|
markup.process_reference = function(name,istype)
|
||||||
if local_context == 'none.' and not name:match '%.' then
|
if local_context == 'none.' and not name:match '%.' then
|
||||||
|
|
|
@ -4,9 +4,12 @@
|
||||||
-- A module reference to an example `test-fun.lua` would look like
|
-- A module reference to an example `test-fun.lua` would look like
|
||||||
-- `@{example:test-fun}`.
|
-- `@{example:test-fun}`.
|
||||||
local List = require 'pl.List'
|
local List = require 'pl.List'
|
||||||
|
local tablex = require 'pl.tablex'
|
||||||
local globals = require 'ldoc.builtin.globals'
|
local globals = require 'ldoc.builtin.globals'
|
||||||
local prettify = {}
|
local prettify = {}
|
||||||
|
|
||||||
|
local user_keywords = {}
|
||||||
|
|
||||||
local escaped_chars = {
|
local escaped_chars = {
|
||||||
['&'] = '&',
|
['&'] = '&',
|
||||||
['<'] = '<',
|
['<'] = '<',
|
||||||
|
@ -58,7 +61,9 @@ function prettify.lua (lang, fname, code, initial_lineno, pre, linenos)
|
||||||
if globals.functions[val] or globals.tables[val] then
|
if globals.functions[val] or globals.tables[val] then
|
||||||
t = 'global'
|
t = 'global'
|
||||||
end
|
end
|
||||||
if spans[t] then
|
if user_keywords[val] then
|
||||||
|
res:append(span('user-keyword keyword-' .. val,val))
|
||||||
|
elseif spans[t] then
|
||||||
if t == 'comment' or t == 'backtick' then -- may contain @{ref} or `..`
|
if t == 'comment' or t == 'backtick' then -- may contain @{ref} or `..`
|
||||||
val = prettify.resolve_inline_references(val,error_reporter)
|
val = prettify.resolve_inline_references(val,error_reporter)
|
||||||
end
|
end
|
||||||
|
@ -111,5 +116,11 @@ function prettify.set_prettifier (pretty)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
function prettify.set_user_keywords(keywords)
|
||||||
|
if keywords then
|
||||||
|
user_keywords = tablex.makeset(keywords)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
return prettify
|
return prettify
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue