doc(@supermodule;ldoc.ltp): Find inherited members

This commit uses the `@supermodule` tag to recursively find all the
properties from supermodules and add them to the current module
documentation.
This commit is contained in:
Aire-One 2021-03-15 18:32:47 +01:00
parent 4dd689f181
commit b82d2a690f
1 changed files with 59 additions and 5 deletions

View File

@ -66,6 +66,57 @@
# if not found then curr = nil end # if not found then curr = nil end
# end # end
# --------- merge modules content with supermodules -------------
# local all_module_kinds = {}
# if module then
# for kind,items in module.kinds() do
# local myitems = {}
# for item in items() do
# myitems[#myitems + 1] = item
# end
# all_module_kinds[#all_module_kinds + 1] = { kind = kind, items = myitems }
# end
# local filtered_kinds = { "Constructors", "Static module functions",
# "Functions", "Methods", "lib.gears.object.properties Functions" }
# for supermodule in iter(hierarchy) do
# for kind,items in supermodule.kinds() do
# local ignored = false
# for _,filtered in ldoc.pairs(filtered_kinds) do
# if kind == filtered then
# ignored = true
# break
# end
# end
# if not ignored then
# local curr_kind = nil
# for k in iter(all_module_kinds) do
# if k.kind == kind then
# curr_kind = k
# break
# end
# end
# if not curr_kind then
# curr_kind = { kind = kind, items = {} }
# all_module_kinds[#all_module_kinds + 1] = curr_kind
# end
# for item in items() do
# local tobeadded = true
# for i in iter(curr_kind.items) do
# if item == i then
# tobeadded = false
# break
# end
# end
# if tobeadded then
# item.inherited = true -- force inherited status
# curr_kind.items[#curr_kind.items + 1] = item
# end
# end
# end
# end
# end
# end
<!-- Menu --> <!-- Menu -->
<div id="navigation"> <div id="navigation">
@ -82,7 +133,8 @@
# if module and not ldoc.no_summary and #module.items > 0 then # if module and not ldoc.no_summary and #module.items > 0 then
<h2>Contents</h2> <h2>Contents</h2>
<ul> <ul>
# for kind,items in module.kinds() do # for k in iter(all_module_kinds) do
# local kind = k.kind
# if not kind:match("^ldoc_skip") then # if not kind:match("^ldoc_skip") then
<li><a href="#$(no_spaces(kind))">$(kind)</a></li> <li><a href="#$(no_spaces(kind))">$(kind)</a></li>
# end # end
@ -196,7 +248,8 @@
# if not ldoc.no_summary then # if not ldoc.no_summary then
# -- bang out the tables of item types for this module (e.g Functions, Tables, etc) # -- bang out the tables of item types for this module (e.g Functions, Tables, etc)
# local last_kind = "" # local last_kind = ""
# for kind,items in module.kinds() do # for k in iter(all_module_kinds) do
# local kind = k.kind
# if not kind:match("^ldoc_skip") then # if not kind:match("^ldoc_skip") then
# if last_kind ~= "" then # if last_kind ~= "" then
</table> </table>
@ -204,7 +257,7 @@
<h2><a href="#$(no_spaces(kind))">$(kind)</a></h2> <h2><a href="#$(no_spaces(kind))">$(kind)</a></h2>
<table class="function_list"> <table class="function_list">
# end # end
# for item in items() do # for item in iter(k.items) do
# local dn = display_name(item) # local dn = display_name(item)
# if item.sanitize_type then item.sanitize_type(item, ldoc) end # if item.sanitize_type then item.sanitize_type(item, ldoc) end
<tr> <tr>
@ -240,7 +293,8 @@
# --- function parameters or table fields. # --- function parameters or table fields.
# local show_return = not ldoc.no_return_or_parms # local show_return = not ldoc.no_return_or_parms
# local show_parms, last_kind = show_return, "" # local show_parms, last_kind = show_return, ""
# for kind, items in module.kinds() do # for k in iter(all_module_kinds) do
# local kind = k.kind
# local kitem = module.kinds:get_item(kind) # local kitem = module.kinds:get_item(kind)
# local has_description = kitem and ldoc.descript(kitem) ~= "" # local has_description = kitem and ldoc.descript(kitem) ~= ""
# if not kind:match("^ldoc_skip") then # if not kind:match("^ldoc_skip") then
@ -264,7 +318,7 @@
# if not kind:match("^ldoc_skip") then # if not kind:match("^ldoc_skip") then
<dl class="function"> <dl class="function">
# end # end
# for item in items() do # for item in iter(k.items) do
<dt> <dt>
<a name = "$(item.name)"></a> <a name = "$(item.name)"></a>
<strong>$(display_name(item))</strong> <strong>$(display_name(item))</strong>