X-Git-Url: https://git.archive.openwrt.org/?p=project%2Fluci.git;a=blobdiff_plain;f=libs%2Fuvldoc%2Fluasrc%2Fuvldoc%2Frenderer.lua;fp=libs%2Fuvldoc%2Fluasrc%2Fuvldoc%2Frenderer.lua;h=f881032c20bf44c22f44122eff3879e62adafe9e;hp=5fce5ec51cbe9dad2f825b42022341905cbebce2;hb=52c9166a7abe947662fe03d1051e2d05e64f4f18;hpb=a4a77446e90d848293baaccf33de6499ffc8aa19 diff --git a/libs/uvldoc/luasrc/uvldoc/renderer.lua b/libs/uvldoc/luasrc/uvldoc/renderer.lua index 5fce5ec51..f881032c2 100644 --- a/libs/uvldoc/luasrc/uvldoc/renderer.lua +++ b/libs/uvldoc/luasrc/uvldoc/renderer.lua @@ -20,7 +20,8 @@ local util = require "luci.util" local ltn12 = require "luci.ltn12" local template = require "luci.template" -local ipairs = ipairs +local ipairs, getfenv, pairs, require = ipairs, getfenv, pairs, require +local luci = luci module "luci.uvldoc.renderer" @@ -52,11 +53,19 @@ function Generator.make(self) template.compiler_mode = "memory" template.viewdir = self.sourcedir + template.context.viewns = { + include = function(name) template.Template(name):render(getfenv(2)) end, + luci = luci, + require = require + } self:_make_index() - for scheme, file in util.kspairs(self.schemes) do + for scheme, package in pairs(self.schemes) do self:_make_package(scheme) + for type, section in pairs(package.sections) do + self:_make_section(scheme, type) + end end end @@ -78,6 +87,18 @@ function Generator._make_package(self, scheme) sink() end +function Generator._make_section(self, scheme, section) + local t = template.Template("section.xml") + local sink = ltn12.sink.file( + io.open(self.output .. "/" .. self:_section_filename(scheme, section), "w") + ) + local pkg = self.schemes[scheme] + t:render({self = self, package = pkg, + scheme = scheme, type=section, section=pkg.sections[section], + write = sink}) + sink() +end + function Generator._index_filename(self) return "index%s" % self.extension end @@ -85,3 +106,7 @@ end function Generator._scheme_filename(self, scheme) return "scheme.%s%s" % {scheme, self.extension} end + +function Generator._section_filename(self, scheme, section) + return "section.%s.%s%s" % {scheme, section, self.extension} +end