mirror of
https://github.com/apple/swift.git
synced 2025-12-21 12:14:44 +01:00
When synthesizing the default initializer for an actor, we'd sometimes hit a cycle when that initializer needs to chain to NSObject.init. The cycle only happens because we ask if the initializer we're trying to synthesize is a convenience init in a scenario which only applies to non-final classes. Since all actors are effectively "final" classes, it's valid to workaround the cycle by only asking that initializer question for non-final classes, thus breaking the cycle.
62 lines
2.5 KiB
Swift
62 lines
2.5 KiB
Swift
// RUN: %target-typecheck-verify-swift -disable-availability-checking
|
|
// REQUIRES: concurrency
|
|
// REQUIRES: objc_interop
|
|
|
|
import Foundation
|
|
|
|
func g(_ selector: Selector) -> Int { }
|
|
|
|
actor A {
|
|
func selectors() {
|
|
_ = #selector(type(of: self).f) // expected-error{{argument of '#selector' refers to instance method 'f()' that is not exposed to Objective-C}}
|
|
_ = #selector(type(of: self).g) // expected-error{{argument of '#selector' refers to instance method 'g()' that is not exposed to Objective-C}}
|
|
_ = #selector(type(of: self).h)
|
|
}
|
|
|
|
func keypaths() {
|
|
_ = #keyPath(A.w) // expected-error {{'#keyPath' refers to non-'@objc' property 'w'}}
|
|
|
|
// expected-error@+1 {{cannot form key path to actor-isolated property 'x'}}
|
|
_ = #keyPath(A.x) // expected-error{{argument of '#keyPath' refers to non-'@objc' property 'x'}}
|
|
|
|
// expected-error@+1 {{cannot form key path to actor-isolated property 'y'}}
|
|
_ = #keyPath(A.y) // expected-error{{argument of '#keyPath' refers to non-'@objc' property 'y'}}
|
|
|
|
// expected-error@+1 {{cannot form key path to actor-isolated property 'computed'}}
|
|
_ = #keyPath(A.computed) // expected-error{{argument of '#keyPath' refers to non-'@objc' property 'computed'}}
|
|
}
|
|
|
|
let w: Int = 0 // expected-note{{add '@objc' to expose this property to Objective-C}}
|
|
|
|
var x: Int = 0 // expected-note{{add '@objc' to expose this property to Objective-C}}
|
|
|
|
@objc var y: Int = 0 // expected-note{{add '@objc' to expose this property to Objective-C}}
|
|
// expected-error@-1{{actor-isolated property 'y' cannot be @objc}}
|
|
|
|
// expected-note@+1 {{add '@objc' to expose this property to Objective-C}}
|
|
@objc var computed : Int { // expected-error{{actor-isolated property 'computed' cannot be @objc}}
|
|
get { 120 }
|
|
}
|
|
|
|
func f() { } // expected-note{{add '@objc' to expose this instance method to Objective-C}}
|
|
func g() { } // expected-note{{add '@objc' to expose this instance method to Objective-C}}
|
|
@objc func h() async { }
|
|
}
|
|
|
|
actor Dril: NSObject {
|
|
// expected-note@+2 {{add 'async' to function 'postSynchronouslyTo(twitter:)' to make it asynchronous}}
|
|
// expected-error@+1 {{actor-isolated instance method 'postSynchronouslyTo(twitter:)' cannot be @objc}}
|
|
@objc func postSynchronouslyTo(twitter msg: String) -> Bool {
|
|
return true
|
|
}
|
|
|
|
@MainActor
|
|
@objc func postFromMainActorTo(twitter msg: String) -> Bool {
|
|
return true
|
|
}
|
|
}
|
|
|
|
|
|
// makes sure the synthesized init's delegation kind is determined correctly.
|
|
actor Pumpkin: NSObject {}
|