XstarS.GuidModule 2.3.1

There is a newer prerelease version of this package available.
See the version list below for details.
dotnet add package XstarS.GuidModule --version 2.3.1
NuGet\Install-Package XstarS.GuidModule -Version 2.3.1
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="XstarS.GuidModule" Version="2.3.1" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add XstarS.GuidModule --version 2.3.1
#r "nuget: XstarS.GuidModule, 2.3.1"
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install XstarS.GuidModule as a Cake Addin
#addin nuget:?package=XstarS.GuidModule&version=2.3.1

// Install XstarS.GuidModule as a Cake Tool
#tool nuget:?package=XstarS.GuidModule&version=2.3.1

F# GUID Module

Provides RFC 4122 UUID and RFC4122bis UUIDREV (draft) compliant GUID operations for F#. The orders of input parameters are adjusted to match F# pipeline patterns.

RFC 4122 UUID Standard

RFC 4122 defines the following five versions of UUID:

  • Version 1: The time-based version, contains a 60-bit timestamp and a 12-bit MAC address
  • Version 2: DCE Security version, contains a 28-bit timestamp, a 12-bit MAC address and a 32-bit local ID
  • Version 3: The name-based version, using MD5 hashing to compute the hash of the namespace and name
  • Version 4: The randomly or pseudo-randomly generated version, equivalent to Guid.NewGuid() in .NET
  • Version 5: The name-based version, using SHA-1 hashing to compute the hash of the namespace and name

There is also a special Nil UUID whose bytes are all 0x00s, which is equivalent to Guid.Empty in .NET.

RFC4122bis UUIDREV Draft

RFC4122bis UUIDREV defines the following three versions of UUID:

  • Version 6: The reordered time-based version, field-compatible with Version 1 except that the timestamp is reordered to big-endian order
  • Version 7: The Unix Epoch time-based version, contains a 48-bit timestamp and a 74-bit random number, field-compatible with ULID
  • Version 8: Reserved for custom UUID formats, fields except the variant and version are user-defined

There is also a special Max UUID whose bytes are all 0xffs, which has no equivalent implementation in .NET (provided in this project).

F# GUID Module Usage

Core module: XNetEx.FSharp.Core.Guid.

RFC 4122 GUID Generation

open System
open XNetEx.FSharp.Core

// load generator state from file.
let loadResult = Guid.loadState "state.bin"

// generate time-based GUID.
let guidV1 = Guid.newV1 () // 3944a871-aa14-11ed-8791-a9a9a46de54f
// generate randomized GUID.
let guidV4 = Guid.newV4 () // 0658f02d-45a4-4c25-b9d0-8ddbda3c3e08
// generate Unix time-based GUID.
let guidV7 = Guid.newV7 () // 018640c6-0dc9-7189-a644-31acdba4cabc

// generate name-based GUID.
let guidV3 = Guid.newV3S Guid.nsDns "github.com"
// 7f4771a0-1982-373d-928f-d31140a51652
let guidV5 = "github.com" |> Guid.newV5S Guid.nsDns
// 6fca3dd2-d61d-58de-9363-1574b382ea68

// build time-based GUID.
let guid6 = Guid.empty
            |> Guid.replaceVariant Guid.Variant.Rfc4122
            |> Guid.replaceVersion Guid.Version.Version6
            |> Guid.replaceTime DateTime.UtcNow
            |> Guid.replaceClockSeq 0x0123s
            |> Guid.replaceNodeId (Array.init 6 (((+) 1) >> byte))
            // 1edaa178-dec2-6054-8123-010203040506

// build Unix time-based GUID.
let guid7 = Guid.newV4 ()
            |> Guid.replaceVersion Guid.Version.Version7
            |> Guid.replaceTime DateTime.UtcNow
            // 018640db-de47-7ab9-bf00-6119a1033265

Common GUID Operations

open XNetEx.FSharp.Core

// GUID parsing and formatting.
let guid1 = Guid.parse "6ba7b810-9dad-11d1-80b4-00c04fd430c8"
let guid2 = "{6ba7b810-9dad-11d1-80b4-00c04fd430c8}"
            |> Guid.parseExact "B"
printfn "%s" (guid2 |> Guid.format "X")

