{{{name}}}
-""" + res.add """"""
+
var mdoc = mpackage.mdoc_or_fallback
- if mdoc != null then res.add mdoc.html_documentation
+ if mdoc == null then
+ res.add """
`.
# `id_prefix` is used to give an id to the `
{{{name}}}
""" + else + res.add """ +
+
+"""
+ res.add mdoc.html_documentation
+ end
res.add "{{{name}}} -
+Content
" var ot = new OrderedTree[MConcern] @@ -250,12 +268,12 @@ redef class Catalog-
"""
- var tryit = mpackage.metadata("upstream.tryit")
+ var tryit = mpackage.metadata.metadata("upstream.tryit")
if tryit != null then
var e = tryit.html_escape
res.add "
- Trynit! \n" end - var apk = mpackage.metadata("upstream.apk") + var apk = mpackage.metadata.metadata("upstream.apk") if apk != null then var e = apk.html_escape res.add "
- Android apk \n" @@ -263,16 +281,15 @@ redef class Catalog res.add """
- \n"""
- var homepage = mpackage.metadata("upstream.homepage")
+ var homepage = mpackage.metadata.metadata("upstream.homepage")
if homepage != null then
var e = homepage.html_escape
res.add "
- {e} \n" end - var maintainer = mpackage.metadata("package.maintainer") - if maintainer != null then - add_contrib(maintainer, mpackage, res) + for maintainer in mpackage.metadata.maintainers do + res.add "
- {maintainer.to_html} " end - var license = mpackage.metadata("package.license") + var license = mpackage.metadata.metadata("package.license") if license != null then var e = license.html_escape res.add "
- {e} license \n" @@ -280,22 +297,22 @@ redef class Catalog res.add "
Source Code
\n- \n"
- var browse = mpackage.metadata("upstream.browse")
+ var browse = mpackage.metadata.metadata("upstream.browse")
if browse != null then
var e = browse.html_escape
res.add "
- {e} \n" end - var git = mpackage.metadata("upstream.git") + var git = mpackage.metadata.metadata("upstream.git") if git != null then var e = git.html_escape res.add "
- {e} \n" end - var last_date = mpackage.last_date + var last_date = mpackage.metadata.last_date if last_date != null then var e = last_date.html_escape res.add "
- most recent commit: {e} \n" end - var first_date = mpackage.first_date + var first_date = mpackage.metadata.first_date if first_date != null then var e = first_date.html_escape res.add "
- oldest commit: {e} \n" @@ -306,16 +323,25 @@ redef class Catalog end res.add "
Quality
\n- \n"
+ var errors = errors[mpackage]
+ if errors > 0 then
+ res.add "
- {errors} errors \n" + end + res.add "
- {warnings[mpackage]} warnings ({warnings_per_kloc[mpackage]}/kloc) \n" + res.add "
- {documentation_score[mpackage]}% documented \n" + res.add "
Tags
\n" var ts2 = new Array[String] - for t in mpackage.tags do + for t in mpackage.metadata.tags do t = t.html_escape ts2.add "{t}" end res.add_list(ts2, ", ", ", ") - if deps.has(mpackage) then - var reqs = deps[mpackage].greaters.to_a + if deps.vertices.has(mpackage) then + var reqs = deps.get_all_successors(mpackage) reqs.remove(mpackage) alpha_comparator.sort(reqs) res.add "Requirements
\n" @@ -324,7 +350,7 @@ redef class Catalog else var list = new Array[String] for r in reqs do - var direct = deps.has_direct_edge(mpackage, r) + var direct = deps.has_arc(mpackage, r) var s = "" if direct then s += "" s += r.to_s @@ -335,7 +361,7 @@ redef class Catalog res.add_list(list, ", ", " and ") end - reqs = deps[mpackage].smallers.to_a + reqs = deps.get_all_predecessors(mpackage) reqs.remove(mpackage) alpha_comparator.sort(reqs) res.add "Clients
\n" @@ -344,7 +370,7 @@ redef class Catalog else var list = new Array[String] for r in reqs do - var direct = deps.has_direct_edge(r, mpackage) + var direct = deps.has_arc(r, mpackage) var s = "" if direct then s += "" s += r.to_s @@ -356,11 +382,11 @@ redef class Catalog end end - var contributors = mpackage.contributors + var contributors = mpackage.metadata.contributors if not contributors.is_empty then res.add "Contributors
\n- "
for c in contributors do
- add_contrib(c, mpackage, res)
+ res.add "
- {c.to_html} " end res.add "
`.
# `id_prefix` is used to give an id to the `` element.
- fun list_by(map: MultiHashMap[String, MPackage], id_prefix: String): Template
+ fun list_by(map: MultiHashMap[Object, MPackage], id_prefix: String): Template
do
var res = new Template
var keys = map.keys.to_a
alpha_comparator.sort(keys)
- var list = [for x in keys do "{x.html_escape}"]
+ var list = [for x in keys do "{x.to_s.html_escape}"]
res.add_list(list, ", ", " and ")
for k in keys do
var projs = map[k].to_a
alpha_comparator.sort(projs)
- var e = k.html_escape
+ var e = k.to_s.html_escape
res.add "{e} ({projs.length})
\n\n"
for p in projs do
res.add "- "
@@ -454,7 +480,7 @@ redef class Catalog
res.add "
name \n"
res.add "maint \n"
res.add "contrib \n"
- if deps.not_empty then
+ if deps.vertices.not_empty then
res.add "reqs \n"
res.add "direct
reqs \n"
res.add "clients \n"
@@ -465,25 +491,33 @@ redef class Catalog
res.add "methods \n"
res.add "lines \n"
res.add "score \n"
+ res.add "errors \n"
+ res.add "warnings \n"
+ res.add "w/kloc \n"
+ res.add "doc \n"
res.add ""
for p in mpackages do
res.add ""
res.add "{p.name} "
var maint = "?"
- if p.maintainers.not_empty then maint = p.maintainers.first
+ if p.metadata.maintainers.not_empty then maint = p.metadata.maintainers.first.name.html_escape
res.add "{maint} "
- res.add "{p.contributors.length} "
- if deps.not_empty then
- res.add "{deps[p].greaters.length-1} "
- res.add "{deps[p].direct_greaters.length} "
- res.add "{deps[p].smallers.length-1} "
- res.add "{deps[p].direct_smallers.length} "
+ res.add "{p.metadata.contributors.length} "
+ if deps.vertices.not_empty then
+ res.add "{deps.get_all_successors(p).length-1} "
+ res.add "{deps.successors(p).length} "
+ res.add "{deps.get_all_predecessors(p).length-1} "
+ res.add "{deps.predecessors(p).length} "
end
res.add "{mmodules[p]} "
res.add "{mclasses[p]} "
res.add "{mmethods[p]} "
res.add "{loc[p]} "
res.add "{score[p]} "
+ res.add "{errors[p]} "
+ res.add "{warnings[p]} "
+ res.add "{warnings_per_kloc[p]} "
+ res.add "{documentation_score[p]} "
res.add " \n"
end
res.add "\n"
@@ -498,6 +532,24 @@ redef class Catalog
var piwik_site_id: Int = 1
end
+redef class Person
+ redef fun to_html do
+ var res = ""
+ var e = name.html_escape
+ var page = self.page
+ if page != null then
+ res += ""
+ end
+ var gravatar = self.gravatar
+ if gravatar != null then
+ res += " "
+ end
+ res += e
+ if page != null then res += ""
+ return res
+ end
+end
+
var model = new Model
var tc = new ToolContext
@@ -535,32 +587,22 @@ end
# Get files or groups
var args = tc.option_context.rest
+var mmodules
if opt_no_parse.value then
- modelbuilder.scan_full(args)
+ mmodules = modelbuilder.scan_full(args)
else
- modelbuilder.parse_full(args)
+ mmodules = modelbuilder.parse_full(args)
end
+var mpackages = modelbuilder.model.mpackage_importation_graph.vertices
# Scan packages and compute information
-for p in model.mpackages do
+for p in mpackages do
var g = p.root
assert g != null
modelbuilder.scan_group(g)
-
- # Load the module to process importation information
- if opt_no_parse.value then continue
-
- catalog.deps.add_node(p)
- for gg in p.mgroups do for m in gg.mmodules do
- for im in m.in_importation.direct_greaters do
- var ip = im.mpackage
- if ip == null or ip == p then continue
- catalog.deps.add_edge(p, ip)
- end
- end
end
-if not opt_no_git.value then for p in model.mpackages do
+if not opt_no_git.value then for p in mpackages do
catalog.git_info(p)
end
@@ -571,6 +613,9 @@ end
var out = opt_dir.value or else "catalog.out"
(out/"p").mkdir
+(out/"res").mkdir
+
+catalog.outdir = out
# Generate the css (hard coded)
var css = """
@@ -674,11 +719,14 @@ css.write_to_file(out/"style.css")
# PAGES
-for p in model.mpackages do
+for p in mpackages do
# print p
var f = "p/{p.name}.html"
catalog.package_page(p)
catalog.generate_page(p).write_to_file(out/f)
+ # copy ini
+ var ini = p.ini
+ if ini != null then ini.write_to_file(out/"p/{p.name}.ini")
end
# INDEX
@@ -694,11 +742,11 @@ index.add """
index.add "Highlighted Packages
\n"
index.add catalog.list_best(catalog.score)
-if catalog.deps.not_empty then
+if catalog.deps.vertices.not_empty then
index.add "Most Required
\n"
var reqs = new Counter[MPackage]
- for p in model.mpackages do
- reqs[p] = catalog.deps[p].smallers.length - 1
+ for p in mpackages do
+ reqs[p] = catalog.deps.get_all_successors(p).length - 1
end
index.add catalog.list_best(reqs)
end
@@ -714,7 +762,7 @@ index.add """
Stats
-- {{{model.mpackages.length}}} packages
+- {{{mpackages.length}}} packages
- {{{catalog.maint2proj.length}}} maintainers
- {{{catalog.contrib2proj.length}}} contributors
- {{{catalog.tag2proj.length}}} tags
@@ -746,6 +794,6 @@ page = catalog.new_page("")
page.more_head.add "Projets of Nit "
page.add """\nPeople of Nit
\n"""
page.add "Table of Projets
\n"
-page.add catalog.table_packages(model.mpackages)
+page.add catalog.table_packages(mpackages.to_a)
page.add "\n"
page.write_to_file(out/"table.html")
{e} ({projs.length})
\n- \n"
for p in projs do
res.add "
- "
@@ -454,7 +480,7 @@ redef class Catalog
res.add "
name \n" res.add "maint \n" res.add "contrib \n" - if deps.not_empty then + if deps.vertices.not_empty then res.add "reqs \n" res.add "direct \n" res.add "
reqsclients \n" @@ -465,25 +491,33 @@ redef class Catalog res.add "methods \n" res.add "lines \n" res.add "score \n" + res.add "errors \n" + res.add "warnings \n" + res.add "w/kloc \n" + res.add "doc \n" res.add "" for p in mpackages do res.add "" res.add " \n" end res.add "\n" @@ -498,6 +532,24 @@ redef class Catalog var piwik_site_id: Int = 1 end +redef class Person + redef fun to_html do + var res = "" + var e = name.html_escape + var page = self.page + if page != null then + res += "" + end + var gravatar = self.gravatar + if gravatar != null then + res += " " + end + res += e + if page != null then res += "" + return res + end +end + var model = new Model var tc = new ToolContext @@ -535,32 +587,22 @@ end # Get files or groups var args = tc.option_context.rest +var mmodules if opt_no_parse.value then - modelbuilder.scan_full(args) + mmodules = modelbuilder.scan_full(args) else - modelbuilder.parse_full(args) + mmodules = modelbuilder.parse_full(args) end +var mpackages = modelbuilder.model.mpackage_importation_graph.vertices # Scan packages and compute information -for p in model.mpackages do +for p in mpackages do var g = p.root assert g != null modelbuilder.scan_group(g) - - # Load the module to process importation information - if opt_no_parse.value then continue - - catalog.deps.add_node(p) - for gg in p.mgroups do for m in gg.mmodules do - for im in m.in_importation.direct_greaters do - var ip = im.mpackage - if ip == null or ip == p then continue - catalog.deps.add_edge(p, ip) - end - end end -if not opt_no_git.value then for p in model.mpackages do +if not opt_no_git.value then for p in mpackages do catalog.git_info(p) end @@ -571,6 +613,9 @@ end var out = opt_dir.value or else "catalog.out" (out/"p").mkdir +(out/"res").mkdir + +catalog.outdir = out # Generate the css (hard coded) var css = """ @@ -674,11 +719,14 @@ css.write_to_file(out/"style.css") # PAGES -for p in model.mpackages do +for p in mpackages do # print p var f = "p/{p.name}.html" catalog.package_page(p) catalog.generate_page(p).write_to_file(out/f) + # copy ini + var ini = p.ini + if ini != null then ini.write_to_file(out/"p/{p.name}.ini") end # INDEX @@ -694,11 +742,11 @@ index.add """ index.add "{p.name} " var maint = "?" - if p.maintainers.not_empty then maint = p.maintainers.first + if p.metadata.maintainers.not_empty then maint = p.metadata.maintainers.first.name.html_escape res.add "{maint} " - res.add "{p.contributors.length} " - if deps.not_empty then - res.add "{deps[p].greaters.length-1} " - res.add "{deps[p].direct_greaters.length} " - res.add "{deps[p].smallers.length-1} " - res.add "{deps[p].direct_smallers.length} " + res.add "{p.metadata.contributors.length} " + if deps.vertices.not_empty then + res.add "{deps.get_all_successors(p).length-1} " + res.add "{deps.successors(p).length} " + res.add "{deps.get_all_predecessors(p).length-1} " + res.add "{deps.predecessors(p).length} " end res.add "{mmodules[p]} " res.add "{mclasses[p]} " res.add "{mmethods[p]} " res.add "{loc[p]} " res.add "{score[p]} " + res.add "{errors[p]} " + res.add "{warnings[p]} " + res.add "{warnings_per_kloc[p]} " + res.add "{documentation_score[p]} " res.add "Highlighted Packages
\n" index.add catalog.list_best(catalog.score) -if catalog.deps.not_empty then +if catalog.deps.vertices.not_empty then index.add "Most Required
\n" var reqs = new Counter[MPackage] - for p in model.mpackages do - reqs[p] = catalog.deps[p].smallers.length - 1 + for p in mpackages do + reqs[p] = catalog.deps.get_all_successors(p).length - 1 end index.add catalog.list_best(reqs) end @@ -714,7 +762,7 @@ index.add """Stats
-
-
- {{{model.mpackages.length}}} packages +
- {{{mpackages.length}}} packages
- {{{catalog.maint2proj.length}}} maintainers
- {{{catalog.contrib2proj.length}}} contributors
- {{{catalog.tag2proj.length}}} tags @@ -746,6 +794,6 @@ page = catalog.new_page("") page.more_head.add "
Projets of Nit " page.add """\n\n" page.write_to_file(out/"table.html")People of Nit
\n""" page.add "Table of Projets
\n" -page.add catalog.table_packages(model.mpackages) +page.add catalog.table_packages(mpackages.to_a) page.add "