Files
swift-mirror/test/IRGen/async/run-call-void-to-existential.sil
Nate Chandler b33b4f05bb [Test] Ensure linked dylib is copied to devices.
The tests IRGen/async/run-* all link against a PrintShims dylib.  To
force that dylib to be copied onto devices running these tests, add the
dylib's path to the %target-run line.
2020-10-07 10:46:59 -07:00

84 lines
3.4 KiB
Plaintext

// RUN: %empty-directory(%t)
// RUN: %target-build-swift-dylib(%t/%target-library-name(PrintShims)) %S/../../Inputs/print-shims.swift -module-name PrintShims -emit-module -emit-module-path %t/PrintShims.swiftmodule
// RUN: %target-codesign %t/%target-library-name(PrintShims)
// RUN: %target-build-swift -Xfrontend -enable-experimental-concurrency -parse-sil %s -emit-ir -I %t -L %t -lPrintShim | %FileCheck %s --check-prefix=CHECK-LL
// RUN: %target-build-swift -Xfrontend -enable-experimental-concurrency -parse-sil %s -module-name main -o %t/main -I %t -L %t -lPrintShims %target-rpath(%t)
// RUN: %target-codesign %t/main
// RUN: %target-run %t/main %t/%target-library-name(PrintShims) | %FileCheck %s
// REQUIRES: executable_test
// REQUIRES: swift_test_mode_optimize_none
// UNSUPPORTED: use_os_stdlib
import Builtin
import Swift
import PrintShims
sil public_external @printAny : $@convention(thin) (@in_guaranteed Any) -> ()
public protocol P {
}
public struct S : P {
@_hasStorage let int: Int64 { get }
init(int: Int64)
}
sil_witness_table [serialized] S: P module main {
}
sil hidden @S_init : $@convention(method) (Int64, @thin S.Type) -> S {
bb0(%int : $Int64, %S_type : $@thin S.Type):
%instance = struct $S (%int : $Int64)
return %instance : $S
}
// CHECK-LL: define hidden swiftcc void @voidToExistential(%swift.context* {{%[0-9]*}}) {{#[0-9]*}} {
sil hidden @voidToExistential : $@async @convention(thin) () -> @out P {
bb0(%out : $*P):
%S_type = metatype $@thin S.Type
%int_literal = integer_literal $Builtin.Int64, 42
%int = struct $Int64 (%int_literal : $Builtin.Int64)
%S_init = function_ref @S_init : $@convention(method) (Int64, @thin S.Type) -> S
%instance = apply %S_init(%int, %S_type) : $@convention(method) (Int64, @thin S.Type) -> S
%existential = alloc_stack $P
%existential_addr = init_existential_addr %existential : $*P, $S
store %instance to %existential_addr : $*S
copy_addr %existential to [initialization] %out : $*P
destroy_addr %existential : $*P
dealloc_stack %existential : $*P
%result = tuple ()
return %result : $()
}
sil hidden @call : $@convention(thin) () -> () {
bb0:
%existential = alloc_stack $P
%voidToExistential = function_ref @voidToExistential : $@async @convention(thin) () -> @out P
%voidToExistential_result = apply %voidToExistential(%existential) : $@async @convention(thin) () -> @out P
%existential_addr = open_existential_addr immutable_access %existential : $*P to $*@opened("1819CC6E-FEC6-11EA-876D-D0817AD71B77") P
%any = alloc_stack $Any
%any_addr = init_existential_addr %any : $*Any, $@opened("1819CC6E-FEC6-11EA-876D-D0817AD71B77") P
copy_addr %existential_addr to [initialization] %any_addr : $*@opened("1819CC6E-FEC6-11EA-876D-D0817AD71B77") P
%printAny = function_ref @printAny : $@convention(thin) (@in_guaranteed Any) -> ()
%result = apply %printAny(%any) : $@convention(thin) (@in_guaranteed Any) -> ()
destroy_addr %any : $*Any
dealloc_stack %any : $*Any
destroy_addr %existential : $*P
dealloc_stack %existential : $*P
return %result : $()
}
sil @main : $@convention(c) (Int32, UnsafeMutablePointer<Optional<UnsafeMutablePointer<Int8>>>) -> Int32 {
bb0(%0 : $Int32, %1 : $UnsafeMutablePointer<Optional<UnsafeMutablePointer<Int8>>>):
%call = function_ref @call : $@convention(thin) () -> ()
%result = apply %call() : $@convention(thin) () -> () // CHECK: S(int: 42)
%2 = integer_literal $Builtin.Int32, 0
%3 = struct $Int32 (%2 : $Builtin.Int32)
return %3 : $Int32
}