blob: 39b3d8b06d3776fb9ea51dd965a6956744e1f95b [file] [log] [blame]
// RUN: %target-swift-frontend -enable-experimental-property-behaviors -emit-silgen -enable-sil-ownership %s | %FileCheck %s
protocol diBehavior {
associatedtype Value
var storage: Value { get set }
}
extension diBehavior {
var value: Value {
get { }
set { }
}
static func initStorage(_ initial: Value) -> Value { }
}
func whack<T>(_ x: inout T) {}
struct Foo {
var x: Int __behavior diBehavior
// FIXME: Hack because we can't find the synthesized associated type witness
// during witness matching.
typealias Value = Int
// TODO
// var xx: (Int, Int) __behavior diBehavior
// CHECK-LABEL: sil hidden @_T022property_behavior_init3FooV{{[_0-9a-zA-Z]*}}fC
// CHECK: bb0([[X:%.*]] : @trivial $Int,
init(x: Int) {
// CHECK: [[MARKED_SELF_BOX:%.*]] = mark_uninitialized [rootself]
// CHECK: [[PB_BOX:%.*]] = project_box [[MARKED_SELF_BOX]]
// CHECK: [[UNINIT_STORAGE:%.*]] = struct_element_addr [[PB_BOX]]
// CHECK: [[UNINIT_BEHAVIOR:%.*]] = mark_uninitialized_behavior {{.*}}<Foo>([[UNINIT_STORAGE]]) : {{.*}}, {{%.*}}([[PB_BOX]])
// Pure assignments undergo DI analysis so assign to the marking proxy.
// CHECK: assign [[X]] to [[UNINIT_BEHAVIOR]]
self.x = x
// CHECK: assign [[X]] to [[UNINIT_BEHAVIOR]]
self.x = x
// Reads or inouts use the accessors normally.
// CHECK: [[READ:%.*]] = begin_access [read] [unknown] [[PB_BOX]]
// CHECK: [[SELF:%.*]] = load [trivial] [[READ]]
// CHECK: [[GETTER:%.*]] = function_ref @_T022property_behavior_init3FooV1xSivg
// CHECK: apply [[GETTER]]([[SELF]])
_ = self.x
// CHECK: [[WHACK:%.*]] = function_ref @_T022property_behavior_init5whackyxzlF
// CHECK: [[WRITE:%.*]] = begin_access [modify] [unknown] [[PB_BOX]]
// CHECK: [[INOUT:%.*]] = alloc_stack
// CHECK: [[SELF:%.*]] = load [trivial] [[WRITE]]
// CHECK: [[GETTER:%.*]] = function_ref @_T022property_behavior_init3FooV1xSivg
// CHECK: [[VALUE:%.*]] = apply [[GETTER]]([[SELF]])
// CHECK: store [[VALUE]] to [trivial] [[INOUT]]
// CHECK: apply [[WHACK]]<Int>([[INOUT]])
// CHECK: [[VALUE:%.*]] = load [trivial] [[INOUT]]
// CHECK: [[SETTER:%.*]] = function_ref @_T022property_behavior_init3FooV1xSivs
// CHECK: apply [[SETTER]]([[VALUE]], [[WRITE]])
whack(&self.x)
}
}