summaryrefslogtreecommitdiffstats
path: root/clang/lib/Parse/ParseDeclCXX.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/lib/Parse/ParseDeclCXX.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/lib/Parse/ParseDeclCXX.cpp')
-rw-r--r--clang/lib/Parse/ParseDeclCXX.cpp3
1 files changed, 2 insertions, 1 deletions
diff --git a/clang/lib/Parse/ParseDeclCXX.cpp b/clang/lib/Parse/ParseDeclCXX.cpp
index 3a82868d5ac..0a97825fd92 100644
--- a/clang/lib/Parse/ParseDeclCXX.cpp
+++ b/clang/lib/Parse/ParseDeclCXX.cpp
@@ -457,7 +457,8 @@ Parser::TypeResult Parser::ParseClassName(SourceLocation &EndLocation,
// We have an identifier; check whether it is actually a type.
TypeTy *Type = Actions.getTypeName(*Tok.getIdentifierInfo(),
- Tok.getLocation(), CurScope, SS);
+ Tok.getLocation(), CurScope, SS,
+ true);
if (!Type) {
Diag(Tok, DestrExpected ? diag::err_destructor_class_name
: diag::err_expected_class_name);
OpenPOWER on IntegriCloud