]> granicus.if.org Git - llvm/commitdiff
[DWARF] Now that Optional is standard layout, put it into an union instead of splatti...
authorBenjamin Kramer <benny.kra@googlemail.com>
Tue, 31 Oct 2017 19:40:03 +0000 (19:40 +0000)
committerBenjamin Kramer <benny.kra@googlemail.com>
Tue, 31 Oct 2017 19:40:03 +0000 (19:40 +0000)
No functionality change intended.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@317028 91177308-0d34-0410-b5e6-96231b3b80d8

include/llvm/DebugInfo/DWARF/DWARFAbbreviationDeclaration.h
lib/DebugInfo/DWARF/DWARFAbbreviationDeclaration.cpp

index 84b23398b8ccd8840af83de2b55b0e3f6ee18e29..de49be5c0b5d5ad45f0b20df62ad10146f6889ab 100644 (file)
@@ -33,11 +33,8 @@ public:
       assert(isImplicitConst());
     }
     AttributeSpec(dwarf::Attribute A, dwarf::Form F, Optional<uint8_t> ByteSize)
-        : Attr(A), Form(F) {
+        : Attr(A), Form(F), ByteSize(ByteSize) {
       assert(!isImplicitConst());
-      this->ByteSize.HasByteSize = ByteSize.hasValue();
-      if (this->ByteSize.HasByteSize)
-        this->ByteSize.ByteSize = *ByteSize;
     }
 
     dwarf::Attribute Attr;
@@ -48,21 +45,17 @@ public:
     /// attributes and as value for implicit_const ones, indicated by
     /// Form == DW_FORM_implicit_const.
     /// The following cases are distinguished:
-    /// * Form != DW_FORM_implicit_const and HasByteSize is true:
+    /// * Form != DW_FORM_implicit_const and ByteSize has a value:
     ///     ByteSize contains the fixed size in bytes for the Form in this
     ///     object.
-    /// * Form != DW_FORM_implicit_const and HasByteSize is false:
+    /// * Form != DW_FORM_implicit_const and ByteSize is None:
     ///     byte size of Form either varies according to the DWARFUnit
     ///     that it is contained in or the value size varies and must be
     ///     decoded from the debug information in order to determine its size.
     /// * Form == DW_FORM_implicit_const:
     ///     Value contains value for the implicit_const attribute.
-    struct ByteSizeStorage {
-      bool HasByteSize;
-      uint8_t ByteSize;
-    };
     union {
-      ByteSizeStorage ByteSize;
+      Optional<uint8_t> ByteSize;
       int64_t Value;
     };
 
index a88dcfcf5423779540f66cf3142095cd464c9a85..1fc54d2065e1bb2dc5430b871bd97d3b230ffe44 100644 (file)
@@ -214,8 +214,8 @@ Optional<int64_t> DWARFAbbreviationDeclaration::AttributeSpec::getByteSize(
     const DWARFUnit &U) const {
   if (isImplicitConst())
     return 0;
-  if (ByteSize.HasByteSize)
-    return ByteSize.ByteSize;
+  if (ByteSize)
+    return *ByteSize;
   Optional<int64_t> S;
   auto FixedByteSize =
       DWARFFormValue::getFixedByteSize(Form, U.getFormParams());