Maintenance
Some checks failed
Bigfoot / Build & Test Debug with ./ConanProfiles/clang (Unity Build: OFF) (push) Failing after 5m22s
Bigfoot / Build & Test Debug with ./ConanProfiles/clang_asan (Unity Build: OFF) (push) Has been cancelled
Bigfoot / Build & Test Debug with ./ConanProfiles/clang_asan (Unity Build: ON) (push) Has been cancelled
Bigfoot / Build & Test RelWithDebInfo with ./ConanProfiles/clang (Unity Build: OFF) (push) Has been cancelled
Bigfoot / Build & Test RelWithDebInfo with ./ConanProfiles/clang (Unity Build: ON) (push) Has been cancelled
Bigfoot / Build & Test RelWithDebInfo with ./ConanProfiles/clang_asan (Unity Build: OFF) (push) Has been cancelled
Bigfoot / Build & Test RelWithDebInfo with ./ConanProfiles/clang_asan (Unity Build: ON) (push) Has been cancelled
Bigfoot / Build & Test Release with ./ConanProfiles/clang (Unity Build: OFF) (push) Has been cancelled
Bigfoot / Build & Test Release with ./ConanProfiles/clang (Unity Build: ON) (push) Has been cancelled
Bigfoot / Build & Test Release with ./ConanProfiles/clang_asan (Unity Build: OFF) (push) Has been cancelled
Bigfoot / Build & Test Release with ./ConanProfiles/clang_asan (Unity Build: ON) (push) Has been cancelled
Bigfoot / Clang Format Checks (push) Has been cancelled
Bigfoot / Build & Test Debug with ./ConanProfiles/clang (Unity Build: ON) (push) Has been cancelled

This commit is contained in:
2026-05-16 17:39:58 +02:00
parent bb279bb212
commit a343d65598
7 changed files with 71 additions and 34 deletions

View File

@@ -34,19 +34,33 @@ class UUID
UUID(const UUID& p_uuid) = default; UUID(const UUID& p_uuid) = default;
UUID(UUID&& p_uuid) noexcept = default; UUID(UUID&& p_uuid) noexcept = default;
/**
* Gets the raw bytes of a UUID
*
* \return A view to the raw bytes
*/
[[nodiscard]]
std::span<const std::byte, UUID_BYTE_SIZE> ToBytes() const;
/**
* Gets the string representation of a UUID
*
* \return A string representing the UUID
*/
[[nodiscard]]
std::string ToString() const;
~UUID() = default; ~UUID() = default;
operator std::span<const std::byte, UUID_BYTE_SIZE>() const;
operator std::string() const;
operator bool() const; operator bool() const;
UUID& operator=(const UUID& p_uuid) = default; UUID& operator=(const UUID& p_uuid) = default;
UUID& operator=(UUID&& p_uuid) noexcept = default; UUID& operator=(UUID&& p_uuid) noexcept = default;
[[nodiscard]] [[nodiscard]]
bool operator==(const UUID& p_uuid) const = default; bool operator==(const UUID& p_uuid) const;
[[nodiscard]] [[nodiscard]]
bool operator<(const UUID& p_uuid) const = default; bool operator<(const UUID& p_uuid) const;
private: private:
/** /**
@@ -130,7 +144,7 @@ struct fmtquill::formatter<Bigfoot::UUID>
auto format(const Bigfoot::UUID& p_uuid, format_context& ctx) const auto format(const Bigfoot::UUID& p_uuid, format_context& ctx) const
{ {
return fmtquill::format_to(ctx.out(), "{}", static_cast<std::string>(p_uuid)); return fmtquill::format_to(ctx.out(), "{}", p_uuid.ToString());
} }
}; };

View File

@@ -43,14 +43,14 @@ UUID::UUID(const std::span<const std::byte, UUID_BYTE_SIZE> p_raw)
/****************************************************************************************/ /****************************************************************************************/
UUID::operator std::span<const std::byte, UUID::UUID_BYTE_SIZE>() const std::span<const std::byte, UUID::UUID_BYTE_SIZE> UUID::ToBytes() const
{ {
return m_uuid.as_bytes(); return m_uuid.as_bytes();
} }
/****************************************************************************************/ /****************************************************************************************/
UUID::operator std::string() const std::string UUID::ToString() const
{ {
return uuids::to_string(m_uuid); return uuids::to_string(m_uuid);
} }
@@ -62,6 +62,18 @@ UUID::operator bool() const
return *this != NULL_UUID; return *this != NULL_UUID;
} }
bool UUID::operator==(const UUID& p_uuid) const
{
return m_uuid == p_uuid.m_uuid;
}
/****************************************************************************************/
bool UUID::operator<(const UUID& p_uuid) const
{
return m_uuid < p_uuid.m_uuid;
}
/****************************************************************************************/ /****************************************************************************************/
std::mt19937 UUID::GetRandomGenerator() std::mt19937 UUID::GetRandomGenerator()
@@ -87,7 +99,7 @@ namespace flatbuffers
{ {
Flat::Bigfoot::UUID Pack(const Bigfoot::UUID& p_uuid) Flat::Bigfoot::UUID Pack(const Bigfoot::UUID& p_uuid)
{ {
const std::span<const std::byte, Bigfoot::UUID::UUID_BYTE_SIZE> bytes = p_uuid; const std::span<const std::byte, Bigfoot::UUID::UUID_BYTE_SIZE> bytes = p_uuid.ToBytes();
return Flat::Bigfoot::UUID { return Flat::Bigfoot::UUID {
std::span<const std::uint8_t, Bigfoot::UUID::UUID_BYTE_SIZE> {reinterpret_cast<const std::uint8_t*>(bytes.data()), std::span<const std::uint8_t, Bigfoot::UUID::UUID_BYTE_SIZE> {reinterpret_cast<const std::uint8_t*>(bytes.data()),
bytes.size()}}; bytes.size()}};

View File

@@ -86,13 +86,24 @@ class Version
return static_cast<std::uint8_t>(m_combined & mask); return static_cast<std::uint8_t>(m_combined & mask);
} }
/**
* Gets the raw Version
*
* \return the raw version
*/
[[nodiscard]] [[nodiscard]]
constexpr operator std::uint32_t() const constexpr std::uint32_t Raw() const
{ {
return m_combined; return m_combined;
} }
operator std::string() const; /**
* Gets the string representation of the Version
*
* \return The string
*/
[[nodiscard]]
std::string ToString() const;
constexpr Version& operator=(const Version& p_version) = default; constexpr Version& operator=(const Version& p_version) = default;
constexpr Version& operator=(Version&& p_version) = default; constexpr Version& operator=(Version&& p_version) = default;
@@ -123,7 +134,7 @@ struct std::formatter<Bigfoot::Version>
template<typename FormatContext> template<typename FormatContext>
auto format(const Bigfoot::Version& p_version, FormatContext& p_context) const auto format(const Bigfoot::Version& p_version, FormatContext& p_context) const
{ {
return std::format_to(p_context.out(), "{}", static_cast<std::string>(p_version)); return std::format_to(p_context.out(), "{}", p_version.ToString());
} }
}; };
#endif #endif

