mirror of
https://github.com/apple/swift.git
synced 2025-12-14 20:36:38 +01:00
Type annotations for instruction operands are omitted, e.g. ``` %3 = struct $S(%1, %2) ``` Operand types are redundant anyway and were only used for sanity checking in the SIL parser. But: operand types _are_ printed if the definition of the operand value was not printed yet. This happens: * if the block with the definition appears after the block where the operand's instruction is located * if a block or instruction is printed in isolation, e.g. in a debugger The old behavior can be restored with `-Xllvm -sil-print-types`. This option is added to many existing test files which check for operand types in their check-lines.
29 lines
958 B
Swift
29 lines
958 B
Swift
// RUN: %target-swift-frontend -parse-as-library -O -module-name=test %s -Xllvm -sil-print-types -emit-sil | %FileCheck %s
|
|
// REQUIRES: optimized_stdlib,swift_stdlib_no_asserts
|
|
|
|
// REQUIRES: swift_in_compiler
|
|
|
|
final class Item {}
|
|
|
|
final public class Escaper {
|
|
var myItem: Item = Item()
|
|
|
|
@inline(never)
|
|
func update(items: [Item]) {
|
|
myItem = items[0]
|
|
}
|
|
|
|
// CHECK-LABEL: sil [noinline] {{.*}}@$s4test7EscaperC15badStuffHappensyyF : $@convention(method) (@guaranteed Escaper) -> () {
|
|
// CHECK: %2 = alloc_ref $Item
|
|
// CHECK: alloc_ref{{(_dynamic)?}} [stack] [tail_elems $Item * %{{[0-9]+}} : $Builtin.Word]{{.*}} $_ContiguousArrayStorage<{{(Item|AnyObject)}}>
|
|
// CHECK: return
|
|
@inline(never)
|
|
public func badStuffHappens() {
|
|
// Check that 'item' is not stack promoted, because it escapes to myItem.
|
|
let item = Item()
|
|
// On the other hand, the array buffer of the array literal should be stack promoted.
|
|
update(items:[item])
|
|
}
|
|
}
|
|
|