]> matita.cs.unibo.it Git - helm.git/blobdiff - helm/software/components/tactics/declarative.ml
Inverters/Inversion:
[helm.git] / helm / software / components / tactics / declarative.ml
index 15fdbf7254c02ebecfc1744d3e26479d5207806a..139dcb1f8757995a9a39fc8df047338885708e80 100644 (file)
 
 type just = [ `Term of Cic.term | `Auto of Auto.auto_params ]
 
-let mk_just ~dbd ~universe =
+let mk_just ~dbd ~automation_cache =
  function
-    `Auto params -> Tactics.auto ~dbd ~params ~universe
+    `Auto (l,params) -> 
+       Tactics.auto ~dbd 
+       ~params:(l,("skip_trie_filtering","1")::(*("skip_context","1")::*)params) ~automation_cache
   | `Term t -> Tactics.apply t
 ;;
 
@@ -53,8 +55,8 @@ let suppose t id ty =
       (fun _ metasenv ugraph -> ty,metasenv,ugraph))
 ;;
 
-let by_just_we_proved ~dbd ~universe just ty id ty' =
- let just = mk_just ~dbd ~universe just in
+let by_just_we_proved ~dbd ~automation_cache just ty id ty' =
+ let just = mk_just ~dbd ~automation_cache just in
   match id with
      None ->
       (match ty' with
@@ -87,8 +89,8 @@ let by_just_we_proved ~dbd ~universe just ty id ty' =
         ~continuations:[ Tacticals.id_tac ; continuation ]
 ;;
 
-let bydone ~dbd ~universe just =
- mk_just ~dbd ~universe just
+let bydone ~dbd ~automation_cache just =
+ mk_just ~dbd ~automation_cache just
 ;;
 
 let we_need_to_prove t id ty =
@@ -126,7 +128,7 @@ let we_need_to_prove t id ty =
       ProofEngineTypes.mk_tactic aux
 ;;
 
-let existselim ~dbd ~universe just id1 t1 id2 t2 =
+let existselim ~dbd ~automation_cache just id1 t1 id2 t2 =
  let aux (proof, goal) = 
   let (n,metasenv,_subst,bo,ty,attrs) = proof in
   let metano,context,_ = CicUtil.lookup_meta goal metasenv in
@@ -142,13 +144,13 @@ let existselim ~dbd ~universe just id1 t1 id2 t2 =
             fun _ _ _  ~typ ->
              incr i;
              if !i = 1 then Cic.Name id1 else Cic.Name id2) ;
-       (mk_just ~dbd ~universe just)
+       (mk_just ~dbd ~automation_cache just)
      ]) (proof', goal)
  in
   ProofEngineTypes.mk_tactic aux
 ;;
 
-let andelim ~dbd ~universe just id1 t1 id2 t2 = 
+let andelim ~dbd ~automation_cache just id1 t1 id2 t2 = 
    Tacticals.thens
     ~start:(Tactics.cut (Cic.Appl [Cic.MutInd (UriManager.uri_of_string "cic:/matita/logic/connectives/And.ind", 0, []); t1 ; t2]))
     ~continuations:
@@ -158,10 +160,10 @@ let andelim ~dbd ~universe just id1 t1 id2 t2 =
             fun _ _ _  ~typ ->
              incr i;
              if !i = 1 then Cic.Name id1 else Cic.Name id2) ;
-       (mk_just ~dbd ~universe just) ]
+       (mk_just ~dbd ~automation_cache just) ]
 ;;
 
-let rewritingstep ~dbd ~universe lhs rhs just last_step =
+let rewritingstep ~dbd ~automation_cache lhs rhs just last_step =
  let aux ((proof,goal) as status) =
   let (curi,metasenv,_subst,proofbo,proofty, attrs) = proof in
   let _,context,gty = CicUtil.lookup_meta goal metasenv in
@@ -187,14 +189,16 @@ let rewritingstep ~dbd ~universe lhs rhs just last_step =
          else params
         in
          if params = params' then
-          Tactics.auto ~dbd ~params:(univ, params) ~universe
+          Tactics.auto ~dbd ~params:(univ, params) ~automation_cache
          else
           Tacticals.first
-           [Tactics.auto ~dbd ~params:(univ, params) ~universe ;
-            Tactics.auto ~dbd ~params:(univ, params') ~universe]
+           [Tactics.auto ~dbd ~params:(univ, params) ~automation_cache ;
+            Tactics.auto ~dbd ~params:(univ, params') ~automation_cache]
     | `Term just -> Tactics.apply just
     | `SolveWith term -> 
-         Tactics.solve_rewrite ~universe ~params:([term],["steps","1"]) ()
+                    Tactics.demodulate ~automation_cache ~dbd
+                    ~params:([term],
+                      ["all","1";"steps","1"; "use_context","false"])
     | `Proof ->
         Tacticals.id_tac
   in
@@ -272,7 +276,7 @@ let we_proceed_by_cases_on t pat =
 ;;
 
 let we_proceed_by_induction_on t pat =
- let pattern = None, [], Some pat in
+(*  let pattern = None, [], Some pat in *)
  Tactics.elim_intros ~depth:0 (*~pattern*) t
 ;;