mirror of
https://github.com/RGBCube/serenity
synced 2025-07-27 04:27:45 +00:00
MACAddress: AK::Array as member variable instead of C-array
Problem: - C-style arrays do not automatically provide bounds checking and are less type safe overall. - `__builtin_memcmp` is not a constant expression in the current gcc. Solution: - Change private m_data to be AK::Array. - Eliminate constructor from C-style array. - Change users of the C-style array constructor to use the default constructor. - Change `operator==()` to be a hand-written comparison loop and let the optimizer figure out to use `memcmp`.
This commit is contained in:
parent
700fe315cf
commit
bdf3baa8ac
4 changed files with 39 additions and 23 deletions
|
@ -26,22 +26,18 @@
|
|||
|
||||
#pragma once
|
||||
|
||||
#include <AK/Array.h>
|
||||
#include <AK/Assertions.h>
|
||||
#include <AK/String.h>
|
||||
#include <AK/Types.h>
|
||||
|
||||
class [[gnu::packed]] MACAddress
|
||||
{
|
||||
static constexpr size_t s_mac_address_length = 6u;
|
||||
|
||||
public:
|
||||
constexpr MACAddress() = default;
|
||||
|
||||
constexpr MACAddress(const u8 data[6])
|
||||
{
|
||||
for (auto i = 0u; i < sizeof(m_data); ++i) {
|
||||
m_data[i] = data[i];
|
||||
}
|
||||
}
|
||||
|
||||
constexpr MACAddress(u8 a, u8 b, u8 c, u8 d, u8 e, u8 f)
|
||||
{
|
||||
m_data[0] = a;
|
||||
|
@ -54,15 +50,26 @@ public:
|
|||
|
||||
constexpr ~MACAddress() = default;
|
||||
|
||||
constexpr u8 operator[](int i) const
|
||||
constexpr const u8& operator[](unsigned i) const
|
||||
{
|
||||
ASSERT(i >= 0 && i < 6);
|
||||
ASSERT(i < s_mac_address_length);
|
||||
return m_data[i];
|
||||
}
|
||||
|
||||
constexpr u8& operator[](unsigned i)
|
||||
{
|
||||
ASSERT(i < s_mac_address_length);
|
||||
return m_data[i];
|
||||
}
|
||||
|
||||
constexpr bool operator==(const MACAddress& other) const
|
||||
{
|
||||
return !__builtin_memcmp(m_data, other.m_data, sizeof(m_data));
|
||||
for (auto i = 0u; i < m_data.size(); ++i) {
|
||||
if (m_data[i] != other.m_data[i]) {
|
||||
return false;
|
||||
}
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
String to_string() const
|
||||
|
@ -76,10 +83,10 @@ public:
|
|||
}
|
||||
|
||||
private:
|
||||
u8 m_data[6] {};
|
||||
AK::Array<u8, s_mac_address_length> m_data {};
|
||||
};
|
||||
|
||||
static_assert(sizeof(MACAddress) == 6);
|
||||
static_assert(sizeof(MACAddress) == 6u);
|
||||
|
||||
namespace AK {
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue