diff --git a/clang/lib/AST/Mangle.cpp b/clang/lib/AST/Mangle.cpp index fba835451e29..b5dbdca9c976 100644 --- a/clang/lib/AST/Mangle.cpp +++ b/clang/lib/AST/Mangle.cpp @@ -135,7 +135,10 @@ void MangleContext::mangleName(const NamedDecl *D, raw_ostream &Out) { bool MCXX = shouldMangleCXXName(D); const TargetInfo &TI = Context.getTargetInfo(); if (CC == SOF_OTHER || (MCXX && TI.getCXXABI() == TargetCXXABI::Microsoft)) { - mangleCXXName(D, Out); + if (const ObjCMethodDecl *OMD = dyn_cast(D)) + mangleObjCMethodName(OMD, Out); + else + mangleCXXName(D, Out); return; } @@ -147,6 +150,8 @@ void MangleContext::mangleName(const NamedDecl *D, raw_ostream &Out) { if (!MCXX) Out << D->getIdentifier()->getName(); + else if (const ObjCMethodDecl *OMD = dyn_cast(D)) + mangleObjCMethodName(OMD, Out); else mangleCXXName(D, Out); diff --git a/clang/test/CodeGenObjC/mangle-blocks.m b/clang/test/CodeGenObjC/mangle-blocks.m new file mode 100644 index 000000000000..f0339c153084 --- /dev/null +++ b/clang/test/CodeGenObjC/mangle-blocks.m @@ -0,0 +1,29 @@ +// RUN: %clang_cc1 -triple i386-apple-ios -fblocks -emit-llvm -o - %s -Wno-objc-root-class \ +// RUN: | FileCheck %s + +void __assert_rtn(const char *, const char *, int, const char *); + +@interface Test +- (void (^)(void)) mangle; +@end + +@implementation Test +- (void (^)(void)) mangle { + return ^() { + void (^b)(void) = ^() { + __assert_rtn(__func__, __FILE__, __LINE__, "mangle"); + }; + }; +} +@end + +// CHECK: @"__func__.__14-[Test mangle]_block_invoke_2" = private unnamed_addr constant [34 x i8] c"__14-[Test mangle]_block_invoke_2\00", align 1 +// CHECK: @.str = private unnamed_addr constant {{.*}}, align 1 +// CHECK: @.str1 = private unnamed_addr constant [7 x i8] c"mangle\00", align 1 + +// CHECK: define internal void @"__14-[Test mangle]_block_invoke"(i8* %.block_descriptor) + +// CHECK: define internal void @"__14-[Test mangle]_block_invoke_2"(i8* %.block_descriptor){{.*}}{ +// CHECK: call void @__assert_rtn(i8* getelementptr inbounds ([34 x i8]* @"__func__.__14-[Test mangle]_block_invoke_2", i32 0, i32 0), i8* getelementptr inbounds {{.*}}, i32 14, i8* getelementptr inbounds ([7 x i8]* @.str1, i32 0, i32 0)) +// CHECK: } +