- Changed my mind on several things:
- Remove rollover guard
- Change to 13bits counter
- Remove timestamp adjustment forward if clock goes back in time (instead, monotony will break). RFC is lacking info about how to handle this case for Uuid v7, but from what the RFC write about Uuid v1/v6 and the clock sequence, adjusting the timestamp forward if the clock goes back, is IMO generally wrong.
- Add rollover guard (initialize top bit of 26bit counter to 0)
- Rename GuidInfoVersion1And6.Sequence -> GuidInfoVersion1And6.ClockSequence
- PERF: reduce lock region
- PERF: do not use class Random to get the 1-255 increment. Fetch it from the Guid instead (a part overwritten by timestamp).
- Add FromHexString
- Sql: add uuid_v7_array function. Using dbo.uuid_swap_endian(dbo.uuid_v7()) directly (two functions calls in same statement) mysteriously generate Uuid's out of order!?
- Make CreateVersion7 and CreateVersion8MsSql monotonic (in same process), so remove CreateVersion7Sequence and CreateVersion8MsSqlSequence.
- Change ms sql scripts to be monotonic for uuid_v7 and uuid_v8mssql (in same session).
- Bitswapping was not correct for v7<->v8MsSql. bytes[6] and bytes[7] were swapped (endianess).
- CreateVersion8MsSql: forgot to preserve 2 random bits in bytes[9].
- Increase the counter size in sequential v7 and v8mssql from 12 to 26 bits (include all bits from 4 middle bytes).
- Instead of +1 in the counter, add a random byte (1-255).
- First release.
- Create Uuid v1 and v6. Convert between v1 and v6.
- Create Uuid v7 and v8MsSql. Convert between v7 and v8MsSql.
- Create Uuid v3 (MD5) and v5 (SHA1)
- Create Uuid v8SHA256 and v8SHA512
- Get info about a Guid (dissect)
- Create monotonic sequence of v7 and v8MsSql Guid's
- Create NEWSEQUENTIALID (ms sql)
- Create/reverse Xor Guid
- Create/reverse numeric Guid
- Create/reverse incremented Guid