// 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 -g -parse-sil %s -emit-ir -I %t -L %t -lPrintShim | %FileCheck %s --check-prefix=CHECK-LL // RUN: %target-build-swift -g -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 // REQUIRES: concurrency // REQUIRES: concurrency_runtime // UNSUPPORTED: back_deployment_runtime import Builtin import Swift import PrintShims import _Concurrency sil public_external @printInt64 : $@convention(thin) (Int64) -> () sil @$ss5ErrorPsE5_codeSivg : $@convention(method) <τ_0_0 where τ_0_0 : Error> (@in_guaranteed τ_0_0) -> Int sil @$ss5ErrorPsE9_userInfoyXlSgvg : $@convention(method) <τ_0_0 where τ_0_0 : Error> (@in_guaranteed τ_0_0) -> @owned Optional sil @$ss5ErrorPsE7_domainSSvg : $@convention(method) <τ_0_0 where τ_0_0 : Error> (@in_guaranteed τ_0_0) -> @owned String struct E : Error { @_hasStorage let code: Int64 { get } init(code: Int64) } sil hidden @E_init : $@convention(method) (Int64, @thin E.Type) -> E { bb0(%int : $Int64, %E_type : $@thin E.Type): %instance = struct $E (%int : $Int64) return %instance : $E } sil private [transparent] [thunk] @S_domain_getter : $@convention(witness_method: Error) (@in_guaranteed E) -> @owned String { bb0(%0 : $*E): %1 = function_ref @$ss5ErrorPsE7_domainSSvg : $@convention(method) <τ_0_0 where τ_0_0 : Error> (@in_guaranteed τ_0_0) -> @owned String %2 = apply %1(%0) : $@convention(method) <τ_0_0 where τ_0_0 : Error> (@in_guaranteed τ_0_0) -> @owned String return %2 : $String } sil private [transparent] [thunk] @S_code_getter : $@convention(witness_method: Error) (@in_guaranteed E) -> Int { bb0(%0 : $*E): %1 = function_ref @$ss5ErrorPsE5_codeSivg : $@convention(method) <τ_0_0 where τ_0_0 : Error> (@in_guaranteed τ_0_0) -> Int %2 = apply %1(%0) : $@convention(method) <τ_0_0 where τ_0_0 : Error> (@in_guaranteed τ_0_0) -> Int return %2 : $Int } sil private [transparent] [thunk] @S_userinfo_getter : $@convention(witness_method: Error) (@in_guaranteed E) -> @owned Optional { bb0(%0 : $*E): %1 = function_ref @$ss5ErrorPsE9_userInfoyXlSgvg : $@convention(method) <τ_0_0 where τ_0_0 : Error> (@in_guaranteed τ_0_0) -> @owned Optional %2 = apply %1(%0) : $@convention(method) <τ_0_0 where τ_0_0 : Error> (@in_guaranteed τ_0_0) -> @owned Optional return %2 : $Optional } sil_witness_table hidden E: Error module main { method #Error._domain!getter: (Self) -> () -> String : @S_domain_getter method #Error._code!getter: (Self) -> () -> Int : @S_code_getter method #Error._userInfo!getter: (Self) -> () -> AnyObject? : @S_userinfo_getter } sil hidden @call : $@async @convention(thin) () -> () { bb0: %voidThrowsToInt = function_ref @voidThrowsToInt : $@async @convention(thin) () -> (Int, @error Error) try_apply %voidThrowsToInt() : $@async @convention(thin) () -> (Int, @error Error), normal bb1, error bb3 bb1(%result_int : $Int): br bb2 bb2: %out = tuple () return %out : $() bb3(%result_error : $Error): %error = alloc_stack $Error strong_retain %result_error : $Error store %result_error to %error : $*Error %instance = alloc_stack $E checked_cast_addr_br copy_on_success Error in %error : $*Error to E in %instance : $*E, bb4, bb5 bb4: dealloc_stack %instance : $*E destroy_addr %error : $*Error dealloc_stack %error : $*Error %int_addr = struct_element_addr %instance : $*E, #E.code %int = load %int_addr : $*Int64 %printInt64 = function_ref @printInt64 : $@convention(thin) (Int64) -> () %result = apply %printInt64(%int) : $@convention(thin) (Int64) -> () br bb2 bb5: dealloc_stack %instance : $*E destroy_addr %error : $*Error dealloc_stack %error : $*Error br bb2 } // CHECK-LL: @voidThrowsToIntTu = // CHECK-LL: define hidden swift{{(tail)?}}cc void @voidThrowsToInt(ptr swiftasync {{%[0-9]+}}) {{#[0-9]*}} sil hidden @voidThrowsToInt : $@async @convention(thin) () -> (Int, @error Error) { bb0: %asyncVoidThrowsToInt = function_ref @asyncVoidThrowsToInt : $@async @convention(thin) () -> (Int, @error Error) try_apply %asyncVoidThrowsToInt() : $@async @convention(thin) () -> (Int, @error Error), normal bb1, error bb2 bb1(%out : $Int): return %out : $Int bb2(%error : $Error): throw %error : $Error } sil hidden @asyncVoidThrowsToInt : $@async @convention(thin) () -> (Int, @error Error) { bb0: %e_type = metatype $@thin E.Type %int_literal = integer_literal $Builtin.Int64, 42 %int = struct $Int64 (%int_literal : $Builtin.Int64) %E_init = function_ref @E_init : $@convention(method) (Int64, @thin E.Type) -> E %instance = apply %E_init(%int, %e_type) : $@convention(method) (Int64, @thin E.Type) -> E %error = alloc_existential_box $Error, $E %instance_addr = project_existential_box $E in %error : $Error store %instance to %instance_addr : $*E %result = builtin "willThrow"(%error : $Error) : $() throw %error : $Error } sil @test_case : $@convention(thin) @async () -> () { %call = function_ref @call : $@async @convention(thin) () -> () // CHECK: 42 %result = apply %call() : $@async @convention(thin) () -> () %void = tuple() return %void : $() } // Defined in _Concurrency sil @$ss13_runAsyncMainyyyyYaKcF : $@convention(thin) (@guaranteed @async @callee_guaranteed () -> @error Error) -> () sil @no_throw_to_throw_think : $@convention(thin) @async (@guaranteed @async @callee_guaranteed () -> ()) -> @error Error { bb0(%0 :$@async @callee_guaranteed () -> ()): %void = apply %0() : $@async @callee_guaranteed () -> () return %void : $() } // main sil @main : $@convention(c) () -> Int32 { %test_case_nothrow = function_ref @test_case : $@convention(thin) @async () -> () %thick_test_case = thin_to_thick_function %test_case_nothrow : $@convention(thin) @async () -> () to $@callee_guaranteed @async () -> () %thunk = function_ref @no_throw_to_throw_think : $@convention(thin) @async (@guaranteed @async @callee_guaranteed () -> ()) -> @error Error %throwing = partial_apply [callee_guaranteed] %thunk(%thick_test_case) : $@convention(thin) @async (@guaranteed @async @callee_guaranteed () -> ()) -> @error Error %runAsyncMain = function_ref @$ss13_runAsyncMainyyyyYaKcF : $@convention(thin) (@guaranteed @async @callee_guaranteed () -> @error Error) -> () %result = apply %runAsyncMain(%throwing) : $@convention(thin) (@guaranteed @async @callee_guaranteed () -> @error Error) -> () %out_literal = integer_literal $Builtin.Int32, 0 %out = struct $Int32 (%out_literal : $Builtin.Int32) return %out : $Int32 }