2022-04-23 04:59:50 -04:00
|
|
|
// SPDX-FileCopyrightText: Copyright 2022 yuzu Emulator Project
|
|
|
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
2018-12-18 09:07:25 -05:00
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
2022-02-05 12:35:39 -05:00
|
|
|
#include <array>
|
|
|
|
#include <functional>
|
2018-12-24 13:30:07 -05:00
|
|
|
#include <string>
|
|
|
|
|
2018-12-18 09:07:25 -05:00
|
|
|
#include "common/common_types.h"
|
|
|
|
|
|
|
|
namespace Common {
|
|
|
|
|
|
|
|
struct UUID {
|
2022-02-05 12:35:39 -05:00
|
|
|
std::array<u8, 0x10> uuid{};
|
|
|
|
|
|
|
|
/// Constructs an invalid UUID.
|
|
|
|
constexpr UUID() = default;
|
|
|
|
|
|
|
|
/// Constructs a UUID from a reference to a 128 bit array.
|
|
|
|
constexpr explicit UUID(const std::array<u8, 16>& uuid_) : uuid{uuid_} {}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Constructs a UUID from either:
|
|
|
|
* 1. A 32 hexadecimal character string representing the bytes of the UUID
|
|
|
|
* 2. A RFC 4122 formatted UUID string, in the format xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx
|
|
|
|
*
|
|
|
|
* The input string may contain uppercase or lowercase characters, but they must:
|
|
|
|
* 1. Contain valid hexadecimal characters (0-9, a-f, A-F)
|
|
|
|
* 2. Not contain the "0x" hexadecimal prefix
|
|
|
|
*
|
|
|
|
* Should the input string not meet the above requirements,
|
|
|
|
* an assert will be triggered and an invalid UUID is set instead.
|
|
|
|
*/
|
|
|
|
explicit UUID(std::string_view uuid_string);
|
|
|
|
|
|
|
|
~UUID() = default;
|
|
|
|
|
|
|
|
constexpr UUID(const UUID&) noexcept = default;
|
|
|
|
constexpr UUID(UUID&&) noexcept = default;
|
|
|
|
|
|
|
|
constexpr UUID& operator=(const UUID&) noexcept = default;
|
|
|
|
constexpr UUID& operator=(UUID&&) noexcept = default;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns whether the stored UUID is valid or not.
|
|
|
|
*
|
|
|
|
* @returns True if the stored UUID is valid, false otherwise.
|
|
|
|
*/
|
|
|
|
constexpr bool IsValid() const {
|
|
|
|
return uuid != std::array<u8, 0x10>{};
|
2018-12-18 09:07:25 -05:00
|
|
|
}
|
|
|
|
|
2022-02-05 12:35:39 -05:00
|
|
|
/**
|
|
|
|
* Returns whether the stored UUID is invalid or not.
|
|
|
|
*
|
|
|
|
* @returns True if the stored UUID is invalid, false otherwise.
|
|
|
|
*/
|
|
|
|
constexpr bool IsInvalid() const {
|
|
|
|
return !IsValid();
|
2021-09-22 17:52:37 -04:00
|
|
|
}
|
|
|
|
|
2022-02-05 12:35:39 -05:00
|
|
|
/**
|
|
|
|
* Returns a 32 hexadecimal character string representing the bytes of the UUID.
|
|
|
|
*
|
|
|
|
* @returns A 32 hexadecimal character string of the UUID.
|
|
|
|
*/
|
|
|
|
std::string RawString() const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns a RFC 4122 formatted UUID string in the format xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx.
|
|
|
|
*
|
|
|
|
* @returns A RFC 4122 formatted UUID string.
|
|
|
|
*/
|
|
|
|
std::string FormattedString() const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns a 64-bit hash of the UUID for use in hash table data structures.
|
|
|
|
*
|
|
|
|
* @returns A 64-bit hash of the UUID.
|
|
|
|
*/
|
|
|
|
size_t Hash() const noexcept;
|
|
|
|
|
|
|
|
/// DO NOT USE. Copies the contents of the UUID into a u128.
|
|
|
|
u128 AsU128() const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Creates a default UUID "yuzu Default UID".
|
|
|
|
*
|
|
|
|
* @returns A UUID with its bytes set to the ASCII values of "yuzu Default UID".
|
|
|
|
*/
|
|
|
|
static constexpr UUID MakeDefault() {
|
|
|
|
return UUID{
|
|
|
|
{'y', 'u', 'z', 'u', ' ', 'D', 'e', 'f', 'a', 'u', 'l', 't', ' ', 'U', 'I', 'D'},
|
|
|
|
};
|
2020-04-29 21:09:53 +10:00
|
|
|
}
|
|
|
|
|
2022-02-05 12:35:39 -05:00
|
|
|
/**
|
|
|
|
* Creates a random UUID.
|
|
|
|
*
|
|
|
|
* @returns A random UUID.
|
|
|
|
*/
|
|
|
|
static UUID MakeRandom();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Creates a random UUID with a seed.
|
|
|
|
*
|
|
|
|
* @param seed A seed to initialize the Mersenne-Twister RNG
|
|
|
|
*
|
|
|
|
* @returns A random UUID.
|
|
|
|
*/
|
|
|
|
static UUID MakeRandomWithSeed(u32 seed);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Creates a random UUID. The generated UUID is RFC 4122 Version 4 compliant.
|
|
|
|
*
|
|
|
|
* @returns A random UUID that is RFC 4122 Version 4 compliant.
|
|
|
|
*/
|
|
|
|
static UUID MakeRandomRFC4122V4();
|
|
|
|
|
|
|
|
friend constexpr bool operator==(const UUID& lhs, const UUID& rhs) = default;
|
2018-12-18 09:07:25 -05:00
|
|
|
};
|
2022-02-05 12:35:39 -05:00
|
|
|
static_assert(sizeof(UUID) == 0x10, "UUID has incorrect size.");
|
|
|
|
|
|
|
|
/// An invalid UUID. This UUID has all its bytes set to 0.
|
|
|
|
constexpr UUID InvalidUUID = {};
|
2018-12-18 09:07:25 -05:00
|
|
|
|
|
|
|
} // namespace Common
|
2021-08-06 00:41:55 -04:00
|
|
|
|
|
|
|
namespace std {
|
|
|
|
|
|
|
|
template <>
|
|
|
|
struct hash<Common::UUID> {
|
|
|
|
size_t operator()(const Common::UUID& uuid) const noexcept {
|
2022-02-05 12:35:39 -05:00
|
|
|
return uuid.Hash();
|
2021-08-06 00:41:55 -04:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace std
|