From ccdb1020a5842de2a76ffc5353dec6062cba745e Mon Sep 17 00:00:00 2001 From: Robb Traister Date: Fri, 1 Nov 2024 11:48:15 -0400 Subject: [PATCH 1/4] fix: apply stricter typing to the v4 signature --- src/v4.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/v4.ts b/src/v4.ts index 3370e554..d3aee6ba 100644 --- a/src/v4.ts +++ b/src/v4.ts @@ -4,7 +4,7 @@ import rng from './rng.js'; import { unsafeStringify } from './stringify.js'; function v4(options?: Version4Options, buf?: undefined, offset?: number): string; -function v4(options?: Version4Options, buf?: Uint8Array, offset?: number): Uint8Array; +function v4(options: Version4Options, buf: Uint8Array, offset?: number): Uint8Array; function v4(options?: Version4Options, buf?: Uint8Array, offset?: number): UUIDTypes { if (native.randomUUID && !buf && !options) { return native.randomUUID(); From 025a00044c6e9eb723ec62668a4ebfcfd17693a0 Mon Sep 17 00:00:00 2001 From: Robb Traister Date: Fri, 1 Nov 2024 11:58:53 -0400 Subject: [PATCH 2/4] fix: allow options to be explicitly passed undefined --- src/v4.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/v4.ts b/src/v4.ts index d3aee6ba..37346adf 100644 --- a/src/v4.ts +++ b/src/v4.ts @@ -4,7 +4,7 @@ import rng from './rng.js'; import { unsafeStringify } from './stringify.js'; function v4(options?: Version4Options, buf?: undefined, offset?: number): string; -function v4(options: Version4Options, buf: Uint8Array, offset?: number): Uint8Array; +function v4(options: Version4Options | undefined, buf: Uint8Array, offset?: number): Uint8Array; function v4(options?: Version4Options, buf?: Uint8Array, offset?: number): UUIDTypes { if (native.randomUUID && !buf && !options) { return native.randomUUID(); From f8919a21b5343736381442db79d7bdf756e7dd06 Mon Sep 17 00:00:00 2001 From: Robb Traister Date: Mon, 4 Nov 2024 09:12:30 -0500 Subject: [PATCH 3/4] fix: apply narrowed typing to all uuid signatures --- src/v1.ts | 2 +- src/v3.ts | 2 +- src/v5.ts | 2 +- src/v6.ts | 2 +- src/v7.ts | 2 +- 5 files changed, 5 insertions(+), 5 deletions(-) diff --git a/src/v1.ts b/src/v1.ts index 0218251d..1accfd51 100644 --- a/src/v1.ts +++ b/src/v1.ts @@ -25,7 +25,7 @@ type V1State = { const _state: V1State = {}; function v1(options?: Version1Options, buf?: undefined, offset?: number): string; -function v1(options?: Version1Options, buf?: Uint8Array, offset?: number): Uint8Array; +function v1(options: Version1Options | undefined, buf: Uint8Array, offset?: number): Uint8Array; function v1(options?: Version1Options, buf?: Uint8Array, offset?: number): UUIDTypes { let bytes: Uint8Array; diff --git a/src/v3.ts b/src/v3.ts index caf9dcc9..59864bd1 100644 --- a/src/v3.ts +++ b/src/v3.ts @@ -13,7 +13,7 @@ function v3( function v3( value: string | Uint8Array, namespace: UUIDTypes, - buf?: Uint8Array, + buf: Uint8Array, offset?: number ): Uint8Array; function v3(value: string | Uint8Array, namespace: UUIDTypes, buf?: Uint8Array, offset?: number) { diff --git a/src/v5.ts b/src/v5.ts index fd01efd6..08968198 100644 --- a/src/v5.ts +++ b/src/v5.ts @@ -13,7 +13,7 @@ function v5( function v5( value: string | Uint8Array, namespace: UUIDTypes, - buf?: Uint8Array, + buf: Uint8Array, offset?: number ): Uint8Array; function v5(value: string | Uint8Array, namespace: UUIDTypes, buf?: Uint8Array, offset?: number) { diff --git a/src/v6.ts b/src/v6.ts index 665d1d4e..a32bff6e 100644 --- a/src/v6.ts +++ b/src/v6.ts @@ -4,7 +4,7 @@ import v1 from './v1.js'; import v1ToV6 from './v1ToV6.js'; function v6(options?: Version6Options, buf?: undefined, offset?: number): string; -function v6(options?: Version6Options, buf?: Uint8Array, offset?: number): Uint8Array; +function v6(options: Version6Options | undefined, buf: Uint8Array, offset?: number): Uint8Array; function v6(options?: Version6Options, buf?: Uint8Array, offset?: number): UUIDTypes { options ??= {}; offset ??= 0; diff --git a/src/v7.ts b/src/v7.ts index f24ba3af..1a41f3ce 100644 --- a/src/v7.ts +++ b/src/v7.ts @@ -10,7 +10,7 @@ type V7State = { const _state: V7State = {}; function v7(options?: Version7Options, buf?: undefined, offset?: number): string; -function v7(options?: Version7Options, buf?: Uint8Array, offset?: number): Uint8Array; +function v7(options: Version7Options | undefined, buf: Uint8Array, offset?: number): Uint8Array; function v7(options?: Version7Options, buf?: Uint8Array, offset?: number): UUIDTypes { let bytes: Uint8Array; From 2e09800e3000d01789ddfd688d0c21578b4b2ad7 Mon Sep 17 00:00:00 2001 From: Robert Kieffer Date: Mon, 4 Nov 2024 09:07:29 -0800 Subject: [PATCH 4/4] fix: simplify type for v3 and v5 --- src/v3.ts | 12 ------------ src/v5.ts | 12 ------------ 2 files changed, 24 deletions(-) diff --git a/src/v3.ts b/src/v3.ts index 59864bd1..83030ca2 100644 --- a/src/v3.ts +++ b/src/v3.ts @@ -4,18 +4,6 @@ import v35, { DNS, URL } from './v35.js'; export { DNS, URL } from './v35.js'; -function v3( - value: string | Uint8Array, - namespace: UUIDTypes, - buf?: undefined, - offset?: number -): string; -function v3( - value: string | Uint8Array, - namespace: UUIDTypes, - buf: Uint8Array, - offset?: number -): Uint8Array; function v3(value: string | Uint8Array, namespace: UUIDTypes, buf?: Uint8Array, offset?: number) { return v35(0x30, md5, value, namespace, buf, offset); } diff --git a/src/v5.ts b/src/v5.ts index 08968198..5e5c0e10 100644 --- a/src/v5.ts +++ b/src/v5.ts @@ -4,18 +4,6 @@ import v35, { DNS, URL } from './v35.js'; export { DNS, URL } from './v35.js'; -function v5( - value: string | Uint8Array, - namespace: UUIDTypes, - buf?: undefined, - offset?: number -): string; -function v5( - value: string | Uint8Array, - namespace: UUIDTypes, - buf: Uint8Array, - offset?: number -): Uint8Array; function v5(value: string | Uint8Array, namespace: UUIDTypes, buf?: Uint8Array, offset?: number) { return v35(0x50, sha1, value, namespace, buf, offset); }