summaryrefslogtreecommitdiff
path: root/test-suite/bugs/closed/6617.v
blob: 9cabd62d48f8bf95f4eb74899c760a6fa6545cf3 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
Definition MR {T M : Type} :=
fun (R : M -> M -> Prop) (m : T -> M) (x y : T) => R (m x) (m y).

Set Primitive Projections.

Record sigma {A : Type} {B : A -> Type} : Type := sigmaI
  { pr1 : A;  pr2 : B pr1 }.

Axiom F : forall {A : Type} {R : A -> A -> Prop},
  (forall x, (forall y, R y x -> unit) -> unit) -> forall (x : A), unit.

Definition foo (A : Type) (l : list A) :=
  let y := {| pr1 := A; pr2 := l |} in
  let bar := MR lt (fun p : sigma =>
                 (fix Ffix (x : list (pr1 p)) : nat :=
                    match x with
                    | nil => 0
                    | cons _ x1 => S (Ffix x1)
                    end) (pr2 p)) in
fun (_ : bar y y) =>
F (fun (r : sigma)
       (X : forall q : sigma, bar q r -> unit) => tt).

Definition fooT (A : Type) (l : list A) : Type :=
  ltac:(let ty := type of (foo A l) in exact ty).
Parameter P : forall A l, fooT A l -> Prop.

Goal forall A l, P A l (foo A l).
Proof.
  intros; unfold foo.
  Fail match goal with
    | [ |- context [False]] => idtac
  end.
Admitted.