Files
swift-mirror/test/SILOptimizer/optional_of_existential.swift
Min-Yih Hsu 9a8f2ed642 [SILOptimizer][DebugInfo] Preliminary support for DIExpression in SROA and Mem2Reg
SROA and Mem2Reg now can leverage DIExpression -- op_fragment, more
specifically -- to generate correct debug info for optimized SIL. Some
important highlights:
 - The new swift::salvageDebugInfo, similar to llvm::salvageDebugInfo,
   tries to restore / transfer debug info from a deleted instruction.
   Currently I only implemented this for store instruction whose
   destination is an alloc_stack value.
 - Since we now have source-variable-specific SIL location inside a
   `debug_value` instruction (and its friends), this patch teaches
   SILCloner and SILInliner to remap the debug scope there in addition
   to debug scope of the instruction.
 - DCE now does not remove `debug_value` instruction whose associating
   with a function argument SSA value that is not used elsewhere. Since
   that SSA value will not disappear so we should keep the debug info.
2021-08-05 17:27:45 -07:00

28 lines
833 B
Swift

// RUN: %target-swift-frontend -O -module-name=test -emit-sil -primary-file %s | %FileCheck %s
protocol P { associatedtype A = Int }
protocol Q : P {}
protocol B { var x: Int { get } }
struct Y<T> {}
extension Y : B where T : Q { var x: Int { 0 }}
extension P {
var z: Int? { (Y<Self>() as? B)?.x }
}
struct X : Q {
// Check that this getter can be folded to a simple "return 0"
// CHECK-LABEL: sil hidden @$s4test1XV0A2MeSiSgvg : $@convention(method) (X) -> Optional<Int> {
// CHECK: bb0(%0 : $X):
// CHECK-NEXT: debug_value
// CHECK-NEXT: integer_literal ${{.*}}, 0
// CHECK-NEXT: struct $Int
// CHECK-NEXT: %[[ENUM:[0-9]+]] = enum $Optional<Int>, #Optional.some!enumelt
// CHECK-NEXT: return %[[ENUM]] : $Optional<Int>
// CHECK-NEXT: } // end sil function '$s4test1XV0A2MeSiSgvg'
var testMe: Int? { z }
}