X-Git-Url: http://matita.cs.unibo.it/gitweb/?a=blobdiff_plain;f=ocaml%2Fnum.ml;h=56ae90ac24d254b9db91ee7d7dacaaffd77e483c;hb=44d012f1bf971bca4cb9380f42f8fca79d414ece;hp=69c87e046c9ab64093579be1868d8083419b30c6;hpb=d3e73f866de30503a4c44d67cdd9e8ff77c15fc3;p=fireball-separation.git diff --git a/ocaml/num.ml b/ocaml/num.ml index 69c87e0..56ae90a 100644 --- a/ocaml/num.ml +++ b/ocaml/num.ml @@ -127,7 +127,7 @@ let rec string_of_term = | `Lam _ as t -> "(" ^ string_of_term_no_pars_lam lev l t ^ ")" | `Match(t,(v,ar),bs_lift,bs,args) -> (* assert (bs_lift = lev); *) - "["^ varname lev l v ^ (if debug_display_arities then ":"^ string_of_int ar else "") ^",match " ^ string_of_term_no_pars lev l (t :> nf) ^ + "(["^ varname lev l v ^ (if debug_display_arities then ":"^ string_of_int ar else "") ^",match " ^ string_of_term_no_pars lev l (t :> nf) ^ " with " ^ String.concat " | " (List.map (fun (n,t) -> string_of_int n ^ " => " ^ string_of_term l (t :> nf)) !bs) ^ "] " ^ String.concat " " (List.map (string_of_term l) (args :> nf list)) ^ ")" and string_of_term_no_pars_app lev l = function @@ -230,12 +230,16 @@ and subst truelam delift_by_one what (with_what : nf) (where : nf) = | `N _ as x -> x | `Match(t,v,bs_lift,bs,args) -> let bs_lift = bs_lift + if delift_by_one then -1 else 0 in + (* Warning! It now applies again the substitution in branches of matches. + But careful, it does it many times, for every occurrence of + the match. This is okay because what does not occur in with_what. *) let l' = l - bs_lift in - let with_what' = lift l' with_what in + let with_what' = lift l' (with_what :> nf) in (* The following line should be the identity when delift_by_one = true because we are assuming the ts to not contain lambda-bound variables. *) bs := List.map (fun (n,t) -> n,subst truelam false what with_what' t) !bs ; - mk_match (cast_to_i_num_var (aux_i_num_var l t)) v bs_lift bs (List.map (aux l) args) + let body = cast_to_i_num_var (aux_i_num_var l t) in + mk_match body v bs_lift bs (List.map (aux l) (args :> nf list)) and aux l(*lift*) = (*function iii -> let res = match iii with*) function