// GUID construction and deconstruction.
let guid3 = Guid.ofFields
                0x00112233 0x4455s 0x6677s (0x88uy, 0x99uy)
                (0xAAuy, 0xBBuy, 0xCCuy, 0xDDuy, 0xEEuy, 0xFFuy)
let guid3Fields = guid3 |> Guid.toFields

let guid4 = Array.map byte
                [| 0x00; 0x11; 0x22; 0x33; 0x44; 0x55; 0x66; 0x77
                   0x88; 0x99; 0xAA; 0xBB; 0xCC; 0xDD; 0xEE; 0xFF |]
            |> Guid.ofBytesUuid
let guid4Bytes = Guid.toBytes guid4
assert (guid3 = guid4)

let guid5 = Array.map byte
                [| 0x33; 0x22; 0x11; 0x00; 0x55; 0x44; 0x77; 0x66
                   0x88; 0x99; 0xAA; 0xBB; 0xCC; 0xDD; 0xEE; 0xFF |]
            |> Guid.ofBytes
let guid5Bytes = Guid.toBytesUuid guid5
assert (guid3 = guid5)
Product Compatible and additional computed target framework versions.
.NET net5.0 was computed.  net5.0-windows was computed.  net6.0 was computed.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 is compatible.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed. 
.NET Core netcoreapp2.0 was computed.  netcoreapp2.1 was computed.  netcoreapp2.2 was computed.  netcoreapp3.0 was computed.  netcoreapp3.1 was computed. 
.NET Standard netstandard2.0 is compatible.  netstandard2.1 is compatible. 
.NET Framework net461 was computed.  net462 was computed.  net463 was computed.  net47 was computed.  net471 was computed.  net472 was computed.  net48 was computed.  net481 was computed. 
MonoAndroid monoandroid was computed. 
MonoMac monomac was computed. 
MonoTouch monotouch was computed. 
Tizen tizen40 was computed.  tizen60 was computed. 
Xamarin.iOS xamarinios was computed. 
Xamarin.Mac xamarinmac was computed. 
Xamarin.TVOS xamarintvos was computed. 
Xamarin.WatchOS xamarinwatchos was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
2.4.0-preview 74 4/20/2024
2.3.1 77 3/24/2024
2.3.0 83 2/24/2024
2.2.1 97 2/8/2024
2.2.0 68 1/26/2024
2.1.2 79 1/22/2024
2.1.1 80 1/20/2024
2.1.0 87 1/12/2024
2.0.0 109 12/24/2023
2.0.0-rc-19 96 12/22/2023
2.0.0-rc-16 82 12/12/2023
2.0.0-rc-15 99 12/6/2023
2.0.0-rc-14 97 11/26/2023
2.0.0-rc-12.5 84 10/15/2023
2.0.0-rc-12 72 10/15/2023
2.0.0-rc-00 93 7/15/2023
2.0.0-preview-04.5 71 6/4/2023
2.0.0-preview-04 91 5/28/2023
2.0.0-preview-03.8 68 5/20/2023
2.0.0-preview-03.5 69 5/14/2023
2.0.0-preview-03 95 4/15/2023
2.0.0-preview-02.5 90 3/26/2023
2.0.0-preview-02 121 3/4/2023
2.0.0-preview-01 113 2/12/2023
1.14.0-preview 68 4/20/2024
1.13.0 83 2/24/2024
1.12.1 82 2/8/2024
1.12.0 60 1/26/2024
1.11.2 74 1/22/2024
1.11.1 74 1/20/2024
1.11.0 77 1/12/2024
1.10.0 94 12/24/2023
1.9.5 103 12/22/2023
1.9.1 88 12/12/2023
1.9.0 118 12/6/2023
1.8.0 112 11/26/2023
1.7.8 110 10/15/2023
1.7.5 119 6/4/2023
1.7.1 111 5/28/2023
1.7.0 115 5/20/2023
1.6.0 123 5/13/2023
1.5.0 249 2/5/2023
1.4.0 273 1/21/2023
1.3.1 269 1/15/2023
1.3.0 252 12/31/2022
1.2.0 381 9/30/2022
1.1.1 383 8/5/2022
1.1.0 368 7/25/2022