]> granicus.if.org Git - clang/commitdiff
Add support for converting member pointer types to LLVM types. Also mangle pointer...
authorAnders Carlsson <andersca@mac.com>
Sun, 17 May 2009 17:41:20 +0000 (17:41 +0000)
committerAnders Carlsson <andersca@mac.com>
Sun, 17 May 2009 17:41:20 +0000 (17:41 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@71981 91177308-0d34-0410-b5e6-96231b3b80d8

lib/CodeGen/CodeGenTypes.cpp
lib/CodeGen/Mangle.cpp
test/CodeGenCXX/mangle.cpp

index a9d4615d2a1b138757ff0b65f9795fd904e60de1..af791f63186ccef36d2889288b6a6edb6a19c9eb 100644 (file)
@@ -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");
index c27ef4fd97859365b62fe9025542079cd14d9b65..c09a13a59f329fb6b7feeff49f9a1a18d8149679 100644 (file)
@@ -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) {
index 86a72011dae31af3fd428589bb67308263420303..ef36a8b23cfc3a71f8076d67b821f44b2b6c94fb 100644 (file)
@@ -75,5 +75,13 @@ void f(S3<true>) {}
 // 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::*)()) {}