[cfe-commits] r71981 - in /cfe/trunk: lib/CodeGen/CodeGenTypes.cpp lib/CodeGen/Mangle.cpp test/CodeGenCXX/mangle.cpp
Anders Carlsson
andersca at mac.com
Sun May 17 10:41:21 PDT 2009
Author: andersca
Date: Sun May 17 12:41:20 2009
New Revision: 71981
URL: http://llvm.org/viewvc/llvm-project?rev=71981&view=rev
Log:
Add support for converting member pointer types to LLVM types. Also mangle pointer to member functions correctly and add tests.
Modified:
cfe/trunk/lib/CodeGen/CodeGenTypes.cpp
cfe/trunk/lib/CodeGen/Mangle.cpp
cfe/trunk/test/CodeGenCXX/mangle.cpp
Modified: cfe/trunk/lib/CodeGen/CodeGenTypes.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/CodeGen/CodeGenTypes.cpp?rev=71981&r1=71980&r2=71981&view=diff
==============================================================================
--- cfe/trunk/lib/CodeGen/CodeGenTypes.cpp (original)
+++ cfe/trunk/lib/CodeGen/CodeGenTypes.cpp Sun May 17 12:41:20 2009
@@ -385,12 +385,19 @@
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");
Modified: cfe/trunk/lib/CodeGen/Mangle.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/CodeGen/Mangle.cpp?rev=71981&r1=71980&r2=71981&view=diff
==============================================================================
--- cfe/trunk/lib/CodeGen/Mangle.cpp (original)
+++ cfe/trunk/lib/CodeGen/Mangle.cpp Sun May 17 12:41:20 2009
@@ -608,7 +608,12 @@
// <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) {
Modified: cfe/trunk/test/CodeGenCXX/mangle.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/test/CodeGenCXX/mangle.cpp?rev=71981&r1=71980&r2=71981&view=diff
==============================================================================
--- cfe/trunk/test/CodeGenCXX/mangle.cpp (original)
+++ cfe/trunk/test/CodeGenCXX/mangle.cpp Sun May 17 12:41:20 2009
@@ -75,5 +75,13 @@
// RUN: grep "_Z1f2S3ILb0EE" %t | count 1 &&
void f(S3<false>) {}
-// RUN: grep "_Z2f22S3ILb1EE" %t | count 1
+// RUN: grep "_Z2f22S3ILb1EE" %t | count 1 &&
void f2(S3<100>) {}
+
+struct S;
+
+// RUN: grep "_Z1fM1SKFvvE" %t | count 1 &&
+void f(void (S::*)() const) {}
+
+// RUN: grep "_Z1fM1SFvvE" %t | count 1
+void f(void (S::*)()) {}
More information about the cfe-commits
mailing list