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.
43 lines
2.0 KiB
Plaintext
43 lines
2.0 KiB
Plaintext
// First parse this and then emit a *.sib. Then read in the *.sib, then recreate
|
|
// RUN: %empty-directory(%t)
|
|
// RUN: %target-sil-opt -sil-print-types %s -emit-sib -o %t/tmp.sib -module-name unmanaged
|
|
// RUN: %target-sil-opt -sil-print-types %t/tmp.sib -o %t/tmp.2.sib -module-name unmanaged
|
|
// RUN: %target-sil-opt -sil-print-types %t/tmp.2.sib -module-name unmanaged | %FileCheck %s
|
|
|
|
import Swift
|
|
import Builtin
|
|
|
|
class C {}
|
|
|
|
// CHECK-LABEL: sil [serialized] [ossa] @retain_release : $@convention(thin) (@sil_unmanaged Optional<C>) -> () {
|
|
// CHECK: bb0([[ARG:%.*]] : $@sil_unmanaged Optional<C>):
|
|
// CHECK: [[REF:%.*]] = unmanaged_to_ref [[ARG]] : $@sil_unmanaged Optional<C> to $Optional<C>
|
|
// CHECK: unmanaged_retain_value [[REF]]
|
|
// CHECK: unmanaged_autorelease_value [[REF]]
|
|
// CHECK: unmanaged_release_value [[REF]]
|
|
sil [serialized] [ossa] @retain_release : $@convention(thin) (@sil_unmanaged Optional<C>) -> () {
|
|
bb0(%0 : $@sil_unmanaged Optional<C>):
|
|
%1 = unmanaged_to_ref %0 : $@sil_unmanaged Optional<C> to $Optional<C>
|
|
unmanaged_retain_value %1 : $Optional<C>
|
|
unmanaged_autorelease_value %1 : $Optional<C>
|
|
unmanaged_release_value %1 : $Optional<C>
|
|
%9999 = tuple()
|
|
return %9999 : $()
|
|
}
|
|
|
|
// CHECK-LABEL: sil [serialized] [ossa] @test : $@convention(thin) <U where U : AnyObject> (@inout Optional<U>) -> () {
|
|
// CHECK: bb0([[ARG:%.*]] : $*Optional<U>):
|
|
// CHECK: [[LOADED_ARG:%.*]] = load [copy] [[ARG]]
|
|
// CHECK: [[UNMANAGED_LOADED_ARG:%.*]] = ref_to_unmanaged [[LOADED_ARG]] : $Optional<U> to $@sil_unmanaged Optional<U>
|
|
// CHECK: {{%.*}} = unmanaged_to_ref [[UNMANAGED_LOADED_ARG]] : $@sil_unmanaged Optional<U> to $Optional<U>
|
|
// CHECK: destroy_value [[LOADED_ARG]]
|
|
sil [serialized] [ossa] @test : $@convention(thin) <U where U : AnyObject> (@inout Optional<U>) -> () {
|
|
bb0(%0 : $*Optional<U>):
|
|
%1 = load [copy] %0 : $*Optional<U>
|
|
%2 = ref_to_unmanaged %1 : $Optional<U> to $@sil_unmanaged Optional<U>
|
|
%3 = unmanaged_to_ref %2 : $@sil_unmanaged Optional<U> to $Optional<U>
|
|
destroy_value %1 : $Optional<U>
|
|
%9999 = tuple ()
|
|
return %9999 : $()
|
|
}
|