Merge: tests: Test result update for `curl_http`
[nit.git] / tests / bench_complex_sort.nit
index ad72cc6..cf460cd 100644 (file)
@@ -22,62 +22,58 @@ end
 
 class A
        super Elt
-       var _a: Int
-       redef fun val1: Int do return _a
+       var a: Int
+       redef fun val1: Int do return a
 
-       init(i: Int) do _a = i
+       redef fun to_s do return "Aa{a}"
 end
 
 class Elt2
        super Elt
-       var _b: Int
-       redef fun val1: Int do return _b/2
-       redef fun val2: Int do return _b
-       init initelt2(i: Int) do _b = i
+       var b: Int
+       redef fun val1: Int do return b/2
+       redef fun val2: Int do return b
 end
 
 class B
        super Elt2
-       init(i: Int) do initelt2(i)
+       redef fun to_s do return "Bb{b}"
 end
 
 class C
        super Elt
-       var _c: Int
-       var _d: Int
-       redef fun val1: Int do return _c end
-       redef fun val2: Int do return _d end
-
-       init init2(i: Int, j: Int) do
-               _c = i
-               _d = j
-       end
+       var c: Int
+       var d: Int
+       redef fun val1: Int do return c
+       redef fun val2: Int do return d
+
+       redef fun to_s do return "Cc{c}d{d}"
 end
 
 class D
        super A
        super Elt2
-       redef fun val1: Int do return _a end
-       redef fun val2: Int do return _b end
+       redef fun val1: Int do return a
+       redef fun val2: Int do return b
 
-       init init2(i: Int, j: Int) do
-               init(i)
-               initelt2(j)
-       end
+       autoinit a=, b=
+
+       redef fun to_s do return "Da{a}b{b}"
 end
 
 class E
        super Elt2
-       redef fun val1: Int do return 5 end
+       redef fun val1: Int do return 5
 
-       init(i: Int) do initelt2(i)
+       redef fun to_s do return "Eb{b}"
 end
 
-class EltSorter
-       super AbstractSorter[Elt]
-       redef fun compare(a: Elt, b: Elt): Int
+class EltComparator
+       super Comparator
+       redef type COMPARED: Elt
+       redef fun compare(a, b)
        do
-               if _is_val1 then
+               if is_val1 then
                        return a.val1 <=> b.val1
                else
                        return a.val2 <=> b.val2
@@ -86,10 +82,10 @@ class EltSorter
        
        fun toggle
        do
-               _is_val1 = not _is_val1
+               is_val1 = not is_val1
        end
        
-       var _is_val1: Bool = false
+       var is_val1: Bool = false
 
        init do end
 end
@@ -102,15 +98,16 @@ do
        else if r == 1 then
                return new B(10.rand)
        else if r == 2 then
-               return new C.init2(10.rand, 10.rand)
+               return new C(10.rand, 10.rand)
        else if r == 3 then
-               return new D.init2(10.rand, 10.rand)
+               return new D(10.rand, 10.rand)
        else
                return new E(10.rand)
        end
 end
 
-var n = 100
+srand_from(0)
+var n = 20
 
 if not args.is_empty then
        n = args.first.to_i
@@ -121,9 +118,12 @@ for i in [0..n[ do
        array.push(generator)
 end
 
-var sorter = new EltSorter
+print array.join(", ")
+
+var comparator = new EltComparator
 for i in [0..n[ do
-       sorter.sort(array)
-       sorter.toggle
+       comparator.sort(array)
+       comparator.toggle
 end
 
+print array.join(", ")