From b5d6902c86ffa2360fdac6f7c510918d5d846e10 Mon Sep 17 00:00:00 2001 From: alvrs Date: Wed, 13 Mar 2024 14:54:40 +0000 Subject: [PATCH] self-review --- packages/store/ts/config/v2/generics.ts | 13 ++++--------- packages/store/ts/config/v2/store.ts | 2 +- packages/world/ts/config/v2/world.test.ts | 2 +- packages/world/ts/config/v2/world.ts | 16 ++++++++-------- 4 files changed, 14 insertions(+), 19 deletions(-) diff --git a/packages/store/ts/config/v2/generics.ts b/packages/store/ts/config/v2/generics.ts index cd0d0edce0..201f356669 100644 --- a/packages/store/ts/config/v2/generics.ts +++ b/packages/store/ts/config/v2/generics.ts @@ -1,14 +1,9 @@ -export type get = key extends keyof input ? input[key] : defaultValue; +export type get = key extends keyof input ? input[key] : undefined; -export function get( - input: input, - key: key, - defaultValue: defaultValue = undefined as defaultValue, -): get { - return (typeof input === "object" && input != null && hasOwnKey(input, key) ? input[key] : defaultValue) as get< +export function get(input: input, key: key): get { + return (typeof input === "object" && input != null && hasOwnKey(input, key) ? input[key] : undefined) as get< input, - key, - defaultValue + key >; } diff --git a/packages/store/ts/config/v2/store.ts b/packages/store/ts/config/v2/store.ts index 952c2c9262..f117938d5b 100644 --- a/packages/store/ts/config/v2/store.ts +++ b/packages/store/ts/config/v2/store.ts @@ -89,7 +89,7 @@ export function scopeWithEnums export type extendedScope = scopeWithEnums, scopeWithUserTypes>>; export function extendedScope(input: input): extendedScope { - return scopeWithEnums(get(input, "enums"), scopeWithUserTypes(get(input, "userTypes", undefined))); + return scopeWithEnums(get(input, "enums"), scopeWithUserTypes(get(input, "userTypes"))); } export type validateStoreConfig = { diff --git a/packages/world/ts/config/v2/world.test.ts b/packages/world/ts/config/v2/world.test.ts index 2d55a003f8..4392952ce8 100644 --- a/packages/world/ts/config/v2/world.test.ts +++ b/packages/world/ts/config/v2/world.test.ts @@ -101,7 +101,7 @@ describe("resolveWorldConfig", () => { namespace: "", } as const; - attest(config).snap(expected); + attest(config).equals(expected); }); it("should resolve namespaced table config with user types and enums", () => { diff --git a/packages/world/ts/config/v2/world.ts b/packages/world/ts/config/v2/world.ts index ee3682a71f..d4780ca597 100644 --- a/packages/world/ts/config/v2/world.ts +++ b/packages/world/ts/config/v2/world.ts @@ -73,13 +73,13 @@ export type resolveWorldConfig = evaluate< >; export function resolveWorldConfig(input: validateWorldConfig): resolveWorldConfig { - const namespaces = get(input, "namespaces", {}); + const namespaces = get(input, "namespaces") ?? {}; const scope = extendedScope(input); const namespacedTables = Object.fromEntries( Object.entries(namespaces) .map(([namespaceKey, namespace]) => { - const tables = get(namespace, "tables", {}); + const tables = get(namespace, "tables") ?? {}; return Object.entries(tables).map(([tableKey, table]) => [`${namespaceKey}__${tableKey}`, table]); }) .flat(), @@ -88,15 +88,15 @@ export function resolveWorldConfig(input: validateWorldConfig [ namespaceKey, - { tables: resolveStoreTablesConfig(get(namespace, "tables", {}), scope) }, + { tables: resolveStoreTablesConfig(get(namespace, "tables") ?? {}, scope) }, ]), ); return { - tables: resolveStoreTablesConfig({ ...get(input, "tables", {}), ...namespacedTables }, scope), + tables: resolveStoreTablesConfig({ ...(get(input, "tables") ?? {}), ...namespacedTables }, scope), namespaces: resolvedNamespaces, - userTypes: get(input, "userTypes", {}), - enums: get(input, "enums", {}), - namespace: get(input, "namespace", ""), - } as unknown as resolveWorldConfig; + userTypes: get(input, "userTypes") ?? {}, + enums: get(input, "enums") ?? {}, + namespace: get(input, "namespace") ?? "", + } as resolveWorldConfig; }