View File

@@ -8,7 +8,7 @@
namespace Bigfoot namespace Bigfoot
{ {
Version::operator std::string() const std::string Version::ToString() const
{ {
return std::format("{}.{}.{}", GetMajor(), GetMinor(), GetPatch()); return std::format("{}.{}.{}", GetMajor(), GetMinor(), GetPatch());
} }

View File

@@ -53,37 +53,37 @@ TEST_F(BigFileFixture, BigFileManipulation)
BigFile::Request assetHeaderRequest { BigFile::Request assetHeaderRequest {
m_bigFile, m_bigFile,
"INSERT INTO AssetHeader (UUID, Name, TypeID, TypeName) VALUES(?, ?, ?, ?)"}; "INSERT INTO AssetHeader (UUID, Name, TypeID, TypeName) VALUES(?, ?, ?, ?)"};
assetHeaderRequest.Bind(1, static_cast<std::span<const std::byte, UUID::UUID_BYTE_SIZE>>(uuid)); assetHeaderRequest.Bind(1, uuid.ToBytes());
assetHeaderRequest.Bind(2, "Test"); assetHeaderRequest.Bind(2, "Test");
assetHeaderRequest.Bind(3, typeIDRef); assetHeaderRequest.Bind(3, typeIDRef);
assetHeaderRequest.Bind(4, "TypeTest"); assetHeaderRequest.Bind(4, "TypeTest");
BigFile::Request assetRequest {m_bigFile, "INSERT INTO Asset (UUID, Asset) VALUES(?, ?)"}; BigFile::Request assetRequest {m_bigFile, "INSERT INTO Asset (UUID, Asset) VALUES(?, ?)"};
assetRequest.Bind(1, static_cast<std::span<const std::byte, UUID::UUID_BYTE_SIZE>>(uuid)); assetRequest.Bind(1, uuid.ToBytes());
assetRequest.Bind(2, blob); assetRequest.Bind(2, blob);
BigFile::Request assetHeaderRequest2 { BigFile::Request assetHeaderRequest2 {
m_bigFile, m_bigFile,
"INSERT INTO AssetHeader (UUID, Name, TypeID, TypeName) VALUES(?, ?, ?, ?)"}; "INSERT INTO AssetHeader (UUID, Name, TypeID, TypeName) VALUES(?, ?, ?, ?)"};
assetHeaderRequest2.Bind(1, static_cast<std::span<const std::byte, UUID::UUID_BYTE_SIZE>>(uuid2)); assetHeaderRequest2.Bind(1, uuid2.ToBytes());
assetHeaderRequest2.Bind(2, "Test2"); assetHeaderRequest2.Bind(2, "Test2");
assetHeaderRequest2.Bind(3, typeIDRef); assetHeaderRequest2.Bind(3, typeIDRef);
assetHeaderRequest2.Bind(4, "TypeTest"); assetHeaderRequest2.Bind(4, "TypeTest");
BigFile::Request assetRequest2 {m_bigFile, "INSERT INTO Asset (UUID, Asset) VALUES(?, ?)"}; BigFile::Request assetRequest2 {m_bigFile, "INSERT INTO Asset (UUID, Asset) VALUES(?, ?)"};
assetRequest2.Bind(1, static_cast<std::span<const std::byte, UUID::UUID_BYTE_SIZE>>(uuid2)); assetRequest2.Bind(1, uuid2.ToBytes());
assetRequest2.Bind(2, blob3); assetRequest2.Bind(2, blob3);
BigFile::Request assetHeaderRequest3 { BigFile::Request assetHeaderRequest3 {
m_bigFile, m_bigFile,
"INSERT INTO AssetHeader (UUID, Name, TypeID, TypeName) VALUES(?, ?, ?, ?)"}; "INSERT INTO AssetHeader (UUID, Name, TypeID, TypeName) VALUES(?, ?, ?, ?)"};
assetHeaderRequest3.Bind(1, static_cast<std::span<const std::byte, UUID::UUID_BYTE_SIZE>>(uuid3)); assetHeaderRequest3.Bind(1, uuid3.ToBytes());
assetHeaderRequest3.Bind(2, "Test3"); assetHeaderRequest3.Bind(2, "Test3");
assetHeaderRequest3.Bind(3, typeIDRef); assetHeaderRequest3.Bind(3, typeIDRef);
assetHeaderRequest3.Bind(4, "TypeTest"); assetHeaderRequest3.Bind(4, "TypeTest");
BigFile::Request assetRequest3 {m_bigFile, "INSERT INTO Asset (UUID, Asset) VALUES(?, ?)"}; BigFile::Request assetRequest3 {m_bigFile, "INSERT INTO Asset (UUID, Asset) VALUES(?, ?)"};
assetRequest3.Bind(1, static_cast<std::span<const std::byte, UUID::UUID_BYTE_SIZE>>(uuid3)); assetRequest3.Bind(1, uuid3.ToBytes());
assetRequest3.Bind(2, blob4); assetRequest3.Bind(2, blob4);
m_bigFile.BeginTransaction(); m_bigFile.BeginTransaction();
@@ -108,7 +108,7 @@ TEST_F(BigFileFixture, BigFileManipulation)
{ {
BigFile::Request updateAsset {m_bigFile, "UPDATE Asset SET Asset = ? WHERE UUID = ?"}; BigFile::Request updateAsset {m_bigFile, "UPDATE Asset SET Asset = ? WHERE UUID = ?"};
updateAsset.Bind(1, blob2); updateAsset.Bind(1, blob2);
updateAsset.Bind(2, static_cast<std::span<const std::byte, UUID::UUID_BYTE_SIZE>>(uuid)); updateAsset.Bind(2, uuid.ToBytes());
m_bigFile.BeginTransaction(); m_bigFile.BeginTransaction();
std::uint32_t updateAssetChangedCount = updateAsset.Execute(); std::uint32_t updateAssetChangedCount = updateAsset.Execute();
@@ -120,7 +120,7 @@ TEST_F(BigFileFixture, BigFileManipulation)
BigFile::Request request { BigFile::Request request {
m_bigFile, m_bigFile,
"SELECT Name, TypeID, TypeName, CreateTime, ModificationTime FROM AssetHeader WHERE UUID = ?"}; "SELECT Name, TypeID, TypeName, CreateTime, ModificationTime FROM AssetHeader WHERE UUID = ?"};
request.Bind(1, static_cast<std::span<const std::byte, UUID::UUID_BYTE_SIZE>>(uuid)); request.Bind(1, uuid.ToBytes());
const bool get = request.Step(); const bool get = request.Step();
EXPECT_TRUE(get); EXPECT_TRUE(get);

View File

@@ -43,13 +43,13 @@ class UUIDFixture: public ::testing::Test
TEST_F(UUIDFixture, DumpingRawAndConstructAnUUIDWithItShouldGiveTheSameUUID) TEST_F(UUIDFixture, DumpingRawAndConstructAnUUIDWithItShouldGiveTheSameUUID)
{ {
std::span<const std::byte, UUID::UUID_BYTE_SIZE> raw = m_a; std::span<const std::byte, UUID::UUID_BYTE_SIZE> raw = m_a.ToBytes();
EXPECT_EQ(m_a, UUID {raw}); EXPECT_EQ(m_a, UUID {raw});
raw = m_b; raw = m_b.ToBytes();
EXPECT_EQ(m_b, UUID {raw}); EXPECT_EQ(m_b, UUID {raw});
raw = m_d; raw = m_d.ToBytes();
EXPECT_EQ(m_d, UUID {raw}); EXPECT_EQ(m_d, UUID {raw});
} }
@@ -57,21 +57,21 @@ TEST_F(UUIDFixture, DumpingRawAndConstructAnUUIDWithItShouldGiveTheSameUUID)
TEST_F(UUIDFixture, ValidIDFromStringShouldBeEqualToString) TEST_F(UUIDFixture, ValidIDFromStringShouldBeEqualToString)
{ {
EXPECT_EQ(static_cast<std::string>(m_b), "47183823-2574-4bfd-b411-99ed177d3e43"); EXPECT_EQ(m_b.ToString(), "47183823-2574-4bfd-b411-99ed177d3e43");
} }
/****************************************************************************************/ /****************************************************************************************/
TEST_F(UUIDFixture, InvalidIDFromStringShouldNotBeEqualToString) TEST_F(UUIDFixture, InvalidIDFromStringShouldNotBeEqualToString)
{ {
EXPECT_NE(static_cast<std::string>(m_c), "4bfd-b411-99ed177d3e43"); EXPECT_NE(m_c.ToString(), "4bfd-b411-99ed177d3e43");
} }
/****************************************************************************************/ /****************************************************************************************/
TEST_F(UUIDFixture, NullIDStringShouldBeEqualToNullIDString) TEST_F(UUIDFixture, NullIDStringShouldBeEqualToNullIDString)
{ {
EXPECT_EQ(static_cast<std::string>(UUID::NULL_UUID), "00000000-0000-0000-0000-000000000000"); EXPECT_EQ(UUID::NULL_UUID.ToString(), "00000000-0000-0000-0000-000000000000");
} }
/****************************************************************************************/ /****************************************************************************************/
@@ -168,9 +168,9 @@ TEST_F(UUIDFixture, GeneratingFiveMillionUniqueID)
/****************************************************************************************/ /****************************************************************************************/
TEST_F(UUIDFixture, Raw_ShouldGiveBackTheRawDataOfTheID) TEST_F(UUIDFixture, ToBytes_ShouldGiveBackTheRawDataOfTheID)
{ {
std::span<const std::byte, UUID::UUID_BYTE_SIZE> d = m_d; std::span<const std::byte, UUID::UUID_BYTE_SIZE> d = m_d.ToBytes();
std::span<const std::byte, UUID::UUID_BYTE_SIZE> raw = m_raw; std::span<const std::byte, UUID::UUID_BYTE_SIZE> raw = m_raw;
for (std::uint32_t i = 0; i < UUID::UUID_BYTE_SIZE; ++i) for (std::uint32_t i = 0; i < UUID::UUID_BYTE_SIZE; ++i)

View File

@@ -19,18 +19,18 @@ class VersionFixture: public ::testing::Test
/****************************************************************************************/ /****************************************************************************************/
TEST_F(VersionFixture, string) TEST_F(VersionFixture, ToString)
{ {
EXPECT_STREQ(static_cast<std::string>(m_detailed).data(), "1.2.3"); EXPECT_STREQ(m_detailed.ToString().data(), "1.2.3");
EXPECT_STREQ(static_cast<std::string>(m_combined).data(), "1.2.3"); EXPECT_STREQ(m_combined.ToString().data(), "1.2.3");
} }
/****************************************************************************************/ /****************************************************************************************/
TEST_F(VersionFixture, uint32_t) TEST_F(VersionFixture, Raw)
{ {
EXPECT_EQ(static_cast<std::uint32_t>(m_detailed), (1 << 16) | (2 << 8) | 3); EXPECT_EQ(m_detailed.Raw(), (1 << 16) | (2 << 8) | 3);
EXPECT_EQ(static_cast<std::uint32_t>(m_combined), (1 << 16) | (2 << 8) | 3); EXPECT_EQ(m_combined.Raw(), (1 << 16) | (2 << 8) | 3);
} }
/****************************************************************************************/ /****************************************************************************************/