mirror of
https://github.com/apple/swift.git
synced 2025-12-14 20:36:38 +01:00
53 lines
2.2 KiB
Swift
53 lines
2.2 KiB
Swift
// 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 -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()
|
|
}
|
|
|
|
}
|