X-Git-Url: http://matita.cs.unibo.it/gitweb/?a=blobdiff_plain;f=helm%2Focaml%2Ftactics%2FproofEngineHelpers.ml;h=9f7fb42f4945a547d839878f158a3b8d3e8f8ca8;hb=8b55faddb06e3c4b0a13839210bb49170939b33e;hp=51405f5fdfa7269f58c3b780b16484eb7b67e85d;hpb=5fbca6bb29378a846f12759d52a5fb9641f63377;p=helm.git diff --git a/helm/ocaml/tactics/proofEngineHelpers.ml b/helm/ocaml/tactics/proofEngineHelpers.ml index 51405f5fd..9f7fb42f4 100644 --- a/helm/ocaml/tactics/proofEngineHelpers.ml +++ b/helm/ocaml/tactics/proofEngineHelpers.ml @@ -23,7 +23,7 @@ * http://cs.unibo.it/helm/. *) -exception Bad_pattern of string +exception Bad_pattern of string Lazy.t let new_meta_of_proof ~proof:(_, metasenv, _, _) = CicMkImplicit.new_meta metasenv [] @@ -231,7 +231,7 @@ let select_in_term ~metasenv ~context ~ugraph ~term ~pattern:(wanted,where) = try List.map2 f l1 l2 with - | Invalid_argument _ -> raise (Bad_pattern error_msg) + | Invalid_argument _ -> raise (Bad_pattern (lazy error_msg)) in let rec aux context where term = match (where, term) with @@ -292,9 +292,9 @@ let select_in_term ~metasenv ~context ~ugraph ~term ~pattern:(wanted,where) = funs1 funs2) | x,y -> raise (Bad_pattern - (Printf.sprintf "Pattern %s versus term %s" + (lazy (Printf.sprintf "Pattern %s versus term %s" (CicPp.ppterm x) - (CicPp.ppterm y))) + (CicPp.ppterm y)))) and auxs context terms1 terms2 = (* as aux for list of terms *) List.concat (map2 "wrong number of arguments in application" (fun t1 t2 -> aux context t1 t2) terms1 terms2) @@ -455,7 +455,7 @@ let pattern_of ?(equality=(==)) ~term terms = in snd (aux term) -exception Fail of string +exception Fail of string Lazy.t (** select metasenv conjecture pattern * select all subterms of [conjecture] matching [pattern]. @@ -678,6 +678,6 @@ let lookup_type metasenv context hyp = | Some (Cic.Name name, Cic.Def (u, _)) :: tail when name = hyp -> p, fst (CicTypeChecker.type_of_aux' metasenv tail u CicUniv.empty_ugraph) | _ :: tail -> aux (succ p) tail - | [] -> raise (ProofEngineTypes.Fail "lookup_type: not premise in the current goal") + | [] -> raise (ProofEngineTypes.Fail (lazy "lookup_type: not premise in the current goal")) in aux 1 context