Common/Random: Add convenience template for simple arithmetic values

In cases where we just want a random value for a primitive arithmetic
type, we can wrap this in a template to allow convenient direct
assignment instead of keeping declaration and initialization separate
(making it more difficult to use values uninitialized). This also allows
the use of Common::Random with functions such as std::generate, making
it more flexible in how random values can be generated.
This commit is contained in:
Lioncash 2018-06-14 10:26:11 -04:00
parent e69c6cdaab
commit 189d277cfc
4 changed files with 15 additions and 6 deletions

View File

@ -5,6 +5,7 @@
#pragma once #pragma once
#include <cstddef> #include <cstddef>
#include <type_traits>
#include "Common/CommonTypes.h" #include "Common/CommonTypes.h"
@ -12,4 +13,14 @@ namespace Common::Random
{ {
/// Fill `buffer` with random bytes using a cryptographically secure pseudo-random number generator. /// Fill `buffer` with random bytes using a cryptographically secure pseudo-random number generator.
void Generate(void* buffer, std::size_t size); void Generate(void* buffer, std::size_t size);
/// Generates a random value of arithmetic type `T`
template <typename T>
T GenerateValue()
{
static_assert(std::is_arithmetic<T>(), "T must be an arithmetic type in GenerateValue.");
T value;
Generate(&value, sizeof(value));
return value;
}
} // namespace Common::Random } // namespace Common::Random

View File

@ -270,7 +270,7 @@ TraversalRequestId TraversalClient::SendTraversalPacket(const TraversalPacket& p
{ {
OutgoingTraversalPacketInfo info; OutgoingTraversalPacketInfo info;
info.packet = packet; info.packet = packet;
Common::Random::Generate(&info.packet.requestId, sizeof(info.packet.requestId)); info.packet.requestId = Common::Random::GenerateValue<TraversalRequestId>();
info.tries = 0; info.tries = 0;
m_OutgoingTraversalPackets.push_back(info); m_OutgoingTraversalPackets.push_back(info);
ResendPacket(&m_OutgoingTraversalPackets.back()); ResendPacket(&m_OutgoingTraversalPackets.back());

View File

@ -169,8 +169,7 @@ static sockaddr_in6 MakeSinAddr(const TraversalInetAddress& addr)
static void GetRandomHostId(TraversalHostId* hostId) static void GetRandomHostId(TraversalHostId* hostId)
{ {
char buf[9]; char buf[9];
u32 num; const u32 num = Common::Random::GenerateValue<u32>();
Common::Random::Generate(&num, sizeof(num));
sprintf(buf, "%08x", num); sprintf(buf, "%08x", num);
memcpy(hostId->data(), buf, 8); memcpy(hostId->data(), buf, 8);
} }

View File

@ -73,9 +73,8 @@ void DolphinAnalytics::ReloadConfig()
void DolphinAnalytics::GenerateNewIdentity() void DolphinAnalytics::GenerateNewIdentity()
{ {
u64 id_high, id_low; const u64 id_high = Common::Random::GenerateValue<u64>();
Common::Random::Generate(&id_high, sizeof(id_high)); const u64 id_low = Common::Random::GenerateValue<u64>();
Common::Random::Generate(&id_low, sizeof(id_low));
m_unique_id = StringFromFormat("%016" PRIx64 "%016" PRIx64, id_high, id_low); m_unique_id = StringFromFormat("%016" PRIx64 "%016" PRIx64, id_high, id_low);
// Save the new id in the configuration. // Save the new id in the configuration.