24#include <boost/random/mersenne_twister.hpp>
25#include <boost/uuid/uuid_generators.hpp>
26#include <boost/uuid/uuid_io.hpp>
28#if BOOST_VERSION >= 106700
29#include <boost/uuid/entropy_error.hpp>
48static thread_local boost::mt19937
rng;
49static thread_local boost::uuids::basic_random_generator<boost::mt19937>
randomGenerator;
75#if BOOST_VERSION >= 106700
89#if BOOST_VERSION >= 106700
91 catch(
const boost::uuids::entropy_error& )
93 wxLogFatalError(
"A Boost UUID entropy exception was thrown in %s:%s.",
94 __FILE__, __FUNCTION__ );
103 wxASSERT( null == 0 );
110 if( !aString.empty() && aString.length() <= 8
111 && std::all_of( aString.begin(), aString.end(),
112 [](
unsigned char c )
114 return std::isxdigit( c );
120 for( int i = 0; i < 4; i++ )
122 int start = static_cast<int>( aString.length() ) - 8 + i * 2;
125 start = std::max( 0, start );
126 int len = std::max( 0, end - start );
128 std::string octet = aString.substr( start, len );
129 m_uuid.data[i + 12] = strtol( octet.data(), nullptr, 16 );
142#if BOOST_VERSION >= 106700
149#if BOOST_VERSION >= 106700
151 catch(
const boost::uuids::entropy_error& )
153 wxLogFatalError(
"A Boost UUID entropy exception was thrown in %s:%s.",
154 __FILE__, __FUNCTION__ );
169 KIID(
std::string( aString.ToUTF8() ) )
176 static wxString niluuidStr =
niluuid.AsString();
178 if( aCandidate.Length() != niluuidStr.Length() )
181 for( wxChar c : aCandidate )
183 if( c >=
'0' && c <=
'9' )
186 if( c >=
'a' && c <=
'f' )
189 if( c >=
'A' && c <=
'F' )
204 m_uuid.data[12] =
static_cast<uint8_t
>( aTimestamp >> 24 );
205 m_uuid.data[13] =
static_cast<uint8_t
>( aTimestamp >> 16 );
206 m_uuid.data[14] =
static_cast<uint8_t
>( aTimestamp >> 8 );
207 m_uuid.data[15] =
static_cast<uint8_t
>( aTimestamp );
221 ret |=
m_uuid.data[12] << 24;
222 ret |=
m_uuid.data[13] << 16;
223 ret |=
m_uuid.data[14] << 8;
232 return boost::uuids::hash_value(
m_uuid );
244 return boost::uuids::to_string(
m_uuid );
250 return boost::uuids::to_string(
m_uuid );
274 for(
int i = 15; i >= 0; --i )
288 for(
int i = 0; i < 16; ++i )
302 std::uint64_t h1 = 0xcbf29ce484222325ULL;
303 std::uint64_t h2 = 0x84222325cbf29ce4ULL;
305 for( wxChar c : aName )
307 h1 ^=
static_cast<std::uint64_t
>( c );
308 h1 *= 0x100000001b3ULL;
309 h2 ^=
static_cast<std::uint64_t
>( c ) * 0x9E3779B97F4A7C15ULL;
310 h2 = ( h2 << 13 ) | ( h2 >> 51 );
313 const wxString uuid = wxString::Format(
314 wxS(
"%08x-%04x-%04x-%04x-%012llx" ),
315 static_cast<unsigned>( h1 >> 32 ),
316 static_cast<unsigned>( ( h1 >> 16 ) & 0xffff ),
317 static_cast<unsigned>( h1 & 0xffff ),
318 static_cast<unsigned>( h2 & 0xffff ),
319 static_cast<unsigned long long>( h2 >> 16 ) & 0xffffffffffffULL );
340 for(
const wxString& pathStep : wxSplit( aString,
'/' ) )
342 if( !pathStep.empty() )
343 emplace_back(
KIID( pathStep ) );
353 if( aPath.size() >
copy.size() )
356 for(
size_t i = 0; i < aPath.size(); ++i )
358 if(
copy.at( i ) != aPath.at( i ) )
365 for(
size_t i = aPath.size(); i <
copy.size(); ++i )
374 if( aPath.size() > size() )
380 while( !copyThat.empty() )
382 if( *std::prev( copyThis.end() ) != *std::prev( copyThat.end() ) )
397 for(
const KIID& pathStep : *
this )
412 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.
static KIID FromDeterministicString(const wxString &aName)
Build a deterministic UUID from an arbitrary name string.
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...
table push_back({ "Source", "Layer", "Vertices", "Strategy", "Build(us)", "ns/query", "Mquery/s", "Inside" })
wxString result
Test unit parsing edge cases and error handling.