mirror of
https://github.com/apple/swift.git
synced 2025-12-14 20:36:38 +01:00
Usually there _must_ be a read from a consuming in-argument, because the function has to consume the argument. But in the special case if all control paths end up in an `unreachable`, the consuming read might have been dead-code eliminated. Therefore make sure to add the read-effect in any case. Otherwise it can result in memory lifetime failures at a call site. fixes a memory lifetime failure rdar://134881045
20 lines
646 B
Swift
20 lines
646 B
Swift
// RUN: %target-swift-frontend -O -Xllvm -sil-disable-pass=function-signature-opts -emit-sil -primary-file %s | %FileCheck %s
|
|
|
|
public struct S {
|
|
@inline(never)
|
|
init<T>(_ t: T) {
|
|
fatalError()
|
|
}
|
|
}
|
|
|
|
// check that this doesn't cause a memory lifetime failure
|
|
|
|
// CHECK-LABEL: sil @$s22generic_specialization6testityAA1SVSSF :
|
|
// CHECK: [[F:%.*]] = function_ref @$s22generic_specialization1SVyACxclufCSS_Tt0g5 :
|
|
// CHECK: = apply [[F]](%0) : $@convention(thin) (@owned String) -> S
|
|
// CHECK: } // end sil function '$s22generic_specialization6testityAA1SVSSF'
|
|
public func testit(_ s: String) -> S {
|
|
return S(s)
|
|
}
|
|
|