diff options
| author | Hugo Herbelin | 2014-11-03 15:00:32 +0100 |
|---|---|---|
| committer | Hugo Herbelin | 2014-11-03 15:27:04 +0100 |
| commit | 7af811e5100839484cbed0126b5c37a972487ec3 (patch) | |
| tree | 4a377904b91723805366bfc89bdcf2954037cbe5 | |
| parent | 7d01d46ce0f9267446b474755762db1ccca5fd78 (diff) | |
Fix to 844431761 on improving elimination with indices, getting rid of
intrusive residual local definitions + more conservative strategy for
which variables are not generalized (point 2 of 4df1ddc6d6bd07073).
| -rw-r--r-- | tactics/tactics.ml | 31 | ||||
| -rw-r--r-- | test-suite/success/destruct.v | 10 |
2 files changed, 24 insertions, 17 deletions
diff --git a/tactics/tactics.ml b/tactics/tactics.ml index 9776784b56..5918cf997c 100644 --- a/tactics/tactics.ml +++ b/tactics/tactics.ml @@ -2661,30 +2661,29 @@ let atomize_param_of_ind (indref,nparams,_) hyp0 = let reduce_to_quantified_ref = Tacmach.New.pf_apply reduce_to_quantified_ref gl in let typ0 = reduce_to_quantified_ref indref tmptyp0 in let prods, indtyp = decompose_prod typ0 in - let ind,argl = decompose_app indtyp in + let hd,argl = decompose_app indtyp in let params = List.firstn nparams argl in (* le gl est important pour ne pas préévaluer *) let rec atomize_one i args = - if not (Int.equal i nparams) then + if Int.equal i nparams then + let t = applist (hd, params @ List.map mkVar args) in + Proofview.V82.tactic + (change_in_hyp None (fun _ sigma -> sigma, t) (hyp0,InHypTypeOnly)) + else let c = List.nth argl (i-1) in match kind_of_term c with - | Var id when not (List.exists (occur_var env id) args) -> - atomize_one (i-1) (mkVar id :: args) + | Var id when not (List.mem id args) -> + atomize_one (i-1) (id::args) | _ -> let id = match kind_of_term c with | Var id -> id | _ -> - let type_of = Tacmach.New.pf_type_of gl in - id_of_name_using_hdchar (Global.env()) (type_of c) Anonymous in - let x = new_fresh_id [] id gl in - Tacticals.New.tclTHENLIST [ - (letin_tac None (Name x) c None allHypsAndConcl); - (atomize_one (i-1) (mkVar x :: args)) - ] - else - Proofview.V82.tactic - (change_in_hyp None (fun _ sigma -> sigma, applist (ind,params@args)) - (hyp0,InHypTypeOnly)) + let type_of = Tacmach.New.pf_type_of gl in + id_of_name_using_hdchar (Global.env()) (type_of c) Anonymous in + let x = fresh_id_in_env args id env in + Tacticals.New.tclTHEN + (letin_tac None (Name x) c None allHypsAndConcl) + (atomize_one (i-1) (x::args)) in atomize_one (List.length argl) [] end @@ -3824,7 +3823,7 @@ let pose_induction_arg_then clear_flag isrec with_evars match res with | None -> (* pattern not found *) - let fixedvars = collect_vars c in + let fixedvars = (* heuristic *) match kind_of_term (fst (decompose_app c)) with Var id -> Id.Set.singleton id | _ -> Id.Set.empty in let with_eq = Option.map (fun eq -> (false,eq)) eqname in (* we restart using bindings after having tried type-class resolution etc. on the term given by the user *) diff --git a/test-suite/success/destruct.v b/test-suite/success/destruct.v index cca54bf1c4..0faaa275f2 100644 --- a/test-suite/success/destruct.v +++ b/test-suite/success/destruct.v @@ -341,7 +341,7 @@ Abort. Goal forall x y e (t:x=y) (z:x=y -> IND y x e), e = e. intros. destruct (z t). -change (x=y) in t. (* Generalization not made *) +change (0=0) in t. (* Generalization made *) Abort. Goal forall x y e (t:x=y) (z:x=y -> IND y x e), e = e /\ z t = z t. @@ -361,3 +361,11 @@ Goal (forall P:Prop, (nat->nat) -> P) -> forall h:nat->nat->nat, h 0 0 = h 1 0. intros. induction (h 1) using H. Qed. + +(* Check blocking generalization is not too strong (failed at some time) *) + +Goal (E -> 0=1) -> 1=0 -> True. +intros. +destruct (H _). +change (0=0) in H0. (* Check generalization on H0 was made *) +Abort. |
