37a56beffe50936c975cbcc7d3c9086998f7386b
1 # This file is part of NIT ( http://www.nitlanguage.org ).
3 # Copyright 2012 Jean Privat <jean@pryen.org>
5 # Licensed under the Apache License, Version 2.0 (the "License");
6 # you may not use this file except in compliance with the License.
7 # You may obtain a copy of the License at
9 # http://www.apache.org/licenses/LICENSE-2.0
11 # Unless required by applicable law or agreed to in writing, software
12 # distributed under the License is distributed on an "AS IS" BASIS,
13 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 # See the License for the specific language governing permissions and
15 # limitations under the License.
17 # Helpers for various statistics tools.
22 redef class ToolContext
25 var opt_nullables
= new OptionBool("Compute metrics on nullables send", "--nullables")
27 var opt_static_types
= new OptionBool("Compute explicit static types metrics", "--static-types")
29 var opt_tables
= new OptionBool("Compute tables metrics", "--tables")
31 var opt_rta
= new OptionBool("Compute RTA metrics", "--rta")
33 var opt_generate_hyperdoc
= new OptionBool("Generate Hyperdoc", "--generate_hyperdoc")
35 var opt_dir
= new OptionString("Directory where some statistics files are generated", "-d", "--dir")
36 var output_dir
: String = "."
41 self.option_context
.add_option
(opt_nullables
)
42 self.option_context
.add_option
(opt_static_types
)
43 self.option_context
.add_option
(opt_tables
)
44 self.option_context
.add_option
(opt_rta
)
45 self.option_context
.add_option
(opt_generate_hyperdoc
)
46 self.option_context
.add_option
(opt_dir
)
49 redef fun process_options
52 var val
= self.opt_dir
.value
54 val
= val
.simplify_path
61 # A counter counts occurence of things
62 # Use this instead of a HashMap[E, Int]
63 class Counter[E
: Object]
64 # Total number of counted occurences
67 private var map
= new HashMap[E
, Int]
69 # The number of counted occurences of `e'
73 if map
.has_key
(e
) then return map
[e
]
77 # Count one more occurence of `e'
80 self.map
[e
] = self[e
] + 1
84 # Return an array of elements sorted by occurences
87 var res
= map
.keys
.to_a
88 var sorter
= new CounterSorter[E
](self)
90 #res.sort !cmp a, b = map[a] <=> map[b]
95 private class CounterSorter[E
: Object]
96 super AbstractSorter[E
]
97 var counter
: Counter[E
]
98 redef fun compare
(a
,b
) do return self.counter
.map
[a
] <=> self.counter
.map
[b
]
101 # Helper function to display n/d and handle division by 0
102 fun div
(n
: Int, d
: Int): String
104 if d
== 0 then return "na"
105 return ((100*n
/d
).to_f
/100.0).to_precision
(2)