Support used-defined keywords (in prettified code).

This commit is contained in:
Mooffie 2014-12-15 10:02:33 +02:00
parent 4ab5f07d84
commit 3313e78b44
8 changed files with 23 additions and 4 deletions

View File

@ -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:_

View File

@ -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.

View File

@ -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; }
]==] ]==]

View File

@ -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; }
]] ]]

View File

@ -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; }
]==] ]==]

View File

@ -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; }
]] ]]

View File

@ -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

View File

@ -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 = {
['&'] = '&', ['&'] = '&',
['<'] = '&lt;', ['<'] = '&lt;',
@ -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