From 4886a4204ff2b20bc226ce70d837de5fcd4a79ab Mon Sep 17 00:00:00 2001 From: Fariborz Jahanian Date: Tue, 17 Feb 2009 21:45:36 +0000 Subject: [PATCH] Simplified ExtQualType per Chris's feedback. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@64820 91177308-0d34-0410-b5e6-96231b3b80d8 --- include/clang/AST/Type.h | 38 +++++++++++++------------------------- lib/AST/ASTContext.cpp | 5 ++--- lib/AST/Type.cpp | 8 +++----- 3 files changed, 18 insertions(+), 33 deletions(-) diff --git a/include/clang/AST/Type.h b/include/clang/AST/Type.h index f5e13c235c..ebbc5504a5 100644 --- a/include/clang/AST/Type.h +++ b/include/clang/AST/Type.h @@ -462,55 +462,43 @@ protected: /// class ExtQualType : public Type, public llvm::FoldingSetNode { public: - enum EQT { - EXTNONE = 0x0, - ASQUAL = 0x01, - GCQUAL = 0x10 + enum GCAttrTypes { + GCNone = 0, + Weak, + Strong }; + private: /// BaseType - This is the underlying type that this qualifies. All CVR /// qualifiers are stored on the QualType that references this type, so we /// can't have any here. Type *BaseType; - unsigned ExtQualTypeKind : 2; /// Address Space ID - The address space ID this type is qualified with. unsigned AddressSpace; /// GC __weak/__strong attributes - ObjCGCAttr *GCAttr; + GCAttrTypes GCAttrType; ExtQualType(Type *Base, QualType CanonicalPtr, unsigned AddrSpace, - ObjCGCAttr *gcAttr, - unsigned ExtKind) : + GCAttrTypes gcAttr) : Type(ExtQual, CanonicalPtr, Base->isDependentType()), BaseType(Base), - ExtQualTypeKind(ExtKind), AddressSpace(0), GCAttr(0) { - if (ExtKind & ASQUAL) - AddressSpace = AddrSpace; - if (ExtKind & GCQUAL) - GCAttr = gcAttr; - } + AddressSpace(AddrSpace), GCAttrType(gcAttr) { } friend class ASTContext; // ASTContext creates these. public: Type *getBaseType() const { return BaseType; } - ObjCGCAttr *getGCAttr() const { - assert((ExtQualTypeKind & GCQUAL) && "Bad ExtQualType Kind - not GCQUAL"); - return GCAttr; - } - unsigned getAddressSpace() const { - assert((ExtQualTypeKind & ASQUAL) && "Bad ExtQualType Kind - not ASQUAL"); - return AddressSpace; - } + GCAttrTypes getType() const { return GCAttrType; } + unsigned getAddressSpace() const { return AddressSpace; } virtual void getAsStringInternal(std::string &InnerString) const; void Profile(llvm::FoldingSetNodeID &ID) { - Profile(ID, getBaseType(), AddressSpace, GCAttr); + Profile(ID, getBaseType(), AddressSpace, GCAttrType); } static void Profile(llvm::FoldingSetNodeID &ID, Type *Base, - unsigned AddrSpace, ObjCGCAttr *gcAttr) { + unsigned AddrSpace, GCAttrTypes gcAttr) { ID.AddPointer(Base); - ID.AddPointer(gcAttr); ID.AddInteger(AddrSpace); + ID.AddInteger(gcAttr); } static bool classof(const Type *T) { return T->getTypeClass() == ExtQual; } diff --git a/lib/AST/ASTContext.cpp b/lib/AST/ASTContext.cpp index dec73182b8..c87b08627d 100644 --- a/lib/AST/ASTContext.cpp +++ b/lib/AST/ASTContext.cpp @@ -725,7 +725,7 @@ QualType ASTContext::getAddrSpaceQualType(QualType T, unsigned AddressSpace) { // Check if we've already instantiated an address space qual'd type of this // type. llvm::FoldingSetNodeID ID; - ExtQualType::Profile(ID, T.getTypePtr(), AddressSpace, 0); + ExtQualType::Profile(ID, T.getTypePtr(), AddressSpace, ExtQualType::GCNone); void *InsertPos = 0; if (ExtQualType *EXTQy = ExtQualTypes.FindNodeOrInsertPos(ID, InsertPos)) return QualType(EXTQy, 0); @@ -741,8 +741,7 @@ QualType ASTContext::getAddrSpaceQualType(QualType T, unsigned AddressSpace) { assert(NewIP == 0 && "Shouldn't be in the map!"); NewIP = NewIP; } ExtQualType *New = new (*this, 8) ExtQualType(T.getTypePtr(), Canonical, - AddressSpace, 0, - ExtQualType::ASQUAL); + AddressSpace, ExtQualType::GCNone); ExtQualTypes.InsertNode(New, InsertPos); Types.push_back(New); return QualType(New, T.getCVRQualifiers()); diff --git a/lib/AST/Type.cpp b/lib/AST/Type.cpp index 6aec24fddd..bc597072ed 100644 --- a/lib/AST/Type.cpp +++ b/lib/AST/Type.cpp @@ -1054,17 +1054,15 @@ void ComplexType::getAsStringInternal(std::string &S) const { void ExtQualType::getAsStringInternal(std::string &S) const { bool space = false; - if (ExtQualTypeKind & ASQUAL) { + if (AddressSpace) { S = "__attribute__((address_space("+llvm::utostr_32(AddressSpace)+")))" + S; space = true; } - if (ExtQualTypeKind & GCQUAL) { + if (GCAttrType != GCNone) { if (space) S += ' '; S += "__attribute__((objc_gc("; - ObjCGCAttr *gcattr = getGCAttr(); - ObjCGCAttr::GCAttrTypes attr = gcattr->getType(); - if (attr & ObjCGCAttr::Weak) + if (GCAttrType == Weak) S += "weak"; else S += "strong";