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>
50static thread_local boost::mt19937
rng;
51static thread_local boost::uuids::basic_random_generator<boost::mt19937>
randomGenerator;
77#if BOOST_VERSION >= 106700
91#if BOOST_VERSION >= 106700
93 catch(
const boost::uuids::entropy_error& )
95 wxLogFatalError(
"A Boost UUID entropy exception was thrown in %s:%s.",
96 __FILE__, __FUNCTION__ );
105 wxASSERT( null == 0 );
112 if( !aString.empty() && aString.length() <= 8
113 && std::all_of( aString.begin(), aString.end(),
114 [](
unsigned char c )
116 return std::isxdigit( c );
122 for( int i = 0; i < 4; i++ )
124 int start = static_cast<int>( aString.length() ) - 8 + i * 2;
127 start = std::max( 0, start );
128 int len = std::max( 0, end - start );
130 std::string octet = aString.substr( start, len );
131 m_uuid.data[i + 12] = strtol( octet.data(), nullptr, 16 );
144#if BOOST_VERSION >= 106700
151#if BOOST_VERSION >= 106700
153 catch(
const boost::uuids::entropy_error& )
155 wxLogFatalError(
"A Boost UUID entropy exception was thrown in %s:%s.",
156 __FILE__, __FUNCTION__ );
171 KIID(
std::string( aString.ToUTF8() ) )
178 static wxString niluuidStr =
niluuid.AsString();
180 if( aCandidate.Length() != niluuidStr.Length() )
183 for( wxChar c : aCandidate )
185 if( c >=
'0' && c <=
'9' )
188 if( c >=
'a' && c <=
'f' )
191 if( c >=
'A' && c <=
'F' )
206 m_uuid.data[12] =
static_cast<uint8_t
>( aTimestamp >> 24 );
207 m_uuid.data[13] =
static_cast<uint8_t
>( aTimestamp >> 16 );
208 m_uuid.data[14] =
static_cast<uint8_t
>( aTimestamp >> 8 );
209 m_uuid.data[15] =
static_cast<uint8_t
>( aTimestamp );
223 ret |=
m_uuid.data[12] << 24;
224 ret |=
m_uuid.data[13] << 16;
225 ret |=
m_uuid.data[14] << 8;
234 return boost::uuids::hash_value(
m_uuid );
246 return boost::uuids::to_string(
m_uuid );
252 return boost::uuids::to_string(
m_uuid );
276 for(
int i = 15; i >= 0; --i )
290 for(
int i = 0; i < 16; ++i )
312 for(
const wxString& pathStep : wxSplit( aString,
'/' ) )
314 if( !pathStep.empty() )
315 emplace_back(
KIID( pathStep ) );
325 if( aPath.size() >
copy.size() )
328 for(
size_t i = 0; i < aPath.size(); ++i )
330 if(
copy.at( i ) != aPath.at( i ) )
337 for(
size_t i = aPath.size(); i <
copy.size(); ++i )
338 push_back(
copy.at( i ) );
346 if( aPath.size() > size() )
352 while( !copyThat.empty() )
354 if( *std::prev( copyThis.end() ) != *std::prev( copyThat.end() ) )
369 for(
const KIID& pathStep : *
this )
384 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 thread_local boost::uuids::basic_random_generator< boost::mt19937 > randomGenerator
void from_json(const nlohmann::json &aJson, KIID &aKIID)
static thread_local boost::mt19937 rng
static boost::uuids::string_generator stringGenerator
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.