diff --git a/src/ast2lic.ml b/src/ast2lic.ml
index 349c6c279713f729c330f318aaa123379a4369d3..3bb4bb02342b85bac9249af9aa5a8ebe3cb8d207 100644
--- a/src/ast2lic.ml
+++ b/src/ast2lic.ml
@@ -1,4 +1,4 @@
-(* Time-stamp: <modified the 26/02/2015 (at 11:19) by Erwan Jahier> *)
+(* Time-stamp: <modified the 25/06/2015 (at 17:32) by Erwan Jahier> *)
 
 
 open Lxm
@@ -357,7 +357,7 @@ and (translate_val_exp_check  : IdSolver.t -> Lic.clock list -> UnifyClock.subst
     let s,vef = translate_val_exp id_solver s ve in
     let lxm = AstCore.lxm_of_val_exp ve in
     let lxms = List.map (fun _ -> lxm) exp_clks in
-    (*     let vef, tl   = EvalType.f id_solver vef in *)
+    (* let vef, tl   = EvalType.f id_solver vef in *)
      EvalClock.f id_solver s vef lxms exp_clks  
    
 
diff --git a/src/evalClock.ml b/src/evalClock.ml
index c916c47f80d5ace9bede4c27bda6e8e4b4de9067..fd65112a9065013e28304b1aef17381ca32bb9f5 100644
--- a/src/evalClock.ml
+++ b/src/evalClock.ml
@@ -1,4 +1,4 @@
-(* Time-stamp: <modified the 26/02/2015 (at 11:20) by Erwan Jahier> *)
+(* Time-stamp: <modified the 25/06/2015 (at 17:30) by Erwan Jahier> *)
  
   
 open AstPredef
@@ -224,13 +224,15 @@ let rec (f : IdSolver.t -> subst -> Lic.val_exp -> Lxm.t list -> Lic.clock list
     let ve, inf_clks, s = f_aux id_solver s ve in
     let s =  
       if exp_clks = [] then s else (
-        assert (List.length exp_clks = List.length inf_clks);
-        fold_left3
-          (fun s lxm eclk iclk -> UnifyClock.f s lxm eclk iclk) 
-          s 
-          lxms
-          exp_clks
-          (List.map (fun (_,clk) -> clk) inf_clks)
+        if (List.length exp_clks <> List.length inf_clks) then
+          raise (Compile_error(lxm_of_val_exp ve, "Bad arity"))
+        else
+          fold_left3
+            (fun s lxm eclk iclk -> UnifyClock.f s lxm eclk iclk) 
+            s 
+            lxms
+            exp_clks
+            (List.map (fun (_,clk) -> clk) inf_clks)
       )
     in 
     let inf_clks = List.map (fun (id,clk) -> id, apply_subst2 s clk) inf_clks in
diff --git a/test/lus2lic.sum b/test/lus2lic.sum
index f8127fda0c2b78fe62e150248630cc03aacb074b..0f87df14ddc1ce2f0b82bd6cbada42a66defa07e 100644
--- a/test/lus2lic.sum
+++ b/test/lus2lic.sum
@@ -1,6 +1,5 @@
-<<<<<<< Updated upstream
 ==> lus2lic0.sum <==
-Test Run By jahier on Tue Jun 23 17:05:08 
+Test Run By jahier on Thu Jun 25 17:33:53 
 Native configuration is x86_64-unknown-linux-gnu
 
 		=== lus2lic0 tests ===
@@ -38,6 +37,7 @@ XFAIL: Test bad programs (clock): test_lus2lic_no_node should_fail/clock/clock2.
 XFAIL: Test bad programs (clock): test_lus2lic_no_node should_fail/clock/inonout.lus
 XFAIL: Test bad programs (clock): test_lus2lic_no_node should_fail/clock/when_enum.lus
 XFAIL: Test bad programs (semantics): test_lus2lic_no_node should_fail/semantics/X1.lus
+XFAIL: Test bad programs (semantics): test_lus2lic_no_node should_fail/semantics/arity.lus
 XFAIL: Test bad programs (semantics): test_lus2lic_no_node should_fail/semantics/aux.lus
 XFAIL: Test bad programs (semantics): test_lus2lic_no_node should_fail/semantics/aux1.lus
 XFAIL: Test bad programs (semantics): test_lus2lic_no_node should_fail/semantics/bad_call01.lus
@@ -64,7 +64,7 @@ XFAIL: Test bad programs (assert): test_lus2lic_no_node should_fail/assert/lecte
 XFAIL: Test bad programs (assert): test_lus2lic_no_node should_fail/assert/s.lus
 
 ==> lus2lic1.sum <==
-Test Run By jahier on Tue Jun 23 17:05:09 
+Test Run By jahier on Thu Jun 25 17:33:54 
 Native configuration is x86_64-unknown-linux-gnu
 
 		=== lus2lic1 tests ===
@@ -399,7 +399,7 @@ PASS: gcc -o multipar.exec multipar_multipar.c multipar_multipar_loop.c
 PASS: /home/jahier/lus2lic/test/../utils/compare_exec_and_2c multipar.lus  {}
 
 ==> lus2lic2.sum <==
-Test Run By jahier on Tue Jun 23 17:05:24 
+Test Run By jahier on Thu Jun 25 17:34:09 
 Native configuration is x86_64-unknown-linux-gnu
 
 		=== lus2lic2 tests ===
@@ -733,7 +733,7 @@ PASS: gcc -o zzz2.exec zzz2_zzz2.c zzz2_zzz2_loop.c
 PASS: /home/jahier/lus2lic/test/../utils/compare_exec_and_2c zzz2.lus  {}
 
 ==> lus2lic3.sum <==
-Test Run By jahier on Tue Jun 23 17:06:08 
+Test Run By jahier on Thu Jun 25 17:34:54 
 Native configuration is x86_64-unknown-linux-gnu
 
 		=== lus2lic3 tests ===
@@ -1240,7 +1240,7 @@ PASS: ./myec2c {-o multipar.c multipar.ec}
 PASS: /home/jahier/lus2lic/test/../utils/test_lus2lic_no_node multipar.lus {}
 
 ==> lus2lic4.sum <==
-Test Run By jahier on Tue Jun 23 17:06:21 
+Test Run By jahier on Thu Jun 25 17:35:07 
 Native configuration is x86_64-unknown-linux-gnu
 
 		=== lus2lic4 tests ===
@@ -1712,7 +1712,7 @@ PASS: /home/jahier/lus2lic/test/../utils/test_lus2lic_no_node zzz2.lus {}
 		=== lus2lic0 Summary ===
 
 # of expected passes		1
-# of expected failures		51
+# of expected failures		52
 
 ==> lus2lic1.sum <==
 
@@ -1741,18 +1741,3 @@ PASS: /home/jahier/lus2lic/test/../utils/test_lus2lic_no_node zzz2.lus {}
 
 # of expected passes		453
 # of unexpected failures	4
-===============================
-# Total number of failures: 18
-lus2lic0.log:testcase ./lus2lic.tests/test0.exp completed in 1 seconds
-lus2lic1.log:testcase ./lus2lic.tests/test1.exp completed in 15 seconds
-lus2lic2.log:testcase ./lus2lic.tests/test2.exp completed in 44 seconds
-lus2lic3.log:testcase ./lus2lic.tests/test3.exp completed in 13 seconds
-lus2lic4.log:testcase ./lus2lic.tests/test4.exp completed in 46 seconds
-* Ref time: 
-0.04user 0.02system 1:59.60elapsed 0%CPU (0avgtext+0avgdata 5064maxresident)k
-96inputs+0outputs (0major+5518minor)pagefaults 0swaps
-* Quick time (-j 4):
-0.03user 0.03system 0:51.33elapsed 0%CPU (0avgtext+0avgdata 5108maxresident)k
-32inputs+0outputs (0major+5566minor)pagefaults 0swaps
-=======
->>>>>>> Stashed changes
diff --git a/test/lus2lic.time b/test/lus2lic.time
index 1f7e54689310be777b9ce71e453b5af6c96b4bab..24e6a1d3aaa012a48dcd73d8104951c1882dd915 100644
--- a/test/lus2lic.time
+++ b/test/lus2lic.time
@@ -1,11 +1,11 @@
 lus2lic0.log:testcase ./lus2lic.tests/test0.exp completed in 1 seconds
-lus2lic1.log:testcase ./lus2lic.tests/test1.exp completed in 15 seconds
-lus2lic2.log:testcase ./lus2lic.tests/test2.exp completed in 44 seconds
+lus2lic1.log:testcase ./lus2lic.tests/test1.exp completed in 14 seconds
+lus2lic2.log:testcase ./lus2lic.tests/test2.exp completed in 45 seconds
 lus2lic3.log:testcase ./lus2lic.tests/test3.exp completed in 13 seconds
-lus2lic4.log:testcase ./lus2lic.tests/test4.exp completed in 46 seconds
+lus2lic4.log:testcase ./lus2lic.tests/test4.exp completed in 49 seconds
 * Ref time: 
-0.04user 0.02system 1:59.60elapsed 0%CPU (0avgtext+0avgdata 5064maxresident)k
-96inputs+0outputs (0major+5518minor)pagefaults 0swaps
+0.05user 0.02system 2:02.40elapsed 0%CPU (0avgtext+0avgdata 5068maxresident)k
+64inputs+0outputs (0major+5545minor)pagefaults 0swaps
 * Quick time (-j 4):
-0.03user 0.03system 0:51.33elapsed 0%CPU (0avgtext+0avgdata 5108maxresident)k
-32inputs+0outputs (0major+5566minor)pagefaults 0swaps
+0.04user 0.02system 0:58.63elapsed 0%CPU (0avgtext+0avgdata 5084maxresident)k
+0inputs+0outputs (0major+5570minor)pagefaults 0swaps
diff --git a/test/should_fail/semantics/arity.lus b/test/should_fail/semantics/arity.lus
new file mode 100644
index 0000000000000000000000000000000000000000..5127f5eab7925e0db98f46be37de390b95bd286d
--- /dev/null
+++ b/test/should_fail/semantics/arity.lus
@@ -0,0 +1,9 @@
+node arity(a,b:int) returns (x,y: int);
+let
+	x,y = myplus(a,b); -- bad arity!
+tel
+
+node myplus(a,b:int) returns (x: int);
+let
+	x = a+b;
+tel
diff --git a/test/should_work/poussoir.lus b/test/should_work/poussoir.lus
index e689ade3ad9ded4fe2b55c3d32513ba346b2eaa0..ea4b6ced20c7eb66fa7442a109862eff64778f73 100644
--- a/test/should_work/poussoir.lus
+++ b/test/should_work/poussoir.lus
@@ -1,18 +1,14 @@
 node TWO_STATES(set,reset,init:bool) returns (state:bool);
 let
-	state = init -> if set and not pre(state) then true
-						else if reset and pre(state) then false
-						else pre(state);
+ state = init -> if set and not pre(state) then true
+      else if reset and pre(state) then false else pre(state);
 tel
-
 node ONE_BUTTON(change,init: bool) returns (state:bool);
 let
-	state = init -> if change then not pre(state) else pre(state);
+ state = init -> if change then not pre(state) else pre(state);
 tel
-
-
 node poussoir (e3,init:bool) returns (s3, s4:bool);
 let
-	s3 = TWO_STATES(e3,e3,init);
-	s4 = ONE_BUTTON(e3,init);
+ s3 = TWO_STATES(e3,e3,init);
+ s4 = ONE_BUTTON(e3,init);
 tel
diff --git a/test/site.exp b/test/site.exp
index 658237439bb664b3bd93f7d59ca22aa0f3bb0410..7d6d8fa954b8f0828ec637be5940a6c5d6955038 100644
--- a/test/site.exp
+++ b/test/site.exp
@@ -1,4 +1,4 @@
-# Time-stamp: <modified the 03/09/2014 (at 17:09) by Erwan Jahier> 
+# Time-stamp: <modified the 01/07/2015 (at 14:24) by Erwan Jahier> 
 # 
 # (nonreg-)test harness main file
 
@@ -49,6 +49,10 @@ proc should_work { test_name command_line args } {
             set failed 1
             exp_continue
         }
+        "kcg name clash" {
+            set failed 0
+            exp_continue
+        }
         "ERROR" {
             set failed 1
             exp_continue