mirror of
https://github.com/apple/swift.git
synced 2025-12-14 20:36:38 +01:00
[embedded] Allow string-interpolatings in assert, assertionFailure, precondition, preconditionFailure
This commit is contained in:
@@ -38,7 +38,6 @@
|
||||
/// fails. The default is the line number where `assert(_:_:file:line:)`
|
||||
/// is called.
|
||||
@_transparent
|
||||
@_unavailableInEmbedded
|
||||
#if $Embedded
|
||||
@_disfavoredOverload
|
||||
#endif
|
||||
@@ -101,7 +100,6 @@ public func assert(
|
||||
/// fails. The default is the line number where
|
||||
/// `precondition(_:_:file:line:)` is called.
|
||||
@_transparent
|
||||
@_unavailableInEmbedded
|
||||
#if $Embedded
|
||||
@_disfavoredOverload
|
||||
#endif
|
||||
@@ -167,7 +165,6 @@ public func precondition(
|
||||
/// line number where `assertionFailure(_:file:line:)` is called.
|
||||
@inlinable
|
||||
@inline(__always)
|
||||
@_unavailableInEmbedded
|
||||
#if $Embedded
|
||||
@_disfavoredOverload
|
||||
#endif
|
||||
@@ -229,7 +226,6 @@ public func assertionFailure(
|
||||
/// - line: The line number to print along with `message`. The default is the
|
||||
/// line number where `preconditionFailure(_:file:line:)` is called.
|
||||
@_transparent
|
||||
@_unavailableInEmbedded
|
||||
#if $Embedded
|
||||
@_disfavoredOverload
|
||||
#endif
|
||||
|
||||
65
test/embedded/traps-string-interpolations.swift
Normal file
65
test/embedded/traps-string-interpolations.swift
Normal file
@@ -0,0 +1,65 @@
|
||||
// RUN: %empty-directory(%t)
|
||||
// RUN: %target-swift-frontend %s -enable-experimental-feature Embedded -emit-ir -Osize -disable-llvm-merge-functions-pass | %FileCheck %s
|
||||
|
||||
// REQUIRES: swift_in_compiler
|
||||
// REQUIRES: optimized_stdlib
|
||||
// REQUIRES: OS=macosx || OS=linux-gnu
|
||||
// REQUIRES: swift_feature_Embedded
|
||||
|
||||
public func test1(i: Int) {
|
||||
fatalError("\(i) is not 42")
|
||||
}
|
||||
|
||||
public func test2(i: Int) {
|
||||
assert(i == 42, "\(i) is not 42")
|
||||
}
|
||||
|
||||
public func test3(i: Int) {
|
||||
precondition(i == 42, "\(i) is not 42")
|
||||
}
|
||||
|
||||
public func test4(i: Int) {
|
||||
assertionFailure("\(i) is not 42")
|
||||
}
|
||||
|
||||
public func test5(i: Int) {
|
||||
preconditionFailure("\(i) is not 42")
|
||||
}
|
||||
|
||||
// CHECK: define {{.*}}@"$e4main5test11iySi_tF"
|
||||
// CHECK-NEXT: entry:
|
||||
// CHECK-NEXT: tail call void asm sideeffect ""
|
||||
// CHECK-NEXT: tail call void @llvm.trap()
|
||||
// CHECK-NEXT: unreachable
|
||||
// CHECK-NEXT: }
|
||||
|
||||
// CHECK: define {{.*}}@"$e4main5test21iySi_tF"
|
||||
// CHECK-NEXT: entry:
|
||||
// CHECK-NEXT: ret void
|
||||
// CHECK-NEXT: }
|
||||
|
||||
// CHECK: define {{.*}}@"$e4main5test31iySi_tF"
|
||||
// CHECK-NEXT: entry:
|
||||
// CHECK-NEXT: %.not = icmp eq i64 %0, 42
|
||||
// CHECK-NEXT: br i1 %.not, label %1, label %2
|
||||
// CHECK-EMPTY:
|
||||
// CHECK-NEXT: 1:
|
||||
// CHECK-NEXT: ret void
|
||||
// CHECK-EMPTY:
|
||||
// CHECK-NEXT: 2:
|
||||
// CHECK-NEXT: tail call void asm sideeffect ""
|
||||
// CHECK-NEXT: tail call void @llvm.trap()
|
||||
// CHECK-NEXT: unreachable
|
||||
// CHECK-NEXT: }
|
||||
|
||||
// CHECK: define {{.*}}@"$e4main5test41iySi_tF"
|
||||
// CHECK-NEXT: entry:
|
||||
// CHECK-NEXT: ret void
|
||||
// CHECK-NEXT: }
|
||||
|
||||
// CHECK: define {{.*}}@"$e4main5test51iySi_tF"
|
||||
// CHECK-NEXT: entry:
|
||||
// CHECK-NEXT: tail call void asm sideeffect ""
|
||||
// CHECK-NEXT: tail call void @llvm.trap()
|
||||
// CHECK-NEXT: unreachable
|
||||
// CHECK-NEXT: }
|
||||
Reference in New Issue
Block a user