From: David Majnemer Date: Tue, 5 Aug 2014 00:01:15 +0000 (+0000) Subject: CodeGenObjCXX: Add a test for r214699 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=05002665ca8ddd27d6df8477e56a4cc22064a7ca;p=clang CodeGenObjCXX: Add a test for r214699 I forgot to add this with the changes for r214699. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@214829 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/test/CodeGenObjCXX/block-id.mm b/test/CodeGenObjCXX/block-id.mm new file mode 100644 index 0000000000..e324841b37 --- /dev/null +++ b/test/CodeGenObjCXX/block-id.mm @@ -0,0 +1,22 @@ +// RUN: %clang_cc1 -emit-llvm -fblocks -o - -triple x86_64-apple-darwin10 -fobjc-runtime=macosx-fragile-10.5 %s | FileCheck %s + +// N.B. This test verifies that two blocks which are otherwise +// indistinguishable receive distinct manglings. +// We had a bug where the first two blocks in the global block map could +// get the same unqualified-block mangling because the logic to handle +// block-ids believed it was handling Itanium-style discriminators. + +template +int tf() { + return T::value; +} +int i1 = ^int { + struct S { enum { value = 1 };}; + // CHECK-DAG: @_Z2tfIZUb_E1SEiv + return tf(); +}(); +int i2 = ^int(int p1) { + struct S { enum { value = 2 };}; + // CHECK-DAG: @_Z2tfIZUb0_E1SEiv + return tf() + p1; +}(1);