forked from OSchip/llvm-project
parent
be829868e1
commit
bec18dbb88
|
@ -601,7 +601,7 @@ public:
|
|||
|
||||
QualType getTemplateTypeParmType(unsigned Depth, unsigned Index,
|
||||
bool ParameterPack,
|
||||
IdentifierInfo *Name = 0);
|
||||
TemplateTypeParmDecl *ParmDecl = 0);
|
||||
|
||||
QualType getTemplateSpecializationType(TemplateName T,
|
||||
const TemplateArgument *Args,
|
||||
|
|
|
@ -640,7 +640,6 @@ struct CanProxyAdaptor<TemplateTypeParmType>
|
|||
LLVM_CLANG_CANPROXY_SIMPLE_ACCESSOR(unsigned, getDepth)
|
||||
LLVM_CLANG_CANPROXY_SIMPLE_ACCESSOR(unsigned, getIndex)
|
||||
LLVM_CLANG_CANPROXY_SIMPLE_ACCESSOR(bool, isParameterPack)
|
||||
LLVM_CLANG_CANPROXY_SIMPLE_ACCESSOR(IdentifierInfo *, getName)
|
||||
};
|
||||
|
||||
template<>
|
||||
|
|
|
@ -662,18 +662,13 @@ class TemplateTypeParmDecl : public TypeDecl {
|
|||
/// default argument.
|
||||
bool InheritedDefault : 1;
|
||||
|
||||
/// \brief Whether this is a parameter pack.
|
||||
bool ParameterPack : 1;
|
||||
|
||||
/// \brief The default template argument, if any.
|
||||
TypeSourceInfo *DefaultArgument;
|
||||
|
||||
TemplateTypeParmDecl(DeclContext *DC, SourceLocation L, IdentifierInfo *Id,
|
||||
bool Typename, QualType Type, bool ParameterPack)
|
||||
bool Typename)
|
||||
: TypeDecl(TemplateTypeParm, DC, L, Id), Typename(Typename),
|
||||
InheritedDefault(false), ParameterPack(ParameterPack), DefaultArgument() {
|
||||
TypeForDecl = Type.getTypePtr();
|
||||
}
|
||||
InheritedDefault(false), DefaultArgument() { }
|
||||
|
||||
public:
|
||||
static TemplateTypeParmDecl *Create(ASTContext &C, DeclContext *DC,
|
||||
|
@ -724,7 +719,7 @@ public:
|
|||
unsigned getIndex() const;
|
||||
|
||||
/// \brief Returns whether this is a parameter pack.
|
||||
bool isParameterPack() const { return ParameterPack; }
|
||||
bool isParameterPack() const;
|
||||
|
||||
// Implement isa/cast/dyncast/etc.
|
||||
static bool classof(const Decl *D) { return classofKind(D->getKind()); }
|
||||
|
|
|
@ -2311,42 +2311,63 @@ public:
|
|||
};
|
||||
|
||||
class TemplateTypeParmType : public Type, public llvm::FoldingSetNode {
|
||||
unsigned Depth : 15;
|
||||
unsigned Index : 16;
|
||||
unsigned ParameterPack : 1;
|
||||
IdentifierInfo *Name;
|
||||
// Helper data collector for canonical types.
|
||||
struct CanonicalTTPTInfo {
|
||||
unsigned Depth : 15;
|
||||
unsigned Index : 16;
|
||||
unsigned ParameterPack : 1;
|
||||
};
|
||||
|
||||
TemplateTypeParmType(unsigned D, unsigned I, bool PP, IdentifierInfo *N,
|
||||
QualType Canon)
|
||||
union {
|
||||
// Info for the canonical type.
|
||||
CanonicalTTPTInfo CanTTPTInfo;
|
||||
// Info for the non-canonical type.
|
||||
TemplateTypeParmDecl *TTPDecl;
|
||||
};
|
||||
|
||||
/// Build a non-canonical type.
|
||||
TemplateTypeParmType(TemplateTypeParmDecl *TTPDecl, QualType Canon)
|
||||
: Type(TemplateTypeParm, Canon, /*Dependent=*/true),
|
||||
Depth(D), Index(I), ParameterPack(PP), Name(N) { }
|
||||
TTPDecl(TTPDecl) { }
|
||||
|
||||
/// Build the canonical type.
|
||||
TemplateTypeParmType(unsigned D, unsigned I, bool PP)
|
||||
: Type(TemplateTypeParm, QualType(this, 0), /*Dependent=*/true),
|
||||
Depth(D), Index(I), ParameterPack(PP), Name(0) { }
|
||||
: Type(TemplateTypeParm, QualType(this, 0), /*Dependent=*/true) {
|
||||
CanTTPTInfo.Depth = D;
|
||||
CanTTPTInfo.Index = I;
|
||||
CanTTPTInfo.ParameterPack = PP;
|
||||
}
|
||||
|
||||
friend class ASTContext; // ASTContext creates these
|
||||
|
||||
const CanonicalTTPTInfo& getCanTTPTInfo() const {
|
||||
QualType Can = getCanonicalTypeInternal();
|
||||
return Can->getAs<TemplateTypeParmType>()->CanTTPTInfo;
|
||||
}
|
||||
|
||||
public:
|
||||
unsigned getDepth() const { return Depth; }
|
||||
unsigned getIndex() const { return Index; }
|
||||
bool isParameterPack() const { return ParameterPack; }
|
||||
IdentifierInfo *getName() const { return Name; }
|
||||
unsigned getDepth() const { return getCanTTPTInfo().Depth; }
|
||||
unsigned getIndex() const { return getCanTTPTInfo().Index; }
|
||||
bool isParameterPack() const { return getCanTTPTInfo().ParameterPack; }
|
||||
|
||||
TemplateTypeParmDecl *getDecl() const {
|
||||
return isCanonicalUnqualified() ? 0 : TTPDecl;
|
||||
}
|
||||
|
||||
bool isSugared() const { return false; }
|
||||
QualType desugar() const { return QualType(this, 0); }
|
||||
|
||||
void Profile(llvm::FoldingSetNodeID &ID) {
|
||||
Profile(ID, Depth, Index, ParameterPack, Name);
|
||||
Profile(ID, getDepth(), getIndex(), isParameterPack(), getDecl());
|
||||
}
|
||||
|
||||
static void Profile(llvm::FoldingSetNodeID &ID, unsigned Depth,
|
||||
unsigned Index, bool ParameterPack,
|
||||
IdentifierInfo *Name) {
|
||||
TemplateTypeParmDecl *TTPDecl) {
|
||||
ID.AddInteger(Depth);
|
||||
ID.AddInteger(Index);
|
||||
ID.AddBoolean(ParameterPack);
|
||||
ID.AddPointer(Name);
|
||||
ID.AddPointer(TTPDecl);
|
||||
}
|
||||
|
||||
static bool classof(const Type *T) {
|
||||
|
@ -2373,8 +2394,6 @@ class SubstTemplateTypeParmType : public Type, public llvm::FoldingSetNode {
|
|||
friend class ASTContext;
|
||||
|
||||
public:
|
||||
IdentifierInfo *getName() const { return Replaced->getName(); }
|
||||
|
||||
/// Gets the template parameter that was substituted for.
|
||||
const TemplateTypeParmType *getReplacedParameter() const {
|
||||
return Replaced;
|
||||
|
|
|
@ -1728,9 +1728,9 @@ ASTContext::getSubstTemplateTypeParmType(const TemplateTypeParmType *Parm,
|
|||
/// name.
|
||||
QualType ASTContext::getTemplateTypeParmType(unsigned Depth, unsigned Index,
|
||||
bool ParameterPack,
|
||||
IdentifierInfo *Name) {
|
||||
TemplateTypeParmDecl *TTPDecl) {
|
||||
llvm::FoldingSetNodeID ID;
|
||||
TemplateTypeParmType::Profile(ID, Depth, Index, ParameterPack, Name);
|
||||
TemplateTypeParmType::Profile(ID, Depth, Index, ParameterPack, TTPDecl);
|
||||
void *InsertPos = 0;
|
||||
TemplateTypeParmType *TypeParm
|
||||
= TemplateTypeParmTypes.FindNodeOrInsertPos(ID, InsertPos);
|
||||
|
@ -1738,10 +1738,9 @@ QualType ASTContext::getTemplateTypeParmType(unsigned Depth, unsigned Index,
|
|||
if (TypeParm)
|
||||
return QualType(TypeParm, 0);
|
||||
|
||||
if (Name) {
|
||||
if (TTPDecl) {
|
||||
QualType Canon = getTemplateTypeParmType(Depth, Index, ParameterPack);
|
||||
TypeParm = new (*this, TypeAlignment)
|
||||
TemplateTypeParmType(Depth, Index, ParameterPack, Name, Canon);
|
||||
TypeParm = new (*this, TypeAlignment) TemplateTypeParmType(TTPDecl, Canon);
|
||||
|
||||
TemplateTypeParmType *TypeCheck
|
||||
= TemplateTypeParmTypes.FindNodeOrInsertPos(ID, InsertPos);
|
||||
|
|
|
@ -623,7 +623,7 @@ void DeclPrinter::VisitTemplateDecl(TemplateDecl *D) {
|
|||
if (TTP->isParameterPack())
|
||||
Out << "... ";
|
||||
|
||||
Out << ParamType.getAsString(Policy);
|
||||
Out << TTP->getNameAsString();
|
||||
|
||||
if (TTP->hasDefaultArgument()) {
|
||||
Out << " = ";
|
||||
|
|
|
@ -265,8 +265,11 @@ TemplateTypeParmDecl::Create(ASTContext &C, DeclContext *DC,
|
|||
SourceLocation L, unsigned D, unsigned P,
|
||||
IdentifierInfo *Id, bool Typename,
|
||||
bool ParameterPack) {
|
||||
QualType Type = C.getTemplateTypeParmType(D, P, ParameterPack, Id);
|
||||
return new (C) TemplateTypeParmDecl(DC, L, Id, Typename, Type, ParameterPack);
|
||||
TemplateTypeParmDecl *TTPDecl
|
||||
= new (C) TemplateTypeParmDecl(DC, L, Id, Typename);
|
||||
QualType TTPType = C.getTemplateTypeParmType(D, P, ParameterPack, TTPDecl);
|
||||
TTPDecl->TypeForDecl = TTPType.getTypePtr();
|
||||
return TTPDecl;
|
||||
}
|
||||
|
||||
SourceLocation TemplateTypeParmDecl::getDefaultArgumentLoc() const {
|
||||
|
@ -281,6 +284,10 @@ unsigned TemplateTypeParmDecl::getIndex() const {
|
|||
return TypeForDecl->getAs<TemplateTypeParmType>()->getIndex();
|
||||
}
|
||||
|
||||
bool TemplateTypeParmDecl::isParameterPack() const {
|
||||
return TypeForDecl->getAs<TemplateTypeParmType>()->isParameterPack();
|
||||
}
|
||||
|
||||
//===----------------------------------------------------------------------===//
|
||||
// NonTypeTemplateParmDecl Method Implementations
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
|
|
@ -506,12 +506,12 @@ void TypePrinter::PrintTemplateTypeParm(const TemplateTypeParmType *T,
|
|||
std::string &S) {
|
||||
if (!S.empty()) // Prefix the basic type, e.g. 'parmname X'.
|
||||
S = ' ' + S;
|
||||
|
||||
if (!T->getName())
|
||||
|
||||
if (IdentifierInfo *Id = T->getDecl() ? T->getDecl()->getIdentifier() : 0)
|
||||
S = Id->getName().str() + S;
|
||||
else
|
||||
S = "type-parameter-" + llvm::utostr_32(T->getDepth()) + '-' +
|
||||
llvm::utostr_32(T->getIndex()) + S;
|
||||
else
|
||||
S = T->getName()->getName().str() + S;
|
||||
}
|
||||
|
||||
void TypePrinter::PrintSubstTemplateTypeParm(const SubstTemplateTypeParmType *T,
|
||||
|
|
|
@ -450,7 +450,7 @@ void Sema::translateTemplateArguments(const ASTTemplateArgsPtr &TemplateArgsIn,
|
|||
/// (otherwise, "class" was used), and KeyLoc is the location of the
|
||||
/// "class" or "typename" keyword. ParamName is the name of the
|
||||
/// parameter (NULL indicates an unnamed template parameter) and
|
||||
/// ParamName is the location of the parameter name (if any).
|
||||
/// ParamNameLoc is the location of the parameter name (if any).
|
||||
/// If the type parameter has a default argument, it will be added
|
||||
/// later via ActOnTypeParameterDefault.
|
||||
Sema::DeclPtrTy Sema::ActOnTypeParameter(Scope *S, bool Typename, bool Ellipsis,
|
||||
|
|
|
@ -896,12 +896,17 @@ TemplateInstantiator::TransformTemplateTypeParmType(TypeLocBuilder &TLB,
|
|||
// the template parameter list of a member template inside the
|
||||
// template we are instantiating). Create a new template type
|
||||
// parameter with the template "level" reduced by one.
|
||||
TemplateTypeParmDecl *NewTTPDecl = 0;
|
||||
if (TemplateTypeParmDecl *OldTTPDecl = T->getDecl())
|
||||
NewTTPDecl = cast_or_null<TemplateTypeParmDecl>(
|
||||
TransformDecl(TL.getNameLoc(), OldTTPDecl));
|
||||
|
||||
QualType Result
|
||||
= getSema().Context.getTemplateTypeParmType(T->getDepth()
|
||||
- TemplateArgs.getNumLevels(),
|
||||
T->getIndex(),
|
||||
T->isParameterPack(),
|
||||
T->getName());
|
||||
NewTTPDecl);
|
||||
TemplateTypeParmTypeLoc NewTL = TLB.push<TemplateTypeParmTypeLoc>(Result);
|
||||
NewTL.setNameLoc(TL.getNameLoc());
|
||||
return Result;
|
||||
|
|
|
@ -1442,14 +1442,12 @@ ParmVarDecl *TemplateDeclInstantiator::VisitParmVarDecl(ParmVarDecl *D) {
|
|||
Decl *TemplateDeclInstantiator::VisitTemplateTypeParmDecl(
|
||||
TemplateTypeParmDecl *D) {
|
||||
// TODO: don't always clone when decls are refcounted.
|
||||
const Type* T = D->getTypeForDecl();
|
||||
assert(T->isTemplateTypeParmType());
|
||||
const TemplateTypeParmType *TTPT = T->getAs<TemplateTypeParmType>();
|
||||
assert(D->getTypeForDecl()->isTemplateTypeParmType());
|
||||
|
||||
TemplateTypeParmDecl *Inst =
|
||||
TemplateTypeParmDecl::Create(SemaRef.Context, Owner, D->getLocation(),
|
||||
TTPT->getDepth() - 1, TTPT->getIndex(),
|
||||
TTPT->getName(),
|
||||
D->getDepth() - 1, D->getIndex(),
|
||||
D->getIdentifier(),
|
||||
D->wasDeclaredWithTypename(),
|
||||
D->isParameterPack());
|
||||
|
||||
|
|
Loading…
Reference in New Issue