Files
swift-mirror/test/Sema/copy_expr.swift
Daniel Rodríguez Troitiño ba68faaed5 [test] Mark tests that use experimental/upcoming features as such
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.
2024-11-02 11:46:46 -07:00

100 lines
2.6 KiB
Swift

// RUN: %target-typecheck-verify-swift -disable-availability-checking -enable-experimental-feature NoImplicitCopy
// REQUIRES: swift_feature_NoImplicitCopy
class Klass {
var k: Klass? = nil
}
var global: Int = 5
func testGlobal() {
let _ = copy global
}
func testLet() {
let t = String()
let _ = copy t
}
func testVar() {
var t = String()
t = String()
let _ = copy t
}
func testExprFailureLet() {
let t = 5
// Next line is parsed as move(t) + t
let _ = copy t + t
}
func testExprFailureVar() {
var t = 5
t = 5
// Next line is parsed as move(t) + t
let _ = copy t + t
}
func letAddressOnly<T>(_ v: T) {
let t = v
let _ = copy t
}
struct StructWithField {
var k: Klass? = nil
var computedK: Klass? { nil }
}
func testLetStructAccessField() {
let t = StructWithField()
let _ = copy t.k // expected-error {{'copy' can only be applied to a local binding ('let', 'var', or parameter)}}
}
func testLetStructAccessComputedField() {
let t = StructWithField()
let _ = copy t.computedK // expected-error {{'copy' can only be applied to a local binding ('let', 'var', or parameter)}}
}
func testVarStructAccessField() {
var t = StructWithField()
t = StructWithField()
let _ = copy t.k // expected-error {{'copy' can only be applied to a local binding ('let', 'var', or parameter)}}
}
func testLetClassAccessField() {
let t = Klass()
let _ = copy t.k // expected-error {{'copy' can only be applied to a local binding ('let', 'var', or parameter)}}
}
func testVarClassAccessField() {
var t = Klass()
t = Klass()
let _ = copy t.k // expected-error {{'copy' can only be applied to a local binding ('let', 'var', or parameter)}}
}
struct MoveOnly : ~Copyable {}
func testNoMoveOnlyCopy(_ x: borrowing MoveOnly) {
let _ = copy x // expected-error {{'copy' cannot be applied to noncopyable types}}
}
func testCopyResultImmutable() {
class Klass {}
struct Test {
var k = Klass()
mutating func mutatingTest() {}
func borrowingTest() {}
consuming func consumingTest() {}
}
var t = Test()
t.mutatingTest()
copy t.borrowingTest() // expected-error {{'copy' can only be applied to a local binding ('let', 'var', or parameter)}}
(copy t).borrowingTest()
(copy t).consumingTest()
(copy t).mutatingTest() // expected-error {{cannot use mutating member on immutable value of type 'Test'}}
(copy t) = Test() // expected-error {{cannot assign to immutable expression of type 'Test'}}
copy t = Test() // expected-error {{cannot assign to immutable expression of type 'Test'}}
}