diff options
author | Jason Gross <jgross@mit.edu> | 2017-01-17 18:29:44 -0500 |
---|---|---|
committer | Jason Gross <jgross@mit.edu> | 2017-01-17 18:29:44 -0500 |
commit | 2b663b207ae295f9d2fe7c67b93e65c8a452050b (patch) | |
tree | 26f1e9ea509b5d33eb87a690eab1bf0421ef55d0 /src/Util/Tactics/SplitInContext.v | |
parent | 0a8a60958f5ad312e7e5ab596a1f9f56694987f2 (diff) |
More fine-grained util tactic files
Also, add [split_and]
Diffstat (limited to 'src/Util/Tactics/SplitInContext.v')
-rw-r--r-- | src/Util/Tactics/SplitInContext.v | 22 |
1 files changed, 22 insertions, 0 deletions
diff --git a/src/Util/Tactics/SplitInContext.v b/src/Util/Tactics/SplitInContext.v new file mode 100644 index 000000000..c2bf364a0 --- /dev/null +++ b/src/Util/Tactics/SplitInContext.v @@ -0,0 +1,22 @@ +Require Export Crypto.Util.FixCoqMistakes. + +(* Coq's build in tactics don't work so well with things like [iff] + so split them up into multiple hypotheses *) +Ltac split_in_context_by ident funl funr tac := + repeat match goal with + | [ H : context p [ident] |- _ ] => + let H0 := context p[funl] in let H0' := eval simpl in H0 in assert H0' by (tac H); + let H1 := context p[funr] in let H1' := eval simpl in H1 in assert H1' by (tac H); + clear H + end. +Ltac split_in_context ident funl funr := + split_in_context_by ident funl funr ltac:(fun H => apply H). + +Ltac split_iff := split_in_context iff (fun a b : Prop => a -> b) (fun a b : Prop => b -> a). + +Ltac split_and' := + repeat match goal with + | [ H : ?a /\ ?b |- _ ] => let H0 := fresh in let H1 := fresh in + assert (H0 := fst H); assert (H1 := snd H); clear H + end. +Ltac split_and := split_and'; split_in_context and (fun a b : Type => a) (fun a b : Type => b). |