mirror of
https://github.com/apple/swift.git
synced 2025-12-21 12:14:44 +01:00
Review over a large number of APIs has found that most of the time, the result type of an Objective-C completion handler method that becomes "async throws" should be optional. Change the default behavior to match this, and replace _Nullable_on_error with _Nullable_result to capture the case where the result should be optional.
40 lines
1.3 KiB
Swift
40 lines
1.3 KiB
Swift
// RUN: %target-swift-frontend(mock-sdk: %clang-importer-sdk) -typecheck -I %S/Inputs/custom-modules -enable-experimental-concurrency %s -verify
|
|
|
|
// REQUIRES: objc_interop
|
|
// REQUIRES: concurrency
|
|
import Foundation
|
|
import ObjCConcurrency
|
|
|
|
func testSlowServer(slowServer: SlowServer) async throws {
|
|
let _: Int = await slowServer.doSomethingSlow("mail")
|
|
let _: Bool = await slowServer.checkAvailability()
|
|
let _: String = try await slowServer.findAnswer()
|
|
let _: String = await try slowServer.findAnswerFailingly()
|
|
let _: Void = await slowServer.doSomethingFun("jump")
|
|
let _: (Int) -> Void = slowServer.completionHandler
|
|
|
|
// async version
|
|
let _: Int = await slowServer.doSomethingConflicted("thinking")
|
|
|
|
// still async version...
|
|
let _: Int = slowServer.doSomethingConflicted("thinking")
|
|
// expected-error@-1{{call is 'async' but is not marked with 'await'}}
|
|
|
|
let _: String? = await try slowServer.fortune()
|
|
let _: Int = await try slowServer.magicNumber(withSeed: 42)
|
|
|
|
await slowServer.serverRestart("localhost")
|
|
await slowServer.server("localhost", atPriorityRestart: 0.8)
|
|
}
|
|
|
|
func testSlowServerSynchronous(slowServer: SlowServer) {
|
|
// synchronous version
|
|
let _: Int = slowServer.doSomethingConflicted("thinking")
|
|
}
|
|
|
|
func testSlowServerOldSchool(slowServer: SlowServer) {
|
|
slowServer.doSomethingSlow("mail") { i in
|
|
_ = i
|
|
}
|
|
}
|