mirror of
https://github.com/apple/swift.git
synced 2025-12-21 12:14:44 +01:00
In particular, this fixes the size calculation for nested enums,
specifically enums within Optionals. Without this, the
reflection library computes `v` below as requiring two bytes
instead of one.
```
enum E {
case a
case b
}
let v = Optional<E>
```
This also adds a number of test cases for enums alone and
wrapped in optionals, including:
* Zero-case enums are allocated zero size and have zero extra inhabitants
* Zero-case enums in optionals also get zero size
* One-case no-payload enums are allocated zero size and have zero extra inhabitants
* One-case no-payload enums in optionals get one byte allocated and have zero extra inhabitants
* 254-case enums have only two extra inhabitants, so putting them in thrice-nested optionals requires an extra byte
* Various cases where each nested optional gets an extra byte
Resolves rdar://31154770
82 lines
3.7 KiB
Swift
82 lines
3.7 KiB
Swift
// RUN: %empty-directory(%t)
|
|
// RUN: %target-build-swift -g -lswiftSwiftReflectionTest %s -o %t/reflect_Enum_SingleCasePointerPayload
|
|
// RUN: %target-codesign %t/reflect_Enum_SingleCasePointerPayload
|
|
|
|
// RUN: %target-run %target-swift-reflection-test %t/reflect_Enum_SingleCasePointerPayload | %FileCheck %s --check-prefix=CHECK-%target-ptrsize
|
|
|
|
// REQUIRES: objc_interop
|
|
// REQUIRES: executable_test
|
|
|
|
import SwiftReflectionTest
|
|
|
|
class Marker {
|
|
let value = 1
|
|
}
|
|
|
|
enum SingleCasePointerPayloadEnum {
|
|
case only(Marker)
|
|
}
|
|
|
|
class ClassWithSingleCasePointerPayloadEnum {
|
|
var e1: SingleCasePointerPayloadEnum?
|
|
var e2: SingleCasePointerPayloadEnum = .only(Marker())
|
|
var e3: SingleCasePointerPayloadEnum? = .some(.only(Marker()))
|
|
var e4: SingleCasePointerPayloadEnum??
|
|
}
|
|
|
|
reflect(object: ClassWithSingleCasePointerPayloadEnum())
|
|
|
|
// CHECK-64: Reflecting an object.
|
|
// CHECK-64: Instance pointer in child address space: 0x{{[0-9a-fA-F]+}}
|
|
// CHECK-64: Type reference:
|
|
// CHECK-64: (class reflect_Enum_SingleCasePointerPayload.ClassWithSingleCasePointerPayloadEnum)
|
|
|
|
// CHECK-64: Type info:
|
|
// CHECK-64: (class_instance size=48 alignment=8 stride=48 num_extra_inhabitants=0 bitwise_takable=1
|
|
// CHECK-64: (field name=e1 offset=16
|
|
// CHECK-64: (single_payload_enum size=8 alignment=8 stride=8 num_extra_inhabitants=2147483646 bitwise_takable=1
|
|
// CHECK-64: (field name=some offset=0
|
|
// CHECK-64: (reference kind=strong refcounting=native))))
|
|
// CHECK-64: (field name=e2 offset=24
|
|
// CHECK-64: (reference kind=strong refcounting=native))
|
|
// CHECK-64: (field name=e3 offset=32
|
|
// CHECK-64: (single_payload_enum size=8 alignment=8 stride=8 num_extra_inhabitants=2147483646 bitwise_takable=1
|
|
// CHECK-64: (field name=some offset=0
|
|
// CHECK-64: (reference kind=strong refcounting=native))))
|
|
// CHECK-64: (field name=e4 offset=40
|
|
// CHECK-64: (single_payload_enum size=8 alignment=8 stride=8 num_extra_inhabitants=2147483645 bitwise_takable=1
|
|
// CHECK-64: (field name=some offset=0
|
|
// CHECK-64: (single_payload_enum size=8 alignment=8 stride=8 num_extra_inhabitants=2147483646 bitwise_takable=1
|
|
// CHECK-64: (field name=some offset=0
|
|
// CHECK-64: (reference kind=strong refcounting=native)))))))
|
|
|
|
// CHECK-32: Reflecting an object.
|
|
// CHECK-32: Instance pointer in child address space: 0x{{[0-9a-fA-F]+}}
|
|
// CHECK-32: Type reference:
|
|
// CHECK-32: (class reflect_Enum_SingleCasePointerPayload.ClassWithSingleCasePointerPayloadEnum)
|
|
|
|
// CHECK-32: Type info:
|
|
// CHECK-32: (class_instance size=24 alignment=4 stride=24 num_extra_inhabitants=0 bitwise_takable=1
|
|
// CHECK-32: (field name=e1 offset=8
|
|
// CHECK-32: (single_payload_enum size=4 alignment=4 stride=4 num_extra_inhabitants=4095 bitwise_takable=1
|
|
// CHECK-32: (field name=some offset=0
|
|
// CHECK-32: (reference kind=strong refcounting=native))))
|
|
// CHECK-32: (field name=e2 offset=12
|
|
// CHECK-32: (reference kind=strong refcounting=native))
|
|
// CHECK-32: (field name=e3 offset=16
|
|
// CHECK-32: (single_payload_enum size=4 alignment=4 stride=4 num_extra_inhabitants=4095 bitwise_takable=1
|
|
// CHECK-32: (field name=some offset=0
|
|
// CHECK-32: (reference kind=strong refcounting=native))))
|
|
// CHECK-32: (field name=e4 offset=20
|
|
// CHECK-32: (single_payload_enum size=4 alignment=4 stride=4 num_extra_inhabitants=4094 bitwise_takable=1
|
|
// CHECK-32: (field name=some offset=0
|
|
// CHECK-32: (single_payload_enum size=4 alignment=4 stride=4 num_extra_inhabitants=4095 bitwise_takable=1
|
|
// CHECK-32: (field name=some offset=0
|
|
// CHECK-32: (reference kind=strong refcounting=native)))))))
|
|
|
|
doneReflecting()
|
|
|
|
// CHECK-64: Done.
|
|
|
|
// CHECK-32: Done.
|