aboutsummaryrefslogtreecommitdiff
path: root/lib/CodeGen
diff options
context:
space:
mode:
authorAnders Carlsson <andersca@mac.com>2009-05-17 17:41:20 +0000
committerAnders Carlsson <andersca@mac.com>2009-05-17 17:41:20 +0000
commit0e650017acdbbeb0c590e77bbea88c200ea1caef (patch)
tree7b3ba4430255a7c9c6a249097bba107cee132e9e /lib/CodeGen
parent1e64a9531bf6e9d99ad3271b3a735ef702689b06 (diff)
Add support for converting member pointer types to LLVM types. Also mangle pointer to member functions correctly and add tests.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@71981 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/CodeGen')
-rw-r--r--lib/CodeGen/CodeGenTypes.cpp19
-rw-r--r--lib/CodeGen/Mangle.cpp7
2 files changed, 19 insertions, 7 deletions
diff --git a/lib/CodeGen/CodeGenTypes.cpp b/lib/CodeGen/CodeGenTypes.cpp
index a9d4615d2a..af791f6318 100644
--- a/lib/CodeGen/CodeGenTypes.cpp
+++ b/lib/CodeGen/CodeGenTypes.cpp
@@ -385,12 +385,19 @@ const llvm::Type *CodeGenTypes::ConvertNewType(QualType T) {
return llvm::PointerType::get(PointeeType, FTy.getAddressSpace());
}
- case Type::MemberPointer:
- // FIXME: Implement C++ pointer-to-member. The GCC representation is
- // documented here:
- // http://gcc.gnu.org/onlinedocs/gccint/Type-Layout.html#Type-Layout
- assert(0 && "FIXME: We can't handle member pointers yet.");
- return llvm::OpaqueType::get();
+ case Type::MemberPointer: {
+ // FIXME: This is ABI dependent. We use the Itanium C++ ABI.
+ // http://www.codesourcery.com/public/cxx-abi/abi.html#member-pointers
+ // If we ever want to support other ABIs this needs to be abstracted.
+
+ QualType ETy = cast<MemberPointerType>(Ty).getPointeeType();
+ if (ETy->isFunctionType()) {
+ return llvm::StructType::get(ConvertType(Context.getPointerDiffType()),
+ ConvertType(Context.getPointerDiffType()),
+ NULL);
+ } else
+ return ConvertType(Context.getPointerDiffType());
+ }
case Type::TemplateSpecialization:
assert(false && "Dependent types can't get here");
diff --git a/lib/CodeGen/Mangle.cpp b/lib/CodeGen/Mangle.cpp
index c27ef4fd97..c09a13a59f 100644
--- a/lib/CodeGen/Mangle.cpp
+++ b/lib/CodeGen/Mangle.cpp
@@ -608,7 +608,12 @@ void CXXNameMangler::mangleType(const MemberPointerType *T) {
// <pointer-to-member-type> ::= M <class type> <member type>
Out << 'M';
mangleType(QualType(T->getClass(), 0));
- mangleType(T->getPointeeType());
+ QualType PointeeType = T->getPointeeType();
+ if (const FunctionProtoType *FPT = dyn_cast<FunctionProtoType>(PointeeType)) {
+ mangleCVQualifiers(FPT->getTypeQuals());
+ mangleType(FPT);
+ } else
+ mangleType(PointeeType);
}
void CXXNameMangler::mangleType(const TemplateTypeParmType *T) {