diff options
author | Enrico Tassi <gareuselesinge@debian.org> | 2015-01-25 14:42:51 +0100 |
---|---|---|
committer | Enrico Tassi <gareuselesinge@debian.org> | 2015-01-25 14:42:51 +0100 |
commit | 7cfc4e5146be5666419451bdd516f1f3f264d24a (patch) | |
tree | e4197645da03dc3c7cc84e434cc31d0a0cca7056 /test-suite/bugs/closed/3439.v | |
parent | 420f78b2caeaaddc6fe484565b2d0e49c66888e5 (diff) |
Imported Upstream version 8.5~beta1+dfsg
Diffstat (limited to 'test-suite/bugs/closed/3439.v')
-rw-r--r-- | test-suite/bugs/closed/3439.v | 43 |
1 files changed, 43 insertions, 0 deletions
diff --git a/test-suite/bugs/closed/3439.v b/test-suite/bugs/closed/3439.v new file mode 100644 index 00000000..bba6140f --- /dev/null +++ b/test-suite/bugs/closed/3439.v @@ -0,0 +1,43 @@ +(* File reduced by coq-bug-finder from original input, then from 3154 lines to 149 lines, then from 89 lines to 55 lines, then from 44 lines to 20 lines *) +Set Primitive Projections. +Generalizable All Variables. +Axiom IsHSet : Type -> Type. +Existing Class IsHSet. +Record PreCategory := { object :> Type }. +Notation IsStrictCategory C := (IsHSet (object C)). +Instance trunc_prod `{IsHSet A} `{IsHSet B} : IsHSet (A * B) | 100. +admit. +Defined. +Typeclasses Transparent object. +Definition prod (C D : PreCategory) : PreCategory := Build_PreCategory (Datatypes.prod C D). +Global Instance isstrict_category_product `{IsStrictCategory C, IsStrictCategory D} : IsStrictCategory (prod C D). +Proof. + typeclasses eauto. +Defined. + + +Set Typeclasses Debug. +(* File reduced by coq-bug-finder from original input, then from 7425 lines to 154 lines, then from 116 lines to 20 lines *) +Class Contr (A : Type) := { center : A }. +Instance contr_unit : Contr unit | 0 := {| center := tt |}. +Module non_prim. + Unset Primitive Projections. + Record PreCategory := { object :> Type }. + Lemma foo : Contr (object (@Build_PreCategory unit)). + Proof. + solve [ simpl; typeclasses eauto ] || fail "goal not solved". + Undo. + solve [ typeclasses eauto ]. + Defined. +End non_prim. + +Module prim. + Set Primitive Projections. + Record PreCategory := { object :> Type }. + Lemma foo : Contr (object (@Build_PreCategory unit)). + Proof. + solve [ simpl; typeclasses eauto ] || fail "goal not solved". + Undo. + solve [ typeclasses eauto ]. (* Error: No applicable tactic. *) + Defined. +End prim.
\ No newline at end of file |