mirror of
https://github.com/apple/swift.git
synced 2025-12-14 20:36:38 +01:00
Out of an abundance of caution, we: 1. Left in parsing support for transferring but internally made it rely on the internals of sending. 2. Added a warning to tell people that transferring was going to be removed very soon. Now that we have given people some time, remove support for parsing transferring. rdar://130253724
59 lines
2.1 KiB
Swift
59 lines
2.1 KiB
Swift
// RUN: %empty-directory(%t)
|
|
// RUN: %target-build-swift -strict-concurrency=complete -Xfrontend -disable-availability-checking -parse-stdlib %s -module-name main -o %t/a.out
|
|
// RUN: %target-codesign %t/a.out
|
|
// RUN: %target-run %t/a.out
|
|
|
|
// REQUIRES: executable_test
|
|
// REQUIRES: concurrency
|
|
// REQUIRES: asserts
|
|
|
|
// UNSUPPORTED: use_os_stdlib
|
|
// UNSUPPORTED: back_deployment_runtime
|
|
|
|
import Swift
|
|
import StdlibUnittest
|
|
import _Concurrency
|
|
|
|
// TODO: Once sending is enabled by default, move these into
|
|
// demangleToMetadata.swift.
|
|
|
|
class Klass {}
|
|
|
|
let DemangleToMetadataTests = TestSuite("DemangleToMetadata")
|
|
|
|
if #available(SwiftStdlib 6.0, *) {
|
|
DemangleToMetadataTests.test("sending parameter") {
|
|
typealias Fn = (sending Klass) -> Void
|
|
expectEqual("y4main5KlassCnYuc", _mangledTypeName(Fn.self)!)
|
|
expectEqual(Fn.self, _typeByName("y4main5KlassCnYuc")!)
|
|
|
|
typealias Fn2 = (sending Klass, sending Klass) -> Void
|
|
expectEqual("y4main5KlassCnYu_ACnYutc", _mangledTypeName(Fn2.self)!)
|
|
expectEqual(Fn2.self, _typeByName("y4main5KlassCnYu_ACnYutc")!)
|
|
|
|
typealias Fn3 = (sending (Klass, Klass)) -> Void
|
|
expectEqual("y4main5KlassC_ACtnYuc", _mangledTypeName(Fn3.self)!)
|
|
expectEqual(Fn3.self, _typeByName("y4main5KlassC_ACtnYuc")!)
|
|
}
|
|
|
|
DemangleToMetadataTests.test("sending result") {
|
|
typealias Fn = (Klass) -> sending Klass
|
|
expectEqual("4main5KlassCACYTc", _mangledTypeName(Fn.self)!)
|
|
expectEqual(Fn.self, _typeByName("4main5KlassCACYTc")!)
|
|
|
|
typealias Fn2 = (sending Klass, sending Klass) -> sending Klass
|
|
expectEqual("4main5KlassCACnYu_ACnYutYTc", _mangledTypeName(Fn2.self)!)
|
|
expectEqual(Fn2.self, _typeByName("4main5KlassCACnYu_ACnYutYTc")!)
|
|
|
|
typealias Fn3 = (sending (Klass, Klass)) -> sending (Klass, Klass)
|
|
expectEqual("4main5KlassC_ACtAC_ACtnYuYTc", _mangledTypeName(Fn3.self)!)
|
|
expectEqual(Fn3.self, _typeByName("4main5KlassC_ACtAC_ACtnYuYTc")!)
|
|
|
|
typealias Fn4 = () -> sending Klass
|
|
expectEqual("4main5KlassCyYTc", _mangledTypeName(Fn4.self)!)
|
|
expectEqual(Fn4.self, _typeByName("4main5KlassCyYTc")!)
|
|
}
|
|
}
|
|
|
|
runAllTests()
|