From f5cea555cdfdd219242ed024d56c8bbafdf9f24b Mon Sep 17 00:00:00 2001 From: Niklas Koll Date: Mon, 19 Jan 2026 12:50:12 +0100 Subject: [PATCH 1/4] chore: Add flake and direnv stuff --- .envrc | 1 + .gitignore | 1 + flake.lock | 27 +++++++++++++++++++++++++++ flake.nix | 40 ++++++++++++++++++++++++++++++++++++++++ 4 files changed, 69 insertions(+) create mode 100644 .envrc create mode 100644 flake.lock create mode 100644 flake.nix diff --git a/.envrc b/.envrc new file mode 100644 index 0000000..3550a30 --- /dev/null +++ b/.envrc @@ -0,0 +1 @@ +use flake diff --git a/.gitignore b/.gitignore index 8b9576a..e500d05 100644 --- a/.gitignore +++ b/.gitignore @@ -4,3 +4,4 @@ node_modules/ # Added by cargo /target +.direnv/ diff --git a/flake.lock b/flake.lock new file mode 100644 index 0000000..69125b4 --- /dev/null +++ b/flake.lock @@ -0,0 +1,27 @@ +{ + "nodes": { + "nixpkgs": { + "locked": { + "lastModified": 1768564909, + "narHash": "sha256-Kell/SpJYVkHWMvnhqJz/8DqQg2b6PguxVWOuadbHCc=", + "owner": "nixos", + "repo": "nixpkgs", + "rev": "e4bae1bd10c9c57b2cf517953ab70060a828ee6f", + "type": "github" + }, + "original": { + "owner": "nixos", + "ref": "nixos-unstable", + "repo": "nixpkgs", + "type": "github" + } + }, + "root": { + "inputs": { + "nixpkgs": "nixpkgs" + } + } + }, + "root": "root", + "version": 7 +} diff --git a/flake.nix b/flake.nix new file mode 100644 index 0000000..b8d7bcc --- /dev/null +++ b/flake.nix @@ -0,0 +1,40 @@ +{ + inputs = { + nixpkgs.url = "github:nixos/nixpkgs/nixos-unstable"; + }; + + outputs = {nixpkgs, ...}: let + systems = ["aarch64-darwin" "x86_64-linux"]; + eachSystem = function: + nixpkgs.lib.genAttrs systems (system: + function { + inherit system; + pkgs = nixpkgs.legacyPackages.${system}; + }); + in { + devShells = eachSystem ({pkgs, ...}: { + default = pkgs.mkShellNoCC { + packages = [ + # general deps + pkgs.nodejs_24 + pkgs.pnpm_10 + + # wasm/rust stuff + pkgs.rustc + pkgs.cargo + pkgs.rust-analyzer + pkgs.rustfmt + pkgs.wasm-bindgen-cli + pkgs.wasm-pack + pkgs.lld + + # frontend + pkgs.vscode-langservers-extracted + pkgs.typescript-language-server + pkgs.prettier + pkgs.tailwindcss-language-server + ]; + }; + }); + }; +} From 83cb2bd950466bae7492e8195dcdc350d4183ad9 Mon Sep 17 00:00:00 2001 From: Max Richter Date: Mon, 19 Jan 2026 14:04:00 +0100 Subject: [PATCH 2/4] feat: move analytics script to env --- app/.env | 1 + app/src/app.html | 1 - app/src/lib/config.ts | 2 ++ app/src/routes/+layout.svelte | 7 +++++++ 4 files changed, 10 insertions(+), 1 deletion(-) create mode 100644 app/.env create mode 100644 app/src/lib/config.ts diff --git a/app/.env b/app/.env new file mode 100644 index 0000000..1c9c594 --- /dev/null +++ b/app/.env @@ -0,0 +1 @@ +PUBLIC_ANALYTIC_SCRIPT="" diff --git a/app/src/app.html b/app/src/app.html index b858bee..addab35 100644 --- a/app/src/app.html +++ b/app/src/app.html @@ -5,7 +5,6 @@ - %sveltekit.head% Nodes {@render children?.()} + + + {#if config.ANALYTIC_SCRIPT} + {@html config.ANALYTIC_SCRIPT} + {/if} + From 11de746c013671cdb8f2333e3ff52346b93f2e4b Mon Sep 17 00:00:00 2001 From: Max Richter Date: Mon, 19 Jan 2026 14:22:14 +0100 Subject: [PATCH 3/4] feat(app): allow disabling of runtime/registry caches --- app/src/lib/runtime/runtime-executor.ts | 2 +- .../runtime/worker-runtime-executor-backend.ts | 16 ++++++++++++++++ app/src/lib/runtime/worker-runtime-executor.ts | 6 ++++++ app/src/lib/settings/app-settings.svelte.ts | 13 +++++++++++++ app/src/routes/+page.svelte | 15 +++++++++++++++ packages/registry/src/node-registry-client.ts | 2 +- 6 files changed, 52 insertions(+), 2 deletions(-) diff --git a/app/src/lib/runtime/runtime-executor.ts b/app/src/lib/runtime/runtime-executor.ts index c7ff8c9..bf09954 100644 --- a/app/src/lib/runtime/runtime-executor.ts +++ b/app/src/lib/runtime/runtime-executor.ts @@ -64,7 +64,7 @@ export class MemoryRuntimeExecutor implements RuntimeExecutor { constructor( private registry: NodeRegistry, - private cache?: SyncCache, + public cache?: SyncCache, ) { this.cache = undefined; } diff --git a/app/src/lib/runtime/worker-runtime-executor-backend.ts b/app/src/lib/runtime/worker-runtime-executor-backend.ts index b26cc07..2c896e7 100644 --- a/app/src/lib/runtime/worker-runtime-executor-backend.ts +++ b/app/src/lib/runtime/worker-runtime-executor-backend.ts @@ -13,6 +13,22 @@ const executor = new MemoryRuntimeExecutor(nodeRegistry, cache); const performanceStore = createPerformanceStore(); executor.perf = performanceStore; +export async function setUseRegistryCache(useCache: boolean) { + if (useCache) { + nodeRegistry.cache = indexDbCache; + } else { + nodeRegistry.cache = undefined; + } +} + +export async function setUseRuntimeCache(useCache: boolean) { + if (useCache) { + executor.cache = cache; + } else { + executor.cache = undefined; + } +} + export async function executeGraph( graph: Graph, settings: Record, diff --git a/app/src/lib/runtime/worker-runtime-executor.ts b/app/src/lib/runtime/worker-runtime-executor.ts index 49ee7ba..8a2594f 100644 --- a/app/src/lib/runtime/worker-runtime-executor.ts +++ b/app/src/lib/runtime/worker-runtime-executor.ts @@ -11,5 +11,11 @@ export class WorkerRuntimeExecutor implements RuntimeExecutor { async getPerformanceData() { return this.worker.getPerformanceData(); } + set useRuntimeCache(useCache: boolean) { + this.worker.setUseRuntimeCache(useCache); + } + set useRegistryCache(useCache: boolean) { + this.worker.setUseRegistryCache(useCache); + } } diff --git a/app/src/lib/settings/app-settings.svelte.ts b/app/src/lib/settings/app-settings.svelte.ts index 54178b1..d5f5829 100644 --- a/app/src/lib/settings/app-settings.svelte.ts +++ b/app/src/lib/settings/app-settings.svelte.ts @@ -87,6 +87,19 @@ export const AppSettingTypes = { label: "Show Graph Source", value: false, }, + cache: { + title: "Cache", + useRuntimeCache: { + type: "boolean", + label: "Node Results", + value: true, + }, + useRegistryCache: { + type: "boolean", + label: "Node Source", + value: true, + }, + }, stressTest: { title: "Stress Test", amount: { diff --git a/app/src/routes/+page.svelte b/app/src/routes/+page.svelte index aee5f4b..aa8b9ab 100644 --- a/app/src/routes/+page.svelte +++ b/app/src/routes/+page.svelte @@ -42,6 +42,21 @@ appSettings.value.debug.useWorker ? workerRuntime : memoryRuntime, ); + $effect(() => { + if (appSettings.value.debug.cache.useRegistryCache) { + nodeRegistry.cache = registryCache; + } else { + nodeRegistry.cache = undefined; + } + + workerRuntime.setUseCache(appSettings.value.debug.cache.useRuntimeCache); + if (appSettings.value.debug.cache.useRuntimeCache) { + memoryRuntime.cache = runtimeCache; + } else { + memoryRuntime.cache = undefined; + } + }); + let activeNode = $state(undefined); let scene = $state(null!); diff --git a/packages/registry/src/node-registry-client.ts b/packages/registry/src/node-registry-client.ts index e10d9ce..7a3cf77 100644 --- a/packages/registry/src/node-registry-client.ts +++ b/packages/registry/src/node-registry-client.ts @@ -16,7 +16,7 @@ export class RemoteNodeRegistry implements NodeRegistry { constructor( private url: string, - private cache?: AsyncCache, + public cache?: AsyncCache, ) { } async fetchJson(url: string, skipCache = false) { From 450262b4ae48d5c7f9ecb23d2869a307b766751d Mon Sep 17 00:00:00 2001 From: Max Richter Date: Mon, 19 Jan 2026 14:24:47 +0100 Subject: [PATCH 4/4] fix(app): remove unused func --- app/src/routes/+page.svelte | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/app/src/routes/+page.svelte b/app/src/routes/+page.svelte index aa8b9ab..0a98614 100644 --- a/app/src/routes/+page.svelte +++ b/app/src/routes/+page.svelte @@ -43,13 +43,17 @@ ); $effect(() => { + workerRuntime.useRegistryCache = + appSettings.value.debug.cache.useRuntimeCache; + workerRuntime.useRuntimeCache = + appSettings.value.debug.cache.useRegistryCache; + if (appSettings.value.debug.cache.useRegistryCache) { nodeRegistry.cache = registryCache; } else { nodeRegistry.cache = undefined; } - workerRuntime.setUseCache(appSettings.value.debug.cache.useRuntimeCache); if (appSettings.value.debug.cache.useRuntimeCache) { memoryRuntime.cache = runtimeCache; } else {