diff --git a/components/media_router/common/providers/cast/channel/enum_table.h b/components/media_router/common/providers/cast/channel/enum_table.h index fdf8941c32..cf0df1dc46 100644 --- a/components/media_router/common/providers/cast/channel/enum_table.h +++ b/components/media_router/common/providers/cast/channel/enum_table.h @@ -16,6 +16,7 @@ #include #include #include +#include #include "base/check_op.h" #include "base/notreached.h" @@ -193,7 +194,6 @@ class inline constexpr GenericEnumTableEntry(int32_t value); inline constexpr GenericEnumTableEntry(int32_t value, std::string_view str); - GenericEnumTableEntry(const GenericEnumTableEntry&) = delete; GenericEnumTableEntry& operator=(const GenericEnumTableEntry&) = delete; private: @@ -259,7 +259,6 @@ class EnumTable { constexpr Entry(E value, std::string_view str) : GenericEnumTableEntry(static_cast(value), str) {} - Entry(const Entry&) = delete; Entry& operator=(const Entry&) = delete; }; @@ -318,7 +317,7 @@ class EnumTable { if (is_sorted_) { const std::size_t index = static_cast(value); if (ANALYZER_ASSUME_TRUE(index < data_.size())) { - const auto& entry = data_.begin()[index]; + const auto& entry = data_[index]; if (ANALYZER_ASSUME_TRUE(entry.has_str())) { return entry.str(); } @@ -326,8 +325,7 @@ class EnumTable { return std::nullopt; } return GenericEnumTableEntry::FindByValue( - reinterpret_cast(data_.begin()), - data_.size(), static_cast(value)); + &data_[0], data_.size(), static_cast(value)); } // This overload of GetString is designed for cases where the argument is a @@ -355,8 +353,7 @@ class EnumTable { // enum value directly. std::optional GetEnum(std::string_view str) const { auto* entry = GenericEnumTableEntry::FindByString( - reinterpret_cast(data_.begin()), - data_.size(), str); + &data_[0], data_.size(), str); return entry ? static_cast(entry->value) : std::optional(); } @@ -368,9 +365,9 @@ class EnumTable { private: #ifdef ARCH_CPU_64_BITS - alignas(std::hardware_destructive_interference_size) + alignas(64) #endif - std::initializer_list data_; + const std::vector data_; bool is_sorted_; constexpr EnumTable(std::initializer_list data, bool is_sorted) @@ -382,8 +379,8 @@ class EnumTable { for (std::size_t i = 0; i < data.size(); i++) { for (std::size_t j = i + 1; j < data.size(); j++) { - const Entry& ei = data.begin()[i]; - const Entry& ej = data.begin()[j]; + const Entry& ei = data[i]; + const Entry& ej = data[j]; DCHECK(ei.value != ej.value) << "Found duplicate enum values at indices " << i << " and " << j; DCHECK(!(ei.has_str() && ej.has_str() && ei.str() == ej.str()))