]> granicus.if.org Git - clang/commitdiff
Mangle block pointer types. Fixes PR5858.
authorAnders Carlsson <andersca@mac.com>
Wed, 23 Dec 2009 22:31:44 +0000 (22:31 +0000)
committerAnders Carlsson <andersca@mac.com>
Wed, 23 Dec 2009 22:31:44 +0000 (22:31 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@92069 91177308-0d34-0410-b5e6-96231b3b80d8

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

index 367c868ba966db9b677f7ae3c6504e06fd7eef31..f4c6ffeeda9cb59d8ebe29f30b408a3641a1ef3a 100644 (file)
@@ -990,7 +990,8 @@ void CXXNameMangler::mangleType(const ObjCInterfaceType *T) {
 }
 
 void CXXNameMangler::mangleType(const BlockPointerType *T) {
-  assert(false && "can't mangle block pointer types yet");
+  Out << "U13block_pointer";
+  mangleType(T->getPointeeType());
 }
 
 void CXXNameMangler::mangleType(const FixedWidthIntType *T) {
index e57fbe343386d50b18b32d4ce2f0c91e444c3c3b..e8770dfec3e8ef870821aac3552696f18ebb9f2c 100644 (file)
@@ -1,4 +1,4 @@
-// RUN: %clang_cc1 -emit-llvm %s -o - -triple=x86_64-apple-darwin9 | FileCheck %s
+// RUN: %clang_cc1 -emit-llvm %s -o - -triple=x86_64-apple-darwin9 -fblocks | FileCheck %s
 
 struct X { };
 struct Y { };
@@ -306,3 +306,6 @@ template<typename T, typename = Policy<P, true> > class Alloc
 // CHECK: define i8* @_ZN6PR58615AllocIcNS_6PolicyINS_1PELb1EEEE8allocateEiPKv
 template class Alloc<char>;
 }
+
+// CHECK: define void @_Z1fU13block_pointerFiiiE
+void f(int (^)(int, int)) { }
\ No newline at end of file