]> matita.cs.unibo.it Git - helm.git/blobdiff - helm/ocaml/tactics/proofEngineTypes.ml
debian version 0.0.6-6
[helm.git] / helm / ocaml / tactics / proofEngineTypes.ml
index d668090e49e2c0f1fd2be733b3ebcbe7b491a55b..ac0713bd057dc364c44a193f71cb1b475a14e564 100644 (file)
@@ -26,7 +26,7 @@
   (**
     current proof (proof uri * metas * (in)complete proof * term to be prooved)
   *)
-type proof = UriManager.uri * Cic.metasenv * Cic.term * Cic.term
+type proof = UriManager.uri option * Cic.metasenv * Cic.term * Cic.term
   (** current goal, integer index *)
 type goal = int
 type status = proof * goal
@@ -38,9 +38,22 @@ type status = proof * goal
   (** an unfinished proof with the optional current goal *)
 type tactic = status -> proof * goal list
 
+  (** creates an opaque tactic from a status->proof*goal list function *)
+let mk_tactic t = t
+
   (** tactic failure *)
 exception Fail of string
 
+  (** 
+    calls the opaque tactic on the status, restoring the original 
+    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)
+
   (** constraint: the returned value will always be constructed by Cic.Name **)
 type mk_fresh_name_type =
  Cic.metasenv -> Cic.context -> Cic.name -> typ:Cic.term -> Cic.name