summaryrefslogtreecommitdiff
path: root/test-suite/bugs/closed/3662.v
diff options
context:
space:
mode:
authorGravatar Enrico Tassi <gareuselesinge@debian.org>2015-01-25 14:42:51 +0100
committerGravatar Enrico Tassi <gareuselesinge@debian.org>2015-01-25 14:42:51 +0100
commit7cfc4e5146be5666419451bdd516f1f3f264d24a (patch)
treee4197645da03dc3c7cc84e434cc31d0a0cca7056 /test-suite/bugs/closed/3662.v
parent420f78b2caeaaddc6fe484565b2d0e49c66888e5 (diff)
Imported Upstream version 8.5~beta1+dfsg
Diffstat (limited to 'test-suite/bugs/closed/3662.v')
-rw-r--r--test-suite/bugs/closed/3662.v47
1 files changed, 47 insertions, 0 deletions
diff --git a/test-suite/bugs/closed/3662.v b/test-suite/bugs/closed/3662.v
new file mode 100644
index 00000000..bd53389b
--- /dev/null
+++ b/test-suite/bugs/closed/3662.v
@@ -0,0 +1,47 @@
+Set Primitive Projections.
+Set Implicit Arguments.
+Set Record Elimination Schemes.
+Record prod A B := pair { fst : A ; snd : B }.
+Definition f : Set -> Type := fun x => x.
+
+Goal (fst (pair (fun x => x + 1) nat) 0) = 0.
+compute.
+Undo.
+cbv.
+Undo.
+Opaque fst.
+cbn.
+Transparent fst.
+cbn.
+Undo.
+simpl.
+Undo.
+Abort.
+
+Goal f (fst (pair nat nat)) = nat.
+compute.
+ match goal with
+ | [ |- fst ?x = nat ] => fail 1 "compute failed"
+ | [ |- nat = nat ] => idtac
+ end.
+ reflexivity.
+Defined.
+
+Goal fst (pair nat nat) = nat.
+ unfold fst.
+ match goal with
+ | [ |- fst ?x = nat ] => fail 1 "compute failed"
+ | [ |- nat = nat ] => idtac
+ end.
+ reflexivity.
+Defined.
+
+Lemma eta A B : forall x : prod A B, x = pair (fst x) (snd x). reflexivity. Qed.
+
+Goal forall x : prod nat nat, fst x = 0.
+ intros. unfold fst.
+ Fail match goal with
+ | [ |- fst ?x = 0 ] => idtac
+ end.
+Abort.
+