-
Notifications
You must be signed in to change notification settings - Fork 10.5k
/
Copy pathcapture-transitive.swift
43 lines (35 loc) · 1.72 KB
/
capture-transitive.swift
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
// RUN: %target-swift-emit-silgen %s | %FileCheck %s
// https://github.com/apple/swift/issues/50924
func fibonacci(_ n: Int) -> Int {
var cache: [Int: Int] = [:]
func recursive(_ m: Int) -> Int {
return cache[m] ?? {
// Make sure cache is only captured once in the closure
// CHECK: implicit closure #1 in recursive #1
// CHECK-LABEL: sil private [transparent] [ossa] @{{.*}}9fibonacci{{.*}}9recursive{{.*}} : $@convention(thin) {{.*}} @guaranteed { var Dictionary<Int, Int> }) ->
// CHECK: closure #1 in implicit closure #1 in recursive #1
// CHECK-LABEL: sil private [ossa] @{{.*}}9fibonacci{{.*}}9recursive{{.*}} : $@convention(thin) {{.*}} @guaranteed { var Dictionary<Int, Int> }) ->
let output = m < 2 ? m : recursive(m - 1) + recursive(m - 2)
cache[m] = output
return output
}()
}
return recursive(n)
}
class C {
required init() {}
func f() {}
// Make sure that we capture dynamic self type if an explicit self isn't guaranteed
func returnsSelf() -> Self {
return { self.f(); return .init() }()
// CHECK-LABEL: sil private [ossa] @{{.*}}returnsSelf{{.*}} : $@convention(thin) (@guaranteed C) -> @owned C
}
func returnsSelf1() -> Self {
return { [weak self] in self?.f(); return .init() }()
// CHECK-LABEL: sil private [ossa] @{{.*}}returnsSelf{{.*}} : $@convention(thin) (@guaranteed { var @sil_weak Optional<C> }, @thick @dynamic_self C.Type) -> @owned C
}
func returnsSelf2() -> Self {
return { [unowned self] in self.f(); return .init() }()
// CHECK-LABEL: sil private [ossa] @{{.*}}returnsSelf{{.*}} : $@convention(thin) (@guaranteed @sil_unowned C, @thick @dynamic_self C.Type) -> @owned C
}
}