Library tactics
Require Import ssreflect ssrbool eqtype.
A slightly extended version of done using eassumption and rewriting
logical connectives
Ltac done := trivial; hnf in |- *; intros;
(
solve [
(do !
[ solve [ trivial | apply : sym_equal; trivial ]
| discriminate
| contradiction
| eassumption
| split
| rewrite ?andbT ?andbF ?orbT ?orbF
]
)
| case not_locked_false_eq_true; assumption
| match goal with
| H:~ _ |- _ => solve [ case H; trivial ]
end
]
).
Ltac bcase :=
match goal with
| [ |- context[ ?b || _ ] ] => case b ; simpl ; try done ; bcase
| [ |- context[ ?b && _ ] ] => case b ; simpl ; try done ; bcase
| [ |- context[ ?b ==> _ ] ] => case b ; simpl ; try done ; bcase
end.
Ltac bcaseHyps :=
(repeat match goal with
| [ H : is_true ?b |- _ ] => move : H ; apply/implyP
end).
Ltac bcaseH := bcaseHyps ; bcase.
Ltac rightb := apply/orP ; right.
Ltac leftb := apply/orP ; left.
Ltac splitb := apply/andP; split.
Hint Rewrite orTb orbT andTb andbT : bool.
Ltac simplb := repeat first [progress simpl; progress autorewrite with bool].
Ltac exists_ H := exists H => //=.
Ltac tsubst := move/eqP => ?; subst.
(
solve [
(do !
[ solve [ trivial | apply : sym_equal; trivial ]
| discriminate
| contradiction
| eassumption
| split
| rewrite ?andbT ?andbF ?orbT ?orbF
]
)
| case not_locked_false_eq_true; assumption
| match goal with
| H:~ _ |- _ => solve [ case H; trivial ]
end
]
).
Ltac bcase :=
match goal with
| [ |- context[ ?b || _ ] ] => case b ; simpl ; try done ; bcase
| [ |- context[ ?b && _ ] ] => case b ; simpl ; try done ; bcase
| [ |- context[ ?b ==> _ ] ] => case b ; simpl ; try done ; bcase
end.
Ltac bcaseHyps :=
(repeat match goal with
| [ H : is_true ?b |- _ ] => move : H ; apply/implyP
end).
Ltac bcaseH := bcaseHyps ; bcase.
Ltac rightb := apply/orP ; right.
Ltac leftb := apply/orP ; left.
Ltac splitb := apply/andP; split.
Hint Rewrite orTb orbT andTb andbT : bool.
Ltac simplb := repeat first [progress simpl; progress autorewrite with bool].
Ltac exists_ H := exists H => //=.
Ltac tsubst := move/eqP => ?; subst.