From 554bcb69c2d785a011a30e7db87a36a87fe7db10 Mon Sep 17 00:00:00 2001
From: dim <dim@FreeBSD.org>
Date: Wed, 15 Aug 2012 20:02:54 +0000
Subject: Vendor import of clang trunk r161861:
 http://llvm.org/svn/llvm-project/cfe/trunk@161861

---
 test/SemaTemplate/instantiation-depth-defarg.cpp | 36 ++++++++++++++++++++++++
 1 file changed, 36 insertions(+)
 create mode 100644 test/SemaTemplate/instantiation-depth-defarg.cpp

(limited to 'test/SemaTemplate/instantiation-depth-defarg.cpp')

diff --git a/test/SemaTemplate/instantiation-depth-defarg.cpp b/test/SemaTemplate/instantiation-depth-defarg.cpp
new file mode 100644
index 0000000..6550987
--- /dev/null
+++ b/test/SemaTemplate/instantiation-depth-defarg.cpp
@@ -0,0 +1,36 @@
+// RUN: %clang_cc1 -fsyntax-only -verify -ftemplate-depth 128 -ftemplate-backtrace-limit 4 %s
+
+template<int N> struct S {
+  typedef typename S<N-1>::type type;
+  static int f(int n = S<N-1>::f()); // \
+// expected-error{{recursive template instantiation exceeded maximum depth of 128}} \
+// expected-note 3 {{instantiation of default function argument}} \
+// expected-note {{skipping 125 contexts in backtrace}} \
+// expected-note {{use -ftemplate-depth=N to increase recursive template instantiation depth}}
+
+};
+template<> struct S<0> {
+  typedef int type;
+};
+
+// Incrementally instantiate up to S<2048>.
+template struct S<128>;
+template struct S<256>;
+template struct S<384>;
+template struct S<512>;
+template struct S<640>;
+template struct S<768>;
+template struct S<896>;
+template struct S<1024>;
+template struct S<1152>;
+template struct S<1280>;
+template struct S<1408>;
+template struct S<1536>;
+template struct S<1664>;
+template struct S<1792>;
+template struct S<1920>;
+template struct S<2048>;
+
+// Check that we actually bail out when we hit the instantiation depth limit for
+// the default arguments.
+void g() { S<2048>::f(); } // expected-note {{required here}}
-- 
cgit v1.1