diff options
author | Douglas Gregor <dgregor@apple.com> | 2009-02-09 18:46:07 +0000 |
---|---|---|
committer | Douglas Gregor <dgregor@apple.com> | 2009-02-09 18:46:07 +0000 |
commit | 8bf4205c703aecfe28a8b4e3ae796e5b40be4672 (patch) | |
tree | 8e840fbe7de62cd7fbb0425a3810095c9e44e608 /clang/lib/AST/ASTContext.cpp | |
parent | 1df2bbe7f9fde4a57ee5c088241007e4401f4061 (diff) | |
download | bcm5719-llvm-8bf4205c703aecfe28a8b4e3ae796e5b40be4672.tar.gz bcm5719-llvm-8bf4205c703aecfe28a8b4e3ae796e5b40be4672.zip |
Start processing template-ids as types when the template-name refers
to a class template. For example, the template-id 'vector<int>' now
has a nice, sugary type in the type system. What we can do now:
- Parse template-ids like 'vector<int>' (where 'vector' names a
class template) and form proper types for them in the type system.
- Parse icky template-ids like 'A<5>' and 'A<(5 > 0)>' properly,
using (sadly) a bool in the parser to tell it whether '>' should
be treated as an operator or not.
This is a baby-step, with major problems and limitations:
- There are currently two ways that we handle template arguments
(whether they are types or expressions). These will be merged, and,
most likely, TemplateArg will disappear.
- We don't have any notion of the declaration of class template
specializations or of template instantiations, so all template-ids
are fancy names for 'int' :)
llvm-svn: 64153
Diffstat (limited to 'clang/lib/AST/ASTContext.cpp')
-rw-r--r-- | clang/lib/AST/ASTContext.cpp | 28 |
1 files changed, 28 insertions, 0 deletions
diff --git a/clang/lib/AST/ASTContext.cpp b/clang/lib/AST/ASTContext.cpp index a87a902d062..72aef4269be 100644 --- a/clang/lib/AST/ASTContext.cpp +++ b/clang/lib/AST/ASTContext.cpp @@ -1220,6 +1220,34 @@ QualType ASTContext::getTemplateTypeParmType(unsigned Depth, unsigned Index, return QualType(TypeParm, 0); } +QualType +ASTContext::getClassTemplateSpecializationType(TemplateDecl *Template, + unsigned NumArgs, + uintptr_t *Args, bool *ArgIsType, + QualType Canon) { + llvm::FoldingSetNodeID ID; + ClassTemplateSpecializationType::Profile(ID, Template, NumArgs, Args, + ArgIsType); + void *InsertPos = 0; + ClassTemplateSpecializationType *Spec + = ClassTemplateSpecializationTypes.FindNodeOrInsertPos(ID, InsertPos); + + if (Spec) + return QualType(Spec, 0); + + void *Mem = Allocate(sizeof(ClassTemplateSpecializationType) + + (sizeof(uintptr_t) * + (ClassTemplateSpecializationType:: + getNumPackedWords(NumArgs) + + NumArgs)), 8); + Spec = new (Mem) ClassTemplateSpecializationType(Template, NumArgs, Args, + ArgIsType, Canon); + Types.push_back(Spec); + ClassTemplateSpecializationTypes.InsertNode(Spec, InsertPos); + + return QualType(Spec, 0); +} + /// CmpProtocolNames - Comparison predicate for sorting protocols /// alphabetically. static bool CmpProtocolNames(const ObjCProtocolDecl *LHS, |