Unicode C
Unicode C
Generate ULID
See more ULID/UUID Examples
Generate a ULID using a specified timestamp or the current system date timestamp.Important: Chilkat's ULID functionality was introduced in v9.5.0.94.
Chilkat Unicode C Downloads
#include <C_CkDateTimeW.h>
void ChilkatSample(void)
{
HCkDateTimeW dt;
BOOL utc;
const wchar_t *ulid;
HCkDateTimeW dt2;
dt = CkDateTimeW_Create();
// Set dt to the current system date/time.
CkDateTimeW_SetFromCurrentSystemTime(dt);
// Generate a ULID for the current UTC date/time.
// (i.e. the current UTC UNIX-time)
utc = TRUE;
ulid = CkDateTimeW_ulidGenerate(dt,utc);
wprintf(L"%s\n",ulid);
// example result: 01GRGCH4J88RECEN4D4VK4F629
// Generate a ULID using the local timezone's current time.
utc = FALSE;
ulid = CkDateTimeW_ulidGenerate(dt,utc);
wprintf(L"%s\n",ulid);
// example result: 01GRH14AA82EY9A7S99YYF2QDY
// -----------------------------------------------
// To generate a ULID using a specific UNIX timestamp
// For example, the Unix timestamp for Sun, 05 Feb 2023 14:57:46 GMT
// is 1675609066
// For more information about the Epoch Unix Timestamp, see Epoch Unix Timestamp
// To generate a ULID from a specified date/time, set the CkDateTime and then generate the ULID.
dt2 = CkDateTimeW_Create();
utc = TRUE;
CkDateTimeW_SetFromUnixTime(dt2,utc,1675609066);
ulid = CkDateTimeW_ulidGenerate(dt2,utc);
wprintf(L"%s\n",ulid);
// example result: 01GRH1AJGG3P5K04DJHN3QJCX3
CkDateTimeW_Dispose(dt);
CkDateTimeW_Dispose(dt2);
}