From 6d70c1ed0e55bb6a4204e5729550f4ece90572aa Mon Sep 17 00:00:00 2001 From: Ilia Mashkov Date: Tue, 30 Dec 2025 11:05:13 +0300 Subject: [PATCH] feat(setup): Add oxlint, dprint, vite, playwright configs --- .gitignore | 9 + .pnp.cjs | 9878 ------------------------------------- .pnp.loader.mjs | 2126 -------- .yarn/install-state.gz | Bin 150127 -> 196027 bytes .yarnrc.yml | 1 + GLYPHDIFF_PROJECT_PLAN.md | 3004 ----------- dprint.json | 21 +- e2e/demo.test.ts | 4 +- lefthook.yml | 69 + package.json | 66 +- playwright.config.ts | 4 +- src/app.css | 121 + src/app.d.ts | 14 +- src/app.html | 16 +- src/lib/utils.ts | 13 + src/routes/+layout.svelte | 8 +- src/routes/+page.svelte | 9 +- svelte.config.js | 24 +- tsconfig.json | 36 +- vite.config.ts | 3 +- yarn.lock | 608 ++- 21 files changed, 898 insertions(+), 15136 deletions(-) delete mode 100755 .pnp.cjs delete mode 100644 .pnp.loader.mjs create mode 100644 .yarnrc.yml delete mode 100644 GLYPHDIFF_PROJECT_PLAN.md create mode 100644 lefthook.yml create mode 100644 src/app.css create mode 100644 src/lib/utils.ts diff --git a/.gitignore b/.gitignore index bff793d..d19106e 100644 --- a/.gitignore +++ b/.gitignore @@ -19,6 +19,15 @@ Thumbs.db !.env.example !.env.test +# Yarn +.yarn +.pnp.* + +# Zed +.zed + # Vite vite.config.js.timestamp-* vite.config.ts.timestamp-* + +/docs diff --git a/.pnp.cjs b/.pnp.cjs deleted file mode 100755 index 916a218..0000000 --- a/.pnp.cjs +++ /dev/null @@ -1,9878 +0,0 @@ -#!/usr/bin/env node -/* eslint-disable */ -// @ts-nocheck -"use strict"; - -const RAW_RUNTIME_STATE = -'{\ - "__info": [\ - "This file is automatically generated. Do not touch it, or risk",\ - "your modifications being lost."\ - ],\ - "dependencyTreeRoots": [\ - {\ - "name": "glyphdiff",\ - "reference": "workspace:."\ - }\ - ],\ - "enableTopLevelFallback": true,\ - "ignorePatternData": "(^(?:\\\\.yarn\\\\/sdks(?:\\\\/(?!\\\\.{1,2}(?:\\\\/|$))(?:(?:(?!(?:^|\\\\/)\\\\.{1,2}(?:\\\\/|$)).)*?)|$))$)",\ - "pnpZipBackend": "libzip",\ - "fallbackExclusionList": [\ - ["glyphdiff", ["workspace:."]]\ - ],\ - "fallbackPool": [\ - ],\ - "packageRegistryData": [\ - [null, [\ - [null, {\ - "packageLocation": "./",\ - "packageDependencies": [\ - ["@playwright/test", "npm:1.57.0"],\ - ["@sveltejs/adapter-auto", "virtual:f7561fcf711f481d620482469a2dbebe3761e771c8deb737eccd373d81f54db92ff85a785fd771382e660ad7ed33436906c28252e5ede1021290f553c7bf8dbc#npm:7.0.0"],\ - ["@sveltejs/kit", "virtual:f7561fcf711f481d620482469a2dbebe3761e771c8deb737eccd373d81f54db92ff85a785fd771382e660ad7ed33436906c28252e5ede1021290f553c7bf8dbc#npm:2.49.2"],\ - ["@sveltejs/vite-plugin-svelte", "virtual:f7561fcf711f481d620482469a2dbebe3761e771c8deb737eccd373d81f54db92ff85a785fd771382e660ad7ed33436906c28252e5ede1021290f553c7bf8dbc#npm:6.2.1"],\ - ["dprint", "npm:0.50.2"],\ - ["glyphdiff", "workspace:."],\ - ["oxlint", "virtual:f7561fcf711f481d620482469a2dbebe3761e771c8deb737eccd373d81f54db92ff85a785fd771382e660ad7ed33436906c28252e5ede1021290f553c7bf8dbc#npm:1.35.0"],\ - ["svelte", "npm:5.46.1"],\ - ["svelte-check", "virtual:f7561fcf711f481d620482469a2dbebe3761e771c8deb737eccd373d81f54db92ff85a785fd771382e660ad7ed33436906c28252e5ede1021290f553c7bf8dbc#npm:4.3.5"],\ - ["typescript", "patch:typescript@npm%3A5.9.3#optional!builtin::version=5.9.3&hash=5786d5"],\ - ["vite", "virtual:f7561fcf711f481d620482469a2dbebe3761e771c8deb737eccd373d81f54db92ff85a785fd771382e660ad7ed33436906c28252e5ede1021290f553c7bf8dbc#npm:7.3.0"]\ - ],\ - "linkType": "SOFT"\ - }]\ - ]],\ - ["@dprint/darwin-arm64", [\ - ["npm:0.50.2", {\ - "packageLocation": "./.yarn/unplugged/@dprint-darwin-arm64-npm-0.50.2-6c06c7bf32/node_modules/@dprint/darwin-arm64/",\ - "packageDependencies": [\ - ["@dprint/darwin-arm64", "npm:0.50.2"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@dprint/darwin-x64", [\ - ["npm:0.50.2", {\ - "packageLocation": "./.yarn/unplugged/@dprint-darwin-x64-npm-0.50.2-17af2e616a/node_modules/@dprint/darwin-x64/",\ - "packageDependencies": [\ - ["@dprint/darwin-x64", "npm:0.50.2"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@dprint/linux-arm64-glibc", [\ - ["npm:0.50.2", {\ - "packageLocation": "./.yarn/unplugged/@dprint-linux-arm64-glibc-npm-0.50.2-e9c006f4a9/node_modules/@dprint/linux-arm64-glibc/",\ - "packageDependencies": [\ - ["@dprint/linux-arm64-glibc", "npm:0.50.2"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@dprint/linux-arm64-musl", [\ - ["npm:0.50.2", {\ - "packageLocation": "./.yarn/unplugged/@dprint-linux-arm64-musl-npm-0.50.2-38da896c54/node_modules/@dprint/linux-arm64-musl/",\ - "packageDependencies": [\ - ["@dprint/linux-arm64-musl", "npm:0.50.2"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@dprint/linux-riscv64-glibc", [\ - ["npm:0.50.2", {\ - "packageLocation": "./.yarn/unplugged/@dprint-linux-riscv64-glibc-npm-0.50.2-d58f0f270b/node_modules/@dprint/linux-riscv64-glibc/",\ - "packageDependencies": [\ - ["@dprint/linux-riscv64-glibc", "npm:0.50.2"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@dprint/linux-x64-glibc", [\ - ["npm:0.50.2", {\ - "packageLocation": "./.yarn/unplugged/@dprint-linux-x64-glibc-npm-0.50.2-9901f3ce7e/node_modules/@dprint/linux-x64-glibc/",\ - "packageDependencies": [\ - ["@dprint/linux-x64-glibc", "npm:0.50.2"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@dprint/linux-x64-musl", [\ - ["npm:0.50.2", {\ - "packageLocation": "./.yarn/unplugged/@dprint-linux-x64-musl-npm-0.50.2-e1aee9b0df/node_modules/@dprint/linux-x64-musl/",\ - "packageDependencies": [\ - ["@dprint/linux-x64-musl", "npm:0.50.2"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@dprint/win32-arm64", [\ - ["npm:0.50.2", {\ - "packageLocation": "./.yarn/unplugged/@dprint-win32-arm64-npm-0.50.2-901c994e98/node_modules/@dprint/win32-arm64/",\ - "packageDependencies": [\ - ["@dprint/win32-arm64", "npm:0.50.2"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@dprint/win32-x64", [\ - ["npm:0.50.2", {\ - "packageLocation": "./.yarn/unplugged/@dprint-win32-x64-npm-0.50.2-2e9b32961d/node_modules/@dprint/win32-x64/",\ - "packageDependencies": [\ - ["@dprint/win32-x64", "npm:0.50.2"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@esbuild/aix-ppc64", [\ - ["npm:0.27.2", {\ - "packageLocation": "./.yarn/unplugged/@esbuild-aix-ppc64-npm-0.27.2-345b18ab38/node_modules/@esbuild/aix-ppc64/",\ - "packageDependencies": [\ - ["@esbuild/aix-ppc64", "npm:0.27.2"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@esbuild/android-arm", [\ - ["npm:0.27.2", {\ - "packageLocation": "./.yarn/unplugged/@esbuild-android-arm-npm-0.27.2-b9ce8adb94/node_modules/@esbuild/android-arm/",\ - "packageDependencies": [\ - ["@esbuild/android-arm", "npm:0.27.2"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@esbuild/android-arm64", [\ - ["npm:0.27.2", {\ - "packageLocation": "./.yarn/unplugged/@esbuild-android-arm64-npm-0.27.2-15df2cdd67/node_modules/@esbuild/android-arm64/",\ - "packageDependencies": [\ - ["@esbuild/android-arm64", "npm:0.27.2"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@esbuild/android-x64", [\ - ["npm:0.27.2", {\ - "packageLocation": "./.yarn/unplugged/@esbuild-android-x64-npm-0.27.2-66d99a6933/node_modules/@esbuild/android-x64/",\ - "packageDependencies": [\ - ["@esbuild/android-x64", "npm:0.27.2"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@esbuild/darwin-arm64", [\ - ["npm:0.27.2", {\ - "packageLocation": "./.yarn/unplugged/@esbuild-darwin-arm64-npm-0.27.2-d675c4a521/node_modules/@esbuild/darwin-arm64/",\ - "packageDependencies": [\ - ["@esbuild/darwin-arm64", "npm:0.27.2"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@esbuild/darwin-x64", [\ - ["npm:0.27.2", {\ - "packageLocation": "./.yarn/unplugged/@esbuild-darwin-x64-npm-0.27.2-ae63bf405f/node_modules/@esbuild/darwin-x64/",\ - "packageDependencies": [\ - ["@esbuild/darwin-x64", "npm:0.27.2"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@esbuild/freebsd-arm64", [\ - ["npm:0.27.2", {\ - "packageLocation": "./.yarn/unplugged/@esbuild-freebsd-arm64-npm-0.27.2-e37daed3be/node_modules/@esbuild/freebsd-arm64/",\ - "packageDependencies": [\ - ["@esbuild/freebsd-arm64", "npm:0.27.2"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@esbuild/freebsd-x64", [\ - ["npm:0.27.2", {\ - "packageLocation": "./.yarn/unplugged/@esbuild-freebsd-x64-npm-0.27.2-4cb2e19a78/node_modules/@esbuild/freebsd-x64/",\ - "packageDependencies": [\ - ["@esbuild/freebsd-x64", "npm:0.27.2"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@esbuild/linux-arm", [\ - ["npm:0.27.2", {\ - "packageLocation": "./.yarn/unplugged/@esbuild-linux-arm-npm-0.27.2-43d77dd61a/node_modules/@esbuild/linux-arm/",\ - "packageDependencies": [\ - ["@esbuild/linux-arm", "npm:0.27.2"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@esbuild/linux-arm64", [\ - ["npm:0.27.2", {\ - "packageLocation": "./.yarn/unplugged/@esbuild-linux-arm64-npm-0.27.2-bf1b0979ac/node_modules/@esbuild/linux-arm64/",\ - "packageDependencies": [\ - ["@esbuild/linux-arm64", "npm:0.27.2"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@esbuild/linux-ia32", [\ - ["npm:0.27.2", {\ - "packageLocation": "./.yarn/unplugged/@esbuild-linux-ia32-npm-0.27.2-9e57150846/node_modules/@esbuild/linux-ia32/",\ - "packageDependencies": [\ - ["@esbuild/linux-ia32", "npm:0.27.2"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@esbuild/linux-loong64", [\ - ["npm:0.27.2", {\ - "packageLocation": "./.yarn/unplugged/@esbuild-linux-loong64-npm-0.27.2-a322ec9c1d/node_modules/@esbuild/linux-loong64/",\ - "packageDependencies": [\ - ["@esbuild/linux-loong64", "npm:0.27.2"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@esbuild/linux-mips64el", [\ - ["npm:0.27.2", {\ - "packageLocation": "./.yarn/unplugged/@esbuild-linux-mips64el-npm-0.27.2-9b26d4ee73/node_modules/@esbuild/linux-mips64el/",\ - "packageDependencies": [\ - ["@esbuild/linux-mips64el", "npm:0.27.2"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@esbuild/linux-ppc64", [\ - ["npm:0.27.2", {\ - "packageLocation": "./.yarn/unplugged/@esbuild-linux-ppc64-npm-0.27.2-28d849768e/node_modules/@esbuild/linux-ppc64/",\ - "packageDependencies": [\ - ["@esbuild/linux-ppc64", "npm:0.27.2"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@esbuild/linux-riscv64", [\ - ["npm:0.27.2", {\ - "packageLocation": "./.yarn/unplugged/@esbuild-linux-riscv64-npm-0.27.2-73c96cf77f/node_modules/@esbuild/linux-riscv64/",\ - "packageDependencies": [\ - ["@esbuild/linux-riscv64", "npm:0.27.2"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@esbuild/linux-s390x", [\ - ["npm:0.27.2", {\ - "packageLocation": "./.yarn/unplugged/@esbuild-linux-s390x-npm-0.27.2-1b2065e648/node_modules/@esbuild/linux-s390x/",\ - "packageDependencies": [\ - ["@esbuild/linux-s390x", "npm:0.27.2"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@esbuild/linux-x64", [\ - ["npm:0.27.2", {\ - "packageLocation": "./.yarn/unplugged/@esbuild-linux-x64-npm-0.27.2-11f1a3d9db/node_modules/@esbuild/linux-x64/",\ - "packageDependencies": [\ - ["@esbuild/linux-x64", "npm:0.27.2"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@esbuild/netbsd-arm64", [\ - ["npm:0.27.2", {\ - "packageLocation": "./.yarn/unplugged/@esbuild-netbsd-arm64-npm-0.27.2-dd6c103966/node_modules/@esbuild/netbsd-arm64/",\ - "packageDependencies": [\ - ["@esbuild/netbsd-arm64", "npm:0.27.2"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@esbuild/netbsd-x64", [\ - ["npm:0.27.2", {\ - "packageLocation": "./.yarn/unplugged/@esbuild-netbsd-x64-npm-0.27.2-1e03e8a7a5/node_modules/@esbuild/netbsd-x64/",\ - "packageDependencies": [\ - ["@esbuild/netbsd-x64", "npm:0.27.2"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@esbuild/openbsd-arm64", [\ - ["npm:0.27.2", {\ - "packageLocation": "./.yarn/unplugged/@esbuild-openbsd-arm64-npm-0.27.2-1d7a76cae4/node_modules/@esbuild/openbsd-arm64/",\ - "packageDependencies": [\ - ["@esbuild/openbsd-arm64", "npm:0.27.2"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@esbuild/openbsd-x64", [\ - ["npm:0.27.2", {\ - "packageLocation": "./.yarn/unplugged/@esbuild-openbsd-x64-npm-0.27.2-27238acba8/node_modules/@esbuild/openbsd-x64/",\ - "packageDependencies": [\ - ["@esbuild/openbsd-x64", "npm:0.27.2"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@esbuild/openharmony-arm64", [\ - ["npm:0.27.2", {\ - "packageLocation": "./.yarn/unplugged/@esbuild-openharmony-arm64-npm-0.27.2-b815985320/node_modules/@esbuild/openharmony-arm64/",\ - "packageDependencies": [\ - ["@esbuild/openharmony-arm64", "npm:0.27.2"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@esbuild/sunos-x64", [\ - ["npm:0.27.2", {\ - "packageLocation": "./.yarn/unplugged/@esbuild-sunos-x64-npm-0.27.2-fb3c4c523d/node_modules/@esbuild/sunos-x64/",\ - "packageDependencies": [\ - ["@esbuild/sunos-x64", "npm:0.27.2"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@esbuild/win32-arm64", [\ - ["npm:0.27.2", {\ - "packageLocation": "./.yarn/unplugged/@esbuild-win32-arm64-npm-0.27.2-78a0e828ec/node_modules/@esbuild/win32-arm64/",\ - "packageDependencies": [\ - ["@esbuild/win32-arm64", "npm:0.27.2"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@esbuild/win32-ia32", [\ - ["npm:0.27.2", {\ - "packageLocation": "./.yarn/unplugged/@esbuild-win32-ia32-npm-0.27.2-f7488076af/node_modules/@esbuild/win32-ia32/",\ - "packageDependencies": [\ - ["@esbuild/win32-ia32", "npm:0.27.2"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@esbuild/win32-x64", [\ - ["npm:0.27.2", {\ - "packageLocation": "./.yarn/unplugged/@esbuild-win32-x64-npm-0.27.2-fb03408001/node_modules/@esbuild/win32-x64/",\ - "packageDependencies": [\ - ["@esbuild/win32-x64", "npm:0.27.2"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@isaacs/balanced-match", [\ - ["npm:4.0.1", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/@isaacs-balanced-match-npm-4.0.1-8965afafe6-10c0.zip/node_modules/@isaacs/balanced-match/",\ - "packageDependencies": [\ - ["@isaacs/balanced-match", "npm:4.0.1"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@isaacs/brace-expansion", [\ - ["npm:5.0.0", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/@isaacs-brace-expansion-npm-5.0.0-754d3cb3f5-10c0.zip/node_modules/@isaacs/brace-expansion/",\ - "packageDependencies": [\ - ["@isaacs/balanced-match", "npm:4.0.1"],\ - ["@isaacs/brace-expansion", "npm:5.0.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@isaacs/fs-minipass", [\ - ["npm:4.0.1", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/@isaacs-fs-minipass-npm-4.0.1-677026e841-10c0.zip/node_modules/@isaacs/fs-minipass/",\ - "packageDependencies": [\ - ["@isaacs/fs-minipass", "npm:4.0.1"],\ - ["minipass", "npm:7.1.2"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@jridgewell/gen-mapping", [\ - ["npm:0.3.13", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/@jridgewell-gen-mapping-npm-0.3.13-9bd96ac800-10c0.zip/node_modules/@jridgewell/gen-mapping/",\ - "packageDependencies": [\ - ["@jridgewell/gen-mapping", "npm:0.3.13"],\ - ["@jridgewell/sourcemap-codec", "npm:1.5.5"],\ - ["@jridgewell/trace-mapping", "npm:0.3.31"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@jridgewell/remapping", [\ - ["npm:2.3.5", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/@jridgewell-remapping-npm-2.3.5-df8dacc063-10c0.zip/node_modules/@jridgewell/remapping/",\ - "packageDependencies": [\ - ["@jridgewell/gen-mapping", "npm:0.3.13"],\ - ["@jridgewell/remapping", "npm:2.3.5"],\ - ["@jridgewell/trace-mapping", "npm:0.3.31"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@jridgewell/resolve-uri", [\ - ["npm:3.1.2", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/@jridgewell-resolve-uri-npm-3.1.2-5bc4245992-10c0.zip/node_modules/@jridgewell/resolve-uri/",\ - "packageDependencies": [\ - ["@jridgewell/resolve-uri", "npm:3.1.2"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@jridgewell/sourcemap-codec", [\ - ["npm:1.5.5", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/@jridgewell-sourcemap-codec-npm-1.5.5-5189d9fc79-10c0.zip/node_modules/@jridgewell/sourcemap-codec/",\ - "packageDependencies": [\ - ["@jridgewell/sourcemap-codec", "npm:1.5.5"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@jridgewell/trace-mapping", [\ - ["npm:0.3.31", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/@jridgewell-trace-mapping-npm-0.3.31-1ae81d75ac-10c0.zip/node_modules/@jridgewell/trace-mapping/",\ - "packageDependencies": [\ - ["@jridgewell/resolve-uri", "npm:3.1.2"],\ - ["@jridgewell/sourcemap-codec", "npm:1.5.5"],\ - ["@jridgewell/trace-mapping", "npm:0.3.31"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@npmcli/agent", [\ - ["npm:4.0.0", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/@npmcli-agent-npm-4.0.0-502e5ae4f0-10c0.zip/node_modules/@npmcli/agent/",\ - "packageDependencies": [\ - ["@npmcli/agent", "npm:4.0.0"],\ - ["agent-base", "npm:7.1.4"],\ - ["http-proxy-agent", "npm:7.0.2"],\ - ["https-proxy-agent", "npm:7.0.6"],\ - ["lru-cache", "npm:11.2.4"],\ - ["socks-proxy-agent", "npm:8.0.5"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@npmcli/fs", [\ - ["npm:5.0.0", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/@npmcli-fs-npm-5.0.0-9d737ae2f3-10c0.zip/node_modules/@npmcli/fs/",\ - "packageDependencies": [\ - ["@npmcli/fs", "npm:5.0.0"],\ - ["semver", "npm:7.7.3"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@oxlint/darwin-arm64", [\ - ["npm:1.35.0", {\ - "packageLocation": "./.yarn/unplugged/@oxlint-darwin-arm64-npm-1.35.0-055e8cc978/node_modules/@oxlint/darwin-arm64/",\ - "packageDependencies": [\ - ["@oxlint/darwin-arm64", "npm:1.35.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@oxlint/darwin-x64", [\ - ["npm:1.35.0", {\ - "packageLocation": "./.yarn/unplugged/@oxlint-darwin-x64-npm-1.35.0-2ea828c882/node_modules/@oxlint/darwin-x64/",\ - "packageDependencies": [\ - ["@oxlint/darwin-x64", "npm:1.35.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@oxlint/linux-arm64-gnu", [\ - ["npm:1.35.0", {\ - "packageLocation": "./.yarn/unplugged/@oxlint-linux-arm64-gnu-npm-1.35.0-b31d573a9d/node_modules/@oxlint/linux-arm64-gnu/",\ - "packageDependencies": [\ - ["@oxlint/linux-arm64-gnu", "npm:1.35.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@oxlint/linux-arm64-musl", [\ - ["npm:1.35.0", {\ - "packageLocation": "./.yarn/unplugged/@oxlint-linux-arm64-musl-npm-1.35.0-40a7187bca/node_modules/@oxlint/linux-arm64-musl/",\ - "packageDependencies": [\ - ["@oxlint/linux-arm64-musl", "npm:1.35.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@oxlint/linux-x64-gnu", [\ - ["npm:1.35.0", {\ - "packageLocation": "./.yarn/unplugged/@oxlint-linux-x64-gnu-npm-1.35.0-eea1411815/node_modules/@oxlint/linux-x64-gnu/",\ - "packageDependencies": [\ - ["@oxlint/linux-x64-gnu", "npm:1.35.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@oxlint/linux-x64-musl", [\ - ["npm:1.35.0", {\ - "packageLocation": "./.yarn/unplugged/@oxlint-linux-x64-musl-npm-1.35.0-dd62ea2186/node_modules/@oxlint/linux-x64-musl/",\ - "packageDependencies": [\ - ["@oxlint/linux-x64-musl", "npm:1.35.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@oxlint/win32-arm64", [\ - ["npm:1.35.0", {\ - "packageLocation": "./.yarn/unplugged/@oxlint-win32-arm64-npm-1.35.0-fe21880669/node_modules/@oxlint/win32-arm64/",\ - "packageDependencies": [\ - ["@oxlint/win32-arm64", "npm:1.35.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@oxlint/win32-x64", [\ - ["npm:1.35.0", {\ - "packageLocation": "./.yarn/unplugged/@oxlint-win32-x64-npm-1.35.0-cce5657d68/node_modules/@oxlint/win32-x64/",\ - "packageDependencies": [\ - ["@oxlint/win32-x64", "npm:1.35.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@playwright/test", [\ - ["npm:1.57.0", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/@playwright-test-npm-1.57.0-d5b9717312-10c0.zip/node_modules/@playwright/test/",\ - "packageDependencies": [\ - ["@playwright/test", "npm:1.57.0"],\ - ["playwright", "npm:1.57.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@polka/url", [\ - ["npm:1.0.0-next.29", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/@polka-url-npm-1.0.0-next.29-b32b372106-10c0.zip/node_modules/@polka/url/",\ - "packageDependencies": [\ - ["@polka/url", "npm:1.0.0-next.29"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@rollup/rollup-android-arm-eabi", [\ - ["npm:4.54.0", {\ - "packageLocation": "./.yarn/unplugged/@rollup-rollup-android-arm-eabi-npm-4.54.0-5c987bc0f8/node_modules/@rollup/rollup-android-arm-eabi/",\ - "packageDependencies": [\ - ["@rollup/rollup-android-arm-eabi", "npm:4.54.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@rollup/rollup-android-arm64", [\ - ["npm:4.54.0", {\ - "packageLocation": "./.yarn/unplugged/@rollup-rollup-android-arm64-npm-4.54.0-e241a385d6/node_modules/@rollup/rollup-android-arm64/",\ - "packageDependencies": [\ - ["@rollup/rollup-android-arm64", "npm:4.54.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@rollup/rollup-darwin-arm64", [\ - ["npm:4.54.0", {\ - "packageLocation": "./.yarn/unplugged/@rollup-rollup-darwin-arm64-npm-4.54.0-d009a30342/node_modules/@rollup/rollup-darwin-arm64/",\ - "packageDependencies": [\ - ["@rollup/rollup-darwin-arm64", "npm:4.54.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@rollup/rollup-darwin-x64", [\ - ["npm:4.54.0", {\ - "packageLocation": "./.yarn/unplugged/@rollup-rollup-darwin-x64-npm-4.54.0-16524b986e/node_modules/@rollup/rollup-darwin-x64/",\ - "packageDependencies": [\ - ["@rollup/rollup-darwin-x64", "npm:4.54.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@rollup/rollup-freebsd-arm64", [\ - ["npm:4.54.0", {\ - "packageLocation": "./.yarn/unplugged/@rollup-rollup-freebsd-arm64-npm-4.54.0-e4f127efa2/node_modules/@rollup/rollup-freebsd-arm64/",\ - "packageDependencies": [\ - ["@rollup/rollup-freebsd-arm64", "npm:4.54.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@rollup/rollup-freebsd-x64", [\ - ["npm:4.54.0", {\ - "packageLocation": "./.yarn/unplugged/@rollup-rollup-freebsd-x64-npm-4.54.0-7536eb9474/node_modules/@rollup/rollup-freebsd-x64/",\ - "packageDependencies": [\ - ["@rollup/rollup-freebsd-x64", "npm:4.54.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@rollup/rollup-linux-arm-gnueabihf", [\ - ["npm:4.54.0", {\ - "packageLocation": "./.yarn/unplugged/@rollup-rollup-linux-arm-gnueabihf-npm-4.54.0-63328931bb/node_modules/@rollup/rollup-linux-arm-gnueabihf/",\ - "packageDependencies": [\ - ["@rollup/rollup-linux-arm-gnueabihf", "npm:4.54.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@rollup/rollup-linux-arm-musleabihf", [\ - ["npm:4.54.0", {\ - "packageLocation": "./.yarn/unplugged/@rollup-rollup-linux-arm-musleabihf-npm-4.54.0-c8e78f6a7d/node_modules/@rollup/rollup-linux-arm-musleabihf/",\ - "packageDependencies": [\ - ["@rollup/rollup-linux-arm-musleabihf", "npm:4.54.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@rollup/rollup-linux-arm64-gnu", [\ - ["npm:4.54.0", {\ - "packageLocation": "./.yarn/unplugged/@rollup-rollup-linux-arm64-gnu-npm-4.54.0-9b5636373e/node_modules/@rollup/rollup-linux-arm64-gnu/",\ - "packageDependencies": [\ - ["@rollup/rollup-linux-arm64-gnu", "npm:4.54.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@rollup/rollup-linux-arm64-musl", [\ - ["npm:4.54.0", {\ - "packageLocation": "./.yarn/unplugged/@rollup-rollup-linux-arm64-musl-npm-4.54.0-a26520c963/node_modules/@rollup/rollup-linux-arm64-musl/",\ - "packageDependencies": [\ - ["@rollup/rollup-linux-arm64-musl", "npm:4.54.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@rollup/rollup-linux-loong64-gnu", [\ - ["npm:4.54.0", {\ - "packageLocation": "./.yarn/unplugged/@rollup-rollup-linux-loong64-gnu-npm-4.54.0-74f934ff03/node_modules/@rollup/rollup-linux-loong64-gnu/",\ - "packageDependencies": [\ - ["@rollup/rollup-linux-loong64-gnu", "npm:4.54.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@rollup/rollup-linux-ppc64-gnu", [\ - ["npm:4.54.0", {\ - "packageLocation": "./.yarn/unplugged/@rollup-rollup-linux-ppc64-gnu-npm-4.54.0-eabf73b6dc/node_modules/@rollup/rollup-linux-ppc64-gnu/",\ - "packageDependencies": [\ - ["@rollup/rollup-linux-ppc64-gnu", "npm:4.54.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@rollup/rollup-linux-riscv64-gnu", [\ - ["npm:4.54.0", {\ - "packageLocation": "./.yarn/unplugged/@rollup-rollup-linux-riscv64-gnu-npm-4.54.0-9e6355f649/node_modules/@rollup/rollup-linux-riscv64-gnu/",\ - "packageDependencies": [\ - ["@rollup/rollup-linux-riscv64-gnu", "npm:4.54.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@rollup/rollup-linux-riscv64-musl", [\ - ["npm:4.54.0", {\ - "packageLocation": "./.yarn/unplugged/@rollup-rollup-linux-riscv64-musl-npm-4.54.0-d0d77f7451/node_modules/@rollup/rollup-linux-riscv64-musl/",\ - "packageDependencies": [\ - ["@rollup/rollup-linux-riscv64-musl", "npm:4.54.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@rollup/rollup-linux-s390x-gnu", [\ - ["npm:4.54.0", {\ - "packageLocation": "./.yarn/unplugged/@rollup-rollup-linux-s390x-gnu-npm-4.54.0-846557d0d4/node_modules/@rollup/rollup-linux-s390x-gnu/",\ - "packageDependencies": [\ - ["@rollup/rollup-linux-s390x-gnu", "npm:4.54.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@rollup/rollup-linux-x64-gnu", [\ - ["npm:4.54.0", {\ - "packageLocation": "./.yarn/unplugged/@rollup-rollup-linux-x64-gnu-npm-4.54.0-a9c3b4c818/node_modules/@rollup/rollup-linux-x64-gnu/",\ - "packageDependencies": [\ - ["@rollup/rollup-linux-x64-gnu", "npm:4.54.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@rollup/rollup-linux-x64-musl", [\ - ["npm:4.54.0", {\ - "packageLocation": "./.yarn/unplugged/@rollup-rollup-linux-x64-musl-npm-4.54.0-d360cc585a/node_modules/@rollup/rollup-linux-x64-musl/",\ - "packageDependencies": [\ - ["@rollup/rollup-linux-x64-musl", "npm:4.54.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@rollup/rollup-openharmony-arm64", [\ - ["npm:4.54.0", {\ - "packageLocation": "./.yarn/unplugged/@rollup-rollup-openharmony-arm64-npm-4.54.0-b8650f377b/node_modules/@rollup/rollup-openharmony-arm64/",\ - "packageDependencies": [\ - ["@rollup/rollup-openharmony-arm64", "npm:4.54.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@rollup/rollup-win32-arm64-msvc", [\ - ["npm:4.54.0", {\ - "packageLocation": "./.yarn/unplugged/@rollup-rollup-win32-arm64-msvc-npm-4.54.0-904aed0643/node_modules/@rollup/rollup-win32-arm64-msvc/",\ - "packageDependencies": [\ - ["@rollup/rollup-win32-arm64-msvc", "npm:4.54.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@rollup/rollup-win32-ia32-msvc", [\ - ["npm:4.54.0", {\ - "packageLocation": "./.yarn/unplugged/@rollup-rollup-win32-ia32-msvc-npm-4.54.0-7a6f5aade6/node_modules/@rollup/rollup-win32-ia32-msvc/",\ - "packageDependencies": [\ - ["@rollup/rollup-win32-ia32-msvc", "npm:4.54.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@rollup/rollup-win32-x64-gnu", [\ - ["npm:4.54.0", {\ - "packageLocation": "./.yarn/unplugged/@rollup-rollup-win32-x64-gnu-npm-4.54.0-d0ee0ef445/node_modules/@rollup/rollup-win32-x64-gnu/",\ - "packageDependencies": [\ - ["@rollup/rollup-win32-x64-gnu", "npm:4.54.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@rollup/rollup-win32-x64-msvc", [\ - ["npm:4.54.0", {\ - "packageLocation": "./.yarn/unplugged/@rollup-rollup-win32-x64-msvc-npm-4.54.0-567c4adf25/node_modules/@rollup/rollup-win32-x64-msvc/",\ - "packageDependencies": [\ - ["@rollup/rollup-win32-x64-msvc", "npm:4.54.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@standard-schema/spec", [\ - ["npm:1.1.0", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/@standard-schema-spec-npm-1.1.0-d3e5ccd2e2-10c0.zip/node_modules/@standard-schema/spec/",\ - "packageDependencies": [\ - ["@standard-schema/spec", "npm:1.1.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@sveltejs/acorn-typescript", [\ - ["npm:1.0.8", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/@sveltejs-acorn-typescript-npm-1.0.8-19447f7e72-10c0.zip/node_modules/@sveltejs/acorn-typescript/",\ - "packageDependencies": [\ - ["@sveltejs/acorn-typescript", "npm:1.0.8"]\ - ],\ - "linkType": "SOFT"\ - }],\ - ["virtual:a6c55ea9de82660519a4b0864315b3b30e10ee152c8339686ba6e2ba939e74cd0a67ef3c9bcef3476be827df82ff71c0899264eeeeeed28d7de83c5a06e785aa#npm:1.0.8", {\ - "packageLocation": "./.yarn/__virtual__/@sveltejs-acorn-typescript-virtual-c0bc413532/4/.local/share/yarn/berry/cache/@sveltejs-acorn-typescript-npm-1.0.8-19447f7e72-10c0.zip/node_modules/@sveltejs/acorn-typescript/",\ - "packageDependencies": [\ - ["@sveltejs/acorn-typescript", "virtual:a6c55ea9de82660519a4b0864315b3b30e10ee152c8339686ba6e2ba939e74cd0a67ef3c9bcef3476be827df82ff71c0899264eeeeeed28d7de83c5a06e785aa#npm:1.0.8"],\ - ["@types/acorn", null],\ - ["acorn", "npm:8.15.0"]\ - ],\ - "packagePeers": [\ - "@types/acorn",\ - "acorn"\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@sveltejs/adapter-auto", [\ - ["npm:7.0.0", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/@sveltejs-adapter-auto-npm-7.0.0-cdbf5495c3-10c0.zip/node_modules/@sveltejs/adapter-auto/",\ - "packageDependencies": [\ - ["@sveltejs/adapter-auto", "npm:7.0.0"]\ - ],\ - "linkType": "SOFT"\ - }],\ - ["virtual:f7561fcf711f481d620482469a2dbebe3761e771c8deb737eccd373d81f54db92ff85a785fd771382e660ad7ed33436906c28252e5ede1021290f553c7bf8dbc#npm:7.0.0", {\ - "packageLocation": "./.yarn/__virtual__/@sveltejs-adapter-auto-virtual-cb3c5572c3/4/.local/share/yarn/berry/cache/@sveltejs-adapter-auto-npm-7.0.0-cdbf5495c3-10c0.zip/node_modules/@sveltejs/adapter-auto/",\ - "packageDependencies": [\ - ["@sveltejs/adapter-auto", "virtual:f7561fcf711f481d620482469a2dbebe3761e771c8deb737eccd373d81f54db92ff85a785fd771382e660ad7ed33436906c28252e5ede1021290f553c7bf8dbc#npm:7.0.0"],\ - ["@sveltejs/kit", "virtual:f7561fcf711f481d620482469a2dbebe3761e771c8deb737eccd373d81f54db92ff85a785fd771382e660ad7ed33436906c28252e5ede1021290f553c7bf8dbc#npm:2.49.2"],\ - ["@types/sveltejs__kit", null]\ - ],\ - "packagePeers": [\ - "@sveltejs/kit",\ - "@types/sveltejs__kit"\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@sveltejs/kit", [\ - ["npm:2.49.2", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/@sveltejs-kit-npm-2.49.2-5ebbcb05d9-10c0.zip/node_modules/@sveltejs/kit/",\ - "packageDependencies": [\ - ["@sveltejs/kit", "npm:2.49.2"]\ - ],\ - "linkType": "SOFT"\ - }],\ - ["virtual:f7561fcf711f481d620482469a2dbebe3761e771c8deb737eccd373d81f54db92ff85a785fd771382e660ad7ed33436906c28252e5ede1021290f553c7bf8dbc#npm:2.49.2", {\ - "packageLocation": "./.yarn/__virtual__/@sveltejs-kit-virtual-492e3c411c/4/.local/share/yarn/berry/cache/@sveltejs-kit-npm-2.49.2-5ebbcb05d9-10c0.zip/node_modules/@sveltejs/kit/",\ - "packageDependencies": [\ - ["@opentelemetry/api", null],\ - ["@standard-schema/spec", "npm:1.1.0"],\ - ["@sveltejs/acorn-typescript", "virtual:a6c55ea9de82660519a4b0864315b3b30e10ee152c8339686ba6e2ba939e74cd0a67ef3c9bcef3476be827df82ff71c0899264eeeeeed28d7de83c5a06e785aa#npm:1.0.8"],\ - ["@sveltejs/kit", "virtual:f7561fcf711f481d620482469a2dbebe3761e771c8deb737eccd373d81f54db92ff85a785fd771382e660ad7ed33436906c28252e5ede1021290f553c7bf8dbc#npm:2.49.2"],\ - ["@sveltejs/vite-plugin-svelte", "virtual:f7561fcf711f481d620482469a2dbebe3761e771c8deb737eccd373d81f54db92ff85a785fd771382e660ad7ed33436906c28252e5ede1021290f553c7bf8dbc#npm:6.2.1"],\ - ["@types/cookie", "npm:0.6.0"],\ - ["@types/opentelemetry__api", null],\ - ["@types/svelte", null],\ - ["@types/sveltejs__vite-plugin-svelte", null],\ - ["@types/vite", null],\ - ["acorn", "npm:8.15.0"],\ - ["cookie", "npm:0.6.0"],\ - ["devalue", "npm:5.6.1"],\ - ["esm-env", "npm:1.2.2"],\ - ["kleur", "npm:4.1.5"],\ - ["magic-string", "npm:0.30.21"],\ - ["mrmime", "npm:2.0.1"],\ - ["sade", "npm:1.8.1"],\ - ["set-cookie-parser", "npm:2.7.2"],\ - ["sirv", "npm:3.0.2"],\ - ["svelte", "npm:5.46.1"],\ - ["vite", "virtual:f7561fcf711f481d620482469a2dbebe3761e771c8deb737eccd373d81f54db92ff85a785fd771382e660ad7ed33436906c28252e5ede1021290f553c7bf8dbc#npm:7.3.0"]\ - ],\ - "packagePeers": [\ - "@opentelemetry/api",\ - "@sveltejs/vite-plugin-svelte",\ - "@types/opentelemetry__api",\ - "@types/svelte",\ - "@types/sveltejs__vite-plugin-svelte",\ - "@types/vite",\ - "svelte",\ - "vite"\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@sveltejs/vite-plugin-svelte", [\ - ["npm:6.2.1", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/@sveltejs-vite-plugin-svelte-npm-6.2.1-109bf2663f-10c0.zip/node_modules/@sveltejs/vite-plugin-svelte/",\ - "packageDependencies": [\ - ["@sveltejs/vite-plugin-svelte", "npm:6.2.1"]\ - ],\ - "linkType": "SOFT"\ - }],\ - ["virtual:f7561fcf711f481d620482469a2dbebe3761e771c8deb737eccd373d81f54db92ff85a785fd771382e660ad7ed33436906c28252e5ede1021290f553c7bf8dbc#npm:6.2.1", {\ - "packageLocation": "./.yarn/__virtual__/@sveltejs-vite-plugin-svelte-virtual-1b5ed8efb6/4/.local/share/yarn/berry/cache/@sveltejs-vite-plugin-svelte-npm-6.2.1-109bf2663f-10c0.zip/node_modules/@sveltejs/vite-plugin-svelte/",\ - "packageDependencies": [\ - ["@sveltejs/vite-plugin-svelte", "virtual:f7561fcf711f481d620482469a2dbebe3761e771c8deb737eccd373d81f54db92ff85a785fd771382e660ad7ed33436906c28252e5ede1021290f553c7bf8dbc#npm:6.2.1"],\ - ["@sveltejs/vite-plugin-svelte-inspector", "virtual:1b5ed8efb66eecc58d54f4ce66d6b24d1d7d9b16bc3a97b929761d21607447f32079dbb5e602dd10e01c9f672487b49b24bd8ec2a92cea203713d35b40fc7aec#npm:5.0.1"],\ - ["@types/svelte", null],\ - ["@types/vite", null],\ - ["debug", "virtual:643ed7cc338bcf145a82d8b05b3bef6bcf150ca545df386225596f10ce53cc90b88b3ca83e348ade1ccea5f3f8e76c92d2f0e2ba544da60d40aff9921c56872d#npm:4.4.3"],\ - ["deepmerge", "npm:4.3.1"],\ - ["magic-string", "npm:0.30.21"],\ - ["svelte", "npm:5.46.1"],\ - ["vite", "virtual:f7561fcf711f481d620482469a2dbebe3761e771c8deb737eccd373d81f54db92ff85a785fd771382e660ad7ed33436906c28252e5ede1021290f553c7bf8dbc#npm:7.3.0"],\ - ["vitefu", "virtual:1b5ed8efb66eecc58d54f4ce66d6b24d1d7d9b16bc3a97b929761d21607447f32079dbb5e602dd10e01c9f672487b49b24bd8ec2a92cea203713d35b40fc7aec#npm:1.1.1"]\ - ],\ - "packagePeers": [\ - "@types/svelte",\ - "@types/vite",\ - "svelte",\ - "vite"\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@sveltejs/vite-plugin-svelte-inspector", [\ - ["npm:5.0.1", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/@sveltejs-vite-plugin-svelte-inspector-npm-5.0.1-1bb26f90cc-10c0.zip/node_modules/@sveltejs/vite-plugin-svelte-inspector/",\ - "packageDependencies": [\ - ["@sveltejs/vite-plugin-svelte-inspector", "npm:5.0.1"]\ - ],\ - "linkType": "SOFT"\ - }],\ - ["virtual:1b5ed8efb66eecc58d54f4ce66d6b24d1d7d9b16bc3a97b929761d21607447f32079dbb5e602dd10e01c9f672487b49b24bd8ec2a92cea203713d35b40fc7aec#npm:5.0.1", {\ - "packageLocation": "./.yarn/__virtual__/@sveltejs-vite-plugin-svelte-inspector-virtual-1b5ed48ab2/4/.local/share/yarn/berry/cache/@sveltejs-vite-plugin-svelte-inspector-npm-5.0.1-1bb26f90cc-10c0.zip/node_modules/@sveltejs/vite-plugin-svelte-inspector/",\ - "packageDependencies": [\ - ["@sveltejs/vite-plugin-svelte", "virtual:f7561fcf711f481d620482469a2dbebe3761e771c8deb737eccd373d81f54db92ff85a785fd771382e660ad7ed33436906c28252e5ede1021290f553c7bf8dbc#npm:6.2.1"],\ - ["@sveltejs/vite-plugin-svelte-inspector", "virtual:1b5ed8efb66eecc58d54f4ce66d6b24d1d7d9b16bc3a97b929761d21607447f32079dbb5e602dd10e01c9f672487b49b24bd8ec2a92cea203713d35b40fc7aec#npm:5.0.1"],\ - ["@types/svelte", null],\ - ["@types/sveltejs__vite-plugin-svelte", null],\ - ["@types/vite", null],\ - ["debug", "virtual:643ed7cc338bcf145a82d8b05b3bef6bcf150ca545df386225596f10ce53cc90b88b3ca83e348ade1ccea5f3f8e76c92d2f0e2ba544da60d40aff9921c56872d#npm:4.4.3"],\ - ["svelte", "npm:5.46.1"],\ - ["vite", "virtual:f7561fcf711f481d620482469a2dbebe3761e771c8deb737eccd373d81f54db92ff85a785fd771382e660ad7ed33436906c28252e5ede1021290f553c7bf8dbc#npm:7.3.0"]\ - ],\ - "packagePeers": [\ - "@sveltejs/vite-plugin-svelte",\ - "@types/svelte",\ - "@types/sveltejs__vite-plugin-svelte",\ - "@types/vite",\ - "svelte",\ - "vite"\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@types/cookie", [\ - ["npm:0.6.0", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/@types-cookie-npm-0.6.0-1f4c3f48f0-10c0.zip/node_modules/@types/cookie/",\ - "packageDependencies": [\ - ["@types/cookie", "npm:0.6.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["@types/estree", [\ - ["npm:1.0.8", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/@types-estree-npm-1.0.8-2195bac6d6-10c0.zip/node_modules/@types/estree/",\ - "packageDependencies": [\ - ["@types/estree", "npm:1.0.8"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["abbrev", [\ - ["npm:4.0.0", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/abbrev-npm-4.0.0-7d848a1ef0-10c0.zip/node_modules/abbrev/",\ - "packageDependencies": [\ - ["abbrev", "npm:4.0.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["acorn", [\ - ["npm:8.15.0", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/acorn-npm-8.15.0-0764cf600e-10c0.zip/node_modules/acorn/",\ - "packageDependencies": [\ - ["acorn", "npm:8.15.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["agent-base", [\ - ["npm:7.1.4", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/agent-base-npm-7.1.4-cb8b4604d5-10c0.zip/node_modules/agent-base/",\ - "packageDependencies": [\ - ["agent-base", "npm:7.1.4"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["aria-query", [\ - ["npm:5.3.2", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/aria-query-npm-5.3.2-78632ac5c5-10c0.zip/node_modules/aria-query/",\ - "packageDependencies": [\ - ["aria-query", "npm:5.3.2"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["axobject-query", [\ - ["npm:4.1.0", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/axobject-query-npm-4.1.0-9703554323-10c0.zip/node_modules/axobject-query/",\ - "packageDependencies": [\ - ["axobject-query", "npm:4.1.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["cacache", [\ - ["npm:20.0.3", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/cacache-npm-20.0.3-5f244d5bdd-10c0.zip/node_modules/cacache/",\ - "packageDependencies": [\ - ["@npmcli/fs", "npm:5.0.0"],\ - ["cacache", "npm:20.0.3"],\ - ["fs-minipass", "npm:3.0.3"],\ - ["glob", "npm:13.0.0"],\ - ["lru-cache", "npm:11.2.4"],\ - ["minipass", "npm:7.1.2"],\ - ["minipass-collect", "npm:2.0.1"],\ - ["minipass-flush", "npm:1.0.5"],\ - ["minipass-pipeline", "npm:1.2.4"],\ - ["p-map", "npm:7.0.4"],\ - ["ssri", "npm:13.0.0"],\ - ["unique-filename", "npm:5.0.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["chokidar", [\ - ["npm:4.0.3", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/chokidar-npm-4.0.3-962354fbb4-10c0.zip/node_modules/chokidar/",\ - "packageDependencies": [\ - ["chokidar", "npm:4.0.3"],\ - ["readdirp", "npm:4.1.2"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["chownr", [\ - ["npm:3.0.0", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/chownr-npm-3.0.0-5275e85d25-10c0.zip/node_modules/chownr/",\ - "packageDependencies": [\ - ["chownr", "npm:3.0.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["clsx", [\ - ["npm:2.1.1", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/clsx-npm-2.1.1-96125b98be-10c0.zip/node_modules/clsx/",\ - "packageDependencies": [\ - ["clsx", "npm:2.1.1"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["cookie", [\ - ["npm:0.6.0", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/cookie-npm-0.6.0-362d6a2e45-10c0.zip/node_modules/cookie/",\ - "packageDependencies": [\ - ["cookie", "npm:0.6.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["debug", [\ - ["npm:4.4.3", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/debug-npm-4.4.3-0105c6123a-10c0.zip/node_modules/debug/",\ - "packageDependencies": [\ - ["debug", "npm:4.4.3"]\ - ],\ - "linkType": "SOFT"\ - }],\ - ["virtual:643ed7cc338bcf145a82d8b05b3bef6bcf150ca545df386225596f10ce53cc90b88b3ca83e348ade1ccea5f3f8e76c92d2f0e2ba544da60d40aff9921c56872d#npm:4.4.3", {\ - "packageLocation": "./.yarn/__virtual__/debug-virtual-5da9fc757d/4/.local/share/yarn/berry/cache/debug-npm-4.4.3-0105c6123a-10c0.zip/node_modules/debug/",\ - "packageDependencies": [\ - ["@types/supports-color", null],\ - ["debug", "virtual:643ed7cc338bcf145a82d8b05b3bef6bcf150ca545df386225596f10ce53cc90b88b3ca83e348ade1ccea5f3f8e76c92d2f0e2ba544da60d40aff9921c56872d#npm:4.4.3"],\ - ["ms", "npm:2.1.3"],\ - ["supports-color", null]\ - ],\ - "packagePeers": [\ - "@types/supports-color",\ - "supports-color"\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["deepmerge", [\ - ["npm:4.3.1", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/deepmerge-npm-4.3.1-4f751a0844-10c0.zip/node_modules/deepmerge/",\ - "packageDependencies": [\ - ["deepmerge", "npm:4.3.1"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["devalue", [\ - ["npm:5.6.1", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/devalue-npm-5.6.1-9da81c4197-10c0.zip/node_modules/devalue/",\ - "packageDependencies": [\ - ["devalue", "npm:5.6.1"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["dprint", [\ - ["npm:0.50.2", {\ - "packageLocation": "./.yarn/unplugged/dprint-npm-0.50.2-6fd6d613ee/node_modules/dprint/",\ - "packageDependencies": [\ - ["@dprint/darwin-arm64", "npm:0.50.2"],\ - ["@dprint/darwin-x64", "npm:0.50.2"],\ - ["@dprint/linux-arm64-glibc", "npm:0.50.2"],\ - ["@dprint/linux-arm64-musl", "npm:0.50.2"],\ - ["@dprint/linux-riscv64-glibc", "npm:0.50.2"],\ - ["@dprint/linux-x64-glibc", "npm:0.50.2"],\ - ["@dprint/linux-x64-musl", "npm:0.50.2"],\ - ["@dprint/win32-arm64", "npm:0.50.2"],\ - ["@dprint/win32-x64", "npm:0.50.2"],\ - ["dprint", "npm:0.50.2"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["encoding", [\ - ["npm:0.1.13", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/encoding-npm-0.1.13-82a1837d30-10c0.zip/node_modules/encoding/",\ - "packageDependencies": [\ - ["encoding", "npm:0.1.13"],\ - ["iconv-lite", "npm:0.6.3"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["env-paths", [\ - ["npm:2.2.1", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/env-paths-npm-2.2.1-7c7577428c-10c0.zip/node_modules/env-paths/",\ - "packageDependencies": [\ - ["env-paths", "npm:2.2.1"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["err-code", [\ - ["npm:2.0.3", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/err-code-npm-2.0.3-082e0ff9a7-10c0.zip/node_modules/err-code/",\ - "packageDependencies": [\ - ["err-code", "npm:2.0.3"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["esbuild", [\ - ["npm:0.27.2", {\ - "packageLocation": "./.yarn/unplugged/esbuild-npm-0.27.2-7789e62c6d/node_modules/esbuild/",\ - "packageDependencies": [\ - ["@esbuild/aix-ppc64", "npm:0.27.2"],\ - ["@esbuild/android-arm", "npm:0.27.2"],\ - ["@esbuild/android-arm64", "npm:0.27.2"],\ - ["@esbuild/android-x64", "npm:0.27.2"],\ - ["@esbuild/darwin-arm64", "npm:0.27.2"],\ - ["@esbuild/darwin-x64", "npm:0.27.2"],\ - ["@esbuild/freebsd-arm64", "npm:0.27.2"],\ - ["@esbuild/freebsd-x64", "npm:0.27.2"],\ - ["@esbuild/linux-arm", "npm:0.27.2"],\ - ["@esbuild/linux-arm64", "npm:0.27.2"],\ - ["@esbuild/linux-ia32", "npm:0.27.2"],\ - ["@esbuild/linux-loong64", "npm:0.27.2"],\ - ["@esbuild/linux-mips64el", "npm:0.27.2"],\ - ["@esbuild/linux-ppc64", "npm:0.27.2"],\ - ["@esbuild/linux-riscv64", "npm:0.27.2"],\ - ["@esbuild/linux-s390x", "npm:0.27.2"],\ - ["@esbuild/linux-x64", "npm:0.27.2"],\ - ["@esbuild/netbsd-arm64", "npm:0.27.2"],\ - ["@esbuild/netbsd-x64", "npm:0.27.2"],\ - ["@esbuild/openbsd-arm64", "npm:0.27.2"],\ - ["@esbuild/openbsd-x64", "npm:0.27.2"],\ - ["@esbuild/openharmony-arm64", "npm:0.27.2"],\ - ["@esbuild/sunos-x64", "npm:0.27.2"],\ - ["@esbuild/win32-arm64", "npm:0.27.2"],\ - ["@esbuild/win32-ia32", "npm:0.27.2"],\ - ["@esbuild/win32-x64", "npm:0.27.2"],\ - ["esbuild", "npm:0.27.2"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["esm-env", [\ - ["npm:1.2.2", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/esm-env-npm-1.2.2-c6981cc52f-10c0.zip/node_modules/esm-env/",\ - "packageDependencies": [\ - ["esm-env", "npm:1.2.2"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["esrap", [\ - ["npm:2.2.1", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/esrap-npm-2.2.1-6dd663c8d5-10c0.zip/node_modules/esrap/",\ - "packageDependencies": [\ - ["@jridgewell/sourcemap-codec", "npm:1.5.5"],\ - ["esrap", "npm:2.2.1"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["exponential-backoff", [\ - ["npm:3.1.3", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/exponential-backoff-npm-3.1.3-28be78d98e-10c0.zip/node_modules/exponential-backoff/",\ - "packageDependencies": [\ - ["exponential-backoff", "npm:3.1.3"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["fdir", [\ - ["npm:6.5.0", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/fdir-npm-6.5.0-8814a0dec7-10c0.zip/node_modules/fdir/",\ - "packageDependencies": [\ - ["fdir", "npm:6.5.0"]\ - ],\ - "linkType": "SOFT"\ - }],\ - ["virtual:0d5188298bfeed88e754a67f03045d4ba43cb6d9f740e3beb25ba36b92527715d8cbec7b1746301ae98a42ebdfa424361668981ae45c58ee9e36badbe285ca9c#npm:6.5.0", {\ - "packageLocation": "./.yarn/__virtual__/fdir-virtual-e0f197a2ad/4/.local/share/yarn/berry/cache/fdir-npm-6.5.0-8814a0dec7-10c0.zip/node_modules/fdir/",\ - "packageDependencies": [\ - ["@types/picomatch", null],\ - ["fdir", "virtual:0d5188298bfeed88e754a67f03045d4ba43cb6d9f740e3beb25ba36b92527715d8cbec7b1746301ae98a42ebdfa424361668981ae45c58ee9e36badbe285ca9c#npm:6.5.0"],\ - ["picomatch", null]\ - ],\ - "packagePeers": [\ - "@types/picomatch",\ - "picomatch"\ - ],\ - "linkType": "HARD"\ - }],\ - ["virtual:0e783aadbd2b4b8e6f6056033c0b290501892d23bc7c5dad5477e00e48ad8bd3e4434c3962a52dd75a58e06dbb7218094a494bac954ef2f7f6fdb65d9717e5f4#npm:6.5.0", {\ - "packageLocation": "./.yarn/__virtual__/fdir-virtual-abd4ab2082/4/.local/share/yarn/berry/cache/fdir-npm-6.5.0-8814a0dec7-10c0.zip/node_modules/fdir/",\ - "packageDependencies": [\ - ["@types/picomatch", null],\ - ["fdir", "virtual:0e783aadbd2b4b8e6f6056033c0b290501892d23bc7c5dad5477e00e48ad8bd3e4434c3962a52dd75a58e06dbb7218094a494bac954ef2f7f6fdb65d9717e5f4#npm:6.5.0"],\ - ["picomatch", "npm:4.0.3"]\ - ],\ - "packagePeers": [\ - "@types/picomatch",\ - "picomatch"\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["fs-minipass", [\ - ["npm:3.0.3", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/fs-minipass-npm-3.0.3-d148d6ac19-10c0.zip/node_modules/fs-minipass/",\ - "packageDependencies": [\ - ["fs-minipass", "npm:3.0.3"],\ - ["minipass", "npm:7.1.2"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["fsevents", [\ - ["patch:fsevents@npm%3A2.3.2#optional!builtin::version=2.3.2&hash=df0bf1", {\ - "packageLocation": "./.yarn/unplugged/fsevents-patch-19706e7e35/node_modules/fsevents/",\ - "packageDependencies": [\ - ["fsevents", "patch:fsevents@npm%3A2.3.2#optional!builtin::version=2.3.2&hash=df0bf1"],\ - ["node-gyp", "npm:12.1.0"]\ - ],\ - "linkType": "HARD"\ - }],\ - ["patch:fsevents@npm%3A2.3.3#optional!builtin::version=2.3.3&hash=df0bf1", {\ - "packageLocation": "./.yarn/unplugged/fsevents-patch-6b67494872/node_modules/fsevents/",\ - "packageDependencies": [\ - ["fsevents", "patch:fsevents@npm%3A2.3.3#optional!builtin::version=2.3.3&hash=df0bf1"],\ - ["node-gyp", "npm:12.1.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["glob", [\ - ["npm:13.0.0", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/glob-npm-13.0.0-8e50143ca8-10c0.zip/node_modules/glob/",\ - "packageDependencies": [\ - ["glob", "npm:13.0.0"],\ - ["minimatch", "npm:10.1.1"],\ - ["minipass", "npm:7.1.2"],\ - ["path-scurry", "npm:2.0.1"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["glyphdiff", [\ - ["workspace:.", {\ - "packageLocation": "./",\ - "packageDependencies": [\ - ["@playwright/test", "npm:1.57.0"],\ - ["@sveltejs/adapter-auto", "virtual:f7561fcf711f481d620482469a2dbebe3761e771c8deb737eccd373d81f54db92ff85a785fd771382e660ad7ed33436906c28252e5ede1021290f553c7bf8dbc#npm:7.0.0"],\ - ["@sveltejs/kit", "virtual:f7561fcf711f481d620482469a2dbebe3761e771c8deb737eccd373d81f54db92ff85a785fd771382e660ad7ed33436906c28252e5ede1021290f553c7bf8dbc#npm:2.49.2"],\ - ["@sveltejs/vite-plugin-svelte", "virtual:f7561fcf711f481d620482469a2dbebe3761e771c8deb737eccd373d81f54db92ff85a785fd771382e660ad7ed33436906c28252e5ede1021290f553c7bf8dbc#npm:6.2.1"],\ - ["dprint", "npm:0.50.2"],\ - ["glyphdiff", "workspace:."],\ - ["oxlint", "virtual:f7561fcf711f481d620482469a2dbebe3761e771c8deb737eccd373d81f54db92ff85a785fd771382e660ad7ed33436906c28252e5ede1021290f553c7bf8dbc#npm:1.35.0"],\ - ["svelte", "npm:5.46.1"],\ - ["svelte-check", "virtual:f7561fcf711f481d620482469a2dbebe3761e771c8deb737eccd373d81f54db92ff85a785fd771382e660ad7ed33436906c28252e5ede1021290f553c7bf8dbc#npm:4.3.5"],\ - ["typescript", "patch:typescript@npm%3A5.9.3#optional!builtin::version=5.9.3&hash=5786d5"],\ - ["vite", "virtual:f7561fcf711f481d620482469a2dbebe3761e771c8deb737eccd373d81f54db92ff85a785fd771382e660ad7ed33436906c28252e5ede1021290f553c7bf8dbc#npm:7.3.0"]\ - ],\ - "linkType": "SOFT"\ - }]\ - ]],\ - ["graceful-fs", [\ - ["npm:4.2.11", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/graceful-fs-npm-4.2.11-24bb648a68-10c0.zip/node_modules/graceful-fs/",\ - "packageDependencies": [\ - ["graceful-fs", "npm:4.2.11"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["http-cache-semantics", [\ - ["npm:4.2.0", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/http-cache-semantics-npm-4.2.0-fadacfb3ad-10c0.zip/node_modules/http-cache-semantics/",\ - "packageDependencies": [\ - ["http-cache-semantics", "npm:4.2.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["http-proxy-agent", [\ - ["npm:7.0.2", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/http-proxy-agent-npm-7.0.2-643ed7cc33-10c0.zip/node_modules/http-proxy-agent/",\ - "packageDependencies": [\ - ["agent-base", "npm:7.1.4"],\ - ["debug", "virtual:643ed7cc338bcf145a82d8b05b3bef6bcf150ca545df386225596f10ce53cc90b88b3ca83e348ade1ccea5f3f8e76c92d2f0e2ba544da60d40aff9921c56872d#npm:4.4.3"],\ - ["http-proxy-agent", "npm:7.0.2"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["https-proxy-agent", [\ - ["npm:7.0.6", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/https-proxy-agent-npm-7.0.6-27a95c2690-10c0.zip/node_modules/https-proxy-agent/",\ - "packageDependencies": [\ - ["agent-base", "npm:7.1.4"],\ - ["debug", "virtual:643ed7cc338bcf145a82d8b05b3bef6bcf150ca545df386225596f10ce53cc90b88b3ca83e348ade1ccea5f3f8e76c92d2f0e2ba544da60d40aff9921c56872d#npm:4.4.3"],\ - ["https-proxy-agent", "npm:7.0.6"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["iconv-lite", [\ - ["npm:0.6.3", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/iconv-lite-npm-0.6.3-24b8aae27e-10c0.zip/node_modules/iconv-lite/",\ - "packageDependencies": [\ - ["iconv-lite", "npm:0.6.3"],\ - ["safer-buffer", "npm:2.1.2"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["imurmurhash", [\ - ["npm:0.1.4", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/imurmurhash-npm-0.1.4-610c5068a0-10c0.zip/node_modules/imurmurhash/",\ - "packageDependencies": [\ - ["imurmurhash", "npm:0.1.4"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["ip-address", [\ - ["npm:10.1.0", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/ip-address-npm-10.1.0-d5d5693401-10c0.zip/node_modules/ip-address/",\ - "packageDependencies": [\ - ["ip-address", "npm:10.1.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["is-reference", [\ - ["npm:3.0.3", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/is-reference-npm-3.0.3-2edaf1be22-10c0.zip/node_modules/is-reference/",\ - "packageDependencies": [\ - ["@types/estree", "npm:1.0.8"],\ - ["is-reference", "npm:3.0.3"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["isexe", [\ - ["npm:3.1.1", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/isexe-npm-3.1.1-9c0061eead-10c0.zip/node_modules/isexe/",\ - "packageDependencies": [\ - ["isexe", "npm:3.1.1"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["kleur", [\ - ["npm:4.1.5", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/kleur-npm-4.1.5-46b6135f41-10c0.zip/node_modules/kleur/",\ - "packageDependencies": [\ - ["kleur", "npm:4.1.5"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["locate-character", [\ - ["npm:3.0.0", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/locate-character-npm-3.0.0-40928dccbb-10c0.zip/node_modules/locate-character/",\ - "packageDependencies": [\ - ["locate-character", "npm:3.0.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["lru-cache", [\ - ["npm:11.2.4", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/lru-cache-npm-11.2.4-3f72660965-10c0.zip/node_modules/lru-cache/",\ - "packageDependencies": [\ - ["lru-cache", "npm:11.2.4"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["magic-string", [\ - ["npm:0.30.21", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/magic-string-npm-0.30.21-9a226cb21e-10c0.zip/node_modules/magic-string/",\ - "packageDependencies": [\ - ["@jridgewell/sourcemap-codec", "npm:1.5.5"],\ - ["magic-string", "npm:0.30.21"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["make-fetch-happen", [\ - ["npm:15.0.3", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/make-fetch-happen-npm-15.0.3-10a832fcad-10c0.zip/node_modules/make-fetch-happen/",\ - "packageDependencies": [\ - ["@npmcli/agent", "npm:4.0.0"],\ - ["cacache", "npm:20.0.3"],\ - ["http-cache-semantics", "npm:4.2.0"],\ - ["make-fetch-happen", "npm:15.0.3"],\ - ["minipass", "npm:7.1.2"],\ - ["minipass-fetch", "npm:5.0.0"],\ - ["minipass-flush", "npm:1.0.5"],\ - ["minipass-pipeline", "npm:1.2.4"],\ - ["negotiator", "npm:1.0.0"],\ - ["proc-log", "npm:6.1.0"],\ - ["promise-retry", "npm:2.0.1"],\ - ["ssri", "npm:13.0.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["minimatch", [\ - ["npm:10.1.1", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/minimatch-npm-10.1.1-453db4ee1a-10c0.zip/node_modules/minimatch/",\ - "packageDependencies": [\ - ["@isaacs/brace-expansion", "npm:5.0.0"],\ - ["minimatch", "npm:10.1.1"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["minipass", [\ - ["npm:3.3.6", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/minipass-npm-3.3.6-b8d93a945b-10c0.zip/node_modules/minipass/",\ - "packageDependencies": [\ - ["minipass", "npm:3.3.6"],\ - ["yallist", "npm:4.0.0"]\ - ],\ - "linkType": "HARD"\ - }],\ - ["npm:7.1.2", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/minipass-npm-7.1.2-3a5327d36d-10c0.zip/node_modules/minipass/",\ - "packageDependencies": [\ - ["minipass", "npm:7.1.2"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["minipass-collect", [\ - ["npm:2.0.1", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/minipass-collect-npm-2.0.1-73d3907e40-10c0.zip/node_modules/minipass-collect/",\ - "packageDependencies": [\ - ["minipass", "npm:7.1.2"],\ - ["minipass-collect", "npm:2.0.1"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["minipass-fetch", [\ - ["npm:5.0.0", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/minipass-fetch-npm-5.0.0-e53c2bae4c-10c0.zip/node_modules/minipass-fetch/",\ - "packageDependencies": [\ - ["encoding", "npm:0.1.13"],\ - ["minipass", "npm:7.1.2"],\ - ["minipass-fetch", "npm:5.0.0"],\ - ["minipass-sized", "npm:1.0.3"],\ - ["minizlib", "npm:3.1.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["minipass-flush", [\ - ["npm:1.0.5", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/minipass-flush-npm-1.0.5-efe79d9826-10c0.zip/node_modules/minipass-flush/",\ - "packageDependencies": [\ - ["minipass", "npm:3.3.6"],\ - ["minipass-flush", "npm:1.0.5"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["minipass-pipeline", [\ - ["npm:1.2.4", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/minipass-pipeline-npm-1.2.4-5924cb077f-10c0.zip/node_modules/minipass-pipeline/",\ - "packageDependencies": [\ - ["minipass", "npm:3.3.6"],\ - ["minipass-pipeline", "npm:1.2.4"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["minipass-sized", [\ - ["npm:1.0.3", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/minipass-sized-npm-1.0.3-306d86f432-10c0.zip/node_modules/minipass-sized/",\ - "packageDependencies": [\ - ["minipass", "npm:3.3.6"],\ - ["minipass-sized", "npm:1.0.3"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["minizlib", [\ - ["npm:3.1.0", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/minizlib-npm-3.1.0-6680befdba-10c0.zip/node_modules/minizlib/",\ - "packageDependencies": [\ - ["minipass", "npm:7.1.2"],\ - ["minizlib", "npm:3.1.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["mri", [\ - ["npm:1.2.0", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/mri-npm-1.2.0-8ecee0357d-10c0.zip/node_modules/mri/",\ - "packageDependencies": [\ - ["mri", "npm:1.2.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["mrmime", [\ - ["npm:2.0.1", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/mrmime-npm-2.0.1-c00bdddb2f-10c0.zip/node_modules/mrmime/",\ - "packageDependencies": [\ - ["mrmime", "npm:2.0.1"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["ms", [\ - ["npm:2.1.3", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/ms-npm-2.1.3-81ff3cfac1-10c0.zip/node_modules/ms/",\ - "packageDependencies": [\ - ["ms", "npm:2.1.3"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["nanoid", [\ - ["npm:3.3.11", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/nanoid-npm-3.3.11-f98c1f9ef6-10c0.zip/node_modules/nanoid/",\ - "packageDependencies": [\ - ["nanoid", "npm:3.3.11"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["negotiator", [\ - ["npm:1.0.0", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/negotiator-npm-1.0.0-47d727e27e-10c0.zip/node_modules/negotiator/",\ - "packageDependencies": [\ - ["negotiator", "npm:1.0.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["node-gyp", [\ - ["npm:12.1.0", {\ - "packageLocation": "./.yarn/unplugged/node-gyp-npm-12.1.0-0690767ce9/node_modules/node-gyp/",\ - "packageDependencies": [\ - ["env-paths", "npm:2.2.1"],\ - ["exponential-backoff", "npm:3.1.3"],\ - ["graceful-fs", "npm:4.2.11"],\ - ["make-fetch-happen", "npm:15.0.3"],\ - ["node-gyp", "npm:12.1.0"],\ - ["nopt", "npm:9.0.0"],\ - ["proc-log", "npm:6.1.0"],\ - ["semver", "npm:7.7.3"],\ - ["tar", "npm:7.5.2"],\ - ["tinyglobby", "npm:0.2.15"],\ - ["which", "npm:6.0.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["nopt", [\ - ["npm:9.0.0", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/nopt-npm-9.0.0-81316ec15c-10c0.zip/node_modules/nopt/",\ - "packageDependencies": [\ - ["abbrev", "npm:4.0.0"],\ - ["nopt", "npm:9.0.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["oxlint", [\ - ["npm:1.35.0", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/oxlint-npm-1.35.0-33a9596aad-10c0.zip/node_modules/oxlint/",\ - "packageDependencies": [\ - ["oxlint", "npm:1.35.0"]\ - ],\ - "linkType": "SOFT"\ - }],\ - ["virtual:f7561fcf711f481d620482469a2dbebe3761e771c8deb737eccd373d81f54db92ff85a785fd771382e660ad7ed33436906c28252e5ede1021290f553c7bf8dbc#npm:1.35.0", {\ - "packageLocation": "./.yarn/__virtual__/oxlint-virtual-cadd58eb07/4/.local/share/yarn/berry/cache/oxlint-npm-1.35.0-33a9596aad-10c0.zip/node_modules/oxlint/",\ - "packageDependencies": [\ - ["@oxlint/darwin-arm64", "npm:1.35.0"],\ - ["@oxlint/darwin-x64", "npm:1.35.0"],\ - ["@oxlint/linux-arm64-gnu", "npm:1.35.0"],\ - ["@oxlint/linux-arm64-musl", "npm:1.35.0"],\ - ["@oxlint/linux-x64-gnu", "npm:1.35.0"],\ - ["@oxlint/linux-x64-musl", "npm:1.35.0"],\ - ["@oxlint/win32-arm64", "npm:1.35.0"],\ - ["@oxlint/win32-x64", "npm:1.35.0"],\ - ["@types/oxlint-tsgolint", null],\ - ["oxlint", "virtual:f7561fcf711f481d620482469a2dbebe3761e771c8deb737eccd373d81f54db92ff85a785fd771382e660ad7ed33436906c28252e5ede1021290f553c7bf8dbc#npm:1.35.0"],\ - ["oxlint-tsgolint", null]\ - ],\ - "packagePeers": [\ - "@types/oxlint-tsgolint",\ - "oxlint-tsgolint"\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["p-map", [\ - ["npm:7.0.4", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/p-map-npm-7.0.4-39386109d0-10c0.zip/node_modules/p-map/",\ - "packageDependencies": [\ - ["p-map", "npm:7.0.4"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["path-scurry", [\ - ["npm:2.0.1", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/path-scurry-npm-2.0.1-7744619e5d-10c0.zip/node_modules/path-scurry/",\ - "packageDependencies": [\ - ["lru-cache", "npm:11.2.4"],\ - ["minipass", "npm:7.1.2"],\ - ["path-scurry", "npm:2.0.1"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["picocolors", [\ - ["npm:1.1.1", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/picocolors-npm-1.1.1-4fede47cf1-10c0.zip/node_modules/picocolors/",\ - "packageDependencies": [\ - ["picocolors", "npm:1.1.1"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["picomatch", [\ - ["npm:4.0.3", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/picomatch-npm-4.0.3-0a647b87cc-10c0.zip/node_modules/picomatch/",\ - "packageDependencies": [\ - ["picomatch", "npm:4.0.3"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["playwright", [\ - ["npm:1.57.0", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/playwright-npm-1.57.0-1712c32e43-10c0.zip/node_modules/playwright/",\ - "packageDependencies": [\ - ["fsevents", "patch:fsevents@npm%3A2.3.2#optional!builtin::version=2.3.2&hash=df0bf1"],\ - ["playwright", "npm:1.57.0"],\ - ["playwright-core", "npm:1.57.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["playwright-core", [\ - ["npm:1.57.0", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/playwright-core-npm-1.57.0-1ccd5476ca-10c0.zip/node_modules/playwright-core/",\ - "packageDependencies": [\ - ["playwright-core", "npm:1.57.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["postcss", [\ - ["npm:8.5.6", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/postcss-npm-8.5.6-e7f126c6f3-10c0.zip/node_modules/postcss/",\ - "packageDependencies": [\ - ["nanoid", "npm:3.3.11"],\ - ["picocolors", "npm:1.1.1"],\ - ["postcss", "npm:8.5.6"],\ - ["source-map-js", "npm:1.2.1"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["proc-log", [\ - ["npm:6.1.0", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/proc-log-npm-6.1.0-84e609b3f4-10c0.zip/node_modules/proc-log/",\ - "packageDependencies": [\ - ["proc-log", "npm:6.1.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["promise-retry", [\ - ["npm:2.0.1", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/promise-retry-npm-2.0.1-871f0b01b7-10c0.zip/node_modules/promise-retry/",\ - "packageDependencies": [\ - ["err-code", "npm:2.0.3"],\ - ["promise-retry", "npm:2.0.1"],\ - ["retry", "npm:0.12.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["readdirp", [\ - ["npm:4.1.2", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/readdirp-npm-4.1.2-3440472afe-10c0.zip/node_modules/readdirp/",\ - "packageDependencies": [\ - ["readdirp", "npm:4.1.2"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["retry", [\ - ["npm:0.12.0", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/retry-npm-0.12.0-72ac7fb4cc-10c0.zip/node_modules/retry/",\ - "packageDependencies": [\ - ["retry", "npm:0.12.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["rollup", [\ - ["npm:4.54.0", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/rollup-npm-4.54.0-5690763b57-10c0.zip/node_modules/rollup/",\ - "packageDependencies": [\ - ["@rollup/rollup-android-arm-eabi", "npm:4.54.0"],\ - ["@rollup/rollup-android-arm64", "npm:4.54.0"],\ - ["@rollup/rollup-darwin-arm64", "npm:4.54.0"],\ - ["@rollup/rollup-darwin-x64", "npm:4.54.0"],\ - ["@rollup/rollup-freebsd-arm64", "npm:4.54.0"],\ - ["@rollup/rollup-freebsd-x64", "npm:4.54.0"],\ - ["@rollup/rollup-linux-arm-gnueabihf", "npm:4.54.0"],\ - ["@rollup/rollup-linux-arm-musleabihf", "npm:4.54.0"],\ - ["@rollup/rollup-linux-arm64-gnu", "npm:4.54.0"],\ - ["@rollup/rollup-linux-arm64-musl", "npm:4.54.0"],\ - ["@rollup/rollup-linux-loong64-gnu", "npm:4.54.0"],\ - ["@rollup/rollup-linux-ppc64-gnu", "npm:4.54.0"],\ - ["@rollup/rollup-linux-riscv64-gnu", "npm:4.54.0"],\ - ["@rollup/rollup-linux-riscv64-musl", "npm:4.54.0"],\ - ["@rollup/rollup-linux-s390x-gnu", "npm:4.54.0"],\ - ["@rollup/rollup-linux-x64-gnu", "npm:4.54.0"],\ - ["@rollup/rollup-linux-x64-musl", "npm:4.54.0"],\ - ["@rollup/rollup-openharmony-arm64", "npm:4.54.0"],\ - ["@rollup/rollup-win32-arm64-msvc", "npm:4.54.0"],\ - ["@rollup/rollup-win32-ia32-msvc", "npm:4.54.0"],\ - ["@rollup/rollup-win32-x64-gnu", "npm:4.54.0"],\ - ["@rollup/rollup-win32-x64-msvc", "npm:4.54.0"],\ - ["@types/estree", "npm:1.0.8"],\ - ["fsevents", "patch:fsevents@npm%3A2.3.3#optional!builtin::version=2.3.3&hash=df0bf1"],\ - ["rollup", "npm:4.54.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["sade", [\ - ["npm:1.8.1", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/sade-npm-1.8.1-4759dc74c1-10c0.zip/node_modules/sade/",\ - "packageDependencies": [\ - ["mri", "npm:1.2.0"],\ - ["sade", "npm:1.8.1"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["safer-buffer", [\ - ["npm:2.1.2", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/safer-buffer-npm-2.1.2-8d5c0b705e-10c0.zip/node_modules/safer-buffer/",\ - "packageDependencies": [\ - ["safer-buffer", "npm:2.1.2"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["semver", [\ - ["npm:7.7.3", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/semver-npm-7.7.3-9cf7b3b46c-10c0.zip/node_modules/semver/",\ - "packageDependencies": [\ - ["semver", "npm:7.7.3"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["set-cookie-parser", [\ - ["npm:2.7.2", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/set-cookie-parser-npm-2.7.2-e1a4d1221b-10c0.zip/node_modules/set-cookie-parser/",\ - "packageDependencies": [\ - ["set-cookie-parser", "npm:2.7.2"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["sirv", [\ - ["npm:3.0.2", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/sirv-npm-3.0.2-6cf658c733-10c0.zip/node_modules/sirv/",\ - "packageDependencies": [\ - ["@polka/url", "npm:1.0.0-next.29"],\ - ["mrmime", "npm:2.0.1"],\ - ["sirv", "npm:3.0.2"],\ - ["totalist", "npm:3.0.1"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["smart-buffer", [\ - ["npm:4.2.0", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/smart-buffer-npm-4.2.0-5ac3f668bb-10c0.zip/node_modules/smart-buffer/",\ - "packageDependencies": [\ - ["smart-buffer", "npm:4.2.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["socks", [\ - ["npm:2.8.7", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/socks-npm-2.8.7-d1d20aae19-10c0.zip/node_modules/socks/",\ - "packageDependencies": [\ - ["ip-address", "npm:10.1.0"],\ - ["smart-buffer", "npm:4.2.0"],\ - ["socks", "npm:2.8.7"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["socks-proxy-agent", [\ - ["npm:8.0.5", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/socks-proxy-agent-npm-8.0.5-24d77a90dc-10c0.zip/node_modules/socks-proxy-agent/",\ - "packageDependencies": [\ - ["agent-base", "npm:7.1.4"],\ - ["debug", "virtual:643ed7cc338bcf145a82d8b05b3bef6bcf150ca545df386225596f10ce53cc90b88b3ca83e348ade1ccea5f3f8e76c92d2f0e2ba544da60d40aff9921c56872d#npm:4.4.3"],\ - ["socks", "npm:2.8.7"],\ - ["socks-proxy-agent", "npm:8.0.5"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["source-map-js", [\ - ["npm:1.2.1", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/source-map-js-npm-1.2.1-b9a47d7e1a-10c0.zip/node_modules/source-map-js/",\ - "packageDependencies": [\ - ["source-map-js", "npm:1.2.1"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["ssri", [\ - ["npm:13.0.0", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/ssri-npm-13.0.0-f5fa93375d-10c0.zip/node_modules/ssri/",\ - "packageDependencies": [\ - ["minipass", "npm:7.1.2"],\ - ["ssri", "npm:13.0.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["svelte", [\ - ["npm:5.46.1", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/svelte-npm-5.46.1-a6c55ea9de-10c0.zip/node_modules/svelte/",\ - "packageDependencies": [\ - ["@jridgewell/remapping", "npm:2.3.5"],\ - ["@jridgewell/sourcemap-codec", "npm:1.5.5"],\ - ["@sveltejs/acorn-typescript", "virtual:a6c55ea9de82660519a4b0864315b3b30e10ee152c8339686ba6e2ba939e74cd0a67ef3c9bcef3476be827df82ff71c0899264eeeeeed28d7de83c5a06e785aa#npm:1.0.8"],\ - ["@types/estree", "npm:1.0.8"],\ - ["acorn", "npm:8.15.0"],\ - ["aria-query", "npm:5.3.2"],\ - ["axobject-query", "npm:4.1.0"],\ - ["clsx", "npm:2.1.1"],\ - ["devalue", "npm:5.6.1"],\ - ["esm-env", "npm:1.2.2"],\ - ["esrap", "npm:2.2.1"],\ - ["is-reference", "npm:3.0.3"],\ - ["locate-character", "npm:3.0.0"],\ - ["magic-string", "npm:0.30.21"],\ - ["svelte", "npm:5.46.1"],\ - ["zimmerframe", "npm:1.1.4"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["svelte-check", [\ - ["npm:4.3.5", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/svelte-check-npm-4.3.5-f05eef0797-10c0.zip/node_modules/svelte-check/",\ - "packageDependencies": [\ - ["svelte-check", "npm:4.3.5"]\ - ],\ - "linkType": "SOFT"\ - }],\ - ["virtual:f7561fcf711f481d620482469a2dbebe3761e771c8deb737eccd373d81f54db92ff85a785fd771382e660ad7ed33436906c28252e5ede1021290f553c7bf8dbc#npm:4.3.5", {\ - "packageLocation": "./.yarn/__virtual__/svelte-check-virtual-0d5188298b/4/.local/share/yarn/berry/cache/svelte-check-npm-4.3.5-f05eef0797-10c0.zip/node_modules/svelte-check/",\ - "packageDependencies": [\ - ["@jridgewell/trace-mapping", "npm:0.3.31"],\ - ["@types/svelte", null],\ - ["@types/typescript", null],\ - ["chokidar", "npm:4.0.3"],\ - ["fdir", "virtual:0d5188298bfeed88e754a67f03045d4ba43cb6d9f740e3beb25ba36b92527715d8cbec7b1746301ae98a42ebdfa424361668981ae45c58ee9e36badbe285ca9c#npm:6.5.0"],\ - ["picocolors", "npm:1.1.1"],\ - ["sade", "npm:1.8.1"],\ - ["svelte", "npm:5.46.1"],\ - ["svelte-check", "virtual:f7561fcf711f481d620482469a2dbebe3761e771c8deb737eccd373d81f54db92ff85a785fd771382e660ad7ed33436906c28252e5ede1021290f553c7bf8dbc#npm:4.3.5"],\ - ["typescript", "patch:typescript@npm%3A5.9.3#optional!builtin::version=5.9.3&hash=5786d5"]\ - ],\ - "packagePeers": [\ - "@types/svelte",\ - "@types/typescript",\ - "svelte",\ - "typescript"\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["tar", [\ - ["npm:7.5.2", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/tar-npm-7.5.2-6d8cfb7a13-10c0.zip/node_modules/tar/",\ - "packageDependencies": [\ - ["@isaacs/fs-minipass", "npm:4.0.1"],\ - ["chownr", "npm:3.0.0"],\ - ["minipass", "npm:7.1.2"],\ - ["minizlib", "npm:3.1.0"],\ - ["tar", "npm:7.5.2"],\ - ["yallist", "npm:5.0.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["tinyglobby", [\ - ["npm:0.2.15", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/tinyglobby-npm-0.2.15-0e783aadbd-10c0.zip/node_modules/tinyglobby/",\ - "packageDependencies": [\ - ["fdir", "virtual:0e783aadbd2b4b8e6f6056033c0b290501892d23bc7c5dad5477e00e48ad8bd3e4434c3962a52dd75a58e06dbb7218094a494bac954ef2f7f6fdb65d9717e5f4#npm:6.5.0"],\ - ["picomatch", "npm:4.0.3"],\ - ["tinyglobby", "npm:0.2.15"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["totalist", [\ - ["npm:3.0.1", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/totalist-npm-3.0.1-91e71f3baa-10c0.zip/node_modules/totalist/",\ - "packageDependencies": [\ - ["totalist", "npm:3.0.1"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["typescript", [\ - ["patch:typescript@npm%3A5.9.3#optional!builtin::version=5.9.3&hash=5786d5", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/typescript-patch-6fda4d02cf-10c0.zip/node_modules/typescript/",\ - "packageDependencies": [\ - ["typescript", "patch:typescript@npm%3A5.9.3#optional!builtin::version=5.9.3&hash=5786d5"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["unique-filename", [\ - ["npm:5.0.0", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/unique-filename-npm-5.0.0-605f54f18e-10c0.zip/node_modules/unique-filename/",\ - "packageDependencies": [\ - ["unique-filename", "npm:5.0.0"],\ - ["unique-slug", "npm:6.0.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["unique-slug", [\ - ["npm:6.0.0", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/unique-slug-npm-6.0.0-f26b186e99-10c0.zip/node_modules/unique-slug/",\ - "packageDependencies": [\ - ["imurmurhash", "npm:0.1.4"],\ - ["unique-slug", "npm:6.0.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["vite", [\ - ["npm:7.3.0", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/vite-npm-7.3.0-70284f6792-10c0.zip/node_modules/vite/",\ - "packageDependencies": [\ - ["vite", "npm:7.3.0"]\ - ],\ - "linkType": "SOFT"\ - }],\ - ["virtual:f7561fcf711f481d620482469a2dbebe3761e771c8deb737eccd373d81f54db92ff85a785fd771382e660ad7ed33436906c28252e5ede1021290f553c7bf8dbc#npm:7.3.0", {\ - "packageLocation": "./.yarn/__virtual__/vite-virtual-b59014cea4/4/.local/share/yarn/berry/cache/vite-npm-7.3.0-70284f6792-10c0.zip/node_modules/vite/",\ - "packageDependencies": [\ - ["@types/jiti", null],\ - ["@types/less", null],\ - ["@types/lightningcss", null],\ - ["@types/node", null],\ - ["@types/sass", null],\ - ["@types/sass-embedded", null],\ - ["@types/stylus", null],\ - ["@types/sugarss", null],\ - ["@types/terser", null],\ - ["@types/tsx", null],\ - ["@types/yaml", null],\ - ["esbuild", "npm:0.27.2"],\ - ["fdir", "virtual:0e783aadbd2b4b8e6f6056033c0b290501892d23bc7c5dad5477e00e48ad8bd3e4434c3962a52dd75a58e06dbb7218094a494bac954ef2f7f6fdb65d9717e5f4#npm:6.5.0"],\ - ["fsevents", "patch:fsevents@npm%3A2.3.3#optional!builtin::version=2.3.3&hash=df0bf1"],\ - ["jiti", null],\ - ["less", null],\ - ["lightningcss", null],\ - ["picomatch", "npm:4.0.3"],\ - ["postcss", "npm:8.5.6"],\ - ["rollup", "npm:4.54.0"],\ - ["sass", null],\ - ["sass-embedded", null],\ - ["stylus", null],\ - ["sugarss", null],\ - ["terser", null],\ - ["tinyglobby", "npm:0.2.15"],\ - ["tsx", null],\ - ["vite", "virtual:f7561fcf711f481d620482469a2dbebe3761e771c8deb737eccd373d81f54db92ff85a785fd771382e660ad7ed33436906c28252e5ede1021290f553c7bf8dbc#npm:7.3.0"],\ - ["yaml", null]\ - ],\ - "packagePeers": [\ - "@types/jiti",\ - "@types/less",\ - "@types/lightningcss",\ - "@types/node",\ - "@types/sass-embedded",\ - "@types/sass",\ - "@types/stylus",\ - "@types/sugarss",\ - "@types/terser",\ - "@types/tsx",\ - "@types/yaml",\ - "jiti",\ - "less",\ - "lightningcss",\ - "sass-embedded",\ - "sass",\ - "stylus",\ - "sugarss",\ - "terser",\ - "tsx",\ - "yaml"\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["vitefu", [\ - ["npm:1.1.1", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/vitefu-npm-1.1.1-f0bee50862-10c0.zip/node_modules/vitefu/",\ - "packageDependencies": [\ - ["vitefu", "npm:1.1.1"]\ - ],\ - "linkType": "SOFT"\ - }],\ - ["virtual:1b5ed8efb66eecc58d54f4ce66d6b24d1d7d9b16bc3a97b929761d21607447f32079dbb5e602dd10e01c9f672487b49b24bd8ec2a92cea203713d35b40fc7aec#npm:1.1.1", {\ - "packageLocation": "./.yarn/__virtual__/vitefu-virtual-6796cf84a3/4/.local/share/yarn/berry/cache/vitefu-npm-1.1.1-f0bee50862-10c0.zip/node_modules/vitefu/",\ - "packageDependencies": [\ - ["@types/vite", null],\ - ["vite", "virtual:f7561fcf711f481d620482469a2dbebe3761e771c8deb737eccd373d81f54db92ff85a785fd771382e660ad7ed33436906c28252e5ede1021290f553c7bf8dbc#npm:7.3.0"],\ - ["vitefu", "virtual:1b5ed8efb66eecc58d54f4ce66d6b24d1d7d9b16bc3a97b929761d21607447f32079dbb5e602dd10e01c9f672487b49b24bd8ec2a92cea203713d35b40fc7aec#npm:1.1.1"]\ - ],\ - "packagePeers": [\ - "@types/vite",\ - "vite"\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["which", [\ - ["npm:6.0.0", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/which-npm-6.0.0-48f25f0ec8-10c0.zip/node_modules/which/",\ - "packageDependencies": [\ - ["isexe", "npm:3.1.1"],\ - ["which", "npm:6.0.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["yallist", [\ - ["npm:4.0.0", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/yallist-npm-4.0.0-b493d9e907-10c0.zip/node_modules/yallist/",\ - "packageDependencies": [\ - ["yallist", "npm:4.0.0"]\ - ],\ - "linkType": "HARD"\ - }],\ - ["npm:5.0.0", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/yallist-npm-5.0.0-8732dd9f1c-10c0.zip/node_modules/yallist/",\ - "packageDependencies": [\ - ["yallist", "npm:5.0.0"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]],\ - ["zimmerframe", [\ - ["npm:1.1.4", {\ - "packageLocation": "../../../.local/share/yarn/berry/cache/zimmerframe-npm-1.1.4-a2c339a65f-10c0.zip/node_modules/zimmerframe/",\ - "packageDependencies": [\ - ["zimmerframe", "npm:1.1.4"]\ - ],\ - "linkType": "HARD"\ - }]\ - ]]\ - ]\ -}'; - -function $$SETUP_STATE(hydrateRuntimeState, basePath) { - return hydrateRuntimeState(JSON.parse(RAW_RUNTIME_STATE), {basePath: basePath || __dirname}); -} - -const fs = require('fs'); -const path = require('path'); -const crypto = require('crypto'); -const os = require('os'); -const events = require('events'); -const nodeUtils = require('util'); -const stream = require('stream'); -const zlib = require('zlib'); -const require$$0 = require('module'); -const StringDecoder = require('string_decoder'); -const url = require('url'); -const buffer = require('buffer'); -const readline = require('readline'); -const assert = require('assert'); - -const _interopDefaultLegacy = e => e && typeof e === 'object' && 'default' in e ? e : { default: e }; - -function _interopNamespace(e) { - if (e && e.__esModule) return e; - const n = Object.create(null); - if (e) { - for (const k in e) { - if (k !== 'default') { - const d = Object.getOwnPropertyDescriptor(e, k); - Object.defineProperty(n, k, d.get ? d : { - enumerable: true, - get: () => e[k] - }); - } - } - } - n.default = e; - return Object.freeze(n); -} - -const fs__default = /*#__PURE__*/_interopDefaultLegacy(fs); -const path__default = /*#__PURE__*/_interopDefaultLegacy(path); -const nodeUtils__namespace = /*#__PURE__*/_interopNamespace(nodeUtils); -const zlib__default = /*#__PURE__*/_interopDefaultLegacy(zlib); -const require$$0__default = /*#__PURE__*/_interopDefaultLegacy(require$$0); -const StringDecoder__default = /*#__PURE__*/_interopDefaultLegacy(StringDecoder); -const buffer__default = /*#__PURE__*/_interopDefaultLegacy(buffer); -const assert__default = /*#__PURE__*/_interopDefaultLegacy(assert); - -const S_IFMT = 61440; -const S_IFDIR = 16384; -const S_IFREG = 32768; -const S_IFLNK = 40960; -const SAFE_TIME = 456789e3; - -function makeError$1(code, message) { - return Object.assign(new Error(`${code}: ${message}`), { code }); -} -function EBUSY(message) { - return makeError$1(`EBUSY`, message); -} -function ENOSYS(message, reason) { - return makeError$1(`ENOSYS`, `${message}, ${reason}`); -} -function EINVAL(reason) { - return makeError$1(`EINVAL`, `invalid argument, ${reason}`); -} -function EBADF(reason) { - return makeError$1(`EBADF`, `bad file descriptor, ${reason}`); -} -function ENOENT(reason) { - return makeError$1(`ENOENT`, `no such file or directory, ${reason}`); -} -function ENOTDIR(reason) { - return makeError$1(`ENOTDIR`, `not a directory, ${reason}`); -} -function EISDIR(reason) { - return makeError$1(`EISDIR`, `illegal operation on a directory, ${reason}`); -} -function EEXIST(reason) { - return makeError$1(`EEXIST`, `file already exists, ${reason}`); -} -function EROFS(reason) { - return makeError$1(`EROFS`, `read-only filesystem, ${reason}`); -} -function ENOTEMPTY(reason) { - return makeError$1(`ENOTEMPTY`, `directory not empty, ${reason}`); -} -function EOPNOTSUPP(reason) { - return makeError$1(`EOPNOTSUPP`, `operation not supported, ${reason}`); -} -function ERR_DIR_CLOSED() { - return makeError$1(`ERR_DIR_CLOSED`, `Directory handle was closed`); -} - -const DEFAULT_MODE = S_IFREG | 420; -class StatEntry { - uid = 0; - gid = 0; - size = 0; - blksize = 0; - atimeMs = 0; - mtimeMs = 0; - ctimeMs = 0; - birthtimeMs = 0; - atime = /* @__PURE__ */ new Date(0); - mtime = /* @__PURE__ */ new Date(0); - ctime = /* @__PURE__ */ new Date(0); - birthtime = /* @__PURE__ */ new Date(0); - dev = 0; - ino = 0; - mode = DEFAULT_MODE; - nlink = 1; - rdev = 0; - blocks = 1; - isBlockDevice() { - return false; - } - isCharacterDevice() { - return false; - } - isDirectory() { - return (this.mode & S_IFMT) === S_IFDIR; - } - isFIFO() { - return false; - } - isFile() { - return (this.mode & S_IFMT) === S_IFREG; - } - isSocket() { - return false; - } - isSymbolicLink() { - return (this.mode & S_IFMT) === S_IFLNK; - } -} -class BigIntStatsEntry { - uid = BigInt(0); - gid = BigInt(0); - size = BigInt(0); - blksize = BigInt(0); - atimeMs = BigInt(0); - mtimeMs = BigInt(0); - ctimeMs = BigInt(0); - birthtimeMs = BigInt(0); - atimeNs = BigInt(0); - mtimeNs = BigInt(0); - ctimeNs = BigInt(0); - birthtimeNs = BigInt(0); - atime = /* @__PURE__ */ new Date(0); - mtime = /* @__PURE__ */ new Date(0); - ctime = /* @__PURE__ */ new Date(0); - birthtime = /* @__PURE__ */ new Date(0); - dev = BigInt(0); - ino = BigInt(0); - mode = BigInt(DEFAULT_MODE); - nlink = BigInt(1); - rdev = BigInt(0); - blocks = BigInt(1); - isBlockDevice() { - return false; - } - isCharacterDevice() { - return false; - } - isDirectory() { - return (this.mode & BigInt(S_IFMT)) === BigInt(S_IFDIR); - } - isFIFO() { - return false; - } - isFile() { - return (this.mode & BigInt(S_IFMT)) === BigInt(S_IFREG); - } - isSocket() { - return false; - } - isSymbolicLink() { - return (this.mode & BigInt(S_IFMT)) === BigInt(S_IFLNK); - } -} -function makeDefaultStats() { - return new StatEntry(); -} -function clearStats(stats) { - for (const key in stats) { - if (Object.hasOwn(stats, key)) { - const element = stats[key]; - if (typeof element === `number`) { - stats[key] = 0; - } else if (typeof element === `bigint`) { - stats[key] = BigInt(0); - } else if (nodeUtils__namespace.types.isDate(element)) { - stats[key] = /* @__PURE__ */ new Date(0); - } - } - } - return stats; -} -function convertToBigIntStats(stats) { - const bigintStats = new BigIntStatsEntry(); - for (const key in stats) { - if (Object.hasOwn(stats, key)) { - const element = stats[key]; - if (typeof element === `number`) { - bigintStats[key] = BigInt(element); - } else if (nodeUtils__namespace.types.isDate(element)) { - bigintStats[key] = new Date(element); - } - } - } - bigintStats.atimeNs = bigintStats.atimeMs * BigInt(1e6); - bigintStats.mtimeNs = bigintStats.mtimeMs * BigInt(1e6); - bigintStats.ctimeNs = bigintStats.ctimeMs * BigInt(1e6); - bigintStats.birthtimeNs = bigintStats.birthtimeMs * BigInt(1e6); - return bigintStats; -} -function areStatsEqual(a, b) { - if (a.atimeMs !== b.atimeMs) - return false; - if (a.birthtimeMs !== b.birthtimeMs) - return false; - if (a.blksize !== b.blksize) - return false; - if (a.blocks !== b.blocks) - return false; - if (a.ctimeMs !== b.ctimeMs) - return false; - if (a.dev !== b.dev) - return false; - if (a.gid !== b.gid) - return false; - if (a.ino !== b.ino) - return false; - if (a.isBlockDevice() !== b.isBlockDevice()) - return false; - if (a.isCharacterDevice() !== b.isCharacterDevice()) - return false; - if (a.isDirectory() !== b.isDirectory()) - return false; - if (a.isFIFO() !== b.isFIFO()) - return false; - if (a.isFile() !== b.isFile()) - return false; - if (a.isSocket() !== b.isSocket()) - return false; - if (a.isSymbolicLink() !== b.isSymbolicLink()) - return false; - if (a.mode !== b.mode) - return false; - if (a.mtimeMs !== b.mtimeMs) - return false; - if (a.nlink !== b.nlink) - return false; - if (a.rdev !== b.rdev) - return false; - if (a.size !== b.size) - return false; - if (a.uid !== b.uid) - return false; - const aN = a; - const bN = b; - if (aN.atimeNs !== bN.atimeNs) - return false; - if (aN.mtimeNs !== bN.mtimeNs) - return false; - if (aN.ctimeNs !== bN.ctimeNs) - return false; - if (aN.birthtimeNs !== bN.birthtimeNs) - return false; - return true; -} - -const PortablePath = { - root: `/`, - dot: `.`, - parent: `..` -}; -const Filename = { - home: `~`, - nodeModules: `node_modules`, - manifest: `package.json`, - lockfile: `yarn.lock`, - virtual: `__virtual__`, - /** - * @deprecated - */ - pnpJs: `.pnp.js`, - pnpCjs: `.pnp.cjs`, - pnpData: `.pnp.data.json`, - pnpEsmLoader: `.pnp.loader.mjs`, - rc: `.yarnrc.yml`, - env: `.env` -}; -const npath = Object.create(path__default.default); -const ppath = Object.create(path__default.default.posix); -npath.cwd = () => process.cwd(); -ppath.cwd = process.platform === `win32` ? () => toPortablePath(process.cwd()) : process.cwd; -if (process.platform === `win32`) { - ppath.resolve = (...segments) => { - if (segments.length > 0 && ppath.isAbsolute(segments[0])) { - return path__default.default.posix.resolve(...segments); - } else { - return path__default.default.posix.resolve(ppath.cwd(), ...segments); - } - }; -} -const contains = function(pathUtils, from, to) { - from = pathUtils.normalize(from); - to = pathUtils.normalize(to); - if (from === to) - return `.`; - if (!from.endsWith(pathUtils.sep)) - from = from + pathUtils.sep; - if (to.startsWith(from)) { - return to.slice(from.length); - } else { - return null; - } -}; -npath.contains = (from, to) => contains(npath, from, to); -ppath.contains = (from, to) => contains(ppath, from, to); -const WINDOWS_PATH_REGEXP = /^([a-zA-Z]:.*)$/; -const UNC_WINDOWS_PATH_REGEXP = /^\/\/(\.\/)?(.*)$/; -const PORTABLE_PATH_REGEXP = /^\/([a-zA-Z]:.*)$/; -const UNC_PORTABLE_PATH_REGEXP = /^\/unc\/(\.dot\/)?(.*)$/; -function fromPortablePathWin32(p) { - let portablePathMatch, uncPortablePathMatch; - if (portablePathMatch = p.match(PORTABLE_PATH_REGEXP)) - p = portablePathMatch[1]; - else if (uncPortablePathMatch = p.match(UNC_PORTABLE_PATH_REGEXP)) - p = `\\\\${uncPortablePathMatch[1] ? `.\\` : ``}${uncPortablePathMatch[2]}`; - else - return p; - return p.replace(/\//g, `\\`); -} -function toPortablePathWin32(p) { - p = p.replace(/\\/g, `/`); - let windowsPathMatch, uncWindowsPathMatch; - if (windowsPathMatch = p.match(WINDOWS_PATH_REGEXP)) - p = `/${windowsPathMatch[1]}`; - else if (uncWindowsPathMatch = p.match(UNC_WINDOWS_PATH_REGEXP)) - p = `/unc/${uncWindowsPathMatch[1] ? `.dot/` : ``}${uncWindowsPathMatch[2]}`; - return p; -} -const toPortablePath = process.platform === `win32` ? toPortablePathWin32 : (p) => p; -const fromPortablePath = process.platform === `win32` ? fromPortablePathWin32 : (p) => p; -npath.fromPortablePath = fromPortablePath; -npath.toPortablePath = toPortablePath; -function convertPath(targetPathUtils, sourcePath) { - return targetPathUtils === npath ? fromPortablePath(sourcePath) : toPortablePath(sourcePath); -} - -const defaultTime = new Date(SAFE_TIME * 1e3); -const defaultTimeMs = defaultTime.getTime(); -async function copyPromise(destinationFs, destination, sourceFs, source, opts) { - const normalizedDestination = destinationFs.pathUtils.normalize(destination); - const normalizedSource = sourceFs.pathUtils.normalize(source); - const prelayout = []; - const postlayout = []; - const { atime, mtime } = opts.stableTime ? { atime: defaultTime, mtime: defaultTime } : await sourceFs.lstatPromise(normalizedSource); - await destinationFs.mkdirpPromise(destinationFs.pathUtils.dirname(destination), { utimes: [atime, mtime] }); - await copyImpl(prelayout, postlayout, destinationFs, normalizedDestination, sourceFs, normalizedSource, { ...opts, didParentExist: true }); - for (const operation of prelayout) - await operation(); - await Promise.all(postlayout.map((operation) => { - return operation(); - })); -} -async function copyImpl(prelayout, postlayout, destinationFs, destination, sourceFs, source, opts) { - const destinationStat = opts.didParentExist ? await maybeLStat(destinationFs, destination) : null; - const sourceStat = await sourceFs.lstatPromise(source); - const { atime, mtime } = opts.stableTime ? { atime: defaultTime, mtime: defaultTime } : sourceStat; - let updated; - switch (true) { - case sourceStat.isDirectory(): - { - updated = await copyFolder(prelayout, postlayout, destinationFs, destination, destinationStat, sourceFs, source, sourceStat, opts); - } - break; - case sourceStat.isFile(): - { - updated = await copyFile(prelayout, postlayout, destinationFs, destination, destinationStat, sourceFs, source, sourceStat, opts); - } - break; - case sourceStat.isSymbolicLink(): - { - updated = await copySymlink(prelayout, postlayout, destinationFs, destination, destinationStat, sourceFs, source, sourceStat, opts); - } - break; - default: { - throw new Error(`Unsupported file type (${sourceStat.mode})`); - } - } - if (opts.linkStrategy?.type !== `HardlinkFromIndex` || !sourceStat.isFile()) { - if (updated || destinationStat?.mtime?.getTime() !== mtime.getTime() || destinationStat?.atime?.getTime() !== atime.getTime()) { - postlayout.push(() => destinationFs.lutimesPromise(destination, atime, mtime)); - updated = true; - } - if (destinationStat === null || (destinationStat.mode & 511) !== (sourceStat.mode & 511)) { - postlayout.push(() => destinationFs.chmodPromise(destination, sourceStat.mode & 511)); - updated = true; - } - } - return updated; -} -async function maybeLStat(baseFs, p) { - try { - return await baseFs.lstatPromise(p); - } catch { - return null; - } -} -async function copyFolder(prelayout, postlayout, destinationFs, destination, destinationStat, sourceFs, source, sourceStat, opts) { - if (destinationStat !== null && !destinationStat.isDirectory()) { - if (opts.overwrite) { - prelayout.push(async () => destinationFs.removePromise(destination)); - destinationStat = null; - } else { - return false; - } - } - let updated = false; - if (destinationStat === null) { - prelayout.push(async () => { - try { - await destinationFs.mkdirPromise(destination, { mode: sourceStat.mode }); - } catch (err) { - if (err.code !== `EEXIST`) { - throw err; - } - } - }); - updated = true; - } - const entries = await sourceFs.readdirPromise(source); - const nextOpts = opts.didParentExist && !destinationStat ? { ...opts, didParentExist: false } : opts; - if (opts.stableSort) { - for (const entry of entries.sort()) { - if (await copyImpl(prelayout, postlayout, destinationFs, destinationFs.pathUtils.join(destination, entry), sourceFs, sourceFs.pathUtils.join(source, entry), nextOpts)) { - updated = true; - } - } - } else { - const entriesUpdateStatus = await Promise.all(entries.map(async (entry) => { - await copyImpl(prelayout, postlayout, destinationFs, destinationFs.pathUtils.join(destination, entry), sourceFs, sourceFs.pathUtils.join(source, entry), nextOpts); - })); - if (entriesUpdateStatus.some((status) => status)) { - updated = true; - } - } - return updated; -} -async function copyFileViaIndex(prelayout, postlayout, destinationFs, destination, destinationStat, sourceFs, source, sourceStat, opts, linkStrategy) { - const sourceHash = await sourceFs.checksumFilePromise(source, { algorithm: `sha1` }); - const defaultMode = 420; - const sourceMode = sourceStat.mode & 511; - const indexFileName = `${sourceHash}${sourceMode !== defaultMode ? sourceMode.toString(8) : ``}`; - const indexPath = destinationFs.pathUtils.join(linkStrategy.indexPath, sourceHash.slice(0, 2), `${indexFileName}.dat`); - let AtomicBehavior; - ((AtomicBehavior2) => { - AtomicBehavior2[AtomicBehavior2["Lock"] = 0] = "Lock"; - AtomicBehavior2[AtomicBehavior2["Rename"] = 1] = "Rename"; - })(AtomicBehavior || (AtomicBehavior = {})); - let atomicBehavior = 1 /* Rename */; - let indexStat = await maybeLStat(destinationFs, indexPath); - if (destinationStat) { - const isDestinationHardlinkedFromIndex = indexStat && destinationStat.dev === indexStat.dev && destinationStat.ino === indexStat.ino; - const isIndexModified = indexStat?.mtimeMs !== defaultTimeMs; - if (isDestinationHardlinkedFromIndex) { - if (isIndexModified && linkStrategy.autoRepair) { - atomicBehavior = 0 /* Lock */; - indexStat = null; - } - } - if (!isDestinationHardlinkedFromIndex) { - if (opts.overwrite) { - prelayout.push(async () => destinationFs.removePromise(destination)); - destinationStat = null; - } else { - return false; - } - } - } - const tempPath = !indexStat && atomicBehavior === 1 /* Rename */ ? `${indexPath}.${Math.floor(Math.random() * 4294967296).toString(16).padStart(8, `0`)}` : null; - let tempPathCleaned = false; - prelayout.push(async () => { - if (!indexStat) { - if (atomicBehavior === 0 /* Lock */) { - await destinationFs.lockPromise(indexPath, async () => { - const content = await sourceFs.readFilePromise(source); - await destinationFs.writeFilePromise(indexPath, content); - }); - } - if (atomicBehavior === 1 /* Rename */ && tempPath) { - const content = await sourceFs.readFilePromise(source); - await destinationFs.writeFilePromise(tempPath, content); - try { - await destinationFs.linkPromise(tempPath, indexPath); - } catch (err) { - if (err.code === `EEXIST`) { - tempPathCleaned = true; - await destinationFs.unlinkPromise(tempPath); - } else { - throw err; - } - } - } - } - if (!destinationStat) { - await destinationFs.linkPromise(indexPath, destination); - } - }); - postlayout.push(async () => { - if (!indexStat) { - await destinationFs.lutimesPromise(indexPath, defaultTime, defaultTime); - if (sourceMode !== defaultMode) { - await destinationFs.chmodPromise(indexPath, sourceMode); - } - } - if (tempPath && !tempPathCleaned) { - await destinationFs.unlinkPromise(tempPath); - } - }); - return false; -} -async function copyFileDirect(prelayout, postlayout, destinationFs, destination, destinationStat, sourceFs, source, sourceStat, opts) { - if (destinationStat !== null) { - if (opts.overwrite) { - prelayout.push(async () => destinationFs.removePromise(destination)); - destinationStat = null; - } else { - return false; - } - } - prelayout.push(async () => { - const content = await sourceFs.readFilePromise(source); - await destinationFs.writeFilePromise(destination, content); - }); - return true; -} -async function copyFile(prelayout, postlayout, destinationFs, destination, destinationStat, sourceFs, source, sourceStat, opts) { - if (opts.linkStrategy?.type === `HardlinkFromIndex`) { - return copyFileViaIndex(prelayout, postlayout, destinationFs, destination, destinationStat, sourceFs, source, sourceStat, opts, opts.linkStrategy); - } else { - return copyFileDirect(prelayout, postlayout, destinationFs, destination, destinationStat, sourceFs, source, sourceStat, opts); - } -} -async function copySymlink(prelayout, postlayout, destinationFs, destination, destinationStat, sourceFs, source, sourceStat, opts) { - if (destinationStat !== null) { - if (opts.overwrite) { - prelayout.push(async () => destinationFs.removePromise(destination)); - destinationStat = null; - } else { - return false; - } - } - prelayout.push(async () => { - await destinationFs.symlinkPromise(convertPath(destinationFs.pathUtils, await sourceFs.readlinkPromise(source)), destination); - }); - return true; -} - -class CustomDir { - constructor(path, nextDirent, opts = {}) { - this.path = path; - this.nextDirent = nextDirent; - this.opts = opts; - } - closed = false; - throwIfClosed() { - if (this.closed) { - throw ERR_DIR_CLOSED(); - } - } - async *[Symbol.asyncIterator]() { - try { - let dirent; - while ((dirent = await this.read()) !== null) { - yield dirent; - } - } finally { - await this.close(); - } - } - read(cb) { - const dirent = this.readSync(); - if (typeof cb !== `undefined`) - return cb(null, dirent); - return Promise.resolve(dirent); - } - readSync() { - this.throwIfClosed(); - return this.nextDirent(); - } - close(cb) { - this.closeSync(); - if (typeof cb !== `undefined`) - return cb(null); - return Promise.resolve(); - } - closeSync() { - this.throwIfClosed(); - this.opts.onClose?.(); - this.closed = true; - } -} -function opendir(fakeFs, path, entries, opts) { - const nextDirent = () => { - const filename = entries.shift(); - if (typeof filename === `undefined`) - return null; - const entryPath = fakeFs.pathUtils.join(path, filename); - return Object.assign(fakeFs.statSync(entryPath), { - name: filename, - path: void 0 - }); - }; - return new CustomDir(path, nextDirent, opts); -} - -function assertStatus(current, expected) { - if (current !== expected) { - throw new Error(`Invalid StatWatcher status: expected '${expected}', got '${current}'`); - } -} -class CustomStatWatcher extends events.EventEmitter { - fakeFs; - path; - bigint; - status = "ready" /* Ready */; - changeListeners = /* @__PURE__ */ new Map(); - lastStats; - startTimeout = null; - static create(fakeFs, path, opts) { - const statWatcher = new CustomStatWatcher(fakeFs, path, opts); - statWatcher.start(); - return statWatcher; - } - constructor(fakeFs, path, { bigint = false } = {}) { - super(); - this.fakeFs = fakeFs; - this.path = path; - this.bigint = bigint; - this.lastStats = this.stat(); - } - start() { - assertStatus(this.status, "ready" /* Ready */); - this.status = "running" /* Running */; - this.startTimeout = setTimeout(() => { - this.startTimeout = null; - if (!this.fakeFs.existsSync(this.path)) { - this.emit("change" /* Change */, this.lastStats, this.lastStats); - } - }, 3); - } - stop() { - assertStatus(this.status, "running" /* Running */); - this.status = "stopped" /* Stopped */; - if (this.startTimeout !== null) { - clearTimeout(this.startTimeout); - this.startTimeout = null; - } - this.emit("stop" /* Stop */); - } - stat() { - try { - return this.fakeFs.statSync(this.path, { bigint: this.bigint }); - } catch { - const statInstance = this.bigint ? new BigIntStatsEntry() : new StatEntry(); - return clearStats(statInstance); - } - } - /** - * Creates an interval whose callback compares the current stats with the previous stats and notifies all listeners in case of changes. - * - * @param opts.persistent Decides whether the interval should be immediately unref-ed. - */ - makeInterval(opts) { - const interval = setInterval(() => { - const currentStats = this.stat(); - const previousStats = this.lastStats; - if (areStatsEqual(currentStats, previousStats)) - return; - this.lastStats = currentStats; - this.emit("change" /* Change */, currentStats, previousStats); - }, opts.interval); - return opts.persistent ? interval : interval.unref(); - } - /** - * Registers a listener and assigns it an interval. - */ - registerChangeListener(listener, opts) { - this.addListener("change" /* Change */, listener); - this.changeListeners.set(listener, this.makeInterval(opts)); - } - /** - * Unregisters the listener and clears the assigned interval. - */ - unregisterChangeListener(listener) { - this.removeListener("change" /* Change */, listener); - const interval = this.changeListeners.get(listener); - if (typeof interval !== `undefined`) - clearInterval(interval); - this.changeListeners.delete(listener); - } - /** - * Unregisters all listeners and clears all assigned intervals. - */ - unregisterAllChangeListeners() { - for (const listener of this.changeListeners.keys()) { - this.unregisterChangeListener(listener); - } - } - hasChangeListeners() { - return this.changeListeners.size > 0; - } - /** - * Refs all stored intervals. - */ - ref() { - for (const interval of this.changeListeners.values()) - interval.ref(); - return this; - } - /** - * Unrefs all stored intervals. - */ - unref() { - for (const interval of this.changeListeners.values()) - interval.unref(); - return this; - } -} - -const statWatchersByFakeFS = /* @__PURE__ */ new WeakMap(); -function watchFile(fakeFs, path, a, b) { - let bigint; - let persistent; - let interval; - let listener; - switch (typeof a) { - case `function`: - { - bigint = false; - persistent = true; - interval = 5007; - listener = a; - } - break; - default: - { - ({ - bigint = false, - persistent = true, - interval = 5007 - } = a); - listener = b; - } - break; - } - let statWatchers = statWatchersByFakeFS.get(fakeFs); - if (typeof statWatchers === `undefined`) - statWatchersByFakeFS.set(fakeFs, statWatchers = /* @__PURE__ */ new Map()); - let statWatcher = statWatchers.get(path); - if (typeof statWatcher === `undefined`) { - statWatcher = CustomStatWatcher.create(fakeFs, path, { bigint }); - statWatchers.set(path, statWatcher); - } - statWatcher.registerChangeListener(listener, { persistent, interval }); - return statWatcher; -} -function unwatchFile(fakeFs, path, cb) { - const statWatchers = statWatchersByFakeFS.get(fakeFs); - if (typeof statWatchers === `undefined`) - return; - const statWatcher = statWatchers.get(path); - if (typeof statWatcher === `undefined`) - return; - if (typeof cb === `undefined`) - statWatcher.unregisterAllChangeListeners(); - else - statWatcher.unregisterChangeListener(cb); - if (!statWatcher.hasChangeListeners()) { - statWatcher.stop(); - statWatchers.delete(path); - } -} -function unwatchAllFiles(fakeFs) { - const statWatchers = statWatchersByFakeFS.get(fakeFs); - if (typeof statWatchers === `undefined`) - return; - for (const path of statWatchers.keys()) { - unwatchFile(fakeFs, path); - } -} - -class FakeFS { - pathUtils; - constructor(pathUtils) { - this.pathUtils = pathUtils; - } - async *genTraversePromise(init, { stableSort = false } = {}) { - const stack = [init]; - while (stack.length > 0) { - const p = stack.shift(); - const entry = await this.lstatPromise(p); - if (entry.isDirectory()) { - const entries = await this.readdirPromise(p); - if (stableSort) { - for (const entry2 of entries.sort()) { - stack.push(this.pathUtils.join(p, entry2)); - } - } else { - throw new Error(`Not supported`); - } - } else { - yield p; - } - } - } - async checksumFilePromise(path, { algorithm = `sha512` } = {}) { - const fd = await this.openPromise(path, `r`); - try { - const CHUNK_SIZE = 65536; - const chunk = Buffer.allocUnsafeSlow(CHUNK_SIZE); - const hash = crypto.createHash(algorithm); - let bytesRead = 0; - while ((bytesRead = await this.readPromise(fd, chunk, 0, CHUNK_SIZE)) !== 0) - hash.update(bytesRead === CHUNK_SIZE ? chunk : chunk.slice(0, bytesRead)); - return hash.digest(`hex`); - } finally { - await this.closePromise(fd); - } - } - async removePromise(p, { recursive = true, maxRetries = 5 } = {}) { - let stat; - try { - stat = await this.lstatPromise(p); - } catch (error) { - if (error.code === `ENOENT`) { - return; - } else { - throw error; - } - } - if (stat.isDirectory()) { - if (recursive) { - const entries = await this.readdirPromise(p); - await Promise.all(entries.map((entry) => { - return this.removePromise(this.pathUtils.resolve(p, entry)); - })); - } - for (let t = 0; t <= maxRetries; t++) { - try { - await this.rmdirPromise(p); - break; - } catch (error) { - if (error.code !== `EBUSY` && error.code !== `ENOTEMPTY`) { - throw error; - } else if (t < maxRetries) { - await new Promise((resolve) => setTimeout(resolve, t * 100)); - } - } - } - } else { - await this.unlinkPromise(p); - } - } - removeSync(p, { recursive = true } = {}) { - let stat; - try { - stat = this.lstatSync(p); - } catch (error) { - if (error.code === `ENOENT`) { - return; - } else { - throw error; - } - } - if (stat.isDirectory()) { - if (recursive) - for (const entry of this.readdirSync(p)) - this.removeSync(this.pathUtils.resolve(p, entry)); - this.rmdirSync(p); - } else { - this.unlinkSync(p); - } - } - async mkdirpPromise(p, { chmod, utimes } = {}) { - p = this.resolve(p); - if (p === this.pathUtils.dirname(p)) - return void 0; - const parts = p.split(this.pathUtils.sep); - let createdDirectory; - for (let u = 2; u <= parts.length; ++u) { - const subPath = parts.slice(0, u).join(this.pathUtils.sep); - if (!this.existsSync(subPath)) { - try { - await this.mkdirPromise(subPath); - } catch (error) { - if (error.code === `EEXIST`) { - continue; - } else { - throw error; - } - } - createdDirectory ??= subPath; - if (chmod != null) - await this.chmodPromise(subPath, chmod); - if (utimes != null) { - await this.utimesPromise(subPath, utimes[0], utimes[1]); - } else { - const parentStat = await this.statPromise(this.pathUtils.dirname(subPath)); - await this.utimesPromise(subPath, parentStat.atime, parentStat.mtime); - } - } - } - return createdDirectory; - } - mkdirpSync(p, { chmod, utimes } = {}) { - p = this.resolve(p); - if (p === this.pathUtils.dirname(p)) - return void 0; - const parts = p.split(this.pathUtils.sep); - let createdDirectory; - for (let u = 2; u <= parts.length; ++u) { - const subPath = parts.slice(0, u).join(this.pathUtils.sep); - if (!this.existsSync(subPath)) { - try { - this.mkdirSync(subPath); - } catch (error) { - if (error.code === `EEXIST`) { - continue; - } else { - throw error; - } - } - createdDirectory ??= subPath; - if (chmod != null) - this.chmodSync(subPath, chmod); - if (utimes != null) { - this.utimesSync(subPath, utimes[0], utimes[1]); - } else { - const parentStat = this.statSync(this.pathUtils.dirname(subPath)); - this.utimesSync(subPath, parentStat.atime, parentStat.mtime); - } - } - } - return createdDirectory; - } - async copyPromise(destination, source, { baseFs = this, overwrite = true, stableSort = false, stableTime = false, linkStrategy = null } = {}) { - return await copyPromise(this, destination, baseFs, source, { overwrite, stableSort, stableTime, linkStrategy }); - } - copySync(destination, source, { baseFs = this, overwrite = true } = {}) { - const stat = baseFs.lstatSync(source); - const exists = this.existsSync(destination); - if (stat.isDirectory()) { - this.mkdirpSync(destination); - const directoryListing = baseFs.readdirSync(source); - for (const entry of directoryListing) { - this.copySync(this.pathUtils.join(destination, entry), baseFs.pathUtils.join(source, entry), { baseFs, overwrite }); - } - } else if (stat.isFile()) { - if (!exists || overwrite) { - if (exists) - this.removeSync(destination); - const content = baseFs.readFileSync(source); - this.writeFileSync(destination, content); - } - } else if (stat.isSymbolicLink()) { - if (!exists || overwrite) { - if (exists) - this.removeSync(destination); - const target = baseFs.readlinkSync(source); - this.symlinkSync(convertPath(this.pathUtils, target), destination); - } - } else { - throw new Error(`Unsupported file type (file: ${source}, mode: 0o${stat.mode.toString(8).padStart(6, `0`)})`); - } - const mode = stat.mode & 511; - this.chmodSync(destination, mode); - } - async changeFilePromise(p, content, opts = {}) { - if (Buffer.isBuffer(content)) { - return this.changeFileBufferPromise(p, content, opts); - } else { - return this.changeFileTextPromise(p, content, opts); - } - } - async changeFileBufferPromise(p, content, { mode } = {}) { - let current = Buffer.alloc(0); - try { - current = await this.readFilePromise(p); - } catch { - } - if (Buffer.compare(current, content) === 0) - return; - await this.writeFilePromise(p, content, { mode }); - } - async changeFileTextPromise(p, content, { automaticNewlines, mode } = {}) { - let current = ``; - try { - current = await this.readFilePromise(p, `utf8`); - } catch { - } - const normalizedContent = automaticNewlines ? normalizeLineEndings(current, content) : content; - if (current === normalizedContent) - return; - await this.writeFilePromise(p, normalizedContent, { mode }); - } - changeFileSync(p, content, opts = {}) { - if (Buffer.isBuffer(content)) { - return this.changeFileBufferSync(p, content, opts); - } else { - return this.changeFileTextSync(p, content, opts); - } - } - changeFileBufferSync(p, content, { mode } = {}) { - let current = Buffer.alloc(0); - try { - current = this.readFileSync(p); - } catch { - } - if (Buffer.compare(current, content) === 0) - return; - this.writeFileSync(p, content, { mode }); - } - changeFileTextSync(p, content, { automaticNewlines = false, mode } = {}) { - let current = ``; - try { - current = this.readFileSync(p, `utf8`); - } catch { - } - const normalizedContent = automaticNewlines ? normalizeLineEndings(current, content) : content; - if (current === normalizedContent) - return; - this.writeFileSync(p, normalizedContent, { mode }); - } - async movePromise(fromP, toP) { - try { - await this.renamePromise(fromP, toP); - } catch (error) { - if (error.code === `EXDEV`) { - await this.copyPromise(toP, fromP); - await this.removePromise(fromP); - } else { - throw error; - } - } - } - moveSync(fromP, toP) { - try { - this.renameSync(fromP, toP); - } catch (error) { - if (error.code === `EXDEV`) { - this.copySync(toP, fromP); - this.removeSync(fromP); - } else { - throw error; - } - } - } - async lockPromise(affectedPath, callback) { - const lockPath = `${affectedPath}.flock`; - const interval = 1e3 / 60; - const startTime = Date.now(); - let fd = null; - const isAlive = async () => { - let pid; - try { - [pid] = await this.readJsonPromise(lockPath); - } catch { - return Date.now() - startTime < 500; - } - try { - process.kill(pid, 0); - return true; - } catch { - return false; - } - }; - while (fd === null) { - try { - fd = await this.openPromise(lockPath, `wx`); - } catch (error) { - if (error.code === `EEXIST`) { - if (!await isAlive()) { - try { - await this.unlinkPromise(lockPath); - continue; - } catch { - } - } - if (Date.now() - startTime < 60 * 1e3) { - await new Promise((resolve) => setTimeout(resolve, interval)); - } else { - throw new Error(`Couldn't acquire a lock in a reasonable time (via ${lockPath})`); - } - } else { - throw error; - } - } - } - await this.writePromise(fd, JSON.stringify([process.pid])); - try { - return await callback(); - } finally { - try { - await this.closePromise(fd); - await this.unlinkPromise(lockPath); - } catch { - } - } - } - async readJsonPromise(p) { - const content = await this.readFilePromise(p, `utf8`); - try { - return JSON.parse(content); - } catch (error) { - error.message += ` (in ${p})`; - throw error; - } - } - readJsonSync(p) { - const content = this.readFileSync(p, `utf8`); - try { - return JSON.parse(content); - } catch (error) { - error.message += ` (in ${p})`; - throw error; - } - } - async writeJsonPromise(p, data, { compact = false } = {}) { - const space = compact ? 0 : 2; - return await this.writeFilePromise(p, `${JSON.stringify(data, null, space)} -`); - } - writeJsonSync(p, data, { compact = false } = {}) { - const space = compact ? 0 : 2; - return this.writeFileSync(p, `${JSON.stringify(data, null, space)} -`); - } - async preserveTimePromise(p, cb) { - const stat = await this.lstatPromise(p); - const result = await cb(); - if (typeof result !== `undefined`) - p = result; - await this.lutimesPromise(p, stat.atime, stat.mtime); - } - async preserveTimeSync(p, cb) { - const stat = this.lstatSync(p); - const result = cb(); - if (typeof result !== `undefined`) - p = result; - this.lutimesSync(p, stat.atime, stat.mtime); - } -} -class BasePortableFakeFS extends FakeFS { - constructor() { - super(ppath); - } -} -function getEndOfLine(content) { - const matches = content.match(/\r?\n/g); - if (matches === null) - return os.EOL; - const crlf = matches.filter((nl) => nl === `\r -`).length; - const lf = matches.length - crlf; - return crlf > lf ? `\r -` : ` -`; -} -function normalizeLineEndings(originalContent, newContent) { - return newContent.replace(/\r?\n/g, getEndOfLine(originalContent)); -} - -class ProxiedFS extends FakeFS { - getExtractHint(hints) { - return this.baseFs.getExtractHint(hints); - } - resolve(path) { - return this.mapFromBase(this.baseFs.resolve(this.mapToBase(path))); - } - getRealPath() { - return this.mapFromBase(this.baseFs.getRealPath()); - } - async openPromise(p, flags, mode) { - return this.baseFs.openPromise(this.mapToBase(p), flags, mode); - } - openSync(p, flags, mode) { - return this.baseFs.openSync(this.mapToBase(p), flags, mode); - } - async opendirPromise(p, opts) { - return Object.assign(await this.baseFs.opendirPromise(this.mapToBase(p), opts), { path: p }); - } - opendirSync(p, opts) { - return Object.assign(this.baseFs.opendirSync(this.mapToBase(p), opts), { path: p }); - } - async readPromise(fd, buffer, offset, length, position) { - return await this.baseFs.readPromise(fd, buffer, offset, length, position); - } - readSync(fd, buffer, offset, length, position) { - return this.baseFs.readSync(fd, buffer, offset, length, position); - } - async writePromise(fd, buffer, offset, length, position) { - if (typeof buffer === `string`) { - return await this.baseFs.writePromise(fd, buffer, offset); - } else { - return await this.baseFs.writePromise(fd, buffer, offset, length, position); - } - } - writeSync(fd, buffer, offset, length, position) { - if (typeof buffer === `string`) { - return this.baseFs.writeSync(fd, buffer, offset); - } else { - return this.baseFs.writeSync(fd, buffer, offset, length, position); - } - } - async closePromise(fd) { - return this.baseFs.closePromise(fd); - } - closeSync(fd) { - this.baseFs.closeSync(fd); - } - createReadStream(p, opts) { - return this.baseFs.createReadStream(p !== null ? this.mapToBase(p) : p, opts); - } - createWriteStream(p, opts) { - return this.baseFs.createWriteStream(p !== null ? this.mapToBase(p) : p, opts); - } - async realpathPromise(p) { - return this.mapFromBase(await this.baseFs.realpathPromise(this.mapToBase(p))); - } - realpathSync(p) { - return this.mapFromBase(this.baseFs.realpathSync(this.mapToBase(p))); - } - async existsPromise(p) { - return this.baseFs.existsPromise(this.mapToBase(p)); - } - existsSync(p) { - return this.baseFs.existsSync(this.mapToBase(p)); - } - accessSync(p, mode) { - return this.baseFs.accessSync(this.mapToBase(p), mode); - } - async accessPromise(p, mode) { - return this.baseFs.accessPromise(this.mapToBase(p), mode); - } - async statPromise(p, opts) { - return this.baseFs.statPromise(this.mapToBase(p), opts); - } - statSync(p, opts) { - return this.baseFs.statSync(this.mapToBase(p), opts); - } - async fstatPromise(fd, opts) { - return this.baseFs.fstatPromise(fd, opts); - } - fstatSync(fd, opts) { - return this.baseFs.fstatSync(fd, opts); - } - lstatPromise(p, opts) { - return this.baseFs.lstatPromise(this.mapToBase(p), opts); - } - lstatSync(p, opts) { - return this.baseFs.lstatSync(this.mapToBase(p), opts); - } - async fchmodPromise(fd, mask) { - return this.baseFs.fchmodPromise(fd, mask); - } - fchmodSync(fd, mask) { - return this.baseFs.fchmodSync(fd, mask); - } - async chmodPromise(p, mask) { - return this.baseFs.chmodPromise(this.mapToBase(p), mask); - } - chmodSync(p, mask) { - return this.baseFs.chmodSync(this.mapToBase(p), mask); - } - async fchownPromise(fd, uid, gid) { - return this.baseFs.fchownPromise(fd, uid, gid); - } - fchownSync(fd, uid, gid) { - return this.baseFs.fchownSync(fd, uid, gid); - } - async chownPromise(p, uid, gid) { - return this.baseFs.chownPromise(this.mapToBase(p), uid, gid); - } - chownSync(p, uid, gid) { - return this.baseFs.chownSync(this.mapToBase(p), uid, gid); - } - async renamePromise(oldP, newP) { - return this.baseFs.renamePromise(this.mapToBase(oldP), this.mapToBase(newP)); - } - renameSync(oldP, newP) { - return this.baseFs.renameSync(this.mapToBase(oldP), this.mapToBase(newP)); - } - async copyFilePromise(sourceP, destP, flags = 0) { - return this.baseFs.copyFilePromise(this.mapToBase(sourceP), this.mapToBase(destP), flags); - } - copyFileSync(sourceP, destP, flags = 0) { - return this.baseFs.copyFileSync(this.mapToBase(sourceP), this.mapToBase(destP), flags); - } - async appendFilePromise(p, content, opts) { - return this.baseFs.appendFilePromise(this.fsMapToBase(p), content, opts); - } - appendFileSync(p, content, opts) { - return this.baseFs.appendFileSync(this.fsMapToBase(p), content, opts); - } - async writeFilePromise(p, content, opts) { - return this.baseFs.writeFilePromise(this.fsMapToBase(p), content, opts); - } - writeFileSync(p, content, opts) { - return this.baseFs.writeFileSync(this.fsMapToBase(p), content, opts); - } - async unlinkPromise(p) { - return this.baseFs.unlinkPromise(this.mapToBase(p)); - } - unlinkSync(p) { - return this.baseFs.unlinkSync(this.mapToBase(p)); - } - async utimesPromise(p, atime, mtime) { - return this.baseFs.utimesPromise(this.mapToBase(p), atime, mtime); - } - utimesSync(p, atime, mtime) { - return this.baseFs.utimesSync(this.mapToBase(p), atime, mtime); - } - async lutimesPromise(p, atime, mtime) { - return this.baseFs.lutimesPromise(this.mapToBase(p), atime, mtime); - } - lutimesSync(p, atime, mtime) { - return this.baseFs.lutimesSync(this.mapToBase(p), atime, mtime); - } - async mkdirPromise(p, opts) { - return this.baseFs.mkdirPromise(this.mapToBase(p), opts); - } - mkdirSync(p, opts) { - return this.baseFs.mkdirSync(this.mapToBase(p), opts); - } - async rmdirPromise(p, opts) { - return this.baseFs.rmdirPromise(this.mapToBase(p), opts); - } - rmdirSync(p, opts) { - return this.baseFs.rmdirSync(this.mapToBase(p), opts); - } - async rmPromise(p, opts) { - return this.baseFs.rmPromise(this.mapToBase(p), opts); - } - rmSync(p, opts) { - return this.baseFs.rmSync(this.mapToBase(p), opts); - } - async linkPromise(existingP, newP) { - return this.baseFs.linkPromise(this.mapToBase(existingP), this.mapToBase(newP)); - } - linkSync(existingP, newP) { - return this.baseFs.linkSync(this.mapToBase(existingP), this.mapToBase(newP)); - } - async symlinkPromise(target, p, type) { - const mappedP = this.mapToBase(p); - if (this.pathUtils.isAbsolute(target)) - return this.baseFs.symlinkPromise(this.mapToBase(target), mappedP, type); - const mappedAbsoluteTarget = this.mapToBase(this.pathUtils.join(this.pathUtils.dirname(p), target)); - const mappedTarget = this.baseFs.pathUtils.relative(this.baseFs.pathUtils.dirname(mappedP), mappedAbsoluteTarget); - return this.baseFs.symlinkPromise(mappedTarget, mappedP, type); - } - symlinkSync(target, p, type) { - const mappedP = this.mapToBase(p); - if (this.pathUtils.isAbsolute(target)) - return this.baseFs.symlinkSync(this.mapToBase(target), mappedP, type); - const mappedAbsoluteTarget = this.mapToBase(this.pathUtils.join(this.pathUtils.dirname(p), target)); - const mappedTarget = this.baseFs.pathUtils.relative(this.baseFs.pathUtils.dirname(mappedP), mappedAbsoluteTarget); - return this.baseFs.symlinkSync(mappedTarget, mappedP, type); - } - async readFilePromise(p, encoding) { - return this.baseFs.readFilePromise(this.fsMapToBase(p), encoding); - } - readFileSync(p, encoding) { - return this.baseFs.readFileSync(this.fsMapToBase(p), encoding); - } - readdirPromise(p, opts) { - return this.baseFs.readdirPromise(this.mapToBase(p), opts); - } - readdirSync(p, opts) { - return this.baseFs.readdirSync(this.mapToBase(p), opts); - } - async readlinkPromise(p) { - return this.mapFromBase(await this.baseFs.readlinkPromise(this.mapToBase(p))); - } - readlinkSync(p) { - return this.mapFromBase(this.baseFs.readlinkSync(this.mapToBase(p))); - } - async truncatePromise(p, len) { - return this.baseFs.truncatePromise(this.mapToBase(p), len); - } - truncateSync(p, len) { - return this.baseFs.truncateSync(this.mapToBase(p), len); - } - async ftruncatePromise(fd, len) { - return this.baseFs.ftruncatePromise(fd, len); - } - ftruncateSync(fd, len) { - return this.baseFs.ftruncateSync(fd, len); - } - watch(p, a, b) { - return this.baseFs.watch( - this.mapToBase(p), - // @ts-expect-error - reason TBS - a, - b - ); - } - watchFile(p, a, b) { - return this.baseFs.watchFile( - this.mapToBase(p), - // @ts-expect-error - reason TBS - a, - b - ); - } - unwatchFile(p, cb) { - return this.baseFs.unwatchFile(this.mapToBase(p), cb); - } - fsMapToBase(p) { - if (typeof p === `number`) { - return p; - } else { - return this.mapToBase(p); - } - } -} - -function direntToPortable(dirent) { - const portableDirent = dirent; - if (typeof dirent.path === `string`) - portableDirent.path = npath.toPortablePath(dirent.path); - return portableDirent; -} -class NodeFS extends BasePortableFakeFS { - realFs; - constructor(realFs = fs__default.default) { - super(); - this.realFs = realFs; - } - getExtractHint() { - return false; - } - getRealPath() { - return PortablePath.root; - } - resolve(p) { - return ppath.resolve(p); - } - async openPromise(p, flags, mode) { - return await new Promise((resolve, reject) => { - this.realFs.open(npath.fromPortablePath(p), flags, mode, this.makeCallback(resolve, reject)); - }); - } - openSync(p, flags, mode) { - return this.realFs.openSync(npath.fromPortablePath(p), flags, mode); - } - async opendirPromise(p, opts) { - return await new Promise((resolve, reject) => { - if (typeof opts !== `undefined`) { - this.realFs.opendir(npath.fromPortablePath(p), opts, this.makeCallback(resolve, reject)); - } else { - this.realFs.opendir(npath.fromPortablePath(p), this.makeCallback(resolve, reject)); - } - }).then((dir) => { - const dirWithFixedPath = dir; - Object.defineProperty(dirWithFixedPath, `path`, { - value: p, - configurable: true, - writable: true - }); - return dirWithFixedPath; - }); - } - opendirSync(p, opts) { - const dir = typeof opts !== `undefined` ? this.realFs.opendirSync(npath.fromPortablePath(p), opts) : this.realFs.opendirSync(npath.fromPortablePath(p)); - const dirWithFixedPath = dir; - Object.defineProperty(dirWithFixedPath, `path`, { - value: p, - configurable: true, - writable: true - }); - return dirWithFixedPath; - } - async readPromise(fd, buffer, offset = 0, length = 0, position = -1) { - return await new Promise((resolve, reject) => { - this.realFs.read(fd, buffer, offset, length, position, (error, bytesRead) => { - if (error) { - reject(error); - } else { - resolve(bytesRead); - } - }); - }); - } - readSync(fd, buffer, offset, length, position) { - return this.realFs.readSync(fd, buffer, offset, length, position); - } - async writePromise(fd, buffer, offset, length, position) { - return await new Promise((resolve, reject) => { - if (typeof buffer === `string`) { - return this.realFs.write(fd, buffer, offset, this.makeCallback(resolve, reject)); - } else { - return this.realFs.write(fd, buffer, offset, length, position, this.makeCallback(resolve, reject)); - } - }); - } - writeSync(fd, buffer, offset, length, position) { - if (typeof buffer === `string`) { - return this.realFs.writeSync(fd, buffer, offset); - } else { - return this.realFs.writeSync(fd, buffer, offset, length, position); - } - } - async closePromise(fd) { - await new Promise((resolve, reject) => { - this.realFs.close(fd, this.makeCallback(resolve, reject)); - }); - } - closeSync(fd) { - this.realFs.closeSync(fd); - } - createReadStream(p, opts) { - const realPath = p !== null ? npath.fromPortablePath(p) : p; - return this.realFs.createReadStream(realPath, opts); - } - createWriteStream(p, opts) { - const realPath = p !== null ? npath.fromPortablePath(p) : p; - return this.realFs.createWriteStream(realPath, opts); - } - async realpathPromise(p) { - return await new Promise((resolve, reject) => { - this.realFs.realpath(npath.fromPortablePath(p), {}, this.makeCallback(resolve, reject)); - }).then((path) => { - return npath.toPortablePath(path); - }); - } - realpathSync(p) { - return npath.toPortablePath(this.realFs.realpathSync(npath.fromPortablePath(p), {})); - } - async existsPromise(p) { - return await new Promise((resolve) => { - this.realFs.exists(npath.fromPortablePath(p), resolve); - }); - } - accessSync(p, mode) { - return this.realFs.accessSync(npath.fromPortablePath(p), mode); - } - async accessPromise(p, mode) { - return await new Promise((resolve, reject) => { - this.realFs.access(npath.fromPortablePath(p), mode, this.makeCallback(resolve, reject)); - }); - } - existsSync(p) { - return this.realFs.existsSync(npath.fromPortablePath(p)); - } - async statPromise(p, opts) { - return await new Promise((resolve, reject) => { - if (opts) { - this.realFs.stat(npath.fromPortablePath(p), opts, this.makeCallback(resolve, reject)); - } else { - this.realFs.stat(npath.fromPortablePath(p), this.makeCallback(resolve, reject)); - } - }); - } - statSync(p, opts) { - if (opts) { - return this.realFs.statSync(npath.fromPortablePath(p), opts); - } else { - return this.realFs.statSync(npath.fromPortablePath(p)); - } - } - async fstatPromise(fd, opts) { - return await new Promise((resolve, reject) => { - if (opts) { - this.realFs.fstat(fd, opts, this.makeCallback(resolve, reject)); - } else { - this.realFs.fstat(fd, this.makeCallback(resolve, reject)); - } - }); - } - fstatSync(fd, opts) { - if (opts) { - return this.realFs.fstatSync(fd, opts); - } else { - return this.realFs.fstatSync(fd); - } - } - async lstatPromise(p, opts) { - return await new Promise((resolve, reject) => { - if (opts) { - this.realFs.lstat(npath.fromPortablePath(p), opts, this.makeCallback(resolve, reject)); - } else { - this.realFs.lstat(npath.fromPortablePath(p), this.makeCallback(resolve, reject)); - } - }); - } - lstatSync(p, opts) { - if (opts) { - return this.realFs.lstatSync(npath.fromPortablePath(p), opts); - } else { - return this.realFs.lstatSync(npath.fromPortablePath(p)); - } - } - async fchmodPromise(fd, mask) { - return await new Promise((resolve, reject) => { - this.realFs.fchmod(fd, mask, this.makeCallback(resolve, reject)); - }); - } - fchmodSync(fd, mask) { - return this.realFs.fchmodSync(fd, mask); - } - async chmodPromise(p, mask) { - return await new Promise((resolve, reject) => { - this.realFs.chmod(npath.fromPortablePath(p), mask, this.makeCallback(resolve, reject)); - }); - } - chmodSync(p, mask) { - return this.realFs.chmodSync(npath.fromPortablePath(p), mask); - } - async fchownPromise(fd, uid, gid) { - return await new Promise((resolve, reject) => { - this.realFs.fchown(fd, uid, gid, this.makeCallback(resolve, reject)); - }); - } - fchownSync(fd, uid, gid) { - return this.realFs.fchownSync(fd, uid, gid); - } - async chownPromise(p, uid, gid) { - return await new Promise((resolve, reject) => { - this.realFs.chown(npath.fromPortablePath(p), uid, gid, this.makeCallback(resolve, reject)); - }); - } - chownSync(p, uid, gid) { - return this.realFs.chownSync(npath.fromPortablePath(p), uid, gid); - } - async renamePromise(oldP, newP) { - return await new Promise((resolve, reject) => { - this.realFs.rename(npath.fromPortablePath(oldP), npath.fromPortablePath(newP), this.makeCallback(resolve, reject)); - }); - } - renameSync(oldP, newP) { - return this.realFs.renameSync(npath.fromPortablePath(oldP), npath.fromPortablePath(newP)); - } - async copyFilePromise(sourceP, destP, flags = 0) { - return await new Promise((resolve, reject) => { - this.realFs.copyFile(npath.fromPortablePath(sourceP), npath.fromPortablePath(destP), flags, this.makeCallback(resolve, reject)); - }); - } - copyFileSync(sourceP, destP, flags = 0) { - return this.realFs.copyFileSync(npath.fromPortablePath(sourceP), npath.fromPortablePath(destP), flags); - } - async appendFilePromise(p, content, opts) { - return await new Promise((resolve, reject) => { - const fsNativePath = typeof p === `string` ? npath.fromPortablePath(p) : p; - if (opts) { - this.realFs.appendFile(fsNativePath, content, opts, this.makeCallback(resolve, reject)); - } else { - this.realFs.appendFile(fsNativePath, content, this.makeCallback(resolve, reject)); - } - }); - } - appendFileSync(p, content, opts) { - const fsNativePath = typeof p === `string` ? npath.fromPortablePath(p) : p; - if (opts) { - this.realFs.appendFileSync(fsNativePath, content, opts); - } else { - this.realFs.appendFileSync(fsNativePath, content); - } - } - async writeFilePromise(p, content, opts) { - return await new Promise((resolve, reject) => { - const fsNativePath = typeof p === `string` ? npath.fromPortablePath(p) : p; - if (opts) { - this.realFs.writeFile(fsNativePath, content, opts, this.makeCallback(resolve, reject)); - } else { - this.realFs.writeFile(fsNativePath, content, this.makeCallback(resolve, reject)); - } - }); - } - writeFileSync(p, content, opts) { - const fsNativePath = typeof p === `string` ? npath.fromPortablePath(p) : p; - if (opts) { - this.realFs.writeFileSync(fsNativePath, content, opts); - } else { - this.realFs.writeFileSync(fsNativePath, content); - } - } - async unlinkPromise(p) { - return await new Promise((resolve, reject) => { - this.realFs.unlink(npath.fromPortablePath(p), this.makeCallback(resolve, reject)); - }); - } - unlinkSync(p) { - return this.realFs.unlinkSync(npath.fromPortablePath(p)); - } - async utimesPromise(p, atime, mtime) { - return await new Promise((resolve, reject) => { - this.realFs.utimes(npath.fromPortablePath(p), atime, mtime, this.makeCallback(resolve, reject)); - }); - } - utimesSync(p, atime, mtime) { - this.realFs.utimesSync(npath.fromPortablePath(p), atime, mtime); - } - async lutimesPromise(p, atime, mtime) { - return await new Promise((resolve, reject) => { - this.realFs.lutimes(npath.fromPortablePath(p), atime, mtime, this.makeCallback(resolve, reject)); - }); - } - lutimesSync(p, atime, mtime) { - this.realFs.lutimesSync(npath.fromPortablePath(p), atime, mtime); - } - async mkdirPromise(p, opts) { - return await new Promise((resolve, reject) => { - this.realFs.mkdir(npath.fromPortablePath(p), opts, this.makeCallback(resolve, reject)); - }); - } - mkdirSync(p, opts) { - return this.realFs.mkdirSync(npath.fromPortablePath(p), opts); - } - async rmdirPromise(p, opts) { - return await new Promise((resolve, reject) => { - if (opts) { - this.realFs.rmdir(npath.fromPortablePath(p), opts, this.makeCallback(resolve, reject)); - } else { - this.realFs.rmdir(npath.fromPortablePath(p), this.makeCallback(resolve, reject)); - } - }); - } - rmdirSync(p, opts) { - return this.realFs.rmdirSync(npath.fromPortablePath(p), opts); - } - async rmPromise(p, opts) { - return await new Promise((resolve, reject) => { - if (opts) { - this.realFs.rm(npath.fromPortablePath(p), opts, this.makeCallback(resolve, reject)); - } else { - this.realFs.rm(npath.fromPortablePath(p), this.makeCallback(resolve, reject)); - } - }); - } - rmSync(p, opts) { - return this.realFs.rmSync(npath.fromPortablePath(p), opts); - } - async linkPromise(existingP, newP) { - return await new Promise((resolve, reject) => { - this.realFs.link(npath.fromPortablePath(existingP), npath.fromPortablePath(newP), this.makeCallback(resolve, reject)); - }); - } - linkSync(existingP, newP) { - return this.realFs.linkSync(npath.fromPortablePath(existingP), npath.fromPortablePath(newP)); - } - async symlinkPromise(target, p, type) { - return await new Promise((resolve, reject) => { - this.realFs.symlink(npath.fromPortablePath(target.replace(/\/+$/, ``)), npath.fromPortablePath(p), type, this.makeCallback(resolve, reject)); - }); - } - symlinkSync(target, p, type) { - return this.realFs.symlinkSync(npath.fromPortablePath(target.replace(/\/+$/, ``)), npath.fromPortablePath(p), type); - } - async readFilePromise(p, encoding) { - return await new Promise((resolve, reject) => { - const fsNativePath = typeof p === `string` ? npath.fromPortablePath(p) : p; - this.realFs.readFile(fsNativePath, encoding, this.makeCallback(resolve, reject)); - }); - } - readFileSync(p, encoding) { - const fsNativePath = typeof p === `string` ? npath.fromPortablePath(p) : p; - return this.realFs.readFileSync(fsNativePath, encoding); - } - async readdirPromise(p, opts) { - return await new Promise((resolve, reject) => { - if (opts) { - if (opts.recursive && process.platform === `win32`) { - if (opts.withFileTypes) { - this.realFs.readdir(npath.fromPortablePath(p), opts, this.makeCallback((results) => resolve(results.map(direntToPortable)), reject)); - } else { - this.realFs.readdir(npath.fromPortablePath(p), opts, this.makeCallback((results) => resolve(results.map(npath.toPortablePath)), reject)); - } - } else { - this.realFs.readdir(npath.fromPortablePath(p), opts, this.makeCallback(resolve, reject)); - } - } else { - this.realFs.readdir(npath.fromPortablePath(p), this.makeCallback(resolve, reject)); - } - }); - } - readdirSync(p, opts) { - if (opts) { - if (opts.recursive && process.platform === `win32`) { - if (opts.withFileTypes) { - return this.realFs.readdirSync(npath.fromPortablePath(p), opts).map(direntToPortable); - } else { - return this.realFs.readdirSync(npath.fromPortablePath(p), opts).map(npath.toPortablePath); - } - } else { - return this.realFs.readdirSync(npath.fromPortablePath(p), opts); - } - } else { - return this.realFs.readdirSync(npath.fromPortablePath(p)); - } - } - async readlinkPromise(p) { - return await new Promise((resolve, reject) => { - this.realFs.readlink(npath.fromPortablePath(p), this.makeCallback(resolve, reject)); - }).then((path) => { - return npath.toPortablePath(path); - }); - } - readlinkSync(p) { - return npath.toPortablePath(this.realFs.readlinkSync(npath.fromPortablePath(p))); - } - async truncatePromise(p, len) { - return await new Promise((resolve, reject) => { - this.realFs.truncate(npath.fromPortablePath(p), len, this.makeCallback(resolve, reject)); - }); - } - truncateSync(p, len) { - return this.realFs.truncateSync(npath.fromPortablePath(p), len); - } - async ftruncatePromise(fd, len) { - return await new Promise((resolve, reject) => { - this.realFs.ftruncate(fd, len, this.makeCallback(resolve, reject)); - }); - } - ftruncateSync(fd, len) { - return this.realFs.ftruncateSync(fd, len); - } - watch(p, a, b) { - return this.realFs.watch( - npath.fromPortablePath(p), - // @ts-expect-error - reason TBS - a, - b - ); - } - watchFile(p, a, b) { - return this.realFs.watchFile( - npath.fromPortablePath(p), - // @ts-expect-error - reason TBS - a, - b - ); - } - unwatchFile(p, cb) { - return this.realFs.unwatchFile(npath.fromPortablePath(p), cb); - } - makeCallback(resolve, reject) { - return (err, result) => { - if (err) { - reject(err); - } else { - resolve(result); - } - }; - } -} - -const MOUNT_MASK = 4278190080; -class MountFS extends BasePortableFakeFS { - baseFs; - mountInstances; - fdMap = /* @__PURE__ */ new Map(); - nextFd = 3; - factoryPromise; - factorySync; - filter; - getMountPoint; - magic; - maxAge; - maxOpenFiles; - typeCheck; - isMount = /* @__PURE__ */ new Set(); - notMount = /* @__PURE__ */ new Set(); - realPaths = /* @__PURE__ */ new Map(); - constructor({ baseFs = new NodeFS(), filter = null, magicByte = 42, maxOpenFiles = Infinity, useCache = true, maxAge = 5e3, typeCheck = fs.constants.S_IFREG, getMountPoint, factoryPromise, factorySync }) { - if (Math.floor(magicByte) !== magicByte || !(magicByte > 1 && magicByte <= 127)) - throw new Error(`The magic byte must be set to a round value between 1 and 127 included`); - super(); - this.baseFs = baseFs; - this.mountInstances = useCache ? /* @__PURE__ */ new Map() : null; - this.factoryPromise = factoryPromise; - this.factorySync = factorySync; - this.filter = filter; - this.getMountPoint = getMountPoint; - this.magic = magicByte << 24; - this.maxAge = maxAge; - this.maxOpenFiles = maxOpenFiles; - this.typeCheck = typeCheck; - } - getExtractHint(hints) { - return this.baseFs.getExtractHint(hints); - } - getRealPath() { - return this.baseFs.getRealPath(); - } - saveAndClose() { - unwatchAllFiles(this); - if (this.mountInstances) { - for (const [path, { childFs }] of this.mountInstances.entries()) { - childFs.saveAndClose?.(); - this.mountInstances.delete(path); - } - } - } - discardAndClose() { - unwatchAllFiles(this); - if (this.mountInstances) { - for (const [path, { childFs }] of this.mountInstances.entries()) { - childFs.discardAndClose?.(); - this.mountInstances.delete(path); - } - } - } - resolve(p) { - return this.baseFs.resolve(p); - } - remapFd(mountFs, fd) { - const remappedFd = this.nextFd++ | this.magic; - this.fdMap.set(remappedFd, [mountFs, fd]); - return remappedFd; - } - async openPromise(p, flags, mode) { - return await this.makeCallPromise(p, async () => { - return await this.baseFs.openPromise(p, flags, mode); - }, async (mountFs, { subPath }) => { - return this.remapFd(mountFs, await mountFs.openPromise(subPath, flags, mode)); - }); - } - openSync(p, flags, mode) { - return this.makeCallSync(p, () => { - return this.baseFs.openSync(p, flags, mode); - }, (mountFs, { subPath }) => { - return this.remapFd(mountFs, mountFs.openSync(subPath, flags, mode)); - }); - } - async opendirPromise(p, opts) { - return await this.makeCallPromise(p, async () => { - return await this.baseFs.opendirPromise(p, opts); - }, async (mountFs, { subPath }) => { - return await mountFs.opendirPromise(subPath, opts); - }, { - requireSubpath: false - }); - } - opendirSync(p, opts) { - return this.makeCallSync(p, () => { - return this.baseFs.opendirSync(p, opts); - }, (mountFs, { subPath }) => { - return mountFs.opendirSync(subPath, opts); - }, { - requireSubpath: false - }); - } - async readPromise(fd, buffer, offset, length, position) { - if ((fd & MOUNT_MASK) !== this.magic) - return await this.baseFs.readPromise(fd, buffer, offset, length, position); - const entry = this.fdMap.get(fd); - if (typeof entry === `undefined`) - throw EBADF(`read`); - const [mountFs, realFd] = entry; - return await mountFs.readPromise(realFd, buffer, offset, length, position); - } - readSync(fd, buffer, offset, length, position) { - if ((fd & MOUNT_MASK) !== this.magic) - return this.baseFs.readSync(fd, buffer, offset, length, position); - const entry = this.fdMap.get(fd); - if (typeof entry === `undefined`) - throw EBADF(`readSync`); - const [mountFs, realFd] = entry; - return mountFs.readSync(realFd, buffer, offset, length, position); - } - async writePromise(fd, buffer, offset, length, position) { - if ((fd & MOUNT_MASK) !== this.magic) { - if (typeof buffer === `string`) { - return await this.baseFs.writePromise(fd, buffer, offset); - } else { - return await this.baseFs.writePromise(fd, buffer, offset, length, position); - } - } - const entry = this.fdMap.get(fd); - if (typeof entry === `undefined`) - throw EBADF(`write`); - const [mountFs, realFd] = entry; - if (typeof buffer === `string`) { - return await mountFs.writePromise(realFd, buffer, offset); - } else { - return await mountFs.writePromise(realFd, buffer, offset, length, position); - } - } - writeSync(fd, buffer, offset, length, position) { - if ((fd & MOUNT_MASK) !== this.magic) { - if (typeof buffer === `string`) { - return this.baseFs.writeSync(fd, buffer, offset); - } else { - return this.baseFs.writeSync(fd, buffer, offset, length, position); - } - } - const entry = this.fdMap.get(fd); - if (typeof entry === `undefined`) - throw EBADF(`writeSync`); - const [mountFs, realFd] = entry; - if (typeof buffer === `string`) { - return mountFs.writeSync(realFd, buffer, offset); - } else { - return mountFs.writeSync(realFd, buffer, offset, length, position); - } - } - async closePromise(fd) { - if ((fd & MOUNT_MASK) !== this.magic) - return await this.baseFs.closePromise(fd); - const entry = this.fdMap.get(fd); - if (typeof entry === `undefined`) - throw EBADF(`close`); - this.fdMap.delete(fd); - const [mountFs, realFd] = entry; - return await mountFs.closePromise(realFd); - } - closeSync(fd) { - if ((fd & MOUNT_MASK) !== this.magic) - return this.baseFs.closeSync(fd); - const entry = this.fdMap.get(fd); - if (typeof entry === `undefined`) - throw EBADF(`closeSync`); - this.fdMap.delete(fd); - const [mountFs, realFd] = entry; - return mountFs.closeSync(realFd); - } - createReadStream(p, opts) { - if (p === null) - return this.baseFs.createReadStream(p, opts); - return this.makeCallSync(p, () => { - return this.baseFs.createReadStream(p, opts); - }, (mountFs, { archivePath, subPath }) => { - const stream = mountFs.createReadStream(subPath, opts); - stream.path = npath.fromPortablePath(this.pathUtils.join(archivePath, subPath)); - return stream; - }); - } - createWriteStream(p, opts) { - if (p === null) - return this.baseFs.createWriteStream(p, opts); - return this.makeCallSync(p, () => { - return this.baseFs.createWriteStream(p, opts); - }, (mountFs, { subPath }) => { - return mountFs.createWriteStream(subPath, opts); - }); - } - async realpathPromise(p) { - return await this.makeCallPromise(p, async () => { - return await this.baseFs.realpathPromise(p); - }, async (mountFs, { archivePath, subPath }) => { - let realArchivePath = this.realPaths.get(archivePath); - if (typeof realArchivePath === `undefined`) { - realArchivePath = await this.baseFs.realpathPromise(archivePath); - this.realPaths.set(archivePath, realArchivePath); - } - return this.pathUtils.join(realArchivePath, this.pathUtils.relative(PortablePath.root, await mountFs.realpathPromise(subPath))); - }); - } - realpathSync(p) { - return this.makeCallSync(p, () => { - return this.baseFs.realpathSync(p); - }, (mountFs, { archivePath, subPath }) => { - let realArchivePath = this.realPaths.get(archivePath); - if (typeof realArchivePath === `undefined`) { - realArchivePath = this.baseFs.realpathSync(archivePath); - this.realPaths.set(archivePath, realArchivePath); - } - return this.pathUtils.join(realArchivePath, this.pathUtils.relative(PortablePath.root, mountFs.realpathSync(subPath))); - }); - } - async existsPromise(p) { - return await this.makeCallPromise(p, async () => { - return await this.baseFs.existsPromise(p); - }, async (mountFs, { subPath }) => { - return await mountFs.existsPromise(subPath); - }); - } - existsSync(p) { - return this.makeCallSync(p, () => { - return this.baseFs.existsSync(p); - }, (mountFs, { subPath }) => { - return mountFs.existsSync(subPath); - }); - } - async accessPromise(p, mode) { - return await this.makeCallPromise(p, async () => { - return await this.baseFs.accessPromise(p, mode); - }, async (mountFs, { subPath }) => { - return await mountFs.accessPromise(subPath, mode); - }); - } - accessSync(p, mode) { - return this.makeCallSync(p, () => { - return this.baseFs.accessSync(p, mode); - }, (mountFs, { subPath }) => { - return mountFs.accessSync(subPath, mode); - }); - } - async statPromise(p, opts) { - return await this.makeCallPromise(p, async () => { - return await this.baseFs.statPromise(p, opts); - }, async (mountFs, { subPath }) => { - return await mountFs.statPromise(subPath, opts); - }); - } - statSync(p, opts) { - return this.makeCallSync(p, () => { - return this.baseFs.statSync(p, opts); - }, (mountFs, { subPath }) => { - return mountFs.statSync(subPath, opts); - }); - } - async fstatPromise(fd, opts) { - if ((fd & MOUNT_MASK) !== this.magic) - return this.baseFs.fstatPromise(fd, opts); - const entry = this.fdMap.get(fd); - if (typeof entry === `undefined`) - throw EBADF(`fstat`); - const [mountFs, realFd] = entry; - return mountFs.fstatPromise(realFd, opts); - } - fstatSync(fd, opts) { - if ((fd & MOUNT_MASK) !== this.magic) - return this.baseFs.fstatSync(fd, opts); - const entry = this.fdMap.get(fd); - if (typeof entry === `undefined`) - throw EBADF(`fstatSync`); - const [mountFs, realFd] = entry; - return mountFs.fstatSync(realFd, opts); - } - async lstatPromise(p, opts) { - return await this.makeCallPromise(p, async () => { - return await this.baseFs.lstatPromise(p, opts); - }, async (mountFs, { subPath }) => { - return await mountFs.lstatPromise(subPath, opts); - }); - } - lstatSync(p, opts) { - return this.makeCallSync(p, () => { - return this.baseFs.lstatSync(p, opts); - }, (mountFs, { subPath }) => { - return mountFs.lstatSync(subPath, opts); - }); - } - async fchmodPromise(fd, mask) { - if ((fd & MOUNT_MASK) !== this.magic) - return this.baseFs.fchmodPromise(fd, mask); - const entry = this.fdMap.get(fd); - if (typeof entry === `undefined`) - throw EBADF(`fchmod`); - const [mountFs, realFd] = entry; - return mountFs.fchmodPromise(realFd, mask); - } - fchmodSync(fd, mask) { - if ((fd & MOUNT_MASK) !== this.magic) - return this.baseFs.fchmodSync(fd, mask); - const entry = this.fdMap.get(fd); - if (typeof entry === `undefined`) - throw EBADF(`fchmodSync`); - const [mountFs, realFd] = entry; - return mountFs.fchmodSync(realFd, mask); - } - async chmodPromise(p, mask) { - return await this.makeCallPromise(p, async () => { - return await this.baseFs.chmodPromise(p, mask); - }, async (mountFs, { subPath }) => { - return await mountFs.chmodPromise(subPath, mask); - }); - } - chmodSync(p, mask) { - return this.makeCallSync(p, () => { - return this.baseFs.chmodSync(p, mask); - }, (mountFs, { subPath }) => { - return mountFs.chmodSync(subPath, mask); - }); - } - async fchownPromise(fd, uid, gid) { - if ((fd & MOUNT_MASK) !== this.magic) - return this.baseFs.fchownPromise(fd, uid, gid); - const entry = this.fdMap.get(fd); - if (typeof entry === `undefined`) - throw EBADF(`fchown`); - const [zipFs, realFd] = entry; - return zipFs.fchownPromise(realFd, uid, gid); - } - fchownSync(fd, uid, gid) { - if ((fd & MOUNT_MASK) !== this.magic) - return this.baseFs.fchownSync(fd, uid, gid); - const entry = this.fdMap.get(fd); - if (typeof entry === `undefined`) - throw EBADF(`fchownSync`); - const [zipFs, realFd] = entry; - return zipFs.fchownSync(realFd, uid, gid); - } - async chownPromise(p, uid, gid) { - return await this.makeCallPromise(p, async () => { - return await this.baseFs.chownPromise(p, uid, gid); - }, async (mountFs, { subPath }) => { - return await mountFs.chownPromise(subPath, uid, gid); - }); - } - chownSync(p, uid, gid) { - return this.makeCallSync(p, () => { - return this.baseFs.chownSync(p, uid, gid); - }, (mountFs, { subPath }) => { - return mountFs.chownSync(subPath, uid, gid); - }); - } - async renamePromise(oldP, newP) { - return await this.makeCallPromise(oldP, async () => { - return await this.makeCallPromise(newP, async () => { - return await this.baseFs.renamePromise(oldP, newP); - }, async () => { - throw Object.assign(new Error(`EEXDEV: cross-device link not permitted`), { code: `EEXDEV` }); - }); - }, async (mountFsO, { subPath: subPathO }) => { - return await this.makeCallPromise(newP, async () => { - throw Object.assign(new Error(`EEXDEV: cross-device link not permitted`), { code: `EEXDEV` }); - }, async (mountFsN, { subPath: subPathN }) => { - if (mountFsO !== mountFsN) { - throw Object.assign(new Error(`EEXDEV: cross-device link not permitted`), { code: `EEXDEV` }); - } else { - return await mountFsO.renamePromise(subPathO, subPathN); - } - }); - }); - } - renameSync(oldP, newP) { - return this.makeCallSync(oldP, () => { - return this.makeCallSync(newP, () => { - return this.baseFs.renameSync(oldP, newP); - }, () => { - throw Object.assign(new Error(`EEXDEV: cross-device link not permitted`), { code: `EEXDEV` }); - }); - }, (mountFsO, { subPath: subPathO }) => { - return this.makeCallSync(newP, () => { - throw Object.assign(new Error(`EEXDEV: cross-device link not permitted`), { code: `EEXDEV` }); - }, (mountFsN, { subPath: subPathN }) => { - if (mountFsO !== mountFsN) { - throw Object.assign(new Error(`EEXDEV: cross-device link not permitted`), { code: `EEXDEV` }); - } else { - return mountFsO.renameSync(subPathO, subPathN); - } - }); - }); - } - async copyFilePromise(sourceP, destP, flags = 0) { - const fallback = async (sourceFs, sourceP2, destFs, destP2) => { - if ((flags & fs.constants.COPYFILE_FICLONE_FORCE) !== 0) - throw Object.assign(new Error(`EXDEV: cross-device clone not permitted, copyfile '${sourceP2}' -> ${destP2}'`), { code: `EXDEV` }); - if (flags & fs.constants.COPYFILE_EXCL && await this.existsPromise(sourceP2)) - throw Object.assign(new Error(`EEXIST: file already exists, copyfile '${sourceP2}' -> '${destP2}'`), { code: `EEXIST` }); - let content; - try { - content = await sourceFs.readFilePromise(sourceP2); - } catch { - throw Object.assign(new Error(`EINVAL: invalid argument, copyfile '${sourceP2}' -> '${destP2}'`), { code: `EINVAL` }); - } - await destFs.writeFilePromise(destP2, content); - }; - return await this.makeCallPromise(sourceP, async () => { - return await this.makeCallPromise(destP, async () => { - return await this.baseFs.copyFilePromise(sourceP, destP, flags); - }, async (mountFsD, { subPath: subPathD }) => { - return await fallback(this.baseFs, sourceP, mountFsD, subPathD); - }); - }, async (mountFsS, { subPath: subPathS }) => { - return await this.makeCallPromise(destP, async () => { - return await fallback(mountFsS, subPathS, this.baseFs, destP); - }, async (mountFsD, { subPath: subPathD }) => { - if (mountFsS !== mountFsD) { - return await fallback(mountFsS, subPathS, mountFsD, subPathD); - } else { - return await mountFsS.copyFilePromise(subPathS, subPathD, flags); - } - }); - }); - } - copyFileSync(sourceP, destP, flags = 0) { - const fallback = (sourceFs, sourceP2, destFs, destP2) => { - if ((flags & fs.constants.COPYFILE_FICLONE_FORCE) !== 0) - throw Object.assign(new Error(`EXDEV: cross-device clone not permitted, copyfile '${sourceP2}' -> ${destP2}'`), { code: `EXDEV` }); - if (flags & fs.constants.COPYFILE_EXCL && this.existsSync(sourceP2)) - throw Object.assign(new Error(`EEXIST: file already exists, copyfile '${sourceP2}' -> '${destP2}'`), { code: `EEXIST` }); - let content; - try { - content = sourceFs.readFileSync(sourceP2); - } catch { - throw Object.assign(new Error(`EINVAL: invalid argument, copyfile '${sourceP2}' -> '${destP2}'`), { code: `EINVAL` }); - } - destFs.writeFileSync(destP2, content); - }; - return this.makeCallSync(sourceP, () => { - return this.makeCallSync(destP, () => { - return this.baseFs.copyFileSync(sourceP, destP, flags); - }, (mountFsD, { subPath: subPathD }) => { - return fallback(this.baseFs, sourceP, mountFsD, subPathD); - }); - }, (mountFsS, { subPath: subPathS }) => { - return this.makeCallSync(destP, () => { - return fallback(mountFsS, subPathS, this.baseFs, destP); - }, (mountFsD, { subPath: subPathD }) => { - if (mountFsS !== mountFsD) { - return fallback(mountFsS, subPathS, mountFsD, subPathD); - } else { - return mountFsS.copyFileSync(subPathS, subPathD, flags); - } - }); - }); - } - async appendFilePromise(p, content, opts) { - return await this.makeCallPromise(p, async () => { - return await this.baseFs.appendFilePromise(p, content, opts); - }, async (mountFs, { subPath }) => { - return await mountFs.appendFilePromise(subPath, content, opts); - }); - } - appendFileSync(p, content, opts) { - return this.makeCallSync(p, () => { - return this.baseFs.appendFileSync(p, content, opts); - }, (mountFs, { subPath }) => { - return mountFs.appendFileSync(subPath, content, opts); - }); - } - async writeFilePromise(p, content, opts) { - return await this.makeCallPromise(p, async () => { - return await this.baseFs.writeFilePromise(p, content, opts); - }, async (mountFs, { subPath }) => { - return await mountFs.writeFilePromise(subPath, content, opts); - }); - } - writeFileSync(p, content, opts) { - return this.makeCallSync(p, () => { - return this.baseFs.writeFileSync(p, content, opts); - }, (mountFs, { subPath }) => { - return mountFs.writeFileSync(subPath, content, opts); - }); - } - async unlinkPromise(p) { - return await this.makeCallPromise(p, async () => { - return await this.baseFs.unlinkPromise(p); - }, async (mountFs, { subPath }) => { - return await mountFs.unlinkPromise(subPath); - }); - } - unlinkSync(p) { - return this.makeCallSync(p, () => { - return this.baseFs.unlinkSync(p); - }, (mountFs, { subPath }) => { - return mountFs.unlinkSync(subPath); - }); - } - async utimesPromise(p, atime, mtime) { - return await this.makeCallPromise(p, async () => { - return await this.baseFs.utimesPromise(p, atime, mtime); - }, async (mountFs, { subPath }) => { - return await mountFs.utimesPromise(subPath, atime, mtime); - }); - } - utimesSync(p, atime, mtime) { - return this.makeCallSync(p, () => { - return this.baseFs.utimesSync(p, atime, mtime); - }, (mountFs, { subPath }) => { - return mountFs.utimesSync(subPath, atime, mtime); - }); - } - async lutimesPromise(p, atime, mtime) { - return await this.makeCallPromise(p, async () => { - return await this.baseFs.lutimesPromise(p, atime, mtime); - }, async (mountFs, { subPath }) => { - return await mountFs.lutimesPromise(subPath, atime, mtime); - }); - } - lutimesSync(p, atime, mtime) { - return this.makeCallSync(p, () => { - return this.baseFs.lutimesSync(p, atime, mtime); - }, (mountFs, { subPath }) => { - return mountFs.lutimesSync(subPath, atime, mtime); - }); - } - async mkdirPromise(p, opts) { - return await this.makeCallPromise(p, async () => { - return await this.baseFs.mkdirPromise(p, opts); - }, async (mountFs, { subPath }) => { - return await mountFs.mkdirPromise(subPath, opts); - }); - } - mkdirSync(p, opts) { - return this.makeCallSync(p, () => { - return this.baseFs.mkdirSync(p, opts); - }, (mountFs, { subPath }) => { - return mountFs.mkdirSync(subPath, opts); - }); - } - async rmdirPromise(p, opts) { - return await this.makeCallPromise(p, async () => { - return await this.baseFs.rmdirPromise(p, opts); - }, async (mountFs, { subPath }) => { - return await mountFs.rmdirPromise(subPath, opts); - }); - } - rmdirSync(p, opts) { - return this.makeCallSync(p, () => { - return this.baseFs.rmdirSync(p, opts); - }, (mountFs, { subPath }) => { - return mountFs.rmdirSync(subPath, opts); - }); - } - async rmPromise(p, opts) { - return await this.makeCallPromise(p, async () => { - return await this.baseFs.rmPromise(p, opts); - }, async (mountFs, { subPath }) => { - return await mountFs.rmPromise(subPath, opts); - }); - } - rmSync(p, opts) { - return this.makeCallSync(p, () => { - return this.baseFs.rmSync(p, opts); - }, (mountFs, { subPath }) => { - return mountFs.rmSync(subPath, opts); - }); - } - async linkPromise(existingP, newP) { - return await this.makeCallPromise(newP, async () => { - return await this.baseFs.linkPromise(existingP, newP); - }, async (mountFs, { subPath }) => { - return await mountFs.linkPromise(existingP, subPath); - }); - } - linkSync(existingP, newP) { - return this.makeCallSync(newP, () => { - return this.baseFs.linkSync(existingP, newP); - }, (mountFs, { subPath }) => { - return mountFs.linkSync(existingP, subPath); - }); - } - async symlinkPromise(target, p, type) { - return await this.makeCallPromise(p, async () => { - return await this.baseFs.symlinkPromise(target, p, type); - }, async (mountFs, { subPath }) => { - return await mountFs.symlinkPromise(target, subPath); - }); - } - symlinkSync(target, p, type) { - return this.makeCallSync(p, () => { - return this.baseFs.symlinkSync(target, p, type); - }, (mountFs, { subPath }) => { - return mountFs.symlinkSync(target, subPath); - }); - } - async readFilePromise(p, encoding) { - return this.makeCallPromise(p, async () => { - return await this.baseFs.readFilePromise(p, encoding); - }, async (mountFs, { subPath }) => { - return await mountFs.readFilePromise(subPath, encoding); - }); - } - readFileSync(p, encoding) { - return this.makeCallSync(p, () => { - return this.baseFs.readFileSync(p, encoding); - }, (mountFs, { subPath }) => { - return mountFs.readFileSync(subPath, encoding); - }); - } - async readdirPromise(p, opts) { - return await this.makeCallPromise(p, async () => { - return await this.baseFs.readdirPromise(p, opts); - }, async (mountFs, { subPath }) => { - return await mountFs.readdirPromise(subPath, opts); - }, { - requireSubpath: false - }); - } - readdirSync(p, opts) { - return this.makeCallSync(p, () => { - return this.baseFs.readdirSync(p, opts); - }, (mountFs, { subPath }) => { - return mountFs.readdirSync(subPath, opts); - }, { - requireSubpath: false - }); - } - async readlinkPromise(p) { - return await this.makeCallPromise(p, async () => { - return await this.baseFs.readlinkPromise(p); - }, async (mountFs, { subPath }) => { - return await mountFs.readlinkPromise(subPath); - }); - } - readlinkSync(p) { - return this.makeCallSync(p, () => { - return this.baseFs.readlinkSync(p); - }, (mountFs, { subPath }) => { - return mountFs.readlinkSync(subPath); - }); - } - async truncatePromise(p, len) { - return await this.makeCallPromise(p, async () => { - return await this.baseFs.truncatePromise(p, len); - }, async (mountFs, { subPath }) => { - return await mountFs.truncatePromise(subPath, len); - }); - } - truncateSync(p, len) { - return this.makeCallSync(p, () => { - return this.baseFs.truncateSync(p, len); - }, (mountFs, { subPath }) => { - return mountFs.truncateSync(subPath, len); - }); - } - async ftruncatePromise(fd, len) { - if ((fd & MOUNT_MASK) !== this.magic) - return this.baseFs.ftruncatePromise(fd, len); - const entry = this.fdMap.get(fd); - if (typeof entry === `undefined`) - throw EBADF(`ftruncate`); - const [mountFs, realFd] = entry; - return mountFs.ftruncatePromise(realFd, len); - } - ftruncateSync(fd, len) { - if ((fd & MOUNT_MASK) !== this.magic) - return this.baseFs.ftruncateSync(fd, len); - const entry = this.fdMap.get(fd); - if (typeof entry === `undefined`) - throw EBADF(`ftruncateSync`); - const [mountFs, realFd] = entry; - return mountFs.ftruncateSync(realFd, len); - } - watch(p, a, b) { - return this.makeCallSync(p, () => { - return this.baseFs.watch( - p, - // @ts-expect-error - reason TBS - a, - b - ); - }, (mountFs, { subPath }) => { - return mountFs.watch( - subPath, - // @ts-expect-error - reason TBS - a, - b - ); - }); - } - watchFile(p, a, b) { - return this.makeCallSync(p, () => { - return this.baseFs.watchFile( - p, - // @ts-expect-error - reason TBS - a, - b - ); - }, () => { - return watchFile(this, p, a, b); - }); - } - unwatchFile(p, cb) { - return this.makeCallSync(p, () => { - return this.baseFs.unwatchFile(p, cb); - }, () => { - return unwatchFile(this, p, cb); - }); - } - async makeCallPromise(p, discard, accept, { requireSubpath = true } = {}) { - if (typeof p !== `string`) - return await discard(); - const normalizedP = this.resolve(p); - const mountInfo = this.findMount(normalizedP); - if (!mountInfo) - return await discard(); - if (requireSubpath && mountInfo.subPath === `/`) - return await discard(); - return await this.getMountPromise(mountInfo.archivePath, async (mountFs) => await accept(mountFs, mountInfo)); - } - makeCallSync(p, discard, accept, { requireSubpath = true } = {}) { - if (typeof p !== `string`) - return discard(); - const normalizedP = this.resolve(p); - const mountInfo = this.findMount(normalizedP); - if (!mountInfo) - return discard(); - if (requireSubpath && mountInfo.subPath === `/`) - return discard(); - return this.getMountSync(mountInfo.archivePath, (mountFs) => accept(mountFs, mountInfo)); - } - findMount(p) { - if (this.filter && !this.filter.test(p)) - return null; - let filePath = ``; - while (true) { - const pathPartWithArchive = p.substring(filePath.length); - const mountPoint = this.getMountPoint(pathPartWithArchive, filePath); - if (!mountPoint) - return null; - filePath = this.pathUtils.join(filePath, mountPoint); - if (!this.isMount.has(filePath)) { - if (this.notMount.has(filePath)) - continue; - try { - if (this.typeCheck !== null && (this.baseFs.statSync(filePath).mode & fs.constants.S_IFMT) !== this.typeCheck) { - this.notMount.add(filePath); - continue; - } - } catch { - return null; - } - this.isMount.add(filePath); - } - return { - archivePath: filePath, - subPath: this.pathUtils.join(PortablePath.root, p.substring(filePath.length)) - }; - } - } - limitOpenFilesTimeout = null; - limitOpenFiles(max) { - if (this.mountInstances === null) - return; - const now = Date.now(); - let nextExpiresAt = now + this.maxAge; - let closeCount = max === null ? 0 : this.mountInstances.size - max; - for (const [path, { childFs, expiresAt, refCount }] of this.mountInstances.entries()) { - if (refCount !== 0 || childFs.hasOpenFileHandles?.()) { - continue; - } else if (now >= expiresAt) { - childFs.saveAndClose?.(); - this.mountInstances.delete(path); - closeCount -= 1; - continue; - } else if (max === null || closeCount <= 0) { - nextExpiresAt = expiresAt; - break; - } - childFs.saveAndClose?.(); - this.mountInstances.delete(path); - closeCount -= 1; - } - if (this.limitOpenFilesTimeout === null && (max === null && this.mountInstances.size > 0 || max !== null) && isFinite(nextExpiresAt)) { - this.limitOpenFilesTimeout = setTimeout(() => { - this.limitOpenFilesTimeout = null; - this.limitOpenFiles(null); - }, nextExpiresAt - now).unref(); - } - } - async getMountPromise(p, accept) { - if (this.mountInstances) { - let cachedMountFs = this.mountInstances.get(p); - if (!cachedMountFs) { - const createFsInstance = await this.factoryPromise(this.baseFs, p); - cachedMountFs = this.mountInstances.get(p); - if (!cachedMountFs) { - cachedMountFs = { - childFs: createFsInstance(), - expiresAt: 0, - refCount: 0 - }; - } - } - this.mountInstances.delete(p); - this.limitOpenFiles(this.maxOpenFiles - 1); - this.mountInstances.set(p, cachedMountFs); - cachedMountFs.expiresAt = Date.now() + this.maxAge; - cachedMountFs.refCount += 1; - try { - return await accept(cachedMountFs.childFs); - } finally { - cachedMountFs.refCount -= 1; - } - } else { - const mountFs = (await this.factoryPromise(this.baseFs, p))(); - try { - return await accept(mountFs); - } finally { - mountFs.saveAndClose?.(); - } - } - } - getMountSync(p, accept) { - if (this.mountInstances) { - let cachedMountFs = this.mountInstances.get(p); - if (!cachedMountFs) { - cachedMountFs = { - childFs: this.factorySync(this.baseFs, p), - expiresAt: 0, - refCount: 0 - }; - } - this.mountInstances.delete(p); - this.limitOpenFiles(this.maxOpenFiles - 1); - this.mountInstances.set(p, cachedMountFs); - cachedMountFs.expiresAt = Date.now() + this.maxAge; - return accept(cachedMountFs.childFs); - } else { - const childFs = this.factorySync(this.baseFs, p); - try { - return accept(childFs); - } finally { - childFs.saveAndClose?.(); - } - } - } -} - -class PosixFS extends ProxiedFS { - baseFs; - constructor(baseFs) { - super(npath); - this.baseFs = baseFs; - } - mapFromBase(path) { - return npath.fromPortablePath(path); - } - mapToBase(path) { - return npath.toPortablePath(path); - } -} - -const NUMBER_REGEXP = /^[0-9]+$/; -const VIRTUAL_REGEXP = /^(\/(?:[^/]+\/)*?(?:\$\$virtual|__virtual__))((?:\/((?:[^/]+-)?[a-f0-9]+)(?:\/([^/]+))?)?((?:\/.*)?))$/; -const VALID_COMPONENT = /^([^/]+-)?[a-f0-9]+$/; -class VirtualFS extends ProxiedFS { - baseFs; - static makeVirtualPath(base, component, to) { - if (ppath.basename(base) !== `__virtual__`) - throw new Error(`Assertion failed: Virtual folders must be named "__virtual__"`); - if (!ppath.basename(component).match(VALID_COMPONENT)) - throw new Error(`Assertion failed: Virtual components must be ended by an hexadecimal hash`); - const target = ppath.relative(ppath.dirname(base), to); - const segments = target.split(`/`); - let depth = 0; - while (depth < segments.length && segments[depth] === `..`) - depth += 1; - const finalSegments = segments.slice(depth); - const fullVirtualPath = ppath.join(base, component, String(depth), ...finalSegments); - return fullVirtualPath; - } - static resolveVirtual(p) { - const match = p.match(VIRTUAL_REGEXP); - if (!match || !match[3] && match[5]) - return p; - const target = ppath.dirname(match[1]); - if (!match[3] || !match[4]) - return target; - const isnum = NUMBER_REGEXP.test(match[4]); - if (!isnum) - return p; - const depth = Number(match[4]); - const backstep = `../`.repeat(depth); - const subpath = match[5] || `.`; - return VirtualFS.resolveVirtual(ppath.join(target, backstep, subpath)); - } - constructor({ baseFs = new NodeFS() } = {}) { - super(ppath); - this.baseFs = baseFs; - } - getExtractHint(hints) { - return this.baseFs.getExtractHint(hints); - } - getRealPath() { - return this.baseFs.getRealPath(); - } - realpathSync(p) { - const match = p.match(VIRTUAL_REGEXP); - if (!match) - return this.baseFs.realpathSync(p); - if (!match[5]) - return p; - const realpath = this.baseFs.realpathSync(this.mapToBase(p)); - return VirtualFS.makeVirtualPath(match[1], match[3], realpath); - } - async realpathPromise(p) { - const match = p.match(VIRTUAL_REGEXP); - if (!match) - return await this.baseFs.realpathPromise(p); - if (!match[5]) - return p; - const realpath = await this.baseFs.realpathPromise(this.mapToBase(p)); - return VirtualFS.makeVirtualPath(match[1], match[3], realpath); - } - mapToBase(p) { - if (p === ``) - return p; - if (this.pathUtils.isAbsolute(p)) - return VirtualFS.resolveVirtual(p); - const resolvedRoot = VirtualFS.resolveVirtual(this.baseFs.resolve(PortablePath.dot)); - const resolvedP = VirtualFS.resolveVirtual(this.baseFs.resolve(p)); - return ppath.relative(resolvedRoot, resolvedP) || PortablePath.dot; - } - mapFromBase(p) { - return p; - } -} - -const URL = Number(process.versions.node.split('.', 1)[0]) < 20 ? url.URL : globalThis.URL; - -class NodePathFS extends ProxiedFS { - baseFs; - constructor(baseFs) { - super(npath); - this.baseFs = baseFs; - } - mapFromBase(path) { - return path; - } - mapToBase(path) { - if (typeof path === `string`) - return path; - if (path instanceof URL) - return url.fileURLToPath(path); - if (Buffer.isBuffer(path)) { - const str = path.toString(); - if (!isUtf8(path, str)) - throw new Error(`Non-utf8 buffers are not supported at the moment. Please upvote the following issue if you encounter this error: https://github.com/yarnpkg/berry/issues/4942`); - return str; - } - throw new Error(`Unsupported path type: ${nodeUtils.inspect(path)}`); - } -} -function isUtf8(buf, str) { - if (typeof buffer__default.default.isUtf8 !== `undefined`) - return buffer__default.default.isUtf8(buf); - return Buffer.byteLength(str) === buf.byteLength; -} - -const kBaseFs = Symbol(`kBaseFs`); -const kFd = Symbol(`kFd`); -const kClosePromise = Symbol(`kClosePromise`); -const kCloseResolve = Symbol(`kCloseResolve`); -const kCloseReject = Symbol(`kCloseReject`); -const kRefs = Symbol(`kRefs`); -const kRef = Symbol(`kRef`); -const kUnref = Symbol(`kUnref`); -class FileHandle { - [kBaseFs]; - [kFd]; - [kRefs] = 1; - [kClosePromise] = void 0; - [kCloseResolve] = void 0; - [kCloseReject] = void 0; - constructor(fd, baseFs) { - this[kBaseFs] = baseFs; - this[kFd] = fd; - } - get fd() { - return this[kFd]; - } - async appendFile(data, options) { - try { - this[kRef](this.appendFile); - const encoding = (typeof options === `string` ? options : options?.encoding) ?? void 0; - return await this[kBaseFs].appendFilePromise(this.fd, data, encoding ? { encoding } : void 0); - } finally { - this[kUnref](); - } - } - async chown(uid, gid) { - try { - this[kRef](this.chown); - return await this[kBaseFs].fchownPromise(this.fd, uid, gid); - } finally { - this[kUnref](); - } - } - async chmod(mode) { - try { - this[kRef](this.chmod); - return await this[kBaseFs].fchmodPromise(this.fd, mode); - } finally { - this[kUnref](); - } - } - createReadStream(options) { - return this[kBaseFs].createReadStream(null, { ...options, fd: this.fd }); - } - createWriteStream(options) { - return this[kBaseFs].createWriteStream(null, { ...options, fd: this.fd }); - } - // FIXME: Missing FakeFS version - datasync() { - throw new Error(`Method not implemented.`); - } - // FIXME: Missing FakeFS version - sync() { - throw new Error(`Method not implemented.`); - } - async read(bufferOrOptions, offsetOrOptions, length, position) { - try { - this[kRef](this.read); - let buffer; - let offset; - if (!ArrayBuffer.isView(bufferOrOptions)) { - buffer = bufferOrOptions?.buffer ?? Buffer.alloc(16384); - offset = bufferOrOptions?.offset ?? 0; - length = bufferOrOptions?.length ?? buffer.byteLength - offset; - position = bufferOrOptions?.position ?? null; - } else if (typeof offsetOrOptions === `object` && offsetOrOptions !== null) { - buffer = bufferOrOptions; - offset = offsetOrOptions?.offset ?? 0; - length = offsetOrOptions?.length ?? buffer.byteLength - offset; - position = offsetOrOptions?.position ?? null; - } else { - buffer = bufferOrOptions; - offset = offsetOrOptions ?? 0; - length ??= 0; - } - if (length === 0) { - return { - bytesRead: length, - buffer - }; - } - const bytesRead = await this[kBaseFs].readPromise( - this.fd, - // FIXME: FakeFS should support ArrayBufferViews directly - Buffer.isBuffer(buffer) ? buffer : Buffer.from(buffer.buffer, buffer.byteOffset, buffer.byteLength), - offset, - length, - position - ); - return { - bytesRead, - buffer - }; - } finally { - this[kUnref](); - } - } - async readFile(options) { - try { - this[kRef](this.readFile); - const encoding = (typeof options === `string` ? options : options?.encoding) ?? void 0; - return await this[kBaseFs].readFilePromise(this.fd, encoding); - } finally { - this[kUnref](); - } - } - readLines(options) { - return readline.createInterface({ - input: this.createReadStream(options), - crlfDelay: Infinity - }); - } - async stat(opts) { - try { - this[kRef](this.stat); - return await this[kBaseFs].fstatPromise(this.fd, opts); - } finally { - this[kUnref](); - } - } - async truncate(len) { - try { - this[kRef](this.truncate); - return await this[kBaseFs].ftruncatePromise(this.fd, len); - } finally { - this[kUnref](); - } - } - // FIXME: Missing FakeFS version - utimes(atime, mtime) { - throw new Error(`Method not implemented.`); - } - async writeFile(data, options) { - try { - this[kRef](this.writeFile); - const encoding = (typeof options === `string` ? options : options?.encoding) ?? void 0; - await this[kBaseFs].writeFilePromise(this.fd, data, encoding); - } finally { - this[kUnref](); - } - } - async write(...args) { - try { - this[kRef](this.write); - if (ArrayBuffer.isView(args[0])) { - const [buffer, offset, length, position] = args; - const bytesWritten = await this[kBaseFs].writePromise(this.fd, buffer, offset ?? void 0, length ?? void 0, position ?? void 0); - return { bytesWritten, buffer }; - } else { - const [data, position, encoding] = args; - const bytesWritten = await this[kBaseFs].writePromise(this.fd, data, position, encoding); - return { bytesWritten, buffer: data }; - } - } finally { - this[kUnref](); - } - } - // TODO: Use writev from FakeFS when that is implemented - async writev(buffers, position) { - try { - this[kRef](this.writev); - let bytesWritten = 0; - if (typeof position !== `undefined`) { - for (const buffer of buffers) { - const writeResult = await this.write(buffer, void 0, void 0, position); - bytesWritten += writeResult.bytesWritten; - position += writeResult.bytesWritten; - } - } else { - for (const buffer of buffers) { - const writeResult = await this.write(buffer); - bytesWritten += writeResult.bytesWritten; - } - } - return { - buffers, - bytesWritten - }; - } finally { - this[kUnref](); - } - } - // FIXME: Missing FakeFS version - readv(buffers, position) { - throw new Error(`Method not implemented.`); - } - close() { - if (this[kFd] === -1) return Promise.resolve(); - if (this[kClosePromise]) return this[kClosePromise]; - this[kRefs]--; - if (this[kRefs] === 0) { - const fd = this[kFd]; - this[kFd] = -1; - this[kClosePromise] = this[kBaseFs].closePromise(fd).finally(() => { - this[kClosePromise] = void 0; - }); - } else { - this[kClosePromise] = new Promise((resolve, reject) => { - this[kCloseResolve] = resolve; - this[kCloseReject] = reject; - }).finally(() => { - this[kClosePromise] = void 0; - this[kCloseReject] = void 0; - this[kCloseResolve] = void 0; - }); - } - return this[kClosePromise]; - } - [kRef](caller) { - if (this[kFd] === -1) { - const err = new Error(`file closed`); - err.code = `EBADF`; - err.syscall = caller.name; - throw err; - } - this[kRefs]++; - } - [kUnref]() { - this[kRefs]--; - if (this[kRefs] === 0) { - const fd = this[kFd]; - this[kFd] = -1; - this[kBaseFs].closePromise(fd).then(this[kCloseResolve], this[kCloseReject]); - } - } -} - -const SYNC_IMPLEMENTATIONS = /* @__PURE__ */ new Set([ - `accessSync`, - `appendFileSync`, - `createReadStream`, - `createWriteStream`, - `chmodSync`, - `fchmodSync`, - `chownSync`, - `fchownSync`, - `closeSync`, - `copyFileSync`, - `linkSync`, - `lstatSync`, - `fstatSync`, - `lutimesSync`, - `mkdirSync`, - `openSync`, - `opendirSync`, - `readlinkSync`, - `readFileSync`, - `readdirSync`, - `readlinkSync`, - `realpathSync`, - `renameSync`, - `rmdirSync`, - `rmSync`, - `statSync`, - `symlinkSync`, - `truncateSync`, - `ftruncateSync`, - `unlinkSync`, - `unwatchFile`, - `utimesSync`, - `watch`, - `watchFile`, - `writeFileSync`, - `writeSync` -]); -const ASYNC_IMPLEMENTATIONS = /* @__PURE__ */ new Set([ - `accessPromise`, - `appendFilePromise`, - `fchmodPromise`, - `chmodPromise`, - `fchownPromise`, - `chownPromise`, - `closePromise`, - `copyFilePromise`, - `linkPromise`, - `fstatPromise`, - `lstatPromise`, - `lutimesPromise`, - `mkdirPromise`, - `openPromise`, - `opendirPromise`, - `readdirPromise`, - `realpathPromise`, - `readFilePromise`, - `readdirPromise`, - `readlinkPromise`, - `renamePromise`, - `rmdirPromise`, - `rmPromise`, - `statPromise`, - `symlinkPromise`, - `truncatePromise`, - `ftruncatePromise`, - `unlinkPromise`, - `utimesPromise`, - `writeFilePromise`, - `writeSync` -]); -function patchFs(patchedFs, fakeFs) { - fakeFs = new NodePathFS(fakeFs); - const setupFn = (target, name, replacement) => { - const orig = target[name]; - target[name] = replacement; - if (typeof orig?.[nodeUtils.promisify.custom] !== `undefined`) { - replacement[nodeUtils.promisify.custom] = orig[nodeUtils.promisify.custom]; - } - }; - { - setupFn(patchedFs, `exists`, (p, ...args) => { - const hasCallback = typeof args[args.length - 1] === `function`; - const callback = hasCallback ? args.pop() : () => { - }; - process.nextTick(() => { - fakeFs.existsPromise(p).then((exists) => { - callback(exists); - }, () => { - callback(false); - }); - }); - }); - setupFn(patchedFs, `read`, (...args) => { - let [fd, buffer, offset, length, position, callback] = args; - if (args.length <= 3) { - let options = {}; - if (args.length < 3) { - callback = args[1]; - } else { - options = args[1]; - callback = args[2]; - } - ({ - buffer = Buffer.alloc(16384), - offset = 0, - length = buffer.byteLength, - position - } = options); - } - if (offset == null) - offset = 0; - length |= 0; - if (length === 0) { - process.nextTick(() => { - callback(null, 0, buffer); - }); - return; - } - if (position == null) - position = -1; - process.nextTick(() => { - fakeFs.readPromise(fd, buffer, offset, length, position).then((bytesRead) => { - callback(null, bytesRead, buffer); - }, (error) => { - callback(error, 0, buffer); - }); - }); - }); - for (const fnName of ASYNC_IMPLEMENTATIONS) { - const origName = fnName.replace(/Promise$/, ``); - if (typeof patchedFs[origName] === `undefined`) - continue; - const fakeImpl = fakeFs[fnName]; - if (typeof fakeImpl === `undefined`) - continue; - const wrapper = (...args) => { - const hasCallback = typeof args[args.length - 1] === `function`; - const callback = hasCallback ? args.pop() : () => { - }; - process.nextTick(() => { - fakeImpl.apply(fakeFs, args).then((result) => { - callback(null, result); - }, (error) => { - callback(error); - }); - }); - }; - setupFn(patchedFs, origName, wrapper); - } - patchedFs.realpath.native = patchedFs.realpath; - } - { - setupFn(patchedFs, `existsSync`, (p) => { - try { - return fakeFs.existsSync(p); - } catch { - return false; - } - }); - setupFn(patchedFs, `readSync`, (...args) => { - let [fd, buffer, offset, length, position] = args; - if (args.length <= 3) { - const options = args[2] || {}; - ({ offset = 0, length = buffer.byteLength, position } = options); - } - if (offset == null) - offset = 0; - length |= 0; - if (length === 0) - return 0; - if (position == null) - position = -1; - return fakeFs.readSync(fd, buffer, offset, length, position); - }); - for (const fnName of SYNC_IMPLEMENTATIONS) { - const origName = fnName; - if (typeof patchedFs[origName] === `undefined`) - continue; - const fakeImpl = fakeFs[fnName]; - if (typeof fakeImpl === `undefined`) - continue; - setupFn(patchedFs, origName, fakeImpl.bind(fakeFs)); - } - patchedFs.realpathSync.native = patchedFs.realpathSync; - } - { - const patchedFsPromises = patchedFs.promises; - for (const fnName of ASYNC_IMPLEMENTATIONS) { - const origName = fnName.replace(/Promise$/, ``); - if (typeof patchedFsPromises[origName] === `undefined`) - continue; - const fakeImpl = fakeFs[fnName]; - if (typeof fakeImpl === `undefined`) - continue; - if (fnName === `open`) - continue; - setupFn(patchedFsPromises, origName, (pathLike, ...args) => { - if (pathLike instanceof FileHandle) { - return pathLike[origName].apply(pathLike, args); - } else { - return fakeImpl.call(fakeFs, pathLike, ...args); - } - }); - } - setupFn(patchedFsPromises, `open`, async (...args) => { - const fd = await fakeFs.openPromise(...args); - return new FileHandle(fd, fakeFs); - }); - } - { - patchedFs.read[nodeUtils.promisify.custom] = async (fd, buffer, ...args) => { - const res = fakeFs.readPromise(fd, buffer, ...args); - return { bytesRead: await res, buffer }; - }; - patchedFs.write[nodeUtils.promisify.custom] = async (fd, buffer, ...args) => { - const res = fakeFs.writePromise(fd, buffer, ...args); - return { bytesWritten: await res, buffer }; - }; - } -} - -let cachedInstance; -let registeredFactory = () => { - throw new Error(`Assertion failed: No libzip instance is available, and no factory was configured`); -}; -function setFactory(factory) { - registeredFactory = factory; -} -function getInstance() { - if (typeof cachedInstance === `undefined`) - cachedInstance = registeredFactory(); - return cachedInstance; -} - -var libzipSync = {exports: {}}; - -(function (module, exports) { -var frozenFs = Object.assign({}, fs__default.default); -var createModule = function() { - var _scriptDir = void 0; - if (typeof __filename !== "undefined") _scriptDir = _scriptDir || __filename; - return function(createModule2) { - createModule2 = createModule2 || {}; - var Module = typeof createModule2 !== "undefined" ? createModule2 : {}; - var readyPromiseResolve, readyPromiseReject; - Module["ready"] = new Promise(function(resolve, reject) { - readyPromiseResolve = resolve; - readyPromiseReject = reject; - }); - var moduleOverrides = {}; - var key; - for (key in Module) { - if (Module.hasOwnProperty(key)) { - moduleOverrides[key] = Module[key]; - } - } - var scriptDirectory = ""; - function locateFile(path) { - if (Module["locateFile"]) { - return Module["locateFile"](path, scriptDirectory); - } - return scriptDirectory + path; - } - var read_, readBinary; - var nodeFS; - var nodePath; - { - { - scriptDirectory = __dirname + "/"; - } - read_ = function shell_read(filename, binary) { - var ret = tryParseAsDataURI(filename); - if (ret) { - return binary ? ret : ret.toString(); - } - if (!nodeFS) nodeFS = frozenFs; - if (!nodePath) nodePath = path__default.default; - filename = nodePath["normalize"](filename); - return nodeFS["readFileSync"](filename, binary ? null : "utf8"); - }; - readBinary = function readBinary2(filename) { - var ret = read_(filename, true); - if (!ret.buffer) { - ret = new Uint8Array(ret); - } - assert(ret.buffer); - return ret; - }; - if (process["argv"].length > 1) { - process["argv"][1].replace(/\\/g, "/"); - } - process["argv"].slice(2); - Module["inspect"] = function() { - return "[Emscripten Module object]"; - }; - } - Module["print"] || console.log.bind(console); - var err = Module["printErr"] || console.warn.bind(console); - for (key in moduleOverrides) { - if (moduleOverrides.hasOwnProperty(key)) { - Module[key] = moduleOverrides[key]; - } - } - moduleOverrides = null; - if (Module["arguments"]) ; - if (Module["thisProgram"]) ; - if (Module["quit"]) ; - var wasmBinary; - if (Module["wasmBinary"]) wasmBinary = Module["wasmBinary"]; - Module["noExitRuntime"] || true; - if (typeof WebAssembly !== "object") { - abort("no native wasm support detected"); - } - function getValue(ptr, type, noSafe) { - type = type || "i8"; - if (type.charAt(type.length - 1) === "*") type = "i32"; - switch (type) { - case "i1": - return HEAP8[ptr >> 0]; - case "i8": - return HEAP8[ptr >> 0]; - case "i16": - return LE_HEAP_LOAD_I16((ptr >> 1) * 2); - case "i32": - return LE_HEAP_LOAD_I32((ptr >> 2) * 4); - case "i64": - return LE_HEAP_LOAD_I32((ptr >> 2) * 4); - case "float": - return LE_HEAP_LOAD_F32((ptr >> 2) * 4); - case "double": - return LE_HEAP_LOAD_F64((ptr >> 3) * 8); - default: - abort("invalid type for getValue: " + type); - } - return null; - } - var wasmMemory; - var ABORT = false; - function assert(condition, text) { - if (!condition) { - abort("Assertion failed: " + text); - } - } - function getCFunc(ident) { - var func = Module["_" + ident]; - assert( - func, - "Cannot call unknown function " + ident + ", make sure it is exported" - ); - return func; - } - function ccall(ident, returnType, argTypes, args, opts) { - var toC = { - string: function(str) { - var ret2 = 0; - if (str !== null && str !== void 0 && str !== 0) { - var len = (str.length << 2) + 1; - ret2 = stackAlloc(len); - stringToUTF8(str, ret2, len); - } - return ret2; - }, - array: function(arr) { - var ret2 = stackAlloc(arr.length); - writeArrayToMemory(arr, ret2); - return ret2; - } - }; - function convertReturnValue(ret2) { - if (returnType === "string") return UTF8ToString(ret2); - if (returnType === "boolean") return Boolean(ret2); - return ret2; - } - var func = getCFunc(ident); - var cArgs = []; - var stack = 0; - if (args) { - for (var i = 0; i < args.length; i++) { - var converter = toC[argTypes[i]]; - if (converter) { - if (stack === 0) stack = stackSave(); - cArgs[i] = converter(args[i]); - } else { - cArgs[i] = args[i]; - } - } - } - var ret = func.apply(null, cArgs); - ret = convertReturnValue(ret); - if (stack !== 0) stackRestore(stack); - return ret; - } - function cwrap(ident, returnType, argTypes, opts) { - argTypes = argTypes || []; - var numericArgs = argTypes.every(function(type) { - return type === "number"; - }); - var numericRet = returnType !== "string"; - if (numericRet && numericArgs && !opts) { - return getCFunc(ident); - } - return function() { - return ccall(ident, returnType, argTypes, arguments); - }; - } - var UTF8Decoder = new TextDecoder("utf8"); - function UTF8ToString(ptr, maxBytesToRead) { - if (!ptr) return ""; - var maxPtr = ptr + maxBytesToRead; - for (var end = ptr; !(end >= maxPtr) && HEAPU8[end]; ) ++end; - return UTF8Decoder.decode(HEAPU8.subarray(ptr, end)); - } - function stringToUTF8Array(str, heap, outIdx, maxBytesToWrite) { - if (!(maxBytesToWrite > 0)) return 0; - var startIdx = outIdx; - var endIdx = outIdx + maxBytesToWrite - 1; - for (var i = 0; i < str.length; ++i) { - var u = str.charCodeAt(i); - if (u >= 55296 && u <= 57343) { - var u1 = str.charCodeAt(++i); - u = 65536 + ((u & 1023) << 10) | u1 & 1023; - } - if (u <= 127) { - if (outIdx >= endIdx) break; - heap[outIdx++] = u; - } else if (u <= 2047) { - if (outIdx + 1 >= endIdx) break; - heap[outIdx++] = 192 | u >> 6; - heap[outIdx++] = 128 | u & 63; - } else if (u <= 65535) { - if (outIdx + 2 >= endIdx) break; - heap[outIdx++] = 224 | u >> 12; - heap[outIdx++] = 128 | u >> 6 & 63; - heap[outIdx++] = 128 | u & 63; - } else { - if (outIdx + 3 >= endIdx) break; - heap[outIdx++] = 240 | u >> 18; - heap[outIdx++] = 128 | u >> 12 & 63; - heap[outIdx++] = 128 | u >> 6 & 63; - heap[outIdx++] = 128 | u & 63; - } - } - heap[outIdx] = 0; - return outIdx - startIdx; - } - function stringToUTF8(str, outPtr, maxBytesToWrite) { - return stringToUTF8Array(str, HEAPU8, outPtr, maxBytesToWrite); - } - function lengthBytesUTF8(str) { - var len = 0; - for (var i = 0; i < str.length; ++i) { - var u = str.charCodeAt(i); - if (u >= 55296 && u <= 57343) - u = 65536 + ((u & 1023) << 10) | str.charCodeAt(++i) & 1023; - if (u <= 127) ++len; - else if (u <= 2047) len += 2; - else if (u <= 65535) len += 3; - else len += 4; - } - return len; - } - function allocateUTF8(str) { - var size = lengthBytesUTF8(str) + 1; - var ret = _malloc(size); - if (ret) stringToUTF8Array(str, HEAP8, ret, size); - return ret; - } - function writeArrayToMemory(array, buffer2) { - HEAP8.set(array, buffer2); - } - function alignUp(x, multiple) { - if (x % multiple > 0) { - x += multiple - x % multiple; - } - return x; - } - var buffer, HEAP8, HEAPU8; - var HEAP_DATA_VIEW; - function updateGlobalBufferAndViews(buf) { - buffer = buf; - Module["HEAP_DATA_VIEW"] = HEAP_DATA_VIEW = new DataView(buf); - Module["HEAP8"] = HEAP8 = new Int8Array(buf); - Module["HEAP16"] = new Int16Array(buf); - Module["HEAP32"] = new Int32Array(buf); - Module["HEAPU8"] = HEAPU8 = new Uint8Array(buf); - Module["HEAPU16"] = new Uint16Array(buf); - Module["HEAPU32"] = new Uint32Array(buf); - Module["HEAPF32"] = new Float32Array(buf); - Module["HEAPF64"] = new Float64Array(buf); - } - Module["INITIAL_MEMORY"] || 16777216; - var wasmTable; - var __ATPRERUN__ = []; - var __ATINIT__ = []; - var __ATPOSTRUN__ = []; - function preRun() { - if (Module["preRun"]) { - if (typeof Module["preRun"] == "function") - Module["preRun"] = [Module["preRun"]]; - while (Module["preRun"].length) { - addOnPreRun(Module["preRun"].shift()); - } - } - callRuntimeCallbacks(__ATPRERUN__); - } - function initRuntime() { - callRuntimeCallbacks(__ATINIT__); - } - function postRun() { - if (Module["postRun"]) { - if (typeof Module["postRun"] == "function") - Module["postRun"] = [Module["postRun"]]; - while (Module["postRun"].length) { - addOnPostRun(Module["postRun"].shift()); - } - } - callRuntimeCallbacks(__ATPOSTRUN__); - } - function addOnPreRun(cb) { - __ATPRERUN__.unshift(cb); - } - function addOnInit(cb) { - __ATINIT__.unshift(cb); - } - function addOnPostRun(cb) { - __ATPOSTRUN__.unshift(cb); - } - var runDependencies = 0; - var dependenciesFulfilled = null; - function addRunDependency(id) { - runDependencies++; - if (Module["monitorRunDependencies"]) { - Module["monitorRunDependencies"](runDependencies); - } - } - function removeRunDependency(id) { - runDependencies--; - if (Module["monitorRunDependencies"]) { - Module["monitorRunDependencies"](runDependencies); - } - if (runDependencies == 0) { - if (dependenciesFulfilled) { - var callback = dependenciesFulfilled; - dependenciesFulfilled = null; - callback(); - } - } - } - Module["preloadedImages"] = {}; - Module["preloadedAudios"] = {}; - function abort(what) { - if (Module["onAbort"]) { - Module["onAbort"](what); - } - what += ""; - err(what); - ABORT = true; - what = "abort(" + what + "). Build with -s ASSERTIONS=1 for more info."; - var e = new WebAssembly.RuntimeError(what); - readyPromiseReject(e); - throw e; - } - var dataURIPrefix = "data:application/octet-stream;base64,"; - function isDataURI(filename) { - return filename.startsWith(dataURIPrefix); - } - var wasmBinaryFile = "data:application/octet-stream;base64,AGFzbQEAAAAB/wEkYAN/f38Bf2ABfwF/YAJ/fwF/YAF/AGAEf39/fwF/YAN/f38AYAV/f39/fwF/YAJ/fwBgBH9/f38AYAABf2AFf39/fn8BfmAEf35/fwF/YAR/f35/AX5gAn9+AX9gA398fwBgA39/fgF/YAF/AX5gBn9/f39/fwF/YAN/fn8Bf2AEf39/fwF+YAV/f35/fwF/YAR/f35/AX9gA39/fgF+YAJ/fgBgAn9/AX5gBX9/f39/AGADf35/AX5gBX5+f35/AX5gA39/fwF+YAZ/fH9/f38Bf2AAAGAHf35/f39+fwF/YAV/fn9/fwF/YAV/f39/fwF+YAJ+fwF/YAJ/fAACJQYBYQFhAAMBYQFiAAEBYQFjAAABYQFkAAEBYQFlAAIBYQFmAAED5wHlAQMAAwEDAwEHDAgDFgcNEgEDDRcFAQ8DEAUQAwIBAhgECxkEAQMBBQsFAwMDARACBAMAAggLBwEAAwADGgQDGwYGABwBBgMTFBEHBwcVCx4ABAgHBAICAgAfAQICAgIGFSAAIQAiAAIBBgIHAg0LEw0FAQUCACMDAQAUAAAGBQECBQUDCwsSAgEDBQIHAQEICAACCQQEAQABCAEBCQoBAwkBAQEBBgEGBgYABAIEBAQGEQQEAAARAAEDCQEJAQAJCQkBAQECCgoAAAMPAQEBAwACAgICBQIABwAKBgwHAAADAgICBQEEBQFwAT8/BQcBAYACgIACBgkBfwFBgInBAgsH+gEzAWcCAAFoAFQBaQDqAQFqALsBAWsAwQEBbACpAQFtAKgBAW4ApwEBbwClAQFwAKMBAXEAoAEBcgCbAQFzAMABAXQAugEBdQC5AQF2AEsBdwDiAQF4AMgBAXkAxwEBegDCAQFBAMkBAUIAuAEBQwAGAUQACQFFAKYBAUYAtwEBRwC2AQFIALUBAUkAtAEBSgCzAQFLALIBAUwAsQEBTQCwAQFOAK8BAU8AvAEBUACuAQFRAK0BAVIArAEBUwAaAVQACwFVAKQBAVYAMgFXAQABWACrAQFZAKoBAVoAxgEBXwDFAQEkAMQBAmFhAL8BAmJhAL4BAmNhAL0BCXgBAEEBCz6iAeMBjgGQAVpbjwFYnwGdAVeeAV1coQFZVlWcAZoBmQGYAZcBlgGVAZQBkwGSAZEB6QHoAecB5gHlAeQB4QHfAeAB3gHdAdwB2gHbAYUB2QHYAdcB1gHVAdQB0wHSAdEB0AHPAc4BzQHMAcsBygE4wwEK1N8G5QHMDAEHfwJAIABFDQAgAEEIayIDIABBBGsoAgAiAUF4cSIAaiEFAkAgAUEBcQ0AIAFBA3FFDQEgAyADKAIAIgFrIgNBxIQBKAIASQ0BIAAgAWohACADQciEASgCAEcEQCABQf8BTQRAIAMoAggiAiABQQN2IgRBA3RB3IQBakYaIAIgAygCDCIBRgRAQbSEAUG0hAEoAgBBfiAEd3E2AgAMAwsgAiABNgIMIAEgAjYCCAwCCyADKAIYIQYCQCADIAMoAgwiAUcEQCADKAIIIgIgATYCDCABIAI2AggMAQsCQCADQRRqIgIoAgAiBA0AIANBEGoiAigCACIEDQBBACEBDAELA0AgAiEHIAQiAUEUaiICKAIAIgQNACABQRBqIQIgASgCECIEDQALIAdBADYCAAsgBkUNAQJAIAMgAygCHCICQQJ0QeSGAWoiBCgCAEYEQCAEIAE2AgAgAQ0BQbiEAUG4hAEoAgBBfiACd3E2AgAMAwsgBkEQQRQgBigCECADRhtqIAE2AgAgAUUNAgsgASAGNgIYIAMoAhAiAgRAIAEgAjYCECACIAE2AhgLIAMoAhQiAkUNASABIAI2AhQgAiABNgIYDAELIAUoAgQiAUEDcUEDRw0AQbyEASAANgIAIAUgAUF+cTYCBCADIABBAXI2AgQgACADaiAANgIADwsgAyAFTw0AIAUoAgQiAUEBcUUNAAJAIAFBAnFFBEAgBUHMhAEoAgBGBEBBzIQBIAM2AgBBwIQBQcCEASgCACAAaiIANgIAIAMgAEEBcjYCBCADQciEASgCAEcNA0G8hAFBADYCAEHIhAFBADYCAA8LIAVByIQBKAIARgRAQciEASADNgIAQbyEAUG8hAEoAgAgAGoiADYCACADIABBAXI2AgQgACADaiAANgIADwsgAUF4cSAAaiEAAkAgAUH/AU0EQCAFKAIIIgIgAUEDdiIEQQN0QdyEAWpGGiACIAUoAgwiAUYEQEG0hAFBtIQBKAIAQX4gBHdxNgIADAILIAIgATYCDCABIAI2AggMAQsgBSgCGCEGAkAgBSAFKAIMIgFHBEAgBSgCCCICQcSEASgCAEkaIAIgATYCDCABIAI2AggMAQsCQCAFQRRqIgIoAgAiBA0AIAVBEGoiAigCACIEDQBBACEBDAELA0AgAiEHIAQiAUEUaiICKAIAIgQNACABQRBqIQIgASgCECIEDQALIAdBADYCAAsgBkUNAAJAIAUgBSgCHCICQQJ0QeSGAWoiBCgCAEYEQCAEIAE2AgAgAQ0BQbiEAUG4hAEoAgBBfiACd3E2AgAMAgsgBkEQQRQgBigCECAFRhtqIAE2AgAgAUUNAQsgASAGNgIYIAUoAhAiAgRAIAEgAjYCECACIAE2AhgLIAUoAhQiAkUNACABIAI2AhQgAiABNgIYCyADIABBAXI2AgQgACADaiAANgIAIANByIQBKAIARw0BQbyEASAANgIADwsgBSABQX5xNgIEIAMgAEEBcjYCBCAAIANqIAA2AgALIABB/wFNBEAgAEEDdiIBQQN0QdyEAWohAAJ/QbSEASgCACICQQEgAXQiAXFFBEBBtIQBIAEgAnI2AgAgAAwBCyAAKAIICyECIAAgAzYCCCACIAM2AgwgAyAANgIMIAMgAjYCCA8LQR8hAiADQgA3AhAgAEH///8HTQRAIABBCHYiASABQYD+P2pBEHZBCHEiAXQiAiACQYDgH2pBEHZBBHEiAnQiBCAEQYCAD2pBEHZBAnEiBHRBD3YgASACciAEcmsiAUEBdCAAIAFBFWp2QQFxckEcaiECCyADIAI2AhwgAkECdEHkhgFqIQECQAJAAkBBuIQBKAIAIgRBASACdCIHcUUEQEG4hAEgBCAHcjYCACABIAM2AgAgAyABNgIYDAELIABBAEEZIAJBAXZrIAJBH0YbdCECIAEoAgAhAQNAIAEiBCgCBEF4cSAARg0CIAJBHXYhASACQQF0IQIgBCABQQRxaiIHQRBqKAIAIgENAAsgByADNgIQIAMgBDYCGAsgAyADNgIMIAMgAzYCCAwBCyAEKAIIIgAgAzYCDCAEIAM2AgggA0EANgIYIAMgBDYCDCADIAA2AggLQdSEAUHUhAEoAgBBAWsiAEF/IAAbNgIACwuDBAEDfyACQYAETwRAIAAgASACEAIaIAAPCyAAIAJqIQMCQCAAIAFzQQNxRQRAAkAgAEEDcUUEQCAAIQIMAQsgAkEBSARAIAAhAgwBCyAAIQIDQCACIAEtAAA6AAAgAUEBaiEBIAJBAWoiAkEDcUUNASACIANJDQALCwJAIANBfHEiBEHAAEkNACACIARBQGoiBUsNAANAIAIgASgCADYCACACIAEoAgQ2AgQgAiABKAIINgIIIAIgASgCDDYCDCACIAEoAhA2AhAgAiABKAIUNgIUIAIgASgCGDYCGCACIAEoAhw2AhwgAiABKAIgNgIgIAIgASgCJDYCJCACIAEoAig2AiggAiABKAIsNgIsIAIgASgCMDYCMCACIAEoAjQ2AjQgAiABKAI4NgI4IAIgASgCPDYCPCABQUBrIQEgAkFAayICIAVNDQALCyACIARPDQEDQCACIAEoAgA2AgAgAUEEaiEBIAJBBGoiAiAESQ0ACwwBCyADQQRJBEAgACECDAELIAAgA0EEayIESwRAIAAhAgwBCyAAIQIDQCACIAEtAAA6AAAgAiABLQABOgABIAIgAS0AAjoAAiACIAEtAAM6AAMgAUEEaiEBIAJBBGoiAiAETQ0ACwsgAiADSQRAA0AgAiABLQAAOgAAIAFBAWohASACQQFqIgIgA0cNAAsLIAALGgAgAARAIAAtAAEEQCAAKAIEEAYLIAAQBgsLoi4BDH8jAEEQayIMJAACQAJAAkACQAJAAkACQAJAAkACQAJAAkAgAEH0AU0EQEG0hAEoAgAiBUEQIABBC2pBeHEgAEELSRsiCEEDdiICdiIBQQNxBEAgAUF/c0EBcSACaiIDQQN0IgFB5IQBaigCACIEQQhqIQACQCAEKAIIIgIgAUHchAFqIgFGBEBBtIQBIAVBfiADd3E2AgAMAQsgAiABNgIMIAEgAjYCCAsgBCADQQN0IgFBA3I2AgQgASAEaiIBIAEoAgRBAXI2AgQMDQsgCEG8hAEoAgAiCk0NASABBEACQEECIAJ0IgBBACAAa3IgASACdHEiAEEAIABrcUEBayIAIABBDHZBEHEiAnYiAUEFdkEIcSIAIAJyIAEgAHYiAUECdkEEcSIAciABIAB2IgFBAXZBAnEiAHIgASAAdiIBQQF2QQFxIgByIAEgAHZqIgNBA3QiAEHkhAFqKAIAIgQoAggiASAAQdyEAWoiAEYEQEG0hAEgBUF+IAN3cSIFNgIADAELIAEgADYCDCAAIAE2AggLIARBCGohACAEIAhBA3I2AgQgBCAIaiICIANBA3QiASAIayIDQQFyNgIEIAEgBGogAzYCACAKBEAgCkEDdiIBQQN0QdyEAWohB0HIhAEoAgAhBAJ/IAVBASABdCIBcUUEQEG0hAEgASAFcjYCACAHDAELIAcoAggLIQEgByAENgIIIAEgBDYCDCAEIAc2AgwgBCABNgIIC0HIhAEgAjYCAEG8hAEgAzYCAAwNC0G4hAEoAgAiBkUNASAGQQAgBmtxQQFrIgAgAEEMdkEQcSICdiIBQQV2QQhxIgAgAnIgASAAdiIBQQJ2QQRxIgByIAEgAHYiAUEBdkECcSIAciABIAB2IgFBAXZBAXEiAHIgASAAdmpBAnRB5IYBaigCACIBKAIEQXhxIAhrIQMgASECA0ACQCACKAIQIgBFBEAgAigCFCIARQ0BCyAAKAIEQXhxIAhrIgIgAyACIANJIgIbIQMgACABIAIbIQEgACECDAELCyABIAhqIgkgAU0NAiABKAIYIQsgASABKAIMIgRHBEAgASgCCCIAQcSEASgCAEkaIAAgBDYCDCAEIAA2AggMDAsgAUEUaiICKAIAIgBFBEAgASgCECIARQ0EIAFBEGohAgsDQCACIQcgACIEQRRqIgIoAgAiAA0AIARBEGohAiAEKAIQIgANAAsgB0EANgIADAsLQX8hCCAAQb9/Sw0AIABBC2oiAEF4cSEIQbiEASgCACIJRQ0AQQAgCGshAwJAAkACQAJ/QQAgCEGAAkkNABpBHyAIQf///wdLDQAaIABBCHYiACAAQYD+P2pBEHZBCHEiAnQiACAAQYDgH2pBEHZBBHEiAXQiACAAQYCAD2pBEHZBAnEiAHRBD3YgASACciAAcmsiAEEBdCAIIABBFWp2QQFxckEcagsiBUECdEHkhgFqKAIAIgJFBEBBACEADAELQQAhACAIQQBBGSAFQQF2ayAFQR9GG3QhAQNAAkAgAigCBEF4cSAIayIHIANPDQAgAiEEIAciAw0AQQAhAyACIQAMAwsgACACKAIUIgcgByACIAFBHXZBBHFqKAIQIgJGGyAAIAcbIQAgAUEBdCEBIAINAAsLIAAgBHJFBEBBAiAFdCIAQQAgAGtyIAlxIgBFDQMgAEEAIABrcUEBayIAIABBDHZBEHEiAnYiAUEFdkEIcSIAIAJyIAEgAHYiAUECdkEEcSIAciABIAB2IgFBAXZBAnEiAHIgASAAdiIBQQF2QQFxIgByIAEgAHZqQQJ0QeSGAWooAgAhAAsgAEUNAQsDQCAAKAIEQXhxIAhrIgEgA0khAiABIAMgAhshAyAAIAQgAhshBCAAKAIQIgEEfyABBSAAKAIUCyIADQALCyAERQ0AIANBvIQBKAIAIAhrTw0AIAQgCGoiBiAETQ0BIAQoAhghBSAEIAQoAgwiAUcEQCAEKAIIIgBBxIQBKAIASRogACABNgIMIAEgADYCCAwKCyAEQRRqIgIoAgAiAEUEQCAEKAIQIgBFDQQgBEEQaiECCwNAIAIhByAAIgFBFGoiAigCACIADQAgAUEQaiECIAEoAhAiAA0ACyAHQQA2AgAMCQsgCEG8hAEoAgAiAk0EQEHIhAEoAgAhAwJAIAIgCGsiAUEQTwRAQbyEASABNgIAQciEASADIAhqIgA2AgAgACABQQFyNgIEIAIgA2ogATYCACADIAhBA3I2AgQMAQtByIQBQQA2AgBBvIQBQQA2AgAgAyACQQNyNgIEIAIgA2oiACAAKAIEQQFyNgIECyADQQhqIQAMCwsgCEHAhAEoAgAiBkkEQEHAhAEgBiAIayIBNgIAQcyEAUHMhAEoAgAiAiAIaiIANgIAIAAgAUEBcjYCBCACIAhBA3I2AgQgAkEIaiEADAsLQQAhACAIQS9qIgkCf0GMiAEoAgAEQEGUiAEoAgAMAQtBmIgBQn83AgBBkIgBQoCggICAgAQ3AgBBjIgBIAxBDGpBcHFB2KrVqgVzNgIAQaCIAUEANgIAQfCHAUEANgIAQYAgCyIBaiIFQQAgAWsiB3EiAiAITQ0KQeyHASgCACIEBEBB5IcBKAIAIgMgAmoiASADTQ0LIAEgBEsNCwtB8IcBLQAAQQRxDQUCQAJAQcyEASgCACIDBEBB9IcBIQADQCADIAAoAgAiAU8EQCABIAAoAgRqIANLDQMLIAAoAggiAA0ACwtBABApIgFBf0YNBiACIQVBkIgBKAIAIgNBAWsiACABcQRAIAIgAWsgACABakEAIANrcWohBQsgBSAITQ0GIAVB/v///wdLDQZB7IcBKAIAIgQEQEHkhwEoAgAiAyAFaiIAIANNDQcgACAESw0HCyAFECkiACABRw0BDAgLIAUgBmsgB3EiBUH+////B0sNBSAFECkiASAAKAIAIAAoAgRqRg0EIAEhAAsCQCAAQX9GDQAgCEEwaiAFTQ0AQZSIASgCACIBIAkgBWtqQQAgAWtxIgFB/v///wdLBEAgACEBDAgLIAEQKUF/RwRAIAEgBWohBSAAIQEMCAtBACAFaxApGgwFCyAAIgFBf0cNBgwECwALQQAhBAwHC0EAIQEMBQsgAUF/Rw0CC0HwhwFB8IcBKAIAQQRyNgIACyACQf7///8HSw0BIAIQKSEBQQAQKSEAIAFBf0YNASAAQX9GDQEgACABTQ0BIAAgAWsiBSAIQShqTQ0BC0HkhwFB5IcBKAIAIAVqIgA2AgBB6IcBKAIAIABJBEBB6IcBIAA2AgALAkACQAJAQcyEASgCACIHBEBB9IcBIQADQCABIAAoAgAiAyAAKAIEIgJqRg0CIAAoAggiAA0ACwwCC0HEhAEoAgAiAEEAIAAgAU0bRQRAQcSEASABNgIAC0EAIQBB+IcBIAU2AgBB9IcBIAE2AgBB1IQBQX82AgBB2IQBQYyIASgCADYCAEGAiAFBADYCAANAIABBA3QiA0HkhAFqIANB3IQBaiICNgIAIANB6IQBaiACNgIAIABBAWoiAEEgRw0AC0HAhAEgBUEoayIDQXggAWtBB3FBACABQQhqQQdxGyIAayICNgIAQcyEASAAIAFqIgA2AgAgACACQQFyNgIEIAEgA2pBKDYCBEHQhAFBnIgBKAIANgIADAILIAAtAAxBCHENACADIAdLDQAgASAHTQ0AIAAgAiAFajYCBEHMhAEgB0F4IAdrQQdxQQAgB0EIakEHcRsiAGoiAjYCAEHAhAFBwIQBKAIAIAVqIgEgAGsiADYCACACIABBAXI2AgQgASAHakEoNgIEQdCEAUGciAEoAgA2AgAMAQtBxIQBKAIAIAFLBEBBxIQBIAE2AgALIAEgBWohAkH0hwEhAAJAAkACQAJAAkACQANAIAIgACgCAEcEQCAAKAIIIgANAQwCCwsgAC0ADEEIcUUNAQtB9IcBIQADQCAHIAAoAgAiAk8EQCACIAAoAgRqIgQgB0sNAwsgACgCCCEADAALAAsgACABNgIAIAAgACgCBCAFajYCBCABQXggAWtBB3FBACABQQhqQQdxG2oiCSAIQQNyNgIEIAJBeCACa0EHcUEAIAJBCGpBB3EbaiIFIAggCWoiBmshAiAFIAdGBEBBzIQBIAY2AgBBwIQBQcCEASgCACACaiIANgIAIAYgAEEBcjYCBAwDCyAFQciEASgCAEYEQEHIhAEgBjYCAEG8hAFBvIQBKAIAIAJqIgA2AgAgBiAAQQFyNgIEIAAgBmogADYCAAwDCyAFKAIEIgBBA3FBAUYEQCAAQXhxIQcCQCAAQf8BTQRAIAUoAggiAyAAQQN2IgBBA3RB3IQBakYaIAMgBSgCDCIBRgRAQbSEAUG0hAEoAgBBfiAAd3E2AgAMAgsgAyABNgIMIAEgAzYCCAwBCyAFKAIYIQgCQCAFIAUoAgwiAUcEQCAFKAIIIgAgATYCDCABIAA2AggMAQsCQCAFQRRqIgAoAgAiAw0AIAVBEGoiACgCACIDDQBBACEBDAELA0AgACEEIAMiAUEUaiIAKAIAIgMNACABQRBqIQAgASgCECIDDQALIARBADYCAAsgCEUNAAJAIAUgBSgCHCIDQQJ0QeSGAWoiACgCAEYEQCAAIAE2AgAgAQ0BQbiEAUG4hAEoAgBBfiADd3E2AgAMAgsgCEEQQRQgCCgCECAFRhtqIAE2AgAgAUUNAQsgASAINgIYIAUoAhAiAARAIAEgADYCECAAIAE2AhgLIAUoAhQiAEUNACABIAA2AhQgACABNgIYCyAFIAdqIQUgAiAHaiECCyAFIAUoAgRBfnE2AgQgBiACQQFyNgIEIAIgBmogAjYCACACQf8BTQRAIAJBA3YiAEEDdEHchAFqIQICf0G0hAEoAgAiAUEBIAB0IgBxRQRAQbSEASAAIAFyNgIAIAIMAQsgAigCCAshACACIAY2AgggACAGNgIMIAYgAjYCDCAGIAA2AggMAwtBHyEAIAJB////B00EQCACQQh2IgAgAEGA/j9qQRB2QQhxIgN0IgAgAEGA4B9qQRB2QQRxIgF0IgAgAEGAgA9qQRB2QQJxIgB0QQ92IAEgA3IgAHJrIgBBAXQgAiAAQRVqdkEBcXJBHGohAAsgBiAANgIcIAZCADcCECAAQQJ0QeSGAWohBAJAQbiEASgCACIDQQEgAHQiAXFFBEBBuIQBIAEgA3I2AgAgBCAGNgIAIAYgBDYCGAwBCyACQQBBGSAAQQF2ayAAQR9GG3QhACAEKAIAIQEDQCABIgMoAgRBeHEgAkYNAyAAQR12IQEgAEEBdCEAIAMgAUEEcWoiBCgCECIBDQALIAQgBjYCECAGIAM2AhgLIAYgBjYCDCAGIAY2AggMAgtBwIQBIAVBKGsiA0F4IAFrQQdxQQAgAUEIakEHcRsiAGsiAjYCAEHMhAEgACABaiIANgIAIAAgAkEBcjYCBCABIANqQSg2AgRB0IQBQZyIASgCADYCACAHIARBJyAEa0EHcUEAIARBJ2tBB3EbakEvayIAIAAgB0EQakkbIgJBGzYCBCACQfyHASkCADcCECACQfSHASkCADcCCEH8hwEgAkEIajYCAEH4hwEgBTYCAEH0hwEgATYCAEGAiAFBADYCACACQRhqIQADQCAAQQc2AgQgAEEIaiEBIABBBGohACABIARJDQALIAIgB0YNAyACIAIoAgRBfnE2AgQgByACIAdrIgRBAXI2AgQgAiAENgIAIARB/wFNBEAgBEEDdiIAQQN0QdyEAWohAgJ/QbSEASgCACIBQQEgAHQiAHFFBEBBtIQBIAAgAXI2AgAgAgwBCyACKAIICyEAIAIgBzYCCCAAIAc2AgwgByACNgIMIAcgADYCCAwEC0EfIQAgB0IANwIQIARB////B00EQCAEQQh2IgAgAEGA/j9qQRB2QQhxIgJ0IgAgAEGA4B9qQRB2QQRxIgF0IgAgAEGAgA9qQRB2QQJxIgB0QQ92IAEgAnIgAHJrIgBBAXQgBCAAQRVqdkEBcXJBHGohAAsgByAANgIcIABBAnRB5IYBaiEDAkBBuIQBKAIAIgJBASAAdCIBcUUEQEG4hAEgASACcjYCACADIAc2AgAgByADNgIYDAELIARBAEEZIABBAXZrIABBH0YbdCEAIAMoAgAhAQNAIAEiAigCBEF4cSAERg0EIABBHXYhASAAQQF0IQAgAiABQQRxaiIDKAIQIgENAAsgAyAHNgIQIAcgAjYCGAsgByAHNgIMIAcgBzYCCAwDCyADKAIIIgAgBjYCDCADIAY2AgggBkEANgIYIAYgAzYCDCAGIAA2AggLIAlBCGohAAwFCyACKAIIIgAgBzYCDCACIAc2AgggB0EANgIYIAcgAjYCDCAHIAA2AggLQcCEASgCACIAIAhNDQBBwIQBIAAgCGsiATYCAEHMhAFBzIQBKAIAIgIgCGoiADYCACAAIAFBAXI2AgQgAiAIQQNyNgIEIAJBCGohAAwDC0GEhAFBMDYCAEEAIQAMAgsCQCAFRQ0AAkAgBCgCHCICQQJ0QeSGAWoiACgCACAERgRAIAAgATYCACABDQFBuIQBIAlBfiACd3EiCTYCAAwCCyAFQRBBFCAFKAIQIARGG2ogATYCACABRQ0BCyABIAU2AhggBCgCECIABEAgASAANgIQIAAgATYCGAsgBCgCFCIARQ0AIAEgADYCFCAAIAE2AhgLAkAgA0EPTQRAIAQgAyAIaiIAQQNyNgIEIAAgBGoiACAAKAIEQQFyNgIEDAELIAQgCEEDcjYCBCAGIANBAXI2AgQgAyAGaiADNgIAIANB/wFNBEAgA0EDdiIAQQN0QdyEAWohAgJ/QbSEASgCACIBQQEgAHQiAHFFBEBBtIQBIAAgAXI2AgAgAgwBCyACKAIICyEAIAIgBjYCCCAAIAY2AgwgBiACNgIMIAYgADYCCAwBC0EfIQAgA0H///8HTQRAIANBCHYiACAAQYD+P2pBEHZBCHEiAnQiACAAQYDgH2pBEHZBBHEiAXQiACAAQYCAD2pBEHZBAnEiAHRBD3YgASACciAAcmsiAEEBdCADIABBFWp2QQFxckEcaiEACyAGIAA2AhwgBkIANwIQIABBAnRB5IYBaiECAkACQCAJQQEgAHQiAXFFBEBBuIQBIAEgCXI2AgAgAiAGNgIAIAYgAjYCGAwBCyADQQBBGSAAQQF2ayAAQR9GG3QhACACKAIAIQgDQCAIIgEoAgRBeHEgA0YNAiAAQR12IQIgAEEBdCEAIAEgAkEEcWoiAigCECIIDQALIAIgBjYCECAGIAE2AhgLIAYgBjYCDCAGIAY2AggMAQsgASgCCCIAIAY2AgwgASAGNgIIIAZBADYCGCAGIAE2AgwgBiAANgIICyAEQQhqIQAMAQsCQCALRQ0AAkAgASgCHCICQQJ0QeSGAWoiACgCACABRgRAIAAgBDYCACAEDQFBuIQBIAZBfiACd3E2AgAMAgsgC0EQQRQgCygCECABRhtqIAQ2AgAgBEUNAQsgBCALNgIYIAEoAhAiAARAIAQgADYCECAAIAQ2AhgLIAEoAhQiAEUNACAEIAA2AhQgACAENgIYCwJAIANBD00EQCABIAMgCGoiAEEDcjYCBCAAIAFqIgAgACgCBEEBcjYCBAwBCyABIAhBA3I2AgQgCSADQQFyNgIEIAMgCWogAzYCACAKBEAgCkEDdiIAQQN0QdyEAWohBEHIhAEoAgAhAgJ/QQEgAHQiACAFcUUEQEG0hAEgACAFcjYCACAEDAELIAQoAggLIQAgBCACNgIIIAAgAjYCDCACIAQ2AgwgAiAANgIIC0HIhAEgCTYCAEG8hAEgAzYCAAsgAUEIaiEACyAMQRBqJAAgAAuJAQEDfyAAKAIcIgEQMAJAIAAoAhAiAiABKAIQIgMgAiADSRsiAkUNACAAKAIMIAEoAgggAhAHGiAAIAAoAgwgAmo2AgwgASABKAIIIAJqNgIIIAAgACgCFCACajYCFCAAIAAoAhAgAms2AhAgASABKAIQIAJrIgA2AhAgAA0AIAEgASgCBDYCCAsLzgEBBX8CQCAARQ0AIAAoAjAiAQRAIAAgAUEBayIBNgIwIAENAQsgACgCIARAIABBATYCICAAEBoaCyAAKAIkQQFGBEAgABBDCwJAIAAoAiwiAUUNACAALQAoDQACQCABKAJEIgNFDQAgASgCTCEEA0AgACAEIAJBAnRqIgUoAgBHBEAgAyACQQFqIgJHDQEMAgsLIAUgBCADQQFrIgJBAnRqKAIANgIAIAEgAjYCRAsLIABBAEIAQQUQDhogACgCACIBBEAgARALCyAAEAYLC1oCAn4BfwJ/AkACQCAALQAARQ0AIAApAxAiAUJ9Vg0AIAFCAnwiAiAAKQMIWA0BCyAAQQA6AABBAAwBC0EAIAAoAgQiA0UNABogACACNwMQIAMgAadqLwAACwthAgJ+AX8CQAJAIAAtAABFDQAgACkDECICQn1WDQAgAkICfCIDIAApAwhYDQELIABBADoAAA8LIAAoAgQiBEUEQA8LIAAgAzcDECAEIAKnaiIAIAFBCHY6AAEgACABOgAAC8wCAQJ/IwBBEGsiBCQAAkAgACkDGCADrYinQQFxRQRAIABBDGoiAARAIABBADYCBCAAQRw2AgALQn8hAgwBCwJ+IAAoAgAiBUUEQCAAKAIIIAEgAiADIAAoAgQRDAAMAQsgBSAAKAIIIAEgAiADIAAoAgQRCgALIgJCf1UNAAJAIANBBGsOCwEAAAAAAAAAAAABAAsCQAJAIAAtABhBEHFFBEAgAEEMaiIBBEAgAUEANgIEIAFBHDYCAAsMAQsCfiAAKAIAIgFFBEAgACgCCCAEQQhqQghBBCAAKAIEEQwADAELIAEgACgCCCAEQQhqQghBBCAAKAIEEQoAC0J/VQ0BCyAAQQxqIgAEQCAAQQA2AgQgAEEUNgIACwwBCyAEKAIIIQEgBCgCDCEDIABBDGoiAARAIAAgAzYCBCAAIAE2AgALCyAEQRBqJAAgAguTFQIOfwN+AkACQAJAAkACQAJAAkACQAJAAkACQCAAKALwLQRAIAAoAogBQQFIDQEgACgCACIEKAIsQQJHDQQgAC8B5AENAyAALwHoAQ0DIAAvAewBDQMgAC8B8AENAyAALwH0AQ0DIAAvAfgBDQMgAC8B/AENAyAALwGcAg0DIAAvAaACDQMgAC8BpAINAyAALwGoAg0DIAAvAawCDQMgAC8BsAINAyAALwG0Ag0DIAAvAbgCDQMgAC8BvAINAyAALwHAAg0DIAAvAcQCDQMgAC8ByAINAyAALwHUAg0DIAAvAdgCDQMgAC8B3AINAyAALwHgAg0DIAAvAYgCDQIgAC8BjAINAiAALwGYAg0CQSAhBgNAIAAgBkECdCIFai8B5AENAyAAIAVBBHJqLwHkAQ0DIAAgBUEIcmovAeQBDQMgACAFQQxyai8B5AENAyAGQQRqIgZBgAJHDQALDAMLIABBBzYC/C0gAkF8Rw0FIAFFDQUMBgsgAkEFaiIEIQcMAwtBASEHCyAEIAc2AiwLIAAgAEHoFmoQUSAAIABB9BZqEFEgAC8B5gEhBCAAIABB7BZqKAIAIgxBAnRqQf//AzsB6gEgAEGQFmohECAAQZQWaiERIABBjBZqIQdBACEGIAxBAE4EQEEHQYoBIAQbIQ1BBEEDIAQbIQpBfyEJA0AgBCEIIAAgCyIOQQFqIgtBAnRqLwHmASEEAkACQCAGQQFqIgVB//8DcSIPIA1B//8DcU8NACAEIAhHDQAgBSEGDAELAn8gACAIQQJ0akHMFWogCkH//wNxIA9LDQAaIAgEQEEBIQUgByAIIAlGDQEaIAAgCEECdGpBzBVqIgYgBi8BAEEBajsBACAHDAELQQEhBSAQIBEgBkH//wNxQQpJGwsiBiAGLwEAIAVqOwEAQQAhBgJ/IARFBEBBAyEKQYoBDAELQQNBBCAEIAhGIgUbIQpBBkEHIAUbCyENIAghCQsgDCAORw0ACwsgAEHaE2ovAQAhBCAAIABB+BZqKAIAIgxBAnRqQd4TakH//wM7AQBBACEGIAxBAE4EQEEHQYoBIAQbIQ1BBEEDIAQbIQpBfyEJQQAhCwNAIAQhCCAAIAsiDkEBaiILQQJ0akHaE2ovAQAhBAJAAkAgBkEBaiIFQf//A3EiDyANQf//A3FPDQAgBCAIRw0AIAUhBgwBCwJ/IAAgCEECdGpBzBVqIApB//8DcSAPSw0AGiAIBEBBASEFIAcgCCAJRg0BGiAAIAhBAnRqQcwVaiIGIAYvAQBBAWo7AQAgBwwBC0EBIQUgECARIAZB//8DcUEKSRsLIgYgBi8BACAFajsBAEEAIQYCfyAERQRAQQMhCkGKAQwBC0EDQQQgBCAIRiIFGyEKQQZBByAFGwshDSAIIQkLIAwgDkcNAAsLIAAgAEGAF2oQUSAAIAAoAvgtAn9BEiAAQYoWai8BAA0AGkERIABB0hVqLwEADQAaQRAgAEGGFmovAQANABpBDyAAQdYVai8BAA0AGkEOIABBghZqLwEADQAaQQ0gAEHaFWovAQANABpBDCAAQf4Vai8BAA0AGkELIABB3hVqLwEADQAaQQogAEH6FWovAQANABpBCSAAQeIVai8BAA0AGkEIIABB9hVqLwEADQAaQQcgAEHmFWovAQANABpBBiAAQfIVai8BAA0AGkEFIABB6hVqLwEADQAaQQQgAEHuFWovAQANABpBA0ECIABBzhVqLwEAGwsiBkEDbGoiBEERajYC+C0gACgC/C1BCmpBA3YiByAEQRtqQQN2IgRNBEAgByEEDAELIAAoAowBQQRHDQAgByEECyAEIAJBBGpPQQAgARsNASAEIAdHDQQLIANBAmqtIRIgACkDmC4hFCAAKAKgLiIBQQNqIgdBP0sNASASIAGthiAUhCESDAILIAAgASACIAMQOQwDCyABQcAARgRAIAAoAgQgACgCEGogFDcAACAAIAAoAhBBCGo2AhBBAyEHDAELIAAoAgQgACgCEGogEiABrYYgFIQ3AAAgACAAKAIQQQhqNgIQIAFBPWshByASQcAAIAFrrYghEgsgACASNwOYLiAAIAc2AqAuIABBgMEAQYDKABCHAQwBCyADQQRqrSESIAApA5guIRQCQCAAKAKgLiIBQQNqIgRBP00EQCASIAGthiAUhCESDAELIAFBwABGBEAgACgCBCAAKAIQaiAUNwAAIAAgACgCEEEIajYCEEEDIQQMAQsgACgCBCAAKAIQaiASIAGthiAUhDcAACAAIAAoAhBBCGo2AhAgAUE9ayEEIBJBwAAgAWutiCESCyAAIBI3A5guIAAgBDYCoC4gAEHsFmooAgAiC6xCgAJ9IRMgAEH4FmooAgAhCQJAAkACfwJ+AkACfwJ/IARBOk0EQCATIASthiAShCETIARBBWoMAQsgBEHAAEYEQCAAKAIEIAAoAhBqIBI3AAAgACAAKAIQQQhqNgIQIAmsIRJCBSEUQQoMAgsgACgCBCAAKAIQaiATIASthiAShDcAACAAIAAoAhBBCGo2AhAgE0HAACAEa62IIRMgBEE7awshBSAJrCESIAVBOksNASAFrSEUIAVBBWoLIQcgEiAUhiAThAwBCyAFQcAARgRAIAAoAgQgACgCEGogEzcAACAAIAAoAhBBCGo2AhAgBq1CA30hE0IFIRRBCQwCCyAAKAIEIAAoAhBqIBIgBa2GIBOENwAAIAAgACgCEEEIajYCECAFQTtrIQcgEkHAACAFa62ICyESIAatQgN9IRMgB0E7Sw0BIAetIRQgB0EEagshBCATIBSGIBKEIRMMAQsgB0HAAEYEQCAAKAIEIAAoAhBqIBI3AAAgACAAKAIQQQhqNgIQQQQhBAwBCyAAKAIEIAAoAhBqIBMgB62GIBKENwAAIAAgACgCEEEIajYCECAHQTxrIQQgE0HAACAHa62IIRMLQQAhBQNAIAAgBSIBQZDWAGotAABBAnRqQc4VajMBACEUAn8gBEE8TQRAIBQgBK2GIBOEIRMgBEEDagwBCyAEQcAARgRAIAAoAgQgACgCEGogEzcAACAAIAAoAhBBCGo2AhAgFCETQQMMAQsgACgCBCAAKAIQaiAUIASthiAThDcAACAAIAAoAhBBCGo2AhAgFEHAACAEa62IIRMgBEE9awshBCABQQFqIQUgASAGRw0ACyAAIAQ2AqAuIAAgEzcDmC4gACAAQeQBaiICIAsQhgEgACAAQdgTaiIBIAkQhgEgACACIAEQhwELIAAQiAEgAwRAAkAgACgCoC4iBEE5TgRAIAAoAgQgACgCEGogACkDmC43AAAgACAAKAIQQQhqNgIQDAELIARBGU4EQCAAKAIEIAAoAhBqIAApA5guPgAAIAAgAEGcLmo1AgA3A5guIAAgACgCEEEEajYCECAAIAAoAqAuQSBrIgQ2AqAuCyAEQQlOBH8gACgCBCAAKAIQaiAAKQOYLj0AACAAIAAoAhBBAmo2AhAgACAAKQOYLkIQiDcDmC4gACgCoC5BEGsFIAQLQQFIDQAgACAAKAIQIgFBAWo2AhAgASAAKAIEaiAAKQOYLjwAAAsgAEEANgKgLiAAQgA3A5guCwsZACAABEAgACgCABAGIAAoAgwQBiAAEAYLC6wBAQJ+Qn8hAwJAIAAtACgNAAJAAkAgACgCIEUNACACQgBTDQAgAlANASABDQELIABBDGoiAARAIABBADYCBCAAQRI2AgALQn8PCyAALQA1DQBCACEDIAAtADQNACACUA0AA0AgACABIAOnaiACIAN9QQEQDiIEQn9XBEAgAEEBOgA1Qn8gAyADUBsPCyAEUEUEQCADIAR8IgMgAloNAgwBCwsgAEEBOgA0CyADC3UCAn4BfwJAAkAgAC0AAEUNACAAKQMQIgJCe1YNACACQgR8IgMgACkDCFgNAQsgAEEAOgAADwsgACgCBCIERQRADwsgACADNwMQIAQgAqdqIgAgAUEYdjoAAyAAIAFBEHY6AAIgACABQQh2OgABIAAgAToAAAtUAgF+AX8CQAJAIAAtAABFDQAgASAAKQMQIgF8IgIgAVQNACACIAApAwhYDQELIABBADoAAEEADwsgACgCBCIDRQRAQQAPCyAAIAI3AxAgAyABp2oLdwECfyMAQRBrIgMkAEF/IQQCQCAALQAoDQAgACgCIEEAIAJBA0kbRQRAIABBDGoiAARAIABBADYCBCAAQRI2AgALDAELIAMgAjYCCCADIAE3AwAgACADQhBBBhAOQgBTDQBBACEEIABBADoANAsgA0EQaiQAIAQLVwICfgF/AkACQCAALQAARQ0AIAApAxAiAUJ7Vg0AIAFCBHwiAiAAKQMIWA0BCyAAQQA6AABBAA8LIAAoAgQiA0UEQEEADwsgACACNwMQIAMgAadqKAAAC1UCAX4BfyAABEACQCAAKQMIUA0AQgEhAQNAIAAoAgAgAkEEdGoQPiABIAApAwhaDQEgAachAiABQgF8IQEMAAsACyAAKAIAEAYgACgCKBAQIAAQBgsLZAECfwJAAkACQCAARQRAIAGnEAkiA0UNAkEYEAkiAkUNAQwDCyAAIQNBGBAJIgINAkEADwsgAxAGC0EADwsgAkIANwMQIAIgATcDCCACIAM2AgQgAkEBOgAAIAIgAEU6AAEgAgudAQICfgF/AkACQCAALQAARQ0AIAApAxAiAkJ3Vg0AIAJCCHwiAyAAKQMIWA0BCyAAQQA6AAAPCyAAKAIEIgRFBEAPCyAAIAM3AxAgBCACp2oiACABQjiIPAAHIAAgAUIwiDwABiAAIAFCKIg8AAUgACABQiCIPAAEIAAgAUIYiDwAAyAAIAFCEIg8AAIgACABQgiIPAABIAAgATwAAAvwAgICfwF+AkAgAkUNACAAIAJqIgNBAWsgAToAACAAIAE6AAAgAkEDSQ0AIANBAmsgAToAACAAIAE6AAEgA0EDayABOgAAIAAgAToAAiACQQdJDQAgA0EEayABOgAAIAAgAToAAyACQQlJDQAgAEEAIABrQQNxIgRqIgMgAUH/AXFBgYKECGwiADYCACADIAIgBGtBfHEiAmoiAUEEayAANgIAIAJBCUkNACADIAA2AgggAyAANgIEIAFBCGsgADYCACABQQxrIAA2AgAgAkEZSQ0AIAMgADYCGCADIAA2AhQgAyAANgIQIAMgADYCDCABQRBrIAA2AgAgAUEUayAANgIAIAFBGGsgADYCACABQRxrIAA2AgAgAiADQQRxQRhyIgFrIgJBIEkNACAArUKBgICAEH4hBSABIANqIQEDQCABIAU3AxggASAFNwMQIAEgBTcDCCABIAU3AwAgAUEgaiEBIAJBIGsiAkEfSw0ACwsLbwEDfyAAQQxqIQICQAJ/IAAoAiAiAUUEQEF/IQFBEgwBCyAAIAFBAWsiAzYCIEEAIQEgAw0BIABBAEIAQQIQDhogACgCACIARQ0BIAAQGkF/Sg0BQRQLIQAgAgRAIAJBADYCBCACIAA2AgALCyABC58BAgF/AX4CfwJAAn4gACgCACIDKAIkQQFGQQAgAkJ/VRtFBEAgA0EMaiIBBEAgAUEANgIEIAFBEjYCAAtCfwwBCyADIAEgAkELEA4LIgRCf1cEQCAAKAIAIQEgAEEIaiIABEAgACABKAIMNgIAIAAgASgCEDYCBAsMAQtBACACIARRDQEaIABBCGoEQCAAQRs2AgwgAEEGNgIICwtBfwsLJAEBfyAABEADQCAAKAIAIQEgACgCDBAGIAAQBiABIgANAAsLC5gBAgJ+AX8CQAJAIAAtAABFDQAgACkDECIBQndWDQAgAUIIfCICIAApAwhYDQELIABBADoAAEIADwsgACgCBCIDRQRAQgAPCyAAIAI3AxAgAyABp2oiADEABkIwhiAAMQAHQjiGhCAAMQAFQiiGhCAAMQAEQiCGhCAAMQADQhiGhCAAMQACQhCGhCAAMQABQgiGhCAAMQAAfAsjACAAQShGBEAgAhAGDwsgAgRAIAEgAkEEaygCACAAEQcACwsyACAAKAIkQQFHBEAgAEEMaiIABEAgAEEANgIEIABBEjYCAAtCfw8LIABBAEIAQQ0QDgsPACAABEAgABA2IAAQBgsLgAEBAX8gAC0AKAR/QX8FIAFFBEAgAEEMagRAIABBADYCECAAQRI2AgwLQX8PCyABECoCQCAAKAIAIgJFDQAgAiABECFBf0oNACAAKAIAIQEgAEEMaiIABEAgACABKAIMNgIAIAAgASgCEDYCBAtBfw8LIAAgAUI4QQMQDkI/h6cLC38BA38gACEBAkAgAEEDcQRAA0AgAS0AAEUNAiABQQFqIgFBA3ENAAsLA0AgASICQQRqIQEgAigCACIDQX9zIANBgYKECGtxQYCBgoR4cUUNAAsgA0H/AXFFBEAgAiAAaw8LA0AgAi0AASEDIAJBAWoiASECIAMNAAsLIAEgAGsL3wIBCH8gAEUEQEEBDwsCQCAAKAIIIgINAEEBIQQgAC8BBCIHRQRAQQEhAgwBCyAAKAIAIQgDQAJAIAMgCGoiBS0AACICQSBPBEAgAkEYdEEYdUF/Sg0BCyACQQ1NQQBBASACdEGAzABxGw0AAn8CfyACQeABcUHAAUYEQEEBIQYgA0EBagwBCyACQfABcUHgAUYEQCADQQJqIQNBACEGQQEMAgsgAkH4AXFB8AFHBEBBBCECDAULQQAhBiADQQNqCyEDQQALIQlBBCECIAMgB08NAiAFLQABQcABcUGAAUcNAkEDIQQgBg0AIAUtAAJBwAFxQYABRw0CIAkNACAFLQADQcABcUGAAUcNAgsgBCECIANBAWoiAyAHSQ0ACwsgACACNgIIAn8CQCABRQ0AAkAgAUECRw0AIAJBA0cNAEECIQIgAEECNgIICyABIAJGDQBBBSACQQFHDQEaCyACCwtIAgJ+An8jAEEQayIEIAE2AgxCASAArYYhAgNAIAQgAUEEaiIANgIMIAIiA0IBIAEoAgAiBa2GhCECIAAhASAFQX9KDQALIAMLhwUBB38CQAJAIABFBEBBxRQhAiABRQ0BIAFBADYCAEHFFA8LIAJBwABxDQEgACgCCEUEQCAAQQAQIxoLIAAoAgghBAJAIAJBgAFxBEAgBEEBa0ECTw0BDAMLIARBBEcNAgsCQCAAKAIMIgINACAAAn8gACgCACEIIABBEGohCUEAIQICQAJAAkACQCAALwEEIgUEQEEBIQQgBUEBcSEHIAVBAUcNAQwCCyAJRQ0CIAlBADYCAEEADAQLIAVBfnEhBgNAIARBAUECQQMgAiAIai0AAEEBdEHQFGovAQAiCkGAEEkbIApBgAFJG2pBAUECQQMgCCACQQFyai0AAEEBdEHQFGovAQAiBEGAEEkbIARBgAFJG2ohBCACQQJqIQIgBkECayIGDQALCwJ/IAcEQCAEQQFBAkEDIAIgCGotAABBAXRB0BRqLwEAIgJBgBBJGyACQYABSRtqIQQLIAQLEAkiB0UNASAFQQEgBUEBSxshCkEAIQVBACEGA0AgBSAHaiEDAn8gBiAIai0AAEEBdEHQFGovAQAiAkH/AE0EQCADIAI6AAAgBUEBagwBCyACQf8PTQRAIAMgAkE/cUGAAXI6AAEgAyACQQZ2QcABcjoAACAFQQJqDAELIAMgAkE/cUGAAXI6AAIgAyACQQx2QeABcjoAACADIAJBBnZBP3FBgAFyOgABIAVBA2oLIQUgBkEBaiIGIApHDQALIAcgBEEBayICakEAOgAAIAlFDQAgCSACNgIACyAHDAELIAMEQCADQQA2AgQgA0EONgIAC0EACyICNgIMIAINAEEADwsgAUUNACABIAAoAhA2AgALIAIPCyABBEAgASAALwEENgIACyAAKAIAC4MBAQR/QRIhBQJAAkAgACkDMCABWA0AIAGnIQYgACgCQCEEIAJBCHEiB0UEQCAEIAZBBHRqKAIEIgINAgsgBCAGQQR0aiIEKAIAIgJFDQAgBC0ADEUNAUEXIQUgBw0BC0EAIQIgAyAAQQhqIAMbIgAEQCAAQQA2AgQgACAFNgIACwsgAgtuAQF/IwBBgAJrIgUkAAJAIARBgMAEcQ0AIAIgA0wNACAFIAFB/wFxIAIgA2siAkGAAiACQYACSSIBGxAZIAFFBEADQCAAIAVBgAIQLiACQYACayICQf8BSw0ACwsgACAFIAIQLgsgBUGAAmokAAuBAQEBfyMAQRBrIgQkACACIANsIQICQCAAQSdGBEAgBEEMaiACEIwBIQBBACAEKAIMIAAbIQAMAQsgAUEBIAJBxABqIAARAAAiAUUEQEEAIQAMAQtBwAAgAUE/cWsiACABakHAAEEAIABBBEkbaiIAQQRrIAE2AAALIARBEGokACAAC1IBAn9BhIEBKAIAIgEgAEEDakF8cSICaiEAAkAgAkEAIAAgAU0bDQAgAD8AQRB0SwRAIAAQA0UNAQtBhIEBIAA2AgAgAQ8LQYSEAUEwNgIAQX8LNwAgAEJ/NwMQIABBADYCCCAAQgA3AwAgAEEANgIwIABC/////w83AyggAEIANwMYIABCADcDIAulAQEBf0HYABAJIgFFBEBBAA8LAkAgAARAIAEgAEHYABAHGgwBCyABQgA3AyAgAUEANgIYIAFC/////w83AxAgAUEAOwEMIAFBv4YoNgIIIAFBAToABiABQQA6AAQgAUIANwNIIAFBgIDYjXg2AkQgAUIANwMoIAFCADcDMCABQgA3AzggAUFAa0EAOwEAIAFCADcDUAsgAUEBOgAFIAFBADYCACABC1gCAn4BfwJAAkAgAC0AAEUNACAAKQMQIgMgAq18IgQgA1QNACAEIAApAwhYDQELIABBADoAAA8LIAAoAgQiBUUEQA8LIAAgBDcDECAFIAOnaiABIAIQBxoLlgEBAn8CQAJAIAJFBEAgAacQCSIFRQ0BQRgQCSIEDQIgBRAGDAELIAIhBUEYEAkiBA0BCyADBEAgA0EANgIEIANBDjYCAAtBAA8LIARCADcDECAEIAE3AwggBCAFNgIEIARBAToAACAEIAJFOgABIAAgBSABIAMQZUEASAR/IAQtAAEEQCAEKAIEEAYLIAQQBkEABSAECwubAgEDfyAALQAAQSBxRQRAAkAgASEDAkAgAiAAIgEoAhAiAAR/IAAFAn8gASABLQBKIgBBAWsgAHI6AEogASgCACIAQQhxBEAgASAAQSByNgIAQX8MAQsgAUIANwIEIAEgASgCLCIANgIcIAEgADYCFCABIAAgASgCMGo2AhBBAAsNASABKAIQCyABKAIUIgVrSwRAIAEgAyACIAEoAiQRAAAaDAILAn8gASwAS0F/SgRAIAIhAANAIAIgACIERQ0CGiADIARBAWsiAGotAABBCkcNAAsgASADIAQgASgCJBEAACAESQ0CIAMgBGohAyABKAIUIQUgAiAEawwBCyACCyEAIAUgAyAAEAcaIAEgASgCFCAAajYCFAsLCwvNBQEGfyAAKAIwIgNBhgJrIQYgACgCPCECIAMhAQNAIAAoAkQgAiAAKAJoIgRqayECIAEgBmogBE0EQCAAKAJIIgEgASADaiADEAcaAkAgAyAAKAJsIgFNBEAgACABIANrNgJsDAELIABCADcCbAsgACAAKAJoIANrIgE2AmggACAAKAJYIANrNgJYIAEgACgChC5JBEAgACABNgKELgsgAEH8gAEoAgARAwAgAiADaiECCwJAIAAoAgAiASgCBCIERQ0AIAAoAjwhBSAAIAIgBCACIARJGyICBH8gACgCSCAAKAJoaiAFaiEFIAEgBCACazYCBAJAAkACQAJAIAEoAhwiBCgCFEEBaw4CAQACCyAEQaABaiAFIAEoAgAgAkHcgAEoAgARCAAMAgsgASABKAIwIAUgASgCACACQcSAASgCABEEADYCMAwBCyAFIAEoAgAgAhAHGgsgASABKAIAIAJqNgIAIAEgASgCCCACajYCCCAAKAI8BSAFCyACaiICNgI8AkAgACgChC4iASACakEDSQ0AIAAoAmggAWshAQJAIAAoAnRBgQhPBEAgACAAIAAoAkggAWoiAi0AACACLQABIAAoAnwRAAA2AlQMAQsgAUUNACAAIAFBAWsgACgChAERAgAaCyAAKAKELiAAKAI8IgJBAUZrIgRFDQAgACABIAQgACgCgAERBQAgACAAKAKELiAEazYChC4gACgCPCECCyACQYUCSw0AIAAoAgAoAgRFDQAgACgCMCEBDAELCwJAIAAoAkQiAiAAKAJAIgNNDQAgAAJ/IAAoAjwgACgCaGoiASADSwRAIAAoAkggAWpBACACIAFrIgNBggIgA0GCAkkbIgMQGSABIANqDAELIAFBggJqIgEgA00NASAAKAJIIANqQQAgAiADayICIAEgA2siAyACIANJGyIDEBkgACgCQCADags2AkALC50CAQF/AkAgAAJ/IAAoAqAuIgFBwABGBEAgACgCBCAAKAIQaiAAKQOYLjcAACAAQgA3A5guIAAgACgCEEEIajYCEEEADAELIAFBIE4EQCAAKAIEIAAoAhBqIAApA5guPgAAIAAgAEGcLmo1AgA3A5guIAAgACgCEEEEajYCECAAIAAoAqAuQSBrIgE2AqAuCyABQRBOBEAgACgCBCAAKAIQaiAAKQOYLj0AACAAIAAoAhBBAmo2AhAgACAAKQOYLkIQiDcDmC4gACAAKAKgLkEQayIBNgKgLgsgAUEISA0BIAAgACgCECIBQQFqNgIQ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KAJUIgEEfyABQQAgARAiEBkgACgCVAVBAAsQBiAAQQA2AlQLC9wMAgl/AX4jAEFAaiIGJAACQAJAAkACQAJAIAEoAjBBABAjIgVBAkZBACABKAI4QQAQIyIEQQFGGw0AIAVBAUZBACAEQQJGGw0AIAVBAkciAw0BIARBAkcNAQsgASABLwEMQYAQcjsBDEEAIQMMAQsgASABLwEMQf/vA3E7AQxBACEFIANFBEBB9eABIAEoAjAgAEEIahBpIgVFDQILIAJBgAJxBEAgBSEDDAELIARBAkcEQCAFIQMMAQtB9cYBIAEoAjggAEEIahBpIgNFBEAgBRAcDAILIAMgBTYCAAsgASABLwEMQf7/A3EgAS8BUiIFQQBHcjsBDAJAAkACQAJAAn8CQAJAIAEpAyhC/v///w9WDQAgASkDIEL+////D1YNACACQYAEcUUNASABKQNIQv////8PVA0BCyAFQYECa0H//wNxQQNJIQdBAQwBCyAFQYECa0H//wNxIQQgAkGACnFBgApHDQEgBEEDSSEHQQALIQkgBkIcEBciBEUEQCAAQQhqIgAEQCAAQQA2AgQgAEEONgIACyADEBwMBQsgAkGACHEhBQJAAkAgAkGAAnEEQAJAIAUNACABKQMgQv////8PVg0AIAEpAyhCgICAgBBUDQMLIAQgASkDKBAYIAEpAyAhDAwBCwJAAkACQCAFDQAgASkDIEL/////D1YNACABKQMoIgxC/////w9WDQEgASkDSEKAgICAEFQNBAsgASkDKCIMQv////8PVA0BCyAEIAwQGAsgASkDICIMQv////8PWgRAIAQgDBAYCyABKQNIIgxC/////w9UDQELIAQgDBAYCyAELQAARQRAIABBCGoiAARAIABBADYCBCAAQRQ2AgALIAQQCCADEBwMBQtBASEKQQEgBC0AAAR+IAQpAxAFQgALp0H//wNxIAYQRyEFIAQQCCAFIAM2AgAgBw0BDAILIAMhBSAEQQJLDQELIAZCBxAXIgRFBEAgAEEIaiIABEAgAEEANgIEIABBDjYCAAsgBRAcDAMLIARBAhANIARBhxJBAhAsIAQgAS0AUhBwIAQgAS8BEBANIAQtAABFBEAgAEEIaiIABEAgAEEANgIEIABBFDYCAAsgBBAIDAILQYGyAkEHIAYQRyEDIAQQCCADIAU2AgBBASEL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NgIEIABB7A42AhggGiEdDAMLIARB/wFxIgJBwABxRQRAIAggDSADLwECQQJ0aiAdp0F/IAJ0QX9zcUECdGoiAy0AASICayEIIB0gAq2IIR0gAy0AACIERQ0HDAELCyAEQSBxBEAgB0G//gA2AgQgASECDAgLIAdB0f4ANgIEIABB0A42AhggASECDAcLIB1BfyAGdEF/c62DIBt8IhunIQUgCCAEQQ9xIgNrIQggGiAErUIPg4ghHSABIBdrIgYgAjMBAiAaQX8gA3RBf3Otg3ynIgRPDQIgBCAGayIGIBlNDQEgBygCjEdFDQEgB0HR/gA2AgQgAEG5DDYCGAsgASECIAshBQwFCwJAIA5FBEAgDCARIAZraiEDDAELIAYgDk0EQCAMIA4gBmtqIQMMAQsgDCARIAYgDmsiBmtqIQMgBSAGTQ0AIAUgBmshBQJAAkAgASADTSABIA8gAWusIhogBq0iGyAaIBtUGyIapyIGaiICIANLcQ0AIAMgBmogAUsgASADT3ENACABIAMgBhAHGiACIQEMAQsgASADIAMgAWsiASABQR91IgFqIAFzIgIQByACaiEBIBogAq0iHn0iHFANACACIANqIQIDQAJAIBwgHiAcIB5UGyIbQiBUBEAgGyEaDAELIBsiGkIgfSIgQgWIQgF8QgODIh9QRQRAA0AgASACKQAANwAAIAEgAikAGDcAGCABIAIpABA3ABAgASACKQAINwAIIBpCIH0hGiACQSBqIQIgAUEgaiEBIB9CAX0iH0IAUg0ACwsgIELgAFQNAANAIAEgAikAADcAACABIAIpABg3ABggASACKQAQNwAQIAEgAikACDcACCABIAIpADg3ADggASACKQAwNwAwIAEgAikAKDcAKCABIAIpACA3ACAgASACKQBYNwBYIAEgAikAUDcAUCABIAIpAEg3AEggASACKQBANwBAIAEgAikAYDcAYCABIAIpAGg3AGggASACKQBwNwBwIAEgAikAeDcAeCACQYABaiECIAFBgAFqIQEgGkKAAX0iGkIfVg0ACwsgGkIQWgRAIAEgAikAADcAACABIAIpAAg3AAggGkIQfSEaIAJBEGohAiABQRBqIQELIBpCCFoEQCABIAIpAAA3AAAgGkIIfSEaIAJBCGohAiABQQhqIQELIBpCBFoEQCABIAIoAAA2AAAgGkIEfSEaIAJBBGohAiABQQRqIQELIBpCAloEQCABIAIvAAA7AAAgGkICfSEaIAJBAmohAiABQQJqIQELIBwgG30hHCAaUEUEQCABIAItAAA6AAAgAkEBaiECIAFBAWohAQsgHEIAUg0ACwsgDiEGIAwhAwsgBSAGSwRAAkACQCABIANNIAEgDyABa6wiGiAGrSIbIBogG1QbIhqnIglqIgIgA0txDQAgAyAJaiABSyABIANPcQ0AIAEgAyAJEAcaDAELIAEgAyADIAFrIgEgAUEfdSIBaiABcyIBEAcgAWohAiAaIAGtIh59IhxQDQAgASADaiEBA0ACQCAcIB4gHCAeVBsiG0IgVARAIBshGgwBCyAbIhpCIH0iIEIFiEIBfEIDgyIfUEUEQANAIAIgASkAADcAACACIAEpABg3ABggAiABKQAQNwAQIAIgASkACDcACCAaQiB9IRogAUEgaiEBIAJBIGohAiAfQgF9Ih9CAFINAAsLICBC4ABUDQADQCACIAEpAAA3AAAgAiABKQAYNwAYIAIgASkAEDcAECACIAEpAAg3AAggAiABKQA4NwA4IAIgASkAMDcAMCACIAEpACg3ACggAiABKQAgNwAgIAIgASkAWDcAWCACIAEpAFA3AFAgAiABKQBINwBIIAIgASkAQDcAQCACIAEpAGA3AGAgAiABKQBoNwBoIAIgASkAcDcAcCACIAEpAHg3AHggAUGAAWohASACQYABaiECIBpCgAF9IhpCH1YNAAsLIBpCEFoEQCACIAEpAAA3AAAgAiABKQAINwAIIBpCEH0hGiACQRBqIQIgAUEQaiEBCyAaQghaBEAgAiABKQAANwAAIBpCCH0hGiACQQhqIQIgAUEIaiEBCyAaQgRaBEAgAiABKAAANgAAIBpCBH0hGiACQQRqIQIgAUEEaiEBCyAaQgJaBEAgAiABLwAAOwAAIBpCAn0hGiACQQJqIQIgAUECaiEBCyAcIBt9IRwgGlBFBEAgAiABLQAAOgAAIAJBAWohAiABQQFqIQELIBxCAFINAAsLIAUgBmshAUEAIARrIQUCQCAEQQdLBEAgBCEDDAELIAEgBE0EQCAEIQMMAQsgAiAEayEFA0ACQCACIAUpAAA3AAAgBEEBdCEDIAEgBGshASACIARqIQIgBEEDSw0AIAMhBCABIANLDQELC0EAIANrIQULIAIgBWohBAJAIAUgDyACa6wiGiABrSIbIBogG1QbIhqnIgFIIAVBf0pxDQAgBUEBSCABIARqIAJLcQ0AIAIgBCABEAcgAWohAgwDCyACIAQgAyADQR91IgFqIAFzIgEQByABaiECIBogAa0iHn0iHFANAiABIARqIQEDQAJAIBwgHiAcIB5UGyIbQiBUBEAgGyEaDAELIBsiGkIgfSIgQgWIQgF8QgODIh9QRQRAA0AgAiABKQAANwAAIAIgASkAGDcAGCACIAEpABA3ABAgAiABKQAINwAIIBpCIH0hGiABQSBqIQEgAkEgaiECIB9CAX0iH0IAUg0ACwsgIELgAFQNAANAIAIgASkAADcAACACIAEpABg3ABggAiABKQAQNwAQIAIgASkACDcACCACIAEpADg3ADggAiABKQAwNwAwIAIgASkAKDcAKCACIAEpACA3ACAgAiABKQBYNwBYIAIgASkAUDcAUCACIAEpAEg3AEggAiABKQBANwBAIAIgASkAYDcAYCACIAEpAGg3AGggAiABKQBwNwBwIAIgASkAeDcAeCABQYABaiEBIAJBgAFqIQIgGkKAAX0iGkIfVg0ACwsgGkIQWgRAIAIgASkAADcAACACIAEpAAg3AAggGkIQfSEaIAJBEGohAiABQRBqIQELIBpCCFoEQCACIAEpAAA3AAAgGkIIfSEaIAJBCGohAiABQQhqIQELIBpCBFoEQCACIAEoAAA2AAAgGkIEfSEaIAJBBGohAiABQQRqIQELIBpCAloEQCACIAEvAAA7AAAgGkICfSEaIAJBAmohAiABQQJqIQELIBwgG30hHCAaUEUEQCACIAEtAAA6AAAgAkEBaiECIAFBAWohAQsgHFBFDQALDAILAkAgASADTSABIA8gAWusIhogBa0iGyAaIBtUGyIapyIEaiICIANLcQ0AIAMgBGogAUsgASADT3ENACABIAMgBBAHGgwCCyABIAMgAyABayIBIAFBH3UiAWogAXMiARAHIAFqIQIgGiABrSIefSIcUA0BIAEgA2ohAQNAAkAgHCAeIBwgHlQbIhtCIFQEQCAbIRoMAQsgGyIaQiB9IiBCBYhCAXxCA4MiH1BFBEADQCACIAEpAAA3AAAgAiABKQAYNwAYIAIgASkAEDcAECACIAEpAAg3AAggGkIgfSEaIAFBIGohASACQSBqIQIgH0IBfSIfQgBSDQALCyAgQuAAVA0AA0AgAiABKQAANwAAIAIgASkAGDcAGCACIAEpABA3ABAgAiABKQAINwAIIAIgASkAODcAOCACIAEpADA3ADAgAiABKQAoNwAoIAIgASkAIDcAICACIAEpAFg3AFggAiABKQBQNwBQIAIgASkASDcASCACIAEpAEA3AEAgAiABKQBgNwBgIAIgASkAaDcAaCACIAEpAHA3AHAgAiABKQB4NwB4IAFBgAFqIQEgAkGAAWohAiAaQoABfSIaQh9WDQALCyAaQhBaBEAgAiABKQAANwAAIAIgASkACDcACCAaQhB9IRogAkEQaiECIAFBEGohAQsgGkIIWgRAIAIgASkAADcAACAaQgh9IRogAkEIaiECIAFBCGohAQsgGkIEWgRAIAIgASgAADYAACAaQgR9IRogAkEEaiECIAFBBGohAQsgGkICWgRAIAIgAS8AADsAACAaQgJ9IRogAkECaiECIAFBAmohAQsgHCAbfSEcIBpQRQRAIAIgAS0AADoAACACQQFqIQIgAUEBaiEBCyAcUEUNAAsMAQsCQAJAIBYEQAJAIAQgBUkEQCAHKAKYRyAESw0BCyABIARrIQMCQEEAIARrIgVBf0ogDyABa6wiGiAbIBogG1QbIhqnIgIgBUpxDQAgBUEBSCACIANqIAFLcQ0AIAEgAyACEAcgAmohAgwFCyABIAMgBCAEQR91IgFqIAFzIgEQByABaiECIBogAa0iHn0iHFANBCABIANqIQEDQAJAIBwgHiAcIB5UGyIbQiBUBEAgGyEaDAELIBsiGkIgfSIgQgWIQgF8QgODIh9QRQRAA0AgAiABKQAANwAAIAIgASkAGDcAGCACIAEpABA3ABAgAiABKQAINwAIIBpCIH0hGiABQSBqIQEgAkEgaiECIB9CAX0iH0IAUg0ACwsgIELgAFQNAANAIAIgASkAADcAACACIAEpABg3ABggAiABKQAQNwAQIAIgASkACDcACCACIAEpADg3ADggAiABKQAwNwAwIAIgASkAKDcAKCACIAEpACA3ACAgAiABKQBYNwBYIAIgASkAUDcAUCACIAEpAEg3AEggAiABKQBANwBAIAIgASkAYDcAYCACIAEpAGg3AGggAiABKQBwNwBwIAIgASkAeDcAeCABQYABaiEBIAJBgAFqIQIgGkKAAX0iGkIfVg0ACwsgGkIQWgRAIAIgASkAADcAACACIAEpAAg3AAggGkIQfSEaIAJBEGohAiABQRBqIQELIBpCCFoEQCACIAEpAAA3AAAgGkIIfSEaIAJBCGohAiABQQhqIQELIBpCBFoEQCACIAEoAAA2AAAgGkIEfSEaIAJBBGohAiABQQRqIQELIBpCAloEQCACIAEvAAA7AAAgGkICfSEaIAJBAmohAiABQQJqIQELIBwgG30hHCAaUEUEQCACIAEtAAA6AAAgAkEBaiECIAFBAWohAQsgHFBFDQALDAQLIBAgAWsiCUEBaiIGIAUgBSAGSxshAyABIARrIQIgAUEHcUUNAiADRQ0CIAEgAi0AADoAACACQQFqIQIgAUEBaiIGQQdxQQAgA0EBayIFGw0BIAYhASAFIQMgCSEGDAILAkAgBCAFSQRAIAcoAphHIARLDQELIAEgASAEayIGKQAANwAAIAEgBUEBa0EHcUEBaiIDaiECIAUgA2siBEUNAyADIAZqIQEDQCACIAEpAAA3AAAgAUEIaiEBIAJBCGohAiAEQQhrIgQNAAsMAwsgASAEIAUQPyECDAILIAEgAi0AADoAASAJQQFrIQYgA0ECayEFIAJBAWohAgJAIAFBAmoiCkEHcUUNACAFRQ0AIAEgAi0AADoAAiAJQQJrIQYgA0EDayEFIAJBAWohAgJAIAFBA2oiCkEHcUUNACAFRQ0AIAEgAi0AADoAAyAJQQNrIQYgA0EEayEFIAJBAWohAgJAIAFBBGoiCkEHcUUNACAFRQ0AIAEgAi0AADoABCAJQQRrIQYgA0EFayEFIAJBAWohAgJAIAFBBWoiCkEHcUUNACAFRQ0AIAEgAi0AADoABSAJQQVrIQYgA0EGayEFIAJBAWohAgJAIAFBBmoiCkEHcUUNACAFRQ0AIAEgAi0AADoABiAJQQZrIQYgA0EHayEFIAJBAWohAgJAIAFBB2oiCkEHcUUNACAFRQ0AIAEgAi0AADoAByAJQQdrIQYgA0EIayEDIAFBCGohASACQQFqIQIMBgsgCiEBIAUhAwwFCyAKIQEgBSEDDAQLIAohASAFIQMMAwsgCiEBIAUhAwwCCyAKIQEgBSEDDAELIAohASAFIQMLAkACQCAGQRdNBEAgA0UNASADQQFrIQUgA0EHcSIEBEADQCABIAItAAA6AAAgA0EBayEDIAFBAWohASACQQFqIQIgBEEBayIEDQALCyAFQQdJDQEDQCABIAItAAA6AAAgASACLQABOgABIAEgAi0AAjoAAiABIAItAAM6AAMgASACLQAEOgAEIAEgAi0ABToABSABIAItAAY6AAYgASACLQAHOgAHIAFBCGohASACQQhqIQIgA0EIayIDDQALDAELIAMNAQsgASECDAELIAEgBCADED8hAgsgCyEFDAELIAEgAy0AAjoAACABQQFqIQILIAUgFE8NACACIBNJDQELCyAAIAI2AgwgACAFIAhBA3ZrIgE2AgAgACATIAJrQYMCajYCECAAIBQgAWtBDmo2AgQgByAIQQdxIgA2AogBIAcgHUJ/IACthkJ/hYM+AoQBC+cFAQR/IAMgAiACIANLGyEEIAAgAWshAgJAIABBB3FFDQAgBEUNACAAIAItAAA6AAAgA0EBayEGIAJBAWohAiAAQQFqIgdBB3FBACAEQQFrIgUbRQRAIAchACAFIQQgBiEDDAELIAAgAi0AADoAASADQQJrIQYgBEECayEFIAJBAWohAgJAIABBAmoiB0EHcUUNACAFRQ0AIAAgAi0AADoAAiADQQNrIQYgBEEDayEFIAJBAWohAgJAIABBA2oiB0EHcUUNACAFRQ0AIAAgAi0AADoAAyADQQRrIQYgBEEEayEFIAJBAWohAgJAIABBBGoiB0EHcUUNACAFRQ0AIAAgAi0AADoABCADQQVrIQYgBEEFayEFIAJBAWohAgJAIABBBWoiB0EHcUUNACAFRQ0AIAAgAi0AADoABSADQQZrIQYgBEEGayEFIAJBAWohAgJAIABBBmoiB0EHcUUNACAFRQ0AIAAgAi0AADoABiADQQdrIQYgBEEHayEFIAJBAWohAgJAIABBB2oiB0EHcUUNACAFRQ0AIAAgAi0AADoAByADQQhrIQMgBEEIayEEIABBCGohACACQQFqIQIMBgsgByEAIAUhBCAGIQMMBQsgByEAIAUhBCAGIQMMBAsgByEAIAUhBCAGIQMMAwsgByEAIAUhBCAGIQMMAgsgByEAIAUhBCAGIQMMAQsgByEAIAUhBCAGIQMLAkAgA0EXTQRAIARFDQEgBEEBayEBIARBB3EiAwRAA0AgACACLQAAOgAAIARBAWshBCAAQQFqIQAgAkEBaiECIANBAWsi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CyAAIAMtAAAEfiADKQMQBUIAC6dB//8DcSADKAIEEEcLIQUgAxAICyAEQRBqJAAgBQvgAQICfwF+QTAQCSICRQRAIAEEQCABQQA2AgQgAUEONgIAC0EADwsgAkIANwMIIAJBADYCACACQgA3AxAgAkIANwMYIAJCADcDICACQgA3ACUgAFAEQCACDwsCQCAAQv////8AVg0AIACnQQR0EAkiA0UNACACIAM2AgBBACEBQgEhBANAIAMgAUEEdGoiAUIANwIAIAFCADcABSAAIARSBEAgBKchASAEQgF8IQQMAQsLIAIgADcDCCACIAA3AxAgAg8LIAEEQCABQQA2AgQgAUEONgIAC0EAEBAgAhAGQQAL7gECA38BfiMAQRBrIgQkAAJAIARBDGpCBBAXIgNFBEBBfyECDAELAkAgAQRAIAJBgAZxIQUDQAJAIAUgASgCBHFFDQACQCADKQMIQgBUBEAgA0EAOgAADAELIANCADcDECADQQE6AAALIAMgAS8BCBANIAMgAS8BChANIAMtAABFBEAgAEEIaiIABEAgAEEANgIEIABBFDYCAAtBfyECDAQLQX8hAiAAIARBDGpCBBAbQQBIDQMgATMBCiIGUA0AIAAgASgCDCAGEBtBAEgNAwsgASgCACIBDQALC0EAIQILIAMQCAsgBEEQaiQAIAILPAEBfyAABEAgAUGABnEhAQNAIAEgACgCBHEEQCACIAAvAQpqQQRqIQILIAAoAgAiAA0ACwsgAkH//wNxC5wBAQN/IABFBEBBAA8LIAAhAwNAAn8CQAJAIAAvAQgiAUH04AFNBEAgAUEBRg0BIAFB9cYBRg0BDAILIAFBgbICRg0AIAFB9eABRw0BCyAAKAIAIQEgAEEANgIAIAAoAgwQBiAAEAYgASADIAAgA0YbIQMCQCACRQRAQQAhAgwBCyACIAE2AgALIAEMAQsgACICKAIACyIADQALIAMLsgQCBX8BfgJAAkACQCAAIAGtEBciAQRAIAEtAAANAUEAIQAMAgsgBARAIARBADYCBCAEQQ42AgALQQAPC0EAIQADQCABLQAABH4gASkDCCABKQMQfQVCAAtCBFQNASABEAwhByABIAEQDCIGrRATIghFBEBBACECIAQEQCAEQQA2AgQgBEEVNgIACyABEAggAEUNAwNAIAAoAgAhASAAKAIMEAYg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DCAAQRg2AggLDAMLIAAgBiAFLwFqQQAgBCABEQYAIQEgBhALIAFFDQILAkAgDUUEQCABIQMMAQsgACABIAUvAWgQgQEhAyABEAsgA0UNAQsCQCAJRSAMckUEQCADIQEMAQsgACADQQEQgAEhASADEAsgAUUNAQsgASEDDAELQQAhAwsgBUHwAGokACADC4UBAQF/IAFFBEAgAEEIaiIABEAgAEEANgIEIABBEjYCAAtBAA8LQTgQCSIDRQRAIABBCGoiAARAIABBADYCBCAAQQ42AgALQQAPCyADQQA2AhAgA0IANwIIIANCADcDKCADQQA2AgQgAyACNgIAIANCADcDGCADQQA2AjAgACABQTsgAxBCCw8AIAAgASACQQBBABCCAQusAgECfyABRQRAIABBCGoiAARAIABBADYCBCAAQRI2AgALQQAPCwJAIAJBfUsNACACQf//A3FBCEYNACAAQQhqIgAEQCAAQQA2AgQgAEEQNgIAC0EADwsCQEGwwAAQCSIFBEAgBUEANgIIIAVCADcCACAFQYiBAUGogQEgAxs2AqhAIAUgAjYCFCAFIAM6ABAgBUEAOgAPIAVBADsBDCAFIAMgAkF9SyIGcToADiAFQQggAiAGG0H//wNxIAQgBUGIgQFBqIEBIAMbKAIAEQAAIgI2AqxAIAINASAFEDEgBRAGCyAAQQhqIgAEQCAAQQA2AgQgAEEONgIAC0EADwsgACABQTogBRBCIgAEfyAABSAFKAKsQCAFKAKoQCgCBBEDACAFEDEgBRAGQQALC6ABAQF/IAIgACgCBCIDIAIgA0kbIgIEQCAAIAMgAms2AgQCQAJAAkACQCAAKAIcIgMoAhRBAWsOAgEAAgsgA0GgAWogASAAKAIAIAJB3IABKAIAEQgADAILIAAgACgCMCABIAAoAgAgAkHEgAEoAgARBAA2AjAMAQsgASAAKAIAIAIQBxoLIAAgACgCACACajYCACAAIAAoAgggAmo2AggLC7cCAQR/QX4hAgJAIABFDQAgACgCIEUNACAAKAIkIgRFDQAgACgCHCIBRQ0AIAEoAgAgAEcNAAJAAkAgASgCICIDQTlrDjkBAgICAgICAgICAgIBAgICAQICAgICAgICAgICAgICAgICAQICAgICAgICAgICAQICAgICAgICAgEACyADQZoFRg0AIANBKkcN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DCABajYCDCAGIAYoAgggAWo2AgggBSAFKAIUIAFqNgIUIAUgBSgCECABazYCECAGIAYoAhAgAWsiATYCECABDQAgBiAGKAIENgIIC0EAIQRBACEJIAMoAhBFDQAMCgsgAygCHCgCJCEGIAMgAygCGCIBQQFqNgIYIAEgBmotAAAhASADIARBAWo2AhAgAygCBCAEaiABOgAAIAEEQCADKAIQIQQMAQsLIAMoAhwoAixFDQAgAygCECIGIAlNDQAgBQJ/IAUoAjAhBEEAIAMoAgQgCWoiAUUNABogBCABIAYgCWtB1IABKAIAEQAACzYCMAsgA0HnADYCIAsCQCADKAIcKAIsBEAgAygCDCADKAIQIgFBAmpJBH8gBRAKIAMoAhANAkEABSABCyADKAIEaiAFKAIwOwAAIAMgAygCEEECajYCECADQaABakHkgAEoAgARAQAaCyADQfEANgIgIAUQCiADKAIQRQ0BDAcLDAYLIAUoAgQNAQsgAygCPA0AIApFDQEgAygCIEGaBUYNAQsCfyADKAKIASIBRQRAIAMgChCFAQwBCwJAAkACQCADKAKMAUECaw4CAAECCwJ/AkADQAJAAkAgAygCPA0AIAMQLyADKAI8DQAgCg0BQQAMBAsgAygCSCADKAJoai0AACEEIAMgAygC8C0iAUEBajYC8C0gASADKALsLWpBADoAACADIAMoAvAtIgFBAWo2AvAtIAEgAygC7C1qQQA6AAAgAyADKALwLSIBQQFqNgLwLSABIAMoAuwtaiAEOgAAIAMgBEECdGoiASABLwHkAUEBajsB5AEgAyADKAI8QQFrNgI8IAMgAygCaEEBaiIBNgJoIAMoAvAtIAMoAvQtRw0BQQAhBCADIAMoAlgiBkEATgR/IAMoAkggBmoFQQALIAEgBmtBABAPIAMgAygCaDYCWCADKAIAEAogAygCACgCEA0BDAILCyADQQA2AoQuIApBBEYEQCADIAMoAlgiAUEATgR/IAMoAkggAWoFQQALIAMoAmggAWtBARAPIAMgAygCaDYCWCADKAIAEApBA0ECIAMoAgAoAhAbDAILIAMoAvAtBEBBACEEIAMgAygCWCIBQQBOBH8gAygCSCABagVBAAsgAygCaCABa0EAEA8gAyADKAJoNgJYIAMoAgAQCiADKAIAKAIQRQ0BC0EBIQQLIAQL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bGl0ZXJhbC9sZW5ndGhzIHNldABpbnZhbGlkIGNvZGUgbGVuZ3RocyBzZXQAdW5rbm93biBoZWFkZXIgZmxhZ3Mgc2V0AGludmFsaWQgZGlzdGFuY2VzIHNldABpbnZhbGlkIGJpdCBsZW5ndGggcmVwZWF0AEZpbGUgYWxyZWFkeSBleGlzdHMAdG9vIG1hbnkgbGVuZ3RoIG9yIGRpc3RhbmNlIHN5bWJvbHMAaW52YWxpZCBzdG9yZWQgYmxvY2sgbGVuZ3RocwAlcyVzJXMAYnVmZmVyIGVycm9yAE5vIGVycm9yAHN0cmVhbSBlcnJvcgBUZWxsIGVycm9yAEludGVybmFsIGVycm9yAFNlZWsgZXJyb3IAV3JpdGUgZXJyb3IAZmlsZSBlcnJvcgBSZWFkIGVycm9yAFpsaWIgZXJyb3IAZGF0YSBlcnJvcgBDUkMgZXJyb3IAaW5jb21wYXRpYmxlIHZlcnNpb24AaW52YWxpZCBjb2RlIC0tIG1pc3NpbmcgZW5kLW9mLWJsb2NrAGluY29ycmVjdCBoZWFkZXIgY2hlY2sAaW5jb3JyZWN0IGxlbmd0aCBjaGVjawBpbmNvcnJlY3QgZGF0YSBjaGVjawBpbnZhbGlkIGRpc3RhbmNlIHRvbyBmYXIgYmFjawBoZWFkZXIgY3JjIG1pc21hdGNoADEuMi4xMy56bGliLW5nAGludmFsaWQgd2luZG93IHNpemUAUmVhZC1vbmx5IGFyY2hpdmUATm90IGEgemlwIGFyY2hpdmUAUmVzb3VyY2Ugc3RpbGwgaW4gdXNlAE1hbGxvYyBmYWlsdXJlAGludmFsaWQgYmxvY2sgdHlwZQBGYWlsdXJlIHRvIGNyZWF0ZSB0ZW1wb3JhcnkgZmlsZQBDYW4ndCBvcGVuIGZpbGUATm8gc3VjaCBmaWxlAFByZW1hdHVyZSBlbmQgb2YgZmlsZQBDYW4ndCByZW1vdmUgZmlsZQBpbnZhbGlkIGxpdGVyYWwvbGVuZ3RoIGNvZGUAaW52YWxpZCBkaXN0YW5jZSBjb2RlAHVua25vd24gY29tcHJlc3Npb24gbWV0aG9kAHN0cmVhbSBlbmQAQ29tcHJlc3NlZCBkYXRhIGludmFsaWQATXVsdGktZGlzayB6aXAgYXJjaGl2ZXMgbm90IHN1cHBvcnRl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UgAIANIACAAyAAgAsgAIAHIACADyAAgACgAIAIoACABKAAgAygAIACoACACqAAgAagAIAOoACAAaAAgAmgAIAFoACADaAAgAOgAIALoACAB6AAgA+gAIAAYACACGAAgARgAIAMYACAAmAAgApgAIAGYACADmAAgAFgAIAJYACABWAAgA1gAIADYACAC2AAgAdgAIAPYACAAOAAgAjgAIAE4ACADOAAgALgAIAK4ACABuAAgA7gAIAB4ACACeAAgAXgAIAN4ACAA+AAgAvgAIAH4ACAD+AAgAAQAIAIEACABBAAgAwQAIACEACAChAAgAYQAIAOEACAARAAgAkQAIAFEACADRAAgAMQAIALEACABxAAgA8QAIAAkACACJAAgASQAIAMkACAApAAgAqQAIAGkACADpAAgAGQAIAJkACABZAAgA2QAIADkACAC5AAgAeQAIAPkACAAFAAgAhQAIAEUACADFAAgAJQAIAKUACABlAAgA5QAIABUACACVAAgAVQAIANUACAA1AAgAtQAIAHUACAD1AAgADQAIAI0ACABNAAgAzQAIAC0ACACtAAgAbQAIAO0ACAAdAAgAnQAIAF0ACADdAAgAPQAIAL0ACAB9AAgA/QAIABMACQATAQkAkwAJAJMBCQBTAAkAUwEJANMACQDTAQkAMwAJADMBCQCzAAkAswEJAHMACQBzAQkA8wAJAPMBCQALAAkACwEJAIsACQCLAQkASwAJAEsBCQDLAAkAywEJACsACQArAQkAqwAJAKsBCQBrAAkAawEJAOsACQDrAQkAGwAJABsBCQCbAAkAmwEJAFsACQBbAQkA2wAJANsBCQA7AAkAOwEJALsACQC7AQkAewAJAHsBCQD7AAkA+wEJAAcACQAHAQkAhwAJAIcBCQBHAAkARwEJAMcACQDHAQkAJwAJACcBCQCnAAkApwEJAGcACQBnAQkA5wAJAOcBCQAXAAkAFwEJAJcACQCXAQkAVwAJAFcBCQDXAAkA1wEJADcACQA3AQkAtwAJALcBCQB3AAkAdwEJAPcACQD3AQkADwAJAA8BCQCPAAkAjwEJAE8ACQBPAQkAzwAJAM8BCQAvAAkALwEJAK8ACQCvAQkAbwAJAG8BCQDvAAkA7wEJAB8ACQAfAQkAnwAJAJ8BCQBfAAkAXwEJAN8ACQDfAQkAPwAJAD8BCQC/AAkA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SXMgYSBkaXJlY3RvcnkAVGV4dCBmaWxlIGJ1c3kARXhlYyBmb3JtYXQgZXJyb3IASW52YWxpZCBhcmd1bWVudABBcmd1bWVudCBsaXN0IHRvbyBsb25nAFN5bWJvbGljIGxpbmsgbG9vcABGaWxlbmFtZSB0b28gbG9uZwBUb28gbWFueSBvcGVuIGZpbGVzIGluIHN5c3RlbQBObyBmaWxlIGRlc2NyaXB0b3JzIGF2YWlsYWJsZQBCYWQgZmlsZSBkZXNjcmlwdG9yAE5vIGNoaWxkIHByb2Nlc3MAQmFkIGFkZHJlc3MARmlsZSB0b28gbGFyZ2UAVG9vIG1hbnkgbGlua3MATm8gbG9ja3MgYXZhaWxhYmxlAFJlc291cmNlIGRlYWRsb2NrIHdvdWxkIG9jY3VyAFN0YXRlIG5vdCByZWNvdmVyYWJsZQBQcmV2aW91cyBvd25lciBkaWVkAE9wZXJhdGlvbiBjYW5jZWxlZABGdW5jdGlvbiBub3QgaW1wbGVtZW50ZWQATm8gbWVzc2FnZSBvZiBkZXNpcmVkIHR5cGUASWRlbnRpZmllciByZW1vdmVkAERldmljZSBub3QgYSBzdHJlYW0ATm8gZGF0YSBhdmFpbGFibGUARGV2aWNlIHRpbWVvdXQAT3V0IG9mIHN0cmVhbXMgcmVzb3VyY2VzAExpbmsgaGFzIGJlZW4gc2V2ZXJlZABQcm90b2NvbCBlcnJvcgBCYWQgbWVzc2FnZQBGaWxlIGRlc2NyaXB0b3IgaW4gYmFkIHN0YXRlAE5vdCBhIHNvY2tldABEZXN0aW5hdGlvbiBhZGRyZXNzIHJlcXVpcmVkAE1lc3NhZ2UgdG9vIGxhcmdlAFByb3RvY29sIHdyb25nIHR5cGUgZm9yIHNvY2tldABQcm90b2NvbCBub3QgYXZhaWxhYmxlAFByb3RvY29sIG5vdCBzdXBwb3J0ZWQAU29ja2V0IHR5cGUgbm90IHN1cHBvcnRlZABOb3Qgc3VwcG9ydGVkAFByb3RvY29sIGZhbWlseSBub3Qgc3VwcG9ydGVkAEFkZHJlc3MgZmFtaWx5IG5vdCBzdXBwb3J0ZWQgYnkgcHJvdG9jb2wAQWRkcmVzcyBub3QgYXZhaWxhYmxlAE5ldHdvcmsgaXMgZG93bgBOZXR3b3JrIHVucmVhY2hhYmxlAENvbm5lY3Rpb24gcmVzZXQgYnkgbmV0d29yawBDb25uZWN0aW9uIGFib3J0ZWQATm8gYnVmZmVyIHNwYWNlIGF2YWlsYWJsZQBTb2NrZXQgaXMgY29ubmVjdGVkAFNvY2tldCBub3QgY29ubmVjdGVkAENhbm5vdCBzZW5kIGFmdGVyIHNvY2tldCBzaHV0ZG93bgBPcGVyYXRpb24gYWxyZWFkeSBpbiBwcm9ncmVzcwBPcGVyYXRpb24gaW4gcHJvZ3Jlc3MAU3RhbGUgZmlsZSBoYW5kbGUAUmVtb3RlIEkvTyBlcnJvcgBRdW90YSBleGNlZWRlZABObyBtZWRpdW0gZm91bmQAV3JvbmcgbWVkaXVtIHR5cGUATm8gZXJyb3IgaW5mb3JtYXRpb24AQcCAAQuFARMAAAAUAAAAFQAAABYAAAAXAAAAGAAAABkAAAAaAAAAGwAAABwAAAAdAAAAHgAAAB8AAAAgAAAAIQAAACIAAAAjAAAAgERQADEAAAAyAAAAMwAAADQAAAA1AAAANgAAADcAAAA4AAAAOQAAADIAAAAzAAAANAAAADUAAAA2AAAANwAAADgAQfSCAQsCXEQAQbCDAQsQ/////////////////////w=="; - if (!isDataURI(wasmBinaryFile)) { - wasmBinaryFile = locateFile(wasmBinaryFile); - } - function getBinary(file) { - try { - if (file == wasmBinaryFile && wasmBinary) { - return new Uint8Array(wasmBinary); - } - var binary = tryParseAsDataURI(file); - if (binary) { - return binary; - } - if (readBinary) { - return readBinary(file); - } else { - throw "sync fetching of the wasm failed: you can preload it to Module['wasmBinary'] manually, or emcc.py will do that for you when generating HTML (but not JS)"; - } - } catch (err2) { - abort(err2); - } - } - function instantiateSync(file, info) { - var instance; - var module2; - var binary; - try { - binary = getBinary(file); - module2 = new WebAssembly.Module(binary); - instance = new WebAssembly.Instance(module2, info); - } catch (e) { - var str = e.toString(); - err("failed to compile wasm module: " + str); - if (str.includes("imported Memory") || str.includes("memory import")) { - err( - "Memory size incompatibility issues may be due to changing INITIAL_MEMORY at runtime to something too large. Use ALLOW_MEMORY_GROWTH to allow any size memory (and also make sure not to set INITIAL_MEMORY at runtime to something smaller than it was at compile time)." - ); - } - throw e; - } - return [instance, module2]; - } - function createWasm() { - var info = { a: asmLibraryArg }; - function receiveInstance(instance, module2) { - var exports3 = instance.exports; - Module["asm"] = exports3; - wasmMemory = Module["asm"]["g"]; - updateGlobalBufferAndViews(wasmMemory.buffer); - wasmTable = Module["asm"]["W"]; - addOnInit(Module["asm"]["h"]); - removeRunDependency(); - } - addRunDependency(); - if (Module["instantiateWasm"]) { - try { - var exports2 = Module["instantiateWasm"](info, receiveInstance); - return exports2; - } catch (e) { - err("Module.instantiateWasm callback failed with error: " + e); - return false; - } - } - var result = instantiateSync(wasmBinaryFile, info); - receiveInstance(result[0]); - return Module["asm"]; - } - function LE_HEAP_LOAD_F32(byteOffset) { - return HEAP_DATA_VIEW.getFloat32(byteOffset, true); - } - function LE_HEAP_LOAD_F64(byteOffset) { - return HEAP_DATA_VIEW.getFloat64(byteOffset, true); - } - function LE_HEAP_LOAD_I16(byteOffset) { - return HEAP_DATA_VIEW.getInt16(byteOffset, true); - } - function LE_HEAP_LOAD_I32(byteOffset) { - return HEAP_DATA_VIEW.getInt32(byteOffset, true); - } - function LE_HEAP_STORE_I32(byteOffset, value) { - HEAP_DATA_VIEW.setInt32(byteOffset, value, true); - } - function callRuntimeCallbacks(callbacks) { - while (callbacks.length > 0) { - var callback = callbacks.shift(); - if (typeof callback == "function") { - callback(Module); - continue; - } - var func = callback.func; - if (typeof func === "number") { - if (callback.arg === void 0) { - wasmTable.get(func)(); - } else { - wasmTable.get(func)(callback.arg); - } - } else { - func(callback.arg === void 0 ? null : callback.arg); - } - } - } - function _gmtime_r(time, tmPtr) { - var date = new Date(LE_HEAP_LOAD_I32((time >> 2) * 4) * 1e3); - LE_HEAP_STORE_I32((tmPtr >> 2) * 4, date.getUTCSeconds()); - LE_HEAP_STORE_I32((tmPtr + 4 >> 2) * 4, date.getUTCMinutes()); - LE_HEAP_STORE_I32((tmPtr + 8 >> 2) * 4, date.getUTCHours()); - LE_HEAP_STORE_I32((tmPtr + 12 >> 2) * 4, date.getUTCDate()); - LE_HEAP_STORE_I32((tmPtr + 16 >> 2) * 4, date.getUTCMonth()); - LE_HEAP_STORE_I32((tmPtr + 20 >> 2) * 4, date.getUTCFullYear() - 1900); - LE_HEAP_STORE_I32((tmPtr + 24 >> 2) * 4, date.getUTCDay()); - LE_HEAP_STORE_I32((tmPtr + 36 >> 2) * 4, 0); - LE_HEAP_STORE_I32((tmPtr + 32 >> 2) * 4, 0); - var start = Date.UTC(date.getUTCFullYear(), 0, 1, 0, 0, 0, 0); - var yday = (date.getTime() - start) / (1e3 * 60 * 60 * 24) | 0; - LE_HEAP_STORE_I32((tmPtr + 28 >> 2) * 4, yday); - if (!_gmtime_r.GMTString) _gmtime_r.GMTString = allocateUTF8("GMT"); - LE_HEAP_STORE_I32((tmPtr + 40 >> 2) * 4, _gmtime_r.GMTString); - return tmPtr; - } - function ___gmtime_r(a0, a1) { - return _gmtime_r(a0, a1); - } - function _emscripten_memcpy_big(dest, src, num) { - HEAPU8.copyWithin(dest, src, src + num); - } - function emscripten_realloc_buffer(size) { - try { - wasmMemory.grow(size - buffer.byteLength + 65535 >>> 16); - updateGlobalBufferAndViews(wasmMemory.buffer); - return 1; - } catch (e) { - } - } - function _emscripten_resize_heap(requestedSize) { - var oldSize = HEAPU8.length; - requestedSize = requestedSize >>> 0; - var maxHeapSize = 2147483648; - if (requestedSize > maxHeapSize) { - return false; - } - for (var cutDown = 1; cutDown <= 4; cutDown *= 2) { - var overGrownHeapSize = oldSize * (1 + 0.2 / cutDown); - overGrownHeapSize = Math.min( - overGrownHeapSize, - requestedSize + 100663296 - ); - var newSize = Math.min( - maxHeapSize, - alignUp(Math.max(requestedSize, overGrownHeapSize), 65536) - ); - var replacement = emscripten_realloc_buffer(newSize); - if (replacement) { - return true; - } - } - return false; - } - function _setTempRet0(val) { - } - function _time(ptr) { - var ret = Date.now() / 1e3 | 0; - if (ptr) { - LE_HEAP_STORE_I32((ptr >> 2) * 4, ret); - } - return ret; - } - function _tzset() { - if (_tzset.called) return; - _tzset.called = true; - var currentYear = (/* @__PURE__ */ new Date()).getFullYear(); - var winter = new Date(currentYear, 0, 1); - var summer = new Date(currentYear, 6, 1); - var winterOffset = winter.getTimezoneOffset(); - var summerOffset = summer.getTimezoneOffset(); - var stdTimezoneOffset = Math.max(winterOffset, summerOffset); - LE_HEAP_STORE_I32((__get_timezone() >> 2) * 4, stdTimezoneOffset * 60); - LE_HEAP_STORE_I32( - (__get_daylight() >> 2) * 4, - Number(winterOffset != summerOffset) - ); - function extractZone(date) { - var match = date.toTimeString().match(/\(([A-Za-z ]+)\)$/); - return match ? match[1] : "GMT"; - } - var winterName = extractZone(winter); - var summerName = extractZone(summer); - var winterNamePtr = allocateUTF8(winterName); - var summerNamePtr = allocateUTF8(summerName); - if (summerOffset < winterOffset) { - LE_HEAP_STORE_I32((__get_tzname() >> 2) * 4, winterNamePtr); - LE_HEAP_STORE_I32((__get_tzname() + 4 >> 2) * 4, summerNamePtr); - } else { - LE_HEAP_STORE_I32((__get_tzname() >> 2) * 4, summerNamePtr); - LE_HEAP_STORE_I32((__get_tzname() + 4 >> 2) * 4, winterNamePtr); - } - } - function _timegm(tmPtr) { - _tzset(); - var time = Date.UTC( - LE_HEAP_LOAD_I32((tmPtr + 20 >> 2) * 4) + 1900, - LE_HEAP_LOAD_I32((tmPtr + 16 >> 2) * 4), - LE_HEAP_LOAD_I32((tmPtr + 12 >> 2) * 4), - LE_HEAP_LOAD_I32((tmPtr + 8 >> 2) * 4), - LE_HEAP_LOAD_I32((tmPtr + 4 >> 2) * 4), - LE_HEAP_LOAD_I32((tmPtr >> 2) * 4), - 0 - ); - var date = new Date(time); - LE_HEAP_STORE_I32((tmPtr + 24 >> 2) * 4, date.getUTCDay()); - var start = Date.UTC(date.getUTCFullYear(), 0, 1, 0, 0, 0, 0); - var yday = (date.getTime() - start) / (1e3 * 60 * 60 * 24) | 0; - LE_HEAP_STORE_I32((tmPtr + 28 >> 2) * 4, yday); - return date.getTime() / 1e3 | 0; - } - function intArrayFromBase64(s) { - { - var buf; - try { - buf = Buffer.from(s, "base64"); - } catch (_) { - buf = new Buffer(s, "base64"); - } - return new Uint8Array( - buf["buffer"], - buf["byteOffset"], - buf["byteLength"] - ); - } - } - function tryParseAsDataURI(filename) { - if (!isDataURI(filename)) { - return; - } - return intArrayFromBase64(filename.slice(dataURIPrefix.length)); - } - var asmLibraryArg = { - e: ___gmtime_r, - c: _emscripten_memcpy_big, - d: _emscripten_resize_heap, - a: _setTempRet0, - b: _time, - f: _timegm - }; - var asm = createWasm(); - Module["___wasm_call_ctors"] = asm["h"]; - Module["_zip_ext_count_symlinks"] = asm["i"]; - Module["_zip_file_get_external_attributes"] = asm["j"]; - Module["_zipstruct_statS"] = asm["k"]; - Module["_zipstruct_stat_size"] = asm["l"]; - Module["_zipstruct_stat_mtime"] = asm["m"]; - Module["_zipstruct_stat_crc"] = asm["n"]; - Module["_zipstruct_errorS"] = asm["o"]; - Module["_zipstruct_error_code_zip"] = asm["p"]; - Module["_zipstruct_stat_comp_size"] = asm["q"]; - Module["_zipstruct_stat_comp_method"] = asm["r"]; - Module["_zip_close"] = asm["s"]; - Module["_zip_delete"] = asm["t"]; - Module["_zip_dir_add"] = asm["u"]; - Module["_zip_discard"] = asm["v"]; - Module["_zip_error_init_with_code"] = asm["w"]; - Module["_zip_get_error"] = asm["x"]; - Module["_zip_file_get_error"] = asm["y"]; - Module["_zip_error_strerror"] = asm["z"]; - Module["_zip_fclose"] = asm["A"]; - Module["_zip_file_add"] = asm["B"]; - Module["_free"] = asm["C"]; - var _malloc = Module["_malloc"] = asm["D"]; - Module["_zip_source_error"] = asm["E"]; - Module["_zip_source_seek"] = asm["F"]; - Module["_zip_file_set_external_attributes"] = asm["G"]; - Module["_zip_file_set_mtime"] = asm["H"]; - Module["_zip_fopen_index"] = asm["I"]; - Module["_zip_fread"] = asm["J"]; - Module["_zip_get_name"] = asm["K"]; - Module["_zip_get_num_entries"] = asm["L"]; - Module["_zip_source_read"] = asm["M"]; - Module["_zip_name_locate"] = asm["N"]; - Module["_zip_open_from_source"] = asm["O"]; - Module["_zip_set_file_compression"] = asm["P"]; - Module["_zip_source_buffer"] = asm["Q"]; - Module["_zip_source_buffer_create"] = asm["R"]; - Module["_zip_source_close"] = asm["S"]; - Module["_zip_source_free"] = asm["T"]; - Module["_zip_source_keep"] = asm["U"]; - Module["_zip_source_open"] = asm["V"]; - Module["_zip_source_tell"] = asm["X"]; - Module["_zip_stat_index"] = asm["Y"]; - var __get_tzname = Module["__get_tzname"] = asm["Z"]; - var __get_daylight = Module["__get_daylight"] = asm["_"]; - var __get_timezone = Module["__get_timezone"] = asm["$"]; - var stackSave = Module["stackSave"] = asm["aa"]; - var stackRestore = Module["stackRestore"] = asm["ba"]; - var stackAlloc = Module["stackAlloc"] = asm["ca"]; - Module["cwrap"] = cwrap; - Module["getValue"] = getValue; - var calledRun; - dependenciesFulfilled = function runCaller() { - if (!calledRun) run(); - if (!calledRun) dependenciesFulfilled = runCaller; - }; - function run(args) { - if (runDependencies > 0) { - return; - } - preRun(); - if (runDependencies > 0) { - return; - } - function doRun() { - if (calledRun) return; - calledRun = true; - Module["calledRun"] = true; - if (ABORT) return; - initRuntime(); - readyPromiseResolve(Module); - if (Module["onRuntimeInitialized"]) Module["onRuntimeInitialized"](); - postRun(); - } - if (Module["setStatus"]) { - Module["setStatus"]("Running..."); - setTimeout(function() { - setTimeout(function() { - Module["setStatus"](""); - }, 1); - doRun(); - }, 1); - } else { - doRun(); - } - } - Module["run"] = run; - if (Module["preInit"]) { - if (typeof Module["preInit"] == "function") - Module["preInit"] = [Module["preInit"]]; - while (Module["preInit"].length > 0) { - Module["preInit"].pop()(); - } - } - run(); - return createModule2; - }; -}(); -module.exports = createModule; -}(libzipSync)); - -const createModule = libzipSync.exports; - -const number64 = [ - `number`, - // low - `number` - // high -]; -var Errors = /* @__PURE__ */ ((Errors2) => { - Errors2[Errors2["ZIP_ER_OK"] = 0] = "ZIP_ER_OK"; - Errors2[Errors2["ZIP_ER_MULTIDISK"] = 1] = "ZIP_ER_MULTIDISK"; - Errors2[Errors2["ZIP_ER_RENAME"] = 2] = "ZIP_ER_RENAME"; - Errors2[Errors2["ZIP_ER_CLOSE"] = 3] = "ZIP_ER_CLOSE"; - Errors2[Errors2["ZIP_ER_SEEK"] = 4] = "ZIP_ER_SEEK"; - Errors2[Errors2["ZIP_ER_READ"] = 5] = "ZIP_ER_READ"; - Errors2[Errors2["ZIP_ER_WRITE"] = 6] = "ZIP_ER_WRITE"; - Errors2[Errors2["ZIP_ER_CRC"] = 7] = "ZIP_ER_CRC"; - Errors2[Errors2["ZIP_ER_ZIPCLOSED"] = 8] = "ZIP_ER_ZIPCLOSED"; - Errors2[Errors2["ZIP_ER_NOENT"] = 9] = "ZIP_ER_NOENT"; - Errors2[Errors2["ZIP_ER_EXISTS"] = 10] = "ZIP_ER_EXISTS"; - Errors2[Errors2["ZIP_ER_OPEN"] = 11] = "ZIP_ER_OPEN"; - Errors2[Errors2["ZIP_ER_TMPOPEN"] = 12] = "ZIP_ER_TMPOPEN"; - Errors2[Errors2["ZIP_ER_ZLIB"] = 13] = "ZIP_ER_ZLIB"; - Errors2[Errors2["ZIP_ER_MEMORY"] = 14] = "ZIP_ER_MEMORY"; - Errors2[Errors2["ZIP_ER_CHANGED"] = 15] = "ZIP_ER_CHANGED"; - Errors2[Errors2["ZIP_ER_COMPNOTSUPP"] = 16] = "ZIP_ER_COMPNOTSUPP"; - Errors2[Errors2["ZIP_ER_EOF"] = 17] = "ZIP_ER_EOF"; - Errors2[Errors2["ZIP_ER_INVAL"] = 18] = "ZIP_ER_INVAL"; - Errors2[Errors2["ZIP_ER_NOZIP"] = 19] = "ZIP_ER_NOZIP"; - Errors2[Errors2["ZIP_ER_INTERNAL"] = 20] = "ZIP_ER_INTERNAL"; - Errors2[Errors2["ZIP_ER_INCONS"] = 21] = "ZIP_ER_INCONS"; - Errors2[Errors2["ZIP_ER_REMOVE"] = 22] = "ZIP_ER_REMOVE"; - Errors2[Errors2["ZIP_ER_DELETED"] = 23] = "ZIP_ER_DELETED"; - Errors2[Errors2["ZIP_ER_ENCRNOTSUPP"] = 24] = "ZIP_ER_ENCRNOTSUPP"; - Errors2[Errors2["ZIP_ER_RDONLY"] = 25] = "ZIP_ER_RDONLY"; - Errors2[Errors2["ZIP_ER_NOPASSWD"] = 26] = "ZIP_ER_NOPASSWD"; - Errors2[Errors2["ZIP_ER_WRONGPASSWD"] = 27] = "ZIP_ER_WRONGPASSWD"; - Errors2[Errors2["ZIP_ER_OPNOTSUPP"] = 28] = "ZIP_ER_OPNOTSUPP"; - Errors2[Errors2["ZIP_ER_INUSE"] = 29] = "ZIP_ER_INUSE"; - Errors2[Errors2["ZIP_ER_TELL"] = 30] = "ZIP_ER_TELL"; - Errors2[Errors2["ZIP_ER_COMPRESSED_DATA"] = 31] = "ZIP_ER_COMPRESSED_DATA"; - return Errors2; -})(Errors || {}); -const makeInterface = (emZip) => ({ - // Those are getters because they can change after memory growth - get HEAPU8() { - return emZip.HEAPU8; - }, - errors: Errors, - SEEK_SET: 0, - SEEK_CUR: 1, - SEEK_END: 2, - ZIP_CHECKCONS: 4, - ZIP_EXCL: 2, - ZIP_RDONLY: 16, - ZIP_FL_OVERWRITE: 8192, - ZIP_FL_COMPRESSED: 4, - ZIP_OPSYS_DOS: 0, - ZIP_OPSYS_AMIGA: 1, - ZIP_OPSYS_OPENVMS: 2, - ZIP_OPSYS_UNIX: 3, - ZIP_OPSYS_VM_CMS: 4, - ZIP_OPSYS_ATARI_ST: 5, - ZIP_OPSYS_OS_2: 6, - ZIP_OPSYS_MACINTOSH: 7, - ZIP_OPSYS_Z_SYSTEM: 8, - ZIP_OPSYS_CPM: 9, - ZIP_OPSYS_WINDOWS_NTFS: 10, - ZIP_OPSYS_MVS: 11, - ZIP_OPSYS_VSE: 12, - ZIP_OPSYS_ACORN_RISC: 13, - ZIP_OPSYS_VFAT: 14, - ZIP_OPSYS_ALTERNATE_MVS: 15, - ZIP_OPSYS_BEOS: 16, - ZIP_OPSYS_TANDEM: 17, - ZIP_OPSYS_OS_400: 18, - ZIP_OPSYS_OS_X: 19, - ZIP_CM_DEFAULT: -1, - ZIP_CM_STORE: 0, - ZIP_CM_DEFLATE: 8, - uint08S: emZip._malloc(1), - uint32S: emZip._malloc(4), - malloc: emZip._malloc, - free: emZip._free, - getValue: emZip.getValue, - openFromSource: emZip.cwrap(`zip_open_from_source`, `number`, [`number`, `number`, `number`]), - close: emZip.cwrap(`zip_close`, `number`, [`number`]), - discard: emZip.cwrap(`zip_discard`, null, [`number`]), - getError: emZip.cwrap(`zip_get_error`, `number`, [`number`]), - getName: emZip.cwrap(`zip_get_name`, `string`, [`number`, `number`, `number`]), - getNumEntries: emZip.cwrap(`zip_get_num_entries`, `number`, [`number`, `number`]), - delete: emZip.cwrap(`zip_delete`, `number`, [`number`, `number`]), - statIndex: emZip.cwrap(`zip_stat_index`, `number`, [`number`, ...number64, `number`, `number`]), - fopenIndex: emZip.cwrap(`zip_fopen_index`, `number`, [`number`, ...number64, `number`]), - fread: emZip.cwrap(`zip_fread`, `number`, [`number`, `number`, `number`, `number`]), - fclose: emZip.cwrap(`zip_fclose`, `number`, [`number`]), - dir: { - add: emZip.cwrap(`zip_dir_add`, `number`, [`number`, `string`]) - }, - file: { - add: emZip.cwrap(`zip_file_add`, `number`, [`number`, `string`, `number`, `number`]), - getError: emZip.cwrap(`zip_file_get_error`, `number`, [`number`]), - getExternalAttributes: emZip.cwrap(`zip_file_get_external_attributes`, `number`, [`number`, ...number64, `number`, `number`, `number`]), - setExternalAttributes: emZip.cwrap(`zip_file_set_external_attributes`, `number`, [`number`, ...number64, `number`, `number`, `number`]), - setMtime: emZip.cwrap(`zip_file_set_mtime`, `number`, [`number`, ...number64, `number`, `number`]), - setCompression: emZip.cwrap(`zip_set_file_compression`, `number`, [`number`, ...number64, `number`, `number`]) - }, - ext: { - countSymlinks: emZip.cwrap(`zip_ext_count_symlinks`, `number`, [`number`]) - }, - error: { - initWithCode: emZip.cwrap(`zip_error_init_with_code`, null, [`number`, `number`]), - strerror: emZip.cwrap(`zip_error_strerror`, `string`, [`number`]) - }, - name: { - locate: emZip.cwrap(`zip_name_locate`, `number`, [`number`, `string`, `number`]) - }, - source: { - fromUnattachedBuffer: emZip.cwrap(`zip_source_buffer_create`, `number`, [`number`, ...number64, `number`, `number`]), - fromBuffer: emZip.cwrap(`zip_source_buffer`, `number`, [`number`, `number`, ...number64, `number`]), - free: emZip.cwrap(`zip_source_free`, null, [`number`]), - keep: emZip.cwrap(`zip_source_keep`, null, [`number`]), - open: emZip.cwrap(`zip_source_open`, `number`, [`number`]), - close: emZip.cwrap(`zip_source_close`, `number`, [`number`]), - seek: emZip.cwrap(`zip_source_seek`, `number`, [`number`, ...number64, `number`]), - tell: emZip.cwrap(`zip_source_tell`, `number`, [`number`]), - read: emZip.cwrap(`zip_source_read`, `number`, [`number`, `number`, `number`]), - error: emZip.cwrap(`zip_source_error`, `number`, [`number`]) - }, - struct: { - statS: emZip.cwrap(`zipstruct_statS`, `number`, []), - statSize: emZip.cwrap(`zipstruct_stat_size`, `number`, [`number`]), - statCompSize: emZip.cwrap(`zipstruct_stat_comp_size`, `number`, [`number`]), - statCompMethod: emZip.cwrap(`zipstruct_stat_comp_method`, `number`, [`number`]), - statMtime: emZip.cwrap(`zipstruct_stat_mtime`, `number`, [`number`]), - statCrc: emZip.cwrap(`zipstruct_stat_crc`, `number`, [`number`]), - errorS: emZip.cwrap(`zipstruct_errorS`, `number`, []), - errorCodeZip: emZip.cwrap(`zipstruct_error_code_zip`, `number`, [`number`]) - } -}); - -function getArchivePart(path, extension) { - let idx = path.indexOf(extension); - if (idx <= 0) - return null; - let nextCharIdx = idx; - while (idx >= 0) { - nextCharIdx = idx + extension.length; - if (path[nextCharIdx] === ppath.sep) - break; - if (path[idx - 1] === ppath.sep) - return null; - idx = path.indexOf(extension, nextCharIdx); - } - if (path.length > nextCharIdx && path[nextCharIdx] !== ppath.sep) - return null; - return path.slice(0, nextCharIdx); -} -class ZipOpenFS extends MountFS { - static async openPromise(fn, opts) { - const zipOpenFs = new ZipOpenFS(opts); - try { - return await fn(zipOpenFs); - } finally { - zipOpenFs.saveAndClose(); - } - } - constructor(opts = {}) { - const fileExtensions = opts.fileExtensions; - const readOnlyArchives = opts.readOnlyArchives; - const getMountPoint = typeof fileExtensions === `undefined` ? (path) => getArchivePart(path, `.zip`) : (path) => { - for (const extension of fileExtensions) { - const result = getArchivePart(path, extension); - if (result) { - return result; - } - } - return null; - }; - const factorySync = (baseFs, p) => { - return new ZipFS(p, { - baseFs, - readOnly: readOnlyArchives, - stats: baseFs.statSync(p), - customZipImplementation: opts.customZipImplementation - }); - }; - const factoryPromise = async (baseFs, p) => { - const zipOptions = { - baseFs, - readOnly: readOnlyArchives, - stats: await baseFs.statPromise(p), - customZipImplementation: opts.customZipImplementation - }; - return () => { - return new ZipFS(p, zipOptions); - }; - }; - super({ - ...opts, - factorySync, - factoryPromise, - getMountPoint - }); - } -} - -class LibzipError extends Error { - code; - constructor(message, code) { - super(message); - this.name = `Libzip Error`; - this.code = code; - } -} -class LibZipImpl { - libzip; - lzSource; - zip; - listings; - symlinkCount; - filesShouldBeCached = true; - constructor(opts) { - const buffer = `buffer` in opts ? opts.buffer : opts.baseFs.readFileSync(opts.path); - this.libzip = getInstance(); - const errPtr = this.libzip.malloc(4); - try { - let flags = 0; - if (opts.readOnly) - flags |= this.libzip.ZIP_RDONLY; - const lzSource = this.allocateUnattachedSource(buffer); - try { - this.zip = this.libzip.openFromSource(lzSource, flags, errPtr); - this.lzSource = lzSource; - } catch (error) { - this.libzip.source.free(lzSource); - throw error; - } - if (this.zip === 0) { - const error = this.libzip.struct.errorS(); - this.libzip.error.initWithCode(error, this.libzip.getValue(errPtr, `i32`)); - throw this.makeLibzipError(error); - } - } finally { - this.libzip.free(errPtr); - } - const entryCount = this.libzip.getNumEntries(this.zip, 0); - const listings = new Array(entryCount); - for (let t = 0; t < entryCount; ++t) - listings[t] = this.libzip.getName(this.zip, t, 0); - this.listings = listings; - this.symlinkCount = this.libzip.ext.countSymlinks(this.zip); - if (this.symlinkCount === -1) { - throw this.makeLibzipError(this.libzip.getError(this.zip)); - } - } - getSymlinkCount() { - return this.symlinkCount; - } - getListings() { - return this.listings; - } - stat(entry) { - const stat = this.libzip.struct.statS(); - const rc = this.libzip.statIndex(this.zip, entry, 0, 0, stat); - if (rc === -1) - throw this.makeLibzipError(this.libzip.getError(this.zip)); - const size = this.libzip.struct.statSize(stat) >>> 0; - const mtime = this.libzip.struct.statMtime(stat) >>> 0; - const crc = this.libzip.struct.statCrc(stat) >>> 0; - return { size, mtime, crc }; - } - makeLibzipError(error) { - const errorCode = this.libzip.struct.errorCodeZip(error); - const strerror = this.libzip.error.strerror(error); - const libzipError = new LibzipError(strerror, this.libzip.errors[errorCode]); - if (errorCode === this.libzip.errors.ZIP_ER_CHANGED) - throw new Error(`Assertion failed: Unexpected libzip error: ${libzipError.message}`); - return libzipError; - } - setFileSource(target, compression, buffer) { - const lzSource = this.allocateSource(buffer); - try { - const newIndex = this.libzip.file.add(this.zip, target, lzSource, this.libzip.ZIP_FL_OVERWRITE); - if (newIndex === -1) - throw this.makeLibzipError(this.libzip.getError(this.zip)); - if (compression !== null) { - const rc = this.libzip.file.setCompression(this.zip, newIndex, 0, compression[0], compression[1]); - if (rc === -1) { - throw this.makeLibzipError(this.libzip.getError(this.zip)); - } - } - return newIndex; - } catch (error) { - this.libzip.source.free(lzSource); - throw error; - } - } - setMtime(entry, mtime) { - const rc = this.libzip.file.setMtime(this.zip, entry, 0, mtime, 0); - if (rc === -1) { - throw this.makeLibzipError(this.libzip.getError(this.zip)); - } - } - getExternalAttributes(index) { - const attrs = this.libzip.file.getExternalAttributes(this.zip, index, 0, 0, this.libzip.uint08S, this.libzip.uint32S); - if (attrs === -1) - throw this.makeLibzipError(this.libzip.getError(this.zip)); - const opsys = this.libzip.getValue(this.libzip.uint08S, `i8`) >>> 0; - const attributes = this.libzip.getValue(this.libzip.uint32S, `i32`) >>> 0; - return [opsys, attributes]; - } - setExternalAttributes(index, opsys, attributes) { - const rc = this.libzip.file.setExternalAttributes(this.zip, index, 0, 0, opsys, attributes); - if (rc === -1) { - throw this.makeLibzipError(this.libzip.getError(this.zip)); - } - } - locate(name) { - return this.libzip.name.locate(this.zip, name, 0); - } - getFileSource(index) { - const stat = this.libzip.struct.statS(); - const rc = this.libzip.statIndex(this.zip, index, 0, 0, stat); - if (rc === -1) - throw this.makeLibzipError(this.libzip.getError(this.zip)); - const size = this.libzip.struct.statCompSize(stat); - const compressionMethod = this.libzip.struct.statCompMethod(stat); - const buffer = this.libzip.malloc(size); - try { - const file = this.libzip.fopenIndex(this.zip, index, 0, this.libzip.ZIP_FL_COMPRESSED); - if (file === 0) - throw this.makeLibzipError(this.libzip.getError(this.zip)); - try { - const rc2 = this.libzip.fread(file, buffer, size, 0); - if (rc2 === -1) - throw this.makeLibzipError(this.libzip.file.getError(file)); - else if (rc2 < size) - throw new Error(`Incomplete read`); - else if (rc2 > size) - throw new Error(`Overread`); - const memory = this.libzip.HEAPU8.subarray(buffer, buffer + size); - const data = Buffer.from(memory); - return { data, compressionMethod }; - } finally { - this.libzip.fclose(file); - } - } finally { - this.libzip.free(buffer); - } - } - deleteEntry(index) { - const rc = this.libzip.delete(this.zip, index); - if (rc === -1) { - throw this.makeLibzipError(this.libzip.getError(this.zip)); - } - } - addDirectory(path) { - const index = this.libzip.dir.add(this.zip, path); - if (index === -1) - throw this.makeLibzipError(this.libzip.getError(this.zip)); - return index; - } - getBufferAndClose() { - try { - this.libzip.source.keep(this.lzSource); - if (this.libzip.close(this.zip) === -1) - throw this.makeLibzipError(this.libzip.getError(this.zip)); - if (this.libzip.source.open(this.lzSource) === -1) - throw this.makeLibzipError(this.libzip.source.error(this.lzSource)); - if (this.libzip.source.seek(this.lzSource, 0, 0, this.libzip.SEEK_END) === -1) - throw this.makeLibzipError(this.libzip.source.error(this.lzSource)); - const size = this.libzip.source.tell(this.lzSource); - if (size === -1) - throw this.makeLibzipError(this.libzip.source.error(this.lzSource)); - if (this.libzip.source.seek(this.lzSource, 0, 0, this.libzip.SEEK_SET) === -1) - throw this.makeLibzipError(this.libzip.source.error(this.lzSource)); - const buffer = this.libzip.malloc(size); - if (!buffer) - throw new Error(`Couldn't allocate enough memory`); - try { - const rc = this.libzip.source.read(this.lzSource, buffer, size); - if (rc === -1) - throw this.makeLibzipError(this.libzip.source.error(this.lzSource)); - else if (rc < size) - throw new Error(`Incomplete read`); - else if (rc > size) - throw new Error(`Overread`); - let result = Buffer.from(this.libzip.HEAPU8.subarray(buffer, buffer + size)); - if (process.env.YARN_IS_TEST_ENV && process.env.YARN_ZIP_DATA_EPILOGUE) - result = Buffer.concat([result, Buffer.from(process.env.YARN_ZIP_DATA_EPILOGUE)]); - return result; - } finally { - this.libzip.free(buffer); - } - } finally { - this.libzip.source.close(this.lzSource); - this.libzip.source.free(this.lzSource); - } - } - allocateBuffer(content) { - if (!Buffer.isBuffer(content)) - content = Buffer.from(content); - const buffer = this.libzip.malloc(content.byteLength); - if (!buffer) - throw new Error(`Couldn't allocate enough memory`); - const heap = new Uint8Array(this.libzip.HEAPU8.buffer, buffer, content.byteLength); - heap.set(content); - return { buffer, byteLength: content.byteLength }; - } - allocateUnattachedSource(content) { - const error = this.libzip.struct.errorS(); - const { buffer, byteLength } = this.allocateBuffer(content); - const source = this.libzip.source.fromUnattachedBuffer(buffer, byteLength, 0, 1, error); - if (source === 0) { - this.libzip.free(error); - throw this.makeLibzipError(error); - } - return source; - } - allocateSource(content) { - const { buffer, byteLength } = this.allocateBuffer(content); - const source = this.libzip.source.fromBuffer(this.zip, buffer, byteLength, 0, 1); - if (source === 0) { - this.libzip.free(buffer); - throw this.makeLibzipError(this.libzip.getError(this.zip)); - } - return source; - } - discard() { - this.libzip.discard(this.zip); - } -} - -const ZIP_UNIX = 3; -const STORE = 0; -const DEFLATE = 8; -const DEFAULT_COMPRESSION_LEVEL = `mixed`; -function toUnixTimestamp(time) { - if (typeof time === `string` && String(+time) === time) - return +time; - if (typeof time === `number` && Number.isFinite(time)) { - if (time < 0) { - return Date.now() / 1e3; - } else { - return time; - } - } - if (nodeUtils.types.isDate(time)) - return time.getTime() / 1e3; - throw new Error(`Invalid time`); -} -function makeEmptyArchive() { - return Buffer.from([ - 80, - 75, - 5, - 6, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0 - ]); -} -class ZipFS extends BasePortableFakeFS { - baseFs; - path; - stats; - level; - zipImpl; - listings = /* @__PURE__ */ new Map(); - entries = /* @__PURE__ */ new Map(); - /** - * A cache of indices mapped to file sources. - * Populated by `setFileSource` calls. - * Required for supporting read after write. - */ - fileSources = /* @__PURE__ */ new Map(); - symlinkCount; - fds = /* @__PURE__ */ new Map(); - nextFd = 0; - ready = false; - readOnly = false; - constructor(source, opts = {}) { - super(); - if (opts.readOnly) - this.readOnly = true; - const pathOptions = opts; - this.level = typeof pathOptions.level !== `undefined` ? pathOptions.level : DEFAULT_COMPRESSION_LEVEL; - const ZipImplCls = opts.customZipImplementation ?? LibZipImpl; - if (typeof source === `string`) { - const { baseFs = new NodeFS() } = pathOptions; - this.baseFs = baseFs; - this.path = source; - } else { - this.path = null; - this.baseFs = null; - } - if (opts.stats) { - this.stats = opts.stats; - } else { - if (typeof source === `string`) { - try { - this.stats = this.baseFs.statSync(source); - } catch (error) { - if (error.code === `ENOENT` && pathOptions.create) { - this.stats = makeDefaultStats(); - } else { - throw error; - } - } - } else { - this.stats = makeDefaultStats(); - } - } - if (typeof source === `string`) { - if (opts.create) { - this.zipImpl = new ZipImplCls({ buffer: makeEmptyArchive(), readOnly: this.readOnly }); - } else { - this.zipImpl = new ZipImplCls({ path: source, baseFs: this.baseFs, readOnly: this.readOnly, size: this.stats.size }); - } - } else { - this.zipImpl = new ZipImplCls({ buffer: source ?? makeEmptyArchive(), readOnly: this.readOnly }); - } - this.listings.set(PortablePath.root, /* @__PURE__ */ new Set()); - const listings = this.zipImpl.getListings(); - for (let t = 0; t < listings.length; t++) { - const raw = listings[t]; - if (ppath.isAbsolute(raw)) - continue; - const p = ppath.resolve(PortablePath.root, raw); - this.registerEntry(p, t); - if (raw.endsWith(`/`)) { - this.registerListing(p); - } - } - this.symlinkCount = this.zipImpl.getSymlinkCount(); - this.ready = true; - } - getExtractHint(hints) { - for (const fileName of this.entries.keys()) { - const ext = this.pathUtils.extname(fileName); - if (hints.relevantExtensions.has(ext)) { - return true; - } - } - return false; - } - getAllFiles() { - return Array.from(this.entries.keys()); - } - getRealPath() { - if (!this.path) - throw new Error(`ZipFS don't have real paths when loaded from a buffer`); - return this.path; - } - prepareClose() { - if (!this.ready) - throw EBUSY(`archive closed, close`); - unwatchAllFiles(this); - } - getBufferAndClose() { - this.prepareClose(); - if (this.entries.size === 0) { - this.discardAndClose(); - return makeEmptyArchive(); - } - try { - return this.zipImpl.getBufferAndClose(); - } finally { - this.ready = false; - } - } - discardAndClose() { - this.prepareClose(); - this.zipImpl.discard(); - this.ready = false; - } - saveAndClose() { - if (!this.path || !this.baseFs) - throw new Error(`ZipFS cannot be saved and must be discarded when loaded from a buffer`); - if (this.readOnly) { - this.discardAndClose(); - return; - } - const newMode = this.baseFs.existsSync(this.path) || this.stats.mode === DEFAULT_MODE ? void 0 : this.stats.mode; - this.baseFs.writeFileSync(this.path, this.getBufferAndClose(), { mode: newMode }); - this.ready = false; - } - resolve(p) { - return ppath.resolve(PortablePath.root, p); - } - async openPromise(p, flags, mode) { - return this.openSync(p, flags, mode); - } - openSync(p, flags, mode) { - const fd = this.nextFd++; - this.fds.set(fd, { cursor: 0, p }); - return fd; - } - hasOpenFileHandles() { - return !!this.fds.size; - } - async opendirPromise(p, opts) { - return this.opendirSync(p, opts); - } - opendirSync(p, opts = {}) { - const resolvedP = this.resolveFilename(`opendir '${p}'`, p); - if (!this.entries.has(resolvedP) && !this.listings.has(resolvedP)) - throw ENOENT(`opendir '${p}'`); - const directoryListing = this.listings.get(resolvedP); - if (!directoryListing) - throw ENOTDIR(`opendir '${p}'`); - const entries = [...directoryListing]; - const fd = this.openSync(resolvedP, `r`); - const onClose = () => { - this.closeSync(fd); - }; - return opendir(this, resolvedP, entries, { onClose }); - } - async readPromise(fd, buffer, offset, length, position) { - return this.readSync(fd, buffer, offset, length, position); - } - readSync(fd, buffer, offset = 0, length = buffer.byteLength, position = -1) { - const entry = this.fds.get(fd); - if (typeof entry === `undefined`) - throw EBADF(`read`); - const realPosition = position === -1 || position === null ? entry.cursor : position; - const source = this.readFileSync(entry.p); - source.copy(buffer, offset, realPosition, realPosition + length); - const bytesRead = Math.max(0, Math.min(source.length - realPosition, length)); - if (position === -1 || position === null) - entry.cursor += bytesRead; - return bytesRead; - } - async writePromise(fd, buffer, offset, length, position) { - if (typeof buffer === `string`) { - return this.writeSync(fd, buffer, position); - } else { - return this.writeSync(fd, buffer, offset, length, position); - } - } - writeSync(fd, buffer, offset, length, position) { - const entry = this.fds.get(fd); - if (typeof entry === `undefined`) - throw EBADF(`read`); - throw new Error(`Unimplemented`); - } - async closePromise(fd) { - return this.closeSync(fd); - } - closeSync(fd) { - const entry = this.fds.get(fd); - if (typeof entry === `undefined`) - throw EBADF(`read`); - this.fds.delete(fd); - } - createReadStream(p, { encoding } = {}) { - if (p === null) - throw new Error(`Unimplemented`); - const fd = this.openSync(p, `r`); - const stream$1 = Object.assign( - new stream.PassThrough({ - emitClose: true, - autoDestroy: true, - destroy: (error, callback) => { - clearImmediate(immediate); - this.closeSync(fd); - callback(error); - } - }), - { - close() { - stream$1.destroy(); - }, - bytesRead: 0, - path: p, - // "This property is `true` if the underlying file has not been opened yet" - pending: false - } - ); - const immediate = setImmediate(async () => { - try { - const data = await this.readFilePromise(p, encoding); - stream$1.bytesRead = data.length; - stream$1.end(data); - } catch (error) { - stream$1.destroy(error); - } - }); - return stream$1; - } - createWriteStream(p, { encoding } = {}) { - if (this.readOnly) - throw EROFS(`open '${p}'`); - if (p === null) - throw new Error(`Unimplemented`); - const chunks = []; - const fd = this.openSync(p, `w`); - const stream$1 = Object.assign( - new stream.PassThrough({ - autoDestroy: true, - emitClose: true, - destroy: (error, callback) => { - try { - if (error) { - callback(error); - } else { - this.writeFileSync(p, Buffer.concat(chunks), encoding); - callback(null); - } - } catch (err) { - callback(err); - } finally { - this.closeSync(fd); - } - } - }), - { - close() { - stream$1.destroy(); - }, - bytesWritten: 0, - path: p, - // "This property is `true` if the underlying file has not been opened yet" - pending: false - } - ); - stream$1.on(`data`, (chunk) => { - const chunkBuffer = Buffer.from(chunk); - stream$1.bytesWritten += chunkBuffer.length; - chunks.push(chunkBuffer); - }); - return stream$1; - } - async realpathPromise(p) { - return this.realpathSync(p); - } - realpathSync(p) { - const resolvedP = this.resolveFilename(`lstat '${p}'`, p); - if (!this.entries.has(resolvedP) && !this.listings.has(resolvedP)) - throw ENOENT(`lstat '${p}'`); - return resolvedP; - } - async existsPromise(p) { - return this.existsSync(p); - } - existsSync(p) { - if (!this.ready) - throw EBUSY(`archive closed, existsSync '${p}'`); - if (this.symlinkCount === 0) { - const resolvedP2 = ppath.resolve(PortablePath.root, p); - return this.entries.has(resolvedP2) || this.listings.has(resolvedP2); - } - let resolvedP; - try { - resolvedP = this.resolveFilename(`stat '${p}'`, p, void 0, false); - } catch { - return false; - } - if (resolvedP === void 0) - return false; - return this.entries.has(resolvedP) || this.listings.has(resolvedP); - } - async accessPromise(p, mode) { - return this.accessSync(p, mode); - } - accessSync(p, mode = fs.constants.F_OK) { - const resolvedP = this.resolveFilename(`access '${p}'`, p); - if (!this.entries.has(resolvedP) && !this.listings.has(resolvedP)) - throw ENOENT(`access '${p}'`); - if (this.readOnly && mode & fs.constants.W_OK) { - throw EROFS(`access '${p}'`); - } - } - async statPromise(p, opts = { bigint: false }) { - if (opts.bigint) - return this.statSync(p, { bigint: true }); - return this.statSync(p); - } - statSync(p, opts = { bigint: false, throwIfNoEntry: true }) { - const resolvedP = this.resolveFilename(`stat '${p}'`, p, void 0, opts.throwIfNoEntry); - if (resolvedP === void 0) - return void 0; - if (!this.entries.has(resolvedP) && !this.listings.has(resolvedP)) { - if (opts.throwIfNoEntry === false) - return void 0; - throw ENOENT(`stat '${p}'`); - } - if (p[p.length - 1] === `/` && !this.listings.has(resolvedP)) - throw ENOTDIR(`stat '${p}'`); - return this.statImpl(`stat '${p}'`, resolvedP, opts); - } - async fstatPromise(fd, opts) { - return this.fstatSync(fd, opts); - } - fstatSync(fd, opts) { - const entry = this.fds.get(fd); - if (typeof entry === `undefined`) - throw EBADF(`fstatSync`); - const { p } = entry; - const resolvedP = this.resolveFilename(`stat '${p}'`, p); - if (!this.entries.has(resolvedP) && !this.listings.has(resolvedP)) - throw ENOENT(`stat '${p}'`); - if (p[p.length - 1] === `/` && !this.listings.has(resolvedP)) - throw ENOTDIR(`stat '${p}'`); - return this.statImpl(`fstat '${p}'`, resolvedP, opts); - } - async lstatPromise(p, opts = { bigint: false }) { - if (opts.bigint) - return this.lstatSync(p, { bigint: true }); - return this.lstatSync(p); - } - lstatSync(p, opts = { bigint: false, throwIfNoEntry: true }) { - const resolvedP = this.resolveFilename(`lstat '${p}'`, p, false, opts.throwIfNoEntry); - if (resolvedP === void 0) - return void 0; - if (!this.entries.has(resolvedP) && !this.listings.has(resolvedP)) { - if (opts.throwIfNoEntry === false) - return void 0; - throw ENOENT(`lstat '${p}'`); - } - if (p[p.length - 1] === `/` && !this.listings.has(resolvedP)) - throw ENOTDIR(`lstat '${p}'`); - return this.statImpl(`lstat '${p}'`, resolvedP, opts); - } - statImpl(reason, p, opts = {}) { - const entry = this.entries.get(p); - if (typeof entry !== `undefined`) { - const stat = this.zipImpl.stat(entry); - const crc = stat.crc; - const size = stat.size; - const mtimeMs = stat.mtime * 1e3; - const uid = this.stats.uid; - const gid = this.stats.gid; - const blksize = 512; - const blocks = Math.ceil(stat.size / blksize); - const atimeMs = mtimeMs; - const birthtimeMs = mtimeMs; - const ctimeMs = mtimeMs; - const atime = new Date(atimeMs); - const birthtime = new Date(birthtimeMs); - const ctime = new Date(ctimeMs); - const mtime = new Date(mtimeMs); - const type = this.listings.has(p) ? fs.constants.S_IFDIR : this.isSymbolicLink(entry) ? fs.constants.S_IFLNK : fs.constants.S_IFREG; - const defaultMode = type === fs.constants.S_IFDIR ? 493 : 420; - const mode = type | this.getUnixMode(entry, defaultMode) & 511; - const statInstance = Object.assign(new StatEntry(), { uid, gid, size, blksize, blocks, atime, birthtime, ctime, mtime, atimeMs, birthtimeMs, ctimeMs, mtimeMs, mode, crc }); - return opts.bigint === true ? convertToBigIntStats(statInstance) : statInstance; - } - if (this.listings.has(p)) { - const uid = this.stats.uid; - const gid = this.stats.gid; - const size = 0; - const blksize = 512; - const blocks = 0; - const atimeMs = this.stats.mtimeMs; - const birthtimeMs = this.stats.mtimeMs; - const ctimeMs = this.stats.mtimeMs; - const mtimeMs = this.stats.mtimeMs; - const atime = new Date(atimeMs); - const birthtime = new Date(birthtimeMs); - const ctime = new Date(ctimeMs); - const mtime = new Date(mtimeMs); - const mode = fs.constants.S_IFDIR | 493; - const crc = 0; - const statInstance = Object.assign(new StatEntry(), { uid, gid, size, blksize, blocks, atime, birthtime, ctime, mtime, atimeMs, birthtimeMs, ctimeMs, mtimeMs, mode, crc }); - return opts.bigint === true ? convertToBigIntStats(statInstance) : statInstance; - } - throw new Error(`Unreachable`); - } - getUnixMode(index, defaultMode) { - const [opsys, attributes] = this.zipImpl.getExternalAttributes(index); - if (opsys !== ZIP_UNIX) - return defaultMode; - return attributes >>> 16; - } - registerListing(p) { - const existingListing = this.listings.get(p); - if (existingListing) - return existingListing; - const parentListing = this.registerListing(ppath.dirname(p)); - parentListing.add(ppath.basename(p)); - const newListing = /* @__PURE__ */ new Set(); - this.listings.set(p, newListing); - return newListing; - } - registerEntry(p, index) { - const parentListing = this.registerListing(ppath.dirname(p)); - parentListing.add(ppath.basename(p)); - this.entries.set(p, index); - } - unregisterListing(p) { - this.listings.delete(p); - const parentListing = this.listings.get(ppath.dirname(p)); - parentListing?.delete(ppath.basename(p)); - } - unregisterEntry(p) { - this.unregisterListing(p); - const entry = this.entries.get(p); - this.entries.delete(p); - if (typeof entry === `undefined`) - return; - this.fileSources.delete(entry); - if (this.isSymbolicLink(entry)) { - this.symlinkCount--; - } - } - deleteEntry(p, index) { - this.unregisterEntry(p); - this.zipImpl.deleteEntry(index); - } - resolveFilename(reason, p, resolveLastComponent = true, throwIfNoEntry = true) { - if (!this.ready) - throw EBUSY(`archive closed, ${reason}`); - let resolvedP = ppath.resolve(PortablePath.root, p); - if (resolvedP === `/`) - return PortablePath.root; - const fileIndex = this.entries.get(resolvedP); - if (resolveLastComponent && fileIndex !== void 0) { - if (this.symlinkCount !== 0 && this.isSymbolicLink(fileIndex)) { - const target = this.getFileSource(fileIndex).toString(); - return this.resolveFilename(reason, ppath.resolve(ppath.dirname(resolvedP), target), true, throwIfNoEntry); - } else { - return resolvedP; - } - } - while (true) { - const parentP = this.resolveFilename(reason, ppath.dirname(resolvedP), true, throwIfNoEntry); - if (parentP === void 0) - return parentP; - const isDir = this.listings.has(parentP); - const doesExist = this.entries.has(parentP); - if (!isDir && !doesExist) { - if (throwIfNoEntry === false) - return void 0; - throw ENOENT(reason); - } - if (!isDir) - throw ENOTDIR(reason); - resolvedP = ppath.resolve(parentP, ppath.basename(resolvedP)); - if (!resolveLastComponent || this.symlinkCount === 0) - break; - const index = this.zipImpl.locate(resolvedP.slice(1)); - if (index === -1) - break; - if (this.isSymbolicLink(index)) { - const target = this.getFileSource(index).toString(); - resolvedP = ppath.resolve(ppath.dirname(resolvedP), target); - } else { - break; - } - } - return resolvedP; - } - setFileSource(p, content) { - const buffer = Buffer.isBuffer(content) ? content : Buffer.from(content); - const target = ppath.relative(PortablePath.root, p); - let compression = null; - if (this.level !== `mixed`) { - const method = this.level === 0 ? STORE : DEFLATE; - compression = [method, this.level]; - } - const newIndex = this.zipImpl.setFileSource(target, compression, buffer); - this.fileSources.set(newIndex, buffer); - return newIndex; - } - isSymbolicLink(index) { - if (this.symlinkCount === 0) - return false; - const [opsys, attrs] = this.zipImpl.getExternalAttributes(index); - if (opsys !== ZIP_UNIX) - return false; - const attributes = attrs >>> 16; - return (attributes & fs.constants.S_IFMT) === fs.constants.S_IFLNK; - } - getFileSource(index, opts = { asyncDecompress: false }) { - const cachedFileSource = this.fileSources.get(index); - if (typeof cachedFileSource !== `undefined`) - return cachedFileSource; - const { data, compressionMethod } = this.zipImpl.getFileSource(index); - if (compressionMethod === STORE) { - if (this.zipImpl.filesShouldBeCached) - this.fileSources.set(index, data); - return data; - } else if (compressionMethod === DEFLATE) { - if (opts.asyncDecompress) { - return new Promise((resolve, reject) => { - zlib__default.default.inflateRaw(data, (error, result) => { - if (error) { - reject(error); - } else { - if (this.zipImpl.filesShouldBeCached) - this.fileSources.set(index, result); - resolve(result); - } - }); - }); - } else { - const decompressedData = zlib__default.default.inflateRawSync(data); - if (this.zipImpl.filesShouldBeCached) - this.fileSources.set(index, decompressedData); - return decompressedData; - } - } else { - throw new Error(`Unsupported compression method: ${compressionMethod}`); - } - } - async fchmodPromise(fd, mask) { - return this.chmodPromise(this.fdToPath(fd, `fchmod`), mask); - } - fchmodSync(fd, mask) { - return this.chmodSync(this.fdToPath(fd, `fchmodSync`), mask); - } - async chmodPromise(p, mask) { - return this.chmodSync(p, mask); - } - chmodSync(p, mask) { - if (this.readOnly) - throw EROFS(`chmod '${p}'`); - mask &= 493; - const resolvedP = this.resolveFilename(`chmod '${p}'`, p, false); - const entry = this.entries.get(resolvedP); - if (typeof entry === `undefined`) - throw new Error(`Assertion failed: The entry should have been registered (${resolvedP})`); - const oldMod = this.getUnixMode(entry, fs.constants.S_IFREG | 0); - const newMod = oldMod & ~511 | mask; - this.zipImpl.setExternalAttributes(entry, ZIP_UNIX, newMod << 16); - } - async fchownPromise(fd, uid, gid) { - return this.chownPromise(this.fdToPath(fd, `fchown`), uid, gid); - } - fchownSync(fd, uid, gid) { - return this.chownSync(this.fdToPath(fd, `fchownSync`), uid, gid); - } - async chownPromise(p, uid, gid) { - return this.chownSync(p, uid, gid); - } - chownSync(p, uid, gid) { - throw new Error(`Unimplemented`); - } - async renamePromise(oldP, newP) { - return this.renameSync(oldP, newP); - } - renameSync(oldP, newP) { - throw new Error(`Unimplemented`); - } - async copyFilePromise(sourceP, destP, flags) { - const { indexSource, indexDest, resolvedDestP } = this.prepareCopyFile(sourceP, destP, flags); - const source = await this.getFileSource(indexSource, { asyncDecompress: true }); - const newIndex = this.setFileSource(resolvedDestP, source); - if (newIndex !== indexDest) { - this.registerEntry(resolvedDestP, newIndex); - } - } - copyFileSync(sourceP, destP, flags = 0) { - const { indexSource, indexDest, resolvedDestP } = this.prepareCopyFile(sourceP, destP, flags); - const source = this.getFileSource(indexSource); - const newIndex = this.setFileSource(resolvedDestP, source); - if (newIndex !== indexDest) { - this.registerEntry(resolvedDestP, newIndex); - } - } - prepareCopyFile(sourceP, destP, flags = 0) { - if (this.readOnly) - throw EROFS(`copyfile '${sourceP} -> '${destP}'`); - if ((flags & fs.constants.COPYFILE_FICLONE_FORCE) !== 0) - throw ENOSYS(`unsupported clone operation`, `copyfile '${sourceP}' -> ${destP}'`); - const resolvedSourceP = this.resolveFilename(`copyfile '${sourceP} -> ${destP}'`, sourceP); - const indexSource = this.entries.get(resolvedSourceP); - if (typeof indexSource === `undefined`) - throw EINVAL(`copyfile '${sourceP}' -> '${destP}'`); - const resolvedDestP = this.resolveFilename(`copyfile '${sourceP}' -> ${destP}'`, destP); - const indexDest = this.entries.get(resolvedDestP); - if ((flags & (fs.constants.COPYFILE_EXCL | fs.constants.COPYFILE_FICLONE_FORCE)) !== 0 && typeof indexDest !== `undefined`) - throw EEXIST(`copyfile '${sourceP}' -> '${destP}'`); - return { - indexSource, - resolvedDestP, - indexDest - }; - } - async appendFilePromise(p, content, opts) { - if (this.readOnly) - throw EROFS(`open '${p}'`); - if (typeof opts === `undefined`) - opts = { flag: `a` }; - else if (typeof opts === `string`) - opts = { flag: `a`, encoding: opts }; - else if (typeof opts.flag === `undefined`) - opts = { flag: `a`, ...opts }; - return this.writeFilePromise(p, content, opts); - } - appendFileSync(p, content, opts = {}) { - if (this.readOnly) - throw EROFS(`open '${p}'`); - if (typeof opts === `undefined`) - opts = { flag: `a` }; - else if (typeof opts === `string`) - opts = { flag: `a`, encoding: opts }; - else if (typeof opts.flag === `undefined`) - opts = { flag: `a`, ...opts }; - return this.writeFileSync(p, content, opts); - } - fdToPath(fd, reason) { - const path = this.fds.get(fd)?.p; - if (typeof path === `undefined`) - throw EBADF(reason); - return path; - } - async writeFilePromise(p, content, opts) { - const { encoding, mode, index, resolvedP } = this.prepareWriteFile(p, opts); - if (index !== void 0 && typeof opts === `object` && opts.flag && opts.flag.includes(`a`)) - content = Buffer.concat([await this.getFileSource(index, { asyncDecompress: true }), Buffer.from(content)]); - if (encoding !== null) - content = content.toString(encoding); - const newIndex = this.setFileSource(resolvedP, content); - if (newIndex !== index) - this.registerEntry(resolvedP, newIndex); - if (mode !== null) { - await this.chmodPromise(resolvedP, mode); - } - } - writeFileSync(p, content, opts) { - const { encoding, mode, index, resolvedP } = this.prepareWriteFile(p, opts); - if (index !== void 0 && typeof opts === `object` && opts.flag && opts.flag.includes(`a`)) - content = Buffer.concat([this.getFileSource(index), Buffer.from(content)]); - if (encoding !== null) - content = content.toString(encoding); - const newIndex = this.setFileSource(resolvedP, content); - if (newIndex !== index) - this.registerEntry(resolvedP, newIndex); - if (mode !== null) { - this.chmodSync(resolvedP, mode); - } - } - prepareWriteFile(p, opts) { - if (typeof p === `number`) - p = this.fdToPath(p, `read`); - if (this.readOnly) - throw EROFS(`open '${p}'`); - const resolvedP = this.resolveFilename(`open '${p}'`, p); - if (this.listings.has(resolvedP)) - throw EISDIR(`open '${p}'`); - let encoding = null, mode = null; - if (typeof opts === `string`) { - encoding = opts; - } else if (typeof opts === `object`) { - ({ - encoding = null, - mode = null - } = opts); - } - const index = this.entries.get(resolvedP); - return { - encoding, - mode, - resolvedP, - index - }; - } - async unlinkPromise(p) { - return this.unlinkSync(p); - } - unlinkSync(p) { - if (this.readOnly) - throw EROFS(`unlink '${p}'`); - const resolvedP = this.resolveFilename(`unlink '${p}'`, p); - if (this.listings.has(resolvedP)) - throw EISDIR(`unlink '${p}'`); - const index = this.entries.get(resolvedP); - if (typeof index === `undefined`) - throw EINVAL(`unlink '${p}'`); - this.deleteEntry(resolvedP, index); - } - async utimesPromise(p, atime, mtime) { - return this.utimesSync(p, atime, mtime); - } - utimesSync(p, atime, mtime) { - if (this.readOnly) - throw EROFS(`utimes '${p}'`); - const resolvedP = this.resolveFilename(`utimes '${p}'`, p); - this.utimesImpl(resolvedP, mtime); - } - async lutimesPromise(p, atime, mtime) { - return this.lutimesSync(p, atime, mtime); - } - lutimesSync(p, atime, mtime) { - if (this.readOnly) - throw EROFS(`lutimes '${p}'`); - const resolvedP = this.resolveFilename(`utimes '${p}'`, p, false); - this.utimesImpl(resolvedP, mtime); - } - utimesImpl(resolvedP, mtime) { - if (this.listings.has(resolvedP)) { - if (!this.entries.has(resolvedP)) - this.hydrateDirectory(resolvedP); - } - const entry = this.entries.get(resolvedP); - if (entry === void 0) - throw new Error(`Unreachable`); - this.zipImpl.setMtime(entry, toUnixTimestamp(mtime)); - } - async mkdirPromise(p, opts) { - return this.mkdirSync(p, opts); - } - mkdirSync(p, { mode = 493, recursive = false } = {}) { - if (recursive) - return this.mkdirpSync(p, { chmod: mode }); - if (this.readOnly) - throw EROFS(`mkdir '${p}'`); - const resolvedP = this.resolveFilename(`mkdir '${p}'`, p); - if (this.entries.has(resolvedP) || this.listings.has(resolvedP)) - throw EEXIST(`mkdir '${p}'`); - this.hydrateDirectory(resolvedP); - this.chmodSync(resolvedP, mode); - return void 0; - } - async rmdirPromise(p, opts) { - return this.rmdirSync(p, opts); - } - rmdirSync(p, { recursive = false } = {}) { - if (this.readOnly) - throw EROFS(`rmdir '${p}'`); - if (recursive) { - this.removeSync(p); - return; - } - const resolvedP = this.resolveFilename(`rmdir '${p}'`, p); - const directoryListing = this.listings.get(resolvedP); - if (!directoryListing) - throw ENOTDIR(`rmdir '${p}'`); - if (directoryListing.size > 0) - throw ENOTEMPTY(`rmdir '${p}'`); - const index = this.entries.get(resolvedP); - if (typeof index === `undefined`) - throw EINVAL(`rmdir '${p}'`); - this.deleteEntry(p, index); - } - async rmPromise(p, opts) { - return this.rmSync(p, opts); - } - rmSync(p, { recursive = false } = {}) { - if (this.readOnly) - throw EROFS(`rm '${p}'`); - if (recursive) { - this.removeSync(p); - return; - } - const resolvedP = this.resolveFilename(`rm '${p}'`, p); - const directoryListing = this.listings.get(resolvedP); - if (!directoryListing) - throw ENOTDIR(`rm '${p}'`); - if (directoryListing.size > 0) - throw ENOTEMPTY(`rm '${p}'`); - const index = this.entries.get(resolvedP); - if (typeof index === `undefined`) - throw EINVAL(`rm '${p}'`); - this.deleteEntry(p, index); - } - hydrateDirectory(resolvedP) { - const index = this.zipImpl.addDirectory(ppath.relative(PortablePath.root, resolvedP)); - this.registerListing(resolvedP); - this.registerEntry(resolvedP, index); - return index; - } - async linkPromise(existingP, newP) { - return this.linkSync(existingP, newP); - } - linkSync(existingP, newP) { - throw EOPNOTSUPP(`link '${existingP}' -> '${newP}'`); - } - async symlinkPromise(target, p) { - return this.symlinkSync(target, p); - } - symlinkSync(target, p) { - if (this.readOnly) - throw EROFS(`symlink '${target}' -> '${p}'`); - const resolvedP = this.resolveFilename(`symlink '${target}' -> '${p}'`, p); - if (this.listings.has(resolvedP)) - throw EISDIR(`symlink '${target}' -> '${p}'`); - if (this.entries.has(resolvedP)) - throw EEXIST(`symlink '${target}' -> '${p}'`); - const index = this.setFileSource(resolvedP, target); - this.registerEntry(resolvedP, index); - this.zipImpl.setExternalAttributes(index, ZIP_UNIX, (fs.constants.S_IFLNK | 511) << 16); - this.symlinkCount += 1; - } - async readFilePromise(p, encoding) { - if (typeof encoding === `object`) - encoding = encoding ? encoding.encoding : void 0; - const data = await this.readFileBuffer(p, { asyncDecompress: true }); - return encoding ? data.toString(encoding) : data; - } - readFileSync(p, encoding) { - if (typeof encoding === `object`) - encoding = encoding ? encoding.encoding : void 0; - const data = this.readFileBuffer(p); - return encoding ? data.toString(encoding) : data; - } - readFileBuffer(p, opts = { asyncDecompress: false }) { - if (typeof p === `number`) - p = this.fdToPath(p, `read`); - const resolvedP = this.resolveFilename(`open '${p}'`, p); - if (!this.entries.has(resolvedP) && !this.listings.has(resolvedP)) - throw ENOENT(`open '${p}'`); - if (p[p.length - 1] === `/` && !this.listings.has(resolvedP)) - throw ENOTDIR(`open '${p}'`); - if (this.listings.has(resolvedP)) - throw EISDIR(`read`); - const entry = this.entries.get(resolvedP); - if (entry === void 0) - throw new Error(`Unreachable`); - return this.getFileSource(entry, opts); - } - async readdirPromise(p, opts) { - return this.readdirSync(p, opts); - } - readdirSync(p, opts) { - const resolvedP = this.resolveFilename(`scandir '${p}'`, p); - if (!this.entries.has(resolvedP) && !this.listings.has(resolvedP)) - throw ENOENT(`scandir '${p}'`); - const directoryListing = this.listings.get(resolvedP); - if (!directoryListing) - throw ENOTDIR(`scandir '${p}'`); - if (opts?.recursive) { - if (opts?.withFileTypes) { - const entries = Array.from(directoryListing, (name) => { - return Object.assign(this.statImpl(`lstat`, ppath.join(p, name)), { - name, - path: PortablePath.dot, - parentPath: PortablePath.dot - }); - }); - for (const entry of entries) { - if (!entry.isDirectory()) - continue; - const subPath = ppath.join(entry.path, entry.name); - const subListing = this.listings.get(ppath.join(resolvedP, subPath)); - for (const child of subListing) { - entries.push(Object.assign(this.statImpl(`lstat`, ppath.join(p, subPath, child)), { - name: child, - path: subPath, - parentPath: subPath - })); - } - } - return entries; - } else { - const entries = [...directoryListing]; - for (const subPath of entries) { - const subListing = this.listings.get(ppath.join(resolvedP, subPath)); - if (typeof subListing === `undefined`) - continue; - for (const child of subListing) { - entries.push(ppath.join(subPath, child)); - } - } - return entries; - } - } else if (opts?.withFileTypes) { - return Array.from(directoryListing, (name) => { - return Object.assign(this.statImpl(`lstat`, ppath.join(p, name)), { - name, - path: void 0, - parentPath: void 0 - }); - }); - } else { - return [...directoryListing]; - } - } - async readlinkPromise(p) { - const entry = this.prepareReadlink(p); - return (await this.getFileSource(entry, { asyncDecompress: true })).toString(); - } - readlinkSync(p) { - const entry = this.prepareReadlink(p); - return this.getFileSource(entry).toString(); - } - prepareReadlink(p) { - const resolvedP = this.resolveFilename(`readlink '${p}'`, p, false); - if (!this.entries.has(resolvedP) && !this.listings.has(resolvedP)) - throw ENOENT(`readlink '${p}'`); - if (p[p.length - 1] === `/` && !this.listings.has(resolvedP)) - throw ENOTDIR(`open '${p}'`); - if (this.listings.has(resolvedP)) - throw EINVAL(`readlink '${p}'`); - const entry = this.entries.get(resolvedP); - if (entry === void 0) - throw new Error(`Unreachable`); - if (!this.isSymbolicLink(entry)) - throw EINVAL(`readlink '${p}'`); - return entry; - } - async truncatePromise(p, len = 0) { - const resolvedP = this.resolveFilename(`open '${p}'`, p); - const index = this.entries.get(resolvedP); - if (typeof index === `undefined`) - throw EINVAL(`open '${p}'`); - const source = await this.getFileSource(index, { asyncDecompress: true }); - const truncated = Buffer.alloc(len, 0); - source.copy(truncated); - return await this.writeFilePromise(p, truncated); - } - truncateSync(p, len = 0) { - const resolvedP = this.resolveFilename(`open '${p}'`, p); - const index = this.entries.get(resolvedP); - if (typeof index === `undefined`) - throw EINVAL(`open '${p}'`); - const source = this.getFileSource(index); - const truncated = Buffer.alloc(len, 0); - source.copy(truncated); - return this.writeFileSync(p, truncated); - } - async ftruncatePromise(fd, len) { - return this.truncatePromise(this.fdToPath(fd, `ftruncate`), len); - } - ftruncateSync(fd, len) { - return this.truncateSync(this.fdToPath(fd, `ftruncateSync`), len); - } - watch(p, a, b) { - let persistent; - switch (typeof a) { - case `function`: - case `string`: - case `undefined`: - { - persistent = true; - } - break; - default: - { - ({ persistent = true } = a); - } - break; - } - if (!persistent) - return { on: () => { - }, close: () => { - } }; - const interval = setInterval(() => { - }, 24 * 60 * 60 * 1e3); - return { - on: () => { - }, - close: () => { - clearInterval(interval); - } - }; - } - watchFile(p, a, b) { - const resolvedP = ppath.resolve(PortablePath.root, p); - return watchFile(this, resolvedP, a, b); - } - unwatchFile(p, cb) { - const resolvedP = ppath.resolve(PortablePath.root, p); - return unwatchFile(this, resolvedP, cb); - } -} - -const SIGNATURE = { - CENTRAL_DIRECTORY: 33639248, - END_OF_CENTRAL_DIRECTORY: 101010256 -}; -const noCommentCDSize = 22; -class JsZipImpl { - fd; - baseFs; - entries; - filesShouldBeCached = false; - constructor(opts) { - if (`buffer` in opts) - throw new Error(`Buffer based zip archives are not supported`); - if (!opts.readOnly) - throw new Error(`Writable zip archives are not supported`); - this.baseFs = opts.baseFs; - this.fd = this.baseFs.openSync(opts.path, `r`); - try { - this.entries = JsZipImpl.readZipSync(this.fd, this.baseFs, opts.size); - } catch (error) { - this.baseFs.closeSync(this.fd); - this.fd = `closed`; - throw error; - } - } - static readZipSync(fd, baseFs, fileSize) { - if (fileSize < noCommentCDSize) - throw new Error(`Invalid ZIP file: EOCD not found`); - let eocdOffset = -1; - let eocdBuffer = Buffer.alloc(noCommentCDSize); - baseFs.readSync( - fd, - eocdBuffer, - 0, - noCommentCDSize, - fileSize - noCommentCDSize - ); - if (eocdBuffer.readUInt32LE(0) === SIGNATURE.END_OF_CENTRAL_DIRECTORY) { - eocdOffset = 0; - } else { - const bufferSize = Math.min(65557, fileSize); - eocdBuffer = Buffer.alloc(bufferSize); - baseFs.readSync( - fd, - eocdBuffer, - 0, - bufferSize, - Math.max(0, fileSize - bufferSize) - ); - for (let i = eocdBuffer.length - 4; i >= 0; i--) { - if (eocdBuffer.readUInt32LE(i) === SIGNATURE.END_OF_CENTRAL_DIRECTORY) { - eocdOffset = i; - break; - } - } - if (eocdOffset === -1) { - throw new Error(`Not a zip archive`); - } - } - const totalEntries = eocdBuffer.readUInt16LE(eocdOffset + 10); - const centralDirSize = eocdBuffer.readUInt32LE(eocdOffset + 12); - const centralDirOffset = eocdBuffer.readUInt32LE(eocdOffset + 16); - const commentLength = eocdBuffer.readUInt16LE(eocdOffset + 20); - if (eocdOffset + commentLength + noCommentCDSize > eocdBuffer.length) - throw new Error(`Zip archive inconsistent`); - if (totalEntries == 65535 || centralDirSize == 4294967295 || centralDirOffset == 4294967295) - throw new Error(`Zip 64 is not supported`); - if (centralDirSize > fileSize) - throw new Error(`Zip archive inconsistent`); - if (totalEntries > centralDirSize / 46) - throw new Error(`Zip archive inconsistent`); - const cdBuffer = Buffer.alloc(centralDirSize); - if (baseFs.readSync(fd, cdBuffer, 0, cdBuffer.length, centralDirOffset) !== cdBuffer.length) - throw new Error(`Zip archive inconsistent`); - const entries = []; - let offset = 0; - let index = 0; - let sumCompressedSize = 0; - while (index < totalEntries) { - if (offset + 46 > cdBuffer.length) - throw new Error(`Zip archive inconsistent`); - if (cdBuffer.readUInt32LE(offset) !== SIGNATURE.CENTRAL_DIRECTORY) - throw new Error(`Zip archive inconsistent`); - const versionMadeBy = cdBuffer.readUInt16LE(offset + 4); - const os = versionMadeBy >>> 8; - const flags = cdBuffer.readUInt16LE(offset + 8); - if ((flags & 1) !== 0) - throw new Error(`Encrypted zip files are not supported`); - const compressionMethod = cdBuffer.readUInt16LE(offset + 10); - const crc = cdBuffer.readUInt32LE(offset + 16); - const nameLength = cdBuffer.readUInt16LE(offset + 28); - const extraLength = cdBuffer.readUInt16LE(offset + 30); - const commentLength2 = cdBuffer.readUInt16LE(offset + 32); - const localHeaderOffset = cdBuffer.readUInt32LE(offset + 42); - const name = cdBuffer.toString(`utf8`, offset + 46, offset + 46 + nameLength).replaceAll(`\0`, ` `); - if (name.includes(`\0`)) - throw new Error(`Invalid ZIP file`); - const compressedSize = cdBuffer.readUInt32LE(offset + 20); - const externalAttributes = cdBuffer.readUInt32LE(offset + 38); - entries.push({ - name, - os, - mtime: SAFE_TIME, - //we dont care, - crc, - compressionMethod, - isSymbolicLink: os === ZIP_UNIX && (externalAttributes >>> 16 & S_IFMT) === S_IFLNK, - size: cdBuffer.readUInt32LE(offset + 24), - compressedSize, - externalAttributes, - localHeaderOffset - }); - sumCompressedSize += compressedSize; - index += 1; - offset += 46 + nameLength + extraLength + commentLength2; - } - if (sumCompressedSize > fileSize) - throw new Error(`Zip archive inconsistent`); - if (offset !== cdBuffer.length) - throw new Error(`Zip archive inconsistent`); - return entries; - } - getExternalAttributes(index) { - const entry = this.entries[index]; - return [entry.os, entry.externalAttributes]; - } - getListings() { - return this.entries.map((e) => e.name); - } - getSymlinkCount() { - let count = 0; - for (const entry of this.entries) - if (entry.isSymbolicLink) - count += 1; - return count; - } - stat(index) { - const entry = this.entries[index]; - return { - crc: entry.crc, - mtime: entry.mtime, - size: entry.size - }; - } - locate(name) { - for (let ind = 0; ind < this.entries.length; ind++) - if (this.entries[ind].name === name) - return ind; - return -1; - } - getFileSource(index) { - if (this.fd === `closed`) - throw new Error(`ZIP file is closed`); - const entry = this.entries[index]; - const localHeaderBuf = Buffer.alloc(30); - this.baseFs.readSync( - this.fd, - localHeaderBuf, - 0, - localHeaderBuf.length, - entry.localHeaderOffset - ); - const nameLength = localHeaderBuf.readUInt16LE(26); - const extraLength = localHeaderBuf.readUInt16LE(28); - const buffer = Buffer.alloc(entry.compressedSize); - if (this.baseFs.readSync(this.fd, buffer, 0, entry.compressedSize, entry.localHeaderOffset + 30 + nameLength + extraLength) !== entry.compressedSize) - throw new Error(`Invalid ZIP file`); - return { data: buffer, compressionMethod: entry.compressionMethod }; - } - discard() { - if (this.fd !== `closed`) { - this.baseFs.closeSync(this.fd); - this.fd = `closed`; - } - } - addDirectory(path) { - throw new Error(`Not implemented`); - } - deleteEntry(index) { - throw new Error(`Not implemented`); - } - setMtime(index, mtime) { - throw new Error(`Not implemented`); - } - getBufferAndClose() { - throw new Error(`Not implemented`); - } - setFileSource(target, compression, buffer) { - throw new Error(`Not implemented`); - } - setExternalAttributes(index, opsys, attributes) { - throw new Error(`Not implemented`); - } -} - -setFactory(() => { - const emZip = createModule(); - return makeInterface(emZip); -}); - -var ErrorCode = /* @__PURE__ */ ((ErrorCode2) => { - ErrorCode2["API_ERROR"] = `API_ERROR`; - ErrorCode2["BUILTIN_NODE_RESOLUTION_FAILED"] = `BUILTIN_NODE_RESOLUTION_FAILED`; - ErrorCode2["EXPORTS_RESOLUTION_FAILED"] = `EXPORTS_RESOLUTION_FAILED`; - ErrorCode2["MISSING_DEPENDENCY"] = `MISSING_DEPENDENCY`; - ErrorCode2["MISSING_PEER_DEPENDENCY"] = `MISSING_PEER_DEPENDENCY`; - ErrorCode2["QUALIFIED_PATH_RESOLUTION_FAILED"] = `QUALIFIED_PATH_RESOLUTION_FAILED`; - ErrorCode2["INTERNAL"] = `INTERNAL`; - ErrorCode2["UNDECLARED_DEPENDENCY"] = `UNDECLARED_DEPENDENCY`; - ErrorCode2["UNSUPPORTED"] = `UNSUPPORTED`; - return ErrorCode2; -})(ErrorCode || {}); -const MODULE_NOT_FOUND_ERRORS = /* @__PURE__ */ new Set([ - "BUILTIN_NODE_RESOLUTION_FAILED" /* BUILTIN_NODE_RESOLUTION_FAILED */, - "MISSING_DEPENDENCY" /* MISSING_DEPENDENCY */, - "MISSING_PEER_DEPENDENCY" /* MISSING_PEER_DEPENDENCY */, - "QUALIFIED_PATH_RESOLUTION_FAILED" /* QUALIFIED_PATH_RESOLUTION_FAILED */, - "UNDECLARED_DEPENDENCY" /* UNDECLARED_DEPENDENCY */ -]); -function makeError(pnpCode, message, data = {}, code) { - code ??= MODULE_NOT_FOUND_ERRORS.has(pnpCode) ? `MODULE_NOT_FOUND` : pnpCode; - const propertySpec = { - configurable: true, - writable: true, - enumerable: false - }; - return Object.defineProperties(new Error(message), { - code: { - ...propertySpec, - value: code - }, - pnpCode: { - ...propertySpec, - value: pnpCode - }, - data: { - ...propertySpec, - value: data - } - }); -} -function getIssuerModule(parent) { - let issuer = parent; - while (issuer && (issuer.id === `[eval]` || issuer.id === `` || !issuer.filename)) - issuer = issuer.parent; - return issuer || null; -} -function getPathForDisplay(p) { - return npath.normalize(npath.fromPortablePath(p)); -} - -const [major, minor] = process.versions.node.split(`.`).map((value) => parseInt(value, 10)); -const WATCH_MODE_MESSAGE_USES_ARRAYS = major > 19 || major === 19 && minor >= 2 || major === 18 && minor >= 13; - -function readPackageScope(checkPath) { - const rootSeparatorIndex = checkPath.indexOf(npath.sep); - let separatorIndex; - do { - separatorIndex = checkPath.lastIndexOf(npath.sep); - checkPath = checkPath.slice(0, separatorIndex); - if (checkPath.endsWith(`${npath.sep}node_modules`)) - return false; - const pjson = readPackage(checkPath + npath.sep); - if (pjson) { - return { - data: pjson, - path: checkPath - }; - } - } while (separatorIndex > rootSeparatorIndex); - return false; -} -function readPackage(requestPath) { - const jsonPath = npath.resolve(requestPath, `package.json`); - if (!fs__default.default.existsSync(jsonPath)) - return null; - return JSON.parse(fs__default.default.readFileSync(jsonPath, `utf8`)); -} -function ERR_REQUIRE_ESM(filename, parentPath = null) { - const basename = parentPath && path__default.default.basename(filename) === path__default.default.basename(parentPath) ? filename : path__default.default.basename(filename); - const msg = `require() of ES Module ${filename}${parentPath ? ` from ${parentPath}` : ``} not supported. -Instead change the require of ${basename} in ${parentPath} to a dynamic import() which is available in all CommonJS modules.`; - const err = new Error(msg); - err.code = `ERR_REQUIRE_ESM`; - return err; -} -function reportRequiredFilesToWatchMode(files) { - if (process.env.WATCH_REPORT_DEPENDENCIES && process.send) { - files = files.map((filename) => npath.fromPortablePath(VirtualFS.resolveVirtual(npath.toPortablePath(filename)))); - if (WATCH_MODE_MESSAGE_USES_ARRAYS) { - process.send({ "watch:require": files }); - } else { - for (const filename of files) { - process.send({ "watch:require": filename }); - } - } - } -} - -function applyPatch(pnpapi, opts) { - let enableNativeHooks = true; - process.versions.pnp = String(pnpapi.VERSIONS.std); - const moduleExports = require$$0__default.default; - moduleExports.findPnpApi = (lookupSource) => { - const lookupPath = lookupSource instanceof URL ? url.fileURLToPath(lookupSource) : lookupSource; - const apiPath = opts.manager.findApiPathFor(lookupPath); - if (apiPath === null) - return null; - const apiEntry = opts.manager.getApiEntry(apiPath, true); - return apiEntry.instance.findPackageLocator(lookupPath) ? apiEntry.instance : null; - }; - function getRequireStack(parent) { - const requireStack = []; - for (let cursor = parent; cursor; cursor = cursor.parent) - requireStack.push(cursor.filename || cursor.id); - return requireStack; - } - const originalModuleLoad = require$$0.Module._load; - require$$0.Module._load = function(request, parent, isMain) { - if (request === `pnpapi`) { - const parentApiPath = opts.manager.getApiPathFromParent(parent); - if (parentApiPath) { - return opts.manager.getApiEntry(parentApiPath, true).instance; - } - } - return originalModuleLoad.call(require$$0.Module, request, parent, isMain); - }; - function getIssuerSpecsFromPaths(paths) { - return paths.map((path) => ({ - apiPath: opts.manager.findApiPathFor(path), - path, - module: null - })); - } - function getIssuerSpecsFromModule(module) { - if (module && module.id !== `` && module.id !== `internal/preload` && !module.parent && !module.filename && module.paths.length > 0) { - return [{ - apiPath: opts.manager.findApiPathFor(module.paths[0]), - path: module.paths[0], - module - }]; - } - const issuer = getIssuerModule(module); - if (issuer !== null) { - const path = npath.dirname(issuer.filename); - const apiPath = opts.manager.getApiPathFromParent(issuer); - return [{ apiPath, path, module }]; - } else { - const path = process.cwd(); - const apiPath = opts.manager.findApiPathFor(npath.join(path, `[file]`)) ?? opts.manager.getApiPathFromParent(null); - return [{ apiPath, path, module }]; - } - } - function makeFakeParent(path) { - const fakeParent = new require$$0.Module(``); - const fakeFilePath = npath.join(path, `[file]`); - fakeParent.paths = require$$0.Module._nodeModulePaths(fakeFilePath); - return fakeParent; - } - const pathRegExp = /^(?![a-zA-Z]:[\\/]|\\\\|\.{0,2}(?:\/|$))((?:@[^/]+\/)?[^/]+)\/*(.*|)$/; - const originalModuleResolveFilename = require$$0.Module._resolveFilename; - require$$0.Module._resolveFilename = function(request, parent, isMain, options) { - if (require$$0.isBuiltin(request)) - return request; - if (!enableNativeHooks) - return originalModuleResolveFilename.call(require$$0.Module, request, parent, isMain, options); - if (options && options.plugnplay === false) { - const { plugnplay, ...forwardedOptions } = options; - try { - enableNativeHooks = false; - return originalModuleResolveFilename.call(require$$0.Module, request, parent, isMain, forwardedOptions); - } finally { - enableNativeHooks = true; - } - } - if (options) { - const optionNames = new Set(Object.keys(options)); - optionNames.delete(`paths`); - optionNames.delete(`plugnplay`); - optionNames.delete(`conditions`); - if (optionNames.size > 0) { - throw makeError( - ErrorCode.UNSUPPORTED, - `Some options passed to require() aren't supported by PnP yet (${Array.from(optionNames).join(`, `)})` - ); - } - } - const issuerSpecs = options && options.paths ? getIssuerSpecsFromPaths(options.paths) : getIssuerSpecsFromModule(parent); - if (request.match(pathRegExp) === null) { - const parentDirectory = parent?.filename != null ? npath.dirname(parent.filename) : null; - const absoluteRequest = npath.isAbsolute(request) ? request : parentDirectory !== null ? npath.resolve(parentDirectory, request) : null; - if (absoluteRequest !== null) { - const apiPath = parent && parentDirectory === npath.dirname(absoluteRequest) ? opts.manager.getApiPathFromParent(parent) : opts.manager.findApiPathFor(absoluteRequest); - if (apiPath !== null) { - issuerSpecs.unshift({ - apiPath, - path: parentDirectory, - module: null - }); - } - } - } - let firstError; - for (const { apiPath, path, module } of issuerSpecs) { - let resolution; - const issuerApi = apiPath !== null ? opts.manager.getApiEntry(apiPath, true).instance : null; - try { - if (issuerApi !== null) { - resolution = issuerApi.resolveRequest(request, path !== null ? `${path}/` : null, { - conditions: options?.conditions - }); - } else { - if (path === null) - throw new Error(`Assertion failed: Expected the path to be set`); - resolution = originalModuleResolveFilename.call(require$$0.Module, request, module || makeFakeParent(path), isMain, { - conditions: options?.conditions - }); - } - } catch (error) { - firstError = firstError || error; - continue; - } - if (resolution !== null) { - return resolution; - } - } - const requireStack = getRequireStack(parent); - Object.defineProperty(firstError, `requireStack`, { - configurable: true, - writable: true, - enumerable: false, - value: requireStack - }); - if (requireStack.length > 0) - firstError.message += ` -Require stack: -- ${requireStack.join(` -- `)}`; - if (typeof firstError.pnpCode === `string`) - Error.captureStackTrace(firstError); - throw firstError; - }; - const originalFindPath = require$$0.Module._findPath; - require$$0.Module._findPath = function(request, paths, isMain) { - if (request === `pnpapi`) - return false; - if (!enableNativeHooks) - return originalFindPath.call(require$$0.Module, request, paths, isMain); - const isAbsolute = npath.isAbsolute(request); - if (isAbsolute) - paths = [``]; - else if (!paths || paths.length === 0) - return false; - for (const path of paths) { - let resolution; - try { - const pnpApiPath = opts.manager.findApiPathFor(isAbsolute ? request : path); - if (pnpApiPath !== null) { - const api = opts.manager.getApiEntry(pnpApiPath, true).instance; - resolution = api.resolveRequest(request, path) || false; - } else { - resolution = originalFindPath.call(require$$0.Module, request, [path], isMain); - } - } catch { - continue; - } - if (resolution) { - return resolution; - } - } - return false; - }; - if (!process.features.require_module) { - const originalExtensionJSFunction = require$$0.Module._extensions[`.js`]; - require$$0.Module._extensions[`.js`] = function(module, filename) { - if (filename.endsWith(`.js`)) { - const pkg = readPackageScope(filename); - if (pkg && pkg.data?.type === `module`) { - const err = ERR_REQUIRE_ESM(filename, module.parent?.filename); - Error.captureStackTrace(err); - throw err; - } - } - originalExtensionJSFunction.call(this, module, filename); - }; - } - const originalDlopen = process.dlopen; - process.dlopen = function(...args) { - const [module, filename, ...rest] = args; - return originalDlopen.call( - this, - module, - npath.fromPortablePath(VirtualFS.resolveVirtual(npath.toPortablePath(filename))), - ...rest - ); - }; - const originalEmit = process.emit; - process.emit = function(name, data, ...args) { - if (name === `warning` && typeof data === `object` && data.name === `ExperimentalWarning` && (data.message.includes(`--experimental-loader`) || data.message.includes(`Custom ESM Loaders is an experimental feature`))) - return false; - return originalEmit.apply(process, arguments); - }; - patchFs(fs__default.default, new PosixFS(opts.fakeFs)); -} - -function hydrateRuntimeState(data, { basePath }) { - const portablePath = npath.toPortablePath(basePath); - const absolutePortablePath = ppath.resolve(portablePath); - const ignorePattern = data.ignorePatternData !== null ? new RegExp(data.ignorePatternData) : null; - const packageLocatorsByLocations = /* @__PURE__ */ new Map(); - const packageRegistry = new Map(data.packageRegistryData.map(([packageName, packageStoreData]) => { - return [packageName, new Map(packageStoreData.map(([packageReference, packageInformationData]) => { - if (packageName === null !== (packageReference === null)) - throw new Error(`Assertion failed: The name and reference should be null, or neither should`); - const discardFromLookup = packageInformationData.discardFromLookup ?? false; - const packageLocator = { name: packageName, reference: packageReference }; - const entry = packageLocatorsByLocations.get(packageInformationData.packageLocation); - if (!entry) { - packageLocatorsByLocations.set(packageInformationData.packageLocation, { locator: packageLocator, discardFromLookup }); - } else { - entry.discardFromLookup = entry.discardFromLookup && discardFromLookup; - if (!discardFromLookup) { - entry.locator = packageLocator; - } - } - let resolvedPackageLocation = null; - return [packageReference, { - packageDependencies: new Map(packageInformationData.packageDependencies), - packagePeers: new Set(packageInformationData.packagePeers), - linkType: packageInformationData.linkType, - discardFromLookup, - // we only need this for packages that are used by the currently running script - // this is a lazy getter because `ppath.join` has some overhead - get packageLocation() { - return resolvedPackageLocation || (resolvedPackageLocation = ppath.join(absolutePortablePath, packageInformationData.packageLocation)); - } - }]; - }))]; - })); - const fallbackExclusionList = new Map(data.fallbackExclusionList.map(([packageName, packageReferences]) => { - return [packageName, new Set(packageReferences)]; - })); - const fallbackPool = new Map(data.fallbackPool); - const dependencyTreeRoots = data.dependencyTreeRoots; - const enableTopLevelFallback = data.enableTopLevelFallback; - return { - basePath: portablePath, - dependencyTreeRoots, - enableTopLevelFallback, - fallbackExclusionList, - pnpZipBackend: data.pnpZipBackend, - fallbackPool, - ignorePattern, - packageLocatorsByLocations, - packageRegistry - }; -} - -const ArrayIsArray = Array.isArray; -const JSONStringify = JSON.stringify; -const ObjectGetOwnPropertyNames = Object.getOwnPropertyNames; -const ObjectPrototypeHasOwnProperty = (obj, prop) => Object.prototype.hasOwnProperty.call(obj, prop); -const RegExpPrototypeExec = (obj, string) => RegExp.prototype.exec.call(obj, string); -const RegExpPrototypeSymbolReplace = (obj, ...rest) => RegExp.prototype[Symbol.replace].apply(obj, rest); -const StringPrototypeEndsWith = (str, ...rest) => String.prototype.endsWith.apply(str, rest); -const StringPrototypeIncludes = (str, ...rest) => String.prototype.includes.apply(str, rest); -const StringPrototypeLastIndexOf = (str, ...rest) => String.prototype.lastIndexOf.apply(str, rest); -const StringPrototypeIndexOf = (str, ...rest) => String.prototype.indexOf.apply(str, rest); -const StringPrototypeReplace = (str, ...rest) => String.prototype.replace.apply(str, rest); -const StringPrototypeSlice = (str, ...rest) => String.prototype.slice.apply(str, rest); -const StringPrototypeStartsWith = (str, ...rest) => String.prototype.startsWith.apply(str, rest); -const SafeMap = Map; -const JSONParse = JSON.parse; - -function createErrorType(code, messageCreator, errorType) { - return class extends errorType { - constructor(...args) { - super(messageCreator(...args)); - this.code = code; - this.name = `${errorType.name} [${code}]`; - } - }; -} -const ERR_PACKAGE_IMPORT_NOT_DEFINED = createErrorType( - `ERR_PACKAGE_IMPORT_NOT_DEFINED`, - (specifier, packagePath, base) => { - return `Package import specifier "${specifier}" is not defined${packagePath ? ` in package ${packagePath}package.json` : ``} imported from ${base}`; - }, - TypeError -); -const ERR_INVALID_MODULE_SPECIFIER = createErrorType( - `ERR_INVALID_MODULE_SPECIFIER`, - (request, reason, base = void 0) => { - return `Invalid module "${request}" ${reason}${base ? ` imported from ${base}` : ``}`; - }, - TypeError -); -const ERR_INVALID_PACKAGE_TARGET = createErrorType( - `ERR_INVALID_PACKAGE_TARGET`, - (pkgPath, key, target, isImport = false, base = void 0) => { - const relError = typeof target === `string` && !isImport && target.length && !StringPrototypeStartsWith(target, `./`); - if (key === `.`) { - assert__default.default(isImport === false); - return `Invalid "exports" main target ${JSONStringify(target)} defined in the package config ${pkgPath}package.json${base ? ` imported from ${base}` : ``}${relError ? `; targets must start with "./"` : ``}`; - } - return `Invalid "${isImport ? `imports` : `exports`}" target ${JSONStringify( - target - )} defined for '${key}' in the package config ${pkgPath}package.json${base ? ` imported from ${base}` : ``}${relError ? `; targets must start with "./"` : ``}`; - }, - Error -); -const ERR_INVALID_PACKAGE_CONFIG = createErrorType( - `ERR_INVALID_PACKAGE_CONFIG`, - (path, base, message) => { - return `Invalid package config ${path}${base ? ` while importing ${base}` : ``}${message ? `. ${message}` : ``}`; - }, - Error -); -const ERR_PACKAGE_PATH_NOT_EXPORTED = createErrorType( - "ERR_PACKAGE_PATH_NOT_EXPORTED", - (pkgPath, subpath, base = void 0) => { - if (subpath === ".") - return `No "exports" main defined in ${pkgPath}package.json${base ? ` imported from ${base}` : ""}`; - return `Package subpath '${subpath}' is not defined by "exports" in ${pkgPath}package.json${base ? ` imported from ${base}` : ""}`; - }, - Error -); - -function filterOwnProperties(source, keys) { - const filtered = /* @__PURE__ */ Object.create(null); - for (let i = 0; i < keys.length; i++) { - const key = keys[i]; - if (ObjectPrototypeHasOwnProperty(source, key)) { - filtered[key] = source[key]; - } - } - return filtered; -} - -const packageJSONCache = new SafeMap(); -function getPackageConfig(path, specifier, base, readFileSyncFn) { - const existing = packageJSONCache.get(path); - if (existing !== void 0) { - return existing; - } - const source = readFileSyncFn(path); - if (source === void 0) { - const packageConfig2 = { - pjsonPath: path, - exists: false, - main: void 0, - name: void 0, - type: "none", - exports: void 0, - imports: void 0 - }; - packageJSONCache.set(path, packageConfig2); - return packageConfig2; - } - let packageJSON; - try { - packageJSON = JSONParse(source); - } catch (error) { - throw new ERR_INVALID_PACKAGE_CONFIG( - path, - (base ? `"${specifier}" from ` : "") + url.fileURLToPath(base || specifier), - error.message - ); - } - let { imports, main, name, type } = filterOwnProperties(packageJSON, [ - "imports", - "main", - "name", - "type" - ]); - const exports = ObjectPrototypeHasOwnProperty(packageJSON, "exports") ? packageJSON.exports : void 0; - if (typeof imports !== "object" || imports === null) { - imports = void 0; - } - if (typeof main !== "string") { - main = void 0; - } - if (typeof name !== "string") { - name = void 0; - } - if (type !== "module" && type !== "commonjs") { - type = "none"; - } - const packageConfig = { - pjsonPath: path, - exists: true, - main, - name, - type, - exports, - imports - }; - packageJSONCache.set(path, packageConfig); - return packageConfig; -} -function getPackageScopeConfig(resolved, readFileSyncFn) { - let packageJSONUrl = new URL("./package.json", resolved); - while (true) { - const packageJSONPath2 = packageJSONUrl.pathname; - if (StringPrototypeEndsWith(packageJSONPath2, "node_modules/package.json")) { - break; - } - const packageConfig2 = getPackageConfig( - url.fileURLToPath(packageJSONUrl), - resolved, - void 0, - readFileSyncFn - ); - if (packageConfig2.exists) { - return packageConfig2; - } - const lastPackageJSONUrl = packageJSONUrl; - packageJSONUrl = new URL("../package.json", packageJSONUrl); - if (packageJSONUrl.pathname === lastPackageJSONUrl.pathname) { - break; - } - } - const packageJSONPath = url.fileURLToPath(packageJSONUrl); - const packageConfig = { - pjsonPath: packageJSONPath, - exists: false, - main: void 0, - name: void 0, - type: "none", - exports: void 0, - imports: void 0 - }; - packageJSONCache.set(packageJSONPath, packageConfig); - return packageConfig; -} - -function throwImportNotDefined(specifier, packageJSONUrl, base) { - throw new ERR_PACKAGE_IMPORT_NOT_DEFINED( - specifier, - packageJSONUrl && url.fileURLToPath(new URL(".", packageJSONUrl)), - url.fileURLToPath(base) - ); -} -function throwInvalidSubpath(subpath, packageJSONUrl, internal, base) { - const reason = `request is not a valid subpath for the "${internal ? "imports" : "exports"}" resolution of ${url.fileURLToPath(packageJSONUrl)}`; - throw new ERR_INVALID_MODULE_SPECIFIER( - subpath, - reason, - base && url.fileURLToPath(base) - ); -} -function throwInvalidPackageTarget(subpath, target, packageJSONUrl, internal, base) { - if (typeof target === "object" && target !== null) { - target = JSONStringify(target, null, ""); - } else { - target = `${target}`; - } - throw new ERR_INVALID_PACKAGE_TARGET( - url.fileURLToPath(new URL(".", packageJSONUrl)), - subpath, - target, - internal, - base && url.fileURLToPath(base) - ); -} -const invalidSegmentRegEx = /(^|\\|\/)((\.|%2e)(\.|%2e)?|(n|%6e|%4e)(o|%6f|%4f)(d|%64|%44)(e|%65|%45)(_|%5f)(m|%6d|%4d)(o|%6f|%4f)(d|%64|%44)(u|%75|%55)(l|%6c|%4c)(e|%65|%45)(s|%73|%53))(\\|\/|$)/i; -const patternRegEx = /\*/g; -function resolvePackageTargetString(target, subpath, match, packageJSONUrl, base, pattern, internal, conditions) { - if (subpath !== "" && !pattern && target[target.length - 1] !== "/") - throwInvalidPackageTarget(match, target, packageJSONUrl, internal, base); - if (!StringPrototypeStartsWith(target, "./")) { - if (internal && !StringPrototypeStartsWith(target, "../") && !StringPrototypeStartsWith(target, "/")) { - let isURL = false; - try { - new URL(target); - isURL = true; - } catch { - } - if (!isURL) { - const exportTarget = pattern ? RegExpPrototypeSymbolReplace(patternRegEx, target, () => subpath) : target + subpath; - return exportTarget; - } - } - throwInvalidPackageTarget(match, target, packageJSONUrl, internal, base); - } - if (RegExpPrototypeExec( - invalidSegmentRegEx, - StringPrototypeSlice(target, 2) - ) !== null) - throwInvalidPackageTarget(match, target, packageJSONUrl, internal, base); - const resolved = new URL(target, packageJSONUrl); - const resolvedPath = resolved.pathname; - const packagePath = new URL(".", packageJSONUrl).pathname; - if (!StringPrototypeStartsWith(resolvedPath, packagePath)) - throwInvalidPackageTarget(match, target, packageJSONUrl, internal, base); - if (subpath === "") return resolved; - if (RegExpPrototypeExec(invalidSegmentRegEx, subpath) !== null) { - const request = pattern ? StringPrototypeReplace(match, "*", () => subpath) : match + subpath; - throwInvalidSubpath(request, packageJSONUrl, internal, base); - } - if (pattern) { - return new URL( - RegExpPrototypeSymbolReplace(patternRegEx, resolved.href, () => subpath) - ); - } - return new URL(subpath, resolved); -} -function isArrayIndex(key) { - const keyNum = +key; - if (`${keyNum}` !== key) return false; - return keyNum >= 0 && keyNum < 4294967295; -} -function resolvePackageTarget(packageJSONUrl, target, subpath, packageSubpath, base, pattern, internal, conditions) { - if (typeof target === "string") { - return resolvePackageTargetString( - target, - subpath, - packageSubpath, - packageJSONUrl, - base, - pattern, - internal); - } else if (ArrayIsArray(target)) { - if (target.length === 0) { - return null; - } - let lastException; - for (let i = 0; i < target.length; i++) { - const targetItem = target[i]; - let resolveResult; - try { - resolveResult = resolvePackageTarget( - packageJSONUrl, - targetItem, - subpath, - packageSubpath, - base, - pattern, - internal, - conditions - ); - } catch (e) { - lastException = e; - if (e.code === "ERR_INVALID_PACKAGE_TARGET") { - continue; - } - throw e; - } - if (resolveResult === void 0) { - continue; - } - if (resolveResult === null) { - lastException = null; - continue; - } - return resolveResult; - } - if (lastException === void 0 || lastException === null) - return lastException; - throw lastException; - } else if (typeof target === "object" && target !== null) { - const keys = ObjectGetOwnPropertyNames(target); - for (let i = 0; i < keys.length; i++) { - const key = keys[i]; - if (isArrayIndex(key)) { - throw new ERR_INVALID_PACKAGE_CONFIG( - url.fileURLToPath(packageJSONUrl), - base, - '"exports" cannot contain numeric property keys.' - ); - } - } - for (let i = 0; i < keys.length; i++) { - const key = keys[i]; - if (key === "default" || conditions.has(key)) { - const conditionalTarget = target[key]; - const resolveResult = resolvePackageTarget( - packageJSONUrl, - conditionalTarget, - subpath, - packageSubpath, - base, - pattern, - internal, - conditions - ); - if (resolveResult === void 0) continue; - return resolveResult; - } - } - return void 0; - } else if (target === null) { - return null; - } - throwInvalidPackageTarget( - packageSubpath, - target, - packageJSONUrl, - internal, - base - ); -} -function patternKeyCompare(a, b) { - const aPatternIndex = StringPrototypeIndexOf(a, "*"); - const bPatternIndex = StringPrototypeIndexOf(b, "*"); - const baseLenA = aPatternIndex === -1 ? a.length : aPatternIndex + 1; - const baseLenB = bPatternIndex === -1 ? b.length : bPatternIndex + 1; - if (baseLenA > baseLenB) return -1; - if (baseLenB > baseLenA) return 1; - if (aPatternIndex === -1) return 1; - if (bPatternIndex === -1) return -1; - if (a.length > b.length) return -1; - if (b.length > a.length) return 1; - return 0; -} -function isConditionalExportsMainSugar(exports, packageJSONUrl, base) { - if (typeof exports === "string" || ArrayIsArray(exports)) return true; - if (typeof exports !== "object" || exports === null) return false; - const keys = ObjectGetOwnPropertyNames(exports); - let isConditionalSugar = false; - let i = 0; - for (let j = 0; j < keys.length; j++) { - const key = keys[j]; - const curIsConditionalSugar = key === "" || key[0] !== "."; - if (i++ === 0) { - isConditionalSugar = curIsConditionalSugar; - } else if (isConditionalSugar !== curIsConditionalSugar) { - throw new ERR_INVALID_PACKAGE_CONFIG( - url.fileURLToPath(packageJSONUrl), - base, - `"exports" cannot contain some keys starting with '.' and some not. The exports object must either be an object of package subpath keys or an object of main entry condition name keys only.` - ); - } - } - return isConditionalSugar; -} -function throwExportsNotFound(subpath, packageJSONUrl, base) { - throw new ERR_PACKAGE_PATH_NOT_EXPORTED( - url.fileURLToPath(new URL(".", packageJSONUrl)), - subpath, - base && url.fileURLToPath(base) - ); -} -const emittedPackageWarnings = /* @__PURE__ */ new Set(); -function emitTrailingSlashPatternDeprecation(match, pjsonUrl, base) { - const pjsonPath = url.fileURLToPath(pjsonUrl); - if (emittedPackageWarnings.has(pjsonPath + "|" + match)) return; - emittedPackageWarnings.add(pjsonPath + "|" + match); - process.emitWarning( - `Use of deprecated trailing slash pattern mapping "${match}" in the "exports" field module resolution of the package at ${pjsonPath}${base ? ` imported from ${url.fileURLToPath(base)}` : ""}. Mapping specifiers ending in "/" is no longer supported.`, - "DeprecationWarning", - "DEP0155" - ); -} -function packageExportsResolve({ - packageJSONUrl, - packageSubpath, - exports, - base, - conditions -}) { - if (isConditionalExportsMainSugar(exports, packageJSONUrl, base)) - exports = { ".": exports }; - if (ObjectPrototypeHasOwnProperty(exports, packageSubpath) && !StringPrototypeIncludes(packageSubpath, "*") && !StringPrototypeEndsWith(packageSubpath, "/")) { - const target = exports[packageSubpath]; - const resolveResult = resolvePackageTarget( - packageJSONUrl, - target, - "", - packageSubpath, - base, - false, - false, - conditions - ); - if (resolveResult == null) { - throwExportsNotFound(packageSubpath, packageJSONUrl, base); - } - return resolveResult; - } - let bestMatch = ""; - let bestMatchSubpath; - const keys = ObjectGetOwnPropertyNames(exports); - for (let i = 0; i < keys.length; i++) { - const key = keys[i]; - const patternIndex = StringPrototypeIndexOf(key, "*"); - if (patternIndex !== -1 && StringPrototypeStartsWith( - packageSubpath, - StringPrototypeSlice(key, 0, patternIndex) - )) { - if (StringPrototypeEndsWith(packageSubpath, "/")) - emitTrailingSlashPatternDeprecation( - packageSubpath, - packageJSONUrl, - base - ); - const patternTrailer = StringPrototypeSlice(key, patternIndex + 1); - if (packageSubpath.length >= key.length && StringPrototypeEndsWith(packageSubpath, patternTrailer) && patternKeyCompare(bestMatch, key) === 1 && StringPrototypeLastIndexOf(key, "*") === patternIndex) { - bestMatch = key; - bestMatchSubpath = StringPrototypeSlice( - packageSubpath, - patternIndex, - packageSubpath.length - patternTrailer.length - ); - } - } - } - if (bestMatch) { - const target = exports[bestMatch]; - const resolveResult = resolvePackageTarget( - packageJSONUrl, - target, - bestMatchSubpath, - bestMatch, - base, - true, - false, - conditions - ); - if (resolveResult == null) { - throwExportsNotFound(packageSubpath, packageJSONUrl, base); - } - return resolveResult; - } - throwExportsNotFound(packageSubpath, packageJSONUrl, base); -} -function packageImportsResolve({ name, base, conditions, readFileSyncFn }) { - if (name === "#" || StringPrototypeStartsWith(name, "#/") || StringPrototypeEndsWith(name, "/")) { - const reason = "is not a valid internal imports specifier name"; - throw new ERR_INVALID_MODULE_SPECIFIER(name, reason, url.fileURLToPath(base)); - } - let packageJSONUrl; - const packageConfig = getPackageScopeConfig(base, readFileSyncFn); - if (packageConfig.exists) { - packageJSONUrl = url.pathToFileURL(packageConfig.pjsonPath); - const imports = packageConfig.imports; - if (imports) { - if (ObjectPrototypeHasOwnProperty(imports, name) && !StringPrototypeIncludes(name, "*")) { - const resolveResult = resolvePackageTarget( - packageJSONUrl, - imports[name], - "", - name, - base, - false, - true, - conditions - ); - if (resolveResult != null) { - return resolveResult; - } - } else { - let bestMatch = ""; - let bestMatchSubpath; - const keys = ObjectGetOwnPropertyNames(imports); - for (let i = 0; i < keys.length; i++) { - const key = keys[i]; - const patternIndex = StringPrototypeIndexOf(key, "*"); - if (patternIndex !== -1 && StringPrototypeStartsWith( - name, - StringPrototypeSlice(key, 0, patternIndex) - )) { - const patternTrailer = StringPrototypeSlice(key, patternIndex + 1); - if (name.length >= key.length && StringPrototypeEndsWith(name, patternTrailer) && patternKeyCompare(bestMatch, key) === 1 && StringPrototypeLastIndexOf(key, "*") === patternIndex) { - bestMatch = key; - bestMatchSubpath = StringPrototypeSlice( - name, - patternIndex, - name.length - patternTrailer.length - ); - } - } - } - if (bestMatch) { - const target = imports[bestMatch]; - const resolveResult = resolvePackageTarget( - packageJSONUrl, - target, - bestMatchSubpath, - bestMatch, - base, - true, - true, - conditions - ); - if (resolveResult != null) { - return resolveResult; - } - } - } - } - } - throwImportNotDefined(name, packageJSONUrl, base); -} - -const flagSymbol = Symbol('arg flag'); - -class ArgError extends Error { - constructor(msg, code) { - super(msg); - this.name = 'ArgError'; - this.code = code; - - Object.setPrototypeOf(this, ArgError.prototype); - } -} - -function arg( - opts, - { - argv = process.argv.slice(2), - permissive = false, - stopAtPositional = false - } = {} -) { - if (!opts) { - throw new ArgError( - 'argument specification object is required', - 'ARG_CONFIG_NO_SPEC' - ); - } - - const result = { _: [] }; - - const aliases = {}; - const handlers = {}; - - for (const key of Object.keys(opts)) { - if (!key) { - throw new ArgError( - 'argument key cannot be an empty string', - 'ARG_CONFIG_EMPTY_KEY' - ); - } - - if (key[0] !== '-') { - throw new ArgError( - `argument key must start with '-' but found: '${key}'`, - 'ARG_CONFIG_NONOPT_KEY' - ); - } - - if (key.length === 1) { - throw new ArgError( - `argument key must have a name; singular '-' keys are not allowed: ${key}`, - 'ARG_CONFIG_NONAME_KEY' - ); - } - - if (typeof opts[key] === 'string') { - aliases[key] = opts[key]; - continue; - } - - let type = opts[key]; - let isFlag = false; - - if ( - Array.isArray(type) && - type.length === 1 && - typeof type[0] === 'function' - ) { - const [fn] = type; - type = (value, name, prev = []) => { - prev.push(fn(value, name, prev[prev.length - 1])); - return prev; - }; - isFlag = fn === Boolean || fn[flagSymbol] === true; - } else if (typeof type === 'function') { - isFlag = type === Boolean || type[flagSymbol] === true; - } else { - throw new ArgError( - `type missing or not a function or valid array type: ${key}`, - 'ARG_CONFIG_VAD_TYPE' - ); - } - - if (key[1] !== '-' && key.length > 2) { - throw new ArgError( - `short argument keys (with a single hyphen) must have only one character: ${key}`, - 'ARG_CONFIG_SHORTOPT_TOOLONG' - ); - } - - handlers[key] = [type, isFlag]; - } - - for (let i = 0, len = argv.length; i < len; i++) { - const wholeArg = argv[i]; - - if (stopAtPositional && result._.length > 0) { - result._ = result._.concat(argv.slice(i)); - break; - } - - if (wholeArg === '--') { - result._ = result._.concat(argv.slice(i + 1)); - break; - } - - if (wholeArg.length > 1 && wholeArg[0] === '-') { - /* eslint-disable operator-linebreak */ - const separatedArguments = - wholeArg[1] === '-' || wholeArg.length === 2 - ? [wholeArg] - : wholeArg - .slice(1) - .split('') - .map((a) => `-${a}`); - /* eslint-enable operator-linebreak */ - - for (let j = 0; j < separatedArguments.length; j++) { - const arg = separatedArguments[j]; - const [originalArgName, argStr] = - arg[1] === '-' ? arg.split(/=(.*)/, 2) : [arg, undefined]; - - let argName = originalArgName; - while (argName in aliases) { - argName = aliases[argName]; - } - - if (!(argName in handlers)) { - if (permissive) { - result._.push(arg); - continue; - } else { - throw new ArgError( - `unknown or unexpected option: ${originalArgName}`, - 'ARG_UNKNOWN_OPTION' - ); - } - } - - const [type, isFlag] = handlers[argName]; - - if (!isFlag && j + 1 < separatedArguments.length) { - throw new ArgError( - `option requires argument (but was followed by another short argument): ${originalArgName}`, - 'ARG_MISSING_REQUIRED_SHORTARG' - ); - } - - if (isFlag) { - result[argName] = type(true, argName, result[argName]); - } else if (argStr === undefined) { - if ( - argv.length < i + 2 || - (argv[i + 1].length > 1 && - argv[i + 1][0] === '-' && - !( - argv[i + 1].match(/^-?\d*(\.(?=\d))?\d*$/) && - (type === Number || - // eslint-disable-next-line no-undef - (typeof BigInt !== 'undefined' && type === BigInt)) - )) - ) { - const extended = - originalArgName === argName ? '' : ` (alias for ${argName})`; - throw new ArgError( - `option requires argument: ${originalArgName}${extended}`, - 'ARG_MISSING_REQUIRED_LONGARG' - ); - } - - result[argName] = type(argv[i + 1], argName, result[argName]); - ++i; - } else { - result[argName] = type(argStr, argName, result[argName]); - } - } - } else { - result._.push(wholeArg); - } - } - - return result; -} - -arg.flag = (fn) => { - fn[flagSymbol] = true; - return fn; -}; - -// Utility types -arg.COUNT = arg.flag((v, name, existingCount) => (existingCount || 0) + 1); - -// Expose error class -arg.ArgError = ArgError; - -var arg_1 = arg; - -/** - @license - The MIT License (MIT) - - Copyright (c) 2014 Blake Embrey (hello@blakeembrey.com) - - Permission is hereby granted, free of charge, to any person obtaining a copy - of this software and associated documentation files (the "Software"), to deal - in the Software without restriction, including without limitation the rights - to use, copy, modify, merge, publish, distribute, sublicense, and/or sell - copies of the Software, and to permit persons to whom the Software is - furnished to do so, subject to the following conditions: - - The above copyright notice and this permission notice shall be included in - all copies or substantial portions of the Software. - - THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR - IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE - AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER - LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, - OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN - THE SOFTWARE. -*/ -function getOptionValue(opt) { - parseOptions(); - return options[opt]; -} -let options; -function parseOptions() { - if (!options) { - options = { - "--conditions": [], - ...parseArgv(getNodeOptionsEnvArgv()), - ...parseArgv(process.execArgv) - }; - } -} -function parseArgv(argv) { - return arg_1( - { - "--conditions": [String], - "-C": "--conditions" - }, - { - argv, - permissive: true - } - ); -} -function getNodeOptionsEnvArgv() { - const errors = []; - const envArgv = ParseNodeOptionsEnvVar(process.env.NODE_OPTIONS || "", errors); - if (errors.length !== 0) ; - return envArgv; -} -function ParseNodeOptionsEnvVar(node_options, errors) { - const env_argv = []; - let is_in_string = false; - let will_start_new_arg = true; - for (let index = 0; index < node_options.length; ++index) { - let c = node_options[index]; - if (c === "\\" && is_in_string) { - if (index + 1 === node_options.length) { - errors.push("invalid value for NODE_OPTIONS (invalid escape)\n"); - return env_argv; - } else { - c = node_options[++index]; - } - } else if (c === " " && !is_in_string) { - will_start_new_arg = true; - continue; - } else if (c === '"') { - is_in_string = !is_in_string; - continue; - } - if (will_start_new_arg) { - env_argv.push(c); - will_start_new_arg = false; - } else { - env_argv[env_argv.length - 1] += c; - } - } - if (is_in_string) { - errors.push("invalid value for NODE_OPTIONS (unterminated string)\n"); - } - return env_argv; -} - -function makeApi(runtimeState, opts) { - const alwaysWarnOnFallback = Number(process.env.PNP_ALWAYS_WARN_ON_FALLBACK) > 0; - const debugLevel = Number(process.env.PNP_DEBUG_LEVEL); - const pathRegExp = /^(?![a-zA-Z]:[\\/]|\\\\|\.{0,2}(?:\/|$))((?:node:)?(?:@[^/]+\/)?[^/]+)\/*(.*|)$/; - const isStrictRegExp = /^(\/|\.{1,2}(\/|$))/; - const isDirRegExp = /\/$/; - const isRelativeRegexp = /^\.{0,2}\//; - const topLevelLocator = { name: null, reference: null }; - const fallbackLocators = []; - const emittedWarnings = /* @__PURE__ */ new Set(); - if (runtimeState.enableTopLevelFallback === true) - fallbackLocators.push(topLevelLocator); - if (opts.compatibilityMode !== false) { - for (const name of [`react-scripts`, `gatsby`]) { - const packageStore = runtimeState.packageRegistry.get(name); - if (packageStore) { - for (const reference of packageStore.keys()) { - if (reference === null) { - throw new Error(`Assertion failed: This reference shouldn't be null`); - } else { - fallbackLocators.push({ name, reference }); - } - } - } - } - } - const { - ignorePattern, - packageRegistry, - packageLocatorsByLocations - } = runtimeState; - function makeLogEntry(name, args) { - return { - fn: name, - args, - error: null, - result: null - }; - } - function trace(entry) { - const colors = process.stderr?.hasColors?.() ?? process.stdout.isTTY; - const c = (n, str) => `\x1B[${n}m${str}\x1B[0m`; - const error = entry.error; - if (error) - console.error(c(`31;1`, `\u2716 ${entry.error?.message.replace(/\n.*/s, ``)}`)); - else - console.error(c(`33;1`, `\u203C Resolution`)); - if (entry.args.length > 0) - console.error(); - for (const arg of entry.args) - console.error(` ${c(`37;1`, `In \u2190`)} ${nodeUtils.inspect(arg, { colors, compact: true })}`); - if (entry.result) { - console.error(); - console.error(` ${c(`37;1`, `Out \u2192`)} ${nodeUtils.inspect(entry.result, { colors, compact: true })}`); - } - const stack = new Error().stack.match(/(?<=^ +)at.*/gm)?.slice(2) ?? []; - if (stack.length > 0) { - console.error(); - for (const line of stack) { - console.error(` ${c(`38;5;244`, line)}`); - } - } - console.error(); - } - function maybeLog(name, fn) { - if (opts.allowDebug === false) - return fn; - if (Number.isFinite(debugLevel)) { - if (debugLevel >= 2) { - return (...args) => { - const logEntry = makeLogEntry(name, args); - try { - return logEntry.result = fn(...args); - } catch (error) { - throw logEntry.error = error; - } finally { - trace(logEntry); - } - }; - } else if (debugLevel >= 1) { - return (...args) => { - try { - return fn(...args); - } catch (error) { - const logEntry = makeLogEntry(name, args); - logEntry.error = error; - trace(logEntry); - throw error; - } - }; - } - } - return fn; - } - function getPackageInformationSafe(packageLocator) { - const packageInformation = getPackageInformation(packageLocator); - if (!packageInformation) { - throw makeError( - ErrorCode.INTERNAL, - `Couldn't find a matching entry in the dependency tree for the specified parent (this is probably an internal error)` - ); - } - return packageInformation; - } - function isDependencyTreeRoot(packageLocator) { - if (packageLocator.name === null) - return true; - for (const dependencyTreeRoot of runtimeState.dependencyTreeRoots) - if (dependencyTreeRoot.name === packageLocator.name && dependencyTreeRoot.reference === packageLocator.reference) - return true; - return false; - } - const defaultExportsConditions = /* @__PURE__ */ new Set([ - `node`, - `require`, - ...getOptionValue(`--conditions`) - ]); - function applyNodeExportsResolution(unqualifiedPath, conditions = defaultExportsConditions, issuer) { - const locator = findPackageLocator(ppath.join(unqualifiedPath, `internal.js`), { - resolveIgnored: true, - includeDiscardFromLookup: true - }); - if (locator === null) { - throw makeError( - ErrorCode.INTERNAL, - `The locator that owns the "${unqualifiedPath}" path can't be found inside the dependency tree (this is probably an internal error)` - ); - } - const { packageLocation } = getPackageInformationSafe(locator); - const manifestPath = ppath.join(packageLocation, Filename.manifest); - if (!opts.fakeFs.existsSync(manifestPath)) - return null; - const pkgJson = JSON.parse(opts.fakeFs.readFileSync(manifestPath, `utf8`)); - if (pkgJson.exports == null) - return null; - let subpath = ppath.contains(packageLocation, unqualifiedPath); - if (subpath === null) { - throw makeError( - ErrorCode.INTERNAL, - `unqualifiedPath doesn't contain the packageLocation (this is probably an internal error)` - ); - } - if (subpath !== `.` && !isRelativeRegexp.test(subpath)) - subpath = `./${subpath}`; - try { - const resolvedExport = packageExportsResolve({ - packageJSONUrl: url.pathToFileURL(npath.fromPortablePath(manifestPath)), - packageSubpath: subpath, - exports: pkgJson.exports, - base: issuer ? url.pathToFileURL(npath.fromPortablePath(issuer)) : null, - conditions - }); - return npath.toPortablePath(url.fileURLToPath(resolvedExport)); - } catch (error) { - throw makeError( - ErrorCode.EXPORTS_RESOLUTION_FAILED, - error.message, - { unqualifiedPath: getPathForDisplay(unqualifiedPath), locator, pkgJson, subpath: getPathForDisplay(subpath), conditions }, - error.code - ); - } - } - function applyNodeExtensionResolution(unqualifiedPath, candidates, { extensions }) { - let stat; - try { - candidates.push(unqualifiedPath); - stat = opts.fakeFs.statSync(unqualifiedPath); - } catch { - } - if (stat && !stat.isDirectory()) - return opts.fakeFs.realpathSync(unqualifiedPath); - if (stat && stat.isDirectory()) { - let pkgJson; - try { - pkgJson = JSON.parse(opts.fakeFs.readFileSync(ppath.join(unqualifiedPath, Filename.manifest), `utf8`)); - } catch { - } - let nextUnqualifiedPath; - if (pkgJson && pkgJson.main) - nextUnqualifiedPath = ppath.resolve(unqualifiedPath, pkgJson.main); - if (nextUnqualifiedPath && nextUnqualifiedPath !== unqualifiedPath) { - const resolution = applyNodeExtensionResolution(nextUnqualifiedPath, candidates, { extensions }); - if (resolution !== null) { - return resolution; - } - } - } - for (let i = 0, length = extensions.length; i < length; i++) { - const candidateFile = `${unqualifiedPath}${extensions[i]}`; - candidates.push(candidateFile); - if (opts.fakeFs.existsSync(candidateFile)) { - return candidateFile; - } - } - if (stat && stat.isDirectory()) { - for (let i = 0, length = extensions.length; i < length; i++) { - const candidateFile = ppath.format({ dir: unqualifiedPath, name: `index`, ext: extensions[i] }); - candidates.push(candidateFile); - if (opts.fakeFs.existsSync(candidateFile)) { - return candidateFile; - } - } - } - return null; - } - function makeFakeModule(path) { - const fakeModule = new require$$0.Module(path, null); - fakeModule.filename = path; - fakeModule.paths = require$$0.Module._nodeModulePaths(path); - return fakeModule; - } - function callNativeResolution(request, issuer) { - if (issuer.endsWith(`/`)) - issuer = ppath.join(issuer, `internal.js`); - return require$$0.Module._resolveFilename(npath.fromPortablePath(request), makeFakeModule(npath.fromPortablePath(issuer)), false, { plugnplay: false }); - } - function isPathIgnored(path) { - if (ignorePattern === null) - return false; - const subPath = ppath.contains(runtimeState.basePath, path); - if (subPath === null) - return false; - if (ignorePattern.test(subPath.replace(/\/$/, ``))) { - return true; - } else { - return false; - } - } - const VERSIONS = { std: 3, resolveVirtual: 1, getAllLocators: 1 }; - const topLevel = topLevelLocator; - function getPackageInformation({ name, reference }) { - const packageInformationStore = packageRegistry.get(name); - if (!packageInformationStore) - return null; - const packageInformation = packageInformationStore.get(reference); - if (!packageInformation) - return null; - return packageInformation; - } - function findPackageDependents({ name, reference }) { - const dependents = []; - for (const [dependentName, packageInformationStore] of packageRegistry) { - if (dependentName === null) - continue; - for (const [dependentReference, packageInformation] of packageInformationStore) { - if (dependentReference === null) - continue; - const dependencyReference = packageInformation.packageDependencies.get(name); - if (dependencyReference !== reference) - continue; - if (dependentName === name && dependentReference === reference) - continue; - dependents.push({ - name: dependentName, - reference: dependentReference - }); - } - } - return dependents; - } - function findBrokenPeerDependencies(dependency, initialPackage) { - const brokenPackages = /* @__PURE__ */ new Map(); - const alreadyVisited = /* @__PURE__ */ new Set(); - const traversal = (currentPackage) => { - const identifier = JSON.stringify(currentPackage.name); - if (alreadyVisited.has(identifier)) - return; - alreadyVisited.add(identifier); - const dependents = findPackageDependents(currentPackage); - for (const dependent of dependents) { - const dependentInformation = getPackageInformationSafe(dependent); - if (dependentInformation.packagePeers.has(dependency)) { - traversal(dependent); - } else { - let brokenSet = brokenPackages.get(dependent.name); - if (typeof brokenSet === `undefined`) - brokenPackages.set(dependent.name, brokenSet = /* @__PURE__ */ new Set()); - brokenSet.add(dependent.reference); - } - } - }; - traversal(initialPackage); - const brokenList = []; - for (const name of [...brokenPackages.keys()].sort()) - for (const reference of [...brokenPackages.get(name)].sort()) - brokenList.push({ name, reference }); - return brokenList; - } - function findPackageLocator(location, { resolveIgnored = false, includeDiscardFromLookup = false } = {}) { - if (isPathIgnored(location) && !resolveIgnored) - return null; - let relativeLocation = ppath.relative(runtimeState.basePath, location); - if (!relativeLocation.match(isStrictRegExp)) - relativeLocation = `./${relativeLocation}`; - if (!relativeLocation.endsWith(`/`)) - relativeLocation = `${relativeLocation}/`; - do { - const entry = packageLocatorsByLocations.get(relativeLocation); - if (typeof entry === `undefined` || entry.discardFromLookup && !includeDiscardFromLookup) { - relativeLocation = relativeLocation.substring(0, relativeLocation.lastIndexOf(`/`, relativeLocation.length - 2) + 1); - continue; - } - return entry.locator; - } while (relativeLocation !== ``); - return null; - } - function tryReadFile(filePath) { - try { - return opts.fakeFs.readFileSync(npath.toPortablePath(filePath), `utf8`); - } catch (err) { - if (err.code === `ENOENT`) - return void 0; - throw err; - } - } - function resolveToUnqualified(request, issuer, { considerBuiltins = true } = {}) { - if (request.startsWith(`#`)) - throw new Error(`resolveToUnqualified can not handle private import mappings`); - if (request === `pnpapi`) - return npath.toPortablePath(opts.pnpapiResolution); - if (considerBuiltins && require$$0.isBuiltin(request)) - return null; - const requestForDisplay = getPathForDisplay(request); - const issuerForDisplay = issuer && getPathForDisplay(issuer); - if (issuer && isPathIgnored(issuer)) { - if (!ppath.isAbsolute(request) || findPackageLocator(request) === null) { - const result = callNativeResolution(request, issuer); - if (result === false) { - throw makeError( - ErrorCode.BUILTIN_NODE_RESOLUTION_FAILED, - `The builtin node resolution algorithm was unable to resolve the requested module (it didn't go through the pnp resolver because the issuer was explicitely ignored by the regexp) - -Require request: "${requestForDisplay}" -Required by: ${issuerForDisplay} -`, - { request: requestForDisplay, issuer: issuerForDisplay } - ); - } - return npath.toPortablePath(result); - } - } - let unqualifiedPath; - const dependencyNameMatch = request.match(pathRegExp); - if (!dependencyNameMatch) { - if (ppath.isAbsolute(request)) { - unqualifiedPath = ppath.normalize(request); - } else { - if (!issuer) { - throw makeError( - ErrorCode.API_ERROR, - `The resolveToUnqualified function must be called with a valid issuer when the path isn't a builtin nor absolute`, - { request: requestForDisplay, issuer: issuerForDisplay } - ); - } - const absoluteIssuer = ppath.resolve(issuer); - if (issuer.match(isDirRegExp)) { - unqualifiedPath = ppath.normalize(ppath.join(absoluteIssuer, request)); - } else { - unqualifiedPath = ppath.normalize(ppath.join(ppath.dirname(absoluteIssuer), request)); - } - } - } else { - if (!issuer) { - throw makeError( - ErrorCode.API_ERROR, - `The resolveToUnqualified function must be called with a valid issuer when the path isn't a builtin nor absolute`, - { request: requestForDisplay, issuer: issuerForDisplay } - ); - } - const [, dependencyName, subPath] = dependencyNameMatch; - const issuerLocator = findPackageLocator(issuer); - if (!issuerLocator) { - const result = callNativeResolution(request, issuer); - if (result === false) { - throw makeError( - ErrorCode.BUILTIN_NODE_RESOLUTION_FAILED, - `The builtin node resolution algorithm was unable to resolve the requested module (it didn't go through the pnp resolver because the issuer doesn't seem to be part of the Yarn-managed dependency tree). - -Require path: "${requestForDisplay}" -Required by: ${issuerForDisplay} -`, - { request: requestForDisplay, issuer: issuerForDisplay } - ); - } - return npath.toPortablePath(result); - } - const issuerInformation = getPackageInformationSafe(issuerLocator); - let dependencyReference = issuerInformation.packageDependencies.get(dependencyName); - let fallbackReference = null; - if (dependencyReference == null) { - if (issuerLocator.name !== null) { - const exclusionEntry = runtimeState.fallbackExclusionList.get(issuerLocator.name); - const canUseFallbacks = !exclusionEntry || !exclusionEntry.has(issuerLocator.reference); - if (canUseFallbacks) { - for (let t = 0, T = fallbackLocators.length; t < T; ++t) { - const fallbackInformation = getPackageInformationSafe(fallbackLocators[t]); - const reference = fallbackInformation.packageDependencies.get(dependencyName); - if (reference == null) - continue; - if (alwaysWarnOnFallback) - fallbackReference = reference; - else - dependencyReference = reference; - break; - } - if (runtimeState.enableTopLevelFallback) { - if (dependencyReference == null && fallbackReference === null) { - const reference = runtimeState.fallbackPool.get(dependencyName); - if (reference != null) { - fallbackReference = reference; - } - } - } - } - } - } - let error = null; - if (dependencyReference === null) { - if (isDependencyTreeRoot(issuerLocator)) { - error = makeError( - ErrorCode.MISSING_PEER_DEPENDENCY, - `Your application tried to access ${dependencyName} (a peer dependency); this isn't allowed as there is no ancestor to satisfy the requirement. Use a devDependency if needed. - -Required package: ${dependencyName}${dependencyName !== requestForDisplay ? ` (via "${requestForDisplay}")` : ``} -Required by: ${issuerForDisplay} -`, - { request: requestForDisplay, issuer: issuerForDisplay, dependencyName } - ); - } else { - const brokenAncestors = findBrokenPeerDependencies(dependencyName, issuerLocator); - if (brokenAncestors.every((ancestor) => isDependencyTreeRoot(ancestor))) { - error = makeError( - ErrorCode.MISSING_PEER_DEPENDENCY, - `${issuerLocator.name} tried to access ${dependencyName} (a peer dependency) but it isn't provided by your application; this makes the require call ambiguous and unsound. - -Required package: ${dependencyName}${dependencyName !== requestForDisplay ? ` (via "${requestForDisplay}")` : ``} -Required by: ${issuerLocator.name}@${issuerLocator.reference} (via ${issuerForDisplay}) -${brokenAncestors.map((ancestorLocator) => `Ancestor breaking the chain: ${ancestorLocator.name}@${ancestorLocator.reference} -`).join(``)} -`, - { request: requestForDisplay, issuer: issuerForDisplay, issuerLocator: Object.assign({}, issuerLocator), dependencyName, brokenAncestors } - ); - } else { - error = makeError( - ErrorCode.MISSING_PEER_DEPENDENCY, - `${issuerLocator.name} tried to access ${dependencyName} (a peer dependency) but it isn't provided by its ancestors; this makes the require call ambiguous and unsound. - -Required package: ${dependencyName}${dependencyName !== requestForDisplay ? ` (via "${requestForDisplay}")` : ``} -Required by: ${issuerLocator.name}@${issuerLocator.reference} (via ${issuerForDisplay}) - -${brokenAncestors.map((ancestorLocator) => `Ancestor breaking the chain: ${ancestorLocator.name}@${ancestorLocator.reference} -`).join(``)} -`, - { request: requestForDisplay, issuer: issuerForDisplay, issuerLocator: Object.assign({}, issuerLocator), dependencyName, brokenAncestors } - ); - } - } - } else if (dependencyReference === void 0) { - if (!considerBuiltins && require$$0.isBuiltin(request)) { - if (isDependencyTreeRoot(issuerLocator)) { - error = makeError( - ErrorCode.UNDECLARED_DEPENDENCY, - `Your application tried to access ${dependencyName}. While this module is usually interpreted as a Node builtin, your resolver is running inside a non-Node resolution context where such builtins are ignored. Since ${dependencyName} isn't otherwise declared in your dependencies, this makes the require call ambiguous and unsound. - -Required package: ${dependencyName}${dependencyName !== requestForDisplay ? ` (via "${requestForDisplay}")` : ``} -Required by: ${issuerForDisplay} -`, - { request: requestForDisplay, issuer: issuerForDisplay, dependencyName } - ); - } else { - error = makeError( - ErrorCode.UNDECLARED_DEPENDENCY, - `${issuerLocator.name} tried to access ${dependencyName}. While this module is usually interpreted as a Node builtin, your resolver is running inside a non-Node resolution context where such builtins are ignored. Since ${dependencyName} isn't otherwise declared in ${issuerLocator.name}'s dependencies, this makes the require call ambiguous and unsound. - -Required package: ${dependencyName}${dependencyName !== requestForDisplay ? ` (via "${requestForDisplay}")` : ``} -Required by: ${issuerForDisplay} -`, - { request: requestForDisplay, issuer: issuerForDisplay, issuerLocator: Object.assign({}, issuerLocator), dependencyName } - ); - } - } else { - if (isDependencyTreeRoot(issuerLocator)) { - error = makeError( - ErrorCode.UNDECLARED_DEPENDENCY, - `Your application tried to access ${dependencyName}, but it isn't declared in your dependencies; this makes the require call ambiguous and unsound. - -Required package: ${dependencyName}${dependencyName !== requestForDisplay ? ` (via "${requestForDisplay}")` : ``} -Required by: ${issuerForDisplay} -`, - { request: requestForDisplay, issuer: issuerForDisplay, dependencyName } - ); - } else { - error = makeError( - ErrorCode.UNDECLARED_DEPENDENCY, - `${issuerLocator.name} tried to access ${dependencyName}, but it isn't declared in its dependencies; this makes the require call ambiguous and unsound. - -Required package: ${dependencyName}${dependencyName !== requestForDisplay ? ` (via "${requestForDisplay}")` : ``} -Required by: ${issuerLocator.name}@${issuerLocator.reference} (via ${issuerForDisplay}) -`, - { request: requestForDisplay, issuer: issuerForDisplay, issuerLocator: Object.assign({}, issuerLocator), dependencyName } - ); - } - } - } - if (dependencyReference == null) { - if (fallbackReference === null || error === null) - throw error || new Error(`Assertion failed: Expected an error to have been set`); - dependencyReference = fallbackReference; - const message = error.message.replace(/\n.*/g, ``); - error.message = message; - if (!emittedWarnings.has(message) && debugLevel !== 0) { - emittedWarnings.add(message); - process.emitWarning(error); - } - } - const dependencyLocator = Array.isArray(dependencyReference) ? { name: dependencyReference[0], reference: dependencyReference[1] } : { name: dependencyName, reference: dependencyReference }; - const dependencyInformation = getPackageInformationSafe(dependencyLocator); - if (!dependencyInformation.packageLocation) { - throw makeError( - ErrorCode.MISSING_DEPENDENCY, - `A dependency seems valid but didn't get installed for some reason. This might be caused by a partial install, such as dev vs prod. - -Required package: ${dependencyLocator.name}@${dependencyLocator.reference}${dependencyLocator.name !== requestForDisplay ? ` (via "${requestForDisplay}")` : ``} -Required by: ${issuerLocator.name}@${issuerLocator.reference} (via ${issuerForDisplay}) -`, - { request: requestForDisplay, issuer: issuerForDisplay, dependencyLocator: Object.assign({}, dependencyLocator) } - ); - } - const dependencyLocation = dependencyInformation.packageLocation; - if (subPath) { - unqualifiedPath = ppath.join(dependencyLocation, subPath); - } else { - unqualifiedPath = dependencyLocation; - } - } - return ppath.normalize(unqualifiedPath); - } - function resolveUnqualifiedExport(request, unqualifiedPath, conditions = defaultExportsConditions, issuer) { - if (isStrictRegExp.test(request)) - return unqualifiedPath; - const unqualifiedExportPath = applyNodeExportsResolution(unqualifiedPath, conditions, issuer); - if (unqualifiedExportPath) { - return ppath.normalize(unqualifiedExportPath); - } else { - return unqualifiedPath; - } - } - function resolveUnqualified(unqualifiedPath, { extensions = Object.keys(require$$0.Module._extensions) } = {}) { - const candidates = []; - const qualifiedPath = applyNodeExtensionResolution(unqualifiedPath, candidates, { extensions }); - if (qualifiedPath) { - return ppath.normalize(qualifiedPath); - } else { - reportRequiredFilesToWatchMode(candidates.map((candidate) => npath.fromPortablePath(candidate))); - const unqualifiedPathForDisplay = getPathForDisplay(unqualifiedPath); - const containingPackage = findPackageLocator(unqualifiedPath); - if (containingPackage) { - const { packageLocation } = getPackageInformationSafe(containingPackage); - let exists = true; - try { - opts.fakeFs.accessSync(packageLocation); - } catch (err) { - if (err?.code === `ENOENT`) { - exists = false; - } else { - const readableError = (err?.message ?? err ?? `empty exception thrown`).replace(/^[A-Z]/, ($0) => $0.toLowerCase()); - throw makeError(ErrorCode.QUALIFIED_PATH_RESOLUTION_FAILED, `Required package exists but could not be accessed (${readableError}). - -Missing package: ${containingPackage.name}@${containingPackage.reference} -Expected package location: ${getPathForDisplay(packageLocation)} -`, { unqualifiedPath: unqualifiedPathForDisplay, extensions }); - } - } - if (!exists) { - const errorMessage = packageLocation.includes(`/unplugged/`) ? `Required unplugged package missing from disk. This may happen when switching branches without running installs (unplugged packages must be fully materialized on disk to work).` : `Required package missing from disk. If you keep your packages inside your repository then restarting the Node process may be enough. Otherwise, try to run an install first.`; - throw makeError( - ErrorCode.QUALIFIED_PATH_RESOLUTION_FAILED, - `${errorMessage} - -Missing package: ${containingPackage.name}@${containingPackage.reference} -Expected package location: ${getPathForDisplay(packageLocation)} -`, - { unqualifiedPath: unqualifiedPathForDisplay, extensions } - ); - } - } - throw makeError( - ErrorCode.QUALIFIED_PATH_RESOLUTION_FAILED, - `Qualified path resolution failed: we looked for the following paths, but none could be accessed. - -Source path: ${unqualifiedPathForDisplay} -${candidates.map((candidate) => `Not found: ${getPathForDisplay(candidate)} -`).join(``)}`, - { unqualifiedPath: unqualifiedPathForDisplay, extensions } - ); - } - } - function resolvePrivateRequest(request, issuer, opts2) { - if (!issuer) - throw new Error(`Assertion failed: An issuer is required to resolve private import mappings`); - const resolved = packageImportsResolve({ - name: request, - base: url.pathToFileURL(npath.fromPortablePath(issuer)), - conditions: opts2.conditions ?? defaultExportsConditions, - readFileSyncFn: tryReadFile - }); - if (resolved instanceof URL) { - return resolveUnqualified(npath.toPortablePath(url.fileURLToPath(resolved)), { extensions: opts2.extensions }); - } else { - if (resolved.startsWith(`#`)) - throw new Error(`Mapping from one private import to another isn't allowed`); - return resolveRequest(resolved, issuer, opts2); - } - } - function resolveRequest(request, issuer, opts2 = {}) { - try { - if (request.startsWith(`#`)) - return resolvePrivateRequest(request, issuer, opts2); - const { considerBuiltins, extensions, conditions } = opts2; - const unqualifiedPath = resolveToUnqualified(request, issuer, { considerBuiltins }); - if (request === `pnpapi`) - return unqualifiedPath; - if (unqualifiedPath === null) - return null; - const isIssuerIgnored = () => issuer !== null ? isPathIgnored(issuer) : false; - const remappedPath = (!considerBuiltins || !require$$0.isBuiltin(request)) && !isIssuerIgnored() ? resolveUnqualifiedExport(request, unqualifiedPath, conditions, issuer) : unqualifiedPath; - return resolveUnqualified(remappedPath, { extensions }); - } catch (error) { - if (Object.hasOwn(error, `pnpCode`)) - Object.assign(error.data, { request: getPathForDisplay(request), issuer: issuer && getPathForDisplay(issuer) }); - throw error; - } - } - function resolveVirtual(request) { - const normalized = ppath.normalize(request); - const resolved = VirtualFS.resolveVirtual(normalized); - return resolved !== normalized ? resolved : null; - } - return { - VERSIONS, - topLevel, - getLocator: (name, referencish) => { - if (Array.isArray(referencish)) { - return { name: referencish[0], reference: referencish[1] }; - } else { - return { name, reference: referencish }; - } - }, - getDependencyTreeRoots: () => { - return [...runtimeState.dependencyTreeRoots]; - }, - getAllLocators() { - const locators = []; - for (const [name, entry] of packageRegistry) - for (const reference of entry.keys()) - if (name !== null && reference !== null) - locators.push({ name, reference }); - return locators; - }, - getPackageInformation: (locator) => { - const info = getPackageInformation(locator); - if (info === null) - return null; - const packageLocation = npath.fromPortablePath(info.packageLocation); - const nativeInfo = { ...info, packageLocation }; - return nativeInfo; - }, - findPackageLocator: (path) => { - return findPackageLocator(npath.toPortablePath(path)); - }, - resolveToUnqualified: maybeLog(`resolveToUnqualified`, (request, issuer, opts2) => { - const portableIssuer = issuer !== null ? npath.toPortablePath(issuer) : null; - const resolution = resolveToUnqualified(npath.toPortablePath(request), portableIssuer, opts2); - if (resolution === null) - return null; - return npath.fromPortablePath(resolution); - }), - resolveUnqualified: maybeLog(`resolveUnqualified`, (unqualifiedPath, opts2) => { - return npath.fromPortablePath(resolveUnqualified(npath.toPortablePath(unqualifiedPath), opts2)); - }), - resolveRequest: maybeLog(`resolveRequest`, (request, issuer, opts2) => { - const portableIssuer = issuer !== null ? npath.toPortablePath(issuer) : null; - const resolution = resolveRequest(npath.toPortablePath(request), portableIssuer, opts2); - if (resolution === null) - return null; - return npath.fromPortablePath(resolution); - }), - resolveVirtual: maybeLog(`resolveVirtual`, (path) => { - const result = resolveVirtual(npath.toPortablePath(path)); - if (result !== null) { - return npath.fromPortablePath(result); - } else { - return null; - } - }) - }; -} - -function makeManager(pnpapi, opts) { - const initialApiPath = npath.toPortablePath(pnpapi.resolveToUnqualified(`pnpapi`, null)); - const initialApiStats = opts.fakeFs.statSync(npath.toPortablePath(initialApiPath)); - const apiMetadata = /* @__PURE__ */ new Map([ - [initialApiPath, { - instance: pnpapi, - stats: initialApiStats, - lastRefreshCheck: Date.now() - }] - ]); - function loadApiInstance(pnpApiPath) { - const nativePath = npath.fromPortablePath(pnpApiPath); - const module = new require$$0.Module(nativePath, null); - module.load(nativePath); - return module.exports; - } - function refreshApiEntry(pnpApiPath, apiEntry) { - const timeNow = Date.now(); - if (timeNow - apiEntry.lastRefreshCheck < 500) - return; - apiEntry.lastRefreshCheck = timeNow; - const stats = opts.fakeFs.statSync(pnpApiPath); - if (stats.mtime > apiEntry.stats.mtime) { - process.emitWarning(`[Warning] The runtime detected new information in a PnP file; reloading the API instance (${npath.fromPortablePath(pnpApiPath)})`); - apiEntry.stats = stats; - apiEntry.instance = loadApiInstance(pnpApiPath); - } - } - function getApiEntry(pnpApiPath, refresh = false) { - let apiEntry = apiMetadata.get(pnpApiPath); - if (typeof apiEntry !== `undefined`) { - if (refresh) { - refreshApiEntry(pnpApiPath, apiEntry); - } - } else { - apiMetadata.set(pnpApiPath, apiEntry = { - instance: loadApiInstance(pnpApiPath), - stats: opts.fakeFs.statSync(pnpApiPath), - lastRefreshCheck: Date.now() - }); - } - return apiEntry; - } - const findApiPathCache = /* @__PURE__ */ new Map(); - function addToCacheAndReturn(start, end, target) { - if (target !== null) { - target = VirtualFS.resolveVirtual(target); - target = opts.fakeFs.realpathSync(target); - } - let curr; - let next = start; - do { - curr = next; - findApiPathCache.set(curr, target); - next = ppath.dirname(curr); - } while (curr !== end); - return target; - } - function findApiPathFor(modulePath) { - let bestCandidate = null; - for (const [apiPath, apiEntry] of apiMetadata) { - const locator = apiEntry.instance.findPackageLocator(modulePath); - if (!locator) - continue; - if (apiMetadata.size === 1) - return apiPath; - const packageInformation = apiEntry.instance.getPackageInformation(locator); - if (!packageInformation) - throw new Error(`Assertion failed: Couldn't get package information for '${modulePath}'`); - if (!bestCandidate) - bestCandidate = { packageLocation: packageInformation.packageLocation, apiPaths: [] }; - if (packageInformation.packageLocation === bestCandidate.packageLocation) { - bestCandidate.apiPaths.push(apiPath); - } else if (packageInformation.packageLocation.length > bestCandidate.packageLocation.length) { - bestCandidate = { packageLocation: packageInformation.packageLocation, apiPaths: [apiPath] }; - } - } - if (bestCandidate) { - if (bestCandidate.apiPaths.length === 1) - return bestCandidate.apiPaths[0]; - const controlSegment = bestCandidate.apiPaths.map((apiPath) => ` ${npath.fromPortablePath(apiPath)}`).join(` -`); - throw new Error(`Unable to locate pnpapi, the module '${modulePath}' is controlled by multiple pnpapi instances. -This is usually caused by using the global cache (enableGlobalCache: true) - -Controlled by: -${controlSegment} -`); - } - const start = ppath.resolve(npath.toPortablePath(modulePath)); - let curr; - let next = start; - do { - curr = next; - const cached = findApiPathCache.get(curr); - if (cached !== void 0) - return addToCacheAndReturn(start, curr, cached); - const cjsCandidate = ppath.join(curr, Filename.pnpCjs); - if (opts.fakeFs.existsSync(cjsCandidate) && opts.fakeFs.statSync(cjsCandidate).isFile()) - return addToCacheAndReturn(start, curr, cjsCandidate); - const legacyCjsCandidate = ppath.join(curr, Filename.pnpJs); - if (opts.fakeFs.existsSync(legacyCjsCandidate) && opts.fakeFs.statSync(legacyCjsCandidate).isFile()) - return addToCacheAndReturn(start, curr, legacyCjsCandidate); - next = ppath.dirname(curr); - } while (curr !== PortablePath.root); - return addToCacheAndReturn(start, curr, null); - } - const moduleToApiPathCache = /* @__PURE__ */ new WeakMap(); - function getApiPathFromParent(parent) { - if (parent == null) - return initialApiPath; - let apiPath = moduleToApiPathCache.get(parent); - if (typeof apiPath !== `undefined`) - return apiPath; - apiPath = parent.filename ? findApiPathFor(parent.filename) : null; - moduleToApiPathCache.set(parent, apiPath); - return apiPath; - } - return { - getApiPathFromParent, - findApiPathFor, - getApiEntry - }; -} - -const localFs = { ...fs__default.default }; -const nodeFs = new NodeFS(localFs); -const defaultRuntimeState = $$SETUP_STATE(hydrateRuntimeState); -const defaultPnpapiResolution = __filename; -const customZipImplementation = defaultRuntimeState.pnpZipBackend === `js` ? JsZipImpl : void 0; -const defaultFsLayer = new VirtualFS({ - baseFs: new ZipOpenFS({ - customZipImplementation, - baseFs: nodeFs, - maxOpenFiles: 80, - readOnlyArchives: true - }) -}); -class DynamicFS extends ProxiedFS { - baseFs = defaultFsLayer; - constructor() { - super(ppath); - } - mapToBase(p) { - return p; - } - mapFromBase(p) { - return p; - } -} -const dynamicFsLayer = new DynamicFS(); -let manager; -const defaultApi = Object.assign(makeApi(defaultRuntimeState, { - fakeFs: dynamicFsLayer, - pnpapiResolution: defaultPnpapiResolution -}), { - /** - * Can be used to generate a different API than the default one (for example - * to map it on `/` rather than the local directory path, or to use a - * different FS layer than the default one). - */ - makeApi: ({ - basePath = void 0, - fakeFs = dynamicFsLayer, - pnpapiResolution = defaultPnpapiResolution, - ...rest - }) => { - const apiRuntimeState = typeof basePath !== `undefined` ? $$SETUP_STATE(hydrateRuntimeState, basePath) : defaultRuntimeState; - return makeApi(apiRuntimeState, { - fakeFs, - pnpapiResolution, - ...rest - }); - }, - /** - * Will inject the specified API into the environment, monkey-patching FS. Is - * automatically called when the hook is loaded through `--require`. - */ - setup: (api) => { - applyPatch(api || defaultApi, { - fakeFs: defaultFsLayer, - manager - }); - dynamicFsLayer.baseFs = new NodeFS(fs__default.default); - } -}); -manager = makeManager(defaultApi, { - fakeFs: dynamicFsLayer -}); -if (module.parent && module.parent.id === `internal/preload`) { - defaultApi.setup(); - if (module.filename) { - delete require$$0__default.default._cache[module.filename]; - } -} -if (process.mainModule === module) { - const reportError = (code, message, data) => { - process.stdout.write(`${JSON.stringify([{ code, message, data }, null])} -`); - }; - const reportSuccess = (resolution) => { - process.stdout.write(`${JSON.stringify([null, resolution])} -`); - }; - const processResolution = (request, issuer) => { - try { - reportSuccess(defaultApi.resolveRequest(request, issuer)); - } catch (error) { - reportError(error.code, error.message, error.data); - } - }; - const processRequest = (data) => { - try { - const [request, issuer] = JSON.parse(data); - processResolution(request, issuer); - } catch (error) { - reportError(`INVALID_JSON`, error.message, error.data); - } - }; - if (process.argv.length > 2) { - if (process.argv.length !== 4) { - process.stderr.write(`Usage: ${process.argv[0]} ${process.argv[1]} -`); - process.exitCode = 64; - } else { - processResolution(process.argv[2], process.argv[3]); - } - } else { - let buffer = ``; - const decoder = new StringDecoder__default.default.StringDecoder(); - process.stdin.on(`data`, (chunk) => { - buffer += decoder.write(chunk); - do { - const index = buffer.indexOf(` -`); - if (index === -1) - break; - const line = buffer.slice(0, index); - buffer = buffer.slice(index + 1); - processRequest(line); - } while (true); - }); - } -} - -module.exports = defaultApi; diff --git a/.pnp.loader.mjs b/.pnp.loader.mjs deleted file mode 100644 index 2d5a584..0000000 --- a/.pnp.loader.mjs +++ /dev/null @@ -1,2126 +0,0 @@ -/* eslint-disable */ -// @ts-nocheck - -import fs from 'fs'; -import { URL as URL$1, fileURLToPath, pathToFileURL } from 'url'; -import path from 'path'; -import { createHash } from 'crypto'; -import { EOL } from 'os'; -import esmModule, { createRequire, isBuiltin } from 'module'; -import assert from 'assert'; - -const SAFE_TIME = 456789e3; - -const PortablePath = { - root: `/`, - dot: `.`, - parent: `..` -}; -const npath = Object.create(path); -const ppath = Object.create(path.posix); -npath.cwd = () => process.cwd(); -ppath.cwd = process.platform === `win32` ? () => toPortablePath(process.cwd()) : process.cwd; -if (process.platform === `win32`) { - ppath.resolve = (...segments) => { - if (segments.length > 0 && ppath.isAbsolute(segments[0])) { - return path.posix.resolve(...segments); - } else { - return path.posix.resolve(ppath.cwd(), ...segments); - } - }; -} -const contains = function(pathUtils, from, to) { - from = pathUtils.normalize(from); - to = pathUtils.normalize(to); - if (from === to) - return `.`; - if (!from.endsWith(pathUtils.sep)) - from = from + pathUtils.sep; - if (to.startsWith(from)) { - return to.slice(from.length); - } else { - return null; - } -}; -npath.contains = (from, to) => contains(npath, from, to); -ppath.contains = (from, to) => contains(ppath, from, to); -const WINDOWS_PATH_REGEXP = /^([a-zA-Z]:.*)$/; -const UNC_WINDOWS_PATH_REGEXP = /^\/\/(\.\/)?(.*)$/; -const PORTABLE_PATH_REGEXP = /^\/([a-zA-Z]:.*)$/; -const UNC_PORTABLE_PATH_REGEXP = /^\/unc\/(\.dot\/)?(.*)$/; -function fromPortablePathWin32(p) { - let portablePathMatch, uncPortablePathMatch; - if (portablePathMatch = p.match(PORTABLE_PATH_REGEXP)) - p = portablePathMatch[1]; - else if (uncPortablePathMatch = p.match(UNC_PORTABLE_PATH_REGEXP)) - p = `\\\\${uncPortablePathMatch[1] ? `.\\` : ``}${uncPortablePathMatch[2]}`; - else - return p; - return p.replace(/\//g, `\\`); -} -function toPortablePathWin32(p) { - p = p.replace(/\\/g, `/`); - let windowsPathMatch, uncWindowsPathMatch; - if (windowsPathMatch = p.match(WINDOWS_PATH_REGEXP)) - p = `/${windowsPathMatch[1]}`; - else if (uncWindowsPathMatch = p.match(UNC_WINDOWS_PATH_REGEXP)) - p = `/unc/${uncWindowsPathMatch[1] ? `.dot/` : ``}${uncWindowsPathMatch[2]}`; - return p; -} -const toPortablePath = process.platform === `win32` ? toPortablePathWin32 : (p) => p; -const fromPortablePath = process.platform === `win32` ? fromPortablePathWin32 : (p) => p; -npath.fromPortablePath = fromPortablePath; -npath.toPortablePath = toPortablePath; -function convertPath(targetPathUtils, sourcePath) { - return targetPathUtils === npath ? fromPortablePath(sourcePath) : toPortablePath(sourcePath); -} - -const defaultTime = new Date(SAFE_TIME * 1e3); -const defaultTimeMs = defaultTime.getTime(); -async function copyPromise(destinationFs, destination, sourceFs, source, opts) { - const normalizedDestination = destinationFs.pathUtils.normalize(destination); - const normalizedSource = sourceFs.pathUtils.normalize(source); - const prelayout = []; - const postlayout = []; - const { atime, mtime } = opts.stableTime ? { atime: defaultTime, mtime: defaultTime } : await sourceFs.lstatPromise(normalizedSource); - await destinationFs.mkdirpPromise(destinationFs.pathUtils.dirname(destination), { utimes: [atime, mtime] }); - await copyImpl(prelayout, postlayout, destinationFs, normalizedDestination, sourceFs, normalizedSource, { ...opts, didParentExist: true }); - for (const operation of prelayout) - await operation(); - await Promise.all(postlayout.map((operation) => { - return operation(); - })); -} -async function copyImpl(prelayout, postlayout, destinationFs, destination, sourceFs, source, opts) { - const destinationStat = opts.didParentExist ? await maybeLStat(destinationFs, destination) : null; - const sourceStat = await sourceFs.lstatPromise(source); - const { atime, mtime } = opts.stableTime ? { atime: defaultTime, mtime: defaultTime } : sourceStat; - let updated; - switch (true) { - case sourceStat.isDirectory(): - { - updated = await copyFolder(prelayout, postlayout, destinationFs, destination, destinationStat, sourceFs, source, sourceStat, opts); - } - break; - case sourceStat.isFile(): - { - updated = await copyFile(prelayout, postlayout, destinationFs, destination, destinationStat, sourceFs, source, sourceStat, opts); - } - break; - case sourceStat.isSymbolicLink(): - { - updated = await copySymlink(prelayout, postlayout, destinationFs, destination, destinationStat, sourceFs, source, sourceStat, opts); - } - break; - default: { - throw new Error(`Unsupported file type (${sourceStat.mode})`); - } - } - if (opts.linkStrategy?.type !== `HardlinkFromIndex` || !sourceStat.isFile()) { - if (updated || destinationStat?.mtime?.getTime() !== mtime.getTime() || destinationStat?.atime?.getTime() !== atime.getTime()) { - postlayout.push(() => destinationFs.lutimesPromise(destination, atime, mtime)); - updated = true; - } - if (destinationStat === null || (destinationStat.mode & 511) !== (sourceStat.mode & 511)) { - postlayout.push(() => destinationFs.chmodPromise(destination, sourceStat.mode & 511)); - updated = true; - } - } - return updated; -} -async function maybeLStat(baseFs, p) { - try { - return await baseFs.lstatPromise(p); - } catch { - return null; - } -} -async function copyFolder(prelayout, postlayout, destinationFs, destination, destinationStat, sourceFs, source, sourceStat, opts) { - if (destinationStat !== null && !destinationStat.isDirectory()) { - if (opts.overwrite) { - prelayout.push(async () => destinationFs.removePromise(destination)); - destinationStat = null; - } else { - return false; - } - } - let updated = false; - if (destinationStat === null) { - prelayout.push(async () => { - try { - await destinationFs.mkdirPromise(destination, { mode: sourceStat.mode }); - } catch (err) { - if (err.code !== `EEXIST`) { - throw err; - } - } - }); - updated = true; - } - const entries = await sourceFs.readdirPromise(source); - const nextOpts = opts.didParentExist && !destinationStat ? { ...opts, didParentExist: false } : opts; - if (opts.stableSort) { - for (const entry of entries.sort()) { - if (await copyImpl(prelayout, postlayout, destinationFs, destinationFs.pathUtils.join(destination, entry), sourceFs, sourceFs.pathUtils.join(source, entry), nextOpts)) { - updated = true; - } - } - } else { - const entriesUpdateStatus = await Promise.all(entries.map(async (entry) => { - await copyImpl(prelayout, postlayout, destinationFs, destinationFs.pathUtils.join(destination, entry), sourceFs, sourceFs.pathUtils.join(source, entry), nextOpts); - })); - if (entriesUpdateStatus.some((status) => status)) { - updated = true; - } - } - return updated; -} -async function copyFileViaIndex(prelayout, postlayout, destinationFs, destination, destinationStat, sourceFs, source, sourceStat, opts, linkStrategy) { - const sourceHash = await sourceFs.checksumFilePromise(source, { algorithm: `sha1` }); - const defaultMode = 420; - const sourceMode = sourceStat.mode & 511; - const indexFileName = `${sourceHash}${sourceMode !== defaultMode ? sourceMode.toString(8) : ``}`; - const indexPath = destinationFs.pathUtils.join(linkStrategy.indexPath, sourceHash.slice(0, 2), `${indexFileName}.dat`); - let AtomicBehavior; - ((AtomicBehavior2) => { - AtomicBehavior2[AtomicBehavior2["Lock"] = 0] = "Lock"; - AtomicBehavior2[AtomicBehavior2["Rename"] = 1] = "Rename"; - })(AtomicBehavior || (AtomicBehavior = {})); - let atomicBehavior = 1 /* Rename */; - let indexStat = await maybeLStat(destinationFs, indexPath); - if (destinationStat) { - const isDestinationHardlinkedFromIndex = indexStat && destinationStat.dev === indexStat.dev && destinationStat.ino === indexStat.ino; - const isIndexModified = indexStat?.mtimeMs !== defaultTimeMs; - if (isDestinationHardlinkedFromIndex) { - if (isIndexModified && linkStrategy.autoRepair) { - atomicBehavior = 0 /* Lock */; - indexStat = null; - } - } - if (!isDestinationHardlinkedFromIndex) { - if (opts.overwrite) { - prelayout.push(async () => destinationFs.removePromise(destination)); - destinationStat = null; - } else { - return false; - } - } - } - const tempPath = !indexStat && atomicBehavior === 1 /* Rename */ ? `${indexPath}.${Math.floor(Math.random() * 4294967296).toString(16).padStart(8, `0`)}` : null; - let tempPathCleaned = false; - prelayout.push(async () => { - if (!indexStat) { - if (atomicBehavior === 0 /* Lock */) { - await destinationFs.lockPromise(indexPath, async () => { - const content = await sourceFs.readFilePromise(source); - await destinationFs.writeFilePromise(indexPath, content); - }); - } - if (atomicBehavior === 1 /* Rename */ && tempPath) { - const content = await sourceFs.readFilePromise(source); - await destinationFs.writeFilePromise(tempPath, content); - try { - await destinationFs.linkPromise(tempPath, indexPath); - } catch (err) { - if (err.code === `EEXIST`) { - tempPathCleaned = true; - await destinationFs.unlinkPromise(tempPath); - } else { - throw err; - } - } - } - } - if (!destinationStat) { - await destinationFs.linkPromise(indexPath, destination); - } - }); - postlayout.push(async () => { - if (!indexStat) { - await destinationFs.lutimesPromise(indexPath, defaultTime, defaultTime); - if (sourceMode !== defaultMode) { - await destinationFs.chmodPromise(indexPath, sourceMode); - } - } - if (tempPath && !tempPathCleaned) { - await destinationFs.unlinkPromise(tempPath); - } - }); - return false; -} -async function copyFileDirect(prelayout, postlayout, destinationFs, destination, destinationStat, sourceFs, source, sourceStat, opts) { - if (destinationStat !== null) { - if (opts.overwrite) { - prelayout.push(async () => destinationFs.removePromise(destination)); - destinationStat = null; - } else { - return false; - } - } - prelayout.push(async () => { - const content = await sourceFs.readFilePromise(source); - await destinationFs.writeFilePromise(destination, content); - }); - return true; -} -async function copyFile(prelayout, postlayout, destinationFs, destination, destinationStat, sourceFs, source, sourceStat, opts) { - if (opts.linkStrategy?.type === `HardlinkFromIndex`) { - return copyFileViaIndex(prelayout, postlayout, destinationFs, destination, destinationStat, sourceFs, source, sourceStat, opts, opts.linkStrategy); - } else { - return copyFileDirect(prelayout, postlayout, destinationFs, destination, destinationStat, sourceFs, source, sourceStat, opts); - } -} -async function copySymlink(prelayout, postlayout, destinationFs, destination, destinationStat, sourceFs, source, sourceStat, opts) { - if (destinationStat !== null) { - if (opts.overwrite) { - prelayout.push(async () => destinationFs.removePromise(destination)); - destinationStat = null; - } else { - return false; - } - } - prelayout.push(async () => { - await destinationFs.symlinkPromise(convertPath(destinationFs.pathUtils, await sourceFs.readlinkPromise(source)), destination); - }); - return true; -} - -class FakeFS { - pathUtils; - constructor(pathUtils) { - this.pathUtils = pathUtils; - } - async *genTraversePromise(init, { stableSort = false } = {}) { - const stack = [init]; - while (stack.length > 0) { - const p = stack.shift(); - const entry = await this.lstatPromise(p); - if (entry.isDirectory()) { - const entries = await this.readdirPromise(p); - if (stableSort) { - for (const entry2 of entries.sort()) { - stack.push(this.pathUtils.join(p, entry2)); - } - } else { - throw new Error(`Not supported`); - } - } else { - yield p; - } - } - } - async checksumFilePromise(path, { algorithm = `sha512` } = {}) { - const fd = await this.openPromise(path, `r`); - try { - const CHUNK_SIZE = 65536; - const chunk = Buffer.allocUnsafeSlow(CHUNK_SIZE); - const hash = createHash(algorithm); - let bytesRead = 0; - while ((bytesRead = await this.readPromise(fd, chunk, 0, CHUNK_SIZE)) !== 0) - hash.update(bytesRead === CHUNK_SIZE ? chunk : chunk.slice(0, bytesRead)); - return hash.digest(`hex`); - } finally { - await this.closePromise(fd); - } - } - async removePromise(p, { recursive = true, maxRetries = 5 } = {}) { - let stat; - try { - stat = await this.lstatPromise(p); - } catch (error) { - if (error.code === `ENOENT`) { - return; - } else { - throw error; - } - } - if (stat.isDirectory()) { - if (recursive) { - const entries = await this.readdirPromise(p); - await Promise.all(entries.map((entry) => { - return this.removePromise(this.pathUtils.resolve(p, entry)); - })); - } - for (let t = 0; t <= maxRetries; t++) { - try { - await this.rmdirPromise(p); - break; - } catch (error) { - if (error.code !== `EBUSY` && error.code !== `ENOTEMPTY`) { - throw error; - } else if (t < maxRetries) { - await new Promise((resolve) => setTimeout(resolve, t * 100)); - } - } - } - } else { - await this.unlinkPromise(p); - } - } - removeSync(p, { recursive = true } = {}) { - let stat; - try { - stat = this.lstatSync(p); - } catch (error) { - if (error.code === `ENOENT`) { - return; - } else { - throw error; - } - } - if (stat.isDirectory()) { - if (recursive) - for (const entry of this.readdirSync(p)) - this.removeSync(this.pathUtils.resolve(p, entry)); - this.rmdirSync(p); - } else { - this.unlinkSync(p); - } - } - async mkdirpPromise(p, { chmod, utimes } = {}) { - p = this.resolve(p); - if (p === this.pathUtils.dirname(p)) - return void 0; - const parts = p.split(this.pathUtils.sep); - let createdDirectory; - for (let u = 2; u <= parts.length; ++u) { - const subPath = parts.slice(0, u).join(this.pathUtils.sep); - if (!this.existsSync(subPath)) { - try { - await this.mkdirPromise(subPath); - } catch (error) { - if (error.code === `EEXIST`) { - continue; - } else { - throw error; - } - } - createdDirectory ??= subPath; - if (chmod != null) - await this.chmodPromise(subPath, chmod); - if (utimes != null) { - await this.utimesPromise(subPath, utimes[0], utimes[1]); - } else { - const parentStat = await this.statPromise(this.pathUtils.dirname(subPath)); - await this.utimesPromise(subPath, parentStat.atime, parentStat.mtime); - } - } - } - return createdDirectory; - } - mkdirpSync(p, { chmod, utimes } = {}) { - p = this.resolve(p); - if (p === this.pathUtils.dirname(p)) - return void 0; - const parts = p.split(this.pathUtils.sep); - let createdDirectory; - for (let u = 2; u <= parts.length; ++u) { - const subPath = parts.slice(0, u).join(this.pathUtils.sep); - if (!this.existsSync(subPath)) { - try { - this.mkdirSync(subPath); - } catch (error) { - if (error.code === `EEXIST`) { - continue; - } else { - throw error; - } - } - createdDirectory ??= subPath; - if (chmod != null) - this.chmodSync(subPath, chmod); - if (utimes != null) { - this.utimesSync(subPath, utimes[0], utimes[1]); - } else { - const parentStat = this.statSync(this.pathUtils.dirname(subPath)); - this.utimesSync(subPath, parentStat.atime, parentStat.mtime); - } - } - } - return createdDirectory; - } - async copyPromise(destination, source, { baseFs = this, overwrite = true, stableSort = false, stableTime = false, linkStrategy = null } = {}) { - return await copyPromise(this, destination, baseFs, source, { overwrite, stableSort, stableTime, linkStrategy }); - } - copySync(destination, source, { baseFs = this, overwrite = true } = {}) { - const stat = baseFs.lstatSync(source); - const exists = this.existsSync(destination); - if (stat.isDirectory()) { - this.mkdirpSync(destination); - const directoryListing = baseFs.readdirSync(source); - for (const entry of directoryListing) { - this.copySync(this.pathUtils.join(destination, entry), baseFs.pathUtils.join(source, entry), { baseFs, overwrite }); - } - } else if (stat.isFile()) { - if (!exists || overwrite) { - if (exists) - this.removeSync(destination); - const content = baseFs.readFileSync(source); - this.writeFileSync(destination, content); - } - } else if (stat.isSymbolicLink()) { - if (!exists || overwrite) { - if (exists) - this.removeSync(destination); - const target = baseFs.readlinkSync(source); - this.symlinkSync(convertPath(this.pathUtils, target), destination); - } - } else { - throw new Error(`Unsupported file type (file: ${source}, mode: 0o${stat.mode.toString(8).padStart(6, `0`)})`); - } - const mode = stat.mode & 511; - this.chmodSync(destination, mode); - } - async changeFilePromise(p, content, opts = {}) { - if (Buffer.isBuffer(content)) { - return this.changeFileBufferPromise(p, content, opts); - } else { - return this.changeFileTextPromise(p, content, opts); - } - } - async changeFileBufferPromise(p, content, { mode } = {}) { - let current = Buffer.alloc(0); - try { - current = await this.readFilePromise(p); - } catch { - } - if (Buffer.compare(current, content) === 0) - return; - await this.writeFilePromise(p, content, { mode }); - } - async changeFileTextPromise(p, content, { automaticNewlines, mode } = {}) { - let current = ``; - try { - current = await this.readFilePromise(p, `utf8`); - } catch { - } - const normalizedContent = automaticNewlines ? normalizeLineEndings(current, content) : content; - if (current === normalizedContent) - return; - await this.writeFilePromise(p, normalizedContent, { mode }); - } - changeFileSync(p, content, opts = {}) { - if (Buffer.isBuffer(content)) { - return this.changeFileBufferSync(p, content, opts); - } else { - return this.changeFileTextSync(p, content, opts); - } - } - changeFileBufferSync(p, content, { mode } = {}) { - let current = Buffer.alloc(0); - try { - current = this.readFileSync(p); - } catch { - } - if (Buffer.compare(current, content) === 0) - return; - this.writeFileSync(p, content, { mode }); - } - changeFileTextSync(p, content, { automaticNewlines = false, mode } = {}) { - let current = ``; - try { - current = this.readFileSync(p, `utf8`); - } catch { - } - const normalizedContent = automaticNewlines ? normalizeLineEndings(current, content) : content; - if (current === normalizedContent) - return; - this.writeFileSync(p, normalizedContent, { mode }); - } - async movePromise(fromP, toP) { - try { - await this.renamePromise(fromP, toP); - } catch (error) { - if (error.code === `EXDEV`) { - await this.copyPromise(toP, fromP); - await this.removePromise(fromP); - } else { - throw error; - } - } - } - moveSync(fromP, toP) { - try { - this.renameSync(fromP, toP); - } catch (error) { - if (error.code === `EXDEV`) { - this.copySync(toP, fromP); - this.removeSync(fromP); - } else { - throw error; - } - } - } - async lockPromise(affectedPath, callback) { - const lockPath = `${affectedPath}.flock`; - const interval = 1e3 / 60; - const startTime = Date.now(); - let fd = null; - const isAlive = async () => { - let pid; - try { - [pid] = await this.readJsonPromise(lockPath); - } catch { - return Date.now() - startTime < 500; - } - try { - process.kill(pid, 0); - return true; - } catch { - return false; - } - }; - while (fd === null) { - try { - fd = await this.openPromise(lockPath, `wx`); - } catch (error) { - if (error.code === `EEXIST`) { - if (!await isAlive()) { - try { - await this.unlinkPromise(lockPath); - continue; - } catch { - } - } - if (Date.now() - startTime < 60 * 1e3) { - await new Promise((resolve) => setTimeout(resolve, interval)); - } else { - throw new Error(`Couldn't acquire a lock in a reasonable time (via ${lockPath})`); - } - } else { - throw error; - } - } - } - await this.writePromise(fd, JSON.stringify([process.pid])); - try { - return await callback(); - } finally { - try { - await this.closePromise(fd); - await this.unlinkPromise(lockPath); - } catch { - } - } - } - async readJsonPromise(p) { - const content = await this.readFilePromise(p, `utf8`); - try { - return JSON.parse(content); - } catch (error) { - error.message += ` (in ${p})`; - throw error; - } - } - readJsonSync(p) { - const content = this.readFileSync(p, `utf8`); - try { - return JSON.parse(content); - } catch (error) { - error.message += ` (in ${p})`; - throw error; - } - } - async writeJsonPromise(p, data, { compact = false } = {}) { - const space = compact ? 0 : 2; - return await this.writeFilePromise(p, `${JSON.stringify(data, null, space)} -`); - } - writeJsonSync(p, data, { compact = false } = {}) { - const space = compact ? 0 : 2; - return this.writeFileSync(p, `${JSON.stringify(data, null, space)} -`); - } - async preserveTimePromise(p, cb) { - const stat = await this.lstatPromise(p); - const result = await cb(); - if (typeof result !== `undefined`) - p = result; - await this.lutimesPromise(p, stat.atime, stat.mtime); - } - async preserveTimeSync(p, cb) { - const stat = this.lstatSync(p); - const result = cb(); - if (typeof result !== `undefined`) - p = result; - this.lutimesSync(p, stat.atime, stat.mtime); - } -} -class BasePortableFakeFS extends FakeFS { - constructor() { - super(ppath); - } -} -function getEndOfLine(content) { - const matches = content.match(/\r?\n/g); - if (matches === null) - return EOL; - const crlf = matches.filter((nl) => nl === `\r -`).length; - const lf = matches.length - crlf; - return crlf > lf ? `\r -` : ` -`; -} -function normalizeLineEndings(originalContent, newContent) { - return newContent.replace(/\r?\n/g, getEndOfLine(originalContent)); -} - -class ProxiedFS extends FakeFS { - getExtractHint(hints) { - return this.baseFs.getExtractHint(hints); - } - resolve(path) { - return this.mapFromBase(this.baseFs.resolve(this.mapToBase(path))); - } - getRealPath() { - return this.mapFromBase(this.baseFs.getRealPath()); - } - async openPromise(p, flags, mode) { - return this.baseFs.openPromise(this.mapToBase(p), flags, mode); - } - openSync(p, flags, mode) { - return this.baseFs.openSync(this.mapToBase(p), flags, mode); - } - async opendirPromise(p, opts) { - return Object.assign(await this.baseFs.opendirPromise(this.mapToBase(p), opts), { path: p }); - } - opendirSync(p, opts) { - return Object.assign(this.baseFs.opendirSync(this.mapToBase(p), opts), { path: p }); - } - async readPromise(fd, buffer, offset, length, position) { - return await this.baseFs.readPromise(fd, buffer, offset, length, position); - } - readSync(fd, buffer, offset, length, position) { - return this.baseFs.readSync(fd, buffer, offset, length, position); - } - async writePromise(fd, buffer, offset, length, position) { - if (typeof buffer === `string`) { - return await this.baseFs.writePromise(fd, buffer, offset); - } else { - return await this.baseFs.writePromise(fd, buffer, offset, length, position); - } - } - writeSync(fd, buffer, offset, length, position) { - if (typeof buffer === `string`) { - return this.baseFs.writeSync(fd, buffer, offset); - } else { - return this.baseFs.writeSync(fd, buffer, offset, length, position); - } - } - async closePromise(fd) { - return this.baseFs.closePromise(fd); - } - closeSync(fd) { - this.baseFs.closeSync(fd); - } - createReadStream(p, opts) { - return this.baseFs.createReadStream(p !== null ? this.mapToBase(p) : p, opts); - } - createWriteStream(p, opts) { - return this.baseFs.createWriteStream(p !== null ? this.mapToBase(p) : p, opts); - } - async realpathPromise(p) { - return this.mapFromBase(await this.baseFs.realpathPromise(this.mapToBase(p))); - } - realpathSync(p) { - return this.mapFromBase(this.baseFs.realpathSync(this.mapToBase(p))); - } - async existsPromise(p) { - return this.baseFs.existsPromise(this.mapToBase(p)); - } - existsSync(p) { - return this.baseFs.existsSync(this.mapToBase(p)); - } - accessSync(p, mode) { - return this.baseFs.accessSync(this.mapToBase(p), mode); - } - async accessPromise(p, mode) { - return this.baseFs.accessPromise(this.mapToBase(p), mode); - } - async statPromise(p, opts) { - return this.baseFs.statPromise(this.mapToBase(p), opts); - } - statSync(p, opts) { - return this.baseFs.statSync(this.mapToBase(p), opts); - } - async fstatPromise(fd, opts) { - return this.baseFs.fstatPromise(fd, opts); - } - fstatSync(fd, opts) { - return this.baseFs.fstatSync(fd, opts); - } - lstatPromise(p, opts) { - return this.baseFs.lstatPromise(this.mapToBase(p), opts); - } - lstatSync(p, opts) { - return this.baseFs.lstatSync(this.mapToBase(p), opts); - } - async fchmodPromise(fd, mask) { - return this.baseFs.fchmodPromise(fd, mask); - } - fchmodSync(fd, mask) { - return this.baseFs.fchmodSync(fd, mask); - } - async chmodPromise(p, mask) { - return this.baseFs.chmodPromise(this.mapToBase(p), mask); - } - chmodSync(p, mask) { - return this.baseFs.chmodSync(this.mapToBase(p), mask); - } - async fchownPromise(fd, uid, gid) { - return this.baseFs.fchownPromise(fd, uid, gid); - } - fchownSync(fd, uid, gid) { - return this.baseFs.fchownSync(fd, uid, gid); - } - async chownPromise(p, uid, gid) { - return this.baseFs.chownPromise(this.mapToBase(p), uid, gid); - } - chownSync(p, uid, gid) { - return this.baseFs.chownSync(this.mapToBase(p), uid, gid); - } - async renamePromise(oldP, newP) { - return this.baseFs.renamePromise(this.mapToBase(oldP), this.mapToBase(newP)); - } - renameSync(oldP, newP) { - return this.baseFs.renameSync(this.mapToBase(oldP), this.mapToBase(newP)); - } - async copyFilePromise(sourceP, destP, flags = 0) { - return this.baseFs.copyFilePromise(this.mapToBase(sourceP), this.mapToBase(destP), flags); - } - copyFileSync(sourceP, destP, flags = 0) { - return this.baseFs.copyFileSync(this.mapToBase(sourceP), this.mapToBase(destP), flags); - } - async appendFilePromise(p, content, opts) { - return this.baseFs.appendFilePromise(this.fsMapToBase(p), content, opts); - } - appendFileSync(p, content, opts) { - return this.baseFs.appendFileSync(this.fsMapToBase(p), content, opts); - } - async writeFilePromise(p, content, opts) { - return this.baseFs.writeFilePromise(this.fsMapToBase(p), content, opts); - } - writeFileSync(p, content, opts) { - return this.baseFs.writeFileSync(this.fsMapToBase(p), content, opts); - } - async unlinkPromise(p) { - return this.baseFs.unlinkPromise(this.mapToBase(p)); - } - unlinkSync(p) { - return this.baseFs.unlinkSync(this.mapToBase(p)); - } - async utimesPromise(p, atime, mtime) { - return this.baseFs.utimesPromise(this.mapToBase(p), atime, mtime); - } - utimesSync(p, atime, mtime) { - return this.baseFs.utimesSync(this.mapToBase(p), atime, mtime); - } - async lutimesPromise(p, atime, mtime) { - return this.baseFs.lutimesPromise(this.mapToBase(p), atime, mtime); - } - lutimesSync(p, atime, mtime) { - return this.baseFs.lutimesSync(this.mapToBase(p), atime, mtime); - } - async mkdirPromise(p, opts) { - return this.baseFs.mkdirPromise(this.mapToBase(p), opts); - } - mkdirSync(p, opts) { - return this.baseFs.mkdirSync(this.mapToBase(p), opts); - } - async rmdirPromise(p, opts) { - return this.baseFs.rmdirPromise(this.mapToBase(p), opts); - } - rmdirSync(p, opts) { - return this.baseFs.rmdirSync(this.mapToBase(p), opts); - } - async rmPromise(p, opts) { - return this.baseFs.rmPromise(this.mapToBase(p), opts); - } - rmSync(p, opts) { - return this.baseFs.rmSync(this.mapToBase(p), opts); - } - async linkPromise(existingP, newP) { - return this.baseFs.linkPromise(this.mapToBase(existingP), this.mapToBase(newP)); - } - linkSync(existingP, newP) { - return this.baseFs.linkSync(this.mapToBase(existingP), this.mapToBase(newP)); - } - async symlinkPromise(target, p, type) { - const mappedP = this.mapToBase(p); - if (this.pathUtils.isAbsolute(target)) - return this.baseFs.symlinkPromise(this.mapToBase(target), mappedP, type); - const mappedAbsoluteTarget = this.mapToBase(this.pathUtils.join(this.pathUtils.dirname(p), target)); - const mappedTarget = this.baseFs.pathUtils.relative(this.baseFs.pathUtils.dirname(mappedP), mappedAbsoluteTarget); - return this.baseFs.symlinkPromise(mappedTarget, mappedP, type); - } - symlinkSync(target, p, type) { - const mappedP = this.mapToBase(p); - if (this.pathUtils.isAbsolute(target)) - return this.baseFs.symlinkSync(this.mapToBase(target), mappedP, type); - const mappedAbsoluteTarget = this.mapToBase(this.pathUtils.join(this.pathUtils.dirname(p), target)); - const mappedTarget = this.baseFs.pathUtils.relative(this.baseFs.pathUtils.dirname(mappedP), mappedAbsoluteTarget); - return this.baseFs.symlinkSync(mappedTarget, mappedP, type); - } - async readFilePromise(p, encoding) { - return this.baseFs.readFilePromise(this.fsMapToBase(p), encoding); - } - readFileSync(p, encoding) { - return this.baseFs.readFileSync(this.fsMapToBase(p), encoding); - } - readdirPromise(p, opts) { - return this.baseFs.readdirPromise(this.mapToBase(p), opts); - } - readdirSync(p, opts) { - return this.baseFs.readdirSync(this.mapToBase(p), opts); - } - async readlinkPromise(p) { - return this.mapFromBase(await this.baseFs.readlinkPromise(this.mapToBase(p))); - } - readlinkSync(p) { - return this.mapFromBase(this.baseFs.readlinkSync(this.mapToBase(p))); - } - async truncatePromise(p, len) { - return this.baseFs.truncatePromise(this.mapToBase(p), len); - } - truncateSync(p, len) { - return this.baseFs.truncateSync(this.mapToBase(p), len); - } - async ftruncatePromise(fd, len) { - return this.baseFs.ftruncatePromise(fd, len); - } - ftruncateSync(fd, len) { - return this.baseFs.ftruncateSync(fd, len); - } - watch(p, a, b) { - return this.baseFs.watch( - this.mapToBase(p), - // @ts-expect-error - reason TBS - a, - b - ); - } - watchFile(p, a, b) { - return this.baseFs.watchFile( - this.mapToBase(p), - // @ts-expect-error - reason TBS - a, - b - ); - } - unwatchFile(p, cb) { - return this.baseFs.unwatchFile(this.mapToBase(p), cb); - } - fsMapToBase(p) { - if (typeof p === `number`) { - return p; - } else { - return this.mapToBase(p); - } - } -} - -function direntToPortable(dirent) { - const portableDirent = dirent; - if (typeof dirent.path === `string`) - portableDirent.path = npath.toPortablePath(dirent.path); - return portableDirent; -} -class NodeFS extends BasePortableFakeFS { - realFs; - constructor(realFs = fs) { - super(); - this.realFs = realFs; - } - getExtractHint() { - return false; - } - getRealPath() { - return PortablePath.root; - } - resolve(p) { - return ppath.resolve(p); - } - async openPromise(p, flags, mode) { - return await new Promise((resolve, reject) => { - this.realFs.open(npath.fromPortablePath(p), flags, mode, this.makeCallback(resolve, reject)); - }); - } - openSync(p, flags, mode) { - return this.realFs.openSync(npath.fromPortablePath(p), flags, mode); - } - async opendirPromise(p, opts) { - return await new Promise((resolve, reject) => { - if (typeof opts !== `undefined`) { - this.realFs.opendir(npath.fromPortablePath(p), opts, this.makeCallback(resolve, reject)); - } else { - this.realFs.opendir(npath.fromPortablePath(p), this.makeCallback(resolve, reject)); - } - }).then((dir) => { - const dirWithFixedPath = dir; - Object.defineProperty(dirWithFixedPath, `path`, { - value: p, - configurable: true, - writable: true - }); - return dirWithFixedPath; - }); - } - opendirSync(p, opts) { - const dir = typeof opts !== `undefined` ? this.realFs.opendirSync(npath.fromPortablePath(p), opts) : this.realFs.opendirSync(npath.fromPortablePath(p)); - const dirWithFixedPath = dir; - Object.defineProperty(dirWithFixedPath, `path`, { - value: p, - configurable: true, - writable: true - }); - return dirWithFixedPath; - } - async readPromise(fd, buffer, offset = 0, length = 0, position = -1) { - return await new Promise((resolve, reject) => { - this.realFs.read(fd, buffer, offset, length, position, (error, bytesRead) => { - if (error) { - reject(error); - } else { - resolve(bytesRead); - } - }); - }); - } - readSync(fd, buffer, offset, length, position) { - return this.realFs.readSync(fd, buffer, offset, length, position); - } - async writePromise(fd, buffer, offset, length, position) { - return await new Promise((resolve, reject) => { - if (typeof buffer === `string`) { - return this.realFs.write(fd, buffer, offset, this.makeCallback(resolve, reject)); - } else { - return this.realFs.write(fd, buffer, offset, length, position, this.makeCallback(resolve, reject)); - } - }); - } - writeSync(fd, buffer, offset, length, position) { - if (typeof buffer === `string`) { - return this.realFs.writeSync(fd, buffer, offset); - } else { - return this.realFs.writeSync(fd, buffer, offset, length, position); - } - } - async closePromise(fd) { - await new Promise((resolve, reject) => { - this.realFs.close(fd, this.makeCallback(resolve, reject)); - }); - } - closeSync(fd) { - this.realFs.closeSync(fd); - } - createReadStream(p, opts) { - const realPath = p !== null ? npath.fromPortablePath(p) : p; - return this.realFs.createReadStream(realPath, opts); - } - createWriteStream(p, opts) { - const realPath = p !== null ? npath.fromPortablePath(p) : p; - return this.realFs.createWriteStream(realPath, opts); - } - async realpathPromise(p) { - return await new Promise((resolve, reject) => { - this.realFs.realpath(npath.fromPortablePath(p), {}, this.makeCallback(resolve, reject)); - }).then((path) => { - return npath.toPortablePath(path); - }); - } - realpathSync(p) { - return npath.toPortablePath(this.realFs.realpathSync(npath.fromPortablePath(p), {})); - } - async existsPromise(p) { - return await new Promise((resolve) => { - this.realFs.exists(npath.fromPortablePath(p), resolve); - }); - } - accessSync(p, mode) { - return this.realFs.accessSync(npath.fromPortablePath(p), mode); - } - async accessPromise(p, mode) { - return await new Promise((resolve, reject) => { - this.realFs.access(npath.fromPortablePath(p), mode, this.makeCallback(resolve, reject)); - }); - } - existsSync(p) { - return this.realFs.existsSync(npath.fromPortablePath(p)); - } - async statPromise(p, opts) { - return await new Promise((resolve, reject) => { - if (opts) { - this.realFs.stat(npath.fromPortablePath(p), opts, this.makeCallback(resolve, reject)); - } else { - this.realFs.stat(npath.fromPortablePath(p), this.makeCallback(resolve, reject)); - } - }); - } - statSync(p, opts) { - if (opts) { - return this.realFs.statSync(npath.fromPortablePath(p), opts); - } else { - return this.realFs.statSync(npath.fromPortablePath(p)); - } - } - async fstatPromise(fd, opts) { - return await new Promise((resolve, reject) => { - if (opts) { - this.realFs.fstat(fd, opts, this.makeCallback(resolve, reject)); - } else { - this.realFs.fstat(fd, this.makeCallback(resolve, reject)); - } - }); - } - fstatSync(fd, opts) { - if (opts) { - return this.realFs.fstatSync(fd, opts); - } else { - return this.realFs.fstatSync(fd); - } - } - async lstatPromise(p, opts) { - return await new Promise((resolve, reject) => { - if (opts) { - this.realFs.lstat(npath.fromPortablePath(p), opts, this.makeCallback(resolve, reject)); - } else { - this.realFs.lstat(npath.fromPortablePath(p), this.makeCallback(resolve, reject)); - } - }); - } - lstatSync(p, opts) { - if (opts) { - return this.realFs.lstatSync(npath.fromPortablePath(p), opts); - } else { - return this.realFs.lstatSync(npath.fromPortablePath(p)); - } - } - async fchmodPromise(fd, mask) { - return await new Promise((resolve, reject) => { - this.realFs.fchmod(fd, mask, this.makeCallback(resolve, reject)); - }); - } - fchmodSync(fd, mask) { - return this.realFs.fchmodSync(fd, mask); - } - async chmodPromise(p, mask) { - return await new Promise((resolve, reject) => { - this.realFs.chmod(npath.fromPortablePath(p), mask, this.makeCallback(resolve, reject)); - }); - } - chmodSync(p, mask) { - return this.realFs.chmodSync(npath.fromPortablePath(p), mask); - } - async fchownPromise(fd, uid, gid) { - return await new Promise((resolve, reject) => { - this.realFs.fchown(fd, uid, gid, this.makeCallback(resolve, reject)); - }); - } - fchownSync(fd, uid, gid) { - return this.realFs.fchownSync(fd, uid, gid); - } - async chownPromise(p, uid, gid) { - return await new Promise((resolve, reject) => { - this.realFs.chown(npath.fromPortablePath(p), uid, gid, this.makeCallback(resolve, reject)); - }); - } - chownSync(p, uid, gid) { - return this.realFs.chownSync(npath.fromPortablePath(p), uid, gid); - } - async renamePromise(oldP, newP) { - return await new Promise((resolve, reject) => { - this.realFs.rename(npath.fromPortablePath(oldP), npath.fromPortablePath(newP), this.makeCallback(resolve, reject)); - }); - } - renameSync(oldP, newP) { - return this.realFs.renameSync(npath.fromPortablePath(oldP), npath.fromPortablePath(newP)); - } - async copyFilePromise(sourceP, destP, flags = 0) { - return await new Promise((resolve, reject) => { - this.realFs.copyFile(npath.fromPortablePath(sourceP), npath.fromPortablePath(destP), flags, this.makeCallback(resolve, reject)); - }); - } - copyFileSync(sourceP, destP, flags = 0) { - return this.realFs.copyFileSync(npath.fromPortablePath(sourceP), npath.fromPortablePath(destP), flags); - } - async appendFilePromise(p, content, opts) { - return await new Promise((resolve, reject) => { - const fsNativePath = typeof p === `string` ? npath.fromPortablePath(p) : p; - if (opts) { - this.realFs.appendFile(fsNativePath, content, opts, this.makeCallback(resolve, reject)); - } else { - this.realFs.appendFile(fsNativePath, content, this.makeCallback(resolve, reject)); - } - }); - } - appendFileSync(p, content, opts) { - const fsNativePath = typeof p === `string` ? npath.fromPortablePath(p) : p; - if (opts) { - this.realFs.appendFileSync(fsNativePath, content, opts); - } else { - this.realFs.appendFileSync(fsNativePath, content); - } - } - async writeFilePromise(p, content, opts) { - return await new Promise((resolve, reject) => { - const fsNativePath = typeof p === `string` ? npath.fromPortablePath(p) : p; - if (opts) { - this.realFs.writeFile(fsNativePath, content, opts, this.makeCallback(resolve, reject)); - } else { - this.realFs.writeFile(fsNativePath, content, this.makeCallback(resolve, reject)); - } - }); - } - writeFileSync(p, content, opts) { - const fsNativePath = typeof p === `string` ? npath.fromPortablePath(p) : p; - if (opts) { - this.realFs.writeFileSync(fsNativePath, content, opts); - } else { - this.realFs.writeFileSync(fsNativePath, content); - } - } - async unlinkPromise(p) { - return await new Promise((resolve, reject) => { - this.realFs.unlink(npath.fromPortablePath(p), this.makeCallback(resolve, reject)); - }); - } - unlinkSync(p) { - return this.realFs.unlinkSync(npath.fromPortablePath(p)); - } - async utimesPromise(p, atime, mtime) { - return await new Promise((resolve, reject) => { - this.realFs.utimes(npath.fromPortablePath(p), atime, mtime, this.makeCallback(resolve, reject)); - }); - } - utimesSync(p, atime, mtime) { - this.realFs.utimesSync(npath.fromPortablePath(p), atime, mtime); - } - async lutimesPromise(p, atime, mtime) { - return await new Promise((resolve, reject) => { - this.realFs.lutimes(npath.fromPortablePath(p), atime, mtime, this.makeCallback(resolve, reject)); - }); - } - lutimesSync(p, atime, mtime) { - this.realFs.lutimesSync(npath.fromPortablePath(p), atime, mtime); - } - async mkdirPromise(p, opts) { - return await new Promise((resolve, reject) => { - this.realFs.mkdir(npath.fromPortablePath(p), opts, this.makeCallback(resolve, reject)); - }); - } - mkdirSync(p, opts) { - return this.realFs.mkdirSync(npath.fromPortablePath(p), opts); - } - async rmdirPromise(p, opts) { - return await new Promise((resolve, reject) => { - if (opts) { - this.realFs.rmdir(npath.fromPortablePath(p), opts, this.makeCallback(resolve, reject)); - } else { - this.realFs.rmdir(npath.fromPortablePath(p), this.makeCallback(resolve, reject)); - } - }); - } - rmdirSync(p, opts) { - return this.realFs.rmdirSync(npath.fromPortablePath(p), opts); - } - async rmPromise(p, opts) { - return await new Promise((resolve, reject) => { - if (opts) { - this.realFs.rm(npath.fromPortablePath(p), opts, this.makeCallback(resolve, reject)); - } else { - this.realFs.rm(npath.fromPortablePath(p), this.makeCallback(resolve, reject)); - } - }); - } - rmSync(p, opts) { - return this.realFs.rmSync(npath.fromPortablePath(p), opts); - } - async linkPromise(existingP, newP) { - return await new Promise((resolve, reject) => { - this.realFs.link(npath.fromPortablePath(existingP), npath.fromPortablePath(newP), this.makeCallback(resolve, reject)); - }); - } - linkSync(existingP, newP) { - return this.realFs.linkSync(npath.fromPortablePath(existingP), npath.fromPortablePath(newP)); - } - async symlinkPromise(target, p, type) { - return await new Promise((resolve, reject) => { - this.realFs.symlink(npath.fromPortablePath(target.replace(/\/+$/, ``)), npath.fromPortablePath(p), type, this.makeCallback(resolve, reject)); - }); - } - symlinkSync(target, p, type) { - return this.realFs.symlinkSync(npath.fromPortablePath(target.replace(/\/+$/, ``)), npath.fromPortablePath(p), type); - } - async readFilePromise(p, encoding) { - return await new Promise((resolve, reject) => { - const fsNativePath = typeof p === `string` ? npath.fromPortablePath(p) : p; - this.realFs.readFile(fsNativePath, encoding, this.makeCallback(resolve, reject)); - }); - } - readFileSync(p, encoding) { - const fsNativePath = typeof p === `string` ? npath.fromPortablePath(p) : p; - return this.realFs.readFileSync(fsNativePath, encoding); - } - async readdirPromise(p, opts) { - return await new Promise((resolve, reject) => { - if (opts) { - if (opts.recursive && process.platform === `win32`) { - if (opts.withFileTypes) { - this.realFs.readdir(npath.fromPortablePath(p), opts, this.makeCallback((results) => resolve(results.map(direntToPortable)), reject)); - } else { - this.realFs.readdir(npath.fromPortablePath(p), opts, this.makeCallback((results) => resolve(results.map(npath.toPortablePath)), reject)); - } - } else { - this.realFs.readdir(npath.fromPortablePath(p), opts, this.makeCallback(resolve, reject)); - } - } else { - this.realFs.readdir(npath.fromPortablePath(p), this.makeCallback(resolve, reject)); - } - }); - } - readdirSync(p, opts) { - if (opts) { - if (opts.recursive && process.platform === `win32`) { - if (opts.withFileTypes) { - return this.realFs.readdirSync(npath.fromPortablePath(p), opts).map(direntToPortable); - } else { - return this.realFs.readdirSync(npath.fromPortablePath(p), opts).map(npath.toPortablePath); - } - } else { - return this.realFs.readdirSync(npath.fromPortablePath(p), opts); - } - } else { - return this.realFs.readdirSync(npath.fromPortablePath(p)); - } - } - async readlinkPromise(p) { - return await new Promise((resolve, reject) => { - this.realFs.readlink(npath.fromPortablePath(p), this.makeCallback(resolve, reject)); - }).then((path) => { - return npath.toPortablePath(path); - }); - } - readlinkSync(p) { - return npath.toPortablePath(this.realFs.readlinkSync(npath.fromPortablePath(p))); - } - async truncatePromise(p, len) { - return await new Promise((resolve, reject) => { - this.realFs.truncate(npath.fromPortablePath(p), len, this.makeCallback(resolve, reject)); - }); - } - truncateSync(p, len) { - return this.realFs.truncateSync(npath.fromPortablePath(p), len); - } - async ftruncatePromise(fd, len) { - return await new Promise((resolve, reject) => { - this.realFs.ftruncate(fd, len, this.makeCallback(resolve, reject)); - }); - } - ftruncateSync(fd, len) { - return this.realFs.ftruncateSync(fd, len); - } - watch(p, a, b) { - return this.realFs.watch( - npath.fromPortablePath(p), - // @ts-expect-error - reason TBS - a, - b - ); - } - watchFile(p, a, b) { - return this.realFs.watchFile( - npath.fromPortablePath(p), - // @ts-expect-error - reason TBS - a, - b - ); - } - unwatchFile(p, cb) { - return this.realFs.unwatchFile(npath.fromPortablePath(p), cb); - } - makeCallback(resolve, reject) { - return (err, result) => { - if (err) { - reject(err); - } else { - resolve(result); - } - }; - } -} - -const NUMBER_REGEXP = /^[0-9]+$/; -const VIRTUAL_REGEXP = /^(\/(?:[^/]+\/)*?(?:\$\$virtual|__virtual__))((?:\/((?:[^/]+-)?[a-f0-9]+)(?:\/([^/]+))?)?((?:\/.*)?))$/; -const VALID_COMPONENT = /^([^/]+-)?[a-f0-9]+$/; -class VirtualFS extends ProxiedFS { - baseFs; - static makeVirtualPath(base, component, to) { - if (ppath.basename(base) !== `__virtual__`) - throw new Error(`Assertion failed: Virtual folders must be named "__virtual__"`); - if (!ppath.basename(component).match(VALID_COMPONENT)) - throw new Error(`Assertion failed: Virtual components must be ended by an hexadecimal hash`); - const target = ppath.relative(ppath.dirname(base), to); - const segments = target.split(`/`); - let depth = 0; - while (depth < segments.length && segments[depth] === `..`) - depth += 1; - const finalSegments = segments.slice(depth); - const fullVirtualPath = ppath.join(base, component, String(depth), ...finalSegments); - return fullVirtualPath; - } - static resolveVirtual(p) { - const match = p.match(VIRTUAL_REGEXP); - if (!match || !match[3] && match[5]) - return p; - const target = ppath.dirname(match[1]); - if (!match[3] || !match[4]) - return target; - const isnum = NUMBER_REGEXP.test(match[4]); - if (!isnum) - return p; - const depth = Number(match[4]); - const backstep = `../`.repeat(depth); - const subpath = match[5] || `.`; - return VirtualFS.resolveVirtual(ppath.join(target, backstep, subpath)); - } - constructor({ baseFs = new NodeFS() } = {}) { - super(ppath); - this.baseFs = baseFs; - } - getExtractHint(hints) { - return this.baseFs.getExtractHint(hints); - } - getRealPath() { - return this.baseFs.getRealPath(); - } - realpathSync(p) { - const match = p.match(VIRTUAL_REGEXP); - if (!match) - return this.baseFs.realpathSync(p); - if (!match[5]) - return p; - const realpath = this.baseFs.realpathSync(this.mapToBase(p)); - return VirtualFS.makeVirtualPath(match[1], match[3], realpath); - } - async realpathPromise(p) { - const match = p.match(VIRTUAL_REGEXP); - if (!match) - return await this.baseFs.realpathPromise(p); - if (!match[5]) - return p; - const realpath = await this.baseFs.realpathPromise(this.mapToBase(p)); - return VirtualFS.makeVirtualPath(match[1], match[3], realpath); - } - mapToBase(p) { - if (p === ``) - return p; - if (this.pathUtils.isAbsolute(p)) - return VirtualFS.resolveVirtual(p); - const resolvedRoot = VirtualFS.resolveVirtual(this.baseFs.resolve(PortablePath.dot)); - const resolvedP = VirtualFS.resolveVirtual(this.baseFs.resolve(p)); - return ppath.relative(resolvedRoot, resolvedP) || PortablePath.dot; - } - mapFromBase(p) { - return p; - } -} - -const URL = Number(process.versions.node.split('.', 1)[0]) < 20 ? URL$1 : globalThis.URL; - -const [major, minor] = process.versions.node.split(`.`).map((value) => parseInt(value, 10)); -const WATCH_MODE_MESSAGE_USES_ARRAYS = major > 19 || major === 19 && minor >= 2 || major === 18 && minor >= 13; -const HAS_LAZY_LOADED_TRANSLATORS = major === 20 && minor < 6 || major === 19 && minor >= 3; -const SUPPORTS_IMPORT_ATTRIBUTES = major >= 21 || major === 20 && minor >= 10 || major === 18 && minor >= 20; -const SUPPORTS_IMPORT_ATTRIBUTES_ONLY = major >= 22; - -function readPackageScope(checkPath) { - const rootSeparatorIndex = checkPath.indexOf(npath.sep); - let separatorIndex; - do { - separatorIndex = checkPath.lastIndexOf(npath.sep); - checkPath = checkPath.slice(0, separatorIndex); - if (checkPath.endsWith(`${npath.sep}node_modules`)) - return false; - const pjson = readPackage(checkPath + npath.sep); - if (pjson) { - return { - data: pjson, - path: checkPath - }; - } - } while (separatorIndex > rootSeparatorIndex); - return false; -} -function readPackage(requestPath) { - const jsonPath = npath.resolve(requestPath, `package.json`); - if (!fs.existsSync(jsonPath)) - return null; - return JSON.parse(fs.readFileSync(jsonPath, `utf8`)); -} - -async function tryReadFile$1(path2) { - try { - return await fs.promises.readFile(path2, `utf8`); - } catch (error) { - if (error.code === `ENOENT`) - return null; - throw error; - } -} -function tryParseURL(str, base) { - try { - return new URL(str, base); - } catch { - return null; - } -} -let entrypointPath = null; -function setEntrypointPath(file) { - entrypointPath = file; -} -function getFileFormat(filepath) { - const ext = path.extname(filepath); - switch (ext) { - case `.mjs`: { - return `module`; - } - case `.cjs`: { - return `commonjs`; - } - case `.wasm`: { - throw new Error( - `Unknown file extension ".wasm" for ${filepath}` - ); - } - case `.json`: { - return `json`; - } - case `.js`: { - const pkg = readPackageScope(filepath); - if (!pkg) - return `commonjs`; - return pkg.data.type ?? `commonjs`; - } - default: { - if (entrypointPath !== filepath) - return null; - const pkg = readPackageScope(filepath); - if (!pkg) - return `commonjs`; - if (pkg.data.type === `module`) - return null; - return pkg.data.type ?? `commonjs`; - } - } -} - -async function load$1(urlString, context, nextLoad) { - const url = tryParseURL(urlString); - if (url?.protocol !== `file:`) - return nextLoad(urlString, context, nextLoad); - const filePath = fileURLToPath(url); - const format = getFileFormat(filePath); - if (!format) - return nextLoad(urlString, context, nextLoad); - if (format === `json`) { - if (SUPPORTS_IMPORT_ATTRIBUTES_ONLY) { - if (context.importAttributes?.type !== `json`) { - const err = new TypeError(`[ERR_IMPORT_ATTRIBUTE_MISSING]: Module "${urlString}" needs an import attribute of "type: json"`); - err.code = `ERR_IMPORT_ATTRIBUTE_MISSING`; - throw err; - } - } else { - const type = `importAttributes` in context ? context.importAttributes?.type : context.importAssertions?.type; - if (type !== `json`) { - const err = new TypeError(`[ERR_IMPORT_ASSERTION_TYPE_MISSING]: Module "${urlString}" needs an import ${SUPPORTS_IMPORT_ATTRIBUTES ? `attribute` : `assertion`} of type "json"`); - err.code = `ERR_IMPORT_ASSERTION_TYPE_MISSING`; - throw err; - } - } - } - if (process.env.WATCH_REPORT_DEPENDENCIES && process.send) { - const pathToSend = pathToFileURL( - npath.fromPortablePath( - VirtualFS.resolveVirtual(npath.toPortablePath(filePath)) - ) - ).href; - process.send({ - "watch:import": WATCH_MODE_MESSAGE_USES_ARRAYS ? [pathToSend] : pathToSend - }); - } - return { - format, - source: format === `commonjs` ? void 0 : await fs.promises.readFile(filePath, `utf8`), - shortCircuit: true - }; -} - -const ArrayIsArray = Array.isArray; -const JSONStringify = JSON.stringify; -const ObjectGetOwnPropertyNames = Object.getOwnPropertyNames; -const ObjectPrototypeHasOwnProperty = (obj, prop) => Object.prototype.hasOwnProperty.call(obj, prop); -const RegExpPrototypeExec = (obj, string) => RegExp.prototype.exec.call(obj, string); -const RegExpPrototypeSymbolReplace = (obj, ...rest) => RegExp.prototype[Symbol.replace].apply(obj, rest); -const StringPrototypeEndsWith = (str, ...rest) => String.prototype.endsWith.apply(str, rest); -const StringPrototypeIncludes = (str, ...rest) => String.prototype.includes.apply(str, rest); -const StringPrototypeLastIndexOf = (str, ...rest) => String.prototype.lastIndexOf.apply(str, rest); -const StringPrototypeIndexOf = (str, ...rest) => String.prototype.indexOf.apply(str, rest); -const StringPrototypeReplace = (str, ...rest) => String.prototype.replace.apply(str, rest); -const StringPrototypeSlice = (str, ...rest) => String.prototype.slice.apply(str, rest); -const StringPrototypeStartsWith = (str, ...rest) => String.prototype.startsWith.apply(str, rest); -const SafeMap = Map; -const JSONParse = JSON.parse; - -function createErrorType(code, messageCreator, errorType) { - return class extends errorType { - constructor(...args) { - super(messageCreator(...args)); - this.code = code; - this.name = `${errorType.name} [${code}]`; - } - }; -} -const ERR_PACKAGE_IMPORT_NOT_DEFINED = createErrorType( - `ERR_PACKAGE_IMPORT_NOT_DEFINED`, - (specifier, packagePath, base) => { - return `Package import specifier "${specifier}" is not defined${packagePath ? ` in package ${packagePath}package.json` : ``} imported from ${base}`; - }, - TypeError -); -const ERR_INVALID_MODULE_SPECIFIER = createErrorType( - `ERR_INVALID_MODULE_SPECIFIER`, - (request, reason, base = void 0) => { - return `Invalid module "${request}" ${reason}${base ? ` imported from ${base}` : ``}`; - }, - TypeError -); -const ERR_INVALID_PACKAGE_TARGET = createErrorType( - `ERR_INVALID_PACKAGE_TARGET`, - (pkgPath, key, target, isImport = false, base = void 0) => { - const relError = typeof target === `string` && !isImport && target.length && !StringPrototypeStartsWith(target, `./`); - if (key === `.`) { - assert(isImport === false); - return `Invalid "exports" main target ${JSONStringify(target)} defined in the package config ${pkgPath}package.json${base ? ` imported from ${base}` : ``}${relError ? `; targets must start with "./"` : ``}`; - } - return `Invalid "${isImport ? `imports` : `exports`}" target ${JSONStringify( - target - )} defined for '${key}' in the package config ${pkgPath}package.json${base ? ` imported from ${base}` : ``}${relError ? `; targets must start with "./"` : ``}`; - }, - Error -); -const ERR_INVALID_PACKAGE_CONFIG = createErrorType( - `ERR_INVALID_PACKAGE_CONFIG`, - (path, base, message) => { - return `Invalid package config ${path}${base ? ` while importing ${base}` : ``}${message ? `. ${message}` : ``}`; - }, - Error -); - -function filterOwnProperties(source, keys) { - const filtered = /* @__PURE__ */ Object.create(null); - for (let i = 0; i < keys.length; i++) { - const key = keys[i]; - if (ObjectPrototypeHasOwnProperty(source, key)) { - filtered[key] = source[key]; - } - } - return filtered; -} - -const packageJSONCache = new SafeMap(); -function getPackageConfig(path, specifier, base, readFileSyncFn) { - const existing = packageJSONCache.get(path); - if (existing !== void 0) { - return existing; - } - const source = readFileSyncFn(path); - if (source === void 0) { - const packageConfig2 = { - pjsonPath: path, - exists: false, - main: void 0, - name: void 0, - type: "none", - exports: void 0, - imports: void 0 - }; - packageJSONCache.set(path, packageConfig2); - return packageConfig2; - } - let packageJSON; - try { - packageJSON = JSONParse(source); - } catch (error) { - throw new ERR_INVALID_PACKAGE_CONFIG( - path, - (base ? `"${specifier}" from ` : "") + fileURLToPath(base || specifier), - error.message - ); - } - let { imports, main, name, type } = filterOwnProperties(packageJSON, [ - "imports", - "main", - "name", - "type" - ]); - const exports = ObjectPrototypeHasOwnProperty(packageJSON, "exports") ? packageJSON.exports : void 0; - if (typeof imports !== "object" || imports === null) { - imports = void 0; - } - if (typeof main !== "string") { - main = void 0; - } - if (typeof name !== "string") { - name = void 0; - } - if (type !== "module" && type !== "commonjs") { - type = "none"; - } - const packageConfig = { - pjsonPath: path, - exists: true, - main, - name, - type, - exports, - imports - }; - packageJSONCache.set(path, packageConfig); - return packageConfig; -} -function getPackageScopeConfig(resolved, readFileSyncFn) { - let packageJSONUrl = new URL("./package.json", resolved); - while (true) { - const packageJSONPath2 = packageJSONUrl.pathname; - if (StringPrototypeEndsWith(packageJSONPath2, "node_modules/package.json")) { - break; - } - const packageConfig2 = getPackageConfig( - fileURLToPath(packageJSONUrl), - resolved, - void 0, - readFileSyncFn - ); - if (packageConfig2.exists) { - return packageConfig2; - } - const lastPackageJSONUrl = packageJSONUrl; - packageJSONUrl = new URL("../package.json", packageJSONUrl); - if (packageJSONUrl.pathname === lastPackageJSONUrl.pathname) { - break; - } - } - const packageJSONPath = fileURLToPath(packageJSONUrl); - const packageConfig = { - pjsonPath: packageJSONPath, - exists: false, - main: void 0, - name: void 0, - type: "none", - exports: void 0, - imports: void 0 - }; - packageJSONCache.set(packageJSONPath, packageConfig); - return packageConfig; -} - -function throwImportNotDefined(specifier, packageJSONUrl, base) { - throw new ERR_PACKAGE_IMPORT_NOT_DEFINED( - specifier, - packageJSONUrl && fileURLToPath(new URL(".", packageJSONUrl)), - fileURLToPath(base) - ); -} -function throwInvalidSubpath(subpath, packageJSONUrl, internal, base) { - const reason = `request is not a valid subpath for the "${internal ? "imports" : "exports"}" resolution of ${fileURLToPath(packageJSONUrl)}`; - throw new ERR_INVALID_MODULE_SPECIFIER( - subpath, - reason, - base && fileURLToPath(base) - ); -} -function throwInvalidPackageTarget(subpath, target, packageJSONUrl, internal, base) { - if (typeof target === "object" && target !== null) { - target = JSONStringify(target, null, ""); - } else { - target = `${target}`; - } - throw new ERR_INVALID_PACKAGE_TARGET( - fileURLToPath(new URL(".", packageJSONUrl)), - subpath, - target, - internal, - base && fileURLToPath(base) - ); -} -const invalidSegmentRegEx = /(^|\\|\/)((\.|%2e)(\.|%2e)?|(n|%6e|%4e)(o|%6f|%4f)(d|%64|%44)(e|%65|%45)(_|%5f)(m|%6d|%4d)(o|%6f|%4f)(d|%64|%44)(u|%75|%55)(l|%6c|%4c)(e|%65|%45)(s|%73|%53))(\\|\/|$)/i; -const patternRegEx = /\*/g; -function resolvePackageTargetString(target, subpath, match, packageJSONUrl, base, pattern, internal, conditions) { - if (subpath !== "" && !pattern && target[target.length - 1] !== "/") - throwInvalidPackageTarget(match, target, packageJSONUrl, internal, base); - if (!StringPrototypeStartsWith(target, "./")) { - if (internal && !StringPrototypeStartsWith(target, "../") && !StringPrototypeStartsWith(target, "/")) { - let isURL = false; - try { - new URL(target); - isURL = true; - } catch { - } - if (!isURL) { - const exportTarget = pattern ? RegExpPrototypeSymbolReplace(patternRegEx, target, () => subpath) : target + subpath; - return exportTarget; - } - } - throwInvalidPackageTarget(match, target, packageJSONUrl, internal, base); - } - if (RegExpPrototypeExec( - invalidSegmentRegEx, - StringPrototypeSlice(target, 2) - ) !== null) - throwInvalidPackageTarget(match, target, packageJSONUrl, internal, base); - const resolved = new URL(target, packageJSONUrl); - const resolvedPath = resolved.pathname; - const packagePath = new URL(".", packageJSONUrl).pathname; - if (!StringPrototypeStartsWith(resolvedPath, packagePath)) - throwInvalidPackageTarget(match, target, packageJSONUrl, internal, base); - if (subpath === "") return resolved; - if (RegExpPrototypeExec(invalidSegmentRegEx, subpath) !== null) { - const request = pattern ? StringPrototypeReplace(match, "*", () => subpath) : match + subpath; - throwInvalidSubpath(request, packageJSONUrl, internal, base); - } - if (pattern) { - return new URL( - RegExpPrototypeSymbolReplace(patternRegEx, resolved.href, () => subpath) - ); - } - return new URL(subpath, resolved); -} -function isArrayIndex(key) { - const keyNum = +key; - if (`${keyNum}` !== key) return false; - return keyNum >= 0 && keyNum < 4294967295; -} -function resolvePackageTarget(packageJSONUrl, target, subpath, packageSubpath, base, pattern, internal, conditions) { - if (typeof target === "string") { - return resolvePackageTargetString( - target, - subpath, - packageSubpath, - packageJSONUrl, - base, - pattern, - internal); - } else if (ArrayIsArray(target)) { - if (target.length === 0) { - return null; - } - let lastException; - for (let i = 0; i < target.length; i++) { - const targetItem = target[i]; - let resolveResult; - try { - resolveResult = resolvePackageTarget( - packageJSONUrl, - targetItem, - subpath, - packageSubpath, - base, - pattern, - internal, - conditions - ); - } catch (e) { - lastException = e; - if (e.code === "ERR_INVALID_PACKAGE_TARGET") { - continue; - } - throw e; - } - if (resolveResult === void 0) { - continue; - } - if (resolveResult === null) { - lastException = null; - continue; - } - return resolveResult; - } - if (lastException === void 0 || lastException === null) - return lastException; - throw lastException; - } else if (typeof target === "object" && target !== null) { - const keys = ObjectGetOwnPropertyNames(target); - for (let i = 0; i < keys.length; i++) { - const key = keys[i]; - if (isArrayIndex(key)) { - throw new ERR_INVALID_PACKAGE_CONFIG( - fileURLToPath(packageJSONUrl), - base, - '"exports" cannot contain numeric property keys.' - ); - } - } - for (let i = 0; i < keys.length; i++) { - const key = keys[i]; - if (key === "default" || conditions.has(key)) { - const conditionalTarget = target[key]; - const resolveResult = resolvePackageTarget( - packageJSONUrl, - conditionalTarget, - subpath, - packageSubpath, - base, - pattern, - internal, - conditions - ); - if (resolveResult === void 0) continue; - return resolveResult; - } - } - return void 0; - } else if (target === null) { - return null; - } - throwInvalidPackageTarget( - packageSubpath, - target, - packageJSONUrl, - internal, - base - ); -} -function patternKeyCompare(a, b) { - const aPatternIndex = StringPrototypeIndexOf(a, "*"); - const bPatternIndex = StringPrototypeIndexOf(b, "*"); - const baseLenA = aPatternIndex === -1 ? a.length : aPatternIndex + 1; - const baseLenB = bPatternIndex === -1 ? b.length : bPatternIndex + 1; - if (baseLenA > baseLenB) return -1; - if (baseLenB > baseLenA) return 1; - if (aPatternIndex === -1) return 1; - if (bPatternIndex === -1) return -1; - if (a.length > b.length) return -1; - if (b.length > a.length) return 1; - return 0; -} -function packageImportsResolve({ name, base, conditions, readFileSyncFn }) { - if (name === "#" || StringPrototypeStartsWith(name, "#/") || StringPrototypeEndsWith(name, "/")) { - const reason = "is not a valid internal imports specifier name"; - throw new ERR_INVALID_MODULE_SPECIFIER(name, reason, fileURLToPath(base)); - } - let packageJSONUrl; - const packageConfig = getPackageScopeConfig(base, readFileSyncFn); - if (packageConfig.exists) { - packageJSONUrl = pathToFileURL(packageConfig.pjsonPath); - const imports = packageConfig.imports; - if (imports) { - if (ObjectPrototypeHasOwnProperty(imports, name) && !StringPrototypeIncludes(name, "*")) { - const resolveResult = resolvePackageTarget( - packageJSONUrl, - imports[name], - "", - name, - base, - false, - true, - conditions - ); - if (resolveResult != null) { - return resolveResult; - } - } else { - let bestMatch = ""; - let bestMatchSubpath; - const keys = ObjectGetOwnPropertyNames(imports); - for (let i = 0; i < keys.length; i++) { - const key = keys[i]; - const patternIndex = StringPrototypeIndexOf(key, "*"); - if (patternIndex !== -1 && StringPrototypeStartsWith( - name, - StringPrototypeSlice(key, 0, patternIndex) - )) { - const patternTrailer = StringPrototypeSlice(key, patternIndex + 1); - if (name.length >= key.length && StringPrototypeEndsWith(name, patternTrailer) && patternKeyCompare(bestMatch, key) === 1 && StringPrototypeLastIndexOf(key, "*") === patternIndex) { - bestMatch = key; - bestMatchSubpath = StringPrototypeSlice( - name, - patternIndex, - name.length - patternTrailer.length - ); - } - } - } - if (bestMatch) { - const target = imports[bestMatch]; - const resolveResult = resolvePackageTarget( - packageJSONUrl, - target, - bestMatchSubpath, - bestMatch, - base, - true, - true, - conditions - ); - if (resolveResult != null) { - return resolveResult; - } - } - } - } - } - throwImportNotDefined(name, packageJSONUrl, base); -} - -let findPnpApi = esmModule.findPnpApi; -if (!findPnpApi) { - const require = createRequire(import.meta.url); - const pnpApi = require(structuredClone(`./.pnp.cjs`)); - pnpApi.setup(); - findPnpApi = esmModule.findPnpApi; -} -const pathRegExp = /^(?![a-zA-Z]:[\\/]|\\\\|\.{0,2}(?:\/|$))((?:node:)?(?:@[^/]+\/)?[^/]+)\/*(.*|)$/; -const isRelativeRegexp = /^\.{0,2}\//; -function tryReadFile(filePath) { - try { - return fs.readFileSync(filePath, `utf8`); - } catch (err) { - if (err.code === `ENOENT`) - return void 0; - throw err; - } -} -async function resolvePrivateRequest(specifier, issuer, context, nextResolve) { - const resolved = packageImportsResolve({ - name: specifier, - base: pathToFileURL(issuer), - conditions: new Set(context.conditions), - readFileSyncFn: tryReadFile - }); - if (resolved instanceof URL) { - return { url: resolved.href, shortCircuit: true }; - } else { - if (resolved.startsWith(`#`)) - throw new Error(`Mapping from one private import to another isn't allowed`); - return resolve$1(resolved, context, nextResolve); - } -} -async function resolve$1(originalSpecifier, context, nextResolve) { - if (!findPnpApi || isBuiltin(originalSpecifier)) - return nextResolve(originalSpecifier, context, nextResolve); - let specifier = originalSpecifier; - const url = tryParseURL(specifier, isRelativeRegexp.test(specifier) ? context.parentURL : void 0); - if (url) { - if (url.protocol !== `file:`) - return nextResolve(originalSpecifier, context, nextResolve); - specifier = fileURLToPath(url); - } - const { parentURL, conditions = [] } = context; - const issuer = parentURL && tryParseURL(parentURL)?.protocol === `file:` ? fileURLToPath(parentURL) : process.cwd(); - const pnpapi = findPnpApi(issuer) ?? (url ? findPnpApi(specifier) : null); - if (!pnpapi) - return nextResolve(originalSpecifier, context, nextResolve); - if (specifier.startsWith(`#`)) - return resolvePrivateRequest(specifier, issuer, context, nextResolve); - const dependencyNameMatch = specifier.match(pathRegExp); - let allowLegacyResolve = false; - if (dependencyNameMatch) { - const [, dependencyName, subPath] = dependencyNameMatch; - if (subPath === `` && dependencyName !== `pnpapi`) { - const resolved = pnpapi.resolveToUnqualified(`${dependencyName}/package.json`, issuer); - if (resolved) { - const content = await tryReadFile$1(resolved); - if (content) { - const pkg = JSON.parse(content); - allowLegacyResolve = pkg.exports == null; - } - } - } - } - let result; - try { - result = pnpapi.resolveRequest(specifier, issuer, { - conditions: new Set(conditions), - // TODO: Handle --experimental-specifier-resolution=node - extensions: allowLegacyResolve ? void 0 : [] - }); - } catch (err) { - if (err instanceof Error && `code` in err && err.code === `MODULE_NOT_FOUND`) - err.code = `ERR_MODULE_NOT_FOUND`; - throw err; - } - if (!result) - throw new Error(`Resolving '${specifier}' from '${issuer}' failed`); - const resultURL = pathToFileURL(result); - if (url) { - resultURL.search = url.search; - resultURL.hash = url.hash; - } - if (!parentURL) - setEntrypointPath(fileURLToPath(resultURL)); - return { - url: resultURL.href, - shortCircuit: true - }; -} - -if (!HAS_LAZY_LOADED_TRANSLATORS) { - const binding = process.binding(`fs`); - const originalReadFile = binding.readFileUtf8 || binding.readFileSync; - if (originalReadFile) { - binding[originalReadFile.name] = function(...args) { - try { - return fs.readFileSync(args[0], { - encoding: `utf8`, - // @ts-expect-error - The docs says it needs to be a string but - // links to https://nodejs.org/dist/latest-v20.x/docs/api/fs.html#file-system-flags - // which says it can be a number which matches the implementation. - flag: args[1] - }); - } catch { - } - return originalReadFile.apply(this, args); - }; - } else { - const binding2 = process.binding(`fs`); - const originalfstat = binding2.fstat; - const ZIP_MASK = 4278190080; - const ZIP_MAGIC = 704643072; - binding2.fstat = function(...args) { - const [fd, useBigint, req] = args; - if ((fd & ZIP_MASK) === ZIP_MAGIC && useBigint === false && req === void 0) { - try { - const stats = fs.fstatSync(fd); - return new Float64Array([ - stats.dev, - stats.mode, - stats.nlink, - stats.uid, - stats.gid, - stats.rdev, - stats.blksize, - stats.ino, - stats.size, - stats.blocks - // atime sec - // atime ns - // mtime sec - // mtime ns - // ctime sec - // ctime ns - // birthtime sec - // birthtime ns - ]); - } catch { - } - } - return originalfstat.apply(this, args); - }; - } -} - -const resolve = resolve$1; -const load = load$1; - -export { load, resolve }; diff --git a/.yarn/install-state.gz b/.yarn/install-state.gz index e1622ea6c4f7ebf130e24f56e26f57ff08bf2663..7f625d0537ff948d33dddb916729928e5c515695 100644 GIT binary patch literal 196027 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∨## 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�n%G%9=DWBjI&(@M2&Vhu! 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 z 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
  • V?A_r6Fc4g4nUv&qEan@0n7K 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

    j7qtHd)Kj7`<4wzn-Ivlh){ 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 diff --git a/.yarnrc.yml b/.yarnrc.yml new file mode 100644 index 0000000..3186f3f --- /dev/null +++ b/.yarnrc.yml @@ -0,0 +1 @@ +nodeLinker: node-modules diff --git a/GLYPHDIFF_PROJECT_PLAN.md b/GLYPHDIFF_PROJECT_PLAN.md deleted file mode 100644 index 55315d8..0000000 --- a/GLYPHDIFF_PROJECT_PLAN.md +++ /dev/null @@ -1,3004 +0,0 @@ -# GlyphDiff.com - Font Comparison Project Plan - -> **Status:** Learning-Focused MVP | **Tech Stack:** SvelteKit + TypeScript + Tailwind CSS | **Transition Path:** React → Svelte - ---- - -## Table of Contents - -1. [Project Overview](#project-overview) -2. [Executive Summary](#executive-summary) -3. [Architecture Decisions](#architecture-decisions) -4. [Font Provider Integration Strategy](#font-provider-integration-strategy) -5. [Performance Optimization](#performance-optimization) -6. [Frontend Architecture](#frontend-architecture) -7. [Data Models](#data-models) -8. [Implementation Roadmap](#implementation-roadmap) -9. [TanStack Query Research](#tanstack-query-research) -10. [Learning Guide: React → Svelte](#learning-guide-react--svelte) -11. [Scalability & Commercialization](#scalability--commercialization) -12. [Deployment](#deployment) -13. [Risk Assessment](#risk-assessment) -14. [Success Metrics](#success-metrics) -15. [Appendix](#appendix) - ---- - -## Project Overview - -### Vision - -Create a modern, fast, and intuitive web application for comparing fonts side-by-side. The tool will help designers, developers, and typographers make informed decisions about font choices by providing real-time visual comparisons, filtering, and customization options. - -### Target Audience - -- **UI/UX Designers:** Selecting typefaces for web and mobile applications -- **Web Developers:** Choosing fonts for implementation in projects -- **Graphic Designers:** Finding complementary fonts for branding -- **Typography Enthusiasts:** Exploring and comparing font characteristics - -### Core Features (MVP) - -1. **Font Catalog:** Browse available fonts from multiple providers -2. **Side-by-Side Comparison:** Compare up to 4 fonts simultaneously -3. **Custom Preview Text:** Enter custom text for realistic comparison -4. **Filter & Search:** Filter by category, popularity, weight, width -5. **Responsive Design:** Seamless experience across all devices -6. **Dark Mode:** Built-in theme toggle for comfortable viewing -7. **URL Sharing:** Share comparison sessions via shareable URLs - -### Tech Stack - -| Layer | Technology | Purpose | -|-------|-----------|---------| -| Framework | SvelteKit 2.x | Full-stack framework with SSR/SSG support | -| UI Language | Svelte 5 | Reactive component framework | -| Styling | Tailwind CSS 4.x | Utility-first CSS framework | -| Component Library | Bits UI | Accessible Svelte components (Radix UI port) | -| Type Safety | TypeScript 5.x | Static type checking | -| Package Manager | Yarn | Fast, reliable dependency management | -| Linting | oxlint | Fast Rust-based linter | -| Formatting | dprint | Fast Rust-based code formatter | -| Hosting | Vercel | Edge deployment & preview environments | - -### Project Goals - -#### Learning Goals (Primary) -- Gain proficiency in Svelte 5 and its reactive primitives (`$state`, `$derived`, `$effect`) -- Understand SvelteKit's routing and data loading architecture -- Learn client-side state management patterns in Svelte ecosystem -- Explore performance optimization techniques for static web apps - -#### Project Goals (Secondary) -- Build a functional, visually appealing font comparison tool -- Create a performant, accessible user interface -- Establish a foundation for future commercialization -- Demonstrate mastery of modern frontend development practices - ---- - -## Executive Summary - -### Recommended Approach: Pure Client-Side Architecture - -**Recommendation:** Build the MVP as a pure client-side application using SvelteKit's static site generation (SSG) capabilities, with no backend infrastructure. - -### Key Rationale - -1. **Learning Focus:** Minimize backend complexity to concentrate on Svelte/SvelteKit mastery -2. **Data Availability:** Font metadata is publicly available via Google Fonts API and Fontshare CDN -3. **Performance:** Static generation provides instant page loads and optimal Core Web Vitals -4. **Cost Efficiency:** No server costs during MVP phase -5. **Future Flexibility:** Can easily add backend later when user data collection becomes necessary - -### Architecture at a Glance - -``` -┌─────────────────────────────────────────────────────────────┐ -│ User Browser │ -│ ┌─────────────────────────────────────────────────────────┐ │ -│ │ SvelteKit Client Application │ │ -│ │ ┌─────────────┐ ┌─────────────┐ ┌─────────────┐ │ │ -│ │ │ Font Store │ │ Filter Store│ │ Comp Store │ │ │ -│ │ └─────────────┘ └─────────────┘ └─────────────┘ │ │ -│ │ ┌─────────────────────────────────────────────────┐ │ │ -│ │ │ Font Provider Services │ │ │ -│ │ │ ┌──────────────┐ ┌──────────────┐ │ │ │ -│ │ │ │ Google Fonts │ │ Fontshare │ │ │ │ -│ │ │ │ API │ │ CDN │ │ │ │ -│ │ │ └──────────────┘ └──────────────┘ │ │ │ -│ │ └─────────────────────────────────────────────────┘ │ │ -│ └─────────────────────────────────────────────────────────┘ │ -└─────────────────────────────────────────────────────────────┘ - │ │ - │ HTTP Requests │ CSS Font Files - ▼ ▼ -┌──────────────────┐ ┌──────────────────┐ -│ Google Fonts API │ │ Fontshare CDN │ -└──────────────────┘ └──────────────────┘ -``` - ---- - -## Architecture Decisions - -### Backend Necessity Analysis - -#### Option A: Pure Client-Side (Recommended for MVP) - -**Pros:** -- **Simplicity:** No server code, database, or API endpoints to maintain -- **Performance:** Static sites load faster and score better on Core Web Vitals -- **Cost:** Zero hosting costs on Vercel free tier -- **Learning Focus:** Maximum time spent on Svelte/SvelteKit fundamentals -- **Deployment:** Instant deployments with zero configuration -- **Scalability:** Vercel Edge handles CDN distribution automatically - -**Cons:** -- **No User Data:** Cannot save user preferences or comparison history -- **No Analytics:** Limited to client-side analytics (e.g., Google Analytics) -- **Rate Limiting:** Google Fonts API has usage limits (1,000 requests/day) -- **Caching:** Cannot implement server-side caching strategies -- **Data Freshness:** Font metadata fetched on each session (mitigated by browser caching) - -**Use Cases This Supports:** -- ✅ Browse and compare fonts -- ✅ Share comparisons via URL -- ✅ Filter and search fonts -- ✅ Save preferences locally (localStorage) -- ✅ Responsive, dark mode UI - -**Use Cases This Does NOT Support:** -- ❌ User accounts and saved comparisons -- ❌ Custom font uploads -- ❌ Collaborative comparisons -- ❌ Advanced analytics - ---- - -#### Option B: Hybrid with Serverless Backend - -**Pros:** -- **Caching Layer:** Server-side caching reduces API calls and improves load times -- **Rate Limit Management:** Proxy requests to avoid Google Fonts API limits -- **User Data:** Save user preferences and comparison history -- **Custom Endpoints:** Create specialized API endpoints for font data -- **Preprocessing:** Transform and normalize font data before sending to client - -**Cons:** -- **Complexity:** Additional infrastructure to build and maintain -- **Cost:** Vercel Pro plan may be required for serverless functions -- **Latency:** Server round-trip adds latency to initial page load -- **Development Overhead:** Testing backend code requires additional considerations -- **Learning Curve:** Takes time away from Svelte learning goals - -**Recommended Backend Stack (if needed later):** -- **API Routes:** SvelteKit server endpoints (`+page.server.ts`, `+server.ts`) -- **Database:** Vercel Postgres (Neon) or SQLite (better-sqlite3) -- **Caching:** Vercel KV (Redis) or in-memory caching -- **Auth:** Lucia Auth or Clerk for user authentication - ---- - -### Recommendation - -**Build Option A (Pure Client-Side) for MVP with these considerations:** - -1. **Design for future backend:** Structure data fetching and state management to be easily adapted to server-side later -2. **Implement smart caching:** Use browser localStorage for font metadata cache with TTL -3. **Optimize API usage:** Batch requests and use Google Fonts API efficiently -4. **Monitor usage:** Track API usage and user engagement to inform backend decision -5. **Migration path:** Keep server components clear of logic that could be moved to `+page.server.ts` later - -### When to Add Backend - -Consider adding backend when: -- ✅ User growth exceeds 1,000 daily active users -- ✅ Analytics show users repeatedly saving comparisons manually -- ✅ Feedback indicates desire for user accounts -- ✅ Performance degrades due to repeated API calls -- ✅ Planning to add premium features requiring payment processing - ---- - -## Font Provider Integration Strategy - -### Provider Overview - -| Provider | API Type | License | Font Count | Integration Complexity | -|----------|----------|---------|------------|------------------------| -| Google Fonts | REST API | Open Source (SIL/OFL) | 1,600+ | Low - Official API available | -| Fontshare | GitHub/CDN | Free License | 100+ | Very Low - Static JSON available | - ---- - -### Google Fonts Integration - -#### API Endpoint - -``` -https://www.googleapis.com/webfonts/v1/webfonts?key=YOUR_API_KEY -``` - -#### TypeScript Implementation - -```typescript -// src/lib/services/google-fonts.ts -import type { FontMetadata, FontVariant, FontCategory } from '$lib/types'; - -export interface GoogleFontsResponse { - kind: string; - items: GoogleFontItem[]; -} - -export interface GoogleFontItem { - family: string; - variants: string[]; - subsets: string[]; - version: string; - lastModified: string; - files: Record; - category: 'sans-serif' | 'serif' | 'display' | 'handwriting' | 'monospace'; -} - -export async function fetchGoogleFonts(apiKey: string): Promise { - const response = await fetch( - `https://www.googleapis.com/webfonts/v1/webfonts?key=${apiKey}` - ); - - if (!response.ok) { - throw new Error(`Google Fonts API error: ${response.statusText}`); - } - - const data: GoogleFontsResponse = await response.json(); - - return data.items.map(mapGoogleFontToMetadata); -} - -function mapGoogleFontToMetadata(item: GoogleFontItem): FontMetadata { - const category = mapGoogleCategory(item.category); - - return { - id: `google-${item.family.toLowerCase().replace(/\s+/g, '-')}`, - provider: 'google-fonts', - family: item.family, - displayName: item.family, - category, - variants: mapGoogleVariants(item.variants), - license: { - type: 'open-source', - url: 'https://fonts.google.com/attribution', - attribution: 'Google Fonts', - commercial: true, - embedding: 'webfont' - }, - languages: item.subsets, - previewUrl: getGoogleFontPreviewUrl(item.family), - cssUrl: getGoogleFontCssUrl(item.family, '400'), - metadata: { - version: item.version, - lastModified: item.lastModified, - files: item.files - } - }; -} - -function mapGoogleCategory( - category: GoogleFontItem['category'] -): FontCategory { - const mapping = { - 'sans-serif': 'sans-serif', - 'serif': 'serif', - 'display': 'display', - 'handwriting': 'handwriting', - 'monospace': 'monospace' - } as const; - return mapping[category] || 'display'; -} - -function mapGoogleVariants(variants: string[]): FontVariant[] { - return variants.map(v => { - const weight = parseInt(v) || 400; - const style = v.includes('italic') ? 'italic' : 'normal'; - return { weight, style, name: v }; - }); -} - -function getGoogleFontPreviewUrl(family: string): string { - return `https://fonts.googleapis.com/css2?family=${encodeURIComponent(family)}:wght@400&display=swap`; -} - -function getGoogleFontCssUrl(family: string, weight: string): string { - return `https://fonts.googleapis.com/css2?family=${encodeURIComponent(family)}:wght@${weight}&display=swap`; -} -``` - -#### Dynamic Font Loading - -```typescript -// src/lib/utils/font-loader.ts -let loadedFonts = new Set(); - -export async function loadFont(family: string, weight: number = 400): Promise { - const fontKey = `${family}-${weight}`; - - if (loadedFonts.has(fontKey)) { - return; - } - - const cssUrl = `https://fonts.googleapis.com/css2?family=${encodeURIComponent(family)}:wght@${weight}&display=swap`; - - try { - // Create and inject link element - const link = document.createElement('link'); - link.rel = 'stylesheet'; - link.href = cssUrl; - link.crossOrigin = 'anonymous'; - - await new Promise((resolve, reject) => { - link.onload = () => { - loadedFonts.add(fontKey); - resolve(); - }; - link.onerror = () => reject(new Error(`Failed to load font: ${family}`)); - document.head.appendChild(link); - }); - } catch (error) { - console.error(`Failed to load font ${family}:`, error); - throw error; - } -} - -export function unloadFont(family: string, weight: number = 400): void { - const cssUrl = `https://fonts.googleapis.com/css2?family=${encodeURIComponent(family)}:wght@${weight}&display=swap`; - const links = document.querySelectorAll(`link[href="${cssUrl}"]`); - links.forEach(link => link.remove()); - loadedFonts.delete(`${family}-${weight}`); -} - -export function preloadFonts(fonts: { family: string; weight: number }[]): void { - fonts.forEach(({ family, weight }) => { - const link = document.createElement('link'); - link.rel = 'preload'; - link.as = 'font'; - link.type = 'font/woff2'; - link.href = `https://fonts.gstatic.com/s/${family.toLowerCase()}/v${weight}`; - link.crossOrigin = 'anonymous'; - document.head.appendChild(link); - }); -} -``` - ---- - -### Fontshare Integration - -#### Data Source - -Fontshare provides a static JSON file with all font metadata: - -``` -https://api.fontshare.com/v2/css?f[]= -``` - -Alternative: Use the GitHub repository data or scrape from the website. - -#### TypeScript Implementation - -```typescript -// src/lib/services/fontshare.ts -import type { FontMetadata } from '$lib/types'; - -export interface FontshareMetadata { - family: string; - slug: string; - styles: FontshareStyle[]; - subsets: string[]; - category: string; -} - -export interface FontshareStyle { - name: string; - weight: number; - file: string; - unicodeRange?: string; -} - -// Fontshare static font list (maintained manually or fetched from their docs) -const FONTHARE_FONTS: FontshareMetadata[] = [ - { - family: 'Albert Sans', - slug: 'albert-sans', - styles: [ - { name: 'Regular', weight: 400, file: 'https://api.fontshare.com/v2/css?f[]=albert-sans@400' }, - { name: 'Medium', weight: 500, file: 'https://api.fontshare.com/v2/css?f[]=albert-sans@500' }, - { name: 'Bold', weight: 700, file: 'https://api.fontshare.com/v2/css?f[]=albert-sans@700' } - ], - subsets: ['latin', 'latin-ext'], - category: 'sans-serif' - }, - // Add more Fontshare fonts as needed... -]; - -export async function fetchFontshareFonts(): Promise { - // In a real implementation, you might fetch this from a maintained JSON file - // For MVP, we use the static list or fetch from Fontshare's API - - // Option 1: Use static list - return FONTHARE_FONTS.map(mapFontshareToMetadata); - - // Option 2: Fetch from Fontshare API (if available) - // const response = await fetch('https://api.fontshare.com/v2/fonts'); - // const data = await response.json(); - // return data.map(mapFontshareToMetadata); -} - -function mapFontshareToMetadata(font: FontshareMetadata): FontMetadata { - return { - id: `fontshare-${font.slug}`, - provider: 'fontshare', - family: font.family, - displayName: font.family, - category: mapFontshareCategory(font.category), - variants: font.styles.map(style => ({ - weight: style.weight, - style: 'normal', - name: style.name, - url: style.file - })), - license: { - type: 'open-source', - url: 'https://www.fontshare.com/license', - attribution: 'Fontshare', - commercial: true, - embedding: 'webfont' - }, - languages: font.subsets, - previewUrl: font.styles[0]?.file || '', - cssUrl: font.styles[0]?.file || '', - metadata: { - slug: font.slug, - styles: font.styles - } - }; -} - -function mapFontshareCategory(category: string): FontCategory { - const validCategories: FontCategory[] = ['sans-serif', 'serif', 'display', 'handwriting', 'monospace']; - const normalized = category.toLowerCase().replace(' ', '-'); - return validCategories.includes(normalized as FontCategory) - ? (normalized as FontCategory) - : 'display'; -} -``` - ---- - -### Data Normalization - -Both providers return different data structures. Normalize to a unified interface: - -```typescript -// src/lib/types/fonts.ts -export type FontCategory = 'sans-serif' | 'serif' | 'display' | 'handwriting' | 'monospace'; -export type FontProvider = 'google-fonts' | 'fontshare'; - -export interface LicenseInfo { - type: 'open-source' | 'commercial' | 'free-for-personal'; - url: string; - attribution: string; - commercial: boolean; - embedding: 'webfont' | 'self-host' | 'both'; -} - -export interface FontVariant { - weight: number; - style: 'normal' | 'italic'; - name: string; - url?: string; -} - -export interface FontMetadata { - id: string; - provider: FontProvider; - family: string; - displayName: string; - category: FontCategory; - variants: FontVariant[]; - license: LicenseInfo; - languages: string[]; - previewUrl: string; - cssUrl: string; - popularity?: number; // For sorting - trending?: boolean; - metadata: Record; -} - -export interface ComparisonFont { - font: FontMetadata; - variant: FontVariant; - size: number; - lineHeight: number; - letterSpacing: number; - color: string; - text?: string; // Override default preview text -} - -export interface ComparisonSettings { - text: string; - backgroundColor: string; - showGrid: boolean; - watermark: boolean; -} -``` - ---- - -## Performance Optimization - -### Lazy Loading Strategy - -#### Font Lazy Loading - -```typescript -// src/lib/hooks/useLazyFontLoader.ts -import { tick } from 'svelte'; -import { loadFont } from '$lib/utils/font-loader'; - -export function useLazyFontLoader() { - let observer: IntersectionObserver | null = null; - let elementsToLoad = new Map(); - - function observe( - element: HTMLElement, - family: string, - weight: number = 400 - ) { - if (!observer) { - observer = new IntersectionObserver( - (entries) => { - entries.forEach(async (entry) => { - if (entry.isIntersecting) { - const data = elementsToLoad.get(entry.target as HTMLElement); - if (data) { - await loadFont(data.family, data.weight); - observer?.unobserve(entry.target); - elementsToLoad.delete(entry.target as HTMLElement); - } - } - }); - }, - { - rootMargin: '200px', // Load before element enters viewport - threshold: 0.01 - } - ); - } - - elementsToLoad.set(element, { family, weight }); - observer.observe(element); - } - - function destroy() { - observer?.disconnect(); - observer = null; - elementsToLoad.clear(); - } - - return { observe, destroy }; -} -``` - -#### Component-Level Usage - -```svelte - - - -

    - {text} -
    - - -``` - -### Caching Strategy - -#### localStorage Caching with TTL - -```typescript -// src/lib/utils/cache.ts -const CACHE_KEY = 'glyphdiff:font-cache'; -const CACHE_VERSION = 1; -const CACHE_TTL = 24 * 60 * 60 * 1000; // 24 hours - -interface CacheEntry { - version: number; - timestamp: number; - data: unknown; -} - -export function setCache(key: string, data: T, ttl: number = CACHE_TTL): void { - const entry: CacheEntry = { - version: CACHE_VERSION, - timestamp: Date.now(), - data - }; - - const cache = getCacheData(); - cache[key] = entry; - - try { - localStorage.setItem(CACHE_KEY, JSON.stringify(cache)); - } catch (error) { - console.warn('Failed to set cache:', error); - } -} - -export function getCache(key: string): T | null { - const cache = getCacheData(); - const entry = cache[key]; - - if (!entry) { - return null; - } - - // Check version - if (entry.version !== CACHE_VERSION) { - delete cache[key]; - saveCacheData(cache); - return null; - } - - // Check TTL - if (Date.now() - entry.timestamp > CACHE_TTL) { - delete cache[key]; - saveCacheData(cache); - return null; - } - - return entry.data as T; -} - -export function clearCache(key?: string): void { - if (key) { - const cache = getCacheData(); - delete cache[key]; - saveCacheData(cache); - } else { - localStorage.removeItem(CACHE_KEY); - } -} - -function getCacheData(): Record { - try { - const cached = localStorage.getItem(CACHE_KEY); - return cached ? JSON.parse(cached) : {}; - } catch { - return {}; - } -} - -function saveCacheData(data: Record): void { - try { - localStorage.setItem(CACHE_KEY, JSON.stringify(data)); - } catch (error) { - console.warn('Failed to save cache:', error); - } -} -``` - -#### Service Worker Caching (Optional for Enhanced PWA) - -```typescript -// src/lib/service-worker.ts -const CACHE_NAME = 'glyphdiff-v1'; -const FONT_CACHE_PREFIX = 'font-'; - -self.addEventListener('install', (event) => { - event.waitUntil( - caches.open(CACHE_NAME).then((cache) => { - return cache.addAll([ - '/', - '/fonts', - '/compare', - // Add other static assets - ]); - }) - ); -}); - -self.addEventListener('fetch', (event) => { - const url = new URL(event.request.url); - - // Cache Google Fonts - if (url.hostname === 'fonts.googleapis.com' || url.hostname === 'fonts.gstatic.com') { - event.respondWith( - caches.open(`${FONT_CACHE_PREFIX}${CACHE_NAME}`).then((cache) => { - return cache.match(event.request).then((response) => { - if (response) { - return response; - } - return fetch(event.request).then((networkResponse) => { - cache.put(event.request, networkResponse.clone()); - return networkResponse; - }); - }); - }) - ); - return; - } - - // Network-first for API calls - if (url.pathname.includes('/api/')) { - event.respondWith( - fetch(event.request) - .then((response) => { - const responseClone = response.clone(); - caches.open(CACHE_NAME).then((cache) => { - cache.put(event.request, responseClone); - }); - return response; - }) - .catch(() => caches.match(event.request)) - ); - return; - } - - // Cache-first for static assets - event.respondWith( - caches.match(event.request).then((response) => { - return response || fetch(event.request); - }) - ); -}); -``` - -### Performance Metrics - -#### Target Core Web Vitals - -| Metric | Target | Why It Matters | -|--------|--------|----------------| -| LCP (Largest Contentful Paint) | < 2.5s | Main content loads quickly | -| FID (First Input Delay) | < 100ms | Responsive to user input | -| CLS (Cumulative Layout Shift) | < 0.1 | Visual stability | -| TTFB (Time to First Byte) | < 600ms | Fast initial response | - -#### Performance Monitoring - -```typescript -// src/lib/utils/performance.ts -export function reportWebVitals(): void { - if (typeof window === 'undefined' || !('PerformanceObserver' in window)) { - return; - } - - // LCP - const lcpObserver = new PerformanceObserver((list) => { - const entries = list.getEntries(); - const lastEntry = entries[entries.length - 1] as any; - console.log('LCP:', lastEntry.startTime); - // Send to analytics - }); - lcpObserver.observe({ entryTypes: ['largest-contentful-paint'] }); - - // FID - const fidObserver = new PerformanceObserver((list) => { - const entries = list.getEntries(); - const fid = entries[0] as any; - console.log('FID:', fid.processingStart - fid.startTime); - // Send to analytics - }); - fidObserver.observe({ entryTypes: ['first-input'] }); - - // CLS - const clsObserver = new PerformanceObserver((list) => { - let clsValue = 0; - for (const entry of list.getEntries() as any[]) { - if (!entry.hadRecentInput) { - clsValue += entry.value; - } - } - console.log('CLS:', clsValue); - // Send to analytics - }); - clsObserver.observe({ entryTypes: ['layout-shift'] }); -} -``` - ---- - -## Frontend Architecture - -### Project Structure - -``` -glyphdiff/ -├── src/ -│ ├── lib/ -│ │ ├── components/ -│ │ │ ├── FontCard.svelte -│ │ │ ├── FontPreview.svelte -│ │ │ ├── ComparisonGrid.svelte -│ │ │ ├── FilterBar.svelte -│ │ │ └── DarkModeToggle.svelte -│ │ ├── stores/ -│ │ │ ├── fontStore.ts -│ │ │ ├── comparisonStore.ts -│ │ │ ├── filterStore.ts -│ │ │ └── uiStore.ts -│ │ ├── services/ -│ │ │ ├── google-fonts.ts -│ │ │ ├── fontshare.ts -│ │ │ └── font-loader.ts -│ │ ├── hooks/ -│ │ │ ├── useLazyFontLoader.ts -│ │ │ ├── useKeyboardShortcuts.ts -│ │ │ └── useLocalStorage.ts -│ │ ├── utils/ -│ │ │ ├── cache.ts -│ │ │ ├── format.ts -│ │ │ └── url.ts -│ │ ├── types/ -│ │ │ ├── fonts.ts -│ │ │ ├── comparison.ts -│ │ │ └── index.ts -│ │ └── constants.ts -│ ├── routes/ -│ │ ├── +layout.svelte -│ │ ├── +layout.ts -│ │ ├── +page.svelte # Home page -│ │ ├── fonts/ -│ │ │ ├── +page.svelte # Font catalog -│ │ │ ├── +page.ts # Font data loading -│ │ │ └── [slug]/ -│ │ │ └── +page.svelte # Font detail page -│ │ └── compare/ -│ │ ├── +page.svelte # Comparison page -│ │ └── +page.ts # URL state parsing -│ ├── app.css -│ └── app.d.ts -├── static/ -│ ├── favicon.ico -│ └── og-image.png -├── tests/ -│ ├── unit/ -│ └── e2e/ -├── package.json -├── svelte.config.js -├── tailwind.config.js -├── tsconfig.json -└── vite.config.ts -``` - -### Component Architecture - -``` -┌────────────────────────────────────────────────────────────┐ -│ +layout.svelte │ -│ ┌──────────────────────────────────────────────────────┐ │ -│ │ Header │ │ -│ │ Logo | Search | DarkModeToggle │ │ -│ └──────────────────────────────────────────────────────┘ │ -│ ┌──────────────────────────────────────────────────────┐ │ -│ │ Main │ │ -│ │ ┌────────────────────────────────────────────────┐ │ │ -│ │ │ +page.svelte (Home) │ │ │ -│ │ │ Hero section → Featured fonts → CTA │ │ │ -│ │ └────────────────────────────────────────────────┘ │ │ -│ │ ┌────────────────────────────────────────────────┐ │ │ -│ │ │ fonts/+page.svelte │ │ │ -│ │ │ FilterBar → FontGrid → FontCard │ │ │ -│ │ │ ┌─────────┐ ┌─────────┐ ┌─────────┐ │ │ │ -│ │ │ │FontCard │ │FontCard │ │FontCard │ ... │ │ │ -│ │ │ └─────────┘ └─────────┘ └─────────┘ │ │ │ -│ │ └────────────────────────────────────────────────┘ │ │ -│ │ ┌────────────────────────────────────────────────┐ │ │ -│ │ │ compare/+page.svelte │ │ │ -│ │ │ ComparisonGrid → FontPreview × 4 │ │ │ -│ │ │ Toolbar (text, size, color, settings) │ │ │ -│ │ └────────────────────────────────────────────────┘ │ │ -│ └──────────────────────────────────────────────────────┘ │ -│ ┌──────────────────────────────────────────────────────┐ │ -│ │ Footer │ │ -│ └──────────────────────────────────────────────────────┘ │ -└────────────────────────────────────────────────────────────┘ -``` - -### Routing Strategy - -#### SvelteKit File-Based Routing - -| Route | File | Purpose | SSR/CSR | -|-------|------|---------|---------| -| `/` | `routes/+page.svelte` | Home/Landing page | SSR | -| `/fonts` | `routes/fonts/+page.svelte` | Font catalog | SSG | -| `/fonts/[slug]` | `routes/fonts/[slug]/+page.svelte` | Font details | SSG | -| `/compare` | `routes/compare/+page.svelte` | Comparison tool | CSR | -| `/api/...` | `routes/api/+server.ts` | Future API routes | Serverless | - -#### URL State for Comparisons - -```typescript -// src/routes/compare/+page.ts -import type { PageLoad } from './$types'; - -export const load: PageLoad = ({ url }) => { - const searchParams = url.searchParams; - - // Parse comparison state from URL - const fontsParam = searchParams.get('fonts'); - const text = searchParams.get('text') || 'The quick brown fox...'; - const size = parseInt(searchParams.get('size') || '24'); - const darkMode = searchParams.get('dark') === 'true'; - - let comparisonFonts: Array<{ family: string; weight: number }> = []; - - if (fontsParam) { - try { - comparisonFonts = JSON.parse(decodeURIComponent(fontsParam)); - } catch (e) { - console.error('Failed to parse fonts param:', e); - } - } - - return { - initialFonts: comparisonFonts, - settings: { text, size, darkMode } - }; -}; -``` - -```svelte - - -``` - ---- - -## Data Models - -### Core Type Definitions - -```typescript -// src/lib/types/fonts.ts - -/** - * Font provider sources - */ -export type FontProvider = 'google-fonts' | 'fontshare'; - -/** - * Standard font categories - */ -export type FontCategory = - | 'sans-serif' - | 'serif' - | 'display' - | 'handwriting' - | 'monospace'; - -/** - * License information for fonts - */ -export interface LicenseInfo { - /** License type classification */ - type: 'open-source' | 'commercial' | 'free-for-personal'; - - /** URL to full license text */ - url: string; - - /** Attribution required for display */ - attribution: string; - - /** Commercial use permitted */ - commercial: boolean; - - /** Allowed embedding methods */ - embedding: 'webfont' | 'self-host' | 'both'; -} - -/** - * Individual font variant (weight/style combination) - */ -export interface FontVariant { - /** Font weight (100-900) */ - weight: number; - - /** Font style */ - style: 'normal' | 'italic'; - - /** Display name for the variant */ - name: string; - - /** URL to the font file (CSS or WOFF2) */ - url?: string; - - /** Subset information (optional) */ - subset?: string; -} - -/** - * Complete metadata for a font family - */ -export interface FontMetadata { - /** Unique identifier for the font */ - id: string; - - /** Source provider */ - provider: FontProvider; - - /** Font family name (CSS property value) */ - family: string; - - /** Display name for UI */ - displayName: string; - - /** Font category */ - category: FontCategory; - - /** Available variants */ - variants: FontVariant[]; - - /** License information */ - license: LicenseInfo; - - /** Supported language subsets */ - languages: string[]; - - /** URL for font preview (CSS) */ - previewUrl: string; - - /** URL for CSS import */ - cssUrl: string; - - /** Popularity score (for sorting) */ - popularity?: number; - - /** Trending status */ - trending?: boolean; - - /** Additional provider-specific metadata */ - metadata: Record; -} - -/** - * Font with selected variant for display - */ -export interface ActiveFont { - /** Font metadata */ - font: FontMetadata; - - /** Selected variant */ - variant: FontVariant; -} - -/** - * Filter options for font catalog - */ -export interface FontFilters { - /** Category filter */ - categories: FontCategory[]; - - /** Weight range filter */ - weightRange: [number, number]; - - /** Provider filter */ - providers: FontProvider[]; - - /** Language subset filter */ - languages: string[]; - - /** Search query */ - search: string; - - /** Sort option */ - sortBy: 'popularity' | 'name' | 'recent' | 'trending'; - - /** Sort direction */ - sortDirection: 'asc' | 'desc'; -} -``` - -```typescript -// src/lib/types/comparison.ts - -import type { FontMetadata, FontVariant } from './fonts'; - -/** - * Display settings for comparison preview - */ -export interface FontDisplaySettings { - /** Font size in pixels */ - size: number; - - /** Line height (unitless multiplier) */ - lineHeight: number; - - /** Letter spacing in pixels */ - letterSpacing: number; - - /** Text color */ - color: string; - - /** Custom preview text override */ - text?: string; - - /** Text alignment */ - textAlign: 'left' | 'center' | 'right'; -} - -/** - * Global comparison settings - */ -export interface ComparisonSettings { - /** Default preview text */ - text: string; - - /** Background color */ - backgroundColor: string; - - /** Show comparison grid lines */ - showGrid: boolean; - - /** Show watermarks/attribution */ - watermark: boolean; - - /** Default display settings */ - display: FontDisplaySettings; -} - -/** - * Font in a comparison session - */ -export interface ComparisonFont { - /** Font metadata */ - font: FontMetadata; - - /** Selected variant */ - variant: FontVariant; - - /** Display settings (overrides global) */ - settings: Partial; -} - -/** - * Complete comparison session - */ -export interface ComparisonSession { - /** Unique session identifier */ - id: string; - - /** Fonts being compared (max 4) */ - fonts: ComparisonFont[]; - - /** Global comparison settings */ - settings: ComparisonSettings; - - /** Session metadata */ - metadata: { - /** Creation timestamp */ - createdAt: number; - - /** Last modified timestamp */ - updatedAt: number; - - /** Session name */ - name?: string; - - /** Whether session is saved */ - saved: boolean; - }; -} - -/** - * Shareable comparison data (for URL encoding) - */ -export interface ShareableComparison { - /** Font identifiers and weights */ - fonts: Array<{ family: string; weight: number }>; - - /** Preview text */ - text?: string; - - /** Font size */ - size?: number; - - /** Dark mode flag */ - dark?: boolean; -} -``` - -```typescript -// src/lib/types/ui.ts - -/** - * UI theme options - */ -export type Theme = 'light' | 'dark' | 'system'; - -/** - * UI settings persisted in localStorage - */ -export interface UISettings { - /** Selected theme */ - theme: Theme; - - /** Grid view density */ - gridDensity: 'compact' | 'comfortable' | 'spacious'; - - /** Show font variants in catalog */ - showVariants: boolean; - - /** Enable animations */ - animationsEnabled: boolean; -} - -/** - * Toast notification types - */ -export type ToastType = 'success' | 'error' | 'info' | 'warning'; - -/** - * Toast notification - */ -export interface Toast { - id: string; - type: ToastType; - message: string; - duration?: number; - action?: { - label: string; - handler: () => void; - }; -} - -/** - * Keyboard shortcut definition - */ -export interface KeyboardShortcut { - key: string; - ctrl?: boolean; - shift?: boolean; - alt?: boolean; - description: string; - action: () => void; -} - -/** - * Modal/Dialog state - */ -export interface ModalState { - id: string | null; - open: boolean; - props?: Record; -} -``` - -```typescript -// src/lib/types/index.ts - -// Re-export all types for convenient importing -export * from './fonts'; -export * from './comparison'; -export * from './ui'; -``` - ---- - -## Implementation Roadmap - -### Week 1: Svelte Fundamentals - -**Goal:** Build foundational understanding of Svelte 5 reactive primitives and set up development environment. - -#### Tasks - -- [ ] **Project Setup** - - [ ] Create SvelteKit project with TypeScript template - - [ ] Install and configure Tailwind CSS 4.x - - [ ] Install and set up Bits UI component library - - [ ] Configure oxlint and dprint for linting and formatting - - [ ] Set up Git repository and .gitignore - -- [ ] **Environment Configuration** - - [ ] Create `.env.example` with GOOGLE_FONTS_API_KEY - - [ ] Add `.env` to `.gitignore` - - [ ] Configure environment variable loading in `vite.config.ts` - -- [ ] **Core Types Definition** - - [ ] Create `src/lib/types/fonts.ts` - - [ ] Create `src/lib/types/comparison.ts` - - [ ] Create `src/lib/types/ui.ts` - - [ ] Create `src/lib/types/index.ts` for re-exports - -- [ ] **Svelte 5 Reactive Primitives Practice** - - [ ] Build Counter component using `$state` - - [ ] Create DerivedCounter component using `$derived` - - [ ] Implement EffectLogger component using `$effect` - - [ ] Practice with reactive arrays and objects - -- [ ] **Practice Components** - - [ ] Build simple Button component - - [ ] Create Toggle component - - [ ] Implement Select dropdown component - - [ ] Build simple FilterBar component - -#### Learning Outcomes -- Understand Svelte 5's new runes system (`$state`, `$derived`, `$effect`) -- Comfortable with Svelte component structure and syntax -- Familiar with Bits UI components -- Tailwind CSS integration working - -#### Week 1 Deliverables -- Working development environment -- 4 practice components demonstrating Svelte reactivity -- Core TypeScript types defined - ---- - -### Week 2: SvelteKit & Routing - -**Goal:** Build font catalog page with routing, data fetching, and understand SvelteKit's SSR capabilities. - -#### Tasks - -- [ ] **Google Fonts Service** - - [ ] Create `fetchGoogleFonts()` function - - [ ] Implement `mapGoogleFontToMetadata()` mapper - - [ ] Add TypeScript interfaces for Google Fonts API response - - [ ] Test with Google Fonts API key - -- [ ] **Fontshare Service** - - [ ] Create `fetchFontshareFonts()` function - - [ ] Build static font list for Fontshare - - [ ] Implement `mapFontshareToMetadata()` mapper - - [ ] Combine both providers into single font catalog - -- [ ] **Font Catalog Page** - - [ ] Create `routes/fonts/+page.svelte` - - [ ] Implement `routes/fonts/+page.ts` for data loading - - [ ] Build FontCard component - - [ ] Create responsive FontGrid layout - -- [ ] **Font Detail Page** - - [ ] Create `routes/fonts/[slug]/+page.svelte` - - [ ] Implement dynamic route parameter extraction - - [ ] Build font detail view with all variants - - [ ] Add "Add to Comparison" button - -- [ ] **Comparison Page Skeleton** - - [ ] Create `routes/compare/+page.svelte` - - [ ] Implement URL state parsing in `+page.ts` - - [ ] Build basic layout for comparison grid - -- [ ] **SSR Understanding** - - [ ] Explore SvelteKit rendering modes (SSR, CSR, SSG) - - [ ] Test page performance with SSR enabled - - [ ] Understand hydration process - - [ ] Configure static generation for font catalog - -#### Learning Outcomes -- Understand SvelteKit file-based routing -- Learn data loading patterns (`+page.ts`, `+page.server.ts`) -- Grasp SSR vs CSR concepts and trade-offs -- Comfortable with dynamic routes and parameters - -#### Week 2 Deliverables -- Working font catalog page with Google Fonts data -- Font detail pages with all metadata -- Basic comparison page with URL state -- Understanding of SvelteKit rendering modes - ---- - -### Week 3: State Management - -**Goal:** Implement comprehensive state management with Svelte stores, localStorage persistence, and URL state synchronization. - -#### Tasks - -- [ ] **Font Store** - - [ ] Create `src/lib/stores/fontStore.ts` - - [ ] Implement `$state` for fonts array - - [ ] Add derived state for filtered fonts - - [ ] Implement localStorage persistence - - [ ] Add loading and error states - -- [ ] **Filter Store** - - [ ] Create `src/lib/stores/filterStore.ts` - - [ ] Implement `$state` for all filter options - - [ ] Add derived state for active filter count - - [ ] Implement reset filters function - - [ ] Add localStorage persistence - -- [ ] **Comparison Store** - - [ ] Create `src/lib/stores/comparisonStore.ts` - - [ ] Implement `$state` for comparison fonts (max 4) - - [ ] Add functions to add/remove fonts - - [ ] Implement comparison settings state - - [ ] Add shareable URL generation - - [ ] Implement localStorage persistence - -- [ ] **UI Store** - - [ ] Create `src/lib/stores/uiStore.ts` - - [ ] Implement theme toggle logic - - [ ] Add settings for grid density, animations - - [ ] Implement system theme detection - - [ ] Add localStorage persistence - -- [ ] **Cache Utility** - - [ ] Implement `cache.ts` with TTL support - - [ ] Add caching to Google Fonts fetcher - - [ ] Implement cache invalidation logic - - [ ] Add cache management UI (optional) - -- [ ] **URL State Integration** - - [ ] Sync comparison state with URL - - [ ] Sync filter state with URL (optional) - - [ ] Implement deep linking to comparisons - - [ ] Handle URL encoding/decoding - -#### Learning Outcomes -- Master Svelte 5 stores with `$state` runes -- Understand localStorage persistence patterns -- Learn URL state synchronization -- Practice derived state and computed values - -#### Week 3 Deliverables -- Fully functional stores for fonts, filters, comparisons, UI -- localStorage persistence working -- URL state synchronization working -- Caching layer implemented - ---- - -### Week 4: UI & Polish - -**Goal:** Build polished UI with Bits UI components, dark mode, responsive design, and smooth animations. - -#### Tasks - -- [ ] **Layout Components** - - [ ] Build Header component with logo and navigation - - [ ] Create Footer component with links and attribution - - [ ] Implement global layout in `+layout.svelte` - - [ ] Add mobile navigation menu - -- [ ] **FilterBar Component** - - [ ] Use Bits UI Select for category filter - - [ ] Use Bits UI Dialog for advanced filters - - [ ] Add search input with debouncing - - [ ] Implement active filter indicators - -- [ ] **ComparisonGrid Component** - - [ ] Use Bits UI Grid for responsive layout - - [ ] Implement drag-and-drop reordering (optional) - - [ ] Add font settings panel per column - - [ ] Implement "Remove font" button - -- [ ] **FontPreview Component** - - [ ] Build preview text area - - [ ] Add size, weight, line-height controls - - [ ] Implement color picker - - [ ] Add lazy loading for fonts - -- [ ] **Dark Mode** - - [ ] Implement dark mode toggle - - [ ] Configure Tailwind dark mode classes - - [ ] Add system preference detection - - [ ] Test color contrast in both themes - -- [ ] **Responsive Design** - - [ ] Test on mobile (375px) - - [ ] Test on tablet (768px) - - [ ] Test on desktop (1280px+) - - [ ] Adjust grid columns for breakpoints - -- [ ] **Animations & Transitions** - - [ ] Add page transitions using Svelte transitions - - [ ] Implement loading skeletons - - [ ] Add hover effects on FontCard - - [ ] Create toast notification system - -- [ ] **Accessibility** - - [ ] Add ARIA labels to interactive elements - - [ ] Ensure keyboard navigation works - - [ ] Test with screen reader - - [ ] Verify color contrast ratios - -- [ ] **Performance Optimization** - - [ ] Implement image/font lazy loading - - [ ] Add code splitting where appropriate - - [ ] Test Lighthouse scores - - [ ] Optimize bundle size - -#### Learning Outcomes -- Proficient with Bits UI component library -- Comfortable building responsive layouts -- Understand accessibility best practices -- Experience with performance optimization - -#### Week 4 Deliverables -- Polished, production-ready UI -- Dark mode fully implemented -- Responsive design across all breakpoints -- Accessibility improvements completed -- Performance targets met - ---- - -## TanStack Query Research - -### What is TanStack Query? - -TanStack Query (formerly React Query) is a powerful data synchronization library for fetching, caching, and managing asynchronous state. It's widely used in the React ecosystem. - -### Key Features - -- **Automatic caching and refetching** -- **Loading and error state management** -- **Optimistic updates** -- **Pagination support** -- **Request deduplication** - -### TanStack Query for Svelte? - -TanStack Query has a Svelte implementation (`@tanstack/svelte-query`) that provides similar functionality to the React version. - -### Why TanStack Query is NOT Recommended for MVP - -| Factor | TanStack Query | SvelteKit Load | Recommendation | -|--------|----------------|----------------|----------------| -| **Data Source** | Client-side API calls | Server-side data loading | SvelteKit Load is sufficient | -| **Complexity** | Additional dependency | Built-in to framework | SvelteKit reduces complexity | -| **SSR Support** | Requires hydration | Native SSR | SvelteKit is cleaner | -| **Learning Curve** | Additional concepts to learn | Learn SvelteKit once | Focus on SvelteKit | -| **Bundle Size** | ~13KB gzipped | 0KB (built-in) | Smaller bundle | -| **Type Safety** | Good | Excellent | SvelteKit with TS is robust | -| **Caching Strategy** | In-memory cache | Static generation + CDN | SSG is more performant | - -### Use Cases Where TanStack Query Would Be Useful - -Consider adding TanStack Query in the future if: -- Implementing user authentication and profile data -- Building real-time features (WebSocket, polling) -- Complex pagination with infinite scroll -- Multiple API endpoints requiring complex cache invalidation -- Offline-first functionality - -### Recommended Data Fetching Approach for MVP - -#### Use SvelteKit's Data Loading - -```typescript -// ✅ Recommended: SvelteKit load function -// src/routes/fonts/+page.ts -import { fetchGoogleFonts, fetchFontshareFonts } from '$lib/services'; -import { setCache, getCache } from '$lib/utils/cache'; - -export const load = async ({ fetch, depends }) => { - // Check cache first - const cached = getCache('font-catalog'); - if (cached) { - return { fonts: cached, cached: true }; - } - - // Fetch from providers - const [googleFonts, fontshareFonts] = await Promise.all([ - fetchGoogleFonts(import.meta.env.VITE_GOOGLE_FONTS_API_KEY), - fetchFontshareFonts() - ]); - - const allFonts = [...googleFonts, ...fontshareFonts]; - - // Cache for 24 hours - setCache('font-catalog', allFonts); - - // Invalidate cache when needed - depends('app:fonts'); - - return { fonts: allFonts, cached: false }; -}; -``` - -#### Use Svelte Stores for Client-Side State - -```typescript -// ✅ Recommended: Svelte 5 stores with $state -// src/lib/stores/fontStore.ts -import { setCache, getCache } from '$lib/utils/cache'; - -class FontStore { - fonts = $state([]); - loading = $state(false); - error = $state(null); - - async loadFonts(apiKey: string) { - this.loading = true; - this.error = null; - - try { - const cached = getCache('font-catalog'); - if (cached) { - this.fonts = cached; - return; - } - - const [googleFonts, fontshareFonts] = await Promise.all([ - fetchGoogleFonts(apiKey), - fetchFontshareFonts() - ]); - - this.fonts = [...googleFonts, ...fontshareFonts]; - setCache('font-catalog', this.fonts); - } catch (e) { - this.error = e as Error; - } finally { - this.loading = false; - } - } -} - -export const fontStore = new FontStore(); -``` - -### Conclusion: Do NOT Use TanStack Query for MVP - -**Reasoning:** -1. SvelteKit's data loading capabilities are sufficient for this project's needs -2. Focus on learning Svelte 5 and SvelteKit rather than adding more dependencies -3. Static generation provides better performance than client-side caching -4. Simpler codebase is easier to maintain while learning - -**Future Consideration:** -Revisit this decision if the project grows to include: -- User authentication -- Real-time features -- Complex client-side data synchronization - ---- - -## Learning Guide: React → Svelte - -### React vs Svelte 5 Comparison - -| React Concept | Svelte 5 Equivalent | Notes | -|--------------|---------------------|-------| -| `useState` | `$state` | No setter function needed, direct reassignment triggers reactivity | -| `useEffect` | `$effect` | Auto-tracks dependencies, no dependency array needed | -| `useMemo` | `$derived` | Computed values that automatically update | -| `useCallback` | Direct function | Functions are auto-memoized in Svelte 5 | -| `children` prop | `` | Slot composition with named slots | -| `props` | `export let` | Props declared with `export let propName` | -| `context` | `setContext` / `getContext` | Similar but with cleaner API | -| `useRef` | `bind:this` | Direct element binding instead of ref objects | -| `useState(prev => prev + 1)` | `count += 1` | Direct mutation works with $state | -| `useReducer` | Custom store with methods | Svelte stores are more flexible | -| `forwardRef` | N/A | Ref forwarding handled automatically | -| `useImperativeHandle` | N/A | Call methods directly on component instances | - -### Code Examples - -#### Counter Component - -**React:** - -```tsx -import { useState, useEffect } from 'react'; - -function Counter({ initial = 0 }: { initial?: number }) { - const [count, setCount] = useState(initial); - const [doubled, setDoubled] = useState(0); - - useEffect(() => { - setDoubled(count * 2); - }, [count]); - - return ( -
    -

    Count: {count}

    -

    Doubled: {doubled}

    - - -
    - ); -} -``` - -**Svelte 5:** - -```svelte - - -
    -

    Count: {count}

    -

    Doubled: {doubled}

    - - -
    -``` - -**Key Differences:** -- No setter function needed - direct mutation works with `$state` -- `$derived` eliminates need for `useEffect` with dependencies -- Functions are defined separately (no need for `useCallback`) -- Event handlers use lowercase `onclick` instead of `onClick` - ---- - -#### Data Fetching - -**React with React Query:** - -```tsx -import { useQuery } from '@tanstack/react-query'; - -function FontList() { - const { - data: fonts, - isLoading, - error - } = useQuery({ - queryKey: ['fonts'], - queryFn: async () => { - const response = await fetch('/api/fonts'); - if (!response.ok) throw new Error('Failed to fetch'); - return response.json(); - } - }); - - if (isLoading) return
    Loading...
    ; - if (error) return
    Error: {error.message}
    ; - - return ( -
      - {fonts.map((font: any) => ( -
    • {font.displayName}
    • - ))} -
    - ); -} -``` - -**SvelteKit with load function:** - -```typescript -// +page.ts -export const load = async ({ fetch }) => { - const response = await fetch('https://www.googleapis.com/webfonts/v1/webfonts?key=' + import.meta.env.VITE_GOOGLE_FONTS_API_KEY); - const fonts = await response.json(); - return { fonts }; -}; -``` - -```svelte - - - -{#if data.fonts} -
      - {#each data.fonts as font} -
    • {font.family}
    • - {/each} -
    -{/if} -``` - -**Key Differences:** -- SvelteKit loads data on the server (SSR) by default -- No loading state needed for initial page load -- Data flows from `load` function to page component via props - ---- - -#### State Management - -**React with Zustand:** - -```ts -// store.ts -import { create } from 'zustand'; - -interface FontStore { - fonts: FontMetadata[]; - selectedFont: string | null; - setFonts: (fonts: FontMetadata[]) => void; - selectFont: (id: string) => void; -} - -export const useFontStore = create((set) => ({ - fonts: [], - selectedFont: null, - setFonts: (fonts) => set({ fonts }), - selectFont: (id) => set({ selectedFont: id }) -})); -``` - -```tsx -// Component.tsx -import { useFontStore } from './store'; - -function FontSelector() { - const { fonts, selectedFont, selectFont } = useFontStore(); - - return ( - - ); -} -``` - -**Svelte with Store:** - -```ts -// fontStore.ts -import type { FontMetadata } from '$lib/types'; - -class FontStore { - fonts = $state([]); - selectedFont = $state(null); - - setFonts(fonts: FontMetadata[]) { - this.fonts = fonts; - } - - selectFont(id: string) { - this.selectedFont = id; - } -} - -export const fontStore = new FontStore(); -``` - -```svelte - - - - -``` - -**Key Differences:** -- Svelte stores use `$state` directly, no need for immer -- Two-way binding with `bind:value` instead of `onChange` -- Store access is simpler - just import and use - ---- - -#### Conditional Rendering - -**React:** - -```tsx -function ConditionalRender({ fonts, loading }: { fonts: Font[]; loading: boolean }) { - if (loading) { - return ; - } - - if (fonts.length === 0) { - return ; - } - - return ( -
    - {fonts.map(font => ( - - ))} -
    - ); -} -``` - -**Svelte:** - -```svelte - - -{#if loading} - -{:else if fonts.length === 0} - -{:else} -
    - {#each fonts as font} - - {/each} -
    -{/if} -``` - -**Key Differences:** -- Svelte uses `{#if}`, `{:else if}`, `{:else}`, `{/if}` block syntax -- No ternary operator needed inside JSX -- `{#each}` block with `{/each}` for lists - ---- - -#### Component Props - -**React:** - -```tsx -interface FontCardProps { - font: FontMetadata; - onClick?: (font: FontMetadata) => void; - size?: number; - showLicense?: boolean; -} - -function FontCard({ font, onClick, size = 16, showLicense = false }: FontCardProps) { - return ( -
    -

    {font.displayName}

    - {showLicense && } - {onClick && } -
    - ); -} -``` - -**Svelte:** - -```svelte - - -
    -

    {font.displayName}

    - {#if showLicense} - - {/if} - {#if onClick} - - {/if} -
    -``` - -**Key Differences:** -- Props declared with `export let` instead of function parameters -- Default values assigned with `=` in declaration -- Event handlers use lowercase (`onclick`) -- Props passed as attributes without curly braces for simple values - ---- - -#### Slot/Children Composition - -**React:** - -```tsx -// Modal.tsx -function Modal({ children, title, footer }: { - children: React.ReactNode; - title: string; - footer?: React.ReactNode; -}) { - return ( -
    -
    {title}
    -
    {children}
    - {footer &&
    {footer}
    } -
    - ); -} - -// Usage -Save}> -

    Choose a font from the list below.

    - -
    -``` - -**Svelte:** - -```svelte - - - - - - - - - - -

    Choose a font from the list below.

    - -
    -``` - -**Key Differences:** -- Named slots using `slot="name"` and `` -- Multiple slots with different names -- Default slot uses `` without name -- `` for content without wrapper element - ---- - -### Common Patterns - -#### Form Handling - -**React:** - -```tsx -function SearchForm({ onSearch }: { onSearch: (query: string) => void }) { - const [query, setQuery] = useState(''); - - const handleSubmit = (e: FormEvent) => { - e.preventDefault(); - onSearch(query); - }; - - return ( -
    - setQuery(e.target.value)} - placeholder="Search fonts..." - /> - -
    - ); -} -``` - -**Svelte:** - -```svelte - - -
    - - -
    -``` - -**Key Difference:** Two-way binding with `bind:value` eliminates the need for `onChange`. - ---- - -#### Lists with Keys - -**React:** - -```tsx -{fonts.map(font => ( - handleSelect(font)} - /> -))} -``` - -**Svelte:** - -```svelte -{#each fonts as font (font.id)} - handleSelect(font)} - /> -{/each} -``` - -**Key Difference:** Key specified in parentheses after item name: `as item (key)`. - ---- - -#### Lifecycle Methods - -**React:** - -```tsx -useEffect(() => { - console.log('Mounted'); - return () => console.log('Cleanup'); -}, []); - -useEffect(() => { - console.log('count changed:', count); -}, [count]); -``` - -**Svelte:** - -```svelte - -``` - ---- - -## Scalability & Commercialization - -### When to Add Backend - -#### Indicators for Backend Implementation - -| Metric | Threshold | Action | -|--------|-----------|--------| -| Daily Active Users | > 1,000 | Consider backend | -| Google Fonts API Usage | > 800/day (80% of limit) | Implement server proxy | -| Feature Requests | > 10/month for user accounts | Plan authentication | -| Comparison Saves | Users frequently export/save | Add database | -| Page Load Time | > 3s on mobile | Optimize with backend caching | - -#### Backend Architecture (When Needed) - -``` -┌─────────────────────────────────────────────────────────────┐ -│ Vercel Edge │ -│ ┌───────────────────────────────────────────────────────┐ │ -│ │ SvelteKit Server Functions │ │ -│ │ ┌──────────────┐ ┌──────────────┐ │ │ -│ │ │ API Routes │ │ Auth Routes │ │ │ -│ │ └──────────────┘ └──────────────┘ │ │ -│ └───────────────────────────────────────────────────────┘ │ -└─────────────────────────────────────────────────────────────┘ - │ │ - ▼ ▼ -┌──────────────────┐ ┌──────────────────┐ -│ Vercel Postgres │ │ Vercel KV │ -│ (User accounts, │ │ (Caching, │ -│ saved comps) │ │ rate limiting) │ -└──────────────────┘ └──────────────────┘ -``` - -#### Recommended Backend Stack - -| Component | Technology | Why | -|-----------|------------|-----| -| Server Runtime | Vercel Edge Functions | Fast, global, free tier generous | -| Database | Vercel Postgres (Neon) | Managed, edge-ready, TypeScript native | -| Caching | Vercel KV (Redis) | Fast key-value store, built-in | -| Authentication | Lucia Auth | Lightweight, framework-agnostic | -| ORM | Drizzle ORM | TypeScript-first, no runtime overhead | -| File Storage | Vercel Blob | Simple, scalable storage | - ---- - -### Monetization Models - -#### Tier 1: Freemium (Recommended Launch Model) - -| Feature | Free | Pro ($5/mo) | -|---------|------|-------------| -| Font comparisons | 4 fonts max | Unlimited | -| Save comparisons | Browser storage only | Cloud sync | -| Export images | Watermarked | No watermark | -| Custom text | Limited chars | Unlimited | -| Advanced filters | Basic | Advanced | -| API access | ❌ | ✅ | - -#### Tier 2: Team/Agency ($29/mo) - -- All Pro features -- Team collaboration (shared workspaces) -- Brand management (save brand fonts) -- Custom domains for shared comparisons -- Priority support -- Monthly usage reports - -#### Tier 3: Enterprise (Custom) - -- Unlimited API access -- Self-hosted deployment option -- Custom integrations -- SSO authentication -- Dedicated support -- SLA guarantees - ---- - -### Additional Features for Monetization - -1. **Font Pairing Recommendations** - - ML-based font matching - - Designer-curated pairings - - Upload custom fonts for analysis - -2. **CSS Generator** - - Export optimized CSS - - Variable font support - - Fallback font stacks - -3. **Embeddable Widget** - - Embed comparison on external sites - - White-label options - - Custom branding - -4. **Font Inspector** - - Detailed glyph analysis - - Character set viewer - - Font metrics display - -5. **A/B Testing** - - Test font combinations - - User feedback collection - - Conversion tracking - ---- - -## Deployment - -### Vercel Configuration - -#### vercel.json - -```json -{ - "buildCommand": "yarn build", - "devCommand": "yarn dev", - "installCommand": "yarn install", - "framework": "sveltekit", - "regions": ["iad1"], - "headers": [ - { - "source": "/(.*)", - "headers": [ - { - "key": "X-Content-Type-Options", - "value": "nosniff" - }, - { - "key": "X-Frame-Options", - "value": "DENY" - }, - { - "key": "X-XSS-Protection", - "value": "1; mode=block" - }, - { - "key": "Referrer-Policy", - "value": "strict-origin-when-cross-origin" - } - ] - }, - { - "source": "/static/(.*)", - "headers": [ - { - "key": "Cache-Control", - "value": "public, max-age=31536000, immutable" - } - ] - }, - { - "source": "/fonts/(.*)", - "headers": [ - { - "key": "Cache-Control", - "value": "public, max-age=604800" - } - ] - } - ], - "rewrites": [ - { - "source": "/api/:path*", - "destination": "/api/:path*" - } - ] -} -``` - ---- - -### Environment Configuration - -#### .env.example - -```bash -# Google Fonts API Key -# Get from: https://developers.google.com/fonts/docs/developer_api -GOOGLE_FONTS_API_KEY=your_api_key_here - -# Application Configuration -APP_URL=https://glyphdiff.com -APP_NAME=GlyphDiff - -# Analytics (Optional) -VITE_GA_ID=G-XXXXXXXXXX -VITE_PLAUSIBLE_DOMAIN= glyphdiff.com - -# Feature Flags -VITE_ENABLE_CACHE=true -VITE_ENABLE_ANALYTICS=false -``` - -#### vite.config.ts - -```typescript -import { sveltekit } from '@sveltejs/kit/vite'; -import { defineConfig } from 'vite'; - -export default defineConfig({ - plugins: [sveltekit()], - define: { - // Expose env variables to client code - 'import.meta.env.VITE_GOOGLE_FONTS_API_KEY': JSON.stringify(process.env.GOOGLE_FONTS_API_KEY), - } -}); -``` - ---- - -### DNS Configuration - -#### DNS Records for glyphdiff.com - -| Type | Name | Value | TTL | -|------|------|-------|-----| -| A | @ | 76.76.21.21 | 3600 | -| CNAME | www | cname.vercel-dns.com | 3600 | - -**Note:** 76.76.21.21 is Vercel's IPv4 address for custom domains. - ---- - -### Build and Deploy Commands - -```bash -# Install dependencies -yarn install - -# Run development server -yarn dev - -# Build for production -yarn build - -# Preview production build -yarn preview - -# Run tests -yarn test - -# Run linter -yarn lint - -# Format code -yarn format - -# Type check -yarn check -``` - -#### package.json Scripts - -```json -{ - "name": "glyphdiff", - "version": "0.1.0", - "private": true, - "scripts": { - "dev": "vite dev", - "build": "vite build", - "preview": "vite preview", - "check": "svelte-kit sync && svelte-check --tsconfig ./tsconfig.json", - "check:watch": "svelte-kit sync && svelte-check --tsconfig ./tsconfig.json --watch", - "lint": "oxlint", - "format": "dprint fmt", - "format:check": "dprint check", - "test": "playwright test", - "test:unit": "vitest" - }, - "devDependencies": { - "@sveltejs/adapter-vercel": "^5.0.0", - "@sveltejs/kit": "^2.0.0", - "svelte": "^5.0.0", - "typescript": "^5.3.0", - "vite": "^5.0.0" - } -} -``` - ---- - -### Deployment Steps - -1. **Push to GitHub** - ```bash - git init - git add . - git commit -m "Initial commit" - git branch -M main - git remote add origin git@github.com:your-username/glyphdiff.git - git push -u origin main - ``` - -2. **Connect to Vercel** - - Go to [vercel.com](https://vercel.com) - - Click "Add New Project" - - Import from GitHub - - Configure environment variables: - - `GOOGLE_FONTS_API_KEY` - -3. **Configure Custom Domain** - - Go to Project Settings → Domains - - Add `glyphdiff.com` - - Add `www.glyphdiff.com` - - Update DNS records as shown above - -4. **Deploy** - - Push changes to GitHub - - Vercel automatically deploys on push to main - - Preview deployments for pull requests - ---- - -## Risk Assessment - -### Technical Risks - -| Risk | Probability | Impact | Mitigation | -|------|-------------|--------|------------| -| Google Fonts API rate limiting | Medium | High | Implement caching, batch requests, consider backend proxy | -| Browser font loading issues | Low | Medium | Use `document.fonts.load()`, implement fallback fonts | -| Poor mobile performance | Medium | High | Lazy loading, code splitting, test on real devices | -| Accessibility violations | Low | Medium | Regular audits with axe DevTools, keyboard testing | -| Vercel free tier limits | Low | Low | Monitor usage, easy upgrade path | - -### Learning Curve Risks - -| Risk | Probability | Impact | Mitigation | -|------|-------------|--------|------------| -| Difficulty with Svelte 5 runes | Medium | High | Start with simple components, practice with $state basics | -| TypeScript integration issues | Low | Medium | Use strict mode from start, leverage SvelteKit templates | -| CSS/Tailwind complexity | Low | Low | Use utility classes, avoid custom CSS where possible | -| Bits UI learning curve | Low | Medium | Read documentation, check examples, copy patterns | - -### External Dependency Risks - -| Risk | Probability | Impact | Mitigation | -|------|-------------|--------|------------| -| Google Fonts API changes | Low | High | Use TypeScript interfaces, watch for deprecation notices | -| Fontshare availability changes | Low | Low | Include as optional source, can be removed if needed | -| Vercel downtime | Very Low | Medium | Static files served from CDN, minimal impact | -| Bits UI breaking changes | Medium | Low | Lock to specific version, update carefully | - ---- - -## Success Metrics - -### Learning Success Metrics - -| Metric | Target | Measurement | -|--------|--------|-------------| -| Svelte 5 proficiency | Comfortable with $state, $derived, $effect | Self-assessment quiz | -| SvelteKit understanding | Build 3+ routes with data loading | Route count | -| Store management | Implement 4 stores with persistence | Store count | -| Component library usage | Use 5+ Bits UI components | Component count | -| TypeScript adoption | 100% typed codebase | Lint check | - -### Project Success Metrics - -| Metric | Target | Measurement | -|--------|--------|-------------| -| Functional font catalog | 1000+ fonts loaded | Google Fonts API response | -| Comparison tool working | 4 fonts simultaneously | Manual testing | -| Performance score | 90+ Lighthouse score | Lighthouse audit | -| Mobile responsiveness | Pass on 375px - 1280px | Browser DevTools | -| Accessibility | WCAG 2.1 AA compliant | axe DevTools | - -### Milestones - -- [ ] **Week 1 Complete:** Environment setup, basic components, types defined -- [ ] **Week 2 Complete:** Font catalog with data fetching, routing working -- [ ] **Week 3 Complete:** All stores implemented, URL state working -- [ ] **Week 4 Complete:** Polished UI, dark mode, responsive design -- [ ] **MVP Launch:** Application deployed to glyphdiff.com -- [ ] **Post-Launch:** Collect feedback, iterate on features - ---- - -## Appendix - -### Commands Reference - -#### Project Initialization - -```bash -# Create new SvelteKit project -yarn create svelte@latest glyphdiff - -# Select options: -# - Which Svelte app template? Skeleton project -# - Add type checking? Yes, using TypeScript -# - Select additional options: Playwright - -# Navigate to project -cd glyphdiff - -# Install dependencies -yarn install - -# Add Tailwind CSS -yarn dlx svelte-add@latest tailwindcss - -# Add Bits UI -yarn add bits-ui - -# Install additional dependencies -yarn add clsx tailwind-merge - -# Install oxlint and dprint -yarn add -D oxlint dprint -``` - -#### Development Commands - -```bash -# Start development server -yarn dev - -# Open browser to localhost:5173 - -# Type check -yarn check - -# Type check in watch mode -yarn check:watch - -# Lint code -yarn lint - -# Format code -yarn format - -# Run Playwright tests -yarn test - -# Run unit tests (Vitest) -yarn test:unit -``` - -#### Build Commands - -```bash -# Build for production -yarn build - -# Preview production build -yarn preview - -# Clean build artifacts -rm -rf .svelte-kit build -``` - -#### Git Commands - -```bash -# Initialize git repo -git init - -# Create .gitignore -echo ".svelte-kit -node_modules -.env -.DS_Store -dist -build -.vercel" > .gitignore - -# Stage all files -git add . - -# Commit -git commit -m "Initial commit" - -# Create main branch -git branch -M main - -# Add remote -git remote add origin git@github.com:username/glyphdiff.git - -# Push to remote -git push -u origin main -``` - ---- - -### Learning Resources - -#### Official Documentation - -- [Svelte 5 Documentation](https://svelte-5-preview.vercel.app/) -- [SvelteKit Documentation](https://kit.svelte.dev/docs) -- [Tailwind CSS Documentation](https://tailwindcss.com/docs) -- [Bits UI Documentation](https://www.bits-ui.com/) - -#### React to Svelte Migration - -- [Svelte for React Developers](https://svelte.dev/docs/svelte-vs-react) -- [Svelte 5 Runes Guide](https://svelte-5-preview.vercel.app/docs/runes-api) -- [SvelteKit Data Loading](https://kit.svelte.dev/docs/load) - -#### Google Fonts API - -- [Google Fonts API Developer Guide](https://developers.google.com/fonts/docs/developer_api) -- [Google Fonts API Reference](https://developers.google.com/fonts/docs/reference/rest) - -#### Video Resources - -- [Svelte 5 Tutorial](https://www.youtube.com/results?search_query=svelte+5+tutorial) -- [SvelteKit Crash Course](https://www.youtube.com/results?search_query=sveltekit+crash+course) -- [Tailwind CSS Full Course](https://www.youtube.com/results?search_query=tailwind+css+full+course) - -#### Community - -- [Svelte Discord](https://svelte.dev/chat) -- [Svelte subreddit](https://reddit.com/r/sveltejs) -- [SvelteKit subreddit](https://reddit.com/r/sveltekit) - ---- - -### File Templates - -#### Component Template - -```svelte - - -
    -

    {prop}

    -

    Count: {count}, Doubled: {doubled}

    - -
    - - -``` - -#### Store Template - -```typescript -import type { FontMetadata } from '$lib/types'; -import { setCache, getCache } from '$lib/utils/cache'; - -class ExampleStore { - // State - items = $state([]); - loading = $state(false); - error = $state(null); - - // Derived state (computed automatically) - get count() { - return this.items.length; - } - - // Methods - async loadItems() { - this.loading = true; - this.error = null; - - try { - // Load from cache first - const cached = getCache('items'); - if (cached) { - this.items = cached; - return; - } - - // Fetch items - // this.items = await fetchItems(); - // setCache('items', this.items); - } catch (e) { - this.error = e as Error; - } finally { - this.loading = false; - } - } - - addItem(item: FontMetadata) { - this.items = [...this.items, item]; - } - - removeItem(id: string) { - this.items = this.items.filter(item => item.id !== id); - } -} - -// Export singleton instance -export const exampleStore = new ExampleStore(); -``` - -#### Load Function Template - -```typescript -// +page.ts or +page.server.ts -import type { PageLoad } from './$types'; - -export const load: PageLoad = async ({ fetch, depends, url }) => { - // Declare dependencies for invalidation - depends('app:data'); - - // Get URL parameters - const search = url.searchParams.get('search') || ''; - - try { - // Fetch data - const response = await fetch('/api/data'); - const data = await response.json(); - - return { - data, - search - }; - } catch (error) { - return { - data: [], - search, - error: error.message - }; - } -}; -``` - ---- - -### Troubleshooting - -#### Common Issues - -**Issue: Google Fonts API returns 403** - -```bash -# Solution: Check API key and rate limits -# 1. Verify API key is correct -# 2. Check API key restrictions (set to None for testing) -# 3. Verify you haven't exceeded daily quota -``` - -**Issue: Tailwind classes not working** - -```bash -# Solution: Check configuration -# 1. Ensure app.css imports tailwind directives -# 2. Restart dev server after config changes -# 3. Check vite.config.ts includes postcss config -``` - -**Issue: Svelte 5 syntax errors** - -```bash -# Solution: Ensure you're using latest Svelte -npm install svelte@next - -# If using VS Code, install Svelte extension -# Ensure it's the latest version for Svelte 5 support -``` - -**Issue: TypeScript errors with $state** - -```bash -# Solution: Update Svelte configuration -# Ensure svelte.config.js includes: -export default { - compilerOptions: { - runes: true - } -}; -``` - -**Issue: Vercel deployment fails** - -```bash -# Solution: Check build output -npm run build - -# Review error logs in Vercel dashboard -# Common issues: -# - Missing environment variables -# - TypeScript errors -# - Build timeout -``` - ---- - -### Performance Checklist - -- [ ] Implement lazy loading for fonts -- [ ] Use SvelteKit static generation where possible -- [ ] Optimize images (use webp format) -- [ ] Minimize JavaScript bundle size -- [ ] Use code splitting for routes -- [ ] Implement caching strategy -- [ ] Enable compression (handled by Vercel) -- [ ] Test Lighthouse scores -- [ ] Minimize layout shifts -- [ ] Use appropriate font formats (WOFF2) - ---- - -## Conclusion - -This project plan provides a comprehensive roadmap for building glyphdiff.com as a learning-focused MVP. The pure client-side approach prioritizes mastering Svelte 5 and SvelteKit while building a functional font comparison tool. - -### Next Steps - -1. Set up the development environment (Week 1 tasks) -2. Obtain Google Fonts API key -3. Configure environment variables -4. Begin implementing Svelte fundamentals - -Good luck on your React → Svelte journey! 🚀 - ---- - -*Document Version: 1.0* -*Last Updated: December 2025* -*Project: glyphdiff.com* diff --git a/dprint.json b/dprint.json index 67d2725..8c057ab 100644 --- a/dprint.json +++ b/dprint.json @@ -1,8 +1,6 @@ { "incremental": true, - "includes": [ - "**/*.{ts,tsx,js,jsx,svelte,json,md}" - ], + "includes": ["**/*.{ts,tsx,js,jsx,svelte,json,md}"], "excludes": [ "**/node_modules", "**/dist", @@ -13,15 +11,16 @@ "plugins": [ "https://plugins.dprint.dev/typescript-0.93.0.wasm", "https://plugins.dprint.dev/json-0.19.3.wasm", - "https://plugins.dprint.dev/markdown-0.17.8.wasm" + "https://plugins.dprint.dev/markdown-0.17.8.wasm", + "https://plugins.dprint.dev/g-plane/markup_fmt-v0.25.3.wasm" ], "typescript": { "lineWidth": 100, - "indentWidth": 2, + "indentWidth": 4, "useTabs": false, "semiColons": "prefer", - "singleQuote": true, - "trailingCommas": "es5", + "quoteStyle": "preferSingle", + "trailingCommas": "onlyMultiLine", "arrowFunction.useParentheses": "preferNone", "importDeclaration.sortNamedImports": "caseInsensitive" }, @@ -31,5 +30,13 @@ }, "markdown": { "lineWidth": 100 + }, + "markup": { + "printWidth": 100, + "indentWidth": 4, + "useTabs": false, + "quotes": "double", + "scriptIndent": true, + "styleIndent": true } } diff --git a/e2e/demo.test.ts b/e2e/demo.test.ts index 9985ce1..cad77f2 100644 --- a/e2e/demo.test.ts +++ b/e2e/demo.test.ts @@ -1,6 +1,6 @@ import { expect, test } from '@playwright/test'; test('home page has expected h1', async ({ page }) => { - await page.goto('/'); - await expect(page.locator('h1')).toBeVisible(); + await page.goto('/'); + await expect(page.locator('h1')).toBeVisible(); }); diff --git a/lefthook.yml b/lefthook.yml new file mode 100644 index 0000000..d16f57f --- /dev/null +++ b/lefthook.yml @@ -0,0 +1,69 @@ +# EXAMPLE USAGE: +# +# Refer for explanation to following link: +# https://lefthook.dev/configuration/ +# +# pre-push: +# jobs: +# - name: packages audit +# tags: +# - frontend +# - security +# run: yarn audit +# +# - name: gems audit +# tags: +# - backend +# - security +# run: bundle audit +# +# pre-commit: +# parallel: true +# jobs: +# - run: yarn eslint {staged_files} +# glob: "*.{js,ts,jsx,tsx}" +# +# - name: rubocop +# glob: "*.rb" +# exclude: +# - config/application.rb +# - config/routes.rb +# run: bundle exec rubocop --force-exclusion {all_files} +# +# - name: govet +# files: git ls-files -m +# glob: "*.go" +# run: go vet {files} +# +# - script: "hello.js" +# runner: node +# +# - script: "hello.go" +# runner: go run + +pre-commit: + parallel: true + commands: + format: + glob: "*.{ts,js,svelte,json,md}" + run: dprint fmt {staged_files} + stage_fixed: true + + lint: + glob: "*.{ts,js,svelte}" + run: oxlint {staged_files} + +pre-push: + parallel: true + commands: + type-check: + run: tsc --noEmit + + svelte-check: + run: svelte-check --threshold warning + + format-check: + run: dprint check + + lint-full: + run: oxlint . diff --git a/package.json b/package.json index 73d257d..77078a6 100644 --- a/package.json +++ b/package.json @@ -1,31 +1,39 @@ { - "name": "glyphdiff", - "private": true, - "version": "0.0.1", - "type": "module", - "scripts": { - "dev": "vite dev", - "build": "vite build", - "preview": "vite preview", - "prepare": "svelte-kit sync || echo ''", - "check": "svelte-kit sync && svelte-check --tsconfig ./tsconfig.json", - "check:watch": "svelte-kit sync && svelte-check --tsconfig ./tsconfig.json --watch", - "lint": "oxlint", - "format": "dprint fmt", - "format:check": "dprint check", - "test:e2e": "playwright test", - "test": "npm run test:e2e" - }, - "devDependencies": { - "@playwright/test": "^1.57.0", - "@sveltejs/adapter-auto": "^7.0.0", - "@sveltejs/kit": "^2.49.1", - "@sveltejs/vite-plugin-svelte": "^6.2.1", - "dprint": "^0.50.2", - "oxlint": "^1.35.0", - "svelte": "^5.45.6", - "svelte-check": "^4.3.4", - "typescript": "^5.9.3", - "vite": "^7.2.6" - } + "name": "glyphdiff", + "private": true, + "version": "0.0.1", + "type": "module", + "scripts": { + "dev": "vite dev", + "build": "vite build", + "preview": "vite preview", + "prepare": "svelte-kit sync || echo ''", + "check": "svelte-kit sync && svelte-check --tsconfig ./tsconfig.json", + "check:watch": "svelte-kit sync && svelte-check --tsconfig ./tsconfig.json --watch", + "lint": "oxlint", + "format": "dprint fmt", + "format:check": "dprint check", + "test:e2e": "playwright test", + "test": "npm run test:e2e" + }, + "devDependencies": { + "@lucide/svelte": "^0.562.0", + "@playwright/test": "^1.57.0", + "@sveltejs/adapter-auto": "^7.0.0", + "@sveltejs/kit": "^2.49.1", + "@sveltejs/vite-plugin-svelte": "^6.2.1", + "@tailwindcss/vite": "^4.1.18", + "clsx": "^2.1.1", + "dprint": "^0.50.2", + "lefthook": "^2.0.13", + "oxlint": "^1.35.0", + "svelte": "^5.45.6", + "svelte-check": "^4.3.4", + "tailwind-merge": "^3.4.0", + "tailwind-variants": "^3.2.2", + "tailwindcss": "^4.1.18", + "tw-animate-css": "^1.4.0", + "typescript": "^5.9.3", + "vite": "^7.2.6" + } } diff --git a/playwright.config.ts b/playwright.config.ts index 8f5062c..999bd03 100644 --- a/playwright.config.ts +++ b/playwright.config.ts @@ -1,6 +1,6 @@ import { defineConfig } from '@playwright/test'; export default defineConfig({ - webServer: { command: 'npm run build && npm run preview', port: 4173 }, - testDir: 'e2e' + webServer: { command: 'npm run build && npm run preview', port: 4173 }, + testDir: 'e2e', }); diff --git a/src/app.css b/src/app.css new file mode 100644 index 0000000..ee2d8d5 --- /dev/null +++ b/src/app.css @@ -0,0 +1,121 @@ +@import "tailwindcss"; + +@import "tw-animate-css"; + +@custom-variant dark (&:is(.dark *)); + +:root { + --radius: 0.625rem; + --background: oklch(1 0 0); + --foreground: oklch(0.141 0.005 285.823); + --card: oklch(1 0 0); + --card-foreground: oklch(0.141 0.005 285.823); + --popover: oklch(1 0 0); + --popover-foreground: oklch(0.141 0.005 285.823); + --primary: oklch(0.21 0.006 285.885); + --primary-foreground: oklch(0.985 0 0); + --secondary: oklch(0.967 0.001 286.375); + --secondary-foreground: oklch(0.21 0.006 285.885); + --muted: oklch(0.967 0.001 286.375); + --muted-foreground: oklch(0.552 0.016 285.938); + --accent: oklch(0.967 0.001 286.375); + --accent-foreground: oklch(0.21 0.006 285.885); + --destructive: oklch(0.577 0.245 27.325); + --border: oklch(0.92 0.004 286.32); + --input: oklch(0.92 0.004 286.32); + --ring: oklch(0.705 0.015 286.067); + --chart-1: oklch(0.646 0.222 41.116); + --chart-2: oklch(0.6 0.118 184.704); + --chart-3: oklch(0.398 0.07 227.392); + --chart-4: oklch(0.828 0.189 84.429); + --chart-5: oklch(0.769 0.188 70.08); + --sidebar: oklch(0.985 0 0); + --sidebar-foreground: oklch(0.141 0.005 285.823); + --sidebar-primary: oklch(0.21 0.006 285.885); + --sidebar-primary-foreground: oklch(0.985 0 0); + --sidebar-accent: oklch(0.967 0.001 286.375); + --sidebar-accent-foreground: oklch(0.21 0.006 285.885); + --sidebar-border: oklch(0.92 0.004 286.32); + --sidebar-ring: oklch(0.705 0.015 286.067); +} + +.dark { + --background: oklch(0.141 0.005 285.823); + --foreground: oklch(0.985 0 0); + --card: oklch(0.21 0.006 285.885); + --card-foreground: oklch(0.985 0 0); + --popover: oklch(0.21 0.006 285.885); + --popover-foreground: oklch(0.985 0 0); + --primary: oklch(0.92 0.004 286.32); + --primary-foreground: oklch(0.21 0.006 285.885); + --secondary: oklch(0.274 0.006 286.033); + --secondary-foreground: oklch(0.985 0 0); + --muted: oklch(0.274 0.006 286.033); + --muted-foreground: oklch(0.705 0.015 286.067); + --accent: oklch(0.274 0.006 286.033); + --accent-foreground: oklch(0.985 0 0); + --destructive: oklch(0.704 0.191 22.216); + --border: oklch(1 0 0 / 10%); + --input: oklch(1 0 0 / 15%); + --ring: oklch(0.552 0.016 285.938); + --chart-1: oklch(0.488 0.243 264.376); + --chart-2: oklch(0.696 0.17 162.48); + --chart-3: oklch(0.769 0.188 70.08); + --chart-4: oklch(0.627 0.265 303.9); + --chart-5: oklch(0.645 0.246 16.439); + --sidebar: oklch(0.21 0.006 285.885); + --sidebar-foreground: oklch(0.985 0 0); + --sidebar-primary: oklch(0.488 0.243 264.376); + --sidebar-primary-foreground: oklch(0.985 0 0); + --sidebar-accent: oklch(0.274 0.006 286.033); + --sidebar-accent-foreground: oklch(0.985 0 0); + --sidebar-border: oklch(1 0 0 / 10%); + --sidebar-ring: oklch(0.552 0.016 285.938); +} + +@theme inline { + --radius-sm: calc(var(--radius) - 4px); + --radius-md: calc(var(--radius) - 2px); + --radius-lg: var(--radius); + --radius-xl: calc(var(--radius) + 4px); + --color-background: var(--background); + --color-foreground: var(--foreground); + --color-card: var(--card); + --color-card-foreground: var(--card-foreground); + --color-popover: var(--popover); + --color-popover-foreground: var(--popover-foreground); + --color-primary: var(--primary); + --color-primary-foreground: var(--primary-foreground); + --color-secondary: var(--secondary); + --color-secondary-foreground: var(--secondary-foreground); + --color-muted: var(--muted); + --color-muted-foreground: var(--muted-foreground); + --color-accent: var(--accent); + --color-accent-foreground: var(--accent-foreground); + --color-destructive: var(--destructive); + --color-border: var(--border); + --color-input: var(--input); + --color-ring: var(--ring); + --color-chart-1: var(--chart-1); + --color-chart-2: var(--chart-2); + --color-chart-3: var(--chart-3); + --color-chart-4: var(--chart-4); + --color-chart-5: var(--chart-5); + --color-sidebar: var(--sidebar); + --color-sidebar-foreground: var(--sidebar-foreground); + --color-sidebar-primary: var(--sidebar-primary); + --color-sidebar-primary-foreground: var(--sidebar-primary-foreground); + --color-sidebar-accent: var(--sidebar-accent); + --color-sidebar-accent-foreground: var(--sidebar-accent-foreground); + --color-sidebar-border: var(--sidebar-border); + --color-sidebar-ring: var(--sidebar-ring); +} + +@layer base { + * { + @apply border-border outline-ring/50; + } + body { + @apply bg-background text-foreground; + } +} \ No newline at end of file diff --git a/src/app.d.ts b/src/app.d.ts index da08e6d..d76242a 100644 --- a/src/app.d.ts +++ b/src/app.d.ts @@ -1,13 +1,13 @@ // See https://svelte.dev/docs/kit/types#app.d.ts // for information about these interfaces declare global { - namespace App { - // interface Error {} - // interface Locals {} - // interface PageData {} - // interface PageState {} - // interface Platform {} - } + namespace App { + // interface Error {} + // interface Locals {} + // interface PageData {} + // interface PageState {} + // interface Platform {} + } } export {}; diff --git a/src/app.html b/src/app.html index f273cc5..1966776 100644 --- a/src/app.html +++ b/src/app.html @@ -1,11 +1,11 @@ - - - - %sveltekit.head% - - -
    %sveltekit.body%
    - + + + + %sveltekit.head% + + +
    %sveltekit.body%
    + diff --git a/src/lib/utils.ts b/src/lib/utils.ts new file mode 100644 index 0000000..f5acaf9 --- /dev/null +++ b/src/lib/utils.ts @@ -0,0 +1,13 @@ +import { type ClassValue, clsx } from 'clsx'; +import { twMerge } from 'tailwind-merge'; + +export function cn(...inputs: ClassValue[]) { + return twMerge(clsx(inputs)); +} + +// eslint-disable-next-line @typescript-eslint/no-explicit-any +export type WithoutChild = T extends { child?: any } ? Omit : T; +// eslint-disable-next-line @typescript-eslint/no-explicit-any +export type WithoutChildren = T extends { children?: any } ? Omit : T; +export type WithoutChildrenOrChild = WithoutChildren>; +export type WithElementRef = T & { ref?: U | null }; diff --git a/src/routes/+layout.svelte b/src/routes/+layout.svelte index 9cebde5..a611c7d 100644 --- a/src/routes/+layout.svelte +++ b/src/routes/+layout.svelte @@ -1,11 +1,11 @@ - + {@render children()} diff --git a/src/routes/+page.svelte b/src/routes/+page.svelte index cc88df0..0bb4a48 100644 --- a/src/routes/+page.svelte +++ b/src/routes/+page.svelte @@ -1,2 +1,9 @@ + +

    Welcome to SvelteKit

    -
    +

    + Visit svelte.dev/docs/kit to read the documentation +

    + diff --git a/svelte.config.js b/svelte.config.js index 74f7d09..37afe3a 100644 --- a/svelte.config.js +++ b/svelte.config.js @@ -3,20 +3,20 @@ import { vitePreprocess } from '@sveltejs/vite-plugin-svelte'; /** @type {import('@sveltejs/kit').Config} */ const config = { - // Consult https://svelte.dev/docs/kit/integrations - // for more information about preprocessors - preprocess: vitePreprocess(), + // Consult https://svelte.dev/docs/kit/integrations + // for more information about preprocessors + preprocess: vitePreprocess(), - compilerOptions: { - runes: true - }, + compilerOptions: { + runes: true, + }, - kit: { - // adapter-auto only supports some environments, see https://svelte.dev/docs/kit/adapter-auto for a list. - // If your environment is not supported, or you settled on a specific environment, switch out the adapter. - // See https://svelte.dev/docs/kit/adapters for more information about adapters. - adapter: adapter() - } + kit: { + // adapter-auto only supports some environments, see https://svelte.dev/docs/kit/adapter-auto for a list. + // If your environment is not supported, or you settled on a specific environment, switch out the adapter. + // See https://svelte.dev/docs/kit/adapters for more information about adapters. + adapter: adapter(), + }, }; export default config; diff --git a/tsconfig.json b/tsconfig.json index 2c2ed3c..c7b9df5 100644 --- a/tsconfig.json +++ b/tsconfig.json @@ -1,20 +1,20 @@ { - "extends": "./.svelte-kit/tsconfig.json", - "compilerOptions": { - "rewriteRelativeImportExtensions": true, - "allowJs": true, - "checkJs": true, - "esModuleInterop": true, - "forceConsistentCasingInFileNames": true, - "resolveJsonModule": true, - "skipLibCheck": true, - "sourceMap": true, - "strict": true, - "moduleResolution": "bundler" - } - // Path aliases are handled by https://svelte.dev/docs/kit/configuration#alias - // except $lib which is handled by https://svelte.dev/docs/kit/configuration#files - // - // To make changes to top-level options such as include and exclude, we recommend extending - // the generated config; see https://svelte.dev/docs/kit/configuration#typescript + "extends": "./.svelte-kit/tsconfig.json", + "compilerOptions": { + "rewriteRelativeImportExtensions": true, + "allowJs": true, + "checkJs": true, + "esModuleInterop": true, + "forceConsistentCasingInFileNames": true, + "resolveJsonModule": true, + "skipLibCheck": true, + "sourceMap": true, + "strict": true, + "moduleResolution": "bundler" + } + // Path aliases are handled by https://svelte.dev/docs/kit/configuration#alias + // except $lib which is handled by https://svelte.dev/docs/kit/configuration#files + // + // To make changes to top-level options such as include and exclude, we recommend extending + // the generated config; see https://svelte.dev/docs/kit/configuration#typescript } diff --git a/vite.config.ts b/vite.config.ts index bbf8c7d..f8b704b 100644 --- a/vite.config.ts +++ b/vite.config.ts @@ -1,6 +1,7 @@ import { sveltekit } from '@sveltejs/kit/vite'; +import tailwindcss from '@tailwindcss/vite'; import { defineConfig } from 'vite'; export default defineConfig({ - plugins: [sveltekit()] + plugins: [sveltekit(), tailwindcss()], }); diff --git a/yarn.lock b/yarn.lock index 4f58bb3..33074cd 100644 --- a/yarn.lock +++ b/yarn.lock @@ -68,6 +68,34 @@ __metadata: languageName: node linkType: hard +"@emnapi/core@npm:^1.7.1": + version: 1.7.1 + resolution: "@emnapi/core@npm:1.7.1" + dependencies: + "@emnapi/wasi-threads": "npm:1.1.0" + tslib: "npm:^2.4.0" + checksum: 10c0/f3740be23440b439333e3ae3832163f60c96c4e35337f3220ceba88f36ee89a57a871d27c94eb7a9ff98a09911ed9a2089e477ab549f4d30029f8b907f84a351 + languageName: node + linkType: hard + +"@emnapi/runtime@npm:^1.7.1": + version: 1.7.1 + resolution: "@emnapi/runtime@npm:1.7.1" + dependencies: + tslib: "npm:^2.4.0" + checksum: 10c0/26b851cd3e93877d8732a985a2ebf5152325bbacc6204ef5336a47359dedcc23faeb08cdfcb8bb389b5401b3e894b882bc1a1e55b4b7c1ed1e67c991a760ddd5 + languageName: node + linkType: hard + +"@emnapi/wasi-threads@npm:1.1.0, @emnapi/wasi-threads@npm:^1.1.0": + version: 1.1.0 + resolution: "@emnapi/wasi-threads@npm:1.1.0" + dependencies: + tslib: "npm:^2.4.0" + checksum: 10c0/e6d54bf2b1e64cdd83d2916411e44e579b6ae35d5def0dea61a3c452d9921373044dff32a8b8473ae60c80692bdc39323e98b96a3f3d87ba6886b24dd0ef7ca1 + languageName: node + linkType: hard + "@esbuild/aix-ppc64@npm:0.27.2": version: 0.27.2 resolution: "@esbuild/aix-ppc64@npm:0.27.2" @@ -319,6 +347,26 @@ __metadata: languageName: node linkType: hard +"@lucide/svelte@npm:^0.562.0": + version: 0.562.0 + resolution: "@lucide/svelte@npm:0.562.0" + peerDependencies: + svelte: ^5 + checksum: 10c0/4886cbae7bf575daf5ee66b26be55a49f6e361672db6eb85f39779c202cd7d4e0d1431f6af710a7045ce9e36e720aef589d78da5807a2f2612c24e54198290bd + languageName: node + linkType: hard + +"@napi-rs/wasm-runtime@npm:^1.1.0": + version: 1.1.0 + resolution: "@napi-rs/wasm-runtime@npm:1.1.0" + dependencies: + "@emnapi/core": "npm:^1.7.1" + "@emnapi/runtime": "npm:^1.7.1" + "@tybys/wasm-util": "npm:^0.10.1" + checksum: 10c0/ee351052123bfc635c4cef03ac273a686522394ccd513b1e5b7b3823cecd6abb4a31f23a3a962933192b87eb7b7c3eb3def7748bd410edc66f932d90cf44e9ab + languageName: node + linkType: hard + "@npmcli/agent@npm:^4.0.0": version: 4.0.0 resolution: "@npmcli/agent@npm:4.0.0" @@ -341,58 +389,58 @@ __metadata: languageName: node linkType: hard -"@oxlint/darwin-arm64@npm:1.35.0": - version: 1.35.0 - resolution: "@oxlint/darwin-arm64@npm:1.35.0" +"@oxlint/darwin-arm64@npm:1.36.0": + version: 1.36.0 + resolution: "@oxlint/darwin-arm64@npm:1.36.0" conditions: os=darwin & cpu=arm64 languageName: node linkType: hard -"@oxlint/darwin-x64@npm:1.35.0": - version: 1.35.0 - resolution: "@oxlint/darwin-x64@npm:1.35.0" +"@oxlint/darwin-x64@npm:1.36.0": + version: 1.36.0 + resolution: "@oxlint/darwin-x64@npm:1.36.0" conditions: os=darwin & cpu=x64 languageName: node linkType: hard -"@oxlint/linux-arm64-gnu@npm:1.35.0": - version: 1.35.0 - resolution: "@oxlint/linux-arm64-gnu@npm:1.35.0" +"@oxlint/linux-arm64-gnu@npm:1.36.0": + version: 1.36.0 + resolution: "@oxlint/linux-arm64-gnu@npm:1.36.0" conditions: os=linux & cpu=arm64 & libc=glibc languageName: node linkType: hard -"@oxlint/linux-arm64-musl@npm:1.35.0": - version: 1.35.0 - resolution: "@oxlint/linux-arm64-musl@npm:1.35.0" +"@oxlint/linux-arm64-musl@npm:1.36.0": + version: 1.36.0 + resolution: "@oxlint/linux-arm64-musl@npm:1.36.0" conditions: os=linux & cpu=arm64 & libc=musl languageName: node linkType: hard -"@oxlint/linux-x64-gnu@npm:1.35.0": - version: 1.35.0 - resolution: "@oxlint/linux-x64-gnu@npm:1.35.0" +"@oxlint/linux-x64-gnu@npm:1.36.0": + version: 1.36.0 + resolution: "@oxlint/linux-x64-gnu@npm:1.36.0" conditions: os=linux & cpu=x64 & libc=glibc languageName: node linkType: hard -"@oxlint/linux-x64-musl@npm:1.35.0": - version: 1.35.0 - resolution: "@oxlint/linux-x64-musl@npm:1.35.0" +"@oxlint/linux-x64-musl@npm:1.36.0": + version: 1.36.0 + resolution: "@oxlint/linux-x64-musl@npm:1.36.0" conditions: os=linux & cpu=x64 & libc=musl languageName: node linkType: hard -"@oxlint/win32-arm64@npm:1.35.0": - version: 1.35.0 - resolution: "@oxlint/win32-arm64@npm:1.35.0" +"@oxlint/win32-arm64@npm:1.36.0": + version: 1.36.0 + resolution: "@oxlint/win32-arm64@npm:1.36.0" conditions: os=win32 & cpu=arm64 languageName: node linkType: hard -"@oxlint/win32-x64@npm:1.35.0": - version: 1.35.0 - resolution: "@oxlint/win32-x64@npm:1.35.0" +"@oxlint/win32-x64@npm:1.36.0": + version: 1.36.0 + resolution: "@oxlint/win32-x64@npm:1.36.0" conditions: os=win32 & cpu=x64 languageName: node linkType: hard @@ -654,6 +702,179 @@ __metadata: languageName: node linkType: hard +"@tailwindcss/node@npm:4.1.18": + version: 4.1.18 + resolution: "@tailwindcss/node@npm:4.1.18" + dependencies: + "@jridgewell/remapping": "npm:^2.3.4" + enhanced-resolve: "npm:^5.18.3" + jiti: "npm:^2.6.1" + lightningcss: "npm:1.30.2" + magic-string: "npm:^0.30.21" + source-map-js: "npm:^1.2.1" + tailwindcss: "npm:4.1.18" + checksum: 10c0/0527f4cb602a80413a7f135edc9a9c785edd543cceedd046ed2401d4c35c1ec433d5162c325d31ee7248f3560a709dafe30a50c1406662f28a2b3aaeb21f69fe + languageName: node + linkType: hard + +"@tailwindcss/oxide-android-arm64@npm:4.1.18": + version: 4.1.18 + resolution: "@tailwindcss/oxide-android-arm64@npm:4.1.18" + conditions: os=android & cpu=arm64 + languageName: node + linkType: hard + +"@tailwindcss/oxide-darwin-arm64@npm:4.1.18": + version: 4.1.18 + resolution: "@tailwindcss/oxide-darwin-arm64@npm:4.1.18" + conditions: os=darwin & cpu=arm64 + languageName: node + linkType: hard + +"@tailwindcss/oxide-darwin-x64@npm:4.1.18": + version: 4.1.18 + resolution: "@tailwindcss/oxide-darwin-x64@npm:4.1.18" + conditions: os=darwin & cpu=x64 + languageName: node + linkType: hard + +"@tailwindcss/oxide-freebsd-x64@npm:4.1.18": + version: 4.1.18 + resolution: "@tailwindcss/oxide-freebsd-x64@npm:4.1.18" + conditions: os=freebsd & cpu=x64 + languageName: node + linkType: hard + +"@tailwindcss/oxide-linux-arm-gnueabihf@npm:4.1.18": + version: 4.1.18 + resolution: "@tailwindcss/oxide-linux-arm-gnueabihf@npm:4.1.18" + conditions: os=linux & cpu=arm + languageName: node + linkType: hard + +"@tailwindcss/oxide-linux-arm64-gnu@npm:4.1.18": + version: 4.1.18 + resolution: "@tailwindcss/oxide-linux-arm64-gnu@npm:4.1.18" + conditions: os=linux & cpu=arm64 & libc=glibc + languageName: node + linkType: hard + +"@tailwindcss/oxide-linux-arm64-musl@npm:4.1.18": + version: 4.1.18 + resolution: "@tailwindcss/oxide-linux-arm64-musl@npm:4.1.18" + conditions: os=linux & cpu=arm64 & libc=musl + languageName: node + linkType: hard + +"@tailwindcss/oxide-linux-x64-gnu@npm:4.1.18": + version: 4.1.18 + resolution: "@tailwindcss/oxide-linux-x64-gnu@npm:4.1.18" + conditions: os=linux & cpu=x64 & libc=glibc + languageName: node + linkType: hard + +"@tailwindcss/oxide-linux-x64-musl@npm:4.1.18": + version: 4.1.18 + resolution: "@tailwindcss/oxide-linux-x64-musl@npm:4.1.18" + conditions: os=linux & cpu=x64 & libc=musl + languageName: node + linkType: hard + +"@tailwindcss/oxide-wasm32-wasi@npm:4.1.18": + version: 4.1.18 + resolution: "@tailwindcss/oxide-wasm32-wasi@npm:4.1.18" + dependencies: + "@emnapi/core": "npm:^1.7.1" + "@emnapi/runtime": "npm:^1.7.1" + "@emnapi/wasi-threads": "npm:^1.1.0" + "@napi-rs/wasm-runtime": "npm:^1.1.0" + "@tybys/wasm-util": "npm:^0.10.1" + tslib: "npm:^2.4.0" + conditions: cpu=wasm32 + languageName: node + linkType: hard + +"@tailwindcss/oxide-win32-arm64-msvc@npm:4.1.18": + version: 4.1.18 + resolution: "@tailwindcss/oxide-win32-arm64-msvc@npm:4.1.18" + conditions: os=win32 & cpu=arm64 + languageName: node + linkType: hard + +"@tailwindcss/oxide-win32-x64-msvc@npm:4.1.18": + version: 4.1.18 + resolution: "@tailwindcss/oxide-win32-x64-msvc@npm:4.1.18" + conditions: os=win32 & cpu=x64 + languageName: node + linkType: hard + +"@tailwindcss/oxide@npm:4.1.18": + version: 4.1.18 + resolution: "@tailwindcss/oxide@npm:4.1.18" + dependencies: + "@tailwindcss/oxide-android-arm64": "npm:4.1.18" + "@tailwindcss/oxide-darwin-arm64": "npm:4.1.18" + "@tailwindcss/oxide-darwin-x64": "npm:4.1.18" + "@tailwindcss/oxide-freebsd-x64": "npm:4.1.18" + "@tailwindcss/oxide-linux-arm-gnueabihf": "npm:4.1.18" + "@tailwindcss/oxide-linux-arm64-gnu": "npm:4.1.18" + "@tailwindcss/oxide-linux-arm64-musl": "npm:4.1.18" + "@tailwindcss/oxide-linux-x64-gnu": "npm:4.1.18" + "@tailwindcss/oxide-linux-x64-musl": "npm:4.1.18" + "@tailwindcss/oxide-wasm32-wasi": "npm:4.1.18" + "@tailwindcss/oxide-win32-arm64-msvc": "npm:4.1.18" + "@tailwindcss/oxide-win32-x64-msvc": "npm:4.1.18" + dependenciesMeta: + "@tailwindcss/oxide-android-arm64": + optional: true + "@tailwindcss/oxide-darwin-arm64": + optional: true + "@tailwindcss/oxide-darwin-x64": + optional: true + "@tailwindcss/oxide-freebsd-x64": + optional: true + "@tailwindcss/oxide-linux-arm-gnueabihf": + optional: true + "@tailwindcss/oxide-linux-arm64-gnu": + optional: true + "@tailwindcss/oxide-linux-arm64-musl": + optional: true + "@tailwindcss/oxide-linux-x64-gnu": + optional: true + "@tailwindcss/oxide-linux-x64-musl": + optional: true + "@tailwindcss/oxide-wasm32-wasi": + optional: true + "@tailwindcss/oxide-win32-arm64-msvc": + optional: true + "@tailwindcss/oxide-win32-x64-msvc": + optional: true + checksum: 10c0/1ff978ef24ffae6369e0468bd8c71d1995a00f1697ac1b8f24e92d2d5505ae23534e6257194e78360c16abbe34fc70de508c86d589917336067a60d755b86fcb + languageName: node + linkType: hard + +"@tailwindcss/vite@npm:^4.1.18": + version: 4.1.18 + resolution: "@tailwindcss/vite@npm:4.1.18" + dependencies: + "@tailwindcss/node": "npm:4.1.18" + "@tailwindcss/oxide": "npm:4.1.18" + tailwindcss: "npm:4.1.18" + peerDependencies: + vite: ^5.2.0 || ^6 || ^7 + checksum: 10c0/7605364d29cd5683948f7b74f22c5f3b39b89b54d25b3b1094f8300ec6fe9f053f73246170debad86e01080f858d0bf6d0ef8e398a9dc0ce1f5a02c34447726b + languageName: node + linkType: hard + +"@tybys/wasm-util@npm:^0.10.1": + version: 0.10.1 + resolution: "@tybys/wasm-util@npm:0.10.1" + dependencies: + tslib: "npm:^2.4.0" + checksum: 10c0/b255094f293794c6d2289300c5fbcafbb5532a3aed3a5ffd2f8dc1828e639b88d75f6a376dd8f94347a44813fd7a7149d8463477a9a49525c8b2dcaa38c2d1e8 + languageName: node + linkType: hard + "@types/cookie@npm:^0.6.0": version: 0.6.0 resolution: "@types/cookie@npm:0.6.0" @@ -773,6 +994,13 @@ __metadata: languageName: node linkType: hard +"detect-libc@npm:^2.0.3": + version: 2.1.2 + resolution: "detect-libc@npm:2.1.2" + checksum: 10c0/acc675c29a5649fa1fb6e255f993b8ee829e510b6b56b0910666949c80c364738833417d0edb5f90e4e46be17228b0f2b66a010513984e18b15deeeac49369c4 + languageName: node + linkType: hard + "devalue@npm:^5.3.2, devalue@npm:^5.5.0": version: 5.6.1 resolution: "devalue@npm:5.6.1" @@ -827,6 +1055,16 @@ __metadata: languageName: node linkType: hard +"enhanced-resolve@npm:^5.18.3": + version: 5.18.4 + resolution: "enhanced-resolve@npm:5.18.4" + dependencies: + graceful-fs: "npm:^4.2.4" + tapable: "npm:^2.2.0" + checksum: 10c0/8f6d42c8a0787a746c493e724c9de5d091cfe8e3f871f2464e2f78a6c55fa1a3aaba495334f923c8ea3ac23e1472491f79feef6fc0fb46a75169cb447ffbe2dc + languageName: node + linkType: hard + "env-paths@npm:^2.2.0": version: 2.2.1 resolution: "env-paths@npm:2.2.1" @@ -1027,20 +1265,28 @@ __metadata: version: 0.0.0-use.local resolution: "glyphdiff@workspace:." dependencies: + "@lucide/svelte": "npm:^0.562.0" "@playwright/test": "npm:^1.57.0" "@sveltejs/adapter-auto": "npm:^7.0.0" "@sveltejs/kit": "npm:^2.49.1" "@sveltejs/vite-plugin-svelte": "npm:^6.2.1" + "@tailwindcss/vite": "npm:^4.1.18" + clsx: "npm:^2.1.1" dprint: "npm:^0.50.2" + lefthook: "npm:^2.0.13" oxlint: "npm:^1.35.0" svelte: "npm:^5.45.6" svelte-check: "npm:^4.3.4" + tailwind-merge: "npm:^3.4.0" + tailwind-variants: "npm:^3.2.2" + tailwindcss: "npm:^4.1.18" + tw-animate-css: "npm:^1.4.0" typescript: "npm:^5.9.3" vite: "npm:^7.2.6" languageName: unknown linkType: soft -"graceful-fs@npm:^4.2.6": +"graceful-fs@npm:^4.2.4, graceful-fs@npm:^4.2.6": version: 4.2.11 resolution: "graceful-fs@npm:4.2.11" checksum: 10c0/386d011a553e02bc594ac2ca0bd6d9e4c22d7fa8cfbfc448a6d148c59ea881b092db9dbe3547ae4b88e55f1b01f7c4a2ecc53b310c042793e63aa44cf6c257f2 @@ -1113,6 +1359,15 @@ __metadata: languageName: node linkType: hard +"jiti@npm:^2.6.1": + version: 2.6.1 + resolution: "jiti@npm:2.6.1" + bin: + jiti: lib/jiti-cli.mjs + checksum: 10c0/79b2e96a8e623f66c1b703b98ec1b8be4500e1d217e09b09e343471bbb9c105381b83edbb979d01cef18318cc45ce6e153571b6c83122170eefa531c64b6789b + languageName: node + linkType: hard + "kleur@npm:^4.1.5": version: 4.1.5 resolution: "kleur@npm:4.1.5" @@ -1120,6 +1375,237 @@ __metadata: languageName: node linkType: hard +"lefthook-darwin-arm64@npm:2.0.13": + version: 2.0.13 + resolution: "lefthook-darwin-arm64@npm:2.0.13" + conditions: os=darwin & cpu=arm64 + languageName: node + linkType: hard + +"lefthook-darwin-x64@npm:2.0.13": + version: 2.0.13 + resolution: "lefthook-darwin-x64@npm:2.0.13" + conditions: os=darwin & cpu=x64 + languageName: node + linkType: hard + +"lefthook-freebsd-arm64@npm:2.0.13": + version: 2.0.13 + resolution: "lefthook-freebsd-arm64@npm:2.0.13" + conditions: os=freebsd & cpu=arm64 + languageName: node + linkType: hard + +"lefthook-freebsd-x64@npm:2.0.13": + version: 2.0.13 + resolution: "lefthook-freebsd-x64@npm:2.0.13" + conditions: os=freebsd & cpu=x64 + languageName: node + linkType: hard + +"lefthook-linux-arm64@npm:2.0.13": + version: 2.0.13 + resolution: "lefthook-linux-arm64@npm:2.0.13" + conditions: os=linux & cpu=arm64 + languageName: node + linkType: hard + +"lefthook-linux-x64@npm:2.0.13": + version: 2.0.13 + resolution: "lefthook-linux-x64@npm:2.0.13" + conditions: os=linux & cpu=x64 + languageName: node + linkType: hard + +"lefthook-openbsd-arm64@npm:2.0.13": + version: 2.0.13 + resolution: "lefthook-openbsd-arm64@npm:2.0.13" + conditions: os=openbsd & cpu=arm64 + languageName: node + linkType: hard + +"lefthook-openbsd-x64@npm:2.0.13": + version: 2.0.13 + resolution: "lefthook-openbsd-x64@npm:2.0.13" + conditions: os=openbsd & cpu=x64 + languageName: node + linkType: hard + +"lefthook-windows-arm64@npm:2.0.13": + version: 2.0.13 + resolution: "lefthook-windows-arm64@npm:2.0.13" + conditions: os=win32 & cpu=arm64 + languageName: node + linkType: hard + +"lefthook-windows-x64@npm:2.0.13": + version: 2.0.13 + resolution: "lefthook-windows-x64@npm:2.0.13" + conditions: os=win32 & cpu=x64 + languageName: node + linkType: hard + +"lefthook@npm:^2.0.13": + version: 2.0.13 + resolution: "lefthook@npm:2.0.13" + dependencies: + lefthook-darwin-arm64: "npm:2.0.13" + lefthook-darwin-x64: "npm:2.0.13" + lefthook-freebsd-arm64: "npm:2.0.13" + lefthook-freebsd-x64: "npm:2.0.13" + lefthook-linux-arm64: "npm:2.0.13" + lefthook-linux-x64: "npm:2.0.13" + lefthook-openbsd-arm64: "npm:2.0.13" + lefthook-openbsd-x64: "npm:2.0.13" + lefthook-windows-arm64: "npm:2.0.13" + lefthook-windows-x64: "npm:2.0.13" + dependenciesMeta: + lefthook-darwin-arm64: + optional: true + lefthook-darwin-x64: + optional: true + lefthook-freebsd-arm64: + optional: true + lefthook-freebsd-x64: + optional: true + lefthook-linux-arm64: + optional: true + lefthook-linux-x64: + optional: true + lefthook-openbsd-arm64: + optional: true + lefthook-openbsd-x64: + optional: true + lefthook-windows-arm64: + optional: true + lefthook-windows-x64: + optional: true + bin: + lefthook: bin/index.js + checksum: 10c0/11dc5a952c24325b19803c261331f1e12ea8eaf31c0ab131815955a6e7210323828995c2b9cc73b79c23de960beda27ab71de88afdf00e40f367c6b13cee1ce3 + languageName: node + linkType: hard + +"lightningcss-android-arm64@npm:1.30.2": + version: 1.30.2 + resolution: "lightningcss-android-arm64@npm:1.30.2" + conditions: os=android & cpu=arm64 + languageName: node + linkType: hard + +"lightningcss-darwin-arm64@npm:1.30.2": + version: 1.30.2 + resolution: "lightningcss-darwin-arm64@npm:1.30.2" + conditions: os=darwin & cpu=arm64 + languageName: node + linkType: hard + +"lightningcss-darwin-x64@npm:1.30.2": + version: 1.30.2 + resolution: "lightningcss-darwin-x64@npm:1.30.2" + conditions: os=darwin & cpu=x64 + languageName: node + linkType: hard + +"lightningcss-freebsd-x64@npm:1.30.2": + version: 1.30.2 + resolution: "lightningcss-freebsd-x64@npm:1.30.2" + conditions: os=freebsd & cpu=x64 + languageName: node + linkType: hard + +"lightningcss-linux-arm-gnueabihf@npm:1.30.2": + version: 1.30.2 + resolution: "lightningcss-linux-arm-gnueabihf@npm:1.30.2" + conditions: os=linux & cpu=arm + languageName: node + linkType: hard + +"lightningcss-linux-arm64-gnu@npm:1.30.2": + version: 1.30.2 + resolution: "lightningcss-linux-arm64-gnu@npm:1.30.2" + conditions: os=linux & cpu=arm64 & libc=glibc + languageName: node + linkType: hard + +"lightningcss-linux-arm64-musl@npm:1.30.2": + version: 1.30.2 + resolution: "lightningcss-linux-arm64-musl@npm:1.30.2" + conditions: os=linux & cpu=arm64 & libc=musl + languageName: node + linkType: hard + +"lightningcss-linux-x64-gnu@npm:1.30.2": + version: 1.30.2 + resolution: "lightningcss-linux-x64-gnu@npm:1.30.2" + conditions: os=linux & cpu=x64 & libc=glibc + languageName: node + linkType: hard + +"lightningcss-linux-x64-musl@npm:1.30.2": + version: 1.30.2 + resolution: "lightningcss-linux-x64-musl@npm:1.30.2" + conditions: os=linux & cpu=x64 & libc=musl + languageName: node + linkType: hard + +"lightningcss-win32-arm64-msvc@npm:1.30.2": + version: 1.30.2 + resolution: "lightningcss-win32-arm64-msvc@npm:1.30.2" + conditions: os=win32 & cpu=arm64 + languageName: node + linkType: hard + +"lightningcss-win32-x64-msvc@npm:1.30.2": + version: 1.30.2 + resolution: "lightningcss-win32-x64-msvc@npm:1.30.2" + conditions: os=win32 & cpu=x64 + languageName: node + linkType: hard + +"lightningcss@npm:1.30.2": + version: 1.30.2 + resolution: "lightningcss@npm:1.30.2" + dependencies: + detect-libc: "npm:^2.0.3" + lightningcss-android-arm64: "npm:1.30.2" + lightningcss-darwin-arm64: "npm:1.30.2" + lightningcss-darwin-x64: "npm:1.30.2" + lightningcss-freebsd-x64: "npm:1.30.2" + lightningcss-linux-arm-gnueabihf: "npm:1.30.2" + lightningcss-linux-arm64-gnu: "npm:1.30.2" + lightningcss-linux-arm64-musl: "npm:1.30.2" + lightningcss-linux-x64-gnu: "npm:1.30.2" + lightningcss-linux-x64-musl: "npm:1.30.2" + lightningcss-win32-arm64-msvc: "npm:1.30.2" + lightningcss-win32-x64-msvc: "npm:1.30.2" + dependenciesMeta: + lightningcss-android-arm64: + optional: true + lightningcss-darwin-arm64: + optional: true + lightningcss-darwin-x64: + optional: true + lightningcss-freebsd-x64: + optional: true + lightningcss-linux-arm-gnueabihf: + optional: true + lightningcss-linux-arm64-gnu: + optional: true + lightningcss-linux-arm64-musl: + optional: true + lightningcss-linux-x64-gnu: + optional: true + lightningcss-linux-x64-musl: + optional: true + lightningcss-win32-arm64-msvc: + optional: true + lightningcss-win32-x64-msvc: + optional: true + checksum: 10c0/5c0c73a33946dab65908d5cd1325df4efa290efb77f940b60f40448b5ab9a87d3ea665ef9bcf00df4209705050ecf2f7ecc649f44d6dfa5905bb50f15717e78d + languageName: node + linkType: hard + "locate-character@npm:^3.0.0": version: 3.0.0 resolution: "locate-character@npm:3.0.0" @@ -1134,7 +1620,7 @@ __metadata: languageName: node linkType: hard -"magic-string@npm:^0.30.11, magic-string@npm:^0.30.17, magic-string@npm:^0.30.5": +"magic-string@npm:^0.30.11, magic-string@npm:^0.30.17, magic-string@npm:^0.30.21, magic-string@npm:^0.30.5": version: 0.30.21 resolution: "magic-string@npm:0.30.21" dependencies: @@ -1316,17 +1802,17 @@ __metadata: linkType: hard "oxlint@npm:^1.35.0": - version: 1.35.0 - resolution: "oxlint@npm:1.35.0" + version: 1.36.0 + resolution: "oxlint@npm:1.36.0" dependencies: - "@oxlint/darwin-arm64": "npm:1.35.0" - "@oxlint/darwin-x64": "npm:1.35.0" - "@oxlint/linux-arm64-gnu": "npm:1.35.0" - "@oxlint/linux-arm64-musl": "npm:1.35.0" - "@oxlint/linux-x64-gnu": "npm:1.35.0" - "@oxlint/linux-x64-musl": "npm:1.35.0" - "@oxlint/win32-arm64": "npm:1.35.0" - "@oxlint/win32-x64": "npm:1.35.0" + "@oxlint/darwin-arm64": "npm:1.36.0" + "@oxlint/darwin-x64": "npm:1.36.0" + "@oxlint/linux-arm64-gnu": "npm:1.36.0" + "@oxlint/linux-arm64-musl": "npm:1.36.0" + "@oxlint/linux-x64-gnu": "npm:1.36.0" + "@oxlint/linux-x64-musl": "npm:1.36.0" + "@oxlint/win32-arm64": "npm:1.36.0" + "@oxlint/win32-x64": "npm:1.36.0" peerDependencies: oxlint-tsgolint: ">=0.10.0" dependenciesMeta: @@ -1352,7 +1838,7 @@ __metadata: bin: oxc_language_server: bin/oxc_language_server oxlint: bin/oxlint - checksum: 10c0/1cc62c5902a944cb4e37c7eaf211aae83f0d57672ecc75f8e92c2c5a208934ed21c67ad2f558009d2ede080683b981fba78242d55013a2d4fc9f5efea2023d54 + checksum: 10c0/e480ede331a2be74f879e378bea9eae9e5561064ea81938cf68c525ef3295633100c92f7f045730eae8561da27f02c0fdfd1a59c567df5a32f5a92a60253b811 languageName: node linkType: hard @@ -1662,6 +2148,40 @@ __metadata: languageName: node linkType: hard +"tailwind-merge@npm:^3.4.0": + version: 3.4.0 + resolution: "tailwind-merge@npm:3.4.0" + checksum: 10c0/eaf17bb695c51c7bb7a90366a9c62be295473ee97fcfd1da54287714d4a5788a88ff4ad1ab9e0128638257fda777d6c9ea88682e36195e31a7fa2cf43f45e310 + languageName: node + linkType: hard + +"tailwind-variants@npm:^3.2.2": + version: 3.2.2 + resolution: "tailwind-variants@npm:3.2.2" + peerDependencies: + tailwind-merge: ">=3.0.0" + tailwindcss: "*" + peerDependenciesMeta: + tailwind-merge: + optional: true + checksum: 10c0/715a35b66c374f3bb234cd1e6737588cb7c0213c80a69bd62239d752d20c44377bec1d028c3ea7c28882d81384507fbae407813d348c142cb991c5a0ad063d48 + languageName: node + linkType: hard + +"tailwindcss@npm:4.1.18, tailwindcss@npm:^4.1.18": + version: 4.1.18 + resolution: "tailwindcss@npm:4.1.18" + checksum: 10c0/c79263cea0b2c577859b02f28284caa4eb3844e4d0f563686726ca97817c045c5c395a55bc776daaa351ba9e4aefa9a75bfbb43c22d86f3c573eecc2b87d6bf1 + languageName: node + linkType: hard + +"tapable@npm:^2.2.0": + version: 2.3.0 + resolution: "tapable@npm:2.3.0" + checksum: 10c0/cb9d67cc2c6a74dedc812ef3085d9d681edd2c1fa18e4aef57a3c0605fdbe44e6b8ea00bd9ef21bc74dd45314e39d31227aa031ebf2f5e38164df514136f2681 + languageName: node + linkType: hard + "tar@npm:^7.5.2": version: 7.5.2 resolution: "tar@npm:7.5.2" @@ -1692,6 +2212,20 @@ __metadata: languageName: node linkType: hard +"tslib@npm:^2.4.0": + version: 2.8.1 + resolution: "tslib@npm:2.8.1" + checksum: 10c0/9c4759110a19c53f992d9aae23aac5ced636e99887b51b9e61def52611732872ff7668757d4e4c61f19691e36f4da981cd9485e869b4a7408d689f6bf1f14e62 + languageName: node + linkType: hard + +"tw-animate-css@npm:^1.4.0": + version: 1.4.0 + resolution: "tw-animate-css@npm:1.4.0" + checksum: 10c0/6cfbc19ccc73883ec80ef1f9147f43e736cb01ee99c8172968b37eb81b720523d30e38b1a96aef92db3c586d864204db5510b51744ddacbbf0ad8e3c7fb56ec7 + languageName: node + linkType: hard + "typescript@npm:^5.9.3": version: 5.9.3 resolution: "typescript@npm:5.9.3"

    Visit svelte.dev/docs/kit to read the documentation