| // RUN: %target-swift-frontend -Xllvm -sil-full-demangle -emit-silgen -enable-sil-ownership -primary-file %s | %FileCheck %s |
| |
| struct B { |
| var i : Int, j : Float |
| var c : C |
| } |
| |
| struct C { |
| var x : Int |
| init() { x = 17 } |
| } |
| |
| struct D { |
| var (i, j) : (Int, Double) = (2, 3.5) |
| } |
| |
| // CHECK-LABEL: sil hidden [transparent] @_T019default_constructor1DV1iSivpfi : $@convention(thin) () -> (Int, Double) |
| // CHECK: [[METATYPE:%.*]] = metatype $@thin Int.Type |
| // CHECK-NEXT: [[VALUE:%.*]] = integer_literal $Builtin.Int2048, 2 |
| // CHECK: [[FN:%.*]] = function_ref @_T0Si22_builtinIntegerLiteralSiBi2048__tcfC : $@convention(method) (Builtin.Int2048, @thin Int.Type) -> Int |
| // CHECK-NEXT: [[LEFT:%.*]] = apply [[FN]]([[VALUE]], [[METATYPE]]) : $@convention(method) (Builtin.Int2048, @thin Int.Type) -> Int |
| // CHECK-NEXT: [[METATYPE:%.*]] = metatype $@thin Double.Type |
| // CHECK-NEXT: [[VALUE:%.*]] = float_literal $Builtin.FPIEEE{{64|80}}, {{0x400C000000000000|0x4000E000000000000000}} |
| // CHECK: [[FN:%.*]] = function_ref @_T0Sd20_builtinFloatLiteralSdBf{{64|80}}__tcfC : $@convention(method) (Builtin.FPIEEE{{64|80}}, @thin Double.Type) -> Double |
| // CHECK-NEXT: [[RIGHT:%.*]] = apply [[FN]]([[VALUE]], [[METATYPE]]) : $@convention(method) (Builtin.FPIEEE{{64|80}}, @thin Double.Type) -> Double |
| // CHECK-NEXT: [[RESULT:%.*]] = tuple ([[LEFT]] : $Int, [[RIGHT]] : $Double) |
| // CHECK-NEXT: return [[RESULT]] : $(Int, Double) |
| |
| |
| // CHECK-LABEL: sil hidden @_T019default_constructor1DV{{[_0-9a-zA-Z]*}}fC : $@convention(method) (@thin D.Type) -> D |
| // CHECK: [[THISBOX:%[0-9]+]] = alloc_box ${ var D } |
| // CHECK: [[THIS:%[0-9]+]] = mark_uninit |
| // CHECK: [[PB_THIS:%.*]] = project_box [[THIS]] |
| // CHECK: [[INIT:%[0-9]+]] = function_ref @_T019default_constructor1DV1iSivpfi |
| // CHECK: [[RESULT:%[0-9]+]] = apply [[INIT]]() |
| // CHECK: [[INTVAL:%[0-9]+]] = tuple_extract [[RESULT]] : $(Int, Double), 0 |
| // CHECK: [[FLOATVAL:%[0-9]+]] = tuple_extract [[RESULT]] : $(Int, Double), 1 |
| // CHECK: [[IADDR:%[0-9]+]] = struct_element_addr [[PB_THIS]] : $*D, #D.i |
| // CHECK: assign [[INTVAL]] to [[IADDR]] |
| // CHECK: [[JADDR:%[0-9]+]] = struct_element_addr [[PB_THIS]] : $*D, #D.j |
| // CHECK: assign [[FLOATVAL]] to [[JADDR]] |
| |
| class E { |
| var i = Int64() |
| } |
| |
| // FIXME(integers): the following checks should be updated for the new way + |
| // gets invoked. <rdar://problem/29939484> |
| // XCHECK-LABEL: sil hidden [transparent] @_T019default_constructor1EC1is5Int64Vvfi : $@convention(thin) () -> Int64 |
| // XCHECK: [[FN:%.*]] = function_ref @_T0s5Int64VABycfC : $@convention(method) (@thin Int64.Type) -> Int64 |
| // XCHECK-NEXT: [[METATYPE:%.*]] = metatype $@thin Int64.Type |
| // XCHECK-NEXT: [[VALUE:%.*]] = apply [[FN]]([[METATYPE]]) : $@convention(method) (@thin Int64.Type) -> Int64 |
| // XCHECK-NEXT: return [[VALUE]] : $Int64 |
| |
| // CHECK-LABEL: sil hidden @_T019default_constructor1EC{{[_0-9a-zA-Z]*}}fc : $@convention(method) (@owned E) -> @owned E |
| // CHECK: bb0([[SELFIN:%[0-9]+]] : @owned $E) |
| // CHECK: [[SELF:%[0-9]+]] = mark_uninitialized |
| // CHECK: [[INIT:%[0-9]+]] = function_ref @_T019default_constructor1EC1is5Int64Vvpfi : $@convention(thin) () -> Int64 |
| // CHECK-NEXT: [[VALUE:%[0-9]+]] = apply [[INIT]]() : $@convention(thin) () -> Int64 |
| // CHECK-NEXT: [[BORROWED_SELF:%.*]] = begin_borrow [[SELF]] |
| // CHECK-NEXT: [[IREF:%[0-9]+]] = ref_element_addr [[BORROWED_SELF]] : $E, #E.i |
| // CHECK-NEXT: [[WRITE:%.*]] = begin_access [modify] [dynamic] [[IREF]] : $*Int64 |
| // CHECK-NEXT: assign [[VALUE]] to [[WRITE]] : $*Int64 |
| // CHECK-NEXT: end_access [[WRITE]] : $*Int64 |
| // CHECK-NEXT: end_borrow [[BORROWED_SELF]] from [[SELF]] |
| // CHECK-NEXT: [[SELF_COPY:%.*]] = copy_value [[SELF]] |
| // CHECK-NEXT: destroy_value [[SELF]] |
| // CHECK-NEXT: return [[SELF_COPY]] : $E |
| |
| class F : E { } |
| |
| // CHECK-LABEL: sil hidden @_T019default_constructor1FCACycfc : $@convention(method) (@owned F) -> @owned F |
| // CHECK: bb0([[ORIGSELF:%[0-9]+]] : @owned $F) |
| // CHECK-NEXT: [[SELF_BOX:%[0-9]+]] = alloc_box ${ var F } |
| // CHECK-NEXT: [[SELF:%[0-9]+]] = mark_uninitialized [derivedself] [[SELF_BOX]] |
| // CHECK-NEXT: [[PB:%.*]] = project_box [[SELF]] |
| // CHECK-NEXT: store [[ORIGSELF]] to [init] [[PB]] : $*F |
| // CHECK-NEXT: [[SELFP:%[0-9]+]] = load [take] [[PB]] : $*F |
| // CHECK-NEXT: [[E:%[0-9]]] = upcast [[SELFP]] : $F to $E |
| // CHECK: [[E_CTOR:%[0-9]+]] = function_ref @_T019default_constructor1ECACycfc : $@convention(method) (@owned E) -> @owned E |
| // CHECK-NEXT: [[ESELF:%[0-9]]] = apply [[E_CTOR]]([[E]]) : $@convention(method) (@owned E) -> @owned E |
| |
| // CHECK-NEXT: [[ESELFW:%[0-9]+]] = unchecked_ref_cast [[ESELF]] : $E to $F |
| // CHECK-NEXT: store [[ESELFW]] to [init] [[PB]] : $*F |
| // CHECK-NEXT: [[SELFP:%[0-9]+]] = load [copy] [[PB]] : $*F |
| // CHECK-NEXT: destroy_value [[SELF]] : ${ var F } |
| // CHECK-NEXT: return [[SELFP]] : $F |
| |
| // <rdar://problem/19780343> Default constructor for a struct with optional doesn't compile |
| |
| // This shouldn't get a default init, since it would be pointless (bar can never |
| // be reassigned). It should get a memberwise init though. |
| struct G { |
| let bar: Int32? |
| } |
| |
| // CHECK-NOT: default_constructor.G.init() |
| // CHECK-LABEL: default_constructor.G.init(bar: Swift.Optional<Swift.Int32>) |
| // CHECK-NEXT: sil hidden @_T019default_constructor1GV{{[_0-9a-zA-Z]*}}fC |
| // CHECK-NOT: default_constructor.G.init() |
| |
| struct H<T> { |
| var opt: T? |
| |
| // CHECK-LABEL: sil hidden @_T019default_constructor1HVyACyxGqd__clufC : $@convention(method) <T><U> (@in U, @thin H<T>.Type) -> @out H<T> { |
| // CHECK: [[INIT_FN:%[0-9]+]] = function_ref @_T019default_constructor1HV3optxSgvpfi : $@convention(thin) <τ_0_0> () -> @out Optional<τ_0_0> |
| // CHECK-NEXT: [[OPT_T:%[0-9]+]] = alloc_stack $Optional<T> |
| // CHECK-NEXT: apply [[INIT_FN]]<T>([[OPT_T]]) : $@convention(thin) <τ_0_0> () -> @out Optional<τ_0_0> |
| init<U>(_: U) { } |
| } |
| |
| // <rdar://problem/29605388> Member initializer for non-generic type with generic constructor doesn't compile |
| |
| struct I { |
| var x: Int = 0 |
| |
| // CHECK-LABEL: sil hidden @_T019default_constructor1IVyACxclufC : $@convention(method) <T> (@in T, @thin I.Type) -> I { |
| // CHECK: [[INIT_FN:%[0-9]+]] = function_ref @_T019default_constructor1IV1xSivpfi : $@convention(thin) () -> Int |
| // CHECK: [[RESULT:%[0-9]+]] = apply [[INIT_FN]]() : $@convention(thin) () -> Int |
| // CHECK: [[X_ADDR:%[0-9]+]] = struct_element_addr {{.*}} : $*I, #I.x |
| // CHECK: assign [[RESULT]] to [[X_ADDR]] : $*Int |
| init<T>(_: T) {} |
| } |