Merge: Nitgs optims
[nit.git] / src / metrics / generate_hierarchies.nit
index e1fdda3..455ed83 100644 (file)
@@ -34,7 +34,7 @@ private class GenerateHierarchyPhase
        do
                if not toolcontext.opt_generate_hyperdoc.value and not toolcontext.opt_all.value then return
                var model = toolcontext.modelbuilder.model
-               generate_module_hierarchy(toolcontext, model)
+               generate_module_hierarchy(toolcontext, given_mmodules)
                generate_classdef_hierarchy(toolcontext, model)
                generate_class_hierarchy(toolcontext, mainmodule)
        end
@@ -43,12 +43,18 @@ end
 # Create a dot file representing the module hierarchy of a model.
 # Importation relation is represented with arrow
 # Nesting relation is represented with nested boxes
-fun generate_module_hierarchy(toolcontext: ToolContext, model: Model)
+fun generate_module_hierarchy(toolcontext: ToolContext, given_mmodules: Collection[MModule])
 do
+       var model = given_mmodules.first.model
        var dot = new MProjectDot(model)
 
+       # Collect requested projects
+       for m in given_mmodules do
+               var g = m.mgroup
+               if g == null then continue
+               dot.mprojects.add(g.mproject)
+       end
        var projectpath = toolcontext.output_dir.join_path("project_hierarchy.dot")
-       dot.mprojects.add(model.mprojects.first)
        print "generating {projectpath}"
        dot.write_to_file(projectpath)
 
@@ -61,7 +67,7 @@ end
 # Create a dot file representing the class hierarchy of a model.
 fun generate_class_hierarchy(toolcontext: ToolContext, mmodule: MModule)
 do
-       var buf = new Buffer
+       var buf = new FlatBuffer
        buf.append("digraph \{\n")
        buf.append("node [shape=box];\n")
        buf.append("rankdir=BT;\n")
@@ -82,7 +88,7 @@ end
 # For a simple user of the model, the classdef hierarchy is not really usefull, it is more an internal thing.
 fun generate_classdef_hierarchy(toolcontext: ToolContext, model: Model)
 do
-       var buf = new Buffer
+       var buf = new FlatBuffer
        buf.append("digraph \{\n")
        buf.append("node [shape=box];\n")
        buf.append("rankdir=BT;\n")