Files
swift-mirror/test/SILOptimizer/stack-nesting-wrong-scope.swift
Erik Eckstein 7cceaff5f3 SIL: don't print operand types in textual SIL
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.
2024-11-21 18:49:52 +01:00

29 lines
1.1 KiB
Swift

// RUN: %target-swift-frontend -Xllvm -sil-print-types -emit-sil %s -Onone -Xllvm \
// RUN: -sil-print-after=allocbox-to-stack -Xllvm \
// RUN: -sil-print-functions=$s3red19ThrowAddrOnlyStructV016throwsOptionalToG0ACyxGSgSi_tcfC \
// RUN: -Xllvm -sil-print-types -Xllvm -sil-print-debuginfo -o %t -module-name red 2>&1 | %FileCheck %s
// CHECK: bb{{[0-9]+}}(%{{[0-9]+}} : @owned $any Error):
// CHECK: dealloc_stack %{{[0-9]+}} : $*ThrowAddrOnlyStruct<T>, loc {{.*}}:26:68, scope [[SCOPE:[0-9]+]]
// CHECK: br bb{{[0-9]+}}(%{{[0-9]+}} : $any Error), loc {{.*}}:26:15, scope [[SCOPE]]
protocol Patatino {
init()
}
struct ThrowAddrOnlyStruct<T : Patatino> {
var x : T
init(fail: ()) throws { x = T() }
init(failDuringDelegation: Int) throws {
try self.init(fail: ())
}
init?(throwsToOptional: Int) {
try? self.init(failDuringDelegation: throwsToOptional)
}
init(throwsOptionalToThrows: Int) throws {
self.init(throwsToOptional: throwsOptionalToThrows)!
}
init?(throwsOptionalToOptional: Int) {
try! self.init(throwsOptionalToThrows: throwsOptionalToOptional)
}
}