|
3 | 3 | sil_stage raw
|
4 | 4 |
|
5 | 5 | import Swift
|
| 6 | +import Builtin |
6 | 7 |
|
7 | 8 | public class CopyableKlass {}
|
8 | 9 |
|
@@ -52,6 +53,17 @@ final class ClassContainingMoveOnly {
|
52 | 53 | var value = NonTrivialStruct()
|
53 | 54 | }
|
54 | 55 |
|
| 56 | +struct SingleTrivialFieldAndDeinit: ~Copyable { |
| 57 | + var value: Builtin.IntLiteral |
| 58 | + |
| 59 | + consuming func finalize() |
| 60 | + |
| 61 | + deinit |
| 62 | +} |
| 63 | + |
| 64 | +sil @getSingleTrivialFieldAndDeinit : $@convention(thin) () -> @owned SingleTrivialFieldAndDeinit |
| 65 | +sil @finalizeSingleTrivialFieldAndDeinit : $@convention(thin) (@owned SingleTrivialFieldAndDeinit) -> () |
| 66 | + |
55 | 67 | @_hasStorage @_hasInitialValue var varGlobal: NonTrivialStruct { get set }
|
56 | 68 | @_hasStorage @_hasInitialValue let letGlobal: NonTrivialStruct { get }
|
57 | 69 | sil_global hidden @$s23moveonly_addresschecker9varGlobalAA16NonTrivialStructVvp : $NonTrivialStruct
|
@@ -632,3 +644,36 @@ bb0:
|
632 | 644 | %22 = tuple ()
|
633 | 645 | return %22 : $()
|
634 | 646 | }
|
| 647 | + |
| 648 | +// rdar://110232973 ([move-only] Checker should distinguish in between field of single field struct |
| 649 | +// vs parent field itself (was: mutation of field in noncopyable struct should not trigger deinit)) |
| 650 | +// |
| 651 | +// Test that the SingleTrivialFieldAndDeinit aggregate is not |
| 652 | +// deinitialized when it's only field is consumed. |
| 653 | +// |
| 654 | +// CHECK-LABEL: sil hidden [ossa] @testNoFieldReinit : $@convention(thin) () -> () { |
| 655 | +// CHECK: [[ALLOC:%.*]] = alloc_stack [lexical] $SingleTrivialFieldAndDeinit |
| 656 | +// CHECK-NOT: destroy_addr [[ALLOC]] |
| 657 | +// CHECK-LABEL: } // end sil function 'testNoFieldReinit' |
| 658 | +sil hidden [ossa] @testNoFieldReinit : $@convention(thin) () -> () { |
| 659 | +bb0: |
| 660 | + %0 = alloc_stack [lexical] $SingleTrivialFieldAndDeinit, var |
| 661 | + %1 = mark_must_check [consumable_and_assignable] %0 : $*SingleTrivialFieldAndDeinit |
| 662 | + %3 = function_ref @getSingleTrivialFieldAndDeinit : $@convention(thin) () -> @owned SingleTrivialFieldAndDeinit |
| 663 | + %4 = apply %3() : $@convention(thin) () -> @owned SingleTrivialFieldAndDeinit |
| 664 | + store %4 to [init] %1 : $*SingleTrivialFieldAndDeinit |
| 665 | + %6 = integer_literal $Builtin.IntLiteral, 20 |
| 666 | + %10 = begin_access [modify] [static] %1 : $*SingleTrivialFieldAndDeinit |
| 667 | + %11 = struct_element_addr %10 : $*SingleTrivialFieldAndDeinit, #SingleTrivialFieldAndDeinit.value |
| 668 | + store %6 to [trivial] %11 : $*Builtin.IntLiteral |
| 669 | + end_access %10 : $*SingleTrivialFieldAndDeinit |
| 670 | + %14 = begin_access [deinit] [static] %1 : $*SingleTrivialFieldAndDeinit |
| 671 | + %15 = load [take] %14 : $*SingleTrivialFieldAndDeinit |
| 672 | + %16 = function_ref @finalizeSingleTrivialFieldAndDeinit : $@convention(thin) (@owned SingleTrivialFieldAndDeinit) -> () |
| 673 | + %17 = apply %16(%15) : $@convention(thin) (@owned SingleTrivialFieldAndDeinit) -> () |
| 674 | + end_access %14 : $*SingleTrivialFieldAndDeinit |
| 675 | + destroy_addr %1 : $*SingleTrivialFieldAndDeinit |
| 676 | + dealloc_stack %0 : $*SingleTrivialFieldAndDeinit |
| 677 | + %21 = tuple () |
| 678 | + return %21 : $() |
| 679 | +} |
0 commit comments