diff options
author | Douglas Gregor <dgregor@apple.com> | 2009-11-23 12:52:47 +0000 |
---|---|---|
committer | Douglas Gregor <dgregor@apple.com> | 2009-11-23 12:52:47 +0000 |
commit | bd866c2985f0a5da3e7fbf9e7c7ca4b6f0c37c9a (patch) | |
tree | 475412f513c1533eb185b414c1f530cfff0eeff0 /clang/lib/AST | |
parent | 601f4f0b07925c9225b2cbd9de268762dadf615a (diff) | |
download | bcm5719-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.cpp | 14 |
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: |