summaryrefslogtreecommitdiffstats
path: root/clang/lib/AST
diff options
context:
space:
mode:
authorDouglas Gregor <dgregor@apple.com>2009-11-23 12:52:47 +0000
committerDouglas Gregor <dgregor@apple.com>2009-11-23 12:52:47 +0000
commitbd866c2985f0a5da3e7fbf9e7c7ca4b6f0c37c9a (patch)
tree475412f513c1533eb185b414c1f530cfff0eeff0 /clang/lib/AST
parent601f4f0b07925c9225b2cbd9de268762dadf615a (diff)
downloadbcm5719-llvm-bd866c2985f0a5da3e7fbf9e7c7ca4b6f0c37c9a.tar.gz
bcm5719-llvm-bd866c2985f0a5da3e7fbf9e7c7ca4b6f0c37c9a.zip
Canonical template arguments that are template template parameters by
their template parameter depth and position, so that we can match redeclarations appropriately. Fixes PR5527 and PR5528. llvm-svn: 89654
Diffstat (limited to 'clang/lib/AST')
-rw-r--r--clang/lib/AST/TemplateBase.cpp14
1 files changed, 12 insertions, 2 deletions
diff --git a/clang/lib/AST/TemplateBase.cpp b/clang/lib/AST/TemplateBase.cpp
index ff02f9a31cb..f341b45fb97 100644
--- a/clang/lib/AST/TemplateBase.cpp
+++ b/clang/lib/AST/TemplateBase.cpp
@@ -15,6 +15,7 @@
#include "llvm/ADT/FoldingSet.h"
#include "clang/AST/TemplateBase.h"
#include "clang/AST/DeclBase.h"
+#include "clang/AST/DeclTemplate.h"
#include "clang/AST/Expr.h"
#include "clang/AST/TypeLoc.h"
@@ -59,8 +60,17 @@ void TemplateArgument::Profile(llvm::FoldingSetNodeID &ID,
break;
case Template:
- ID.AddPointer(Context.getCanonicalTemplateName(getAsTemplate())
- .getAsVoidPointer());
+ if (TemplateTemplateParmDecl *TTP
+ = dyn_cast_or_null<TemplateTemplateParmDecl>(
+ getAsTemplate().getAsTemplateDecl())) {
+ ID.AddBoolean(true);
+ ID.AddInteger(TTP->getDepth());
+ ID.AddInteger(TTP->getPosition());
+ } else {
+ ID.AddBoolean(false);
+ ID.AddPointer(Context.getCanonicalTemplateName(getAsTemplate())
+ .getAsVoidPointer());
+ }
break;
case Integral:
OpenPOWER on IntegriCloud