mirror of
https://github.com/apple/swift.git
synced 2025-12-14 20:36:38 +01:00
Find all the usages of `--enable-experimental-feature` or `--enable-upcoming-feature` in the tests and replace some of the `REQUIRES: asserts` to use `REQUIRES: swift-feature-Foo` instead, which should correctly apply to depending on the asserts/noasserts mode of the toolchain for each feature. Remove some comments that talked about enabling asserts since they don't apply anymore (but I might had miss some). All this was done with an automated script, so some formatting weirdness might happen, but I hope I fixed most of those. There might be some tests that were `REQUIRES: asserts` that might run in `noasserts` toolchains now. This will normally be because their feature went from experimental to upcoming/base and the tests were not updated.
48 lines
1.9 KiB
Swift
48 lines
1.9 KiB
Swift
// RUN: %target-swift-frontend -plugin-path %swift-plugin-dir -strict-concurrency=targeted -target %target-swift-5.1-abi-triple -emit-sil -verify -o /dev/null %s
|
|
// RUN: %target-swift-frontend -plugin-path %swift-plugin-dir -strict-concurrency=complete -verify-additional-prefix complete- -target %target-swift-5.1-abi-triple -emit-sil -verify -o /dev/null %s
|
|
// RUN: %target-swift-frontend -plugin-path %swift-plugin-dir -strict-concurrency=complete -verify-additional-prefix complete- -target %target-swift-5.1-abi-triple -emit-sil -verify -o /dev/null %s -enable-upcoming-feature RegionBasedIsolation
|
|
|
|
// REQUIRES: concurrency
|
|
// REQUIRES: swift_feature_RegionBasedIsolation
|
|
|
|
@available(SwiftStdlib 5.1, *)
|
|
struct TL {
|
|
@TaskLocal // expected-note{{in expansion of macro 'TaskLocal' on static property 'number' here}}
|
|
static var number: Int = 0
|
|
|
|
@TaskLocal
|
|
static var someNil: Int?
|
|
|
|
// expected-note@+1{{in expansion of macro 'TaskLocal' on static property 'noValue' here}}
|
|
@TaskLocal // expected-error{{@TaskLocal' property must have default value, or be optional}}
|
|
static var noValue: Int // expected-note{{'noValue' declared here}}
|
|
|
|
@TaskLocal // expected-error{{'@TaskLocal' can only be applied to 'static' property}}
|
|
var notStatic: String?
|
|
}
|
|
|
|
@TaskLocal
|
|
var global: Int = 0
|
|
|
|
class NotSendable {}
|
|
|
|
@available(SwiftStdlib 5.1, *)
|
|
func test () async {
|
|
TL.number = 10 // expected-error{{cannot assign to property: 'number' is a get-only property}}
|
|
|
|
TL.$number = 10 // expected-error{{cannot assign value of type 'Int' to type 'TaskLocal<Int>'}}
|
|
// expected-error@-1{{cannot assign to property: '$number' is a 'let' constant}}
|
|
|
|
let _: Int = TL.number
|
|
let _: Int = TL.$number.get()
|
|
}
|
|
|
|
@TaskLocal // expected-error{{'accessor' macro cannot be attached to global function ('test')}}
|
|
func test() {}
|
|
|
|
class X {
|
|
@TaskLocal // expected-error{{'accessor' macro cannot be attached to static method ('test')}}
|
|
static func test() {
|
|
}
|
|
}
|