]> matita.cs.unibo.it Git - helm.git/blobdiff - helm/ocaml/tactics/proofEngineTypes.ml
implemented lazy disambiguation of tactics arguments, when those
[helm.git] / helm / ocaml / tactics / proofEngineTypes.ml
index b4992aca3496420c9f1277a50b9065aed36985c5..2e25e4a057389f7149bfa64334bcbefdca615d84 100644 (file)
@@ -56,6 +56,32 @@ type tactic = status -> proof * goal list
   (** creates an opaque tactic from a status->proof*goal list function *)
 let mk_tactic t = t
 
+type reduction = Cic.context -> Cic.term -> Cic.term
+
+type lazy_term =
+  Cic.context -> Cic.metasenv -> CicUniv.universe_graph ->
+    Cic.term * Cic.metasenv * CicUniv.universe_graph
+
+let const_lazy_term t =
+  (fun _ metasenv ugraph -> t, metasenv, ugraph)
+
+type lazy_reduction =
+  Cic.context -> Cic.metasenv -> CicUniv.universe_graph ->
+    reduction * Cic.metasenv * CicUniv.universe_graph
+
+let const_lazy_reduction red =
+  (fun _ metasenv ugraph -> red, metasenv, ugraph)
+
+type pattern = lazy_term option * (string * Cic.term) list * Cic.term
+
+let conclusion_pattern t =
+  let t' = 
+    match t with
+    | None -> None
+    | Some t -> Some (fun _ m u -> t, m, u)
+  in
+  t',[],Cic.Implicit (Some `Hole)
+
   (** tactic failure *)
 exception Fail of string
 
@@ -64,12 +90,7 @@ exception Fail of string
     universe graph if the tactic Fails
   *)
 let apply_tactic t status = 
-  let saved_univ = CicUniv.get_working() in
-  try 
-    t status
-  with Fail s ->
-    CicUniv.set_working saved_univ;
-    raise (Fail s)
+  t status
 
   (** constraint: the returned value will always be constructed by Cic.Name **)
 type mk_fresh_name_type =