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.
56 lines
2.5 KiB
Swift
56 lines
2.5 KiB
Swift
|
|
// RUN: %target-swift-emit-sil -Xllvm -sil-print-types -module-name unmanaged %s | %FileCheck %s
|
|
|
|
class C {}
|
|
|
|
struct Holder {
|
|
unowned(unsafe) var value: C
|
|
}
|
|
_ = Holder(value: C())
|
|
// CHECK-LABEL:sil hidden @$s9unmanaged6HolderV{{[_0-9a-zA-Z]*}}fC : $@convention(method) (@owned C, @thin Holder.Type) -> Holder
|
|
// CHECK: bb0([[T0:%.*]] : $C,
|
|
// CHECK-NEXT: [[T1:%.*]] = ref_to_unmanaged [[T0]] : $C to $@sil_unmanaged C
|
|
// CHECK-NEXT: strong_release [[T0]] : $C
|
|
// CHECK-NEXT: [[T2:%.*]] = struct $Holder ([[T1]] : $@sil_unmanaged C)
|
|
// CHECK-NEXT: return [[T2]] : $Holder
|
|
|
|
func set(holder holder: inout Holder) {
|
|
holder.value = C()
|
|
}
|
|
// CHECK-LABEL:sil hidden @$s9unmanaged3set6holderyAA6HolderVz_tF : $@convention(thin) (@inout Holder) -> ()
|
|
// CHECK: bb0([[ADDR:%.*]] : $*Holder):
|
|
// CHECK: [[T0:%.*]] = function_ref @$s9unmanaged1CC{{[_0-9a-zA-Z]*}}fC
|
|
// CHECK: [[C:%.*]] = apply [[T0]](
|
|
// CHECK-NEXT: [[WRITE:%.*]] = begin_access [modify] [static] [[ADDR]] : $*Holder
|
|
// CHECK-NEXT: [[T0:%.*]] = struct_element_addr [[WRITE]] : $*Holder, #Holder.value
|
|
// CHECK-NEXT: [[T1:%.*]] = ref_to_unmanaged [[C]]
|
|
// CHECK-NEXT: store [[T1]] to [[T0]]
|
|
// CHECK-NEXT: strong_release [[C]]
|
|
// CHECK-NEXT: end_access [[WRITE]] : $*Holder
|
|
// CHECK-NEXT: tuple ()
|
|
// CHECK-NEXT: return
|
|
|
|
func get(holder holder: inout Holder) -> C {
|
|
return holder.value
|
|
}
|
|
// CHECK-LABEL:sil hidden @$s9unmanaged3get6holderAA1CCAA6HolderVz_tF : $@convention(thin) (@inout Holder) -> @owned C
|
|
// CHECK: bb0([[ADDR:%.*]] : $*Holder):
|
|
// CHECK-NEXT: debug_value %0 : $*Holder, var, name "holder", argno 1, expr op_deref
|
|
// CHECK-NEXT: [[READ:%.*]] = begin_access [read] [static] [[ADDR]] : $*Holder
|
|
// CHECK-NEXT: [[T0:%.*]] = struct_element_addr [[READ]] : $*Holder, #Holder.value
|
|
// CHECK-NEXT: [[T1:%.*]] = load [[T0]] : $*@sil_unmanaged C
|
|
// CHECK-NEXT: [[T2:%.*]] = strong_copy_unmanaged_value [[T1]]
|
|
// CHECK-NEXT: end_access [[READ]] : $*Holder
|
|
// CHECK-NEXT: return [[T2]]
|
|
|
|
func project(fn fn: () -> Holder) -> C {
|
|
return fn().value
|
|
}
|
|
// CHECK-LABEL: sil hidden @$s9unmanaged7project2fnAA1CCAA6HolderVyXE_tF : $@convention(thin) (@guaranteed @noescape @callee_guaranteed () -> Holder) -> @owned C
|
|
// CHECK: bb0([[FN:%.*]] : $@noescape @callee_guaranteed () -> Holder):
|
|
// CHECK-NEXT: debug_value
|
|
// CHECK-NEXT: [[T0:%.*]] = apply [[FN]]()
|
|
// CHECK-NEXT: [[T1:%.*]] = struct_extract [[T0]] : $Holder, #Holder.value
|
|
// CHECK-NEXT: [[T2:%.*]] = strong_copy_unmanaged_value [[T1]]
|
|
// CHECK-NEXT: return [[T2]]
|