X-Git-Url: http://nitlanguage.org diff --git a/src/metrics/mmodules_metrics.nit b/src/metrics/mmodules_metrics.nit index ca87fdf..b740912 100644 --- a/src/metrics/mmodules_metrics.nit +++ b/src/metrics/mmodules_metrics.nit @@ -17,12 +17,12 @@ # Collect common metrics about modules module mmodules_metrics -import model import metrics_base -import phase -import frontend +import model::model_collect redef class ToolContext + + # MModules related metrics phase var mmodules_metrics_phase: Phase = new MModulesMetricsPhase(self, null) end @@ -36,18 +36,27 @@ private class MModulesMetricsPhase var out = "{toolcontext.opt_dir.value or else "metrics"}/mmodules" out.mkdir + var model = toolcontext.modelbuilder.model + print toolcontext.format_h1("\n# MModules metrics") var metrics = new MetricSet - metrics.register(new MNOA, new MNOP, new MNOC, new MNOD, new MDIT) - metrics.register(new MNBI, new MNBR, new MNBCC, new MNBAC, new MNBIC) + metrics.register(new MNOA(model, mainmodule)) + metrics.register(new MNOP(model, mainmodule)) + metrics.register(new MNOC(model, mainmodule)) + metrics.register(new MNOD(model, mainmodule)) + metrics.register(new MDIT(model, mainmodule)) + metrics.register(new MNBI(model, mainmodule)) + metrics.register(new MNBR(model, mainmodule)) + metrics.register(new MNBCC(model, mainmodule)) + metrics.register(new MNBAC(model, mainmodule)) + metrics.register(new MNBIC(model, mainmodule)) - var model = toolcontext.modelbuilder.model var mmodules = new HashSet[MModule] - for mproject in model.mprojects do + for mpackage in model.mpackages do - print toolcontext.format_h2("\n ## project {mproject}") - for mgroup in mproject.mgroups do + print toolcontext.format_h2("\n ## package {mpackage}") + for mgroup in mpackage.mgroups do if mgroup.mmodules.is_empty then continue # Scalar metrics @@ -56,7 +65,7 @@ private class MModulesMetricsPhase metrics.clear metrics.collect(new HashSet[MModule].from(mgroup.mmodules)) metrics.to_console(1, not toolcontext.opt_nocolors.value) - if csv then metrics.to_csv.save("{out}/{mgroup}.csv") + if csv then metrics.to_csv.write_to_file("{out}/{mgroup}.csv") end end if not mmodules.is_empty then @@ -65,15 +74,24 @@ private class MModulesMetricsPhase metrics.clear metrics.collect(mmodules) metrics.to_console(1, not toolcontext.opt_nocolors.value) - if csv then metrics.to_csv.save("{out}/summary.csv") + if csv then metrics.to_csv.write_to_file("{out}/summary.csv") end end end # A metric about MModule -interface MModuleMetric +abstract class MModuleMetric super Metric redef type ELM: MModule + + # Model view used to collect and filter entities + var model: Model + + # Mainmodule used for linearization + var mainmodule: MModule + + # Filter to apply on model if any + var filter: nullable ModelFilter end # Module Metric: Number of Ancestors @@ -146,6 +164,25 @@ class MDIT end end +# Module Metric: Number of Accessible Definitions (of all kind) +# +# count all mclasses accessible by the module +class MNBD + super MModuleMetric + super IntMetric + redef fun name do return "mnbd" + redef fun desc do return "number of definition accessibles in module" + + redef fun collect(mmodules) do + for mmodule in mmodules do + values[mmodule] = 0 + for a in mmodule.collect_ancestors(mainmodule, filter) do + values[mmodule] += a.intro_mclasses.length + end + end + end +end + # Module Metric: Number of Introduction (of all kind) # # count all mclasses introduced by the module @@ -253,5 +290,3 @@ class MNBEC end end end - -