1 # This file is part of NIT ( http://www.nitlanguage.org ).
3 # This file is free software, which comes along with NIT. This software is
4 # distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
5 # without even the implied warranty of MERCHANTABILITY or FITNESS FOR A
6 # PARTICULAR PURPOSE. You can modify it is you want, provided this header
7 # is kept unaltered, and a notification of the changes is added.
8 # You are allowed to redistribute it and sell it, alone or is a part of
11 # Benches on the indexed access operation on variants of Text
17 private fun bench_string
(loops
: Int, strlen
: Int)
19 var a
= prepare_string
(strlen
)
20 var maxl
= a
.length
- 1
28 private fun bench_buffer
(loops
: Int, strlen
: Int)
30 var x
= prepare_buffer
(strlen
)
31 var maxl
= x
.length
- 1
39 var opts
= new OptionContext
40 var mode
= new OptionEnum(["string", "buffer"], "Mode", -1, "-m")
41 var loops
= new OptionInt("Number of loops to be done", -1, "--loops")
42 var strlen
= new OptionInt("Length of the base string", -1, "--strlen")
43 opts
.add_option
(mode
, loops
, strlen
)
47 if loops
.value
== -1 or strlen
.value
== -1 then
52 var modval
= mode
.value
56 bench_string
(loops
.value
, strlen
.value
)
57 else if modval
== 1 then
58 bench_buffer
(loops
.value
, strlen
.value
)