aboutsummaryrefslogtreecommitdiffhomepage
path: root/test-suite/bugs/closed/2255.v
blob: bf80ff6607a1997b3ef2b8be4bfa94f3773abca9 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
(* Check injection in presence of dependencies hidden in applicative terms *)

Inductive TupleT : nat -> Type :=
  nilT : TupleT 0
| consT {n} A : (A -> TupleT n) -> TupleT (S n).

Inductive Tuple : forall n, TupleT n -> Type :=
  nil : Tuple _ nilT
| cons {n} A (x : A) (F : A -> TupleT n) : Tuple _ (F x) -> Tuple _ (consT A F).

Goal forall n A F x X n0 A0 x0 F0 H0 (H : existT (fun n0 : nat => {H0 : TupleT
n0 & Tuple n0 H0}) 
         (S n0)
         (existT (fun H0 : TupleT (S n0) => Tuple (S n0) H0) 
            (consT A0 F0) (cons A0 x0 F0 H0)) =
       existT (fun n0 : nat => {H0 : TupleT n0 & Tuple n0 H0}) 
         (S n)
         (existT (fun H0 : TupleT (S n) => Tuple (S n) H0) 
            (consT A F) (cons A x F X))), False.
intros.
injection H.