diff options
author | Douglas Gregor <dgregor@apple.com> | 2009-07-23 23:49:00 +0000 |
---|---|---|
committer | Douglas Gregor <dgregor@apple.com> | 2009-07-23 23:49:00 +0000 |
commit | 5e03f9ea8174ae588c5e69ec6b5ef4c68f8fd766 (patch) | |
tree | c28c5e0be4aa5ba6ea746eda3c255afee997abdd /lib/AST/Type.cpp | |
parent | 70ee975fad4653fa09f8e77f9a46a7b1f592ef59 (diff) |
This patch fixes the implementations of the __has_trivial_destructor
and __has_trivial_constructor builtin pseudo-functions and
additionally implements __has_trivial_copy and __has_trivial_assign,
from John McCall!
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@76916 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/AST/Type.cpp')
-rw-r--r-- | lib/AST/Type.cpp | 24 |
1 files changed, 24 insertions, 0 deletions
diff --git a/lib/AST/Type.cpp b/lib/AST/Type.cpp index 1df8b63e2e..c3bb29b8d5 100644 --- a/lib/AST/Type.cpp +++ b/lib/AST/Type.cpp @@ -1072,6 +1072,30 @@ TemplateSpecializationType::Profile(llvm::FoldingSetNodeID &ID, Args[Idx].Profile(ID); } +const Type *QualifierSet::strip(const Type* T) { + QualType DT = T->getDesugaredType(); + CVRMask |= DT.getCVRQualifiers(); + + if (const ExtQualType* EQT = dyn_cast<ExtQualType>(DT)) { + if (EQT->getAddressSpace()) + AddressSpace = EQT->getAddressSpace(); + if (EQT->getObjCGCAttr()) + GCAttrType = EQT->getObjCGCAttr(); + return EQT->getBaseType(); + }else { + // Use the sugared type unless desugaring found extra qualifiers. + return (DT.getCVRQualifiers() ? DT.getTypePtr() : T); + } +} + +QualType QualifierSet::apply(QualType QT, ASTContext& C) { + QT = QT.getWithAdditionalQualifiers(CVRMask); + if (GCAttrType) QT = C.getObjCGCQualType(QT, GCAttrType); + if (AddressSpace) QT = C.getAddrSpaceQualType(QT, AddressSpace); + return QT; +} + + //===----------------------------------------------------------------------===// // Type Printing //===----------------------------------------------------------------------===// |