diff options
| author | Gabriel Kerneis | 2014-02-07 18:13:16 +0000 |
|---|---|---|
| committer | Gabriel Kerneis | 2014-02-07 18:13:16 +0000 |
| commit | 54005e457eb069330219dbe2cbd0a903ffbdb517 (patch) | |
| tree | 701d09b2986e6c23e1d5a1b17c98ae0766bafc40 /src/lem_interp/interp_lib.lem | |
| parent | dcbc80a3419a828da8cdb6250ecb52f52a72a28b (diff) | |
Fix a few stupid bugs
Diffstat (limited to 'src/lem_interp/interp_lib.lem')
| -rw-r--r-- | src/lem_interp/interp_lib.lem | 10 |
1 files changed, 6 insertions, 4 deletions
diff --git a/src/lem_interp/interp_lib.lem b/src/lem_interp/interp_lib.lem index f6485666..158b9fa5 100644 --- a/src/lem_interp/interp_lib.lem +++ b/src/lem_interp/interp_lib.lem @@ -20,16 +20,18 @@ let neq = compose neg eq ;; let add (V_tuple [V_lit(L_num x); V_lit(L_num y)]) = V_lit(L_num (x+y)) ;; let rec vec_concat (V_tuple args) = match args with - | [V_vector 0 true l; V_vector 0 true l'] -> V_vector 0 true (l ++ l') + | [V_vector n d l; V_vector n' d' l'] -> + (* XXX d = d' ? droping n' ? *) + V_vector n d (l ++ l') | [V_lit l; x] -> vec_concat (V_tuple [litV_to_vec l; x]) | [x; V_lit l] -> vec_concat (V_tuple [x; litV_to_vec l]) - end;; + end ;; let function_map = [ ("add", add); ("add_infix", add); - ("=", eq); - (":", vec_concat); + ("eq", eq); + ("vec_concat", vec_concat); ("is_one", is_one); ] ;; |
