-
Notifications
You must be signed in to change notification settings - Fork 10.4k
/
Copy pathrun-partialapply-capture-int64-int64-throws-to-int64.sil
103 lines (89 loc) · 5.58 KB
/
run-partialapply-capture-int64-int64-throws-to-int64.sil
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
// 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 @printGeneric : $@convention(thin) <T> (@in_guaranteed T) -> ()
sil public_external @printInt64 : $@convention(thin) (Int64) -> ()
sil hidden @createAndInvokeClosure : $@async @convention(thin) () -> () {
bb0:
%captured_literal = integer_literal $Builtin.Int64, 783247897
%captured = struct $Int64 (%captured_literal : $Builtin.Int64)
%createPartialApply = function_ref @createPartialApply : $@async @convention(thin) (Int64) -> @owned @async @callee_guaranteed (Int64) -> (Int64, @error Error)
%partialApply = apply %createPartialApply(%captured) : $@async @convention(thin) (Int64) -> @owned @async @callee_guaranteed (Int64) -> (Int64, @error Error)
strong_retain %partialApply : $@async @callee_guaranteed (Int64) -> (Int64, @error Error)
%applied_literal = integer_literal $Builtin.Int64, 7823478
%applied = struct $Int64 (%applied_literal : $Builtin.Int64)
try_apply %partialApply(%applied) : $@async @callee_guaranteed (Int64) -> (Int64, @error Error), normal success, error failure
success(%sum : $Int64):
%printInt64 = function_ref @printInt64 : $@convention(thin) (Int64) -> ()
%result = apply %printInt64(%sum) : $@convention(thin) (Int64) -> () // CHECK: 791071375
br exit
failure(%error : $Error):
br exit
exit:
strong_release %partialApply : $@async @callee_guaranteed (Int64) -> (Int64, @error Error)
strong_release %partialApply : $@async @callee_guaranteed (Int64) -> (Int64, @error Error)
%out = tuple ()
return %out : $()
}
// CHECK-LL: @closureTu =
// CHECK-LL: define internal swift{{(tail)?}}cc void @closure(
// CHECK-LL: define internal swift{{(tail)?}}cc void @"$s7closureTA"(
sil hidden @createPartialApply : $@async @convention(thin) (Int64) -> @owned @async @callee_guaranteed (Int64) -> (Int64, @error Error) {
bb0(%captured : $Int64):
%closure = function_ref @closure : $@async @convention(thin) (Int64, Int64) -> (Int64, @error Error)
%partialApply = partial_apply [callee_guaranteed] %closure(%captured) : $@async @convention(thin) (Int64, Int64) -> (Int64, @error Error)
return %partialApply : $@async @callee_guaranteed (Int64) -> (Int64, @error Error)
}
sil private @closure : $@async @convention(thin) (Int64, Int64) -> (Int64, @error Error) {
bb0(%one : $Int64, %two : $Int64):
%printInt64 = function_ref @printInt64 : $@convention(thin) (Int64) -> ()
%printInt64_1 = apply %printInt64(%one) : $@convention(thin) (Int64) -> ()
%printInt64_2 = apply %printInt64(%two) : $@convention(thin) (Int64) -> ()
%one_builtin = struct_extract %one : $Int64, #Int64._value
%two_builtin = struct_extract %two : $Int64, #Int64._value
%flag = integer_literal $Builtin.Int1, -1
%sumAndOverflowed = builtin "sadd_with_overflow_Int64"(%one_builtin : $Builtin.Int64, %two_builtin : $Builtin.Int64, %flag : $Builtin.Int1) : $(Builtin.Int64, Builtin.Int1)
%sum_builtin = tuple_extract %sumAndOverflowed : $(Builtin.Int64, Builtin.Int1), 0
%overflowed = tuple_extract %sumAndOverflowed : $(Builtin.Int64, Builtin.Int1), 1
cond_fail %overflowed : $Builtin.Int1, "arithmetic overflow"
%sum = struct $Int64 (%sum_builtin : $Builtin.Int64)
return %sum : $Int64
}
sil @test_case : $@convention(thin) @async () -> () {
%createAndInvokeClosure = function_ref @createAndInvokeClosure : $@async @convention(thin) () -> ()
%createAndInvokeClosure_result = apply %createAndInvokeClosure() : $@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
}