From e181217f5df30e0447239fb2f3d2b0048621b63d Mon Sep 17 00:00:00 2001 From: Jason Gross Date: Fri, 2 Sep 2016 13:14:37 -0700 Subject: Slightly better cfail --- src/Util/Tactics.v | 18 +++++++++--------- 1 file changed, 9 insertions(+), 9 deletions(-) (limited to 'src/Util/Tactics.v') diff --git a/src/Util/Tactics.v b/src/Util/Tactics.v index f251b2e51..6f2c407f5 100644 --- a/src/Util/Tactics.v +++ b/src/Util/Tactics.v @@ -444,19 +444,19 @@ Hint Extern 0 (cidtac2 ?msg1 ?msg2) => idtac "" msg1 msg2 ""; Class cidtac3 {T1 T2 T3} (msg1 : T1) (msg2 : T2) (msg3 : T3) := Build_cidtac3 : True. Hint Extern 0 (cidtac3 ?msg1 ?msg2 ?msg3) => idtac "" msg1 msg2 msg3 ""; exact I : typeclass_instances. -Class cfail {T} (msg : T) := Build_cfail : False. -Hint Extern 0 (cfail ?msg) => fail 0 "Error:" msg "" : typeclass_instances. -Class cfail2 {T1 T2} (msg1 : T1) (msg2 : T2) := Build_cfail2 : False. -Hint Extern 0 (cfail2 ?msg1 ?msg2) => fail 0 "Error:" msg1 msg2 "" : typeclass_instances. -Class cfail3 {T1 T2 T3} (msg1 : T1) (msg2 : T2) (msg3 : T3) := Build_cfail3 : False. -Hint Extern 0 (cfail3 ?msg1 ?msg2 ?msg3) => fail 0 "Error:" msg1 msg2 msg3 "" : typeclass_instances. +Class cfail {T} (msg : T) := Build_cfail : True. +Hint Extern 0 (cfail ?msg) => idtac "Error:" msg ""; exact I : typeclass_instances. +Class cfail2 {T1 T2} (msg1 : T1) (msg2 : T2) := Build_cfail2 : True. +Hint Extern 0 (cfail2 ?msg1 ?msg2) => idtac "Error:" msg1 msg2 ""; exact I : typeclass_instances. +Class cfail3 {T1 T2 T3} (msg1 : T1) (msg2 : T2) (msg3 : T3) := Build_cfail3 : True. +Hint Extern 0 (cfail3 ?msg1 ?msg2 ?msg3) => idtac "Error:" msg1 msg2 msg3 ""; exact I : typeclass_instances. Ltac cidtac msg := constr:(_ : cidtac msg). Ltac cidtac2 msg1 msg2 := constr:(_ : cidtac2 msg1 msg2). Ltac cidtac3 msg1 msg2 msg3 := constr:(_ : cidtac2 msg1 msg2 msg3). -Ltac cfail msg := constr:(_ : cfail msg). -Ltac cfail2 msg1 msg2 := constr:(_ : cfail2 msg1 msg2). -Ltac cfail3 msg1 msg2 msg3 := constr:(_ : cfail2 msg1 msg2 msg3). +Ltac cfail msg := let dummy := constr:(_ : cfail msg) in constr:(I : I). +Ltac cfail2 msg1 msg2 := let dummy := constr:(_ : cfail2 msg1 msg2) in constr:(I : I). +Ltac cfail3 msg1 msg2 msg3 := let dummy := constr:(_ : cfail2 msg1 msg2 msg3) in constr:(I : I). Ltac idtac_goal := lazymatch goal with |- ?G => idtac "Goal:" G "" end. Ltac idtac_context := -- cgit v1.2.3