summaryrefslogtreecommitdiff
path: root/test-suite/bugs/closed/2353.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/2353.v
parent420f78b2caeaaddc6fe484565b2d0e49c66888e5 (diff)
Imported Upstream version 8.5~beta1+dfsg
Diffstat (limited to 'test-suite/bugs/closed/2353.v')
-rw-r--r--test-suite/bugs/closed/2353.v12
1 files changed, 12 insertions, 0 deletions
diff --git a/test-suite/bugs/closed/2353.v b/test-suite/bugs/closed/2353.v
new file mode 100644
index 00000000..baae9a6e
--- /dev/null
+++ b/test-suite/bugs/closed/2353.v
@@ -0,0 +1,12 @@
+(* Are recursively non-uniform params correctly treated? *)
+Inductive list (A:nat -> Type) n := cons : A n -> list A (S n) -> list A n.
+Inductive term n := app (l : list term n).
+Definition term_list :=
+ fix term_size n (t : term n) (acc : nat) {struct t} : nat :=
+ match t with
+ | app _ l =>
+ (fix term_list_size n (l : list term n) (acc : nat) {struct l} : nat :=
+ match l with
+ | cons _ _ t q => term_list_size (S n) q (term_size n t acc)
+ end) n l (S acc)
+ end.