import web_base
import highlight
import uml
+import model::model_index
redef class APIRouter
redef init do
use("/search", new APISearch(config))
use("/random", new APIRandom(config))
use("/entity/:id", new APIEntity(config))
+ use("/entity/:id/doc", new APIEntityDoc(config))
use("/code/:id", new APIEntityCode(config))
use("/uml/:id", new APIEntityUML(config))
use("/linearization/:id", new APIEntityLinearization(config))
var k = req.string_arg("k")
var mentities = new Array[MEntity]
if k == "package" then
- for mentity in view.mpackages do mentities.add mentity
+ for mentity in config.view.mpackages do mentities.add mentity
else if k == "group" then
- for mentity in view.mgroups do mentities.add mentity
+ for mentity in config.view.mgroups do mentities.add mentity
else if k == "module" then
- for mentity in view.mmodules do mentities.add mentity
+ for mentity in config.view.mmodules do mentities.add mentity
else if k == "class" then
- for mentity in view.mclasses do mentities.add mentity
+ for mentity in config.view.mclasses do mentities.add mentity
else if k == "classdef" then
- for mentity in view.mclassdefs do mentities.add mentity
+ for mentity in config.view.mclassdefs do mentities.add mentity
else if k == "property" then
- for mentity in view.mproperties do mentities.add mentity
+ for mentity in config.view.mproperties do mentities.add mentity
else if k == "propdef" then
- for mentity in view.mpropdefs do mentities.add mentity
+ for mentity in config.view.mpropdefs do mentities.add mentity
else
- for mentity in view.mentities do mentities.add mentity
+ for mentity in config.view.mentities do mentities.add mentity
end
return mentities
end
+ # Sort mentities by lexicographic order
+ #
+ # TODO choose order from request
+ fun sort_mentities(req: HttpRequest, mentities: Array[MEntity]) : Array[MEntity] do
+ var sorted = mentities.to_a
+ var sorter = new MEntityNameSorter
+ sorter.sort(sorted)
+ return sorted
+ end
+
# Limit mentities depending on the `n` parameter.
fun limit_mentities(req: HttpRequest, mentities: Array[MEntity]): Array[MEntity] do
var n = req.int_arg("n")
redef fun get(req, res) do
var mentities = list_mentities(req)
+ mentities = sort_mentities(req, mentities)
mentities = limit_mentities(req, mentities)
res.json new JsonArray.from(mentities)
end
class APISearch
super APIList
- redef fun list_mentities(req) do
+ redef fun get(req, res) do
var q = req.string_arg("q")
- var mentities = new Array[MEntity]
- if q == null then return mentities
- for mentity in view.mentities do
- if mentity.name.has_prefix(q) then mentities.add mentity
+ if q == null then
+ res.json new JsonArray
+ return
end
- return mentities
+ var n = req.int_arg("n")
+ res.json new JsonArray.from(config.view.find(q, n))
end
end
redef fun get(req, res) do
var mentities = list_mentities(req)
- mentities = limit_mentities(req, mentities)
mentities = randomize_mentities(req, mentities)
+ mentities = limit_mentities(req, mentities)
res.json new JsonArray.from(mentities)
end
end
redef fun get(req, res) do
var mentity = mentity_from_uri(req, res)
if mentity == null then return
- res.json mentity.api_json(self)
+ res.raw_json mentity.to_full_json
+ end
+end
+
+# Return the full MDoc of a MEntity.
+#
+# Example: `GET /entity/core::Array/doc`
+class APIEntityDoc
+ super APIHandler
+
+ redef fun get(req, res) do
+ var mentity = mentity_from_uri(req, res)
+ if mentity == null then return
+
+ var obj = new JsonObject
+ var mdoc = mentity.mdoc_or_fallback
+ if mdoc != null then
+ obj["documentation"] = mdoc.html_documentation.write_to_string
+ obj["location"] = mdoc.location
+ end
+ res.json obj
end
end
redef fun get(req, res) do
var mentity = mentity_from_uri(req, res)
if mentity == null then return
- res.json mentity.hierarchy_poset(view)[mentity]
+ res.json mentity.hierarchy_poset(config.view)[mentity]
end
end
return
end
var mentities = new JsonArray
- for e in lin do mentities.add e.full_json
+ for e in lin do mentities.add e
res.json mentities
end
end
#
# Example: `GET /defs/core::Array`
class APIEntityDefs
- super APIHandler
+ super APIList
redef fun get(req, res) do
var mentity = mentity_from_uri(req, res)
if mentity == null then return
- var arr = new JsonArray
- if mentity isa MModule then
- for mclassdef in mentity.mclassdefs do arr.add mclassdef
+ var mentities: Array[MEntity]
+ if mentity isa MPackage then
+ mentities = mentity.mgroups.to_a
+ else if mentity isa MGroup then
+ mentities = new Array[MEntity]
+ mentities.add_all mentity.in_nesting.direct_smallers
+ mentities.add_all mentity.mmodules
+ else if mentity isa MModule then
+ mentities = mentity.mclassdefs
else if mentity isa MClass then
- for mclassdef in mentity.mclassdefs do arr.add mclassdef
+ mentities = mentity.mclassdefs
else if mentity isa MClassDef then
- for mpropdef in mentity.mpropdefs do arr.add mpropdef
+ mentities = mentity.mpropdefs
else if mentity isa MProperty then
- for mpropdef in mentity.mpropdefs do arr.add mpropdef
+ mentities = mentity.mpropdefs
else
res.api_error(404, "No definition list for mentity `{mentity.full_name}`")
return
end
- res.json arr
+ mentities = sort_mentities(req, mentities)
+ mentities = limit_mentities(req, mentities)
+ res.json new JsonArray.from(mentities)
end
end
var dot
if mentity isa MClassDef then mentity = mentity.mclass
if mentity isa MClass then
- var uml = new UMLModel(view, config.mainmodule)
+ var uml = new UMLModel(config.view, config.mainmodule)
dot = uml.generate_class_uml.write_to_string
else if mentity isa MModule then
- var uml = new UMLModel(view, mentity)
+ var uml = new UMLModel(config.view, mentity)
dot = uml.generate_package_uml.write_to_string
else
res.api_error(404, "No UML for mentity `{mentity.full_name}`")