| 
									
										
										
										
											2022-02-05 12:35:39 -05:00
										 |  |  | // Copyright 2022 yuzu Emulator Project
 | 
					
						
							| 
									
										
										
										
											2018-12-18 09:07:25 -05:00
										 |  |  | // Licensed under GPLv2 or any later version
 | 
					
						
							|  |  |  | // Refer to the license.txt file included.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #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
 |