summaryrefslogtreecommitdiff
path: root/tactics/auto.ml
diff options
context:
space:
mode:
authorGravatar Samuel Mimram <samuel.mimram@ens-lyon.org>2005-01-31 14:34:14 +0000
committerGravatar Samuel Mimram <samuel.mimram@ens-lyon.org>2005-01-31 14:34:14 +0000
commit6497f27021fec4e01f2182014f2bb1989b4707f9 (patch)
tree473be7e63895a42966970ab6a70998113bc1bd59 /tactics/auto.ml
parent6b649aba925b6f7462da07599fe67ebb12a3460e (diff)
Imported Upstream version 8.0pl2upstream/8.0pl2
Diffstat (limited to 'tactics/auto.ml')
-rw-r--r--tactics/auto.ml70
1 files changed, 30 insertions, 40 deletions
diff --git a/tactics/auto.ml b/tactics/auto.ml
index d087420a..b530178e 100644
--- a/tactics/auto.ml
+++ b/tactics/auto.ml
@@ -6,7 +6,7 @@
(* * GNU Lesser General Public License Version 2.1 *)
(************************************************************************)
-(* $Id: auto.ml,v 1.63.2.1 2004/07/16 19:30:51 herbelin Exp $ *)
+(* $Id: auto.ml,v 1.63.2.2 2004/12/06 11:25:21 herbelin Exp $ *)
open Pp
open Util
@@ -199,8 +199,12 @@ let make_apply_entry env sigma (eapply,verbose) name (c,cty) =
in
if eapply & (nmiss <> 0) then begin
if verbose then
+ if !Options.v7 then
warn (str "the hint: EApply " ++ prterm c ++
- str " will only be used by EAuto");
+ str " will only be used by EAuto")
+ else
+ warn (str "the hint: eapply " ++ prterm c ++
+ str " will only be used by eauto");
(hd,
{ hname = name;
pri = nb_hyp cty + nmiss;
@@ -281,40 +285,8 @@ let add_hint dbname hintlist =
let cache_autohint (_,(local,name,hintlist)) = add_hint name hintlist
-(* let recalc_hints hintlist =
- let env = Global.env() and sigma = Evd.empty in
- let recalc_hint ((_,data) as hint) =
- match data.code with
- | Res_pf (c,_) ->
- let c' = Term.subst_mps subst c in
- if c==c' then hint else
- make_apply_entry env sigma (false,false)
- data.hname (c', type_of env sigma c')
- | ERes_pf (c,_) ->
- let c' = Term.subst_mps subst c in
- if c==c' then hint else
- make_apply_entry env sigma (true,false)
- data.hname (c', type_of env sigma c')
- | Give_exact c ->
- let c' = Term.subst_mps subst c in
- if c==c' then hint else
- make_exact_entry data.hname (c',type_of env sigma c')
- | Res_pf_THEN_trivial_fail (c,_) ->
- let c' = Term.subst_mps subst c in
- if c==c' then hint else
- make_trivial env sigma (data.hname,c')
- | Unfold_nth ref ->
- let ref' = subst_global subst ref in
- if ref==ref' then hint else
- make_unfold (data.hname,ref')
- | Extern _ ->
- anomaly "Extern hints cannot be substituted!!!"
- in
- list_smartmap recalc_hint hintlist
-*)
-
let forward_subst_tactic =
- ref (fun _ -> failwith "subst_tactic is not installed for Auto")
+ ref (fun _ -> failwith "subst_tactic is not installed for auto")
let set_extern_subst_tactic f = forward_subst_tactic := f
@@ -430,7 +402,7 @@ let add_trivials env sigma l local dbnames =
dbnames
let forward_intern_tac =
- ref (fun _ -> failwith "intern_tac is not installed for Auto")
+ ref (fun _ -> failwith "intern_tac is not installed for auto")
let set_extern_intern_tac f = forward_intern_tac := f
@@ -492,7 +464,9 @@ let add_hints local dbnames0 h =
(* Functions for printing the hints *)
(**************************************************************************)
-let fmt_autotactic = function
+let fmt_autotactic =
+ if !Options.v7 then
+ function
| Res_pf (c,clenv) -> (str"Apply " ++ prterm c)
| ERes_pf (c,clenv) -> (str"EApply " ++ prterm c)
| Give_exact c -> (str"Exact " ++ prterm c)
@@ -500,6 +474,16 @@ let fmt_autotactic = function
(str"Apply " ++ prterm c ++ str" ; Trivial")
| Unfold_nth c -> (str"Unfold " ++ pr_global c)
| Extern tac -> (str "Extern " ++ Pptactic.pr_glob_tactic tac)
+ else
+ function
+ | Res_pf (c,clenv) -> (str"apply " ++ prterm c)
+ | ERes_pf (c,clenv) -> (str"eapply " ++ prterm c)
+ | Give_exact c -> (str"exact " ++ prterm c)
+ | Res_pf_THEN_trivial_fail (c,clenv) ->
+ (str"apply " ++ prterm c ++ str" ; trivial")
+ | Unfold_nth c -> (str"unfold " ++ pr_global c)
+ | Extern tac ->
+ (str "(external) " ++ Pptacticnew.pr_glob_tactic (Global.env()) tac)
let fmt_hint v =
(fmt_autotactic v.code ++ str"(" ++ int v.pri ++ str")" ++ spc ())
@@ -631,7 +615,7 @@ si après Intros la conclusion matche le pattern.
(* conclPattern doit échouer avec error car il est rattraper par tclFIRST *)
let forward_interp_tactic =
- ref (fun _ -> failwith "interp_tactic is not installed for Auto")
+ ref (fun _ -> failwith "interp_tactic is not installed for auto")
let set_extern_interp f = forward_interp_tactic := f
@@ -700,7 +684,10 @@ let trivial dbnames gl =
try
searchtable_map x
with Not_found ->
- error ("Trivial: "^x^": No such Hint database"))
+ if !Options.v7 then
+ error ("Trivial: "^x^": No such Hint database")
+ else
+ error ("trivial: "^x^": No such Hint database"))
("core"::dbnames)
in
tclTRY (trivial_fail_db db_list (make_local_hint_db gl)) gl
@@ -799,7 +786,10 @@ let auto n dbnames gl =
try
searchtable_map x
with Not_found ->
- error ("Auto: "^x^": No such Hint database"))
+ if !Options.v7 then
+ error ("Auto: "^x^": No such Hint database")
+ else
+ error ("auto: "^x^": No such Hint database"))
("core"::dbnames)
in
let hyps = pf_hyps gl in