|
| 1 | +// RUN: %target-swift-frontend -emit-ir %s -g -o - \ |
| 2 | +// RUN: -enable-experimental-feature VariadicGenerics \ |
| 3 | +// RUN: -parse-as-library -module-name a \ |
| 4 | +// RUN: -disable-round-trip-debug-types | %FileCheck %s |
| 5 | +// FIXME: ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ remove this! |
| 6 | +// rdar://105021109 |
| 7 | + |
| 8 | +public func f1<T...>(ts: repeat each T) { |
| 9 | + // CHECK: define {{.*}} @"$s1a2f12tsyxxQp_tlF"(%swift.opaque** {{.*}}, i{{32|64}} [[COUNT1_1:.*]], %swift.type** {{.*}}) |
| 10 | + // CHECK-DAG: store i{{32|64}} [[COUNT1_1]], i{{32|64}}* %[[COUNT1_1_A:.*]], align |
| 11 | + // CHECK-DAG: call void @llvm.dbg.declare({{.*}}[[COUNT1_1_A]], metadata ![[COUNT1_1_VAR:[0-9]+]], metadata !DIExpression()) |
| 12 | + // CHECK-LABEL: ret void |
| 13 | +} |
| 14 | + |
| 15 | +public func f2<U..., V...>(us: repeat each U, vs: repeat each V) { |
| 16 | + // CHECK: define {{.*}} @"$s1a2f22us2vsyxxQp_q_q_Qptr0_lF"(%swift.opaque** {{.*}}, %swift.opaque** {{.*}}, i{{32|64}} [[COUNT2_1:.*]], i{{32|64}} [[COUNT2_2:.*]], %swift.type** {{.*}}, %swift.type** {{.*}}) |
| 17 | + // CHECK-DAG: store i{{32|64}} [[COUNT2_1]], i{{32|64}}* %[[COUNT2_1_A:.*]], align |
| 18 | + // CHECK-DAG: store i{{32|64}} [[COUNT2_2]], i{{32|64}}* %[[COUNT2_2_A:.*]], align |
| 19 | + // CHECK-DAG: call void @llvm.dbg.declare({{.*}}[[COUNT2_1_A]], metadata ![[COUNT2_1_VAR:[0-9]+]], metadata !DIExpression()) |
| 20 | + // CHECK-DAG: call void @llvm.dbg.declare({{.*}}[[COUNT2_2_A]], metadata ![[COUNT2_2_VAR:[0-9]+]], metadata !DIExpression()) |
| 21 | + // CHECK-LABEL: ret void |
| 22 | +} |
| 23 | + |
| 24 | +public func f3<T...>(ts: repeat each T, more_ts: repeat each T) { |
| 25 | + // CHECK: define {{.*}} @"$s1a2f32ts05more_B0yxxQp_xxQptlF"(%swift.opaque** {{.*}}, %swift.opaque** {{.*}}, i{{32|64}} [[COUNT3_1:.*]], %swift.type** {{.*}}) |
| 26 | + // CHECK-DAG: store i{{32|64}} [[COUNT3_1]], i{{32|64}}* %[[COUNT3_1_A:.*]], align |
| 27 | + // CHECK-DAG: call void @llvm.dbg.declare({{.*}}[[COUNT3_1_A]], metadata ![[COUNT3_1_VAR:[0-9]+]], metadata !DIExpression()) |
| 28 | + // CHECK-LABEL: ret void |
| 29 | +} |
| 30 | + |
| 31 | +public func f4<U..., V...>(us: repeat (each U, each V)) { |
| 32 | + // CHECK: define {{.*}} @"$s1a2f42usyx_q_txQp_tq_Rhzr0_lF"(%swift.opaque** {{.*}}, i{{32|64}} [[COUNT4_1:.*]], %swift.type** {{.*}}, %swift.type** {{.*}}) |
| 33 | + // CHECK-DAG: store i{{32|64}} [[COUNT4_1]], i{{32|64}}* %[[COUNT4_1_A:.*]], align |
| 34 | + // CHECK-DAG: call void @llvm.dbg.declare({{.*}}[[COUNT4_1_A]], metadata ![[COUNT4_1_VAR:[0-9]+]], metadata !DIExpression()) |
| 35 | + // CHECK-LABEL: ret void |
| 36 | +} |
| 37 | + |
| 38 | +// CHECK-LABEL: !DICompileUnit |
| 39 | +// CHECK-DAG: [[COUNT1_1_VAR]] = !DILocalVariable(name: "$pack_count_1",{{.*}} flags: DIFlagArtificial) |
| 40 | +// CHECK-DAG: [[COUNT2_1_VAR]] = !DILocalVariable(name: "$pack_count_1",{{.*}} flags: DIFlagArtificial) |
| 41 | +// CHECK-DAG: [[COUNT2_2_VAR]] = !DILocalVariable(name: "$pack_count_2",{{.*}} flags: DIFlagArtificial) |
| 42 | +// CHECK-DAG: [[COUNT3_1_VAR]] = !DILocalVariable(name: "$pack_count_1",{{.*}} flags: DIFlagArtificial) |
| 43 | +// CHECK-DAG: [[COUNT4_1_VAR]] = !DILocalVariable(name: "$pack_count_1",{{.*}} flags: DIFlagArtificial) |
| 44 | + |
0 commit comments