Files
swift-mirror/test/SILOptimizer/moveonly_generics_complex.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

66 lines
1.7 KiB
Swift

// RUN: %target-swift-frontend \
// RUN: -emit-sil -verify \
// RUN: %s \
// RUN: -enable-experimental-feature BuiltinModule \
// RUN: -sil-verify-all
// REQUIRES: swift_feature_BuiltinModule
import Builtin
enum MyLittleLayout<T : ~Copyable> {
@_transparent
static var size: Int {
return Int(Builtin.sizeof(T.self))
}
@_transparent
static var stride: Int {
return Int(Builtin.strideof(T.self))
}
}
enum MyLittleResult<Success : ~Copyable, Failure : Error> : ~Copyable {
case success(Success)
case failure(Failure)
}
@usableFromInline
@_alwaysEmitIntoClient
@inline(__always)
func _rethrowsViaClosure<R : ~Copyable>(_ fn: () throws -> R) rethrows -> R {
return try fn()
}
func _withUnprotectedUnsafeTemporaryAllocation<T: ~Copyable, R: ~Copyable>(
of type: T.Type,
capacity: Int,
alignment: Int,
_ body: (Builtin.RawPointer) throws -> R
) rethrows -> R {
let result: MyLittleResult<R, Error>
#if $BuiltinUnprotectedStackAlloc
let stackAddress = Builtin.unprotectedStackAlloc(
capacity._builtinWordValue,
MyLittleLayout<T>.stride._builtinWordValue,
alignment._builtinWordValue
)
#else
let stackAddress = Builtin.stackAlloc(
capacity._builtinWordValue,
MyLittleLayout<T>.stride._builtinWordValue,
alignment._builtinWordValue
)
#endif
do {
result = .success(try body(stackAddress))
Builtin.stackDealloc(stackAddress)
} catch {
result = .failure(error)
Builtin.stackDealloc(stackAddress)
}
switch consume result {
case .success(let success): return success
case .failure(let error): return try _rethrowsViaClosure { throw error }
}
}