28#include <boost/random/mersenne_twister.hpp>
29#include <boost/uuid/uuid_generators.hpp>
30#include <boost/uuid/uuid_io.hpp>
32#if BOOST_VERSION >= 106700
33#include <boost/uuid/entropy_error.hpp>
52static boost::mt19937
rng;
79#if BOOST_VERSION >= 106700
90 std::lock_guard<std::mutex> lock(
rng_mutex );
94#if BOOST_VERSION >= 106700
96 catch(
const boost::uuids::entropy_error& )
98 wxLogFatalError(
"A Boost UUID entropy exception was thrown in %s:%s.",
99 __FILE__, __FUNCTION__ );
108 wxASSERT( null == 0 );
115 if( !aString.empty() && aString.length() <= 8
116 && std::all_of( aString.begin(), aString.end(),
117 [](
unsigned char c )
119 return std::isxdigit( c );
125 for( int i = 0; i < 4; i++ )
127 int start = static_cast<int>( aString.length() ) - 8 + i * 2;
130 start = std::max( 0, start );
131 int len = std::max( 0, end - start );
133 std::string octet = aString.substr( start, len );
134 m_uuid.data[i + 12] = strtol( octet.data(), nullptr, 16 );
147#if BOOST_VERSION >= 106700
154#if BOOST_VERSION >= 106700
156 catch(
const boost::uuids::entropy_error& )
158 wxLogFatalError(
"A Boost UUID entropy exception was thrown in %s:%s.",
159 __FILE__, __FUNCTION__ );
174 KIID(
std::string( aString.ToUTF8() ) )
181 static wxString niluuidStr =
niluuid.AsString();
183 if( aCandidate.Length() != niluuidStr.Length() )
186 for( wxChar c : aCandidate )
188 if( c >=
'0' && c <=
'9' )
191 if( c >=
'a' && c <=
'f' )
194 if( c >=
'A' && c <=
'F' )
209 m_uuid.data[12] =
static_cast<uint8_t
>( aTimestamp >> 24 );
210 m_uuid.data[13] =
static_cast<uint8_t
>( aTimestamp >> 16 );
211 m_uuid.data[14] =
static_cast<uint8_t
>( aTimestamp >> 8 );
212 m_uuid.data[15] =
static_cast<uint8_t
>( aTimestamp );
226 ret |=
m_uuid.data[12] << 24;
227 ret |=
m_uuid.data[13] << 16;
228 ret |=
m_uuid.data[14] << 8;
237 return boost::uuids::hash_value(
m_uuid );
249 return boost::uuids::to_string(
m_uuid );
255 return boost::uuids::to_string(
m_uuid );
279 for(
int i = 15; i >= 0; --i )
293 for(
int i = 0; i < 16; ++i )
315 for(
const wxString& pathStep : wxSplit( aString,
'/' ) )
317 if( !pathStep.empty() )
318 emplace_back(
KIID( pathStep ) );
328 if( aPath.size() >
copy.size() )
331 for(
size_t i = 0; i < aPath.size(); ++i )
333 if(
copy.at( i ) != aPath.at( i ) )
340 for(
size_t i = aPath.size(); i <
copy.size(); ++i )
341 push_back(
copy.at( i ) );
349 if( aPath.size() > size() )
355 while( !copyThat.empty() )
357 if( *std::prev( copyThis.end() ) != *std::prev( copyThat.end() ) )
372 for(
const KIID& pathStep : *
this )
387 aKIID =
KIID( aJson.get<std::string>() );
bool EndsWith(const KIID_PATH &aPath) const
Test if aPath from the last path towards the first path.
bool MakeRelativeTo(const KIID_PATH &aPath)
wxString AsString() const
static void SeedGenerator(unsigned int aSeed)
Re-initialize the UUID generator with a given seed (for testing or QA purposes)
wxString AsString() const
static KIID Combine(const KIID &aFirst, const KIID &aSecond)
Creates a deterministic KIID from two input KIIDs by XORing their underlying UUIDs.
boost::uuids::uuid m_uuid
void Increment()
Generates a deterministic replacement for a given ID.
std::string AsStdString() const
wxString AsLegacyTimestampString() const
timestamp_t AsLegacyTimestamp() const
static void CreateNilUuids(bool aNil=true)
A performance optimization which disables/enables the generation of pseudo-random UUIDs.
static bool SniffTest(const wxString &aCandidate)
Returns true if a string has the correct formatting to be a KIID.
void Clone(const KIID &aUUID)
bool IsLegacyTimestamp() const
void ConvertTimestampToUuid()
Change an existing time stamp based UUID into a true UUID.
static boost::uuids::nil_generator nilGenerator
static std::mutex rng_mutex
static boost::mt19937 rng
void from_json(const nlohmann::json &aJson, KIID &aKIID)
static boost::uuids::string_generator stringGenerator
static boost::uuids::basic_random_generator< boost::mt19937 > randomGenerator
static thread_local bool g_createNilUuids
void to_json(nlohmann::json &aJson, const KIID &aKIID)
KICOMMON_API KIID niluuid
uint32_t timestamp_t
timestamp_t is our type to represent unique IDs for all kinds of elements; historically simply the ti...
wxString result
Test unit parsing edge cases and error handling.