summaryrefslogtreecommitdiffstats
path: root/clang/test/SemaTemplate/dependent-base-member-init.cpp
diff options
context:
space:
mode:
authorDouglas Gregor <dgregor@apple.com>2009-08-26 18:27:52 +0000
committerDouglas Gregor <dgregor@apple.com>2009-08-26 18:27:52 +0000
commit5e0962f944c80f66bfccff18a4c072c8b28fc7ab (patch)
tree0910b146880277f110b622930bd82ab691e60759 /clang/test/SemaTemplate/dependent-base-member-init.cpp
parentf571c11d54b4ee1b94217bf9f6ade057f105bf50 (diff)
downloadbcm5719-llvm-5e0962f944c80f66bfccff18a4c072c8b28fc7ab.tar.gz
bcm5719-llvm-5e0962f944c80f66bfccff18a4c072c8b28fc7ab.zip
When we know that we are parsing a class-name, implicitly construct a
TypenameType if getTypeName is looking at a member of an unknown specialization. This allows us to properly parse class templates that derived from type that could only otherwise be described by a typename type, e.g., template<class T> struct X {}; template<typename T> struct Y : public X<T>::X { }; Fixes PR4381. llvm-svn: 80123
Diffstat (limited to 'clang/test/SemaTemplate/dependent-base-member-init.cpp')
-rw-r--r--clang/test/SemaTemplate/dependent-base-member-init.cpp4
1 files changed, 4 insertions, 0 deletions
diff --git a/clang/test/SemaTemplate/dependent-base-member-init.cpp b/clang/test/SemaTemplate/dependent-base-member-init.cpp
index 684bce6f5a6..b3d707b632b 100644
--- a/clang/test/SemaTemplate/dependent-base-member-init.cpp
+++ b/clang/test/SemaTemplate/dependent-base-member-init.cpp
@@ -1,5 +1,9 @@
// RUN: clang-cc -fsyntax-only -verify %s
+// PR4381
+template<class T> struct X {};
+template<typename T> struct Y : public X<T>::X { };
+
// PR4621
class A1 {
A1(int x) {}
OpenPOWER on IntegriCloud