summaryrefslogtreecommitdiffstats
path: root/clang
diff options
context:
space:
mode:
authorDouglas Gregor <dgregor@apple.com>2011-09-22 23:04:35 +0000
committerDouglas Gregor <dgregor@apple.com>2011-09-22 23:04:35 +0000
commit5223529b2786e09793baed67648e4476f0a30a98 (patch)
tree019a28c1287ef329c593d06b0950e8757a67a14f /clang
parente83e1b2d2c2811449221ff3784f340ec893cd4e2 (diff)
downloadbcm5719-llvm-5223529b2786e09793baed67648e4476f0a30a98.tar.gz
bcm5719-llvm-5223529b2786e09793baed67648e4476f0a30a98.zip
Don't finalize checking of base and member initializers for a
constructor template. Fixes PR10457. llvm-svn: 140350
Diffstat (limited to 'clang')
-rw-r--r--clang/lib/Sema/SemaDeclCXX.cpp2
-rw-r--r--clang/test/SemaTemplate/delegating-constructors.cpp18
2 files changed, 19 insertions, 1 deletions
diff --git a/clang/lib/Sema/SemaDeclCXX.cpp b/clang/lib/Sema/SemaDeclCXX.cpp
index 6f14e61630f..616f798594e 100644
--- a/clang/lib/Sema/SemaDeclCXX.cpp
+++ b/clang/lib/Sema/SemaDeclCXX.cpp
@@ -2373,7 +2373,7 @@ bool Sema::SetCtorInitializers(CXXConstructorDecl *Constructor,
CXXCtorInitializer **Initializers,
unsigned NumInitializers,
bool AnyErrors) {
- if (Constructor->getDeclContext()->isDependentContext()) {
+ if (Constructor->isDependentContext()) {
// Just store the initializers as written, they will be checked during
// instantiation.
if (NumInitializers > 0) {
diff --git a/clang/test/SemaTemplate/delegating-constructors.cpp b/clang/test/SemaTemplate/delegating-constructors.cpp
new file mode 100644
index 00000000000..5c7d85f6ed5
--- /dev/null
+++ b/clang/test/SemaTemplate/delegating-constructors.cpp
@@ -0,0 +1,18 @@
+// RUN: %clang_cc1 -fsyntax-only -std=c++0x %s -verify
+
+namespace PR10457 {
+
+ class string
+ {
+ string(const char* str, unsigned);
+
+ public:
+ template <unsigned N>
+ string(const char (&str)[N])
+ : string(str) {} // expected-error{{constructor for 'string<6>' creates a delegation cycle}}
+ };
+
+ void f() {
+ string s("hello");
+ }
+}
OpenPOWER on IntegriCloud