mirror of
https://github.com/apple/swift.git
synced 2025-12-14 20:36:38 +01:00
Type annotations for instruction operands are omitted, e.g. ``` %3 = struct $S(%1, %2) ``` Operand types are redundant anyway and were only used for sanity checking in the SIL parser. But: operand types _are_ printed if the definition of the operand value was not printed yet. This happens: * if the block with the definition appears after the block where the operand's instruction is located * if a block or instruction is printed in isolation, e.g. in a debugger The old behavior can be restored with `-Xllvm -sil-print-types`. This option is added to many existing test files which check for operand types in their check-lines.
100 lines
3.4 KiB
Swift
100 lines
3.4 KiB
Swift
// RUN: %target-swift-emit-silgen -Xllvm -sil-print-types -module-name switch %s | %FileCheck %s
|
|
//
|
|
// A temporary file for testing switch code around ownership. Once SILGenPattern
|
|
// refactoring is complete, this will be merged into the normal pattern file.
|
|
|
|
//////////////////
|
|
// Declarations //
|
|
//////////////////
|
|
|
|
class Klass {
|
|
init() {}
|
|
}
|
|
|
|
enum Foo { case A, B }
|
|
|
|
enum NonTrivialFoo {
|
|
case A(Klass)
|
|
case B(Klass)
|
|
}
|
|
|
|
func a() {}
|
|
func b() {}
|
|
func c() {}
|
|
func d() {}
|
|
func e() {}
|
|
func f() {}
|
|
func g() {}
|
|
|
|
///////////
|
|
// Tests //
|
|
///////////
|
|
|
|
// CHECK-LABEL: sil hidden [ossa] @$s6switch05test_A19_two_trivial_unions1x1yyAA3FooO_AFtF : $@convention(thin) (Foo, Foo) -> () {
|
|
func test_switch_two_trivial_unions(x: Foo, y: Foo) {
|
|
// CHECK: [[T0:%.*]] = tuple (%0 : $Foo, %1 : $Foo)
|
|
// CHECK: ([[X:%.*]], [[Y:%.*]]) = destructure_tuple [[T0]]
|
|
// CHECK: switch_enum [[Y]] : $Foo, case #Foo.A!enumelt: [[IS_CASE1:bb[0-9]+]], default [[IS_NOT_CASE1:bb[0-9]+]]
|
|
|
|
switch (x, y) {
|
|
// CHECK: [[IS_CASE1]]:
|
|
case (_, Foo.A):
|
|
// CHECK: function_ref @$s6switch1ayyF
|
|
a()
|
|
|
|
// CHECK: [[IS_NOT_CASE1]]:
|
|
// CHECK: switch_enum [[X]] : $Foo, case #Foo.B!enumelt: [[IS_CASE2:bb[0-9]+]], default [[IS_NOT_CASE2:bb[0-9]+]]
|
|
// CHECK: [[IS_CASE2]]:
|
|
case (Foo.B, _):
|
|
// CHECK: function_ref @$s6switch1byyF
|
|
b()
|
|
|
|
// CHECK: [[IS_NOT_CASE2]]:
|
|
// CHECK: switch_enum [[Y]] : $Foo, case #Foo.B!enumelt: [[IS_CASE3:bb[0-9]+]], default [[UNREACHABLE:bb[0-9]+]]
|
|
// CHECK: [[IS_CASE3]]:
|
|
case (_, Foo.B):
|
|
// CHECK: function_ref @$s6switch1cyyF
|
|
c()
|
|
|
|
// CHECK: [[UNREACHABLE]]:
|
|
// CHECK: unreachable
|
|
}
|
|
}
|
|
// CHECK: } // end sil function '$s6switch05test_A19_two_trivial_unions1x1yyAA3FooO_AFtF'
|
|
|
|
// CHECK-LABEL: sil hidden [ossa] @$s6switch05test_A22_two_nontrivial_unions1x1yyAA13NonTrivialFooO_AFtF : $@convention(thin) (@guaranteed NonTrivialFoo, @guaranteed NonTrivialFoo) -> () {
|
|
func test_switch_two_nontrivial_unions(x: NonTrivialFoo, y: NonTrivialFoo) {
|
|
// CHECK: [[ARG0_COPY:%.*]] = copy_value %0
|
|
// CHECK: [[ARG1_COPY:%.*]] = copy_value %1
|
|
// CHECK: [[T0:%.*]] = tuple ([[ARG0_COPY]] : $NonTrivialFoo, [[ARG1_COPY]] : $NonTrivialFoo)
|
|
// CHECK: ([[X:%.*]], [[Y:%.*]]) = destructure_tuple [[T0]]
|
|
// CHECK: [[BORROWED_Y:%.*]] = begin_borrow [[Y]]
|
|
// CHECK: switch_enum [[BORROWED_Y]] : $NonTrivialFoo, case #NonTrivialFoo.A!enumelt: [[IS_CASE1:bb[0-9]+]], default [[IS_NOT_CASE1:bb[0-9]+]]
|
|
|
|
switch (x, y) {
|
|
// CHECK: [[IS_CASE1]]({{%.*}} : @guaranteed $Klass)
|
|
case (_, NonTrivialFoo.A):
|
|
// CHECK: function_ref @$s6switch1ayyF
|
|
a()
|
|
|
|
// CHECK: [[IS_NOT_CASE1]]({{%.*}} : @guaranteed $Klass):
|
|
// CHECK: [[BORROWED_X:%.*]] = begin_borrow [[X]]
|
|
// CHECK: switch_enum [[BORROWED_X]] : $NonTrivialFoo, case #NonTrivialFoo.B!enumelt: [[IS_CASE2:bb[0-9]+]], default [[IS_NOT_CASE2:bb[0-9]+]]
|
|
// CHECK: [[IS_CASE2]]({{%.*}} : @guaranteed $Klass)
|
|
case (NonTrivialFoo.B, _):
|
|
// CHECK: function_ref @$s6switch1byyF
|
|
b()
|
|
|
|
// CHECK: [[IS_NOT_CASE2]]({{%.*}} : @guaranteed $Klass)
|
|
// CHECK: switch_enum [[Y]] : $NonTrivialFoo, case #NonTrivialFoo.B!enumelt: [[IS_CASE3:bb[0-9]+]], default [[UNREACHABLE:bb[0-9]+]]
|
|
// CHECK: [[IS_CASE3]]({{%.*}} : @owned $Klass):
|
|
case (_, NonTrivialFoo.B):
|
|
// CHECK: function_ref @$s6switch1cyyF
|
|
c()
|
|
|
|
// CHECK: [[UNREACHABLE]]({{%.*}} : @owned $Klass):
|
|
// CHECK: unreachable
|
|
}
|
|
}
|
|
// CHECK: } // end sil function '$s6switch05test_A22_two_nontrivial_unions1x1yyAA13NonTrivialFooO_AFtF'
|