Files
swift-mirror/test/embedded/static-string-interpolation.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

60 lines
1.8 KiB
Swift

// RUN: %target-run-simple-swift(-enable-experimental-feature Embedded -Xfrontend -throws-as-traps -parse-as-library -runtime-compatibility-version none -wmo -Xfrontend -disable-objc-interop) | %FileCheck %s
// REQUIRES: swift_in_compiler
// REQUIRES: executable_test
// REQUIRES: optimized_stdlib
// REQUIRES: OS=macosx || OS=linux-gnu
// REQUIRES: swift_feature_Embedded
public struct MyInterpolation : StringInterpolationProtocol {
public typealias StringLiteralType = StaticString
public init(literalCapacity: Int, interpolationCount: Int) {}
var literalCount = 0
var interpolationCount = 0
public mutating func appendLiteral(_ literal: StaticString) {
print("appendLiteral")
literalCount += 1
}
public mutating func appendInterpolation<T>(_ value: @autoclosure @escaping () -> T) {
print("appendInterpolation<T>")
interpolationCount += 1
}
}
public struct MyMessage : ExpressibleByStringInterpolation {
public typealias StringInterpolation = MyInterpolation
var interpolation: MyInterpolation
public init(stringInterpolation: MyInterpolation) {
self.interpolation = stringInterpolation
}
public init(stringLiteral value: StaticString) {
self.interpolation = MyInterpolation(literalCapacity: 0, interpolationCount: 0)
self.interpolation.appendLiteral(value)
}
}
public func print_interpolation(_ message: MyMessage) {
print(message.interpolation.literalCount)
print(message.interpolation.interpolationCount)
}
@main
struct Main {
static func main() {
print_interpolation("hello \(42) \(123) abc")
}
}
// CHECK: appendLiteral
// CHECK: appendInterpolation<T>
// CHECK: appendLiteral
// CHECK: appendInterpolation<T>
// CHECK: appendLiteral
// CHECK: 3
// CHECK: 2