blob: fab6f7758b75a1b6e4c02f931ff7065e3212888b (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
|
(************************************************************************)
(* v * The Coq Proof Assistant / The Coq Development Team *)
(* <O___,, * CNRS-Ecole Polytechnique-INRIA Futurs-Universite Paris Sud *)
(* \VV/ **************************************************************)
(* // * This file is distributed under the terms of the *)
(* * GNU Lesser General Public License Version 2.1 *)
(************************************************************************)
(* $Id: CCSolve.v,v 1.4.2.1 2004/07/16 19:29:58 herbelin Exp $ *)
Ltac CCsolve :=
repeat
match goal with
| H:?X1 |- ?X2 =>
let Heq := fresh "Heq" in
(assert (Heq : X2 = X1); [ congruence | rewrite Heq; exact H ])
| H:?X1,G:(?X2 -> ?X3) |- _ =>
let Heq := fresh "Heq" in
(assert (Heq : X2 = X1);
[ congruence
| rewrite Heq in G; generalize (G H); clear G; intro G ])
end.
|