forked from swiftlang/swift
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdistributed_actor_nonisolated.swift
52 lines (39 loc) · 2.23 KB
/
distributed_actor_nonisolated.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
42
43
44
45
46
47
48
49
50
51
52
// RUN: %empty-directory(%t)
// RUN: %target-swift-frontend-emit-module -emit-module-path %t/FakeDistributedActorSystems.swiftmodule -module-name FakeDistributedActorSystems -disable-availability-checking %S/Inputs/FakeDistributedActorSystems.swift
// RUN: %target-swift-frontend -typecheck -verify -enable-experimental-distributed -disable-availability-checking -I %t 2>&1 %s
// REQUIRES: concurrency
// REQUIRES: distributed
import _Distributed
import FakeDistributedActorSystems
@available(SwiftStdlib 5.5, *)
typealias DefaultDistributedActorSystem = FakeActorSystem
distributed actor DA {
let local: Int = 42
// expected-note@-1{{access to property 'local' is only permitted within distributed actor 'DA'}}
// expected-note@-2{{access to property 'local' is only permitted within distributed actor 'DA'}}
nonisolated let nope: Int = 13
// expected-error@-1{{'nonisolated' can not be applied to distributed actor stored properties}}
nonisolated var computedNonisolated: Int {
// nonisolated computed properties are outside of the actor and as such cannot access local
_ = self.local // expected-error{{distributed actor-isolated property 'local' can not be accessed from a non-isolated context}}
_ = self.id // ok, special handled and always available
_ = self.actorSystem // ok, special handled and always available
}
distributed func dist() {}
nonisolated func access() async throws {
_ = self.id // ok
_ = self.actorSystem // ok
// self is a distributed actor self is NOT isolated
_ = self.local // expected-error{{distributed actor-isolated property 'local' can not be accessed from a non-isolated context}}
_ = try await self.dist() // ok, was made implicitly throwing and async
_ = self.computedNonisolated // it's okay, only the body of computedNonisolated is wrong
}
nonisolated distributed func nonisolatedDistributed() async {
// expected-error@-1{{cannot declare method 'nonisolatedDistributed()' as both 'nonisolated' and 'distributed'}}{{3-15=}}
fatalError()
}
distributed nonisolated func distributedNonisolated() async {
// expected-error@-1{{cannot declare method 'distributedNonisolated()' as both 'nonisolated' and 'distributed'}}{{15-27=}}
fatalError()
}
}