diff --git a/.gitignore b/.gitignore new file mode 100644 index 000000000..f3a2f3a74 --- /dev/null +++ b/.gitignore @@ -0,0 +1,3 @@ +restored-src/.claude-sandbox/ +restored-src/tmp-debug*.log +restored-src/ui-debug.log diff --git a/README.md b/README.md index 04e97ab6e..aade64473 100644 --- a/README.md +++ b/README.md @@ -14,6 +14,50 @@ 本仓库通过 npm 发布包(`@anthropic-ai/claude-code`)内附带的 source map(`cli.js.map`)还原的 TypeScript 源码,版本为 `2.1.88`。 +## 运行 + +当前仓库里真正可直接运行的是 npm 发布包内的打包产物 `package/cli.js`,不是 `restored-src`。 + +```bash +npm run version:claude +npm start -- --help +``` + +重新提取源码可直接执行: + +```bash +npm run extract +``` + +`restored-src` 目前仍是还原后的研究素材,不包含完整官方构建配置,不能视为已恢复成可直接编译运行的源码工程。 + +如果后续目标是把 `restored-src` 也修到可运行,需要继续补官方构建期宏、路径别名以及还原结果里缺失的依赖文件;当前这一步只把仓库修到“可以直接运行打包版 CLI,并能重新提取源码”。 + +当前仓库也额外提供了 `restored-src` 的最小启动壳,方便继续排查源码工程的运行阻塞: + +```bash +cd restored-src +bun run bootstrap:manifests +``` + +如果在 Windows 上从 `restored-src` 或其子目录直接执行 `bun`,Bun 1.3.7 目前会额外打印一条与仓库根目录相关的伪 `EPERM`: + +```text +error: Cannot read file "F:\Projects\claude-code-sourcemap\": EPERM +``` + +这条噪音不来自 `restored-src` 源码本身;从仓库根目录启动同一入口则不会出现。为了走干净链路,仓库根还提供了无噪音包装脚本: + +```bash +bun run restored:help +bun run restored:version +bun run restored:cli -- --bare -p "ping" +bun run version:claude +bun run help +``` + +它会先为还原出来但缺少 `package.json` 的依赖包生成最小入口清单,再用 Bun 启动入口;这仍然不代表 `restored-src` 已完全恢复为官方可构建工程。 + ## 来源 - npm 包:[@anthropic-ai/claude-code](https://www.npmjs.com/package/@anthropic-ai/claude-code) diff --git a/extract-sources.js b/extract-sources.js index 635f7047e..0db3fa783 100644 --- a/extract-sources.js +++ b/extract-sources.js @@ -1,4 +1,3 @@ -const { SourceMapConsumer } = require('source-map'); const fs = require('fs'); const path = require('path'); diff --git a/package.json b/package.json new file mode 100644 index 000000000..80e6b609a --- /dev/null +++ b/package.json @@ -0,0 +1,18 @@ +{ + "name": "claude-code-sourcemap", + "private": true, + "version": "0.1.0", + "description": "Research workspace for the reconstructed Claude Code 2.1.88 package and extracted sources.", + "scripts": { + "extract": "node extract-sources.js", + "claude": "node package/cli.js", + "start": "node package/cli.js", + "version:claude": "node package/cli.js -v", + "restored:cli": "bun --preload ./restored-src/macro-shim.cjs ./restored-src/src/entrypoints/cli.tsx", + "restored:help": "bun --preload ./restored-src/macro-shim.cjs ./restored-src/src/entrypoints/cli.tsx --help", + "restored:version": "bun --preload ./restored-src/macro-shim.cjs ./restored-src/src/entrypoints/cli.tsx -v" + }, + "engines": { + "node": ">=18.0.0" + } +} diff --git a/restored-src/macro-shim.cjs b/restored-src/macro-shim.cjs new file mode 100644 index 000000000..dc2e1f0e3 --- /dev/null +++ b/restored-src/macro-shim.cjs @@ -0,0 +1,39 @@ +const fs = require("fs"); +const path = require("path"); + +function readPackagedVersion() { + try { + const pkgPath = path.join(__dirname, "..", "package", "package.json"); + const pkg = JSON.parse(fs.readFileSync(pkgPath, "utf8")); + return { + version: pkg.version || "0.0.0", + packageName: pkg.name || "@anthropic-ai/claude-code", + }; + } catch { + return { + version: "0.0.0", + packageName: "@anthropic-ai/claude-code", + }; + } +} + +const packaged = readPackagedVersion(); + +globalThis.MACRO = new Proxy( + { + VERSION: packaged.version, + PACKAGE_URL: packaged.packageName, + NATIVE_PACKAGE_URL: packaged.packageName, + FEEDBACK_CHANNEL: "the Claude Code issue tracker", + ISSUES_EXPLAINER: "file an issue in the Claude Code issue tracker", + BUILD_TIME: "", + }, + { + get(target, prop) { + if (prop in target) { + return target[prop]; + } + return ""; + }, + }, +); diff --git a/restored-src/node_modules/@alcalzone/ansi-tokenize/package.json b/restored-src/node_modules/@alcalzone/ansi-tokenize/package.json new file mode 100644 index 000000000..f270c2085 --- /dev/null +++ b/restored-src/node_modules/@alcalzone/ansi-tokenize/package.json @@ -0,0 +1,6 @@ +{ + "name": "@alcalzone/ansi-tokenize", + "private": true, + "main": "./build/index.js", + "type": "module" +} diff --git a/restored-src/node_modules/@ant/claude-for-chrome-mcp/package.json b/restored-src/node_modules/@ant/claude-for-chrome-mcp/package.json new file mode 100644 index 000000000..bee50eced --- /dev/null +++ b/restored-src/node_modules/@ant/claude-for-chrome-mcp/package.json @@ -0,0 +1,6 @@ +{ + "name": "@ant/claude-for-chrome-mcp", + "private": true, + "main": "./src/index.ts", + "type": "module" +} diff --git a/restored-src/node_modules/@ant/computer-use-input/package.json b/restored-src/node_modules/@ant/computer-use-input/package.json new file mode 100644 index 000000000..a17ecb2e0 --- /dev/null +++ b/restored-src/node_modules/@ant/computer-use-input/package.json @@ -0,0 +1,6 @@ +{ + "name": "@ant/computer-use-input", + "private": true, + "main": "./js/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@ant/computer-use-mcp/package.json b/restored-src/node_modules/@ant/computer-use-mcp/package.json new file mode 100644 index 000000000..6a655983b --- /dev/null +++ b/restored-src/node_modules/@ant/computer-use-mcp/package.json @@ -0,0 +1,6 @@ +{ + "name": "@ant/computer-use-mcp", + "private": true, + "main": "./src/index.ts", + "type": "module" +} diff --git a/restored-src/node_modules/@ant/computer-use-swift/package.json b/restored-src/node_modules/@ant/computer-use-swift/package.json new file mode 100644 index 000000000..43c22bfbb --- /dev/null +++ b/restored-src/node_modules/@ant/computer-use-swift/package.json @@ -0,0 +1,6 @@ +{ + "name": "@ant/computer-use-swift", + "private": true, + "main": "./js/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@anthropic-ai/bedrock-sdk/package.json b/restored-src/node_modules/@anthropic-ai/bedrock-sdk/package.json new file mode 100644 index 000000000..46a15b64b --- /dev/null +++ b/restored-src/node_modules/@anthropic-ai/bedrock-sdk/package.json @@ -0,0 +1,6 @@ +{ + "name": "@anthropic-ai/bedrock-sdk", + "private": true, + "main": "./index.mjs", + "type": "module" +} diff --git a/restored-src/node_modules/@anthropic-ai/foundry-sdk/package.json b/restored-src/node_modules/@anthropic-ai/foundry-sdk/package.json new file mode 100644 index 000000000..2b12ac2b0 --- /dev/null +++ b/restored-src/node_modules/@anthropic-ai/foundry-sdk/package.json @@ -0,0 +1,6 @@ +{ + "name": "@anthropic-ai/foundry-sdk", + "private": true, + "main": "./index.mjs", + "type": "module" +} diff --git a/restored-src/node_modules/@anthropic-ai/mcpb/package.json b/restored-src/node_modules/@anthropic-ai/mcpb/package.json new file mode 100644 index 000000000..80fc10d34 --- /dev/null +++ b/restored-src/node_modules/@anthropic-ai/mcpb/package.json @@ -0,0 +1,6 @@ +{ + "name": "@anthropic-ai/mcpb", + "private": true, + "main": "./dist/index.js", + "type": "module" +} diff --git a/restored-src/node_modules/@anthropic-ai/sandbox-runtime/package.json b/restored-src/node_modules/@anthropic-ai/sandbox-runtime/package.json new file mode 100644 index 000000000..ffe2cc488 --- /dev/null +++ b/restored-src/node_modules/@anthropic-ai/sandbox-runtime/package.json @@ -0,0 +1,6 @@ +{ + "name": "@anthropic-ai/sandbox-runtime", + "private": true, + "main": "./dist/index.js", + "type": "module" +} diff --git a/restored-src/node_modules/@anthropic-ai/sdk/package.json b/restored-src/node_modules/@anthropic-ai/sdk/package.json new file mode 100644 index 000000000..85b529dfc --- /dev/null +++ b/restored-src/node_modules/@anthropic-ai/sdk/package.json @@ -0,0 +1,6 @@ +{ + "name": "@anthropic-ai/sdk", + "private": true, + "main": "./index.mjs", + "type": "module" +} diff --git a/restored-src/node_modules/@anthropic-ai/sdk/resources/shared.mjs b/restored-src/node_modules/@anthropic-ai/sdk/resources/shared.mjs new file mode 100644 index 000000000..e23bc6c8b --- /dev/null +++ b/restored-src/node_modules/@anthropic-ai/sdk/resources/shared.mjs @@ -0,0 +1,6 @@ +// Reconstructed workspace shim. +// The source map extraction missed this file, but resources/index.mjs re-exports it. +// An empty module is sufficient for runtime loading in this workspace because +// the current CLI path does not consume any concrete values from it. + +export {}; diff --git a/restored-src/node_modules/@anthropic-ai/vertex-sdk/package.json b/restored-src/node_modules/@anthropic-ai/vertex-sdk/package.json new file mode 100644 index 000000000..c1ae1999d --- /dev/null +++ b/restored-src/node_modules/@anthropic-ai/vertex-sdk/package.json @@ -0,0 +1,6 @@ +{ + "name": "@anthropic-ai/vertex-sdk", + "private": true, + "main": "./index.mjs", + "type": "module" +} diff --git a/restored-src/node_modules/@aws-crypto/crc32/package.json b/restored-src/node_modules/@aws-crypto/crc32/package.json new file mode 100644 index 000000000..44ecf4209 --- /dev/null +++ b/restored-src/node_modules/@aws-crypto/crc32/package.json @@ -0,0 +1,6 @@ +{ + "name": "@aws-crypto/crc32", + "private": true, + "main": "./build/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@aws-crypto/sha256-js/package.json b/restored-src/node_modules/@aws-crypto/sha256-js/package.json new file mode 100644 index 000000000..a95007e85 --- /dev/null +++ b/restored-src/node_modules/@aws-crypto/sha256-js/package.json @@ -0,0 +1,6 @@ +{ + "name": "@aws-crypto/sha256-js", + "private": true, + "main": "./build/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@aws-crypto/util/package.json b/restored-src/node_modules/@aws-crypto/util/package.json new file mode 100644 index 000000000..5496602b7 --- /dev/null +++ b/restored-src/node_modules/@aws-crypto/util/package.json @@ -0,0 +1,6 @@ +{ + "name": "@aws-crypto/util", + "private": true, + "main": "./build/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@aws-sdk/client-bedrock-runtime/package.json b/restored-src/node_modules/@aws-sdk/client-bedrock-runtime/package.json new file mode 100644 index 000000000..8e84f8fcd --- /dev/null +++ b/restored-src/node_modules/@aws-sdk/client-bedrock-runtime/package.json @@ -0,0 +1,6 @@ +{ + "name": "@aws-sdk/client-bedrock-runtime", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@aws-sdk/client-bedrock/package.json b/restored-src/node_modules/@aws-sdk/client-bedrock/package.json new file mode 100644 index 000000000..7edf4634e --- /dev/null +++ b/restored-src/node_modules/@aws-sdk/client-bedrock/package.json @@ -0,0 +1,6 @@ +{ + "name": "@aws-sdk/client-bedrock", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@aws-sdk/client-cognito-identity/package.json b/restored-src/node_modules/@aws-sdk/client-cognito-identity/package.json new file mode 100644 index 000000000..8c75301ba --- /dev/null +++ b/restored-src/node_modules/@aws-sdk/client-cognito-identity/package.json @@ -0,0 +1,6 @@ +{ + "name": "@aws-sdk/client-cognito-identity", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@aws-sdk/client-sso/package.json b/restored-src/node_modules/@aws-sdk/client-sso/package.json new file mode 100644 index 000000000..37e6864f0 --- /dev/null +++ b/restored-src/node_modules/@aws-sdk/client-sso/package.json @@ -0,0 +1,6 @@ +{ + "name": "@aws-sdk/client-sso", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@aws-sdk/client-sts/package.json b/restored-src/node_modules/@aws-sdk/client-sts/package.json new file mode 100644 index 000000000..00e2fa98d --- /dev/null +++ b/restored-src/node_modules/@aws-sdk/client-sts/package.json @@ -0,0 +1,6 @@ +{ + "name": "@aws-sdk/client-sts", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@aws-sdk/core/package.json b/restored-src/node_modules/@aws-sdk/core/package.json new file mode 100644 index 000000000..570b1d5f1 --- /dev/null +++ b/restored-src/node_modules/@aws-sdk/core/package.json @@ -0,0 +1,6 @@ +{ + "name": "@aws-sdk/core", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@aws-sdk/credential-provider-cognito-identity/package.json b/restored-src/node_modules/@aws-sdk/credential-provider-cognito-identity/package.json new file mode 100644 index 000000000..2216f5968 --- /dev/null +++ b/restored-src/node_modules/@aws-sdk/credential-provider-cognito-identity/package.json @@ -0,0 +1,6 @@ +{ + "name": "@aws-sdk/credential-provider-cognito-identity", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@aws-sdk/credential-provider-env/package.json b/restored-src/node_modules/@aws-sdk/credential-provider-env/package.json new file mode 100644 index 000000000..0753b6b79 --- /dev/null +++ b/restored-src/node_modules/@aws-sdk/credential-provider-env/package.json @@ -0,0 +1,6 @@ +{ + "name": "@aws-sdk/credential-provider-env", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@aws-sdk/credential-provider-http/package.json b/restored-src/node_modules/@aws-sdk/credential-provider-http/package.json new file mode 100644 index 000000000..212ac0583 --- /dev/null +++ b/restored-src/node_modules/@aws-sdk/credential-provider-http/package.json @@ -0,0 +1,6 @@ +{ + "name": "@aws-sdk/credential-provider-http", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@aws-sdk/credential-provider-ini/package.json b/restored-src/node_modules/@aws-sdk/credential-provider-ini/package.json new file mode 100644 index 000000000..c3125f1b6 --- /dev/null +++ b/restored-src/node_modules/@aws-sdk/credential-provider-ini/package.json @@ -0,0 +1,6 @@ +{ + "name": "@aws-sdk/credential-provider-ini", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@aws-sdk/credential-provider-login/package.json b/restored-src/node_modules/@aws-sdk/credential-provider-login/package.json new file mode 100644 index 000000000..b3c186e1f --- /dev/null +++ b/restored-src/node_modules/@aws-sdk/credential-provider-login/package.json @@ -0,0 +1,6 @@ +{ + "name": "@aws-sdk/credential-provider-login", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@aws-sdk/credential-provider-node/package.json b/restored-src/node_modules/@aws-sdk/credential-provider-node/package.json new file mode 100644 index 000000000..2bcbd2505 --- /dev/null +++ b/restored-src/node_modules/@aws-sdk/credential-provider-node/package.json @@ -0,0 +1,6 @@ +{ + "name": "@aws-sdk/credential-provider-node", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@aws-sdk/credential-provider-process/package.json b/restored-src/node_modules/@aws-sdk/credential-provider-process/package.json new file mode 100644 index 000000000..9599e2575 --- /dev/null +++ b/restored-src/node_modules/@aws-sdk/credential-provider-process/package.json @@ -0,0 +1,6 @@ +{ + "name": "@aws-sdk/credential-provider-process", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@aws-sdk/credential-provider-sso/package.json b/restored-src/node_modules/@aws-sdk/credential-provider-sso/package.json new file mode 100644 index 000000000..5c9df7068 --- /dev/null +++ b/restored-src/node_modules/@aws-sdk/credential-provider-sso/package.json @@ -0,0 +1,6 @@ +{ + "name": "@aws-sdk/credential-provider-sso", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@aws-sdk/credential-provider-web-identity/package.json b/restored-src/node_modules/@aws-sdk/credential-provider-web-identity/package.json new file mode 100644 index 000000000..62bbcf120 --- /dev/null +++ b/restored-src/node_modules/@aws-sdk/credential-provider-web-identity/package.json @@ -0,0 +1,6 @@ +{ + "name": "@aws-sdk/credential-provider-web-identity", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@aws-sdk/credential-providers/package.json b/restored-src/node_modules/@aws-sdk/credential-providers/package.json new file mode 100644 index 000000000..ab134e45a --- /dev/null +++ b/restored-src/node_modules/@aws-sdk/credential-providers/package.json @@ -0,0 +1,6 @@ +{ + "name": "@aws-sdk/credential-providers", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@aws-sdk/eventstream-handler-node/package.json b/restored-src/node_modules/@aws-sdk/eventstream-handler-node/package.json new file mode 100644 index 000000000..dd160ef46 --- /dev/null +++ b/restored-src/node_modules/@aws-sdk/eventstream-handler-node/package.json @@ -0,0 +1,6 @@ +{ + "name": "@aws-sdk/eventstream-handler-node", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@aws-sdk/middleware-eventstream/package.json b/restored-src/node_modules/@aws-sdk/middleware-eventstream/package.json new file mode 100644 index 000000000..6aafda7ad --- /dev/null +++ b/restored-src/node_modules/@aws-sdk/middleware-eventstream/package.json @@ -0,0 +1,6 @@ +{ + "name": "@aws-sdk/middleware-eventstream", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@aws-sdk/middleware-host-header/package.json b/restored-src/node_modules/@aws-sdk/middleware-host-header/package.json new file mode 100644 index 000000000..3be588e71 --- /dev/null +++ b/restored-src/node_modules/@aws-sdk/middleware-host-header/package.json @@ -0,0 +1,6 @@ +{ + "name": "@aws-sdk/middleware-host-header", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@aws-sdk/middleware-logger/package.json b/restored-src/node_modules/@aws-sdk/middleware-logger/package.json new file mode 100644 index 000000000..1659a7f8e --- /dev/null +++ b/restored-src/node_modules/@aws-sdk/middleware-logger/package.json @@ -0,0 +1,6 @@ +{ + "name": "@aws-sdk/middleware-logger", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@aws-sdk/middleware-recursion-detection/package.json b/restored-src/node_modules/@aws-sdk/middleware-recursion-detection/package.json new file mode 100644 index 000000000..31703559a --- /dev/null +++ b/restored-src/node_modules/@aws-sdk/middleware-recursion-detection/package.json @@ -0,0 +1,6 @@ +{ + "name": "@aws-sdk/middleware-recursion-detection", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@aws-sdk/middleware-user-agent/package.json b/restored-src/node_modules/@aws-sdk/middleware-user-agent/package.json new file mode 100644 index 000000000..5ecb3cb0a --- /dev/null +++ b/restored-src/node_modules/@aws-sdk/middleware-user-agent/package.json @@ -0,0 +1,6 @@ +{ + "name": "@aws-sdk/middleware-user-agent", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@aws-sdk/middleware-websocket/package.json b/restored-src/node_modules/@aws-sdk/middleware-websocket/package.json new file mode 100644 index 000000000..d7960ee02 --- /dev/null +++ b/restored-src/node_modules/@aws-sdk/middleware-websocket/package.json @@ -0,0 +1,6 @@ +{ + "name": "@aws-sdk/middleware-websocket", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@aws-sdk/nested-clients/package.json b/restored-src/node_modules/@aws-sdk/nested-clients/package.json new file mode 100644 index 000000000..162fa95e9 --- /dev/null +++ b/restored-src/node_modules/@aws-sdk/nested-clients/package.json @@ -0,0 +1,6 @@ +{ + "name": "@aws-sdk/nested-clients", + "private": true, + "main": "./dist-cjs/submodules/sts/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@aws-sdk/region-config-resolver/package.json b/restored-src/node_modules/@aws-sdk/region-config-resolver/package.json new file mode 100644 index 000000000..1b8831e3b --- /dev/null +++ b/restored-src/node_modules/@aws-sdk/region-config-resolver/package.json @@ -0,0 +1,6 @@ +{ + "name": "@aws-sdk/region-config-resolver", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@aws-sdk/token-providers/package.json b/restored-src/node_modules/@aws-sdk/token-providers/package.json new file mode 100644 index 000000000..60882e598 --- /dev/null +++ b/restored-src/node_modules/@aws-sdk/token-providers/package.json @@ -0,0 +1,6 @@ +{ + "name": "@aws-sdk/token-providers", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@aws-sdk/util-endpoints/package.json b/restored-src/node_modules/@aws-sdk/util-endpoints/package.json new file mode 100644 index 000000000..65603af30 --- /dev/null +++ b/restored-src/node_modules/@aws-sdk/util-endpoints/package.json @@ -0,0 +1,6 @@ +{ + "name": "@aws-sdk/util-endpoints", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@aws-sdk/util-format-url/package.json b/restored-src/node_modules/@aws-sdk/util-format-url/package.json new file mode 100644 index 000000000..facd873a4 --- /dev/null +++ b/restored-src/node_modules/@aws-sdk/util-format-url/package.json @@ -0,0 +1,6 @@ +{ + "name": "@aws-sdk/util-format-url", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@aws-sdk/util-user-agent-node/package.json b/restored-src/node_modules/@aws-sdk/util-user-agent-node/package.json new file mode 100644 index 000000000..56237ad0c --- /dev/null +++ b/restored-src/node_modules/@aws-sdk/util-user-agent-node/package.json @@ -0,0 +1,6 @@ +{ + "name": "@aws-sdk/util-user-agent-node", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@aws-sdk/util-utf8-browser/package.json b/restored-src/node_modules/@aws-sdk/util-utf8-browser/package.json new file mode 100644 index 000000000..8a729a22b --- /dev/null +++ b/restored-src/node_modules/@aws-sdk/util-utf8-browser/package.json @@ -0,0 +1,6 @@ +{ + "name": "@aws-sdk/util-utf8-browser", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@aws-sdk/xml-builder/package.json b/restored-src/node_modules/@aws-sdk/xml-builder/package.json new file mode 100644 index 000000000..4027cb064 --- /dev/null +++ b/restored-src/node_modules/@aws-sdk/xml-builder/package.json @@ -0,0 +1,6 @@ +{ + "name": "@aws-sdk/xml-builder", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@aws/lambda-invoke-store/package.json b/restored-src/node_modules/@aws/lambda-invoke-store/package.json new file mode 100644 index 000000000..24556a81a --- /dev/null +++ b/restored-src/node_modules/@aws/lambda-invoke-store/package.json @@ -0,0 +1,6 @@ +{ + "name": "@aws/lambda-invoke-store", + "private": true, + "main": "./dist-cjs/invoke-store.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@azure/abort-controller/package.json b/restored-src/node_modules/@azure/abort-controller/package.json new file mode 100644 index 000000000..125904037 --- /dev/null +++ b/restored-src/node_modules/@azure/abort-controller/package.json @@ -0,0 +1,6 @@ +{ + "name": "@azure/abort-controller", + "private": true, + "main": "./dist/esm/index.js", + "type": "module" +} diff --git a/restored-src/node_modules/@azure/core-client/package.json b/restored-src/node_modules/@azure/core-client/package.json new file mode 100644 index 000000000..d2acd5abc --- /dev/null +++ b/restored-src/node_modules/@azure/core-client/package.json @@ -0,0 +1,6 @@ +{ + "name": "@azure/core-client", + "private": true, + "main": "./dist/esm/index.js", + "type": "module" +} diff --git a/restored-src/node_modules/@azure/core-rest-pipeline/package.json b/restored-src/node_modules/@azure/core-rest-pipeline/package.json new file mode 100644 index 000000000..99fea53ba --- /dev/null +++ b/restored-src/node_modules/@azure/core-rest-pipeline/package.json @@ -0,0 +1,6 @@ +{ + "name": "@azure/core-rest-pipeline", + "private": true, + "main": "./dist/esm/index.js", + "type": "module" +} diff --git a/restored-src/node_modules/@azure/core-tracing/package.json b/restored-src/node_modules/@azure/core-tracing/package.json new file mode 100644 index 000000000..a8d79314c --- /dev/null +++ b/restored-src/node_modules/@azure/core-tracing/package.json @@ -0,0 +1,6 @@ +{ + "name": "@azure/core-tracing", + "private": true, + "main": "./dist/esm/index.js", + "type": "module" +} diff --git a/restored-src/node_modules/@azure/core-util/package.json b/restored-src/node_modules/@azure/core-util/package.json new file mode 100644 index 000000000..2b89a35c4 --- /dev/null +++ b/restored-src/node_modules/@azure/core-util/package.json @@ -0,0 +1,6 @@ +{ + "name": "@azure/core-util", + "private": true, + "main": "./dist/esm/index.js", + "type": "module" +} diff --git a/restored-src/node_modules/@azure/identity/package.json b/restored-src/node_modules/@azure/identity/package.json new file mode 100644 index 000000000..16f2fef53 --- /dev/null +++ b/restored-src/node_modules/@azure/identity/package.json @@ -0,0 +1,6 @@ +{ + "name": "@azure/identity", + "private": true, + "main": "./dist/esm/index.js", + "type": "module" +} diff --git a/restored-src/node_modules/@azure/logger/package.json b/restored-src/node_modules/@azure/logger/package.json new file mode 100644 index 000000000..ce7bdc264 --- /dev/null +++ b/restored-src/node_modules/@azure/logger/package.json @@ -0,0 +1,6 @@ +{ + "name": "@azure/logger", + "private": true, + "main": "./dist/esm/index.js", + "type": "module" +} diff --git a/restored-src/node_modules/@azure/msal-common/package.json b/restored-src/node_modules/@azure/msal-common/package.json new file mode 100644 index 000000000..b11d07f4e --- /dev/null +++ b/restored-src/node_modules/@azure/msal-common/package.json @@ -0,0 +1,6 @@ +{ + "name": "@azure/msal-common", + "private": true, + "main": "./dist/index.mjs", + "type": "module" +} diff --git a/restored-src/node_modules/@azure/msal-node/package.json b/restored-src/node_modules/@azure/msal-node/package.json new file mode 100644 index 000000000..feb75e736 --- /dev/null +++ b/restored-src/node_modules/@azure/msal-node/package.json @@ -0,0 +1,6 @@ +{ + "name": "@azure/msal-node", + "private": true, + "main": "./dist/index.mjs", + "type": "module" +} diff --git a/restored-src/node_modules/@commander-js/extra-typings/package.json b/restored-src/node_modules/@commander-js/extra-typings/package.json new file mode 100644 index 000000000..4ca0000e9 --- /dev/null +++ b/restored-src/node_modules/@commander-js/extra-typings/package.json @@ -0,0 +1,6 @@ +{ + "name": "@commander-js/extra-typings", + "private": true, + "main": "./esm.mjs", + "type": "module" +} diff --git a/restored-src/node_modules/@growthbook/growthbook/package.json b/restored-src/node_modules/@growthbook/growthbook/package.json new file mode 100644 index 000000000..32722e841 --- /dev/null +++ b/restored-src/node_modules/@growthbook/growthbook/package.json @@ -0,0 +1,6 @@ +{ + "name": "@growthbook/growthbook", + "private": true, + "main": "./dist/esm/index.mjs", + "type": "module" +} diff --git a/restored-src/node_modules/@grpc/grpc-js/package.json b/restored-src/node_modules/@grpc/grpc-js/package.json new file mode 100644 index 000000000..66284dd14 --- /dev/null +++ b/restored-src/node_modules/@grpc/grpc-js/package.json @@ -0,0 +1,6 @@ +{ + "name": "@grpc/grpc-js", + "private": true, + "main": "./build/src/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@grpc/proto-loader/package.json b/restored-src/node_modules/@grpc/proto-loader/package.json new file mode 100644 index 000000000..5c999a4d4 --- /dev/null +++ b/restored-src/node_modules/@grpc/proto-loader/package.json @@ -0,0 +1,6 @@ +{ + "name": "@grpc/proto-loader", + "private": true, + "main": "./build/src/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@img/colour/package.json b/restored-src/node_modules/@img/colour/package.json new file mode 100644 index 000000000..605e2f40d --- /dev/null +++ b/restored-src/node_modules/@img/colour/package.json @@ -0,0 +1,6 @@ +{ + "name": "@img/colour", + "private": true, + "main": "./index.cjs", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@inquirer/confirm/package.json b/restored-src/node_modules/@inquirer/confirm/package.json new file mode 100644 index 000000000..be00e1eb9 --- /dev/null +++ b/restored-src/node_modules/@inquirer/confirm/package.json @@ -0,0 +1,6 @@ +{ + "name": "@inquirer/confirm", + "private": true, + "main": "./dist/esm/index.mjs", + "type": "module" +} diff --git a/restored-src/node_modules/@inquirer/core/package.json b/restored-src/node_modules/@inquirer/core/package.json new file mode 100644 index 000000000..ad42b77fc --- /dev/null +++ b/restored-src/node_modules/@inquirer/core/package.json @@ -0,0 +1,6 @@ +{ + "name": "@inquirer/core", + "private": true, + "main": "./dist/esm/index.mjs", + "type": "module" +} diff --git a/restored-src/node_modules/@inquirer/figures/package.json b/restored-src/node_modules/@inquirer/figures/package.json new file mode 100644 index 000000000..80d776ddc --- /dev/null +++ b/restored-src/node_modules/@inquirer/figures/package.json @@ -0,0 +1,6 @@ +{ + "name": "@inquirer/figures", + "private": true, + "main": "./dist/esm/index.js", + "type": "module" +} diff --git a/restored-src/node_modules/@inquirer/input/package.json b/restored-src/node_modules/@inquirer/input/package.json new file mode 100644 index 000000000..3ca2fbe0c --- /dev/null +++ b/restored-src/node_modules/@inquirer/input/package.json @@ -0,0 +1,6 @@ +{ + "name": "@inquirer/input", + "private": true, + "main": "./dist/esm/index.mjs", + "type": "module" +} diff --git a/restored-src/node_modules/@inquirer/prompts/package.json b/restored-src/node_modules/@inquirer/prompts/package.json new file mode 100644 index 000000000..e095d223e --- /dev/null +++ b/restored-src/node_modules/@inquirer/prompts/package.json @@ -0,0 +1,6 @@ +{ + "name": "@inquirer/prompts", + "private": true, + "main": "./dist/esm/index.mjs", + "type": "module" +} diff --git a/restored-src/node_modules/@inquirer/select/package.json b/restored-src/node_modules/@inquirer/select/package.json new file mode 100644 index 000000000..353cdbe07 --- /dev/null +++ b/restored-src/node_modules/@inquirer/select/package.json @@ -0,0 +1,6 @@ +{ + "name": "@inquirer/select", + "private": true, + "main": "./dist/esm/index.mjs", + "type": "module" +} diff --git a/restored-src/node_modules/@js-sdsl/ordered-map/package.json b/restored-src/node_modules/@js-sdsl/ordered-map/package.json new file mode 100644 index 000000000..2a0eed86e --- /dev/null +++ b/restored-src/node_modules/@js-sdsl/ordered-map/package.json @@ -0,0 +1,6 @@ +{ + "name": "@js-sdsl/ordered-map", + "private": true, + "main": "./dist/cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@mixmark-io/domino/package.json b/restored-src/node_modules/@mixmark-io/domino/package.json new file mode 100644 index 000000000..80834afaf --- /dev/null +++ b/restored-src/node_modules/@mixmark-io/domino/package.json @@ -0,0 +1,6 @@ +{ + "name": "@mixmark-io/domino", + "private": true, + "main": "./lib/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@modelcontextprotocol/sdk/client/auth.js b/restored-src/node_modules/@modelcontextprotocol/sdk/client/auth.js new file mode 100644 index 000000000..eee2948fe --- /dev/null +++ b/restored-src/node_modules/@modelcontextprotocol/sdk/client/auth.js @@ -0,0 +1 @@ +export * from '../dist/esm/client/auth.js' diff --git a/restored-src/node_modules/@modelcontextprotocol/sdk/client/index.js b/restored-src/node_modules/@modelcontextprotocol/sdk/client/index.js new file mode 100644 index 000000000..331abcc39 --- /dev/null +++ b/restored-src/node_modules/@modelcontextprotocol/sdk/client/index.js @@ -0,0 +1 @@ +export * from '../dist/esm/client/index.js' diff --git a/restored-src/node_modules/@modelcontextprotocol/sdk/client/sse.js b/restored-src/node_modules/@modelcontextprotocol/sdk/client/sse.js new file mode 100644 index 000000000..5a936b546 --- /dev/null +++ b/restored-src/node_modules/@modelcontextprotocol/sdk/client/sse.js @@ -0,0 +1 @@ +export * from '../dist/esm/client/sse.js' diff --git a/restored-src/node_modules/@modelcontextprotocol/sdk/client/stdio.js b/restored-src/node_modules/@modelcontextprotocol/sdk/client/stdio.js new file mode 100644 index 000000000..9b7f6b769 --- /dev/null +++ b/restored-src/node_modules/@modelcontextprotocol/sdk/client/stdio.js @@ -0,0 +1 @@ +export * from '../dist/esm/client/stdio.js' diff --git a/restored-src/node_modules/@modelcontextprotocol/sdk/client/streamableHttp.js b/restored-src/node_modules/@modelcontextprotocol/sdk/client/streamableHttp.js new file mode 100644 index 000000000..eb8dca4cb --- /dev/null +++ b/restored-src/node_modules/@modelcontextprotocol/sdk/client/streamableHttp.js @@ -0,0 +1 @@ +export * from '../dist/esm/client/streamableHttp.js' diff --git a/restored-src/node_modules/@modelcontextprotocol/sdk/dist/esm/server/zod-json-schema-compat.js b/restored-src/node_modules/@modelcontextprotocol/sdk/dist/esm/server/zod-json-schema-compat.js index 62f7fd0ef..287cceacf 100644 --- a/restored-src/node_modules/@modelcontextprotocol/sdk/dist/esm/server/zod-json-schema-compat.js +++ b/restored-src/node_modules/@modelcontextprotocol/sdk/dist/esm/server/zod-json-schema-compat.js @@ -5,7 +5,6 @@ // ---------------------------------------------------- import * as z4mini from 'zod/v4-mini'; import { getObjectShape, safeParse, isZ4Schema, getLiteralValue } from './zod-compat.js'; -import { zodToJsonSchema } from 'zod-to-json-schema'; function mapMiniTarget(t) { if (!t) return 'draft-7'; @@ -23,11 +22,9 @@ export function toJsonSchemaCompat(schema, opts) { io: opts?.pipeStrategy ?? 'input' }); } - // v3 branch — use vendored converter - return zodToJsonSchema(schema, { - strictUnions: opts?.strictUnions ?? true, - pipeStrategy: opts?.pipeStrategy ?? 'input' - }); + // Restored source builds do not include the vendored Zod v3 converter. + // Return a permissive object schema instead of failing module evaluation. + return { type: 'object', additionalProperties: true }; } export function getMethodLiteral(schema) { const shape = getObjectShape(schema); @@ -48,4 +45,4 @@ export function parseWithCompat(schema, data) { } return result.data; } -//# sourceMappingURL=zod-json-schema-compat.js.map \ No newline at end of file +//# sourceMappingURL=zod-json-schema-compat.js.map diff --git a/restored-src/node_modules/@modelcontextprotocol/sdk/package.json b/restored-src/node_modules/@modelcontextprotocol/sdk/package.json new file mode 100644 index 000000000..006004942 --- /dev/null +++ b/restored-src/node_modules/@modelcontextprotocol/sdk/package.json @@ -0,0 +1,6 @@ +{ + "name": "@modelcontextprotocol/sdk", + "private": true, + "main": "./dist/esm/client/index.js", + "type": "module" +} diff --git a/restored-src/node_modules/@modelcontextprotocol/sdk/server/auth/errors.js b/restored-src/node_modules/@modelcontextprotocol/sdk/server/auth/errors.js new file mode 100644 index 000000000..a72388c8c --- /dev/null +++ b/restored-src/node_modules/@modelcontextprotocol/sdk/server/auth/errors.js @@ -0,0 +1 @@ +export * from '../../dist/esm/server/auth/errors.js' diff --git a/restored-src/node_modules/@modelcontextprotocol/sdk/server/index.js b/restored-src/node_modules/@modelcontextprotocol/sdk/server/index.js new file mode 100644 index 000000000..d3bea2f8a --- /dev/null +++ b/restored-src/node_modules/@modelcontextprotocol/sdk/server/index.js @@ -0,0 +1 @@ +export * from '../dist/esm/server/index.js' diff --git a/restored-src/node_modules/@modelcontextprotocol/sdk/server/stdio.js b/restored-src/node_modules/@modelcontextprotocol/sdk/server/stdio.js new file mode 100644 index 000000000..cc15d5625 --- /dev/null +++ b/restored-src/node_modules/@modelcontextprotocol/sdk/server/stdio.js @@ -0,0 +1 @@ +export * from '../dist/esm/server/stdio.js' diff --git a/restored-src/node_modules/@modelcontextprotocol/sdk/shared/auth.js b/restored-src/node_modules/@modelcontextprotocol/sdk/shared/auth.js new file mode 100644 index 000000000..c1a77b03e --- /dev/null +++ b/restored-src/node_modules/@modelcontextprotocol/sdk/shared/auth.js @@ -0,0 +1 @@ +export * from '../dist/esm/shared/auth.js' diff --git a/restored-src/node_modules/@modelcontextprotocol/sdk/shared/transport.js b/restored-src/node_modules/@modelcontextprotocol/sdk/shared/transport.js new file mode 100644 index 000000000..710d9a4db --- /dev/null +++ b/restored-src/node_modules/@modelcontextprotocol/sdk/shared/transport.js @@ -0,0 +1 @@ +export * from '../dist/esm/shared/transport.js' diff --git a/restored-src/node_modules/@modelcontextprotocol/sdk/types.js b/restored-src/node_modules/@modelcontextprotocol/sdk/types.js new file mode 100644 index 000000000..e724ec460 --- /dev/null +++ b/restored-src/node_modules/@modelcontextprotocol/sdk/types.js @@ -0,0 +1 @@ +export * from './dist/esm/types.js' diff --git a/restored-src/node_modules/@opentelemetry/api-logs/package.json b/restored-src/node_modules/@opentelemetry/api-logs/package.json new file mode 100644 index 000000000..af5d19053 --- /dev/null +++ b/restored-src/node_modules/@opentelemetry/api-logs/package.json @@ -0,0 +1,6 @@ +{ + "name": "@opentelemetry/api-logs", + "private": true, + "main": "./build/src/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@opentelemetry/api/package.json b/restored-src/node_modules/@opentelemetry/api/package.json new file mode 100644 index 000000000..625d7ed05 --- /dev/null +++ b/restored-src/node_modules/@opentelemetry/api/package.json @@ -0,0 +1,6 @@ +{ + "name": "@opentelemetry/api", + "private": true, + "main": "./build/src/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@opentelemetry/core/package.json b/restored-src/node_modules/@opentelemetry/core/package.json new file mode 100644 index 000000000..080db35fa --- /dev/null +++ b/restored-src/node_modules/@opentelemetry/core/package.json @@ -0,0 +1,6 @@ +{ + "name": "@opentelemetry/core", + "private": true, + "main": "./build/src/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@opentelemetry/exporter-logs-otlp-grpc/package.json b/restored-src/node_modules/@opentelemetry/exporter-logs-otlp-grpc/package.json new file mode 100644 index 000000000..c35034031 --- /dev/null +++ b/restored-src/node_modules/@opentelemetry/exporter-logs-otlp-grpc/package.json @@ -0,0 +1,6 @@ +{ + "name": "@opentelemetry/exporter-logs-otlp-grpc", + "private": true, + "main": "./build/src/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@opentelemetry/exporter-logs-otlp-http/package.json b/restored-src/node_modules/@opentelemetry/exporter-logs-otlp-http/package.json new file mode 100644 index 000000000..b6b278b79 --- /dev/null +++ b/restored-src/node_modules/@opentelemetry/exporter-logs-otlp-http/package.json @@ -0,0 +1,6 @@ +{ + "name": "@opentelemetry/exporter-logs-otlp-http", + "private": true, + "main": "./build/src/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@opentelemetry/exporter-logs-otlp-proto/package.json b/restored-src/node_modules/@opentelemetry/exporter-logs-otlp-proto/package.json new file mode 100644 index 000000000..433669a9e --- /dev/null +++ b/restored-src/node_modules/@opentelemetry/exporter-logs-otlp-proto/package.json @@ -0,0 +1,6 @@ +{ + "name": "@opentelemetry/exporter-logs-otlp-proto", + "private": true, + "main": "./build/src/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@opentelemetry/exporter-metrics-otlp-grpc/package.json b/restored-src/node_modules/@opentelemetry/exporter-metrics-otlp-grpc/package.json new file mode 100644 index 000000000..6d0a5879c --- /dev/null +++ b/restored-src/node_modules/@opentelemetry/exporter-metrics-otlp-grpc/package.json @@ -0,0 +1,6 @@ +{ + "name": "@opentelemetry/exporter-metrics-otlp-grpc", + "private": true, + "main": "./build/src/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@opentelemetry/exporter-metrics-otlp-http/package.json b/restored-src/node_modules/@opentelemetry/exporter-metrics-otlp-http/package.json new file mode 100644 index 000000000..cfa4aa96a --- /dev/null +++ b/restored-src/node_modules/@opentelemetry/exporter-metrics-otlp-http/package.json @@ -0,0 +1,6 @@ +{ + "name": "@opentelemetry/exporter-metrics-otlp-http", + "private": true, + "main": "./build/src/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@opentelemetry/exporter-metrics-otlp-proto/package.json b/restored-src/node_modules/@opentelemetry/exporter-metrics-otlp-proto/package.json new file mode 100644 index 000000000..7b8d41973 --- /dev/null +++ b/restored-src/node_modules/@opentelemetry/exporter-metrics-otlp-proto/package.json @@ -0,0 +1,6 @@ +{ + "name": "@opentelemetry/exporter-metrics-otlp-proto", + "private": true, + "main": "./build/src/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@opentelemetry/exporter-prometheus/package.json b/restored-src/node_modules/@opentelemetry/exporter-prometheus/package.json new file mode 100644 index 000000000..468412c7b --- /dev/null +++ b/restored-src/node_modules/@opentelemetry/exporter-prometheus/package.json @@ -0,0 +1,6 @@ +{ + "name": "@opentelemetry/exporter-prometheus", + "private": true, + "main": "./build/src/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@opentelemetry/exporter-trace-otlp-grpc/package.json b/restored-src/node_modules/@opentelemetry/exporter-trace-otlp-grpc/package.json new file mode 100644 index 000000000..aa40093f6 --- /dev/null +++ b/restored-src/node_modules/@opentelemetry/exporter-trace-otlp-grpc/package.json @@ -0,0 +1,6 @@ +{ + "name": "@opentelemetry/exporter-trace-otlp-grpc", + "private": true, + "main": "./build/src/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@opentelemetry/exporter-trace-otlp-http/package.json b/restored-src/node_modules/@opentelemetry/exporter-trace-otlp-http/package.json new file mode 100644 index 000000000..d58aa659e --- /dev/null +++ b/restored-src/node_modules/@opentelemetry/exporter-trace-otlp-http/package.json @@ -0,0 +1,6 @@ +{ + "name": "@opentelemetry/exporter-trace-otlp-http", + "private": true, + "main": "./build/src/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@opentelemetry/exporter-trace-otlp-proto/package.json b/restored-src/node_modules/@opentelemetry/exporter-trace-otlp-proto/package.json new file mode 100644 index 000000000..6f73f201d --- /dev/null +++ b/restored-src/node_modules/@opentelemetry/exporter-trace-otlp-proto/package.json @@ -0,0 +1,6 @@ +{ + "name": "@opentelemetry/exporter-trace-otlp-proto", + "private": true, + "main": "./build/src/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@opentelemetry/otlp-exporter-base/package.json b/restored-src/node_modules/@opentelemetry/otlp-exporter-base/package.json new file mode 100644 index 000000000..647a535c2 --- /dev/null +++ b/restored-src/node_modules/@opentelemetry/otlp-exporter-base/package.json @@ -0,0 +1,6 @@ +{ + "name": "@opentelemetry/otlp-exporter-base", + "private": true, + "main": "./build/src/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@opentelemetry/otlp-grpc-exporter-base/package.json b/restored-src/node_modules/@opentelemetry/otlp-grpc-exporter-base/package.json new file mode 100644 index 000000000..75f223802 --- /dev/null +++ b/restored-src/node_modules/@opentelemetry/otlp-grpc-exporter-base/package.json @@ -0,0 +1,6 @@ +{ + "name": "@opentelemetry/otlp-grpc-exporter-base", + "private": true, + "main": "./build/src/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@opentelemetry/otlp-transformer/package.json b/restored-src/node_modules/@opentelemetry/otlp-transformer/package.json new file mode 100644 index 000000000..fd6440366 --- /dev/null +++ b/restored-src/node_modules/@opentelemetry/otlp-transformer/package.json @@ -0,0 +1,6 @@ +{ + "name": "@opentelemetry/otlp-transformer", + "private": true, + "main": "./build/src/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@opentelemetry/resources/package.json b/restored-src/node_modules/@opentelemetry/resources/package.json new file mode 100644 index 000000000..af73fea38 --- /dev/null +++ b/restored-src/node_modules/@opentelemetry/resources/package.json @@ -0,0 +1,6 @@ +{ + "name": "@opentelemetry/resources", + "private": true, + "main": "./build/src/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@opentelemetry/sdk-logs/package.json b/restored-src/node_modules/@opentelemetry/sdk-logs/package.json new file mode 100644 index 000000000..506b7e51e --- /dev/null +++ b/restored-src/node_modules/@opentelemetry/sdk-logs/package.json @@ -0,0 +1,6 @@ +{ + "name": "@opentelemetry/sdk-logs", + "private": true, + "main": "./build/src/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@opentelemetry/sdk-metrics/package.json b/restored-src/node_modules/@opentelemetry/sdk-metrics/package.json new file mode 100644 index 000000000..390f57167 --- /dev/null +++ b/restored-src/node_modules/@opentelemetry/sdk-metrics/package.json @@ -0,0 +1,6 @@ +{ + "name": "@opentelemetry/sdk-metrics", + "private": true, + "main": "./build/src/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@opentelemetry/sdk-trace-base/package.json b/restored-src/node_modules/@opentelemetry/sdk-trace-base/package.json new file mode 100644 index 000000000..14399a234 --- /dev/null +++ b/restored-src/node_modules/@opentelemetry/sdk-trace-base/package.json @@ -0,0 +1,6 @@ +{ + "name": "@opentelemetry/sdk-trace-base", + "private": true, + "main": "./build/src/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@opentelemetry/semantic-conventions/package.json b/restored-src/node_modules/@opentelemetry/semantic-conventions/package.json new file mode 100644 index 000000000..b2209d4e1 --- /dev/null +++ b/restored-src/node_modules/@opentelemetry/semantic-conventions/package.json @@ -0,0 +1,6 @@ +{ + "name": "@opentelemetry/semantic-conventions", + "private": true, + "main": "./build/src/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@pondwader/socks5-server/package.json b/restored-src/node_modules/@pondwader/socks5-server/package.json new file mode 100644 index 000000000..145f8447e --- /dev/null +++ b/restored-src/node_modules/@pondwader/socks5-server/package.json @@ -0,0 +1,6 @@ +{ + "name": "@pondwader/socks5-server", + "private": true, + "main": "./dist/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@protobufjs/aspromise/package.json b/restored-src/node_modules/@protobufjs/aspromise/package.json new file mode 100644 index 000000000..408277e58 --- /dev/null +++ b/restored-src/node_modules/@protobufjs/aspromise/package.json @@ -0,0 +1,6 @@ +{ + "name": "@protobufjs/aspromise", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@protobufjs/base64/package.json b/restored-src/node_modules/@protobufjs/base64/package.json new file mode 100644 index 000000000..eafd6e5fe --- /dev/null +++ b/restored-src/node_modules/@protobufjs/base64/package.json @@ -0,0 +1,6 @@ +{ + "name": "@protobufjs/base64", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@protobufjs/codegen/package.json b/restored-src/node_modules/@protobufjs/codegen/package.json new file mode 100644 index 000000000..b79949929 --- /dev/null +++ b/restored-src/node_modules/@protobufjs/codegen/package.json @@ -0,0 +1,6 @@ +{ + "name": "@protobufjs/codegen", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@protobufjs/eventemitter/package.json b/restored-src/node_modules/@protobufjs/eventemitter/package.json new file mode 100644 index 000000000..61034b3c5 --- /dev/null +++ b/restored-src/node_modules/@protobufjs/eventemitter/package.json @@ -0,0 +1,6 @@ +{ + "name": "@protobufjs/eventemitter", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@protobufjs/fetch/package.json b/restored-src/node_modules/@protobufjs/fetch/package.json new file mode 100644 index 000000000..5251f6f46 --- /dev/null +++ b/restored-src/node_modules/@protobufjs/fetch/package.json @@ -0,0 +1,6 @@ +{ + "name": "@protobufjs/fetch", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@protobufjs/float/package.json b/restored-src/node_modules/@protobufjs/float/package.json new file mode 100644 index 000000000..3e8507587 --- /dev/null +++ b/restored-src/node_modules/@protobufjs/float/package.json @@ -0,0 +1,6 @@ +{ + "name": "@protobufjs/float", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@protobufjs/inquire/package.json b/restored-src/node_modules/@protobufjs/inquire/package.json new file mode 100644 index 000000000..6a8397124 --- /dev/null +++ b/restored-src/node_modules/@protobufjs/inquire/package.json @@ -0,0 +1,6 @@ +{ + "name": "@protobufjs/inquire", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@protobufjs/path/package.json b/restored-src/node_modules/@protobufjs/path/package.json new file mode 100644 index 000000000..1cf0df9f7 --- /dev/null +++ b/restored-src/node_modules/@protobufjs/path/package.json @@ -0,0 +1,6 @@ +{ + "name": "@protobufjs/path", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@protobufjs/pool/package.json b/restored-src/node_modules/@protobufjs/pool/package.json new file mode 100644 index 000000000..003ed6f5a --- /dev/null +++ b/restored-src/node_modules/@protobufjs/pool/package.json @@ -0,0 +1,6 @@ +{ + "name": "@protobufjs/pool", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@protobufjs/utf8/package.json b/restored-src/node_modules/@protobufjs/utf8/package.json new file mode 100644 index 000000000..94d27d46b --- /dev/null +++ b/restored-src/node_modules/@protobufjs/utf8/package.json @@ -0,0 +1,6 @@ +{ + "name": "@protobufjs/utf8", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@smithy/config-resolver/package.json b/restored-src/node_modules/@smithy/config-resolver/package.json new file mode 100644 index 000000000..cfb9ccdf2 --- /dev/null +++ b/restored-src/node_modules/@smithy/config-resolver/package.json @@ -0,0 +1,6 @@ +{ + "name": "@smithy/config-resolver", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@smithy/core/package.json b/restored-src/node_modules/@smithy/core/package.json new file mode 100644 index 000000000..a4cd7f4c4 --- /dev/null +++ b/restored-src/node_modules/@smithy/core/package.json @@ -0,0 +1,6 @@ +{ + "name": "@smithy/core", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@smithy/credential-provider-imds/package.json b/restored-src/node_modules/@smithy/credential-provider-imds/package.json new file mode 100644 index 000000000..117746efd --- /dev/null +++ b/restored-src/node_modules/@smithy/credential-provider-imds/package.json @@ -0,0 +1,6 @@ +{ + "name": "@smithy/credential-provider-imds", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@smithy/eventstream-codec/package.json b/restored-src/node_modules/@smithy/eventstream-codec/package.json new file mode 100644 index 000000000..cd40f5aac --- /dev/null +++ b/restored-src/node_modules/@smithy/eventstream-codec/package.json @@ -0,0 +1,6 @@ +{ + "name": "@smithy/eventstream-codec", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@smithy/eventstream-serde-browser/package.json b/restored-src/node_modules/@smithy/eventstream-serde-browser/package.json new file mode 100644 index 000000000..acf662507 --- /dev/null +++ b/restored-src/node_modules/@smithy/eventstream-serde-browser/package.json @@ -0,0 +1,6 @@ +{ + "name": "@smithy/eventstream-serde-browser", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@smithy/eventstream-serde-config-resolver/package.json b/restored-src/node_modules/@smithy/eventstream-serde-config-resolver/package.json new file mode 100644 index 000000000..da368c89a --- /dev/null +++ b/restored-src/node_modules/@smithy/eventstream-serde-config-resolver/package.json @@ -0,0 +1,6 @@ +{ + "name": "@smithy/eventstream-serde-config-resolver", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@smithy/eventstream-serde-node/package.json b/restored-src/node_modules/@smithy/eventstream-serde-node/package.json new file mode 100644 index 000000000..4b100dfc0 --- /dev/null +++ b/restored-src/node_modules/@smithy/eventstream-serde-node/package.json @@ -0,0 +1,6 @@ +{ + "name": "@smithy/eventstream-serde-node", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@smithy/eventstream-serde-universal/package.json b/restored-src/node_modules/@smithy/eventstream-serde-universal/package.json new file mode 100644 index 000000000..1be48c58d --- /dev/null +++ b/restored-src/node_modules/@smithy/eventstream-serde-universal/package.json @@ -0,0 +1,6 @@ +{ + "name": "@smithy/eventstream-serde-universal", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@smithy/fetch-http-handler/package.json b/restored-src/node_modules/@smithy/fetch-http-handler/package.json new file mode 100644 index 000000000..d1a9f7f78 --- /dev/null +++ b/restored-src/node_modules/@smithy/fetch-http-handler/package.json @@ -0,0 +1,6 @@ +{ + "name": "@smithy/fetch-http-handler", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@smithy/hash-node/package.json b/restored-src/node_modules/@smithy/hash-node/package.json new file mode 100644 index 000000000..e9c578828 --- /dev/null +++ b/restored-src/node_modules/@smithy/hash-node/package.json @@ -0,0 +1,6 @@ +{ + "name": "@smithy/hash-node", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@smithy/is-array-buffer/package.json b/restored-src/node_modules/@smithy/is-array-buffer/package.json new file mode 100644 index 000000000..3b56ed236 --- /dev/null +++ b/restored-src/node_modules/@smithy/is-array-buffer/package.json @@ -0,0 +1,6 @@ +{ + "name": "@smithy/is-array-buffer", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@smithy/middleware-content-length/package.json b/restored-src/node_modules/@smithy/middleware-content-length/package.json new file mode 100644 index 000000000..6af594369 --- /dev/null +++ b/restored-src/node_modules/@smithy/middleware-content-length/package.json @@ -0,0 +1,6 @@ +{ + "name": "@smithy/middleware-content-length", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@smithy/middleware-endpoint/package.json b/restored-src/node_modules/@smithy/middleware-endpoint/package.json new file mode 100644 index 000000000..ba966bf3d --- /dev/null +++ b/restored-src/node_modules/@smithy/middleware-endpoint/package.json @@ -0,0 +1,6 @@ +{ + "name": "@smithy/middleware-endpoint", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@smithy/middleware-retry/package.json b/restored-src/node_modules/@smithy/middleware-retry/package.json new file mode 100644 index 000000000..00d2725e3 --- /dev/null +++ b/restored-src/node_modules/@smithy/middleware-retry/package.json @@ -0,0 +1,6 @@ +{ + "name": "@smithy/middleware-retry", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@smithy/middleware-serde/package.json b/restored-src/node_modules/@smithy/middleware-serde/package.json new file mode 100644 index 000000000..8d7bed936 --- /dev/null +++ b/restored-src/node_modules/@smithy/middleware-serde/package.json @@ -0,0 +1,6 @@ +{ + "name": "@smithy/middleware-serde", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@smithy/middleware-stack/package.json b/restored-src/node_modules/@smithy/middleware-stack/package.json new file mode 100644 index 000000000..cc806141e --- /dev/null +++ b/restored-src/node_modules/@smithy/middleware-stack/package.json @@ -0,0 +1,6 @@ +{ + "name": "@smithy/middleware-stack", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@smithy/node-config-provider/package.json b/restored-src/node_modules/@smithy/node-config-provider/package.json new file mode 100644 index 000000000..10aedce71 --- /dev/null +++ b/restored-src/node_modules/@smithy/node-config-provider/package.json @@ -0,0 +1,6 @@ +{ + "name": "@smithy/node-config-provider", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@smithy/node-http-handler/package.json b/restored-src/node_modules/@smithy/node-http-handler/package.json new file mode 100644 index 000000000..9bc5e38b8 --- /dev/null +++ b/restored-src/node_modules/@smithy/node-http-handler/package.json @@ -0,0 +1,6 @@ +{ + "name": "@smithy/node-http-handler", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@smithy/property-provider/package.json b/restored-src/node_modules/@smithy/property-provider/package.json new file mode 100644 index 000000000..6fe364a02 --- /dev/null +++ b/restored-src/node_modules/@smithy/property-provider/package.json @@ -0,0 +1,6 @@ +{ + "name": "@smithy/property-provider", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@smithy/protocol-http/package.json b/restored-src/node_modules/@smithy/protocol-http/package.json new file mode 100644 index 000000000..90bd37331 --- /dev/null +++ b/restored-src/node_modules/@smithy/protocol-http/package.json @@ -0,0 +1,6 @@ +{ + "name": "@smithy/protocol-http", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@smithy/querystring-builder/package.json b/restored-src/node_modules/@smithy/querystring-builder/package.json new file mode 100644 index 000000000..af17f0dfe --- /dev/null +++ b/restored-src/node_modules/@smithy/querystring-builder/package.json @@ -0,0 +1,6 @@ +{ + "name": "@smithy/querystring-builder", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@smithy/querystring-parser/package.json b/restored-src/node_modules/@smithy/querystring-parser/package.json new file mode 100644 index 000000000..ccd14e2e4 --- /dev/null +++ b/restored-src/node_modules/@smithy/querystring-parser/package.json @@ -0,0 +1,6 @@ +{ + "name": "@smithy/querystring-parser", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@smithy/service-error-classification/package.json b/restored-src/node_modules/@smithy/service-error-classification/package.json new file mode 100644 index 000000000..4fdbe1190 --- /dev/null +++ b/restored-src/node_modules/@smithy/service-error-classification/package.json @@ -0,0 +1,6 @@ +{ + "name": "@smithy/service-error-classification", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@smithy/shared-ini-file-loader/package.json b/restored-src/node_modules/@smithy/shared-ini-file-loader/package.json new file mode 100644 index 000000000..d443f2a0c --- /dev/null +++ b/restored-src/node_modules/@smithy/shared-ini-file-loader/package.json @@ -0,0 +1,6 @@ +{ + "name": "@smithy/shared-ini-file-loader", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@smithy/signature-v4/package.json b/restored-src/node_modules/@smithy/signature-v4/package.json new file mode 100644 index 000000000..051e22d08 --- /dev/null +++ b/restored-src/node_modules/@smithy/signature-v4/package.json @@ -0,0 +1,6 @@ +{ + "name": "@smithy/signature-v4", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@smithy/smithy-client/package.json b/restored-src/node_modules/@smithy/smithy-client/package.json new file mode 100644 index 000000000..329d199a7 --- /dev/null +++ b/restored-src/node_modules/@smithy/smithy-client/package.json @@ -0,0 +1,6 @@ +{ + "name": "@smithy/smithy-client", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@smithy/types/package.json b/restored-src/node_modules/@smithy/types/package.json new file mode 100644 index 000000000..45478cd78 --- /dev/null +++ b/restored-src/node_modules/@smithy/types/package.json @@ -0,0 +1,6 @@ +{ + "name": "@smithy/types", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@smithy/url-parser/package.json b/restored-src/node_modules/@smithy/url-parser/package.json new file mode 100644 index 000000000..59af042c3 --- /dev/null +++ b/restored-src/node_modules/@smithy/url-parser/package.json @@ -0,0 +1,6 @@ +{ + "name": "@smithy/url-parser", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@smithy/util-base64/package.json b/restored-src/node_modules/@smithy/util-base64/package.json new file mode 100644 index 000000000..65ec8f0be --- /dev/null +++ b/restored-src/node_modules/@smithy/util-base64/package.json @@ -0,0 +1,6 @@ +{ + "name": "@smithy/util-base64", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@smithy/util-body-length-browser/package.json b/restored-src/node_modules/@smithy/util-body-length-browser/package.json new file mode 100644 index 000000000..43e99410a --- /dev/null +++ b/restored-src/node_modules/@smithy/util-body-length-browser/package.json @@ -0,0 +1,6 @@ +{ + "name": "@smithy/util-body-length-browser", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@smithy/util-body-length-node/package.json b/restored-src/node_modules/@smithy/util-body-length-node/package.json new file mode 100644 index 000000000..7929a81e4 --- /dev/null +++ b/restored-src/node_modules/@smithy/util-body-length-node/package.json @@ -0,0 +1,6 @@ +{ + "name": "@smithy/util-body-length-node", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@smithy/util-buffer-from/package.json b/restored-src/node_modules/@smithy/util-buffer-from/package.json new file mode 100644 index 000000000..9bae8cf21 --- /dev/null +++ b/restored-src/node_modules/@smithy/util-buffer-from/package.json @@ -0,0 +1,6 @@ +{ + "name": "@smithy/util-buffer-from", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@smithy/util-config-provider/package.json b/restored-src/node_modules/@smithy/util-config-provider/package.json new file mode 100644 index 000000000..6315d30b0 --- /dev/null +++ b/restored-src/node_modules/@smithy/util-config-provider/package.json @@ -0,0 +1,6 @@ +{ + "name": "@smithy/util-config-provider", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@smithy/util-defaults-mode-node/package.json b/restored-src/node_modules/@smithy/util-defaults-mode-node/package.json new file mode 100644 index 000000000..705859bab --- /dev/null +++ b/restored-src/node_modules/@smithy/util-defaults-mode-node/package.json @@ -0,0 +1,6 @@ +{ + "name": "@smithy/util-defaults-mode-node", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@smithy/util-endpoints/package.json b/restored-src/node_modules/@smithy/util-endpoints/package.json new file mode 100644 index 000000000..8243f78c2 --- /dev/null +++ b/restored-src/node_modules/@smithy/util-endpoints/package.json @@ -0,0 +1,6 @@ +{ + "name": "@smithy/util-endpoints", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@smithy/util-hex-encoding/package.json b/restored-src/node_modules/@smithy/util-hex-encoding/package.json new file mode 100644 index 000000000..aa95f5e15 --- /dev/null +++ b/restored-src/node_modules/@smithy/util-hex-encoding/package.json @@ -0,0 +1,6 @@ +{ + "name": "@smithy/util-hex-encoding", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@smithy/util-middleware/package.json b/restored-src/node_modules/@smithy/util-middleware/package.json new file mode 100644 index 000000000..dd80ec21f --- /dev/null +++ b/restored-src/node_modules/@smithy/util-middleware/package.json @@ -0,0 +1,6 @@ +{ + "name": "@smithy/util-middleware", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@smithy/util-retry/package.json b/restored-src/node_modules/@smithy/util-retry/package.json new file mode 100644 index 000000000..6b24c7bf6 --- /dev/null +++ b/restored-src/node_modules/@smithy/util-retry/package.json @@ -0,0 +1,6 @@ +{ + "name": "@smithy/util-retry", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@smithy/util-stream/package.json b/restored-src/node_modules/@smithy/util-stream/package.json new file mode 100644 index 000000000..9e0ff4eb2 --- /dev/null +++ b/restored-src/node_modules/@smithy/util-stream/package.json @@ -0,0 +1,6 @@ +{ + "name": "@smithy/util-stream", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@smithy/util-uri-escape/package.json b/restored-src/node_modules/@smithy/util-uri-escape/package.json new file mode 100644 index 000000000..fce510c0a --- /dev/null +++ b/restored-src/node_modules/@smithy/util-uri-escape/package.json @@ -0,0 +1,6 @@ +{ + "name": "@smithy/util-uri-escape", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@smithy/util-utf8/package.json b/restored-src/node_modules/@smithy/util-utf8/package.json new file mode 100644 index 000000000..7a2b79979 --- /dev/null +++ b/restored-src/node_modules/@smithy/util-utf8/package.json @@ -0,0 +1,6 @@ +{ + "name": "@smithy/util-utf8", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@smithy/uuid/package.json b/restored-src/node_modules/@smithy/uuid/package.json new file mode 100644 index 000000000..aa884e6d3 --- /dev/null +++ b/restored-src/node_modules/@smithy/uuid/package.json @@ -0,0 +1,6 @@ +{ + "name": "@smithy/uuid", + "private": true, + "main": "./dist-cjs/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/@typespec/ts-http-runtime/package.json b/restored-src/node_modules/@typespec/ts-http-runtime/package.json new file mode 100644 index 000000000..252a3a91a --- /dev/null +++ b/restored-src/node_modules/@typespec/ts-http-runtime/package.json @@ -0,0 +1,6 @@ +{ + "name": "@typespec/ts-http-runtime", + "private": true, + "main": "./dist/esm/index.js", + "type": "module" +} diff --git a/restored-src/node_modules/@xmldom/xmldom/package.json b/restored-src/node_modules/@xmldom/xmldom/package.json new file mode 100644 index 000000000..7f9066c01 --- /dev/null +++ b/restored-src/node_modules/@xmldom/xmldom/package.json @@ -0,0 +1,6 @@ +{ + "name": "@xmldom/xmldom", + "private": true, + "main": "./lib/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/agent-base/package.json b/restored-src/node_modules/agent-base/package.json new file mode 100644 index 000000000..d82f8bf34 --- /dev/null +++ b/restored-src/node_modules/agent-base/package.json @@ -0,0 +1,6 @@ +{ + "name": "agent-base", + "private": true, + "main": "./dist/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/ajv-formats/package.json b/restored-src/node_modules/ajv-formats/package.json new file mode 100644 index 000000000..494b78835 --- /dev/null +++ b/restored-src/node_modules/ajv-formats/package.json @@ -0,0 +1,6 @@ +{ + "name": "ajv-formats", + "private": true, + "main": "./dist/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/ajv/dist/refs/data.json b/restored-src/node_modules/ajv/dist/refs/data.json new file mode 100644 index 000000000..b33bf5c38 --- /dev/null +++ b/restored-src/node_modules/ajv/dist/refs/data.json @@ -0,0 +1,10 @@ +{ + "$id": "https://raw.githubusercontent.com/ajv-validator/ajv/master/lib/refs/data.json#", + "type": "object", + "properties": { + "$data": { + "type": "string" + } + }, + "additionalProperties": true +} diff --git a/restored-src/node_modules/ajv/dist/refs/json-schema-draft-07.json b/restored-src/node_modules/ajv/dist/refs/json-schema-draft-07.json new file mode 100644 index 000000000..f9e2852f1 --- /dev/null +++ b/restored-src/node_modules/ajv/dist/refs/json-schema-draft-07.json @@ -0,0 +1,50 @@ +{ + "$schema": "http://json-schema.org/draft-07/schema#", + "$id": "http://json-schema.org/draft-07/schema#", + "title": "Draft 7 schema meta-schema (restored build stub)", + "definitions": { + "schemaArray": { + "type": "array", + "items": { + "$ref": "#" + } + }, + "nonNegativeInteger": { + "type": "integer", + "minimum": 0 + }, + "nonNegativeIntegerDefault0": { + "allOf": [ + { + "$ref": "#/definitions/nonNegativeInteger" + }, + { + "default": 0 + } + ] + }, + "simpleTypes": { + "enum": [ + "array", + "boolean", + "integer", + "null", + "number", + "object", + "string" + ] + }, + "stringArray": { + "type": "array", + "items": { + "type": "string" + }, + "uniqueItems": true, + "default": [] + } + }, + "type": [ + "object", + "boolean" + ] +} diff --git a/restored-src/node_modules/ajv/package.json b/restored-src/node_modules/ajv/package.json new file mode 100644 index 000000000..fa343f7a8 --- /dev/null +++ b/restored-src/node_modules/ajv/package.json @@ -0,0 +1,6 @@ +{ + "name": "ajv", + "private": true, + "main": "./dist/ajv.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/ansi-escapes/package.json b/restored-src/node_modules/ansi-escapes/package.json new file mode 100644 index 000000000..ab879d7d1 --- /dev/null +++ b/restored-src/node_modules/ansi-escapes/package.json @@ -0,0 +1,6 @@ +{ + "name": "ansi-escapes", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/ansi-regex/package.json b/restored-src/node_modules/ansi-regex/package.json new file mode 100644 index 000000000..59dd18666 --- /dev/null +++ b/restored-src/node_modules/ansi-regex/package.json @@ -0,0 +1,6 @@ +{ + "name": "ansi-regex", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/ansi-styles/index.js b/restored-src/node_modules/ansi-styles/index.js index 5d82581a1..000b253f2 100644 --- a/restored-src/node_modules/ansi-styles/index.js +++ b/restored-src/node_modules/ansi-styles/index.js @@ -146,10 +146,18 @@ function assembleStyles() { styles.color.close = '\u001B[39m'; styles.bgColor.close = '\u001B[49m'; - setLazyProperty(styles.color, 'ansi', () => makeDynamicStyles(wrapAnsi16, 'ansi16', ansi2ansi, false)); + setLazyProperty(styles.color, 'ansi', () => { + const converters = makeDynamicStyles(wrapAnsi16, 'ansi16', ansi2ansi, false); + const ansi = code => `\u001B[${code}m`; + return Object.assign(ansi, converters); + }); setLazyProperty(styles.color, 'ansi256', () => makeDynamicStyles(wrapAnsi256, 'ansi256', ansi2ansi, false)); setLazyProperty(styles.color, 'ansi16m', () => makeDynamicStyles(wrapAnsi16m, 'rgb', rgb2rgb, false)); - setLazyProperty(styles.bgColor, 'ansi', () => makeDynamicStyles(wrapAnsi16, 'ansi16', ansi2ansi, true)); + setLazyProperty(styles.bgColor, 'ansi', () => { + const converters = makeDynamicStyles(wrapAnsi16, 'ansi16', ansi2ansi, true); + const ansi = code => `\u001B[${code}m`; + return Object.assign(ansi, converters); + }); setLazyProperty(styles.bgColor, 'ansi256', () => makeDynamicStyles(wrapAnsi256, 'ansi256', ansi2ansi, true)); setLazyProperty(styles.bgColor, 'ansi16m', () => makeDynamicStyles(wrapAnsi16m, 'rgb', rgb2rgb, true)); diff --git a/restored-src/node_modules/ansi-styles/package.json b/restored-src/node_modules/ansi-styles/package.json new file mode 100644 index 000000000..471da7ce9 --- /dev/null +++ b/restored-src/node_modules/ansi-styles/package.json @@ -0,0 +1,6 @@ +{ + "name": "ansi-styles", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/asciichart/package.json b/restored-src/node_modules/asciichart/package.json new file mode 100644 index 000000000..9741be045 --- /dev/null +++ b/restored-src/node_modules/asciichart/package.json @@ -0,0 +1,6 @@ +{ + "name": "asciichart", + "private": true, + "main": "./asciichart.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/asynckit/package.json b/restored-src/node_modules/asynckit/package.json new file mode 100644 index 000000000..3d8ff4e6e --- /dev/null +++ b/restored-src/node_modules/asynckit/package.json @@ -0,0 +1,6 @@ +{ + "name": "asynckit", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/auto-bind/package.json b/restored-src/node_modules/auto-bind/package.json new file mode 100644 index 000000000..6950e111d --- /dev/null +++ b/restored-src/node_modules/auto-bind/package.json @@ -0,0 +1,6 @@ +{ + "name": "auto-bind", + "private": true, + "main": "./index.js", + "type": "module" +} diff --git a/restored-src/node_modules/axios/package.json b/restored-src/node_modules/axios/package.json new file mode 100644 index 000000000..36fa9405c --- /dev/null +++ b/restored-src/node_modules/axios/package.json @@ -0,0 +1,6 @@ +{ + "name": "axios", + "private": true, + "main": "./index.js", + "type": "module" +} diff --git a/restored-src/node_modules/base64-js/package.json b/restored-src/node_modules/base64-js/package.json new file mode 100644 index 000000000..868c926d0 --- /dev/null +++ b/restored-src/node_modules/base64-js/package.json @@ -0,0 +1,6 @@ +{ + "name": "base64-js", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/bidi-js/package.json b/restored-src/node_modules/bidi-js/package.json new file mode 100644 index 000000000..8443b7984 --- /dev/null +++ b/restored-src/node_modules/bidi-js/package.json @@ -0,0 +1,6 @@ +{ + "name": "bidi-js", + "private": true, + "main": "./dist/bidi.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/bignumber.js/package.json b/restored-src/node_modules/bignumber.js/package.json new file mode 100644 index 000000000..a315e1027 --- /dev/null +++ b/restored-src/node_modules/bignumber.js/package.json @@ -0,0 +1,6 @@ +{ + "name": "bignumber.js", + "private": true, + "main": "./bignumber.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/buffer-equal-constant-time/package.json b/restored-src/node_modules/buffer-equal-constant-time/package.json new file mode 100644 index 000000000..0a7156cca --- /dev/null +++ b/restored-src/node_modules/buffer-equal-constant-time/package.json @@ -0,0 +1,6 @@ +{ + "name": "buffer-equal-constant-time", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/bundle-name/package.json b/restored-src/node_modules/bundle-name/package.json new file mode 100644 index 000000000..56d6505ab --- /dev/null +++ b/restored-src/node_modules/bundle-name/package.json @@ -0,0 +1,6 @@ +{ + "name": "bundle-name", + "private": true, + "main": "./index.js", + "type": "module" +} diff --git a/restored-src/node_modules/call-bind-apply-helpers/package.json b/restored-src/node_modules/call-bind-apply-helpers/package.json new file mode 100644 index 000000000..8ad5a7e82 --- /dev/null +++ b/restored-src/node_modules/call-bind-apply-helpers/package.json @@ -0,0 +1,6 @@ +{ + "name": "call-bind-apply-helpers", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/chalk/package.json b/restored-src/node_modules/chalk/package.json new file mode 100644 index 000000000..ed909ce7d --- /dev/null +++ b/restored-src/node_modules/chalk/package.json @@ -0,0 +1,6 @@ +{ + "name": "chalk", + "private": true, + "main": "./source/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/chalk/source/index.js b/restored-src/node_modules/chalk/source/index.js index 75ec66350..1f3b3db95 100644 --- a/restored-src/node_modules/chalk/source/index.js +++ b/restored-src/node_modules/chalk/source/index.js @@ -227,3 +227,4 @@ chalk.stderr = Chalk({level: stderrColor ? stderrColor.level : 0}); // eslint-di chalk.stderr.supportsColor = stderrColor; module.exports = chalk; +module.exports.Chalk = Chalk; diff --git a/restored-src/node_modules/chokidar/package.json b/restored-src/node_modules/chokidar/package.json new file mode 100644 index 000000000..fcf0f1807 --- /dev/null +++ b/restored-src/node_modules/chokidar/package.json @@ -0,0 +1,6 @@ +{ + "name": "chokidar", + "private": true, + "main": "./esm/index.js", + "type": "module" +} diff --git a/restored-src/node_modules/cli-boxes/boxes.json b/restored-src/node_modules/cli-boxes/boxes.json new file mode 100644 index 000000000..5d71dcb77 --- /dev/null +++ b/restored-src/node_modules/cli-boxes/boxes.json @@ -0,0 +1,42 @@ +{ + "single": { + "topLeft": "┌", + "topRight": "┐", + "bottomRight": "┘", + "bottomLeft": "└", + "horizontal": "─", + "vertical": "│" + }, + "double": { + "topLeft": "╔", + "topRight": "╗", + "bottomRight": "╝", + "bottomLeft": "╚", + "horizontal": "═", + "vertical": "║" + }, + "round": { + "topLeft": "╭", + "topRight": "╮", + "bottomRight": "╯", + "bottomLeft": "╰", + "horizontal": "─", + "vertical": "│" + }, + "bold": { + "topLeft": "┏", + "topRight": "┓", + "bottomRight": "┛", + "bottomLeft": "┗", + "horizontal": "━", + "vertical": "┃" + }, + "classic": { + "topLeft": "+", + "topRight": "+", + "bottomRight": "+", + "bottomLeft": "+", + "horizontal": "-", + "vertical": "|" + } +} diff --git a/restored-src/node_modules/cli-boxes/package.json b/restored-src/node_modules/cli-boxes/package.json new file mode 100644 index 000000000..96e3712e8 --- /dev/null +++ b/restored-src/node_modules/cli-boxes/package.json @@ -0,0 +1,6 @@ +{ + "name": "cli-boxes", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/cli-highlight/package.json b/restored-src/node_modules/cli-highlight/package.json new file mode 100644 index 000000000..67609c94d --- /dev/null +++ b/restored-src/node_modules/cli-highlight/package.json @@ -0,0 +1,6 @@ +{ + "name": "cli-highlight", + "private": true, + "main": "./dist/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/cli-width/package.json b/restored-src/node_modules/cli-width/package.json new file mode 100644 index 000000000..2fa37e9a8 --- /dev/null +++ b/restored-src/node_modules/cli-width/package.json @@ -0,0 +1,6 @@ +{ + "name": "cli-width", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/code-excerpt/package.json b/restored-src/node_modules/code-excerpt/package.json new file mode 100644 index 000000000..e7e5d5706 --- /dev/null +++ b/restored-src/node_modules/code-excerpt/package.json @@ -0,0 +1,6 @@ +{ + "name": "code-excerpt", + "private": true, + "main": "./dist/index.js", + "type": "module" +} diff --git a/restored-src/node_modules/color-convert/package.json b/restored-src/node_modules/color-convert/package.json new file mode 100644 index 000000000..42e59bf4b --- /dev/null +++ b/restored-src/node_modules/color-convert/package.json @@ -0,0 +1,6 @@ +{ + "name": "color-convert", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/color-name/package.json b/restored-src/node_modules/color-name/package.json new file mode 100644 index 000000000..dca1bd107 --- /dev/null +++ b/restored-src/node_modules/color-name/package.json @@ -0,0 +1,6 @@ +{ + "name": "color-name", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/combined-stream/package.json b/restored-src/node_modules/combined-stream/package.json new file mode 100644 index 000000000..554d95d7e --- /dev/null +++ b/restored-src/node_modules/combined-stream/package.json @@ -0,0 +1,6 @@ +{ + "name": "combined-stream", + "private": true, + "main": "./lib/combined_stream.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/commander/package.json b/restored-src/node_modules/commander/package.json new file mode 100644 index 000000000..217c4d5a3 --- /dev/null +++ b/restored-src/node_modules/commander/package.json @@ -0,0 +1,6 @@ +{ + "name": "commander", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/convert-to-spaces/package.json b/restored-src/node_modules/convert-to-spaces/package.json new file mode 100644 index 000000000..cbeacc5d8 --- /dev/null +++ b/restored-src/node_modules/convert-to-spaces/package.json @@ -0,0 +1,6 @@ +{ + "name": "convert-to-spaces", + "private": true, + "main": "./dist/index.js", + "type": "module" +} diff --git a/restored-src/node_modules/cross-spawn/package.json b/restored-src/node_modules/cross-spawn/package.json new file mode 100644 index 000000000..69128d207 --- /dev/null +++ b/restored-src/node_modules/cross-spawn/package.json @@ -0,0 +1,6 @@ +{ + "name": "cross-spawn", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/cssfilter/package.json b/restored-src/node_modules/cssfilter/package.json new file mode 100644 index 000000000..c6b70af26 --- /dev/null +++ b/restored-src/node_modules/cssfilter/package.json @@ -0,0 +1,6 @@ +{ + "name": "cssfilter", + "private": true, + "main": "./lib/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/debug/package.json b/restored-src/node_modules/debug/package.json new file mode 100644 index 000000000..cefbcee6e --- /dev/null +++ b/restored-src/node_modules/debug/package.json @@ -0,0 +1,6 @@ +{ + "name": "debug", + "private": true, + "main": "./src/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/default-browser-id/package.json b/restored-src/node_modules/default-browser-id/package.json new file mode 100644 index 000000000..406e0bdc1 --- /dev/null +++ b/restored-src/node_modules/default-browser-id/package.json @@ -0,0 +1,6 @@ +{ + "name": "default-browser-id", + "private": true, + "main": "./index.js", + "type": "module" +} diff --git a/restored-src/node_modules/default-browser/package.json b/restored-src/node_modules/default-browser/package.json new file mode 100644 index 000000000..8d315bc42 --- /dev/null +++ b/restored-src/node_modules/default-browser/package.json @@ -0,0 +1,6 @@ +{ + "name": "default-browser", + "private": true, + "main": "./index.js", + "type": "module" +} diff --git a/restored-src/node_modules/define-lazy-prop/package.json b/restored-src/node_modules/define-lazy-prop/package.json new file mode 100644 index 000000000..8efc68592 --- /dev/null +++ b/restored-src/node_modules/define-lazy-prop/package.json @@ -0,0 +1,6 @@ +{ + "name": "define-lazy-prop", + "private": true, + "main": "./index.js", + "type": "module" +} diff --git a/restored-src/node_modules/delayed-stream/package.json b/restored-src/node_modules/delayed-stream/package.json new file mode 100644 index 000000000..6cf39a653 --- /dev/null +++ b/restored-src/node_modules/delayed-stream/package.json @@ -0,0 +1,6 @@ +{ + "name": "delayed-stream", + "private": true, + "main": "./lib/delayed_stream.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/detect-libc/package.json b/restored-src/node_modules/detect-libc/package.json new file mode 100644 index 000000000..2328d0418 --- /dev/null +++ b/restored-src/node_modules/detect-libc/package.json @@ -0,0 +1,6 @@ +{ + "name": "detect-libc", + "private": true, + "main": "./lib/detect-libc.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/diff/libesm/util/params.js b/restored-src/node_modules/diff/libesm/util/params.js new file mode 100644 index 000000000..e9eeecf38 --- /dev/null +++ b/restored-src/node_modules/diff/libesm/util/params.js @@ -0,0 +1,11 @@ +export function generateOptions(options, defaults = {}) { + if (options === undefined) { + return { ...defaults }; + } + + if (typeof options === "function") { + return { ...defaults, callback: options }; + } + + return { ...defaults, ...options }; +} diff --git a/restored-src/node_modules/diff/package.json b/restored-src/node_modules/diff/package.json new file mode 100644 index 000000000..3912eead4 --- /dev/null +++ b/restored-src/node_modules/diff/package.json @@ -0,0 +1,6 @@ +{ + "name": "diff", + "private": true, + "main": "./libesm/index.js", + "type": "module" +} diff --git a/restored-src/node_modules/dijkstrajs/package.json b/restored-src/node_modules/dijkstrajs/package.json new file mode 100644 index 000000000..5b82430bc --- /dev/null +++ b/restored-src/node_modules/dijkstrajs/package.json @@ -0,0 +1,6 @@ +{ + "name": "dijkstrajs", + "private": true, + "main": "./dijkstra.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/dom-mutator/package.json b/restored-src/node_modules/dom-mutator/package.json new file mode 100644 index 000000000..a127e3a5d --- /dev/null +++ b/restored-src/node_modules/dom-mutator/package.json @@ -0,0 +1,6 @@ +{ + "name": "dom-mutator", + "private": true, + "main": "./dist/dom-mutator.cjs.production.min.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/dunder-proto/package.json b/restored-src/node_modules/dunder-proto/package.json new file mode 100644 index 000000000..5b8726dff --- /dev/null +++ b/restored-src/node_modules/dunder-proto/package.json @@ -0,0 +1,6 @@ +{ + "name": "dunder-proto", + "private": true, + "main": "./get.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/ecdsa-sig-formatter/package.json b/restored-src/node_modules/ecdsa-sig-formatter/package.json new file mode 100644 index 000000000..c4425e262 --- /dev/null +++ b/restored-src/node_modules/ecdsa-sig-formatter/package.json @@ -0,0 +1,6 @@ +{ + "name": "ecdsa-sig-formatter", + "private": true, + "main": "./src/ecdsa-sig-formatter.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/emoji-regex/package.json b/restored-src/node_modules/emoji-regex/package.json new file mode 100644 index 000000000..407e5ecc4 --- /dev/null +++ b/restored-src/node_modules/emoji-regex/package.json @@ -0,0 +1,6 @@ +{ + "name": "emoji-regex", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/env-paths/package.json b/restored-src/node_modules/env-paths/package.json new file mode 100644 index 000000000..9539a9c68 --- /dev/null +++ b/restored-src/node_modules/env-paths/package.json @@ -0,0 +1,6 @@ +{ + "name": "env-paths", + "private": true, + "main": "./index.js", + "type": "module" +} diff --git a/restored-src/node_modules/es-define-property/package.json b/restored-src/node_modules/es-define-property/package.json new file mode 100644 index 000000000..942980bd3 --- /dev/null +++ b/restored-src/node_modules/es-define-property/package.json @@ -0,0 +1,6 @@ +{ + "name": "es-define-property", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/es-errors/package.json b/restored-src/node_modules/es-errors/package.json new file mode 100644 index 000000000..4f5422a31 --- /dev/null +++ b/restored-src/node_modules/es-errors/package.json @@ -0,0 +1,6 @@ +{ + "name": "es-errors", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/es-object-atoms/package.json b/restored-src/node_modules/es-object-atoms/package.json new file mode 100644 index 000000000..56a0e07c5 --- /dev/null +++ b/restored-src/node_modules/es-object-atoms/package.json @@ -0,0 +1,6 @@ +{ + "name": "es-object-atoms", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/es-set-tostringtag/package.json b/restored-src/node_modules/es-set-tostringtag/package.json new file mode 100644 index 000000000..478fa57ab --- /dev/null +++ b/restored-src/node_modules/es-set-tostringtag/package.json @@ -0,0 +1,6 @@ +{ + "name": "es-set-tostringtag", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/escape-string-regexp/package.json b/restored-src/node_modules/escape-string-regexp/package.json new file mode 100644 index 000000000..7508c2b06 --- /dev/null +++ b/restored-src/node_modules/escape-string-regexp/package.json @@ -0,0 +1,6 @@ +{ + "name": "escape-string-regexp", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/eventsource-parser/package.json b/restored-src/node_modules/eventsource-parser/package.json new file mode 100644 index 000000000..616135d64 --- /dev/null +++ b/restored-src/node_modules/eventsource-parser/package.json @@ -0,0 +1,6 @@ +{ + "name": "eventsource-parser", + "private": true, + "main": "./dist/index.js", + "type": "module" +} diff --git a/restored-src/node_modules/eventsource-parser/stream.js b/restored-src/node_modules/eventsource-parser/stream.js new file mode 100644 index 000000000..814b5edbc --- /dev/null +++ b/restored-src/node_modules/eventsource-parser/stream.js @@ -0,0 +1 @@ +export * from './dist/stream.js' diff --git a/restored-src/node_modules/eventsource/package.json b/restored-src/node_modules/eventsource/package.json new file mode 100644 index 000000000..dab267b2d --- /dev/null +++ b/restored-src/node_modules/eventsource/package.json @@ -0,0 +1,6 @@ +{ + "name": "eventsource", + "private": true, + "main": "./dist/index.js", + "type": "module" +} diff --git a/restored-src/node_modules/execa/package.json b/restored-src/node_modules/execa/package.json new file mode 100644 index 000000000..f5bbb4914 --- /dev/null +++ b/restored-src/node_modules/execa/package.json @@ -0,0 +1,6 @@ +{ + "name": "execa", + "private": true, + "main": "./index.js", + "type": "module" +} diff --git a/restored-src/node_modules/extend/package.json b/restored-src/node_modules/extend/package.json new file mode 100644 index 000000000..8f85930c5 --- /dev/null +++ b/restored-src/node_modules/extend/package.json @@ -0,0 +1,6 @@ +{ + "name": "extend", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/fast-deep-equal/package.json b/restored-src/node_modules/fast-deep-equal/package.json new file mode 100644 index 000000000..1778606eb --- /dev/null +++ b/restored-src/node_modules/fast-deep-equal/package.json @@ -0,0 +1,6 @@ +{ + "name": "fast-deep-equal", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/fast-uri/package.json b/restored-src/node_modules/fast-uri/package.json new file mode 100644 index 000000000..b8e48adeb --- /dev/null +++ b/restored-src/node_modules/fast-uri/package.json @@ -0,0 +1,6 @@ +{ + "name": "fast-uri", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/fast-xml-parser/package.json b/restored-src/node_modules/fast-xml-parser/package.json new file mode 100644 index 000000000..76da6bebc --- /dev/null +++ b/restored-src/node_modules/fast-xml-parser/package.json @@ -0,0 +1,6 @@ +{ + "name": "fast-xml-parser", + "private": true, + "main": "./lib/fxp.cjs", + "type": "commonjs" +} diff --git a/restored-src/node_modules/fflate/package.json b/restored-src/node_modules/fflate/package.json new file mode 100644 index 000000000..15c9bdb7a --- /dev/null +++ b/restored-src/node_modules/fflate/package.json @@ -0,0 +1,6 @@ +{ + "name": "fflate", + "private": true, + "main": "./esm/index.mjs", + "type": "module" +} diff --git a/restored-src/node_modules/figures/package.json b/restored-src/node_modules/figures/package.json new file mode 100644 index 000000000..9a400e444 --- /dev/null +++ b/restored-src/node_modules/figures/package.json @@ -0,0 +1,6 @@ +{ + "name": "figures", + "private": true, + "main": "./index.js", + "type": "module" +} diff --git a/restored-src/node_modules/flora-colossus/package.json b/restored-src/node_modules/flora-colossus/package.json new file mode 100644 index 000000000..f68a6441e --- /dev/null +++ b/restored-src/node_modules/flora-colossus/package.json @@ -0,0 +1,6 @@ +{ + "name": "flora-colossus", + "private": true, + "main": "./lib/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/follow-redirects/package.json b/restored-src/node_modules/follow-redirects/package.json new file mode 100644 index 000000000..ac30124e3 --- /dev/null +++ b/restored-src/node_modules/follow-redirects/package.json @@ -0,0 +1,6 @@ +{ + "name": "follow-redirects", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/form-data/package.json b/restored-src/node_modules/form-data/package.json new file mode 100644 index 000000000..f8bd3dcd3 --- /dev/null +++ b/restored-src/node_modules/form-data/package.json @@ -0,0 +1,6 @@ +{ + "name": "form-data", + "private": true, + "main": "./lib/form_data.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/fs-extra/package.json b/restored-src/node_modules/fs-extra/package.json new file mode 100644 index 000000000..4b008a03d --- /dev/null +++ b/restored-src/node_modules/fs-extra/package.json @@ -0,0 +1,6 @@ +{ + "name": "fs-extra", + "private": true, + "main": "./lib/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/function-bind/package.json b/restored-src/node_modules/function-bind/package.json new file mode 100644 index 000000000..c9e3b8230 --- /dev/null +++ b/restored-src/node_modules/function-bind/package.json @@ -0,0 +1,6 @@ +{ + "name": "function-bind", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/fuse.js/package.json b/restored-src/node_modules/fuse.js/package.json new file mode 100644 index 000000000..5e2ea77ba --- /dev/null +++ b/restored-src/node_modules/fuse.js/package.json @@ -0,0 +1,6 @@ +{ + "name": "fuse.js", + "private": true, + "main": "./dist/fuse.mjs", + "type": "module" +} diff --git a/restored-src/node_modules/galactus/package.json b/restored-src/node_modules/galactus/package.json new file mode 100644 index 000000000..168a5b953 --- /dev/null +++ b/restored-src/node_modules/galactus/package.json @@ -0,0 +1,6 @@ +{ + "name": "galactus", + "private": true, + "main": "./lib/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/gaxios/package.json b/restored-src/node_modules/gaxios/package.json new file mode 100644 index 000000000..f649e7841 --- /dev/null +++ b/restored-src/node_modules/gaxios/package.json @@ -0,0 +1,6 @@ +{ + "name": "gaxios", + "private": true, + "main": "./build/src/gaxios.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/gcp-metadata/package.json b/restored-src/node_modules/gcp-metadata/package.json new file mode 100644 index 000000000..cba221491 --- /dev/null +++ b/restored-src/node_modules/gcp-metadata/package.json @@ -0,0 +1,6 @@ +{ + "name": "gcp-metadata", + "private": true, + "main": "./build/src/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/get-east-asian-width/package.json b/restored-src/node_modules/get-east-asian-width/package.json new file mode 100644 index 000000000..a03b5f13c --- /dev/null +++ b/restored-src/node_modules/get-east-asian-width/package.json @@ -0,0 +1,6 @@ +{ + "name": "get-east-asian-width", + "private": true, + "main": "./index.js", + "type": "module" +} diff --git a/restored-src/node_modules/get-intrinsic/package.json b/restored-src/node_modules/get-intrinsic/package.json new file mode 100644 index 000000000..d6ca9f5b8 --- /dev/null +++ b/restored-src/node_modules/get-intrinsic/package.json @@ -0,0 +1,6 @@ +{ + "name": "get-intrinsic", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/get-proto/package.json b/restored-src/node_modules/get-proto/package.json new file mode 100644 index 000000000..f75136b79 --- /dev/null +++ b/restored-src/node_modules/get-proto/package.json @@ -0,0 +1,6 @@ +{ + "name": "get-proto", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/get-stream/package.json b/restored-src/node_modules/get-stream/package.json new file mode 100644 index 000000000..8b191ff37 --- /dev/null +++ b/restored-src/node_modules/get-stream/package.json @@ -0,0 +1,6 @@ +{ + "name": "get-stream", + "private": true, + "main": "./source/index.js", + "type": "module" +} diff --git a/restored-src/node_modules/google-auth-library/package.json b/restored-src/node_modules/google-auth-library/package.json new file mode 100644 index 000000000..7400bbf0c --- /dev/null +++ b/restored-src/node_modules/google-auth-library/package.json @@ -0,0 +1,6 @@ +{ + "name": "google-auth-library", + "private": true, + "main": "./build/src/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/google-logging-utils/package.json b/restored-src/node_modules/google-logging-utils/package.json new file mode 100644 index 000000000..cb767bc26 --- /dev/null +++ b/restored-src/node_modules/google-logging-utils/package.json @@ -0,0 +1,6 @@ +{ + "name": "google-logging-utils", + "private": true, + "main": "./build/src/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/gopd/package.json b/restored-src/node_modules/gopd/package.json new file mode 100644 index 000000000..4dffa8244 --- /dev/null +++ b/restored-src/node_modules/gopd/package.json @@ -0,0 +1,6 @@ +{ + "name": "gopd", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/graceful-fs/package.json b/restored-src/node_modules/graceful-fs/package.json new file mode 100644 index 000000000..814677dd0 --- /dev/null +++ b/restored-src/node_modules/graceful-fs/package.json @@ -0,0 +1,6 @@ +{ + "name": "graceful-fs", + "private": true, + "main": "./graceful-fs.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/gtoken/package.json b/restored-src/node_modules/gtoken/package.json new file mode 100644 index 000000000..7de1e2f0a --- /dev/null +++ b/restored-src/node_modules/gtoken/package.json @@ -0,0 +1,6 @@ +{ + "name": "gtoken", + "private": true, + "main": "./build/src/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/has-flag/package.json b/restored-src/node_modules/has-flag/package.json new file mode 100644 index 000000000..7a5eff60b --- /dev/null +++ b/restored-src/node_modules/has-flag/package.json @@ -0,0 +1,6 @@ +{ + "name": "has-flag", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/has-symbols/package.json b/restored-src/node_modules/has-symbols/package.json new file mode 100644 index 000000000..0e5a72735 --- /dev/null +++ b/restored-src/node_modules/has-symbols/package.json @@ -0,0 +1,6 @@ +{ + "name": "has-symbols", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/has-tostringtag/package.json b/restored-src/node_modules/has-tostringtag/package.json new file mode 100644 index 000000000..0a2baf2ec --- /dev/null +++ b/restored-src/node_modules/has-tostringtag/package.json @@ -0,0 +1,6 @@ +{ + "name": "has-tostringtag", + "private": true, + "main": "./shams.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/hasown/package.json b/restored-src/node_modules/hasown/package.json new file mode 100644 index 000000000..374e886f0 --- /dev/null +++ b/restored-src/node_modules/hasown/package.json @@ -0,0 +1,6 @@ +{ + "name": "hasown", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/highlight.js/package.json b/restored-src/node_modules/highlight.js/package.json new file mode 100644 index 000000000..c55c93c95 --- /dev/null +++ b/restored-src/node_modules/highlight.js/package.json @@ -0,0 +1,6 @@ +{ + "name": "highlight.js", + "private": true, + "main": "./lib/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/http-proxy-agent/package.json b/restored-src/node_modules/http-proxy-agent/package.json new file mode 100644 index 000000000..c6277ba4d --- /dev/null +++ b/restored-src/node_modules/http-proxy-agent/package.json @@ -0,0 +1,6 @@ +{ + "name": "http-proxy-agent", + "private": true, + "main": "./dist/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/https-proxy-agent/package.json b/restored-src/node_modules/https-proxy-agent/package.json new file mode 100644 index 000000000..356c19ef2 --- /dev/null +++ b/restored-src/node_modules/https-proxy-agent/package.json @@ -0,0 +1,6 @@ +{ + "name": "https-proxy-agent", + "private": true, + "main": "./dist/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/human-signals/package.json b/restored-src/node_modules/human-signals/package.json new file mode 100644 index 000000000..74bfe2da8 --- /dev/null +++ b/restored-src/node_modules/human-signals/package.json @@ -0,0 +1,6 @@ +{ + "name": "human-signals", + "private": true, + "main": "./build/src/main.js", + "type": "module" +} diff --git a/restored-src/node_modules/ignore/package.json b/restored-src/node_modules/ignore/package.json new file mode 100644 index 000000000..149098b91 --- /dev/null +++ b/restored-src/node_modules/ignore/package.json @@ -0,0 +1,6 @@ +{ + "name": "ignore", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/indent-string/package.json b/restored-src/node_modules/indent-string/package.json new file mode 100644 index 000000000..1fc5e56c4 --- /dev/null +++ b/restored-src/node_modules/indent-string/package.json @@ -0,0 +1,6 @@ +{ + "name": "indent-string", + "private": true, + "main": "./index.js", + "type": "module" +} diff --git a/restored-src/node_modules/is-docker/package.json b/restored-src/node_modules/is-docker/package.json new file mode 100644 index 000000000..d7fe66b9c --- /dev/null +++ b/restored-src/node_modules/is-docker/package.json @@ -0,0 +1,6 @@ +{ + "name": "is-docker", + "private": true, + "main": "./index.js", + "type": "module" +} diff --git a/restored-src/node_modules/is-fullwidth-code-point/package.json b/restored-src/node_modules/is-fullwidth-code-point/package.json new file mode 100644 index 000000000..047f3cb8a --- /dev/null +++ b/restored-src/node_modules/is-fullwidth-code-point/package.json @@ -0,0 +1,6 @@ +{ + "name": "is-fullwidth-code-point", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/is-inside-container/package.json b/restored-src/node_modules/is-inside-container/package.json new file mode 100644 index 000000000..9d1e9f4ae --- /dev/null +++ b/restored-src/node_modules/is-inside-container/package.json @@ -0,0 +1,6 @@ +{ + "name": "is-inside-container", + "private": true, + "main": "./index.js", + "type": "module" +} diff --git a/restored-src/node_modules/is-stream/index.js b/restored-src/node_modules/is-stream/index.js index 2e43434da..4b3f81d8a 100644 --- a/restored-src/node_modules/is-stream/index.js +++ b/restored-src/node_modules/is-stream/index.js @@ -26,3 +26,8 @@ isStream.transform = stream => typeof stream._transform === 'function'; module.exports = isStream; +module.exports.isStream = isStream; +module.exports.isWritableStream = isStream.writable; +module.exports.isReadableStream = isStream.readable; +module.exports.isDuplexStream = isStream.duplex; +module.exports.isTransformStream = isStream.transform; diff --git a/restored-src/node_modules/is-stream/package.json b/restored-src/node_modules/is-stream/package.json new file mode 100644 index 000000000..78ed8eb14 --- /dev/null +++ b/restored-src/node_modules/is-stream/package.json @@ -0,0 +1,6 @@ +{ + "name": "is-stream", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/is-unicode-supported/package.json b/restored-src/node_modules/is-unicode-supported/package.json new file mode 100644 index 000000000..7a22ec0c9 --- /dev/null +++ b/restored-src/node_modules/is-unicode-supported/package.json @@ -0,0 +1,6 @@ +{ + "name": "is-unicode-supported", + "private": true, + "main": "./index.js", + "type": "module" +} diff --git a/restored-src/node_modules/is-wsl/package.json b/restored-src/node_modules/is-wsl/package.json new file mode 100644 index 000000000..a07765ff1 --- /dev/null +++ b/restored-src/node_modules/is-wsl/package.json @@ -0,0 +1,6 @@ +{ + "name": "is-wsl", + "private": true, + "main": "./index.js", + "type": "module" +} diff --git a/restored-src/node_modules/isexe/package.json b/restored-src/node_modules/isexe/package.json new file mode 100644 index 000000000..efbac8516 --- /dev/null +++ b/restored-src/node_modules/isexe/package.json @@ -0,0 +1,6 @@ +{ + "name": "isexe", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/json-bigint/package.json b/restored-src/node_modules/json-bigint/package.json new file mode 100644 index 000000000..8af8d02bc --- /dev/null +++ b/restored-src/node_modules/json-bigint/package.json @@ -0,0 +1,6 @@ +{ + "name": "json-bigint", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/json-schema-traverse/package.json b/restored-src/node_modules/json-schema-traverse/package.json new file mode 100644 index 000000000..f72aa6641 --- /dev/null +++ b/restored-src/node_modules/json-schema-traverse/package.json @@ -0,0 +1,6 @@ +{ + "name": "json-schema-traverse", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/jsonc-parser/package.json b/restored-src/node_modules/jsonc-parser/package.json new file mode 100644 index 000000000..d6dbc53c7 --- /dev/null +++ b/restored-src/node_modules/jsonc-parser/package.json @@ -0,0 +1,6 @@ +{ + "name": "jsonc-parser", + "private": true, + "main": "./lib/esm/main.js", + "type": "module" +} diff --git a/restored-src/node_modules/jsonfile/package.json b/restored-src/node_modules/jsonfile/package.json new file mode 100644 index 000000000..3ac235751 --- /dev/null +++ b/restored-src/node_modules/jsonfile/package.json @@ -0,0 +1,6 @@ +{ + "name": "jsonfile", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/jsonwebtoken/package.json b/restored-src/node_modules/jsonwebtoken/package.json new file mode 100644 index 000000000..070ed337a --- /dev/null +++ b/restored-src/node_modules/jsonwebtoken/package.json @@ -0,0 +1,6 @@ +{ + "name": "jsonwebtoken", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/jwa/package.json b/restored-src/node_modules/jwa/package.json new file mode 100644 index 000000000..b22dcf2fb --- /dev/null +++ b/restored-src/node_modules/jwa/package.json @@ -0,0 +1,6 @@ +{ + "name": "jwa", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/jws/package.json b/restored-src/node_modules/jws/package.json new file mode 100644 index 000000000..9b39ea53d --- /dev/null +++ b/restored-src/node_modules/jws/package.json @@ -0,0 +1,6 @@ +{ + "name": "jws", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/lodash-es/lodash.js b/restored-src/node_modules/lodash-es/lodash.js index 25b790ec1..95b590723 100644 --- a/restored-src/node_modules/lodash-es/lodash.js +++ b/restored-src/node_modules/lodash-es/lodash.js @@ -1,331 +1,11 @@ -/** - * @license - * Lodash (Custom Build) - * Build: `lodash modularize exports="es" -o ./` - * Copyright OpenJS Foundation and other contributors - * Released under MIT license - * Based on Underscore.js 1.8.3 - * Copyright Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors - */ -export { default as add } from './add.js'; -export { default as after } from './after.js'; -export { default as ary } from './ary.js'; -export { default as assign } from './assign.js'; -export { default as assignIn } from './assignIn.js'; -export { default as assignInWith } from './assignInWith.js'; -export { default as assignWith } from './assignWith.js'; -export { default as at } from './at.js'; -export { default as attempt } from './attempt.js'; -export { default as before } from './before.js'; -export { default as bind } from './bind.js'; -export { default as bindAll } from './bindAll.js'; -export { default as bindKey } from './bindKey.js'; -export { default as camelCase } from './camelCase.js'; -export { default as capitalize } from './capitalize.js'; -export { default as castArray } from './castArray.js'; -export { default as ceil } from './ceil.js'; -export { default as chain } from './chain.js'; -export { default as chunk } from './chunk.js'; -export { default as clamp } from './clamp.js'; -export { default as clone } from './clone.js'; -export { default as cloneDeep } from './cloneDeep.js'; -export { default as cloneDeepWith } from './cloneDeepWith.js'; -export { default as cloneWith } from './cloneWith.js'; -export { default as commit } from './commit.js'; -export { default as compact } from './compact.js'; -export { default as concat } from './concat.js'; -export { default as cond } from './cond.js'; -export { default as conforms } from './conforms.js'; -export { default as conformsTo } from './conformsTo.js'; -export { default as constant } from './constant.js'; -export { default as countBy } from './countBy.js'; -export { default as create } from './create.js'; -export { default as curry } from './curry.js'; -export { default as curryRight } from './curryRight.js'; -export { default as debounce } from './debounce.js'; -export { default as deburr } from './deburr.js'; -export { default as defaultTo } from './defaultTo.js'; -export { default as defaults } from './defaults.js'; -export { default as defaultsDeep } from './defaultsDeep.js'; -export { default as defer } from './defer.js'; -export { default as delay } from './delay.js'; -export { default as difference } from './difference.js'; -export { default as differenceBy } from './differenceBy.js'; -export { default as differenceWith } from './differenceWith.js'; -export { default as divide } from './divide.js'; -export { default as drop } from './drop.js'; -export { default as dropRight } from './dropRight.js'; -export { default as dropRightWhile } from './dropRightWhile.js'; -export { default as dropWhile } from './dropWhile.js'; -export { default as each } from './each.js'; -export { default as eachRight } from './eachRight.js'; -export { default as endsWith } from './endsWith.js'; -export { default as entries } from './entries.js'; -export { default as entriesIn } from './entriesIn.js'; -export { default as eq } from './eq.js'; -export { default as escape } from './escape.js'; -export { default as escapeRegExp } from './escapeRegExp.js'; -export { default as every } from './every.js'; -export { default as extend } from './extend.js'; -export { default as extendWith } from './extendWith.js'; -export { default as fill } from './fill.js'; -export { default as filter } from './filter.js'; -export { default as find } from './find.js'; -export { default as findIndex } from './findIndex.js'; -export { default as findKey } from './findKey.js'; -export { default as findLast } from './findLast.js'; -export { default as findLastIndex } from './findLastIndex.js'; -export { default as findLastKey } from './findLastKey.js'; -export { default as first } from './first.js'; -export { default as flatMap } from './flatMap.js'; -export { default as flatMapDeep } from './flatMapDeep.js'; -export { default as flatMapDepth } from './flatMapDepth.js'; -export { default as flatten } from './flatten.js'; -export { default as flattenDeep } from './flattenDeep.js'; -export { default as flattenDepth } from './flattenDepth.js'; -export { default as flip } from './flip.js'; -export { default as floor } from './floor.js'; -export { default as flow } from './flow.js'; -export { default as flowRight } from './flowRight.js'; -export { default as forEach } from './forEach.js'; -export { default as forEachRight } from './forEachRight.js'; -export { default as forIn } from './forIn.js'; -export { default as forInRight } from './forInRight.js'; -export { default as forOwn } from './forOwn.js'; -export { default as forOwnRight } from './forOwnRight.js'; -export { default as fromPairs } from './fromPairs.js'; -export { default as functions } from './functions.js'; -export { default as functionsIn } from './functionsIn.js'; -export { default as get } from './get.js'; -export { default as groupBy } from './groupBy.js'; -export { default as gt } from './gt.js'; -export { default as gte } from './gte.js'; -export { default as has } from './has.js'; -export { default as hasIn } from './hasIn.js'; -export { default as head } from './head.js'; -export { default as identity } from './identity.js'; -export { default as inRange } from './inRange.js'; -export { default as includes } from './includes.js'; -export { default as indexOf } from './indexOf.js'; -export { default as initial } from './initial.js'; -export { default as intersection } from './intersection.js'; -export { default as intersectionBy } from './intersectionBy.js'; -export { default as intersectionWith } from './intersectionWith.js'; -export { default as invert } from './invert.js'; -export { default as invertBy } from './invertBy.js'; -export { default as invoke } from './invoke.js'; -export { default as invokeMap } from './invokeMap.js'; -export { default as isArguments } from './isArguments.js'; -export { default as isArray } from './isArray.js'; -export { default as isArrayBuffer } from './isArrayBuffer.js'; -export { default as isArrayLike } from './isArrayLike.js'; -export { default as isArrayLikeObject } from './isArrayLikeObject.js'; -export { default as isBoolean } from './isBoolean.js'; -export { default as isBuffer } from './isBuffer.js'; -export { default as isDate } from './isDate.js'; -export { default as isElement } from './isElement.js'; -export { default as isEmpty } from './isEmpty.js'; -export { default as isEqual } from './isEqual.js'; -export { default as isEqualWith } from './isEqualWith.js'; -export { default as isError } from './isError.js'; -export { default as isFinite } from './isFinite.js'; -export { default as isFunction } from './isFunction.js'; -export { default as isInteger } from './isInteger.js'; -export { default as isLength } from './isLength.js'; -export { default as isMap } from './isMap.js'; -export { default as isMatch } from './isMatch.js'; -export { default as isMatchWith } from './isMatchWith.js'; -export { default as isNaN } from './isNaN.js'; -export { default as isNative } from './isNative.js'; -export { default as isNil } from './isNil.js'; -export { default as isNull } from './isNull.js'; -export { default as isNumber } from './isNumber.js'; -export { default as isObject } from './isObject.js'; -export { default as isObjectLike } from './isObjectLike.js'; -export { default as isPlainObject } from './isPlainObject.js'; -export { default as isRegExp } from './isRegExp.js'; -export { default as isSafeInteger } from './isSafeInteger.js'; -export { default as isSet } from './isSet.js'; -export { default as isString } from './isString.js'; -export { default as isSymbol } from './isSymbol.js'; -export { default as isTypedArray } from './isTypedArray.js'; -export { default as isUndefined } from './isUndefined.js'; -export { default as isWeakMap } from './isWeakMap.js'; -export { default as isWeakSet } from './isWeakSet.js'; -export { default as iteratee } from './iteratee.js'; -export { default as join } from './join.js'; -export { default as kebabCase } from './kebabCase.js'; -export { default as keyBy } from './keyBy.js'; -export { default as keys } from './keys.js'; -export { default as keysIn } from './keysIn.js'; -export { default as last } from './last.js'; -export { default as lastIndexOf } from './lastIndexOf.js'; -export { default as lodash } from './wrapperLodash.js'; -export { default as lowerCase } from './lowerCase.js'; -export { default as lowerFirst } from './lowerFirst.js'; -export { default as lt } from './lt.js'; -export { default as lte } from './lte.js'; -export { default as map } from './map.js'; -export { default as mapKeys } from './mapKeys.js'; -export { default as mapValues } from './mapValues.js'; -export { default as matches } from './matches.js'; -export { default as matchesProperty } from './matchesProperty.js'; -export { default as max } from './max.js'; -export { default as maxBy } from './maxBy.js'; -export { default as mean } from './mean.js'; -export { default as meanBy } from './meanBy.js'; -export { default as memoize } from './memoize.js'; -export { default as merge } from './merge.js'; -export { default as mergeWith } from './mergeWith.js'; -export { default as method } from './method.js'; -export { default as methodOf } from './methodOf.js'; -export { default as min } from './min.js'; -export { default as minBy } from './minBy.js'; -export { default as mixin } from './mixin.js'; -export { default as multiply } from './multiply.js'; -export { default as negate } from './negate.js'; -export { default as next } from './next.js'; -export { default as noop } from './noop.js'; -export { default as now } from './now.js'; -export { default as nth } from './nth.js'; -export { default as nthArg } from './nthArg.js'; -export { default as omit } from './omit.js'; -export { default as omitBy } from './omitBy.js'; -export { default as once } from './once.js'; -export { default as orderBy } from './orderBy.js'; -export { default as over } from './over.js'; -export { default as overArgs } from './overArgs.js'; -export { default as overEvery } from './overEvery.js'; -export { default as overSome } from './overSome.js'; -export { default as pad } from './pad.js'; -export { default as padEnd } from './padEnd.js'; -export { default as padStart } from './padStart.js'; -export { default as parseInt } from './parseInt.js'; -export { default as partial } from './partial.js'; -export { default as partialRight } from './partialRight.js'; -export { default as partition } from './partition.js'; -export { default as pick } from './pick.js'; -export { default as pickBy } from './pickBy.js'; -export { default as plant } from './plant.js'; -export { default as property } from './property.js'; -export { default as propertyOf } from './propertyOf.js'; -export { default as pull } from './pull.js'; -export { default as pullAll } from './pullAll.js'; -export { default as pullAllBy } from './pullAllBy.js'; -export { default as pullAllWith } from './pullAllWith.js'; -export { default as pullAt } from './pullAt.js'; -export { default as random } from './random.js'; -export { default as range } from './range.js'; -export { default as rangeRight } from './rangeRight.js'; -export { default as rearg } from './rearg.js'; -export { default as reduce } from './reduce.js'; -export { default as reduceRight } from './reduceRight.js'; -export { default as reject } from './reject.js'; -export { default as remove } from './remove.js'; -export { default as repeat } from './repeat.js'; -export { default as replace } from './replace.js'; -export { default as rest } from './rest.js'; -export { default as result } from './result.js'; -export { default as reverse } from './reverse.js'; -export { default as round } from './round.js'; -export { default as sample } from './sample.js'; -export { default as sampleSize } from './sampleSize.js'; -export { default as set } from './set.js'; -export { default as setWith } from './setWith.js'; -export { default as shuffle } from './shuffle.js'; -export { default as size } from './size.js'; -export { default as slice } from './slice.js'; -export { default as snakeCase } from './snakeCase.js'; -export { default as some } from './some.js'; -export { default as sortBy } from './sortBy.js'; -export { default as sortedIndex } from './sortedIndex.js'; -export { default as sortedIndexBy } from './sortedIndexBy.js'; -export { default as sortedIndexOf } from './sortedIndexOf.js'; -export { default as sortedLastIndex } from './sortedLastIndex.js'; -export { default as sortedLastIndexBy } from './sortedLastIndexBy.js'; -export { default as sortedLastIndexOf } from './sortedLastIndexOf.js'; -export { default as sortedUniq } from './sortedUniq.js'; -export { default as sortedUniqBy } from './sortedUniqBy.js'; -export { default as split } from './split.js'; -export { default as spread } from './spread.js'; -export { default as startCase } from './startCase.js'; -export { default as startsWith } from './startsWith.js'; -export { default as stubArray } from './stubArray.js'; -export { default as stubFalse } from './stubFalse.js'; -export { default as stubObject } from './stubObject.js'; -export { default as stubString } from './stubString.js'; -export { default as stubTrue } from './stubTrue.js'; -export { default as subtract } from './subtract.js'; -export { default as sum } from './sum.js'; -export { default as sumBy } from './sumBy.js'; -export { default as tail } from './tail.js'; -export { default as take } from './take.js'; -export { default as takeRight } from './takeRight.js'; -export { default as takeRightWhile } from './takeRightWhile.js'; -export { default as takeWhile } from './takeWhile.js'; -export { default as tap } from './tap.js'; -export { default as template } from './template.js'; -export { default as templateSettings } from './templateSettings.js'; -export { default as throttle } from './throttle.js'; -export { default as thru } from './thru.js'; -export { default as times } from './times.js'; -export { default as toArray } from './toArray.js'; -export { default as toFinite } from './toFinite.js'; -export { default as toInteger } from './toInteger.js'; -export { default as toIterator } from './toIterator.js'; -export { default as toJSON } from './toJSON.js'; -export { default as toLength } from './toLength.js'; -export { default as toLower } from './toLower.js'; -export { default as toNumber } from './toNumber.js'; -export { default as toPairs } from './toPairs.js'; -export { default as toPairsIn } from './toPairsIn.js'; -export { default as toPath } from './toPath.js'; -export { default as toPlainObject } from './toPlainObject.js'; -export { default as toSafeInteger } from './toSafeInteger.js'; -export { default as toString } from './toString.js'; -export { default as toUpper } from './toUpper.js'; -export { default as transform } from './transform.js'; -export { default as trim } from './trim.js'; -export { default as trimEnd } from './trimEnd.js'; -export { default as trimStart } from './trimStart.js'; -export { default as truncate } from './truncate.js'; -export { default as unary } from './unary.js'; -export { default as unescape } from './unescape.js'; -export { default as union } from './union.js'; -export { default as unionBy } from './unionBy.js'; -export { default as unionWith } from './unionWith.js'; -export { default as uniq } from './uniq.js'; -export { default as uniqBy } from './uniqBy.js'; -export { default as uniqWith } from './uniqWith.js'; -export { default as uniqueId } from './uniqueId.js'; -export { default as unset } from './unset.js'; -export { default as unzip } from './unzip.js'; -export { default as unzipWith } from './unzipWith.js'; -export { default as update } from './update.js'; -export { default as updateWith } from './updateWith.js'; -export { default as upperCase } from './upperCase.js'; -export { default as upperFirst } from './upperFirst.js'; -export { default as value } from './value.js'; -export { default as valueOf } from './valueOf.js'; -export { default as values } from './values.js'; -export { default as valuesIn } from './valuesIn.js'; -export { default as without } from './without.js'; -export { default as words } from './words.js'; -export { default as wrap } from './wrap.js'; -export { default as wrapperAt } from './wrapperAt.js'; -export { default as wrapperChain } from './wrapperChain.js'; -export { default as wrapperCommit } from './commit.js'; -export { default as wrapperLodash } from './wrapperLodash.js'; -export { default as wrapperNext } from './next.js'; -export { default as wrapperPlant } from './plant.js'; -export { default as wrapperReverse } from './wrapperReverse.js'; -export { default as wrapperToIterator } from './toIterator.js'; -export { default as wrapperValue } from './wrapperValue.js'; -export { default as xor } from './xor.js'; -export { default as xorBy } from './xorBy.js'; -export { default as xorWith } from './xorWith.js'; -export { default as zip } from './zip.js'; -export { default as zipObject } from './zipObject.js'; -export { default as zipObjectDeep } from './zipObjectDeep.js'; -export { default as zipWith } from './zipWith.js'; -export { default } from './lodash.default.js'; +import cloneDeep from './cloneDeep.js' +import isEqual from './isEqual.js' +import memoize from './memoize.js' + +export { cloneDeep, isEqual, memoize } + +export default { + cloneDeep, + isEqual, + memoize, +} diff --git a/restored-src/node_modules/lodash-es/package.json b/restored-src/node_modules/lodash-es/package.json new file mode 100644 index 000000000..7cd911253 --- /dev/null +++ b/restored-src/node_modules/lodash-es/package.json @@ -0,0 +1,6 @@ +{ + "name": "lodash-es", + "private": true, + "main": "./lodash.js", + "type": "module" +} diff --git a/restored-src/node_modules/lodash.camelcase/package.json b/restored-src/node_modules/lodash.camelcase/package.json new file mode 100644 index 000000000..703f8c59d --- /dev/null +++ b/restored-src/node_modules/lodash.camelcase/package.json @@ -0,0 +1,6 @@ +{ + "name": "lodash.camelcase", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/lodash.debounce/package.json b/restored-src/node_modules/lodash.debounce/package.json new file mode 100644 index 000000000..6058ed6e2 --- /dev/null +++ b/restored-src/node_modules/lodash.debounce/package.json @@ -0,0 +1,6 @@ +{ + "name": "lodash.debounce", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/lodash.includes/package.json b/restored-src/node_modules/lodash.includes/package.json new file mode 100644 index 000000000..8c4dea3a0 --- /dev/null +++ b/restored-src/node_modules/lodash.includes/package.json @@ -0,0 +1,6 @@ +{ + "name": "lodash.includes", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/lodash.isboolean/package.json b/restored-src/node_modules/lodash.isboolean/package.json new file mode 100644 index 000000000..5c4ecb7aa --- /dev/null +++ b/restored-src/node_modules/lodash.isboolean/package.json @@ -0,0 +1,6 @@ +{ + "name": "lodash.isboolean", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/lodash.isinteger/package.json b/restored-src/node_modules/lodash.isinteger/package.json new file mode 100644 index 000000000..1b3cc9cc3 --- /dev/null +++ b/restored-src/node_modules/lodash.isinteger/package.json @@ -0,0 +1,6 @@ +{ + "name": "lodash.isinteger", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/lodash.isnumber/package.json b/restored-src/node_modules/lodash.isnumber/package.json new file mode 100644 index 000000000..33e44da4a --- /dev/null +++ b/restored-src/node_modules/lodash.isnumber/package.json @@ -0,0 +1,6 @@ +{ + "name": "lodash.isnumber", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/lodash.isplainobject/package.json b/restored-src/node_modules/lodash.isplainobject/package.json new file mode 100644 index 000000000..ae0aff844 --- /dev/null +++ b/restored-src/node_modules/lodash.isplainobject/package.json @@ -0,0 +1,6 @@ +{ + "name": "lodash.isplainobject", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/lodash.isstring/package.json b/restored-src/node_modules/lodash.isstring/package.json new file mode 100644 index 000000000..67e9e7397 --- /dev/null +++ b/restored-src/node_modules/lodash.isstring/package.json @@ -0,0 +1,6 @@ +{ + "name": "lodash.isstring", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/lodash.once/package.json b/restored-src/node_modules/lodash.once/package.json new file mode 100644 index 000000000..6ac09fcde --- /dev/null +++ b/restored-src/node_modules/lodash.once/package.json @@ -0,0 +1,6 @@ +{ + "name": "lodash.once", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/long/package.json b/restored-src/node_modules/long/package.json new file mode 100644 index 000000000..21cb159fc --- /dev/null +++ b/restored-src/node_modules/long/package.json @@ -0,0 +1,6 @@ +{ + "name": "long", + "private": true, + "main": "./umd/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/lru-cache/package.json b/restored-src/node_modules/lru-cache/package.json new file mode 100644 index 000000000..11f59291b --- /dev/null +++ b/restored-src/node_modules/lru-cache/package.json @@ -0,0 +1,6 @@ +{ + "name": "lru-cache", + "private": true, + "main": "./dist/esm/index.js", + "type": "module" +} diff --git a/restored-src/node_modules/marked/package.json b/restored-src/node_modules/marked/package.json new file mode 100644 index 000000000..f4d96724a --- /dev/null +++ b/restored-src/node_modules/marked/package.json @@ -0,0 +1,6 @@ +{ + "name": "marked", + "private": true, + "main": "./lib/marked.esm.js", + "type": "module" +} diff --git a/restored-src/node_modules/math-intrinsics/package.json b/restored-src/node_modules/math-intrinsics/package.json new file mode 100644 index 000000000..4501d8143 --- /dev/null +++ b/restored-src/node_modules/math-intrinsics/package.json @@ -0,0 +1,6 @@ +{ + "name": "math-intrinsics", + "private": true, + "main": "./abs.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/merge-stream/package.json b/restored-src/node_modules/merge-stream/package.json new file mode 100644 index 000000000..329fdb0e7 --- /dev/null +++ b/restored-src/node_modules/merge-stream/package.json @@ -0,0 +1,6 @@ +{ + "name": "merge-stream", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/mime-types/package.json b/restored-src/node_modules/mime-types/package.json new file mode 100644 index 000000000..28d3e25d9 --- /dev/null +++ b/restored-src/node_modules/mime-types/package.json @@ -0,0 +1,6 @@ +{ + "name": "mime-types", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/mimic-fn/package.json b/restored-src/node_modules/mimic-fn/package.json new file mode 100644 index 000000000..37c4f6803 --- /dev/null +++ b/restored-src/node_modules/mimic-fn/package.json @@ -0,0 +1,6 @@ +{ + "name": "mimic-fn", + "private": true, + "main": "./index.js", + "type": "module" +} diff --git a/restored-src/node_modules/ms/package.json b/restored-src/node_modules/ms/package.json new file mode 100644 index 000000000..ee0e1b0e9 --- /dev/null +++ b/restored-src/node_modules/ms/package.json @@ -0,0 +1,6 @@ +{ + "name": "ms", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/mute-stream/package.json b/restored-src/node_modules/mute-stream/package.json new file mode 100644 index 000000000..80bda849e --- /dev/null +++ b/restored-src/node_modules/mute-stream/package.json @@ -0,0 +1,6 @@ +{ + "name": "mute-stream", + "private": true, + "main": "./lib/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/node-fetch/package.json b/restored-src/node_modules/node-fetch/package.json new file mode 100644 index 000000000..96a49ca9c --- /dev/null +++ b/restored-src/node_modules/node-fetch/package.json @@ -0,0 +1,6 @@ +{ + "name": "node-fetch", + "private": true, + "main": "./lib/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/node-forge/package.json b/restored-src/node_modules/node-forge/package.json new file mode 100644 index 000000000..5599a5b04 --- /dev/null +++ b/restored-src/node_modules/node-forge/package.json @@ -0,0 +1,6 @@ +{ + "name": "node-forge", + "private": true, + "main": "./lib/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/npm-run-path/package.json b/restored-src/node_modules/npm-run-path/package.json new file mode 100644 index 000000000..1e156c895 --- /dev/null +++ b/restored-src/node_modules/npm-run-path/package.json @@ -0,0 +1,6 @@ +{ + "name": "npm-run-path", + "private": true, + "main": "./index.js", + "type": "module" +} diff --git a/restored-src/node_modules/onetime/package.json b/restored-src/node_modules/onetime/package.json new file mode 100644 index 000000000..da726d7d4 --- /dev/null +++ b/restored-src/node_modules/onetime/package.json @@ -0,0 +1,6 @@ +{ + "name": "onetime", + "private": true, + "main": "./index.js", + "type": "module" +} diff --git a/restored-src/node_modules/open/package.json b/restored-src/node_modules/open/package.json new file mode 100644 index 000000000..5fbc03d2a --- /dev/null +++ b/restored-src/node_modules/open/package.json @@ -0,0 +1,6 @@ +{ + "name": "open", + "private": true, + "main": "./index.js", + "type": "module" +} diff --git a/restored-src/node_modules/p-map/package.json b/restored-src/node_modules/p-map/package.json new file mode 100644 index 000000000..4562f26aa --- /dev/null +++ b/restored-src/node_modules/p-map/package.json @@ -0,0 +1,6 @@ +{ + "name": "p-map", + "private": true, + "main": "./index.js", + "type": "module" +} diff --git a/restored-src/node_modules/parse5-htmlparser2-tree-adapter/package.json b/restored-src/node_modules/parse5-htmlparser2-tree-adapter/package.json new file mode 100644 index 000000000..0ad04936c --- /dev/null +++ b/restored-src/node_modules/parse5-htmlparser2-tree-adapter/package.json @@ -0,0 +1,6 @@ +{ + "name": "parse5-htmlparser2-tree-adapter", + "private": true, + "main": "./lib/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/parse5/package.json b/restored-src/node_modules/parse5/package.json new file mode 100644 index 000000000..a78874fcf --- /dev/null +++ b/restored-src/node_modules/parse5/package.json @@ -0,0 +1,6 @@ +{ + "name": "parse5", + "private": true, + "main": "./lib/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/path-key/package.json b/restored-src/node_modules/path-key/package.json new file mode 100644 index 000000000..8adb949ec --- /dev/null +++ b/restored-src/node_modules/path-key/package.json @@ -0,0 +1,6 @@ +{ + "name": "path-key", + "private": true, + "main": "./index.js", + "type": "module" +} diff --git a/restored-src/node_modules/picomatch/package.json b/restored-src/node_modules/picomatch/package.json new file mode 100644 index 000000000..b28db561f --- /dev/null +++ b/restored-src/node_modules/picomatch/package.json @@ -0,0 +1,6 @@ +{ + "name": "picomatch", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/pkce-challenge/package.json b/restored-src/node_modules/pkce-challenge/package.json new file mode 100644 index 000000000..a84f08bee --- /dev/null +++ b/restored-src/node_modules/pkce-challenge/package.json @@ -0,0 +1,6 @@ +{ + "name": "pkce-challenge", + "private": true, + "main": "./dist/index.node.js", + "type": "module" +} diff --git a/restored-src/node_modules/plist/package.json b/restored-src/node_modules/plist/package.json new file mode 100644 index 000000000..0b89e063c --- /dev/null +++ b/restored-src/node_modules/plist/package.json @@ -0,0 +1,6 @@ +{ + "name": "plist", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/pngjs/package.json b/restored-src/node_modules/pngjs/package.json new file mode 100644 index 000000000..7453e3e8f --- /dev/null +++ b/restored-src/node_modules/pngjs/package.json @@ -0,0 +1,6 @@ +{ + "name": "pngjs", + "private": true, + "main": "./lib/png.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/pretty-bytes/package.json b/restored-src/node_modules/pretty-bytes/package.json new file mode 100644 index 000000000..5002d055a --- /dev/null +++ b/restored-src/node_modules/pretty-bytes/package.json @@ -0,0 +1,6 @@ +{ + "name": "pretty-bytes", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/proper-lockfile/package.json b/restored-src/node_modules/proper-lockfile/package.json new file mode 100644 index 000000000..73fcd9397 --- /dev/null +++ b/restored-src/node_modules/proper-lockfile/package.json @@ -0,0 +1,6 @@ +{ + "name": "proper-lockfile", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/protobufjs/package.json b/restored-src/node_modules/protobufjs/package.json new file mode 100644 index 000000000..9aeb17315 --- /dev/null +++ b/restored-src/node_modules/protobufjs/package.json @@ -0,0 +1,6 @@ +{ + "name": "protobufjs", + "private": true, + "main": "./src/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/proxy-from-env/package.json b/restored-src/node_modules/proxy-from-env/package.json new file mode 100644 index 000000000..ffdc3269a --- /dev/null +++ b/restored-src/node_modules/proxy-from-env/package.json @@ -0,0 +1,6 @@ +{ + "name": "proxy-from-env", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/punycode/package.json b/restored-src/node_modules/punycode/package.json new file mode 100644 index 000000000..89327dc2e --- /dev/null +++ b/restored-src/node_modules/punycode/package.json @@ -0,0 +1,6 @@ +{ + "name": "punycode", + "private": true, + "main": "./punycode.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/qrcode/package.json b/restored-src/node_modules/qrcode/package.json new file mode 100644 index 000000000..643158371 --- /dev/null +++ b/restored-src/node_modules/qrcode/package.json @@ -0,0 +1,6 @@ +{ + "name": "qrcode", + "private": true, + "main": "./lib/core/qrcode.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/react-reconciler/constants.js b/restored-src/node_modules/react-reconciler/constants.js new file mode 100644 index 000000000..3af820fdc --- /dev/null +++ b/restored-src/node_modules/react-reconciler/constants.js @@ -0,0 +1,3 @@ +"use strict"; + +module.exports = require("./cjs/react-reconciler-constants.production.js"); diff --git a/restored-src/node_modules/react-reconciler/package.json b/restored-src/node_modules/react-reconciler/package.json new file mode 100644 index 000000000..5630dbfc7 --- /dev/null +++ b/restored-src/node_modules/react-reconciler/package.json @@ -0,0 +1,6 @@ +{ + "name": "react-reconciler", + "private": true, + "main": "./cjs/react-reconciler.production.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/react/compiler-runtime.js b/restored-src/node_modules/react/compiler-runtime.js new file mode 100644 index 000000000..38f1426ef --- /dev/null +++ b/restored-src/node_modules/react/compiler-runtime.js @@ -0,0 +1,3 @@ +"use strict"; + +module.exports = require("./cjs/react-compiler-runtime.production.js"); diff --git a/restored-src/node_modules/react/jsx-dev-runtime.js b/restored-src/node_modules/react/jsx-dev-runtime.js new file mode 100644 index 000000000..f3435ec9f --- /dev/null +++ b/restored-src/node_modules/react/jsx-dev-runtime.js @@ -0,0 +1,10 @@ +"use strict"; + +const jsxRuntime = require("./jsx-runtime.js"); + +function jsxDEV(type, props, key) { + return jsxRuntime.jsx(type, props, key); +} + +exports.Fragment = jsxRuntime.Fragment; +exports.jsxDEV = jsxDEV; diff --git a/restored-src/node_modules/react/jsx-runtime.js b/restored-src/node_modules/react/jsx-runtime.js new file mode 100644 index 000000000..4b39fce94 --- /dev/null +++ b/restored-src/node_modules/react/jsx-runtime.js @@ -0,0 +1,15 @@ +"use strict"; + +const React = require("./cjs/react.production.js"); + +function jsx(type, props, key) { + if (key === undefined) { + return React.createElement(type, props); + } + + return React.createElement(type, { ...props, key }); +} + +exports.Fragment = React.Fragment; +exports.jsx = jsx; +exports.jsxs = jsx; diff --git a/restored-src/node_modules/react/package.json b/restored-src/node_modules/react/package.json new file mode 100644 index 000000000..3f8e64ea6 --- /dev/null +++ b/restored-src/node_modules/react/package.json @@ -0,0 +1,6 @@ +{ + "name": "react", + "private": true, + "main": "./cjs/react.production.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/readdirp/package.json b/restored-src/node_modules/readdirp/package.json new file mode 100644 index 000000000..b23e47b1d --- /dev/null +++ b/restored-src/node_modules/readdirp/package.json @@ -0,0 +1,6 @@ +{ + "name": "readdirp", + "private": true, + "main": "./esm/index.js", + "type": "module" +} diff --git a/restored-src/node_modules/retry/package.json b/restored-src/node_modules/retry/package.json new file mode 100644 index 000000000..9bbeefcb4 --- /dev/null +++ b/restored-src/node_modules/retry/package.json @@ -0,0 +1,6 @@ +{ + "name": "retry", + "private": true, + "main": "./lib/retry.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/run-applescript/package.json b/restored-src/node_modules/run-applescript/package.json new file mode 100644 index 000000000..d03f37a96 --- /dev/null +++ b/restored-src/node_modules/run-applescript/package.json @@ -0,0 +1,6 @@ +{ + "name": "run-applescript", + "private": true, + "main": "./index.js", + "type": "module" +} diff --git a/restored-src/node_modules/safe-buffer/package.json b/restored-src/node_modules/safe-buffer/package.json new file mode 100644 index 000000000..4b83608e5 --- /dev/null +++ b/restored-src/node_modules/safe-buffer/package.json @@ -0,0 +1,6 @@ +{ + "name": "safe-buffer", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/scheduler/package.json b/restored-src/node_modules/scheduler/package.json new file mode 100644 index 000000000..4aab9b035 --- /dev/null +++ b/restored-src/node_modules/scheduler/package.json @@ -0,0 +1,6 @@ +{ + "name": "scheduler", + "private": true, + "main": "./cjs/scheduler.production.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/semver/package.json b/restored-src/node_modules/semver/package.json new file mode 100644 index 000000000..d4f1d7798 --- /dev/null +++ b/restored-src/node_modules/semver/package.json @@ -0,0 +1,6 @@ +{ + "name": "semver", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/sharp/package.json b/restored-src/node_modules/sharp/package.json new file mode 100644 index 000000000..f9ecfc87c --- /dev/null +++ b/restored-src/node_modules/sharp/package.json @@ -0,0 +1,6 @@ +{ + "name": "sharp", + "private": true, + "main": "./lib/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/shebang-command/package.json b/restored-src/node_modules/shebang-command/package.json new file mode 100644 index 000000000..9583cbb72 --- /dev/null +++ b/restored-src/node_modules/shebang-command/package.json @@ -0,0 +1,6 @@ +{ + "name": "shebang-command", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/shebang-regex/package.json b/restored-src/node_modules/shebang-regex/package.json new file mode 100644 index 000000000..e553f1f28 --- /dev/null +++ b/restored-src/node_modules/shebang-regex/package.json @@ -0,0 +1,6 @@ +{ + "name": "shebang-regex", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/shell-quote/package.json b/restored-src/node_modules/shell-quote/package.json new file mode 100644 index 000000000..6c260fe91 --- /dev/null +++ b/restored-src/node_modules/shell-quote/package.json @@ -0,0 +1,6 @@ +{ + "name": "shell-quote", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/signal-exit/index.js b/restored-src/node_modules/signal-exit/index.js index 93703f369..ccc8d3b88 100644 --- a/restored-src/node_modules/signal-exit/index.js +++ b/restored-src/node_modules/signal-exit/index.js @@ -78,6 +78,7 @@ if (!processOk(process)) { return remove } + module.exports.onExit = module.exports var unload = function unload () { if (!loaded || !processOk(global.process)) { diff --git a/restored-src/node_modules/signal-exit/package.json b/restored-src/node_modules/signal-exit/package.json new file mode 100644 index 000000000..4b993243f --- /dev/null +++ b/restored-src/node_modules/signal-exit/package.json @@ -0,0 +1,6 @@ +{ + "name": "signal-exit", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/stack-utils/package.json b/restored-src/node_modules/stack-utils/package.json new file mode 100644 index 000000000..77b8f0727 --- /dev/null +++ b/restored-src/node_modules/stack-utils/package.json @@ -0,0 +1,6 @@ +{ + "name": "stack-utils", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/string-width/package.json b/restored-src/node_modules/string-width/package.json new file mode 100644 index 000000000..8a9014044 --- /dev/null +++ b/restored-src/node_modules/string-width/package.json @@ -0,0 +1,6 @@ +{ + "name": "string-width", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/strip-ansi/package.json b/restored-src/node_modules/strip-ansi/package.json new file mode 100644 index 000000000..a98ca699c --- /dev/null +++ b/restored-src/node_modules/strip-ansi/package.json @@ -0,0 +1,6 @@ +{ + "name": "strip-ansi", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/strip-final-newline/package.json b/restored-src/node_modules/strip-final-newline/package.json new file mode 100644 index 000000000..4f4dc3af2 --- /dev/null +++ b/restored-src/node_modules/strip-final-newline/package.json @@ -0,0 +1,6 @@ +{ + "name": "strip-final-newline", + "private": true, + "main": "./index.js", + "type": "module" +} diff --git a/restored-src/node_modules/supports-color/package.json b/restored-src/node_modules/supports-color/package.json new file mode 100644 index 000000000..e70b4c32b --- /dev/null +++ b/restored-src/node_modules/supports-color/package.json @@ -0,0 +1,6 @@ +{ + "name": "supports-color", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/supports-hyperlinks/package.json b/restored-src/node_modules/supports-hyperlinks/package.json new file mode 100644 index 000000000..8407158ba --- /dev/null +++ b/restored-src/node_modules/supports-hyperlinks/package.json @@ -0,0 +1,6 @@ +{ + "name": "supports-hyperlinks", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/tr46/package.json b/restored-src/node_modules/tr46/package.json new file mode 100644 index 000000000..c3cdcde30 --- /dev/null +++ b/restored-src/node_modules/tr46/package.json @@ -0,0 +1,6 @@ +{ + "name": "tr46", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/tree-kill/package.json b/restored-src/node_modules/tree-kill/package.json new file mode 100644 index 000000000..161d6468e --- /dev/null +++ b/restored-src/node_modules/tree-kill/package.json @@ -0,0 +1,6 @@ +{ + "name": "tree-kill", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/tslib/package.json b/restored-src/node_modules/tslib/package.json new file mode 100644 index 000000000..99f34db0b --- /dev/null +++ b/restored-src/node_modules/tslib/package.json @@ -0,0 +1,6 @@ +{ + "name": "tslib", + "private": true, + "main": "./tslib.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/turndown/package.json b/restored-src/node_modules/turndown/package.json new file mode 100644 index 000000000..14e9cd422 --- /dev/null +++ b/restored-src/node_modules/turndown/package.json @@ -0,0 +1,6 @@ +{ + "name": "turndown", + "private": true, + "main": "./lib/turndown.cjs.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/undici/package.json b/restored-src/node_modules/undici/package.json new file mode 100644 index 000000000..9f13a415d --- /dev/null +++ b/restored-src/node_modules/undici/package.json @@ -0,0 +1,6 @@ +{ + "name": "undici", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/universalify/package.json b/restored-src/node_modules/universalify/package.json new file mode 100644 index 000000000..75cf1f6cd --- /dev/null +++ b/restored-src/node_modules/universalify/package.json @@ -0,0 +1,6 @@ +{ + "name": "universalify", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/usehooks-ts/package.json b/restored-src/node_modules/usehooks-ts/package.json new file mode 100644 index 000000000..5a1b33a49 --- /dev/null +++ b/restored-src/node_modules/usehooks-ts/package.json @@ -0,0 +1,6 @@ +{ + "name": "usehooks-ts", + "private": true, + "main": "./dist/index.js", + "type": "module" +} diff --git a/restored-src/node_modules/uuid/package.json b/restored-src/node_modules/uuid/package.json new file mode 100644 index 000000000..a74d13bbb --- /dev/null +++ b/restored-src/node_modules/uuid/package.json @@ -0,0 +1,6 @@ +{ + "name": "uuid", + "private": true, + "main": "./dist/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/vscode-jsonrpc/package.json b/restored-src/node_modules/vscode-jsonrpc/package.json new file mode 100644 index 000000000..a8ba8056e --- /dev/null +++ b/restored-src/node_modules/vscode-jsonrpc/package.json @@ -0,0 +1,6 @@ +{ + "name": "vscode-jsonrpc", + "private": true, + "main": "./lib/node/main.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/webidl-conversions/package.json b/restored-src/node_modules/webidl-conversions/package.json new file mode 100644 index 000000000..7121ca829 --- /dev/null +++ b/restored-src/node_modules/webidl-conversions/package.json @@ -0,0 +1,6 @@ +{ + "name": "webidl-conversions", + "private": true, + "main": "./lib/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/whatwg-url/package.json b/restored-src/node_modules/whatwg-url/package.json new file mode 100644 index 000000000..8d0ac2e62 --- /dev/null +++ b/restored-src/node_modules/whatwg-url/package.json @@ -0,0 +1,6 @@ +{ + "name": "whatwg-url", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/which/package.json b/restored-src/node_modules/which/package.json new file mode 100644 index 000000000..e40298d3b --- /dev/null +++ b/restored-src/node_modules/which/package.json @@ -0,0 +1,6 @@ +{ + "name": "which", + "private": true, + "main": "./which.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/wrap-ansi/package.json b/restored-src/node_modules/wrap-ansi/package.json new file mode 100644 index 000000000..830551d77 --- /dev/null +++ b/restored-src/node_modules/wrap-ansi/package.json @@ -0,0 +1,6 @@ +{ + "name": "wrap-ansi", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/ws/package.json b/restored-src/node_modules/ws/package.json new file mode 100644 index 000000000..d74a5b441 --- /dev/null +++ b/restored-src/node_modules/ws/package.json @@ -0,0 +1,6 @@ +{ + "name": "ws", + "private": true, + "main": "./wrapper.mjs", + "type": "module" +} diff --git a/restored-src/node_modules/wsl-utils/package.json b/restored-src/node_modules/wsl-utils/package.json new file mode 100644 index 000000000..b4d3ca1fc --- /dev/null +++ b/restored-src/node_modules/wsl-utils/package.json @@ -0,0 +1,6 @@ +{ + "name": "wsl-utils", + "private": true, + "main": "./index.js", + "type": "module" +} diff --git a/restored-src/node_modules/xmlbuilder/package.json b/restored-src/node_modules/xmlbuilder/package.json new file mode 100644 index 000000000..2a03d3837 --- /dev/null +++ b/restored-src/node_modules/xmlbuilder/package.json @@ -0,0 +1,6 @@ +{ + "name": "xmlbuilder", + "private": true, + "main": "./lib/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/xss/package.json b/restored-src/node_modules/xss/package.json new file mode 100644 index 000000000..ce51f9c1f --- /dev/null +++ b/restored-src/node_modules/xss/package.json @@ -0,0 +1,6 @@ +{ + "name": "xss", + "private": true, + "main": "./lib/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/yaml/package.json b/restored-src/node_modules/yaml/package.json new file mode 100644 index 000000000..7e86413c1 --- /dev/null +++ b/restored-src/node_modules/yaml/package.json @@ -0,0 +1,6 @@ +{ + "name": "yaml", + "private": true, + "main": "./dist/index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/yoctocolors-cjs/package.json b/restored-src/node_modules/yoctocolors-cjs/package.json new file mode 100644 index 000000000..988809a0e --- /dev/null +++ b/restored-src/node_modules/yoctocolors-cjs/package.json @@ -0,0 +1,6 @@ +{ + "name": "yoctocolors-cjs", + "private": true, + "main": "./index.js", + "type": "commonjs" +} diff --git a/restored-src/node_modules/zod-to-json-schema/dist/esm/index.js b/restored-src/node_modules/zod-to-json-schema/dist/esm/index.js index cdfb5306e..1643f6278 100644 --- a/restored-src/node_modules/zod-to-json-schema/dist/esm/index.js +++ b/restored-src/node_modules/zod-to-json-schema/dist/esm/index.js @@ -1,40 +1,4 @@ -export * from "./Options.js"; -export * from "./Refs.js"; -export * from "./errorMessages.js"; -export * from "./getRelativePath.js"; -export * from "./parseDef.js"; -export * from "./parseTypes.js"; -export * from "./parsers/any.js"; -export * from "./parsers/array.js"; -export * from "./parsers/bigint.js"; -export * from "./parsers/boolean.js"; -export * from "./parsers/branded.js"; -export * from "./parsers/catch.js"; -export * from "./parsers/date.js"; -export * from "./parsers/default.js"; -export * from "./parsers/effects.js"; -export * from "./parsers/enum.js"; -export * from "./parsers/intersection.js"; -export * from "./parsers/literal.js"; -export * from "./parsers/map.js"; -export * from "./parsers/nativeEnum.js"; -export * from "./parsers/never.js"; -export * from "./parsers/null.js"; -export * from "./parsers/nullable.js"; -export * from "./parsers/number.js"; -export * from "./parsers/object.js"; -export * from "./parsers/optional.js"; -export * from "./parsers/pipeline.js"; -export * from "./parsers/promise.js"; -export * from "./parsers/readonly.js"; -export * from "./parsers/record.js"; -export * from "./parsers/set.js"; -export * from "./parsers/string.js"; -export * from "./parsers/tuple.js"; -export * from "./parsers/undefined.js"; -export * from "./parsers/union.js"; -export * from "./parsers/unknown.js"; -export * from "./selectParser.js"; -export * from "./zodToJsonSchema.js"; -import { zodToJsonSchema } from "./zodToJsonSchema.js"; -export default zodToJsonSchema; +export * from './zodToJsonSchema.js' +import { zodToJsonSchema } from './zodToJsonSchema.js' + +export default zodToJsonSchema diff --git a/restored-src/node_modules/zod-to-json-schema/package.json b/restored-src/node_modules/zod-to-json-schema/package.json new file mode 100644 index 000000000..d30fe1375 --- /dev/null +++ b/restored-src/node_modules/zod-to-json-schema/package.json @@ -0,0 +1,6 @@ +{ + "name": "zod-to-json-schema", + "private": true, + "main": "./dist/esm/index.js", + "type": "module" +} diff --git a/restored-src/node_modules/zod/package.json b/restored-src/node_modules/zod/package.json new file mode 100644 index 000000000..48567f643 --- /dev/null +++ b/restored-src/node_modules/zod/package.json @@ -0,0 +1,6 @@ +{ + "name": "zod", + "private": true, + "main": "./index.js", + "type": "module" +} diff --git a/restored-src/node_modules/zod/v3/helpers/typeAliases.js b/restored-src/node_modules/zod/v3/helpers/typeAliases.js new file mode 100644 index 000000000..cb0ff5c3b --- /dev/null +++ b/restored-src/node_modules/zod/v3/helpers/typeAliases.js @@ -0,0 +1 @@ +export {}; diff --git a/restored-src/node_modules/zod/v3/index.js b/restored-src/node_modules/zod/v3/index.js new file mode 100644 index 000000000..070524f04 --- /dev/null +++ b/restored-src/node_modules/zod/v3/index.js @@ -0,0 +1 @@ +export * from './external.js' diff --git a/restored-src/node_modules/zod/v4-mini/index.js b/restored-src/node_modules/zod/v4-mini/index.js index 87b293a4f..0dcdf5a90 100644 --- a/restored-src/node_modules/zod/v4-mini/index.js +++ b/restored-src/node_modules/zod/v4-mini/index.js @@ -1 +1 @@ -export * from "../v4/mini/index.js"; +export * from '../v4/index.js' diff --git a/restored-src/node_modules/zod/v4/core/json-schema.js b/restored-src/node_modules/zod/v4/core/json-schema.js new file mode 100644 index 000000000..e3806290f --- /dev/null +++ b/restored-src/node_modules/zod/v4/core/json-schema.js @@ -0,0 +1 @@ +export * from './to-json-schema.js' diff --git a/restored-src/node_modules/zod/v4/mini/external.js b/restored-src/node_modules/zod/v4/mini/external.js index d42478c56..19b3108a1 100644 --- a/restored-src/node_modules/zod/v4/mini/external.js +++ b/restored-src/node_modules/zod/v4/mini/external.js @@ -1,13 +1 @@ -export * as core from "../core/index.js"; -export * from "./parse.js"; -export * from "./schemas.js"; -export * from "./checks.js"; -export { globalRegistry, registry, config, $output, $input, $brand, function, clone, regexes, treeifyError, prettifyError, formatError, flattenError, toJSONSchema, TimePrecision, NEVER, } from "../core/index.js"; -export * as locales from "../locales/index.js"; -/** A special constant with type `never` */ -// export const NEVER = {} as never; -// iso -export * as iso from "./iso.js"; -export { ZodMiniISODateTime, ZodMiniISODate, ZodMiniISOTime, ZodMiniISODuration, } from "./iso.js"; -// coerce -export * as coerce from "./coerce.js"; +export * from '../index.js' diff --git a/restored-src/node_modules/zod/v4/mini/index.js b/restored-src/node_modules/zod/v4/mini/index.js index f6c2a2649..19b3108a1 100644 --- a/restored-src/node_modules/zod/v4/mini/index.js +++ b/restored-src/node_modules/zod/v4/mini/index.js @@ -1,3 +1 @@ -import * as z from "./external.js"; -export * from "./external.js"; -export { z }; +export * from '../index.js' diff --git a/restored-src/package.json b/restored-src/package.json new file mode 100644 index 000000000..3cf185fea --- /dev/null +++ b/restored-src/package.json @@ -0,0 +1,11 @@ +{ + "name": "claude-code-restored-src", + "private": true, + "version": "0.1.0", + "type": "module", + "scripts": { + "bootstrap:manifests": "node ./scripts/synthesize-node-module-manifests.cjs", + "version:claude": "bun --preload ./macro-shim.cjs src/entrypoints/cli.tsx -v", + "help": "bun --preload ./macro-shim.cjs src/entrypoints/cli.tsx --help" + } +} diff --git a/restored-src/scripts/synthesize-node-module-manifests.cjs b/restored-src/scripts/synthesize-node-module-manifests.cjs new file mode 100644 index 000000000..137711515 --- /dev/null +++ b/restored-src/scripts/synthesize-node-module-manifests.cjs @@ -0,0 +1,238 @@ +const fs = require("fs"); +const path = require("path"); + +const NODE_MODULES_DIR = path.resolve(__dirname, "..", "node_modules"); + +const ENTRY_CANDIDATES = [ + "index.mjs", + "esm.mjs", + "index.js", + "index.cjs", + "main.js", + "main.mjs", + "wrapper.mjs", + "source/index.mjs", + "source/index.js", + "src/index.mjs", + "src/index.ts", + "src/index.js", + "src/main.js", + "src/main.mjs", + "dist/index.mjs", + "dist/index.js", + "dist/index.cjs", + "dist/main.mjs", + "dist/main.js", + "dist/main.cjs", + "dist-cjs/index.js", + "dist-cjs/index.cjs", + "dist-cjs/main.js", + "dist-cjs/main.cjs", + "lib/index.mjs", + "lib/index.js", + "lib/index.cjs", + "lib/main.mjs", + "lib/main.js", + "lib/main.cjs", + "lib/esm/main.js", + "lib/node/main.js", + "build/index.mjs", + "build/index.js", + "build/index.cjs", + "build/src/main.js", + "cjs/index.js", + "cjs/index.cjs", +]; + +const ENTRY_EXTENSIONS = new Set([".js", ".mjs", ".cjs", ".ts", ".tsx"]); + +function normalizeName(value) { + return value.toLowerCase().replace(/[^a-z0-9]/g, ""); +} + +function listPackages(rootDir) { + const packages = []; + for (const entry of fs.readdirSync(rootDir, { withFileTypes: true })) { + if (!entry.isDirectory()) continue; + if (entry.name.startsWith("@")) { + const scopeDir = path.join(rootDir, entry.name); + for (const scopedEntry of fs.readdirSync(scopeDir, { withFileTypes: true })) { + if (!scopedEntry.isDirectory()) continue; + packages.push({ + name: `${entry.name}/${scopedEntry.name}`, + dir: path.join(scopeDir, scopedEntry.name), + }); + } + continue; + } + packages.push({ + name: entry.name, + dir: path.join(rootDir, entry.name), + }); + } + return packages; +} + +function chooseCandidate(dir, pkgName) { + for (const relPath of ENTRY_CANDIDATES) { + const fullPath = path.join(dir, relPath); + if (fs.existsSync(fullPath) && fs.statSync(fullPath).isFile()) { + return relPath; + } + } + + const baseName = pkgName.split("/").pop(); + const matches = []; + + function walk(currentDir, depth) { + if (depth > 3) return; + for (const entry of fs.readdirSync(currentDir, { withFileTypes: true })) { + const fullPath = path.join(currentDir, entry.name); + const relPath = path.relative(dir, fullPath).replace(/\\/g, "/"); + if (entry.isDirectory()) { + walk(fullPath, depth + 1); + continue; + } + if (!ENTRY_EXTENSIONS.has(path.extname(entry.name))) continue; + matches.push(relPath); + } + } + + walk(dir, 0); + + if (matches.length === 1) { + return matches[0]; + } + + const preferred = matches + .filter((relPath) => { + const fileName = path.basename(relPath); + return ( + fileName === `${baseName}.mjs` || + fileName === `${baseName}.js` || + fileName === `${baseName}.cjs` || + fileName === `${baseName}.ts` || + fileName === `${baseName}.tsx` || + fileName === `${baseName}.production.js` + ); + }) + .sort((a, b) => a.length - b.length); + + if (preferred.length > 0) { + return preferred[0]; + } + + const normalizedVariants = new Set([ + normalizeName(baseName), + normalizeName(baseName.replace(/[-.]?(?:es|module)$/i, "")), + normalizeName(baseName.replace(/[-.]?js$/i, "")), + ]); + + const matchingPackageNames = matches + .filter((relPath) => { + const fileName = path.basename(relPath, path.extname(relPath)); + return normalizedVariants.has(normalizeName(fileName)); + }) + .sort((a, b) => a.length - b.length); + + if (matchingPackageNames.length > 0) { + return matchingPackageNames[0]; + } + + const fallbackIndex = matches + .filter((relPath) => /^(.+\/)?index\.(mjs|js|cjs|ts|tsx)$/.test(relPath)) + .sort((a, b) => a.length - b.length); + + if (fallbackIndex.length > 0) { + return fallbackIndex[0]; + } + + const rootFileFallback = matches + .filter((relPath) => !relPath.includes("/") && !path.basename(relPath).startsWith("_")) + .sort((a, b) => a.length - b.length); + + if (rootFileFallback.length > 0) { + return rootFileFallback[0]; + } + + return null; +} + +function detectModuleType(entryPath) { + const ext = path.extname(entryPath); + if (ext === ".mjs") return "module"; + if (ext === ".cjs") return "commonjs"; + + const source = fs.readFileSync(entryPath, "utf8"); + const hasEsmSyntax = + /^\s*import\s/m.test(source) || + /^\s*export\s/m.test(source) || + source.includes("import.meta"); + const hasCommonJsSyntax = + source.includes("module.exports") || + source.includes("exports.") || + source.includes("require("); + + if (hasEsmSyntax && !hasCommonJsSyntax) { + return "module"; + } + + return "commonjs"; +} + +function writeManifest(pkg) { + const manifestPath = path.join(pkg.dir, "package.json"); + if (fs.existsSync(manifestPath)) { + return { status: "existing" }; + } + + const entry = chooseCandidate(pkg.dir, pkg.name); + if (!entry) { + return { status: "missing-entry" }; + } + + const entryPath = path.join(pkg.dir, entry); + const type = detectModuleType(entryPath); + const manifest = { + name: pkg.name, + private: true, + main: `./${entry.replace(/\\/g, "/")}`, + type, + }; + + fs.writeFileSync(manifestPath, `${JSON.stringify(manifest, null, 2)}\n`, "utf8"); + return { status: "written", entry: manifest.main, type }; +} + +function main() { + const packages = listPackages(NODE_MODULES_DIR); + let written = 0; + let existing = 0; + const missing = []; + + for (const pkg of packages) { + const result = writeManifest(pkg); + if (result.status === "written") { + written += 1; + } else if (result.status === "existing") { + existing += 1; + } else { + missing.push(pkg.name); + } + } + + console.log( + JSON.stringify( + { + packages: packages.length, + written, + existing, + missing, + }, + null, + 2, + ), + ); +} + +main(); diff --git a/restored-src/src/commands/insights.ts b/restored-src/src/commands/insights.ts index f66380a7c..7583d49f4 100644 --- a/restored-src/src/commands/insights.ts +++ b/restored-src/src/commands/insights.ts @@ -1,5 +1,5 @@ import { execFileSync } from 'child_process' -import { diffLines } from 'diff' +import { diffLines } from 'diff/libesm/diff/line.js' import { constants as fsConstants } from 'fs' import { copyFile, diff --git a/restored-src/src/components/StructuredDiff/Fallback.tsx b/restored-src/src/components/StructuredDiff/Fallback.tsx index 8948d7688..c33566f57 100644 --- a/restored-src/src/components/StructuredDiff/Fallback.tsx +++ b/restored-src/src/components/StructuredDiff/Fallback.tsx @@ -1,5 +1,6 @@ import { c as _c } from "react/compiler-runtime"; -import { diffWordsWithSpace, type StructuredPatchHunk } from 'diff'; +import type { StructuredPatchHunk } from 'diff'; +import { diffWordsWithSpace } from 'diff/libesm/diff/word.js'; import * as React from 'react'; import { useMemo } from 'react'; import type { ThemeName } from 'src/utils/theme.js'; @@ -484,4 +485,4 @@ export function numberDiffLines(diff: LineObject[], startLine: number): DiffLine } return result; } -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["diffWordsWithSpace","StructuredPatchHunk","React","useMemo","ThemeName","stringWidth","Box","NoSelect","Text","useTheme","wrapText","DiffLine","code","type","i","originalCode","wordDiff","matchedLine","LineObject","DiffPart","added","removed","value","Props","patch","dim","width","CHANGE_THRESHOLD","StructuredDiffFallback","t0","$","_c","theme","t1","lines","oldStart","formatDiff","diff","t2","map","_temp","t3","node","transformLinesToObjects","startsWith","slice","processAdjacentLines","lineObjects","processedLines","length","current","removeLines","j","line","push","addLines","pairCount","Math","min","k","removeLine","addLine","filter","Boolean","calculateWordDiffs","oldText","newText","result","ignoreCase","generateWordDiffElements","item","maxWidth","overrideTheme","ReactNode","removedLineText","addedLineText","wordDiffs","totalLength","changedLength","part","reduce","sum","changeRatio","diffPrefix","diffPrefixWidth","availableContentWidth","max","wrappedLines","content","contentWidth","currentLine","currentLineWidth","forEach","partIndex","shouldShow","partBgColor","partWrapped","partLines","split","partLine","lineIdx","lineIndex","key","lineBgColor","lineNum","undefined","lineNumStr","toString","padStart","repeat","usedWidth","padding","startingLineNumber","safeWidth","floor","ls","numberDiffLines","maxLineNumber","flatMap","wordDiffElements","wrappedText","sigil","bgColor","startLine","queue","shift","numRemoved"],"sources":["Fallback.tsx"],"sourcesContent":["import { diffWordsWithSpace, type StructuredPatchHunk } from 'diff'\nimport * as React from 'react'\nimport { useMemo } from 'react'\nimport type { ThemeName } from 'src/utils/theme.js'\nimport { stringWidth } from '../../ink/stringWidth.js'\nimport { Box, NoSelect, Text, useTheme, wrapText } from '../../ink.js'\n\n/*\n * StructuredDiffFallback Component: Word-Level Diff Highlighting Example\n *\n * This component shows diff changes with word-level highlighting. Here's a walkthrough:\n *\n * Example:\n * ```\n * // Original code\n * function oldName(param) {\n *   return param.oldProperty;\n * }\n *\n * // Changed code\n * function newName(param) {\n *   return param.newProperty;\n * }\n * ```\n *\n * Processing flow:\n * 1. Component receives a patch with lines including '+' and '-' prefixes\n * 2. Lines are transformed into objects with type (add/remove/nochange)\n * 3. Related add/remove lines are paired (e.g., oldName with newName)\n * 4. Word-level diffing identifies specific changed parts:\n *    [\n *      { value: 'function ', added: undefined, removed: undefined },  // Common\n *      { value: 'oldName', removed: true },                           // Removed\n *      { value: 'newName', added: true },                             // Added\n *      { value: '(param) {', added: undefined, removed: undefined }   // Common\n *    ]\n * 5. Renders with enhanced highlighting:\n *    - Common parts are shown normally\n *    - Removed words get a darker red background\n *    - Added words get a darker green background\n *\n * This produces a visually clear diff where users can see exactly which words\n * changed rather than just which lines were modified.\n */\n\n// Define DiffLine interface to be used throughout the file\ninterface DiffLine {\n  code: string\n  type: 'add' | 'remove' | 'nochange'\n  i: number\n  originalCode: string\n  wordDiff?: boolean // Flag for word-level diffing\n  matchedLine?: DiffLine\n}\n\n// Line object type for internal functions\nexport interface LineObject {\n  code: string\n  i: number\n  type: 'add' | 'remove' | 'nochange'\n  originalCode: string\n  wordDiff?: boolean\n  matchedLine?: LineObject\n}\n\n// Type for word-level diff parts\ninterface DiffPart {\n  added?: boolean\n  removed?: boolean\n  value: string\n}\n\ntype Props = {\n  patch: StructuredPatchHunk\n  dim: boolean\n  width: number\n}\n\n// Threshold for when we show a full-line diff instead of word-level diffing\nconst CHANGE_THRESHOLD = 0.4\n\nexport function StructuredDiffFallback({\n  patch,\n  dim,\n  width,\n}: Props): React.ReactNode {\n  const [theme] = useTheme()\n  const diff = useMemo(\n    () => formatDiff(patch.lines, patch.oldStart, width, dim, theme),\n    [patch.lines, patch.oldStart, width, dim, theme],\n  )\n\n  return (\n    <Box flexDirection=\"column\" flexGrow={1}>\n      {diff.map((node, i) => (\n        <Box key={i}>{node}</Box>\n      ))}\n    </Box>\n  )\n}\n\n// Transform lines to line objects with type information\nexport function transformLinesToObjects(lines: string[]): LineObject[] {\n  return lines.map(code => {\n    if (code.startsWith('+')) {\n      return {\n        code: code.slice(1),\n        i: 0,\n        type: 'add',\n        originalCode: code.slice(1),\n      }\n    }\n    if (code.startsWith('-')) {\n      return {\n        code: code.slice(1),\n        i: 0,\n        type: 'remove',\n        originalCode: code.slice(1),\n      }\n    }\n    return {\n      code: code.slice(1),\n      i: 0,\n      type: 'nochange',\n      originalCode: code.slice(1),\n    }\n  })\n}\n\n// Group adjacent add/remove lines for word-level diffing\nexport function processAdjacentLines(lineObjects: LineObject[]): LineObject[] {\n  const processedLines: LineObject[] = []\n  let i = 0\n\n  while (i < lineObjects.length) {\n    const current = lineObjects[i]\n    if (!current) {\n      i++\n      continue\n    }\n\n    // Find a sequence of remove followed by add (possible word-level diff candidates)\n    if (current.type === 'remove') {\n      const removeLines: LineObject[] = [current]\n      let j = i + 1\n\n      // Collect consecutive remove lines\n      while (j < lineObjects.length && lineObjects[j]?.type === 'remove') {\n        const line = lineObjects[j]\n        if (line) {\n          removeLines.push(line)\n        }\n        j++\n      }\n\n      // Check if there are add lines following the remove lines\n      const addLines: LineObject[] = []\n      while (j < lineObjects.length && lineObjects[j]?.type === 'add') {\n        const line = lineObjects[j]\n        if (line) {\n          addLines.push(line)\n        }\n        j++\n      }\n\n      // If we have both remove and add lines, perform word-level diffing\n      if (removeLines.length > 0 && addLines.length > 0) {\n        // For word diffing, we'll compare each pair of lines or the closest available match\n        const pairCount = Math.min(removeLines.length, addLines.length)\n\n        // Add paired lines with word diff info\n        for (let k = 0; k < pairCount; k++) {\n          const removeLine = removeLines[k]\n          const addLine = addLines[k]\n\n          if (removeLine && addLine) {\n            removeLine.wordDiff = true\n            addLine.wordDiff = true\n\n            // Store the matched pair for later word diffing\n            removeLine.matchedLine = addLine\n            addLine.matchedLine = removeLine\n          }\n        }\n\n        // Add all remove lines (both paired and unpaired)\n        processedLines.push(...removeLines.filter(Boolean))\n\n        // Then add all add lines (both paired and unpaired)\n        processedLines.push(...addLines.filter(Boolean))\n\n        i = j // Skip all the lines we've processed\n      } else {\n        // No matching add lines, just add the current remove line\n        processedLines.push(current)\n        i++\n      }\n    } else {\n      // Not a remove line, just add it\n      processedLines.push(current)\n      i++\n    }\n  }\n\n  return processedLines\n}\n\n// Calculate word-level diffs between two text strings\nexport function calculateWordDiffs(\n  oldText: string,\n  newText: string,\n): DiffPart[] {\n  // Use diffWordsWithSpace instead of diffWords to preserve whitespace\n  // This ensures spaces between tokens like > and { are preserved\n  const result = diffWordsWithSpace(oldText, newText, { ignoreCase: false })\n\n  return result\n}\n\n// Process word-level diffs with manual wrapping support\nfunction generateWordDiffElements(\n  item: DiffLine,\n  width: number,\n  maxWidth: number,\n  dim: boolean,\n  overrideTheme?: ThemeName,\n): React.ReactNode[] | null {\n  const { type, i, wordDiff, matchedLine, originalCode } = item\n\n  if (!wordDiff || !matchedLine) {\n    return null // This function only handles word-level diff rendering\n  }\n\n  const removedLineText =\n    type === 'remove' ? originalCode : matchedLine.originalCode\n  const addedLineText =\n    type === 'remove' ? matchedLine.originalCode : originalCode\n\n  const wordDiffs = calculateWordDiffs(removedLineText, addedLineText)\n\n  // Check if we should use word-level diffing\n  const totalLength = removedLineText.length + addedLineText.length\n  const changedLength = wordDiffs\n    .filter(part => part.added || part.removed)\n    .reduce((sum, part) => sum + part.value.length, 0)\n  const changeRatio = changedLength / totalLength\n\n  if (changeRatio > CHANGE_THRESHOLD || dim) {\n    return null // Fall back to standard rendering for major changes\n  }\n\n  // Calculate available width for content\n  const diffPrefix = type === 'add' ? '+' : '-'\n  const diffPrefixWidth = diffPrefix.length\n  const availableContentWidth = Math.max(\n    1,\n    width - maxWidth - 1 - diffPrefixWidth,\n  )\n\n  // Manually wrap the word diff parts with better space efficiency\n  const wrappedLines: { content: React.ReactNode[]; contentWidth: number }[] =\n    []\n  let currentLine: React.ReactNode[] = []\n  let currentLineWidth = 0\n\n  wordDiffs.forEach((part, partIndex) => {\n    // Determine if this part should be shown for this line type\n    let shouldShow = false\n    let partBgColor: 'diffAddedWord' | 'diffRemovedWord' | undefined\n\n    if (type === 'add') {\n      if (part.added) {\n        shouldShow = true\n        partBgColor = 'diffAddedWord'\n      } else if (!part.removed) {\n        shouldShow = true\n      }\n    } else if (type === 'remove') {\n      if (part.removed) {\n        shouldShow = true\n        partBgColor = 'diffRemovedWord'\n      } else if (!part.added) {\n        shouldShow = true\n      }\n    }\n\n    if (!shouldShow) return\n\n    // Use wrapText to wrap this individual part if it's long\n    const partWrapped = wrapText(part.value, availableContentWidth, 'wrap')\n    const partLines = partWrapped.split('\\n')\n\n    partLines.forEach((partLine, lineIdx) => {\n      if (!partLine) return\n\n      // Check if we need to start a new line\n      if (\n        lineIdx > 0 ||\n        currentLineWidth + stringWidth(partLine) > availableContentWidth\n      ) {\n        if (currentLine.length > 0) {\n          wrappedLines.push({\n            content: [...currentLine],\n            contentWidth: currentLineWidth,\n          })\n          currentLine = []\n          currentLineWidth = 0\n        }\n      }\n\n      currentLine.push(\n        <Text\n          key={`part-${partIndex}-${lineIdx}`}\n          backgroundColor={partBgColor}\n        >\n          {partLine}\n        </Text>,\n      )\n\n      currentLineWidth += stringWidth(partLine)\n    })\n  })\n\n  if (currentLine.length > 0) {\n    wrappedLines.push({ content: currentLine, contentWidth: currentLineWidth })\n  }\n\n  // Render each wrapped line as a separate Text element\n  return wrappedLines.map(({ content, contentWidth }, lineIndex) => {\n    const key = `${type}-${i}-${lineIndex}`\n    const lineBgColor =\n      type === 'add'\n        ? dim\n          ? 'diffAddedDimmed'\n          : 'diffAdded'\n        : dim\n          ? 'diffRemovedDimmed'\n          : 'diffRemoved'\n    const lineNum = lineIndex === 0 ? i : undefined\n    const lineNumStr =\n      (lineNum !== undefined\n        ? lineNum.toString().padStart(maxWidth)\n        : ' '.repeat(maxWidth)) + ' '\n    // Calculate padding to fill the entire terminal width\n    const usedWidth = lineNumStr.length + diffPrefixWidth + contentWidth\n    const padding = Math.max(0, width - usedWidth)\n\n    return (\n      <Box key={key} flexDirection=\"row\">\n        <NoSelect fromLeftEdge>\n          <Text\n            color={overrideTheme ? 'text' : undefined}\n            backgroundColor={lineBgColor}\n            dimColor={dim}\n          >\n            {lineNumStr}\n            {diffPrefix}\n          </Text>\n        </NoSelect>\n        <Text\n          color={overrideTheme ? 'text' : undefined}\n          backgroundColor={lineBgColor}\n          dimColor={dim}\n        >\n          {content}\n          {' '.repeat(padding)}\n        </Text>\n      </Box>\n    )\n  })\n}\n\nfunction formatDiff(\n  lines: string[],\n  startingLineNumber: number,\n  width: number,\n  dim: boolean,\n  overrideTheme?: ThemeName,\n): React.ReactNode[] {\n  // Ensure width is at least 1 to prevent rendering issues with very narrow terminals\n  const safeWidth = Math.max(1, Math.floor(width))\n\n  // Step 1: Transform lines to line objects with type information\n  const lineObjects = transformLinesToObjects(lines)\n\n  // Step 2: Group adjacent add/remove lines for word-level diffing\n  const processedLines = processAdjacentLines(lineObjects)\n\n  // Step 3: Number the diff lines\n  const ls = numberDiffLines(processedLines, startingLineNumber)\n\n  // Find max line number width for alignment\n  const maxLineNumber = Math.max(...ls.map(({ i }) => i), 0)\n  const maxWidth = Math.max(maxLineNumber.toString().length + 1, 0)\n\n  // Step 4: Render formatting\n  return ls.flatMap((item): React.ReactNode[] => {\n    const { type, code, i, wordDiff, matchedLine } = item\n\n    // Handle word-level diffing for add/remove pairs\n    if (wordDiff && matchedLine) {\n      const wordDiffElements = generateWordDiffElements(\n        item,\n        safeWidth,\n        maxWidth,\n        dim,\n        overrideTheme,\n      )\n\n      // word-diff might refuse (e.g. due to lines being substantially different) in which\n      // case we'll fall through to normal renderin gbelow\n      if (wordDiffElements !== null) {\n        return wordDiffElements\n      }\n    }\n\n    // Standard rendering for lines without word diffing or as fallback\n    // Calculate available width accounting for line number + space + diff prefix\n    const diffPrefixWidth = 2 // \"  \" for unchanged, \"+ \" or \"- \" for changes\n    const availableContentWidth = Math.max(\n      1,\n      safeWidth - maxWidth - 1 - diffPrefixWidth,\n    ) // -1 for space after line number\n    const wrappedText = wrapText(code, availableContentWidth, 'wrap')\n    const wrappedLines = wrappedText.split('\\n')\n\n    return wrappedLines.map((line, lineIndex) => {\n      const key = `${type}-${i}-${lineIndex}`\n      const lineNum = lineIndex === 0 ? i : undefined\n      const lineNumStr =\n        (lineNum !== undefined\n          ? lineNum.toString().padStart(maxWidth)\n          : ' '.repeat(maxWidth)) + ' '\n      const sigil = type === 'add' ? '+' : type === 'remove' ? '-' : ' '\n      // Calculate padding to fill the entire terminal width\n      const contentWidth = lineNumStr.length + 1 + stringWidth(line) // lineNum + sigil + code\n      const padding = Math.max(0, safeWidth - contentWidth)\n\n      const bgColor =\n        type === 'add'\n          ? dim\n            ? 'diffAddedDimmed'\n            : 'diffAdded'\n          : type === 'remove'\n            ? dim\n              ? 'diffRemovedDimmed'\n              : 'diffRemoved'\n            : undefined\n\n      // Gutter (line number + sigil) is wrapped in <NoSelect> so fullscreen\n      // text selection yields clean code. bgColor carries across both boxes\n      // so the visual continuity (solid red/green bar) is unchanged.\n      return (\n        <Box key={key} flexDirection=\"row\">\n          <NoSelect fromLeftEdge>\n            <Text\n              color={overrideTheme ? 'text' : undefined}\n              backgroundColor={bgColor}\n              dimColor={dim || type === 'nochange'}\n            >\n              {lineNumStr}\n              {sigil}\n            </Text>\n          </NoSelect>\n          <Text\n            color={overrideTheme ? 'text' : undefined}\n            backgroundColor={bgColor}\n            dimColor={dim}\n          >\n            {line}\n            {' '.repeat(padding)}\n          </Text>\n        </Box>\n      )\n    })\n  })\n}\n\nexport function numberDiffLines(\n  diff: LineObject[],\n  startLine: number,\n): DiffLine[] {\n  let i = startLine\n  const result: DiffLine[] = []\n  const queue = [...diff]\n\n  while (queue.length > 0) {\n    const current = queue.shift()!\n    const { code, type, originalCode, wordDiff, matchedLine } = current\n    const line = {\n      code,\n      type,\n      i,\n      originalCode,\n      wordDiff,\n      matchedLine,\n    }\n\n    // Update counters based on change type\n    switch (type) {\n      case 'nochange':\n        i++\n        result.push(line)\n        break\n      case 'add':\n        i++\n        result.push(line)\n        break\n      case 'remove': {\n        result.push(line)\n        let numRemoved = 0\n        while (queue[0]?.type === 'remove') {\n          i++\n          const current = queue.shift()!\n          const { code, type, originalCode, wordDiff, matchedLine } = current\n          const line = {\n            code,\n            type,\n            i,\n            originalCode,\n            wordDiff,\n            matchedLine,\n          }\n          result.push(line)\n          numRemoved++\n        }\n        i -= numRemoved\n        break\n      }\n    }\n  }\n\n  return result\n}\n"],"mappings":"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","ignoreList":[]} \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["diffWordsWithSpace","StructuredPatchHunk","React","useMemo","ThemeName","stringWidth","Box","NoSelect","Text","useTheme","wrapText","DiffLine","code","type","i","originalCode","wordDiff","matchedLine","LineObject","DiffPart","added","removed","value","Props","patch","dim","width","CHANGE_THRESHOLD","StructuredDiffFallback","t0","$","_c","theme","t1","lines","oldStart","formatDiff","diff","t2","map","_temp","t3","node","transformLinesToObjects","startsWith","slice","processAdjacentLines","lineObjects","processedLines","length","current","removeLines","j","line","push","addLines","pairCount","Math","min","k","removeLine","addLine","filter","Boolean","calculateWordDiffs","oldText","newText","result","ignoreCase","generateWordDiffElements","item","maxWidth","overrideTheme","ReactNode","removedLineText","addedLineText","wordDiffs","totalLength","changedLength","part","reduce","sum","changeRatio","diffPrefix","diffPrefixWidth","availableContentWidth","max","wrappedLines","content","contentWidth","currentLine","currentLineWidth","forEach","partIndex","shouldShow","partBgColor","partWrapped","partLines","split","partLine","lineIdx","lineIndex","key","lineBgColor","lineNum","undefined","lineNumStr","toString","padStart","repeat","usedWidth","padding","startingLineNumber","safeWidth","floor","ls","numberDiffLines","maxLineNumber","flatMap","wordDiffElements","wrappedText","sigil","bgColor","startLine","queue","shift","numRemoved"],"sources":["Fallback.tsx"],"sourcesContent":["import { diffWordsWithSpace, type StructuredPatchHunk } from 'diff'\nimport * as React from 'react'\nimport { useMemo } from 'react'\nimport type { ThemeName } from 'src/utils/theme.js'\nimport { stringWidth } from '../../ink/stringWidth.js'\nimport { Box, NoSelect, Text, useTheme, wrapText } from '../../ink.js'\n\n/*\n * StructuredDiffFallback Component: Word-Level Diff Highlighting Example\n *\n * This component shows diff changes with word-level highlighting. Here's a walkthrough:\n *\n * Example:\n * ```\n * // Original code\n * function oldName(param) {\n *   return param.oldProperty;\n * }\n *\n * // Changed code\n * function newName(param) {\n *   return param.newProperty;\n * }\n * ```\n *\n * Processing flow:\n * 1. Component receives a patch with lines including '+' and '-' prefixes\n * 2. Lines are transformed into objects with type (add/remove/nochange)\n * 3. Related add/remove lines are paired (e.g., oldName with newName)\n * 4. Word-level diffing identifies specific changed parts:\n *    [\n *      { value: 'function ', added: undefined, removed: undefined },  // Common\n *      { value: 'oldName', removed: true },                           // Removed\n *      { value: 'newName', added: true },                             // Added\n *      { value: '(param) {', added: undefined, removed: undefined }   // Common\n *    ]\n * 5. Renders with enhanced highlighting:\n *    - Common parts are shown normally\n *    - Removed words get a darker red background\n *    - Added words get a darker green background\n *\n * This produces a visually clear diff where users can see exactly which words\n * changed rather than just which lines were modified.\n */\n\n// Define DiffLine interface to be used throughout the file\ninterface DiffLine {\n  code: string\n  type: 'add' | 'remove' | 'nochange'\n  i: number\n  originalCode: string\n  wordDiff?: boolean // Flag for word-level diffing\n  matchedLine?: DiffLine\n}\n\n// Line object type for internal functions\nexport interface LineObject {\n  code: string\n  i: number\n  type: 'add' | 'remove' | 'nochange'\n  originalCode: string\n  wordDiff?: boolean\n  matchedLine?: LineObject\n}\n\n// Type for word-level diff parts\ninterface DiffPart {\n  added?: boolean\n  removed?: boolean\n  value: string\n}\n\ntype Props = {\n  patch: StructuredPatchHunk\n  dim: boolean\n  width: number\n}\n\n// Threshold for when we show a full-line diff instead of word-level diffing\nconst CHANGE_THRESHOLD = 0.4\n\nexport function StructuredDiffFallback({\n  patch,\n  dim,\n  width,\n}: Props): React.ReactNode {\n  const [theme] = useTheme()\n  const diff = useMemo(\n    () => formatDiff(patch.lines, patch.oldStart, width, dim, theme),\n    [patch.lines, patch.oldStart, width, dim, theme],\n  )\n\n  return (\n    <Box flexDirection=\"column\" flexGrow={1}>\n      {diff.map((node, i) => (\n        <Box key={i}>{node}</Box>\n      ))}\n    </Box>\n  )\n}\n\n// Transform lines to line objects with type information\nexport function transformLinesToObjects(lines: string[]): LineObject[] {\n  return lines.map(code => {\n    if (code.startsWith('+')) {\n      return {\n        code: code.slice(1),\n        i: 0,\n        type: 'add',\n        originalCode: code.slice(1),\n      }\n    }\n    if (code.startsWith('-')) {\n      return {\n        code: code.slice(1),\n        i: 0,\n        type: 'remove',\n        originalCode: code.slice(1),\n      }\n    }\n    return {\n      code: code.slice(1),\n      i: 0,\n      type: 'nochange',\n      originalCode: code.slice(1),\n    }\n  })\n}\n\n// Group adjacent add/remove lines for word-level diffing\nexport function processAdjacentLines(lineObjects: LineObject[]): LineObject[] {\n  const processedLines: LineObject[] = []\n  let i = 0\n\n  while (i < lineObjects.length) {\n    const current = lineObjects[i]\n    if (!current) {\n      i++\n      continue\n    }\n\n    // Find a sequence of remove followed by add (possible word-level diff candidates)\n    if (current.type === 'remove') {\n      const removeLines: LineObject[] = [current]\n      let j = i + 1\n\n      // Collect consecutive remove lines\n      while (j < lineObjects.length && lineObjects[j]?.type === 'remove') {\n        const line = lineObjects[j]\n        if (line) {\n          removeLines.push(line)\n        }\n        j++\n      }\n\n      // Check if there are add lines following the remove lines\n      const addLines: LineObject[] = []\n      while (j < lineObjects.length && lineObjects[j]?.type === 'add') {\n        const line = lineObjects[j]\n        if (line) {\n          addLines.push(line)\n        }\n        j++\n      }\n\n      // If we have both remove and add lines, perform word-level diffing\n      if (removeLines.length > 0 && addLines.length > 0) {\n        // For word diffing, we'll compare each pair of lines or the closest available match\n        const pairCount = Math.min(removeLines.length, addLines.length)\n\n        // Add paired lines with word diff info\n        for (let k = 0; k < pairCount; k++) {\n          const removeLine = removeLines[k]\n          const addLine = addLines[k]\n\n          if (removeLine && addLine) {\n            removeLine.wordDiff = true\n            addLine.wordDiff = true\n\n            // Store the matched pair for later word diffing\n            removeLine.matchedLine = addLine\n            addLine.matchedLine = removeLine\n          }\n        }\n\n        // Add all remove lines (both paired and unpaired)\n        processedLines.push(...removeLines.filter(Boolean))\n\n        // Then add all add lines (both paired and unpaired)\n        processedLines.push(...addLines.filter(Boolean))\n\n        i = j // Skip all the lines we've processed\n      } else {\n        // No matching add lines, just add the current remove line\n        processedLines.push(current)\n        i++\n      }\n    } else {\n      // Not a remove line, just add it\n      processedLines.push(current)\n      i++\n    }\n  }\n\n  return processedLines\n}\n\n// Calculate word-level diffs between two text strings\nexport function calculateWordDiffs(\n  oldText: string,\n  newText: string,\n): DiffPart[] {\n  // Use diffWordsWithSpace instead of diffWords to preserve whitespace\n  // This ensures spaces between tokens like > and { are preserved\n  const result = diffWordsWithSpace(oldText, newText, { ignoreCase: false })\n\n  return result\n}\n\n// Process word-level diffs with manual wrapping support\nfunction generateWordDiffElements(\n  item: DiffLine,\n  width: number,\n  maxWidth: number,\n  dim: boolean,\n  overrideTheme?: ThemeName,\n): React.ReactNode[] | null {\n  const { type, i, wordDiff, matchedLine, originalCode } = item\n\n  if (!wordDiff || !matchedLine) {\n    return null // This function only handles word-level diff rendering\n  }\n\n  const removedLineText =\n    type === 'remove' ? originalCode : matchedLine.originalCode\n  const addedLineText =\n    type === 'remove' ? matchedLine.originalCode : originalCode\n\n  const wordDiffs = calculateWordDiffs(removedLineText, addedLineText)\n\n  // Check if we should use word-level diffing\n  const totalLength = removedLineText.length + addedLineText.length\n  const changedLength = wordDiffs\n    .filter(part => part.added || part.removed)\n    .reduce((sum, part) => sum + part.value.length, 0)\n  const changeRatio = changedLength / totalLength\n\n  if (changeRatio > CHANGE_THRESHOLD || dim) {\n    return null // Fall back to standard rendering for major changes\n  }\n\n  // Calculate available width for content\n  const diffPrefix = type === 'add' ? '+' : '-'\n  const diffPrefixWidth = diffPrefix.length\n  const availableContentWidth = Math.max(\n    1,\n    width - maxWidth - 1 - diffPrefixWidth,\n  )\n\n  // Manually wrap the word diff parts with better space efficiency\n  const wrappedLines: { content: React.ReactNode[]; contentWidth: number }[] =\n    []\n  let currentLine: React.ReactNode[] = []\n  let currentLineWidth = 0\n\n  wordDiffs.forEach((part, partIndex) => {\n    // Determine if this part should be shown for this line type\n    let shouldShow = false\n    let partBgColor: 'diffAddedWord' | 'diffRemovedWord' | undefined\n\n    if (type === 'add') {\n      if (part.added) {\n        shouldShow = true\n        partBgColor = 'diffAddedWord'\n      } else if (!part.removed) {\n        shouldShow = true\n      }\n    } else if (type === 'remove') {\n      if (part.removed) {\n        shouldShow = true\n        partBgColor = 'diffRemovedWord'\n      } else if (!part.added) {\n        shouldShow = true\n      }\n    }\n\n    if (!shouldShow) return\n\n    // Use wrapText to wrap this individual part if it's long\n    const partWrapped = wrapText(part.value, availableContentWidth, 'wrap')\n    const partLines = partWrapped.split('\\n')\n\n    partLines.forEach((partLine, lineIdx) => {\n      if (!partLine) return\n\n      // Check if we need to start a new line\n      if (\n        lineIdx > 0 ||\n        currentLineWidth + stringWidth(partLine) > availableContentWidth\n      ) {\n        if (currentLine.length > 0) {\n          wrappedLines.push({\n            content: [...currentLine],\n            contentWidth: currentLineWidth,\n          })\n          currentLine = []\n          currentLineWidth = 0\n        }\n      }\n\n      currentLine.push(\n        <Text\n          key={`part-${partIndex}-${lineIdx}`}\n          backgroundColor={partBgColor}\n        >\n          {partLine}\n        </Text>,\n      )\n\n      currentLineWidth += stringWidth(partLine)\n    })\n  })\n\n  if (currentLine.length > 0) {\n    wrappedLines.push({ content: currentLine, contentWidth: currentLineWidth })\n  }\n\n  // Render each wrapped line as a separate Text element\n  return wrappedLines.map(({ content, contentWidth }, lineIndex) => {\n    const key = `${type}-${i}-${lineIndex}`\n    const lineBgColor =\n      type === 'add'\n        ? dim\n          ? 'diffAddedDimmed'\n          : 'diffAdded'\n        : dim\n          ? 'diffRemovedDimmed'\n          : 'diffRemoved'\n    const lineNum = lineIndex === 0 ? i : undefined\n    const lineNumStr =\n      (lineNum !== undefined\n        ? lineNum.toString().padStart(maxWidth)\n        : ' '.repeat(maxWidth)) + ' '\n    // Calculate padding to fill the entire terminal width\n    const usedWidth = lineNumStr.length + diffPrefixWidth + contentWidth\n    const padding = Math.max(0, width - usedWidth)\n\n    return (\n      <Box key={key} flexDirection=\"row\">\n        <NoSelect fromLeftEdge>\n          <Text\n            color={overrideTheme ? 'text' : undefined}\n            backgroundColor={lineBgColor}\n            dimColor={dim}\n          >\n            {lineNumStr}\n            {diffPrefix}\n          </Text>\n        </NoSelect>\n        <Text\n          color={overrideTheme ? 'text' : undefined}\n          backgroundColor={lineBgColor}\n          dimColor={dim}\n        >\n          {content}\n          {' '.repeat(padding)}\n        </Text>\n      </Box>\n    )\n  })\n}\n\nfunction formatDiff(\n  lines: string[],\n  startingLineNumber: number,\n  width: number,\n  dim: boolean,\n  overrideTheme?: ThemeName,\n): React.ReactNode[] {\n  // Ensure width is at least 1 to prevent rendering issues with very narrow terminals\n  const safeWidth = Math.max(1, Math.floor(width))\n\n  // Step 1: Transform lines to line objects with type information\n  const lineObjects = transformLinesToObjects(lines)\n\n  // Step 2: Group adjacent add/remove lines for word-level diffing\n  const processedLines = processAdjacentLines(lineObjects)\n\n  // Step 3: Number the diff lines\n  const ls = numberDiffLines(processedLines, startingLineNumber)\n\n  // Find max line number width for alignment\n  const maxLineNumber = Math.max(...ls.map(({ i }) => i), 0)\n  const maxWidth = Math.max(maxLineNumber.toString().length + 1, 0)\n\n  // Step 4: Render formatting\n  return ls.flatMap((item): React.ReactNode[] => {\n    const { type, code, i, wordDiff, matchedLine } = item\n\n    // Handle word-level diffing for add/remove pairs\n    if (wordDiff && matchedLine) {\n      const wordDiffElements = generateWordDiffElements(\n        item,\n        safeWidth,\n        maxWidth,\n        dim,\n        overrideTheme,\n      )\n\n      // word-diff might refuse (e.g. due to lines being substantially different) in which\n      // case we'll fall through to normal renderin gbelow\n      if (wordDiffElements !== null) {\n        return wordDiffElements\n      }\n    }\n\n    // Standard rendering for lines without word diffing or as fallback\n    // Calculate available width accounting for line number + space + diff prefix\n    const diffPrefixWidth = 2 // \"  \" for unchanged, \"+ \" or \"- \" for changes\n    const availableContentWidth = Math.max(\n      1,\n      safeWidth - maxWidth - 1 - diffPrefixWidth,\n    ) // -1 for space after line number\n    const wrappedText = wrapText(code, availableContentWidth, 'wrap')\n    const wrappedLines = wrappedText.split('\\n')\n\n    return wrappedLines.map((line, lineIndex) => {\n      const key = `${type}-${i}-${lineIndex}`\n      const lineNum = lineIndex === 0 ? i : undefined\n      const lineNumStr =\n        (lineNum !== undefined\n          ? lineNum.toString().padStart(maxWidth)\n          : ' '.repeat(maxWidth)) + ' '\n      const sigil = type === 'add' ? '+' : type === 'remove' ? '-' : ' '\n      // Calculate padding to fill the entire terminal width\n      const contentWidth = lineNumStr.length + 1 + stringWidth(line) // lineNum + sigil + code\n      const padding = Math.max(0, safeWidth - contentWidth)\n\n      const bgColor =\n        type === 'add'\n          ? dim\n            ? 'diffAddedDimmed'\n            : 'diffAdded'\n          : type === 'remove'\n            ? dim\n              ? 'diffRemovedDimmed'\n              : 'diffRemoved'\n            : undefined\n\n      // Gutter (line number + sigil) is wrapped in <NoSelect> so fullscreen\n      // text selection yields clean code. bgColor carries across both boxes\n      // so the visual continuity (solid red/green bar) is unchanged.\n      return (\n        <Box key={key} flexDirection=\"row\">\n          <NoSelect fromLeftEdge>\n            <Text\n              color={overrideTheme ? 'text' : undefined}\n              backgroundColor={bgColor}\n              dimColor={dim || type === 'nochange'}\n            >\n              {lineNumStr}\n              {sigil}\n            </Text>\n          </NoSelect>\n          <Text\n            color={overrideTheme ? 'text' : undefined}\n            backgroundColor={bgColor}\n            dimColor={dim}\n          >\n            {line}\n            {' '.repeat(padding)}\n          </Text>\n        </Box>\n      )\n    })\n  })\n}\n\nexport function numberDiffLines(\n  diff: LineObject[],\n  startLine: number,\n): DiffLine[] {\n  let i = startLine\n  const result: DiffLine[] = []\n  const queue = [...diff]\n\n  while (queue.length > 0) {\n    const current = queue.shift()!\n    const { code, type, originalCode, wordDiff, matchedLine } = current\n    const line = {\n      code,\n      type,\n      i,\n      originalCode,\n      wordDiff,\n      matchedLine,\n    }\n\n    // Update counters based on change type\n    switch (type) {\n      case 'nochange':\n        i++\n        result.push(line)\n        break\n      case 'add':\n        i++\n        result.push(line)\n        break\n      case 'remove': {\n        result.push(line)\n        let numRemoved = 0\n        while (queue[0]?.type === 'remove') {\n          i++\n          const current = queue.shift()!\n          const { code, type, originalCode, wordDiff, matchedLine } = current\n          const line = {\n            code,\n            type,\n            i,\n            originalCode,\n            wordDiff,\n            matchedLine,\n          }\n          result.push(line)\n          numRemoved++\n        }\n        i -= numRemoved\n        break\n      }\n    }\n  }\n\n  return result\n}\n"],"mappings":"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","ignoreList":[]} diff --git a/restored-src/src/components/StructuredDiff/colorDiff.ts b/restored-src/src/components/StructuredDiff/colorDiff.ts index d3abaa280..97bdc72a2 100644 --- a/restored-src/src/components/StructuredDiff/colorDiff.ts +++ b/restored-src/src/components/StructuredDiff/colorDiff.ts @@ -3,7 +3,7 @@ import { ColorFile, getSyntaxTheme as nativeGetSyntaxTheme, type SyntaxTheme, -} from 'color-diff-napi' +} from '../../native-ts/color-diff/index.js' import { isEnvDefinedFalsy } from '../../utils/envUtils.js' export type ColorModuleUnavailableReason = 'env' diff --git a/restored-src/src/entrypoints/sdk/controlTypes.ts b/restored-src/src/entrypoints/sdk/controlTypes.ts new file mode 100644 index 000000000..336ce12bb --- /dev/null +++ b/restored-src/src/entrypoints/sdk/controlTypes.ts @@ -0,0 +1 @@ +export {} diff --git a/restored-src/src/entrypoints/sdk/coreTypes.generated.ts b/restored-src/src/entrypoints/sdk/coreTypes.generated.ts new file mode 100644 index 000000000..336ce12bb --- /dev/null +++ b/restored-src/src/entrypoints/sdk/coreTypes.generated.ts @@ -0,0 +1 @@ +export {} diff --git a/restored-src/src/entrypoints/sdk/runtimeTypes.ts b/restored-src/src/entrypoints/sdk/runtimeTypes.ts new file mode 100644 index 000000000..336ce12bb --- /dev/null +++ b/restored-src/src/entrypoints/sdk/runtimeTypes.ts @@ -0,0 +1 @@ +export {} diff --git a/restored-src/src/entrypoints/sdk/settingsTypes.generated.ts b/restored-src/src/entrypoints/sdk/settingsTypes.generated.ts new file mode 100644 index 000000000..336ce12bb --- /dev/null +++ b/restored-src/src/entrypoints/sdk/settingsTypes.generated.ts @@ -0,0 +1 @@ +export {} diff --git a/restored-src/src/entrypoints/sdk/toolTypes.ts b/restored-src/src/entrypoints/sdk/toolTypes.ts new file mode 100644 index 000000000..336ce12bb --- /dev/null +++ b/restored-src/src/entrypoints/sdk/toolTypes.ts @@ -0,0 +1 @@ +export {} diff --git a/restored-src/src/ink/components/Box.tsx b/restored-src/src/ink/components/Box.tsx index 67f2500ff..83b692f3a 100644 --- a/restored-src/src/ink/components/Box.tsx +++ b/restored-src/src/ink/components/Box.tsx @@ -1,5 +1,5 @@ import { c as _c } from "react/compiler-runtime"; -import '../global.d.ts'; +import type {} from '../global.d.ts'; import React, { type PropsWithChildren, type Ref } from 'react'; import type { Except } from 'type-fest'; import type { DOMElement } from '../dom.js'; @@ -211,4 +211,4 @@ function Box(t0) { return t4; } export default Box; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","PropsWithChildren","Ref","Except","DOMElement","ClickEvent","FocusEvent","KeyboardEvent","Styles","warn","Props","ref","tabIndex","autoFocus","onClick","event","onFocus","onFocusCapture","onBlur","onBlurCapture","onKeyDown","onKeyDownCapture","onMouseEnter","onMouseLeave","Box","t0","$","_c","children","flexDirection","flexGrow","flexShrink","flexWrap","style","t1","t2","t3","t4","t5","t6","t7","t8","t9","t10","t11","t12","t13","t14","t15","t16","t17","t18","undefined","ifNotInteger","margin","marginX","marginY","marginTop","marginBottom","marginLeft","marginRight","padding","paddingX","paddingY","paddingTop","paddingBottom","paddingLeft","paddingRight","gap","columnGap","rowGap","overflowX","overflow","overflowY"],"sources":["Box.tsx"],"sourcesContent":["import '../global.d.ts'\nimport React, { type PropsWithChildren, type Ref } from 'react'\nimport type { Except } from 'type-fest'\nimport type { DOMElement } from '../dom.js'\nimport type { ClickEvent } from '../events/click-event.js'\nimport type { FocusEvent } from '../events/focus-event.js'\nimport type { KeyboardEvent } from '../events/keyboard-event.js'\nimport type { Styles } from '../styles.js'\nimport * as warn from '../warn.js'\n\nexport type Props = Except<Styles, 'textWrap'> & {\n  ref?: Ref<DOMElement>\n  /**\n   * Tab order index. Nodes with `tabIndex >= 0` participate in\n   * Tab/Shift+Tab cycling; `-1` means programmatically focusable only.\n   */\n  tabIndex?: number\n  /**\n   * Focus this element when it mounts. Like the HTML `autofocus`\n   * attribute — the FocusManager calls `focus(node)` during the\n   * reconciler's `commitMount` phase.\n   */\n  autoFocus?: boolean\n  /**\n   * Fired on left-button click (press + release without drag). Only works\n   * inside `<AlternateScreen>` where mouse tracking is enabled — no-op\n   * otherwise. The event bubbles from the deepest hit Box up through\n   * ancestors; call `event.stopImmediatePropagation()` to stop bubbling.\n   */\n  onClick?: (event: ClickEvent) => void\n  onFocus?: (event: FocusEvent) => void\n  onFocusCapture?: (event: FocusEvent) => void\n  onBlur?: (event: FocusEvent) => void\n  onBlurCapture?: (event: FocusEvent) => void\n  onKeyDown?: (event: KeyboardEvent) => void\n  onKeyDownCapture?: (event: KeyboardEvent) => void\n  /**\n   * Fired when the mouse moves into this Box's rendered rect. Like DOM\n   * `mouseenter`, does NOT bubble — moving between children does not\n   * re-fire on the parent. Only works inside `<AlternateScreen>` where\n   * mode-1003 mouse tracking is enabled.\n   */\n  onMouseEnter?: () => void\n  /** Fired when the mouse moves out of this Box's rendered rect. */\n  onMouseLeave?: () => void\n}\n\n/**\n * `<Box>` is an essential Ink component to build your layout. It's like `<div style=\"display: flex\">` in the browser.\n */\nfunction Box({\n  children,\n  flexWrap = 'nowrap',\n  flexDirection = 'row',\n  flexGrow = 0,\n  flexShrink = 1,\n  ref,\n  tabIndex,\n  autoFocus,\n  onClick,\n  onFocus,\n  onFocusCapture,\n  onBlur,\n  onBlurCapture,\n  onMouseEnter,\n  onMouseLeave,\n  onKeyDown,\n  onKeyDownCapture,\n  ...style\n}: PropsWithChildren<Props>): React.ReactNode {\n  // Warn if spacing values are not integers to prevent fractional layout dimensions\n  warn.ifNotInteger(style.margin, 'margin')\n  warn.ifNotInteger(style.marginX, 'marginX')\n  warn.ifNotInteger(style.marginY, 'marginY')\n  warn.ifNotInteger(style.marginTop, 'marginTop')\n  warn.ifNotInteger(style.marginBottom, 'marginBottom')\n  warn.ifNotInteger(style.marginLeft, 'marginLeft')\n  warn.ifNotInteger(style.marginRight, 'marginRight')\n  warn.ifNotInteger(style.padding, 'padding')\n  warn.ifNotInteger(style.paddingX, 'paddingX')\n  warn.ifNotInteger(style.paddingY, 'paddingY')\n  warn.ifNotInteger(style.paddingTop, 'paddingTop')\n  warn.ifNotInteger(style.paddingBottom, 'paddingBottom')\n  warn.ifNotInteger(style.paddingLeft, 'paddingLeft')\n  warn.ifNotInteger(style.paddingRight, 'paddingRight')\n  warn.ifNotInteger(style.gap, 'gap')\n  warn.ifNotInteger(style.columnGap, 'columnGap')\n  warn.ifNotInteger(style.rowGap, 'rowGap')\n\n  return (\n    <ink-box\n      ref={ref}\n      tabIndex={tabIndex}\n      autoFocus={autoFocus}\n      onClick={onClick}\n      onFocus={onFocus}\n      onFocusCapture={onFocusCapture}\n      onBlur={onBlur}\n      onBlurCapture={onBlurCapture}\n      onMouseEnter={onMouseEnter}\n      onMouseLeave={onMouseLeave}\n      onKeyDown={onKeyDown}\n      onKeyDownCapture={onKeyDownCapture}\n      style={{\n        flexWrap,\n        flexDirection,\n        flexGrow,\n        flexShrink,\n        ...style,\n        overflowX: style.overflowX ?? style.overflow ?? 'visible',\n        overflowY: style.overflowY ?? style.overflow ?? 'visible',\n      }}\n    >\n      {children}\n    </ink-box>\n  )\n}\n\nexport default Box\n"],"mappings":"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","ignoreList":[]} \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","PropsWithChildren","Ref","Except","DOMElement","ClickEvent","FocusEvent","KeyboardEvent","Styles","warn","Props","ref","tabIndex","autoFocus","onClick","event","onFocus","onFocusCapture","onBlur","onBlurCapture","onKeyDown","onKeyDownCapture","onMouseEnter","onMouseLeave","Box","t0","$","_c","children","flexDirection","flexGrow","flexShrink","flexWrap","style","t1","t2","t3","t4","t5","t6","t7","t8","t9","t10","t11","t12","t13","t14","t15","t16","t17","t18","undefined","ifNotInteger","margin","marginX","marginY","marginTop","marginBottom","marginLeft","marginRight","padding","paddingX","paddingY","paddingTop","paddingBottom","paddingLeft","paddingRight","gap","columnGap","rowGap","overflowX","overflow","overflowY"],"sources":["Box.tsx"],"sourcesContent":["import '../global.d.ts'\nimport React, { type PropsWithChildren, type Ref } from 'react'\nimport type { Except } from 'type-fest'\nimport type { DOMElement } from '../dom.js'\nimport type { ClickEvent } from '../events/click-event.js'\nimport type { FocusEvent } from '../events/focus-event.js'\nimport type { KeyboardEvent } from '../events/keyboard-event.js'\nimport type { Styles } from '../styles.js'\nimport * as warn from '../warn.js'\n\nexport type Props = Except<Styles, 'textWrap'> & {\n  ref?: Ref<DOMElement>\n  /**\n   * Tab order index. Nodes with `tabIndex >= 0` participate in\n   * Tab/Shift+Tab cycling; `-1` means programmatically focusable only.\n   */\n  tabIndex?: number\n  /**\n   * Focus this element when it mounts. Like the HTML `autofocus`\n   * attribute — the FocusManager calls `focus(node)` during the\n   * reconciler's `commitMount` phase.\n   */\n  autoFocus?: boolean\n  /**\n   * Fired on left-button click (press + release without drag). Only works\n   * inside `<AlternateScreen>` where mouse tracking is enabled — no-op\n   * otherwise. The event bubbles from the deepest hit Box up through\n   * ancestors; call `event.stopImmediatePropagation()` to stop bubbling.\n   */\n  onClick?: (event: ClickEvent) => void\n  onFocus?: (event: FocusEvent) => void\n  onFocusCapture?: (event: FocusEvent) => void\n  onBlur?: (event: FocusEvent) => void\n  onBlurCapture?: (event: FocusEvent) => void\n  onKeyDown?: (event: KeyboardEvent) => void\n  onKeyDownCapture?: (event: KeyboardEvent) => void\n  /**\n   * Fired when the mouse moves into this Box's rendered rect. Like DOM\n   * `mouseenter`, does NOT bubble — moving between children does not\n   * re-fire on the parent. Only works inside `<AlternateScreen>` where\n   * mode-1003 mouse tracking is enabled.\n   */\n  onMouseEnter?: () => void\n  /** Fired when the mouse moves out of this Box's rendered rect. */\n  onMouseLeave?: () => void\n}\n\n/**\n * `<Box>` is an essential Ink component to build your layout. It's like `<div style=\"display: flex\">` in the browser.\n */\nfunction Box({\n  children,\n  flexWrap = 'nowrap',\n  flexDirection = 'row',\n  flexGrow = 0,\n  flexShrink = 1,\n  ref,\n  tabIndex,\n  autoFocus,\n  onClick,\n  onFocus,\n  onFocusCapture,\n  onBlur,\n  onBlurCapture,\n  onMouseEnter,\n  onMouseLeave,\n  onKeyDown,\n  onKeyDownCapture,\n  ...style\n}: PropsWithChildren<Props>): React.ReactNode {\n  // Warn if spacing values are not integers to prevent fractional layout dimensions\n  warn.ifNotInteger(style.margin, 'margin')\n  warn.ifNotInteger(style.marginX, 'marginX')\n  warn.ifNotInteger(style.marginY, 'marginY')\n  warn.ifNotInteger(style.marginTop, 'marginTop')\n  warn.ifNotInteger(style.marginBottom, 'marginBottom')\n  warn.ifNotInteger(style.marginLeft, 'marginLeft')\n  warn.ifNotInteger(style.marginRight, 'marginRight')\n  warn.ifNotInteger(style.padding, 'padding')\n  warn.ifNotInteger(style.paddingX, 'paddingX')\n  warn.ifNotInteger(style.paddingY, 'paddingY')\n  warn.ifNotInteger(style.paddingTop, 'paddingTop')\n  warn.ifNotInteger(style.paddingBottom, 'paddingBottom')\n  warn.ifNotInteger(style.paddingLeft, 'paddingLeft')\n  warn.ifNotInteger(style.paddingRight, 'paddingRight')\n  warn.ifNotInteger(style.gap, 'gap')\n  warn.ifNotInteger(style.columnGap, 'columnGap')\n  warn.ifNotInteger(style.rowGap, 'rowGap')\n\n  return (\n    <ink-box\n      ref={ref}\n      tabIndex={tabIndex}\n      autoFocus={autoFocus}\n      onClick={onClick}\n      onFocus={onFocus}\n      onFocusCapture={onFocusCapture}\n      onBlur={onBlur}\n      onBlurCapture={onBlurCapture}\n      onMouseEnter={onMouseEnter}\n      onMouseLeave={onMouseLeave}\n      onKeyDown={onKeyDown}\n      onKeyDownCapture={onKeyDownCapture}\n      style={{\n        flexWrap,\n        flexDirection,\n        flexGrow,\n        flexShrink,\n        ...style,\n        overflowX: style.overflowX ?? style.overflow ?? 'visible',\n        overflowY: style.overflowY ?? style.overflow ?? 'visible',\n      }}\n    >\n      {children}\n    </ink-box>\n  )\n}\n\nexport default Box\n"],"mappings":";AAAA,OAAO,gBAAgB;AACvB,OAAOA,KAAK,IAAI,KAAKC,iBAAiB,EAAE,KAAKC,GAAG,QAAQ,OAAO;AAC/D,cAAcC,MAAM,QAAQ,WAAW;AACvC,cAAcC,UAAU,QAAQ,WAAW;AAC3C,cAAcC,UAAU,QAAQ,0BAA0B;AAC1D,cAAcC,UAAU,QAAQ,0BAA0B;AAC1D,cAAcC,aAAa,QAAQ,6BAA6B;AAChE,cAAcC,MAAM,QAAQ,cAAc;AAC1C,OAAO,KAAKC,IAAI,MAAM,YAAY;AAElC,OAAO,KAAKC,KAAK,GAAGP,MAAM,CAACK,MAAM,EAAE,UAAU,CAAC,GAAG;EAC/CG,GAAG,CAAC,EAAET,GAAG,CAACE,UAAU,CAAC;EACrB;AACF;AACA;AACA;EACEQ,QAAQ,CAAC,EAAE,MAAM;EACjB;AACF;AACA;AACA;AACA;EACEC,SAAS,CAAC,EAAE,OAAO;EACnB;AACF;AACA;AACA;AACA;AACA;EACEC,OAAO,CAAC,EAAE,CAACC,KAAK,EAAEV,UAAU,EAAE,GAAG,IAAI;EACrCW,OAAO,CAAC,EAAE,CAACD,KAAK,EAAET,UAAU,EAAE,GAAG,IAAI;EACrCW,cAAc,CAAC,EAAE,CAACF,KAAK,EAAET,UAAU,EAAE,GAAG,IAAI;EAC5CY,MAAM,CAAC,EAAE,CAACH,KAAK,EAAET,UAAU,EAAE,GAAG,IAAI;EACpCa,aAAa,CAAC,EAAE,CAACJ,KAAK,EAAET,UAAU,EAAE,GAAG,IAAI;EAC3Cc,SAAS,CAAC,EAAE,CAACL,KAAK,EAAER,aAAa,EAAE,GAAG,IAAI;EAC1Cc,gBAAgB,CAAC,EAAE,CAACN,KAAK,EAAER,aAAa,EAAE,GAAG,IAAI;EACjD;AACF;AACA;AACA;AACA;AACA;EACEe,YAAY,CAAC,EAAE,GAAG,GAAG,IAAI;EACzB;EACAC,YAAY,CAAC,EAAE,GAAG,GAAG,IAAI;AAC3B,CAAC;;AAED;AACA;AACA;AACA,SAAAC,IAAAC,EAAA;EAAA,MAAAC,CAAA,GAAAC,EAAA;EAAA,IAAAd,SAAA;EAAA,IAAAe,QAAA;EAAA,IAAAC,aAAA;EAAA,IAAAC,QAAA;EAAA,IAAAC,UAAA;EAAA,IAAAC,QAAA;EAAA,IAAAd,MAAA;EAAA,IAAAC,aAAA;EAAA,IAAAL,OAAA;EAAA,IAAAE,OAAA;EAAA,IAAAC,cAAA;EAAA,IAAAG,SAAA;EAAA,IAAAC,gBAAA;EAAA,IAAAC,YAAA;EAAA,IAAAC,YAAA;EAAA,IAAAZ,GAAA;EAAA,IAAAsB,KAAA;EAAA,IAAArB,QAAA;EAAA,IAAAc,CAAA,QAAAD,EAAA;IAAa;MAAAG,QAAA,EAAAM,EAAA;MAAAF,QAAA,EAAAG,EAAA;MAAAN,aAAA,EAAAO,EAAA;MAAAN,QAAA,EAAAO,EAAA;MAAAN,UAAA,EAAAO,EAAA;MAAA3B,GAAA,EAAA4B,EAAA;MAAA3B,QAAA,EAAA4B,EAAA;MAAA3B,SAAA,EAAA4B,EAAA;MAAA3B,OAAA,EAAA4B,EAAA;MAAA1B,OAAA,EAAA2B,GAAA;MAAA1B,cAAA,EAAA2B,GAAA;MAAA1B,MAAA,EAAA2B,GAAA;MAAA1B,aAAA,EAAA2B,GAAA;MAAAxB,YAAA,EAAAyB,GAAA;MAAAxB,YAAA,EAAAyB,GAAA;MAAA5B,SAAA,EAAA6B,GAAA;MAAA5B,gBAAA,EAAA6B,GAAA;MAAA,GAAAC;IAAA,IAAA1B,EAmBc;IAnBdG,QAAA,GAAAM,EAAA;IAAAvB,GAAA,GAAA4B,EAAA;IAAA3B,QAAA,GAAA4B,EAAA;IAAA3B,SAAA,GAAA4B,EAAA;IAAA3B,OAAA,GAAA4B,EAAA;IAAA1B,OAAA,GAAA2B,GAAA;IAAA1B,cAAA,GAAA2B,GAAA;IAAA1B,MAAA,GAAA2B,GAAA;IAAA1B,aAAA,GAAA2B,GAAA;IAAAxB,YAAA,GAAAyB,GAAA;IAAAxB,YAAA,GAAAyB,GAAA;IAAA5B,SAAA,GAAA6B,GAAA;IAAA5B,gBAAA,GAAA6B,GAAA;IAAAjB,KAAA,GAAAkB,GAAA;IAEXnB,QAAA,GAAAG,EAAmB,KAAnBiB,SAAmB,GAAnB,QAAmB,GAAnBjB,EAAmB;IACnBN,aAAA,GAAAO,EAAqB,KAArBgB,SAAqB,GAArB,KAAqB,GAArBhB,EAAqB;IACrBN,QAAA,GAAAO,EAAY,KAAZe,SAAY,GAAZ,CAAY,GAAZf,EAAY;IACZN,UAAA,GAAAO,EAAc,KAAdc,SAAc,GAAd,CAAc,GAAdd,EAAc;IAgBd7B,IAAI,CAAA4C,YAAa,CAACpB,KAAK,CAAAqB,MAAO,EAAE,QAAQ,CAAC;IACzC7C,IAAI,CAAA4C,YAAa,CAACpB,KAAK,CAAAsB,OAAQ,EAAE,SAAS,CAAC;IAC3C9C,IAAI,CAAA4C,YAAa,CAACpB,KAAK,CAAAuB,OAAQ,EAAE,SAAS,CAAC;IAC3C/C,IAAI,CAAA4C,YAAa,CAACpB,KAAK,CAAAwB,SAAU,EAAE,WAAW,CAAC;IAC/ChD,IAAI,CAAA4C,YAAa,CAACpB,KAAK,CAAAyB,YAAa,EAAE,cAAc,CAAC;IACrDjD,IAAI,CAAA4C,YAAa,CAACpB,KAAK,CAAA0B,UAAW,EAAE,YAAY,CAAC;IACjDlD,IAAI,CAAA4C,YAAa,CAACpB,KAAK,CAAA2B,WAAY,EAAE,aAAa,CAAC;IACnDnD,IAAI,CAAA4C,YAAa,CAACpB,KAAK,CAAA4B,OAAQ,EAAE,SAAS,CAAC;IAC3CpD,IAAI,CAAA4C,YAAa,CAACpB,KAAK,CAAA6B,QAAS,EAAE,UAAU,CAAC;IAC7CrD,IAAI,CAAA4C,YAAa,CAACpB,KAAK,CAAA8B,QAAS,EAAE,UAAU,CAAC;IAC7CtD,IAAI,CAAA4C,YAAa,CAACpB,KAAK,CAAA+B,UAAW,EAAE,YAAY,CAAC;IACjDvD,IAAI,CAAA4C,YAAa,CAACpB,KAAK,CAAAgC,aAAc,EAAE,eAAe,CAAC;IACvDxD,IAAI,CAAA4C,YAAa,CAACpB,KAAK,CAAAiC,WAAY,EAAE,aAAa,CAAC;IACnDzD,IAAI,CAAA4C,YAAa,CAACpB,KAAK,CAAAkC,YAAa,EAAE,cAAc,CAAC;IACrD1D,IAAI,CAAA4C,YAAa,CAACpB,KAAK,CAAAmC,GAAI,EAAE,KAAK,CAAC;IACnC3D,IAAI,CAAA4C,YAAa,CAACpB,KAAK,CAAAoC,SAAU,EAAE,WAAW,CAAC;IAC/C5D,IAAI,CAAA4C,YAAa,CAACpB,KAAK,CAAAqC,MAAO,EAAE,QAAQ,CAAC;IAAA5C,CAAA,MAAAD,EAAA;IAAAC,CAAA,MAAAb,SAAA;IAAAa,CAAA,MAAAE,QAAA;IAAAF,CAAA,MAAAG,aAAA;IAAAH,CAAA,MAAAI,QAAA;IAAAJ,CAAA,MAAAK,UAAA;IAAAL,CAAA,MAAAM,QAAA;IAAAN,CAAA,MAAAR,MAAA;IAAAQ,CAAA,MAAAP,aAAA;IAAAO,CAAA,MAAAZ,OAAA;IAAAY,CAAA,OAAAV,OAAA;IAAAU,CAAA,OAAAT,cAAA;IAAAS,CAAA,OAAAN,SAAA;IAAAM,CAAA,OAAAL,gBAAA;IAAAK,CAAA,OAAAJ,YAAA;IAAAI,CAAA,OAAAH,YAAA;IAAAG,CAAA,OAAAf,GAAA;IAAAe,CAAA,OAAAO,KAAA;IAAAP,CAAA,OAAAd,QAAA;EAAA;IAAAC,SAAA,GAAAa,CAAA;IAAAE,QAAA,GAAAF,CAAA;IAAAG,aAAA,GAAAH,CAAA;IAAAI,QAAA,GAAAJ,CAAA;IAAAK,UAAA,GAAAL,CAAA;IAAAM,QAAA,GAAAN,CAAA;IAAAR,MAAA,GAAAQ,CAAA;IAAAP,aAAA,GAAAO,CAAA;IAAAZ,OAAA,GAAAY,CAAA;IAAAV,OAAA,GAAAU,CAAA;IAAAT,cAAA,GAAAS,CAAA;IAAAN,SAAA,GAAAM,CAAA;IAAAL,gBAAA,GAAAK,CAAA;IAAAJ,YAAA,GAAAI,CAAA;IAAAH,YAAA,GAAAG,CAAA;IAAAf,GAAA,GAAAe,CAAA;IAAAO,KAAA,GAAAP,CAAA;IAAAd,QAAA,GAAAc,CAAA;EAAA;EAsBxB,MAAAQ,EAAA,GAAAD,KAAK,CAAAsC,SAA4B,IAAdtC,KAAK,CAAAuC,QAAsB,IAA9C,SAA8C;EAC9C,MAAArC,EAAA,GAAAF,KAAK,CAAAwC,SAA4B,IAAdxC,KAAK,CAAAuC,QAAsB,IAA9C,SAA8C;EAAA,IAAApC,EAAA;EAAA,IAAAV,CAAA,SAAAG,aAAA,IAAAH,CAAA,SAAAI,QAAA,IAAAJ,CAAA,SAAAK,UAAA,IAAAL,CAAA,SAAAM,QAAA,IAAAN,CAAA,SAAAO,KAAA,IAAAP,CAAA,SAAAQ,EAAA,IAAAR,CAAA,SAAAS,EAAA;IAPpDC,EAAA;MAAAJ,QAAA;MAAAH,aAAA;MAAAC,QAAA;MAAAC,UAAA;MAAA,GAKFE,KAAK;MAAAsC,SAAA,EACGrC,EAA8C;MAAAuC,SAAA,EAC9CtC;IACb,CAAC;IAAAT,CAAA,OAAAG,aAAA;IAAAH,CAAA,OAAAI,QAAA;IAAAJ,CAAA,OAAAK,UAAA;IAAAL,CAAA,OAAAM,QAAA;IAAAN,CAAA,OAAAO,KAAA;IAAAP,CAAA,OAAAQ,EAAA;IAAAR,CAAA,OAAAS,EAAA;IAAAT,CAAA,OAAAU,EAAA;EAAA;IAAAA,EAAA,GAAAV,CAAA;EAAA;EAAA,IAAAW,EAAA;EAAA,IAAAX,CAAA,SAAAb,SAAA,IAAAa,CAAA,SAAAE,QAAA,IAAAF,CAAA,SAAAR,MAAA,IAAAQ,CAAA,SAAAP,aAAA,IAAAO,CAAA,SAAAZ,OAAA,IAAAY,CAAA,SAAAV,OAAA,IAAAU,CAAA,SAAAT,cAAA,IAAAS,CAAA,SAAAN,SAAA,IAAAM,CAAA,SAAAL,gBAAA,IAAAK,CAAA,SAAAJ,YAAA,IAAAI,CAAA,SAAAH,YAAA,IAAAG,CAAA,SAAAf,GAAA,IAAAe,CAAA,SAAAU,EAAA,IAAAV,CAAA,SAAAd,QAAA;IArBHyB,EAAA,WAwBU,CAvBH1B,GAAG,CAAHA,IAAE,CAAC,CACEC,QAAQ,CAARA,SAAO,CAAC,CACPC,SAAS,CAATA,UAAQ,CAAC,CACXC,OAAO,CAAPA,QAAM,CAAC,CACPE,OAAO,CAAPA,QAAM,CAAC,CACAC,cAAc,CAAdA,eAAa,CAAC,CACtBC,MAAM,CAANA,OAAK,CAAC,CACCC,aAAa,CAAbA,cAAY,CAAC,CACdG,YAAY,CAAZA,aAAW,CAAC,CACZC,YAAY,CAAZA,aAAW,CAAC,CACfH,SAAS,CAATA,UAAQ,CAAC,CACFC,gBAAgB,CAAhBA,iBAAe,CAAC,CAC3B,KAQN,CARM,CAAAe,EAQP,CAAC,CAEAR,SAAO,CACV,EAxBA,OAwBU;IAAAF,CAAA,OAAAb,SAAA;IAAAa,CAAA,OAAAE,QAAA;IAAAF,CAAA,OAAAR,MAAA;IAAAQ,CAAA,OAAAP,aAAA;IAAAO,CAAA,OAAAZ,OAAA;IAAAY,CAAA,OAAAV,OAAA;IAAAU,CAAA,OAAAT,cAAA;IAAAS,CAAA,OAAAN,SAAA;IAAAM,CAAA,OAAAL,gBAAA;IAAAK,CAAA,OAAAJ,YAAA;IAAAI,CAAA,OAAAH,YAAA;IAAAG,CAAA,OAAAf,GAAA;IAAAe,CAAA,OAAAU,EAAA;IAAAV,CAAA,OAAAd,QAAA;IAAAc,CAAA,OAAAW,EAAA;EAAA;IAAAA,EAAA,GAAAX,CAAA;EAAA;EAAA,OAxBVW,EAwBU;AAAA;AAId,eAAeb,GAAG","ignoreList":[]} diff --git a/restored-src/src/ink/components/ScrollBox.tsx b/restored-src/src/ink/components/ScrollBox.tsx index 03e4a31cb..59aa6bb3b 100644 --- a/restored-src/src/ink/components/ScrollBox.tsx +++ b/restored-src/src/ink/components/ScrollBox.tsx @@ -5,7 +5,7 @@ import type { DOMElement } from '../dom.js'; import { markDirty, scheduleRenderFrom } from '../dom.js'; import { markCommitStart } from '../reconciler.js'; import type { Styles } from '../styles.js'; -import '../global.d.ts'; +import type {} from '../global.d.ts'; import Box from './Box.js'; export type ScrollBoxHandle = { scrollTo: (y: number) => void; @@ -234,4 +234,4 @@ function ScrollBox({ ; } export default ScrollBox; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","PropsWithChildren","Ref","useImperativeHandle","useRef","useState","Except","markScrollActivity","DOMElement","markDirty","scheduleRenderFrom","markCommitStart","Styles","Box","ScrollBoxHandle","scrollTo","y","scrollBy","dy","scrollToElement","el","offset","scrollToBottom","getScrollTop","getPendingDelta","getScrollHeight","getFreshScrollHeight","getViewportHeight","getViewportTop","isSticky","subscribe","listener","setClampBounds","min","max","ScrollBoxProps","ref","stickyScroll","ScrollBox","children","style","ReactNode","domRef","forceRender","listenersRef","Set","renderQueuedRef","notify","l","current","scrollMutated","queueMicrotask","pendingScrollDelta","undefined","scrollAnchor","scrollTop","Math","floor","box","n","scrollHeight","content","childNodes","yogaNode","getComputedHeight","scrollViewportHeight","scrollViewportTop","Boolean","attributes","add","delete","scrollClampMin","scrollClampMax","flexWrap","flexDirection","flexGrow","flexShrink","overflowX","overflowY"],"sources":["ScrollBox.tsx"],"sourcesContent":["import React, {\n  type PropsWithChildren,\n  type Ref,\n  useImperativeHandle,\n  useRef,\n  useState,\n} from 'react'\nimport type { Except } from 'type-fest'\nimport { markScrollActivity } from '../../bootstrap/state.js'\nimport type { DOMElement } from '../dom.js'\nimport { markDirty, scheduleRenderFrom } from '../dom.js'\nimport { markCommitStart } from '../reconciler.js'\nimport type { Styles } from '../styles.js'\nimport '../global.d.ts'\nimport Box from './Box.js'\n\nexport type ScrollBoxHandle = {\n  scrollTo: (y: number) => void\n  scrollBy: (dy: number) => void\n  /**\n   * Scroll so `el`'s top is at the viewport top (plus `offset`). Unlike\n   * scrollTo which bakes a number that's stale by the time the throttled\n   * render fires, this defers the position read to render time —\n   * render-node-to-output reads `el.yogaNode.getComputedTop()` in the\n   * SAME Yoga pass that computes scrollHeight. Deterministic. One-shot.\n   */\n  scrollToElement: (el: DOMElement, offset?: number) => void\n  scrollToBottom: () => void\n  getScrollTop: () => number\n  getPendingDelta: () => number\n  getScrollHeight: () => number\n  /**\n   * Like getScrollHeight, but reads Yoga directly instead of the cached\n   * value written by render-node-to-output (throttled, up to 16ms stale).\n   * Use when you need a fresh value in useLayoutEffect after a React commit\n   * that grew content. Slightly more expensive (native Yoga call).\n   */\n  getFreshScrollHeight: () => number\n  getViewportHeight: () => number\n  /**\n   * Absolute screen-buffer row of the first visible content line (inside\n   * padding). Used for drag-to-scroll edge detection.\n   */\n  getViewportTop: () => number\n  /**\n   * True when scroll is pinned to the bottom. Set by scrollToBottom, the\n   * initial stickyScroll attribute, and by the renderer when positional\n   * follow fires (scrollTop at prevMax, content grows). Cleared by\n   * scrollTo/scrollBy. Stable signal for \"at bottom\" that doesn't depend on\n   * layout values (unlike scrollTop+viewportH >= scrollHeight).\n   */\n  isSticky: () => boolean\n  /**\n   * Subscribe to imperative scroll changes (scrollTo/scrollBy/scrollToBottom).\n   * Does NOT fire for stickyScroll updates done by the Ink renderer — those\n   * happen during Ink's render phase after React has committed. Callers that\n   * care about the sticky case should treat \"at bottom\" as a fallback.\n   */\n  subscribe: (listener: () => void) => () => void\n  /**\n   * Set the render-time scrollTop clamp to the currently-mounted children's\n   * coverage span. Called by useVirtualScroll after computing its range;\n   * render-node-to-output clamps scrollTop to [min, max] so burst scrollTo\n   * calls that race past React's async re-render show the edge of mounted\n   * content instead of blank spacer. Pass undefined to disable (sticky,\n   * cold start).\n   */\n  setClampBounds: (min: number | undefined, max: number | undefined) => void\n}\n\nexport type ScrollBoxProps = Except<\n  Styles,\n  'textWrap' | 'overflow' | 'overflowX' | 'overflowY'\n> & {\n  ref?: Ref<ScrollBoxHandle>\n  /**\n   * When true, automatically pins scroll position to the bottom when content\n   * grows. Unset manually via scrollTo/scrollBy to break the stickiness.\n   */\n  stickyScroll?: boolean\n}\n\n/**\n * A Box with `overflow: scroll` and an imperative scroll API.\n *\n * Children are laid out at their full Yoga-computed height inside a\n * constrained container. At render time, only children intersecting the\n * visible window (scrollTop..scrollTop+height) are rendered (viewport\n * culling). Content is translated by -scrollTop and clipped to the box bounds.\n *\n * Works best inside a fullscreen (constrained-height root) Ink tree.\n */\nfunction ScrollBox({\n  children,\n  ref,\n  stickyScroll,\n  ...style\n}: PropsWithChildren<ScrollBoxProps>): React.ReactNode {\n  const domRef = useRef<DOMElement>(null)\n  // scrollTo/scrollBy bypass React: they mutate scrollTop on the DOM node,\n  // mark it dirty, and call the root's throttled scheduleRender directly.\n  // The Ink renderer reads scrollTop from the node — no React state needed,\n  // no reconciler overhead per wheel event. The microtask defer coalesces\n  // multiple scrollBy calls in one input batch (discreteUpdates) into one\n  // render — otherwise scheduleRender's leading edge fires on the FIRST\n  // event before subsequent events mutate scrollTop. scrollToBottom still\n  // forces a React render: sticky is attribute-observed, no DOM-only path.\n  const [, forceRender] = useState(0)\n  const listenersRef = useRef(new Set<() => void>())\n  const renderQueuedRef = useRef(false)\n\n  const notify = () => {\n    for (const l of listenersRef.current) l()\n  }\n\n  function scrollMutated(el: DOMElement): void {\n    // Signal background intervals (IDE poll, LSP poll, GCS fetch, orphan\n    // check) to skip their next tick — they compete for the event loop and\n    // contributed to 1402ms max frame gaps during scroll drain.\n    markScrollActivity()\n    markDirty(el)\n    markCommitStart()\n    notify()\n    if (renderQueuedRef.current) return\n    renderQueuedRef.current = true\n    queueMicrotask(() => {\n      renderQueuedRef.current = false\n      scheduleRenderFrom(el)\n    })\n  }\n\n  useImperativeHandle(\n    ref,\n    (): ScrollBoxHandle => ({\n      scrollTo(y: number) {\n        const el = domRef.current\n        if (!el) return\n        // Explicit false overrides the DOM attribute so manual scroll\n        // breaks stickiness. Render code checks ?? precedence.\n        el.stickyScroll = false\n        el.pendingScrollDelta = undefined\n        el.scrollAnchor = undefined\n        el.scrollTop = Math.max(0, Math.floor(y))\n        scrollMutated(el)\n      },\n      scrollToElement(el: DOMElement, offset = 0) {\n        const box = domRef.current\n        if (!box) return\n        box.stickyScroll = false\n        box.pendingScrollDelta = undefined\n        box.scrollAnchor = { el, offset }\n        scrollMutated(box)\n      },\n      scrollBy(dy: number) {\n        const el = domRef.current\n        if (!el) return\n        el.stickyScroll = false\n        // Wheel input cancels any in-flight anchor seek — user override.\n        el.scrollAnchor = undefined\n        // Accumulate in pendingScrollDelta; renderer drains it at a capped\n        // rate so fast flicks show intermediate frames. Pure accumulator:\n        // scroll-up followed by scroll-down naturally cancels.\n        el.pendingScrollDelta = (el.pendingScrollDelta ?? 0) + Math.floor(dy)\n        scrollMutated(el)\n      },\n      scrollToBottom() {\n        const el = domRef.current\n        if (!el) return\n        el.pendingScrollDelta = undefined\n        el.stickyScroll = true\n        markDirty(el)\n        notify()\n        forceRender(n => n + 1)\n      },\n      getScrollTop() {\n        return domRef.current?.scrollTop ?? 0\n      },\n      getPendingDelta() {\n        // Accumulated-but-not-yet-drained delta. useVirtualScroll needs\n        // this to mount the union [committed, committed+pending] range —\n        // otherwise intermediate drain frames find no children (blank).\n        return domRef.current?.pendingScrollDelta ?? 0\n      },\n      getScrollHeight() {\n        return domRef.current?.scrollHeight ?? 0\n      },\n      getFreshScrollHeight() {\n        const content = domRef.current?.childNodes[0] as DOMElement | undefined\n        return (\n          content?.yogaNode?.getComputedHeight() ??\n          domRef.current?.scrollHeight ??\n          0\n        )\n      },\n      getViewportHeight() {\n        return domRef.current?.scrollViewportHeight ?? 0\n      },\n      getViewportTop() {\n        return domRef.current?.scrollViewportTop ?? 0\n      },\n      isSticky() {\n        const el = domRef.current\n        if (!el) return false\n        return el.stickyScroll ?? Boolean(el.attributes['stickyScroll'])\n      },\n      subscribe(listener: () => void) {\n        listenersRef.current.add(listener)\n        return () => listenersRef.current.delete(listener)\n      },\n      setClampBounds(min, max) {\n        const el = domRef.current\n        if (!el) return\n        el.scrollClampMin = min\n        el.scrollClampMax = max\n      },\n    }),\n    // notify/scrollMutated are inline (no useCallback) but only close over\n    // refs + imports — stable. Empty deps avoids rebuilding the handle on\n    // every render (which re-registers the ref = churn).\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n    [],\n  )\n\n  // Structure: outer viewport (overflow:scroll, constrained height) >\n  // inner content (flexGrow:1, flexShrink:0 — fills at least the viewport\n  // but grows beyond it for tall content). flexGrow:1 lets children use\n  // spacers to pin elements to the bottom of the scroll area. Yoga's\n  // Overflow.Scroll prevents the viewport from growing to fit the content.\n  // The renderer computes scrollHeight from the content box and culls\n  // content's children based on scrollTop.\n  //\n  // stickyScroll is passed as a DOM attribute (via ink-box directly) so it's\n  // available on the first render — ref callbacks fire after the initial\n  // commit, which is too late for the first frame.\n  return (\n    <ink-box\n      ref={el => {\n        domRef.current = el\n        if (el) el.scrollTop ??= 0\n      }}\n      style={{\n        flexWrap: 'nowrap',\n        flexDirection: style.flexDirection ?? 'row',\n        flexGrow: style.flexGrow ?? 0,\n        flexShrink: style.flexShrink ?? 1,\n        ...style,\n        overflowX: 'scroll',\n        overflowY: 'scroll',\n      }}\n      {...(stickyScroll ? { stickyScroll: true } : {})}\n    >\n      <Box flexDirection=\"column\" flexGrow={1} flexShrink={0} width=\"100%\">\n        {children}\n      </Box>\n    </ink-box>\n  )\n}\n\nexport default ScrollBox\n"],"mappings":"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","ignoreList":[]} \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","PropsWithChildren","Ref","useImperativeHandle","useRef","useState","Except","markScrollActivity","DOMElement","markDirty","scheduleRenderFrom","markCommitStart","Styles","Box","ScrollBoxHandle","scrollTo","y","scrollBy","dy","scrollToElement","el","offset","scrollToBottom","getScrollTop","getPendingDelta","getScrollHeight","getFreshScrollHeight","getViewportHeight","getViewportTop","isSticky","subscribe","listener","setClampBounds","min","max","ScrollBoxProps","ref","stickyScroll","ScrollBox","children","style","ReactNode","domRef","forceRender","listenersRef","Set","renderQueuedRef","notify","l","current","scrollMutated","queueMicrotask","pendingScrollDelta","undefined","scrollAnchor","scrollTop","Math","floor","box","n","scrollHeight","content","childNodes","yogaNode","getComputedHeight","scrollViewportHeight","scrollViewportTop","Boolean","attributes","add","delete","scrollClampMin","scrollClampMax","flexWrap","flexDirection","flexGrow","flexShrink","overflowX","overflowY"],"sources":["ScrollBox.tsx"],"sourcesContent":["import React, {\n  type PropsWithChildren,\n  type Ref,\n  useImperativeHandle,\n  useRef,\n  useState,\n} from 'react'\nimport type { Except } from 'type-fest'\nimport { markScrollActivity } from '../../bootstrap/state.js'\nimport type { DOMElement } from '../dom.js'\nimport { markDirty, scheduleRenderFrom } from '../dom.js'\nimport { markCommitStart } from '../reconciler.js'\nimport type { Styles } from '../styles.js'\nimport '../global.d.ts'\nimport Box from './Box.js'\n\nexport type ScrollBoxHandle = {\n  scrollTo: (y: number) => void\n  scrollBy: (dy: number) => void\n  /**\n   * Scroll so `el`'s top is at the viewport top (plus `offset`). Unlike\n   * scrollTo which bakes a number that's stale by the time the throttled\n   * render fires, this defers the position read to render time —\n   * render-node-to-output reads `el.yogaNode.getComputedTop()` in the\n   * SAME Yoga pass that computes scrollHeight. Deterministic. One-shot.\n   */\n  scrollToElement: (el: DOMElement, offset?: number) => void\n  scrollToBottom: () => void\n  getScrollTop: () => number\n  getPendingDelta: () => number\n  getScrollHeight: () => number\n  /**\n   * Like getScrollHeight, but reads Yoga directly instead of the cached\n   * value written by render-node-to-output (throttled, up to 16ms stale).\n   * Use when you need a fresh value in useLayoutEffect after a React commit\n   * that grew content. Slightly more expensive (native Yoga call).\n   */\n  getFreshScrollHeight: () => number\n  getViewportHeight: () => number\n  /**\n   * Absolute screen-buffer row of the first visible content line (inside\n   * padding). Used for drag-to-scroll edge detection.\n   */\n  getViewportTop: () => number\n  /**\n   * True when scroll is pinned to the bottom. Set by scrollToBottom, the\n   * initial stickyScroll attribute, and by the renderer when positional\n   * follow fires (scrollTop at prevMax, content grows). Cleared by\n   * scrollTo/scrollBy. Stable signal for \"at bottom\" that doesn't depend on\n   * layout values (unlike scrollTop+viewportH >= scrollHeight).\n   */\n  isSticky: () => boolean\n  /**\n   * Subscribe to imperative scroll changes (scrollTo/scrollBy/scrollToBottom).\n   * Does NOT fire for stickyScroll updates done by the Ink renderer — those\n   * happen during Ink's render phase after React has committed. Callers that\n   * care about the sticky case should treat \"at bottom\" as a fallback.\n   */\n  subscribe: (listener: () => void) => () => void\n  /**\n   * Set the render-time scrollTop clamp to the currently-mounted children's\n   * coverage span. Called by useVirtualScroll after computing its range;\n   * render-node-to-output clamps scrollTop to [min, max] so burst scrollTo\n   * calls that race past React's async re-render show the edge of mounted\n   * content instead of blank spacer. Pass undefined to disable (sticky,\n   * cold start).\n   */\n  setClampBounds: (min: number | undefined, max: number | undefined) => void\n}\n\nexport type ScrollBoxProps = Except<\n  Styles,\n  'textWrap' | 'overflow' | 'overflowX' | 'overflowY'\n> & {\n  ref?: Ref<ScrollBoxHandle>\n  /**\n   * When true, automatically pins scroll position to the bottom when content\n   * grows. Unset manually via scrollTo/scrollBy to break the stickiness.\n   */\n  stickyScroll?: boolean\n}\n\n/**\n * A Box with `overflow: scroll` and an imperative scroll API.\n *\n * Children are laid out at their full Yoga-computed height inside a\n * constrained container. At render time, only children intersecting the\n * visible window (scrollTop..scrollTop+height) are rendered (viewport\n * culling). Content is translated by -scrollTop and clipped to the box bounds.\n *\n * Works best inside a fullscreen (constrained-height root) Ink tree.\n */\nfunction ScrollBox({\n  children,\n  ref,\n  stickyScroll,\n  ...style\n}: PropsWithChildren<ScrollBoxProps>): React.ReactNode {\n  const domRef = useRef<DOMElement>(null)\n  // scrollTo/scrollBy bypass React: they mutate scrollTop on the DOM node,\n  // mark it dirty, and call the root's throttled scheduleRender directly.\n  // The Ink renderer reads scrollTop from the node — no React state needed,\n  // no reconciler overhead per wheel event. The microtask defer coalesces\n  // multiple scrollBy calls in one input batch (discreteUpdates) into one\n  // render — otherwise scheduleRender's leading edge fires on the FIRST\n  // event before subsequent events mutate scrollTop. scrollToBottom still\n  // forces a React render: sticky is attribute-observed, no DOM-only path.\n  const [, forceRender] = useState(0)\n  const listenersRef = useRef(new Set<() => void>())\n  const renderQueuedRef = useRef(false)\n\n  const notify = () => {\n    for (const l of listenersRef.current) l()\n  }\n\n  function scrollMutated(el: DOMElement): void {\n    // Signal background intervals (IDE poll, LSP poll, GCS fetch, orphan\n    // check) to skip their next tick — they compete for the event loop and\n    // contributed to 1402ms max frame gaps during scroll drain.\n    markScrollActivity()\n    markDirty(el)\n    markCommitStart()\n    notify()\n    if (renderQueuedRef.current) return\n    renderQueuedRef.current = true\n    queueMicrotask(() => {\n      renderQueuedRef.current = false\n      scheduleRenderFrom(el)\n    })\n  }\n\n  useImperativeHandle(\n    ref,\n    (): ScrollBoxHandle => ({\n      scrollTo(y: number) {\n        const el = domRef.current\n        if (!el) return\n        // Explicit false overrides the DOM attribute so manual scroll\n        // breaks stickiness. Render code checks ?? precedence.\n        el.stickyScroll = false\n        el.pendingScrollDelta = undefined\n        el.scrollAnchor = undefined\n        el.scrollTop = Math.max(0, Math.floor(y))\n        scrollMutated(el)\n      },\n      scrollToElement(el: DOMElement, offset = 0) {\n        const box = domRef.current\n        if (!box) return\n        box.stickyScroll = false\n        box.pendingScrollDelta = undefined\n        box.scrollAnchor = { el, offset }\n        scrollMutated(box)\n      },\n      scrollBy(dy: number) {\n        const el = domRef.current\n        if (!el) return\n        el.stickyScroll = false\n        // Wheel input cancels any in-flight anchor seek — user override.\n        el.scrollAnchor = undefined\n        // Accumulate in pendingScrollDelta; renderer drains it at a capped\n        // rate so fast flicks show intermediate frames. Pure accumulator:\n        // scroll-up followed by scroll-down naturally cancels.\n        el.pendingScrollDelta = (el.pendingScrollDelta ?? 0) + Math.floor(dy)\n        scrollMutated(el)\n      },\n      scrollToBottom() {\n        const el = domRef.current\n        if (!el) return\n        el.pendingScrollDelta = undefined\n        el.stickyScroll = true\n        markDirty(el)\n        notify()\n        forceRender(n => n + 1)\n      },\n      getScrollTop() {\n        return domRef.current?.scrollTop ?? 0\n      },\n      getPendingDelta() {\n        // Accumulated-but-not-yet-drained delta. useVirtualScroll needs\n        // this to mount the union [committed, committed+pending] range —\n        // otherwise intermediate drain frames find no children (blank).\n        return domRef.current?.pendingScrollDelta ?? 0\n      },\n      getScrollHeight() {\n        return domRef.current?.scrollHeight ?? 0\n      },\n      getFreshScrollHeight() {\n        const content = domRef.current?.childNodes[0] as DOMElement | undefined\n        return (\n          content?.yogaNode?.getComputedHeight() ??\n          domRef.current?.scrollHeight ??\n          0\n        )\n      },\n      getViewportHeight() {\n        return domRef.current?.scrollViewportHeight ?? 0\n      },\n      getViewportTop() {\n        return domRef.current?.scrollViewportTop ?? 0\n      },\n      isSticky() {\n        const el = domRef.current\n        if (!el) return false\n        return el.stickyScroll ?? Boolean(el.attributes['stickyScroll'])\n      },\n      subscribe(listener: () => void) {\n        listenersRef.current.add(listener)\n        return () => listenersRef.current.delete(listener)\n      },\n      setClampBounds(min, max) {\n        const el = domRef.current\n        if (!el) return\n        el.scrollClampMin = min\n        el.scrollClampMax = max\n      },\n    }),\n    // notify/scrollMutated are inline (no useCallback) but only close over\n    // refs + imports — stable. Empty deps avoids rebuilding the handle on\n    // every render (which re-registers the ref = churn).\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n    [],\n  )\n\n  // Structure: outer viewport (overflow:scroll, constrained height) >\n  // inner content (flexGrow:1, flexShrink:0 — fills at least the viewport\n  // but grows beyond it for tall content). flexGrow:1 lets children use\n  // spacers to pin elements to the bottom of the scroll area. Yoga's\n  // Overflow.Scroll prevents the viewport from growing to fit the content.\n  // The renderer computes scrollHeight from the content box and culls\n  // content's children based on scrollTop.\n  //\n  // stickyScroll is passed as a DOM attribute (via ink-box directly) so it's\n  // available on the first render — ref callbacks fire after the initial\n  // commit, which is too late for the first frame.\n  return (\n    <ink-box\n      ref={el => {\n        domRef.current = el\n        if (el) el.scrollTop ??= 0\n      }}\n      style={{\n        flexWrap: 'nowrap',\n        flexDirection: style.flexDirection ?? 'row',\n        flexGrow: style.flexGrow ?? 0,\n        flexShrink: style.flexShrink ?? 1,\n        ...style,\n        overflowX: 'scroll',\n        overflowY: 'scroll',\n      }}\n      {...(stickyScroll ? { stickyScroll: true } : {})}\n    >\n      <Box flexDirection=\"column\" flexGrow={1} flexShrink={0} width=\"100%\">\n        {children}\n      </Box>\n    </ink-box>\n  )\n}\n\nexport default ScrollBox\n"],"mappings":"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","ignoreList":[]} diff --git a/restored-src/src/ink/global.d.ts b/restored-src/src/ink/global.d.ts new file mode 100644 index 000000000..336ce12bb --- /dev/null +++ b/restored-src/src/ink/global.d.ts @@ -0,0 +1 @@ +export {} diff --git a/restored-src/src/native-ts/color-diff/index.ts b/restored-src/src/native-ts/color-diff/index.ts index d2757d3d1..dcedbc3db 100644 --- a/restored-src/src/native-ts/color-diff/index.ts +++ b/restored-src/src/native-ts/color-diff/index.ts @@ -17,7 +17,7 @@ * getSyntaxTheme always returns the default for the given Claude theme. */ -import { diffArrays } from 'diff' +import { diffArrays } from 'diff/libesm/diff/array.js' import type * as hljsNamespace from 'highlight.js' import { basename, extname } from 'path' diff --git a/restored-src/src/services/analytics/firstPartyEventLogger.ts b/restored-src/src/services/analytics/firstPartyEventLogger.ts index e3a501d74..18578683d 100644 --- a/restored-src/src/services/analytics/firstPartyEventLogger.ts +++ b/restored-src/src/services/analytics/firstPartyEventLogger.ts @@ -9,7 +9,7 @@ import { ATTR_SERVICE_VERSION, } from '@opentelemetry/semantic-conventions' import { randomUUID } from 'crypto' -import { isEqual } from 'lodash-es' +import isEqual from 'lodash-es/isEqual.js' import { getOrCreateUserID } from '../../utils/config.js' import { logForDebugging } from '../../utils/debug.js' import { logError } from '../../utils/log.js' diff --git a/restored-src/src/services/analytics/growthbook.ts b/restored-src/src/services/analytics/growthbook.ts index c71bba849..c36f20d2e 100644 --- a/restored-src/src/services/analytics/growthbook.ts +++ b/restored-src/src/services/analytics/growthbook.ts @@ -1,5 +1,6 @@ -import { GrowthBook } from '@growthbook/growthbook' -import { isEqual, memoize } from 'lodash-es' +import { GrowthBook } from '@growthbook/growthbook/dist/esm/GrowthBook.mjs' +import isEqual from 'lodash-es/isEqual.js' +import memoize from 'lodash-es/memoize.js' import { getIsNonInteractiveSession, getSessionTrustAccepted, diff --git a/restored-src/src/services/api/promptCacheBreakDetection.ts b/restored-src/src/services/api/promptCacheBreakDetection.ts index 1599d537e..90151d28b 100644 --- a/restored-src/src/services/api/promptCacheBreakDetection.ts +++ b/restored-src/src/services/api/promptCacheBreakDetection.ts @@ -1,6 +1,6 @@ import type { BetaToolUnion } from '@anthropic-ai/sdk/resources/beta/messages/messages.mjs' import type { TextBlockParam } from '@anthropic-ai/sdk/resources/index.mjs' -import { createPatch } from 'diff' +import { createPatch } from 'diff/libesm/patch/create.js' import { mkdir, writeFile } from 'fs/promises' import { join } from 'path' import type { AgentId } from 'src/types/ids.js' diff --git a/restored-src/src/skills/bundled/claudeApiContent.ts b/restored-src/src/skills/bundled/claudeApiContent.ts index cba76a3b3..7baf6fc84 100644 --- a/restored-src/src/skills/bundled/claudeApiContent.ts +++ b/restored-src/src/skills/bundled/claudeApiContent.ts @@ -1,38 +1,6 @@ -// Content for the claude-api bundled skill. -// Each .md file is inlined as a string at build time via Bun's text loader. +// Restored source builds do not include the bundled Claude API markdown +// documentation tree. Provide placeholders so skill registration can load. -import csharpClaudeApi from './claude-api/csharp/claude-api.md' -import curlExamples from './claude-api/curl/examples.md' -import goClaudeApi from './claude-api/go/claude-api.md' -import javaClaudeApi from './claude-api/java/claude-api.md' -import phpClaudeApi from './claude-api/php/claude-api.md' -import pythonAgentSdkPatterns from './claude-api/python/agent-sdk/patterns.md' -import pythonAgentSdkReadme from './claude-api/python/agent-sdk/README.md' -import pythonClaudeApiBatches from './claude-api/python/claude-api/batches.md' -import pythonClaudeApiFilesApi from './claude-api/python/claude-api/files-api.md' -import pythonClaudeApiReadme from './claude-api/python/claude-api/README.md' -import pythonClaudeApiStreaming from './claude-api/python/claude-api/streaming.md' -import pythonClaudeApiToolUse from './claude-api/python/claude-api/tool-use.md' -import rubyClaudeApi from './claude-api/ruby/claude-api.md' -import skillPrompt from './claude-api/SKILL.md' -import sharedErrorCodes from './claude-api/shared/error-codes.md' -import sharedLiveSources from './claude-api/shared/live-sources.md' -import sharedModels from './claude-api/shared/models.md' -import sharedPromptCaching from './claude-api/shared/prompt-caching.md' -import sharedToolUseConcepts from './claude-api/shared/tool-use-concepts.md' -import typescriptAgentSdkPatterns from './claude-api/typescript/agent-sdk/patterns.md' -import typescriptAgentSdkReadme from './claude-api/typescript/agent-sdk/README.md' -import typescriptClaudeApiBatches from './claude-api/typescript/claude-api/batches.md' -import typescriptClaudeApiFilesApi from './claude-api/typescript/claude-api/files-api.md' -import typescriptClaudeApiReadme from './claude-api/typescript/claude-api/README.md' -import typescriptClaudeApiStreaming from './claude-api/typescript/claude-api/streaming.md' -import typescriptClaudeApiToolUse from './claude-api/typescript/claude-api/tool-use.md' - -// @[MODEL LAUNCH]: Update the model IDs/names below. These are substituted into {{VAR}} -// placeholders in the .md files at runtime before the skill prompt is sent. -// After updating these constants, manually update the two files that still hardcode models: -// - claude-api/SKILL.md (Current Models pricing table) -// - claude-api/shared/models.md (full model catalog with legacy versions and alias mappings) export const SKILL_MODEL_VARS = { OPUS_ID: 'claude-opus-4-6', OPUS_NAME: 'Claude Opus 4.6', @@ -40,36 +8,15 @@ export const SKILL_MODEL_VARS = { SONNET_NAME: 'Claude Sonnet 4.6', HAIKU_ID: 'claude-haiku-4-5', HAIKU_NAME: 'Claude Haiku 4.5', - // Previous Sonnet ID — used in "do not append date suffixes" example in SKILL.md. PREV_SONNET_ID: 'claude-sonnet-4-5', } satisfies Record -export const SKILL_PROMPT: string = skillPrompt +export const SKILL_PROMPT = `# Claude API + +Bundled Claude API documentation is unavailable in this restored source build. +` export const SKILL_FILES: Record = { - 'csharp/claude-api.md': csharpClaudeApi, - 'curl/examples.md': curlExamples, - 'go/claude-api.md': goClaudeApi, - 'java/claude-api.md': javaClaudeApi, - 'php/claude-api.md': phpClaudeApi, - 'python/agent-sdk/README.md': pythonAgentSdkReadme, - 'python/agent-sdk/patterns.md': pythonAgentSdkPatterns, - 'python/claude-api/README.md': pythonClaudeApiReadme, - 'python/claude-api/batches.md': pythonClaudeApiBatches, - 'python/claude-api/files-api.md': pythonClaudeApiFilesApi, - 'python/claude-api/streaming.md': pythonClaudeApiStreaming, - 'python/claude-api/tool-use.md': pythonClaudeApiToolUse, - 'ruby/claude-api.md': rubyClaudeApi, - 'shared/error-codes.md': sharedErrorCodes, - 'shared/live-sources.md': sharedLiveSources, - 'shared/models.md': sharedModels, - 'shared/prompt-caching.md': sharedPromptCaching, - 'shared/tool-use-concepts.md': sharedToolUseConcepts, - 'typescript/agent-sdk/README.md': typescriptAgentSdkReadme, - 'typescript/agent-sdk/patterns.md': typescriptAgentSdkPatterns, - 'typescript/claude-api/README.md': typescriptClaudeApiReadme, - 'typescript/claude-api/batches.md': typescriptClaudeApiBatches, - 'typescript/claude-api/files-api.md': typescriptClaudeApiFilesApi, - 'typescript/claude-api/streaming.md': typescriptClaudeApiStreaming, - 'typescript/claude-api/tool-use.md': typescriptClaudeApiToolUse, + 'shared/live-sources.md': + 'Bundled Claude API reference files are unavailable in this restored source build.\n', } diff --git a/restored-src/src/skills/bundled/verifyContent.ts b/restored-src/src/skills/bundled/verifyContent.ts index a90044fdd..8088e60c8 100644 --- a/restored-src/src/skills/bundled/verifyContent.ts +++ b/restored-src/src/skills/bundled/verifyContent.ts @@ -1,13 +1,18 @@ -// Content for the verify bundled skill. -// Each .md file is inlined as a string at build time via Bun's text loader. +// Restored source builds do not include the bundled markdown assets that the +// official build inlines here. Keep the module surface intact with placeholders. -import cliMd from './verify/examples/cli.md' -import serverMd from './verify/examples/server.md' -import skillMd from './verify/SKILL.md' +export const SKILL_MD = `--- +description: Verify a code change does what it should by running the app. +--- -export const SKILL_MD: string = skillMd +# Verify + +Bundled verify skill content is unavailable in this restored source build. +` export const SKILL_FILES: Record = { - 'examples/cli.md': cliMd, - 'examples/server.md': serverMd, + 'examples/cli.md': + 'CLI verification example is unavailable in this restored source build.\n', + 'examples/server.md': + 'Server verification example is unavailable in this restored source build.\n', } diff --git a/restored-src/src/tools/FileEditTool/utils.ts b/restored-src/src/tools/FileEditTool/utils.ts index 2520ed553..1a4362ce8 100644 --- a/restored-src/src/tools/FileEditTool/utils.ts +++ b/restored-src/src/tools/FileEditTool/utils.ts @@ -1,4 +1,5 @@ -import { type StructuredPatchHunk, structuredPatch } from 'diff' +import type { StructuredPatchHunk } from 'diff' +import { structuredPatch } from 'diff/libesm/patch/create.js' import { logError } from 'src/utils/log.js' import { expandPath } from 'src/utils/path.js' import { countCharInString } from 'src/utils/stringUtils.js' diff --git a/restored-src/src/tools/SkillTool/prompt.ts b/restored-src/src/tools/SkillTool/prompt.ts index b05a58f3d..1bd61fa07 100644 --- a/restored-src/src/tools/SkillTool/prompt.ts +++ b/restored-src/src/tools/SkillTool/prompt.ts @@ -1,4 +1,4 @@ -import { memoize } from 'lodash-es' +import memoize from 'lodash-es/memoize.js' import type { Command } from 'src/commands.js' import { getCommandName, diff --git a/restored-src/src/tools/TungstenTool/TungstenLiveMonitor.tsx b/restored-src/src/tools/TungstenTool/TungstenLiveMonitor.tsx new file mode 100644 index 000000000..1340073be --- /dev/null +++ b/restored-src/src/tools/TungstenTool/TungstenLiveMonitor.tsx @@ -0,0 +1,3 @@ +export function TungstenLiveMonitor() { + return null +} diff --git a/restored-src/src/tools/TungstenTool/TungstenTool.ts b/restored-src/src/tools/TungstenTool/TungstenTool.ts new file mode 100644 index 000000000..5e37fb727 --- /dev/null +++ b/restored-src/src/tools/TungstenTool/TungstenTool.ts @@ -0,0 +1,40 @@ +import { z } from 'zod/v4' + +const UNAVAILABLE_MESSAGE = + 'TungstenTool is unavailable in this restored source build.' + +const inputSchema = z.object({}).passthrough() + +export const TungstenTool = { + name: 'TungstenTool', + inputSchema, + maxResultSizeChars: 0, + async call() { + throw new Error(UNAVAILABLE_MESSAGE) + }, + async checkPermissions() { + throw new Error(UNAVAILABLE_MESSAGE) + }, + async description() { + return UNAVAILABLE_MESSAGE + }, + async prompt() { + return UNAVAILABLE_MESSAGE + }, + isConcurrencySafe() { + return true + }, + isEnabled() { + return false + }, + isReadOnly() { + return false + }, + userFacingName() { + return 'TungstenTool' + }, +} + +export function clearSessionsWithTungstenUsage(): void {} + +export function resetInitializationState(): void {} diff --git a/restored-src/src/tools/WorkflowTool/WorkflowPermissionRequest.tsx b/restored-src/src/tools/WorkflowTool/WorkflowPermissionRequest.tsx new file mode 100644 index 000000000..f1b153ac9 --- /dev/null +++ b/restored-src/src/tools/WorkflowTool/WorkflowPermissionRequest.tsx @@ -0,0 +1,3 @@ +export function WorkflowPermissionRequest() { + return null +} diff --git a/restored-src/src/tools/WorkflowTool/WorkflowTool.ts b/restored-src/src/tools/WorkflowTool/WorkflowTool.ts new file mode 100644 index 000000000..69cfdd346 --- /dev/null +++ b/restored-src/src/tools/WorkflowTool/WorkflowTool.ts @@ -0,0 +1,35 @@ +import { z } from 'zod/v4' +import { WORKFLOW_TOOL_NAME } from './constants.js' + +const UNAVAILABLE_MESSAGE = + 'WorkflowTool is unavailable in this restored source build.' + +export const WorkflowTool = { + name: WORKFLOW_TOOL_NAME, + inputSchema: z.object({}).passthrough(), + maxResultSizeChars: 0, + async call() { + throw new Error(UNAVAILABLE_MESSAGE) + }, + async checkPermissions() { + throw new Error(UNAVAILABLE_MESSAGE) + }, + async description() { + return UNAVAILABLE_MESSAGE + }, + async prompt() { + return UNAVAILABLE_MESSAGE + }, + isConcurrencySafe() { + return true + }, + isEnabled() { + return false + }, + isReadOnly() { + return false + }, + userFacingName() { + return WORKFLOW_TOOL_NAME + }, +} diff --git a/restored-src/src/tools/WorkflowTool/bundled/index.js b/restored-src/src/tools/WorkflowTool/bundled/index.js new file mode 100644 index 000000000..ea54c8246 --- /dev/null +++ b/restored-src/src/tools/WorkflowTool/bundled/index.js @@ -0,0 +1 @@ +export function initBundledWorkflows() {} diff --git a/restored-src/src/tools/WorkflowTool/constants.ts b/restored-src/src/tools/WorkflowTool/constants.ts new file mode 100644 index 000000000..473d974fa --- /dev/null +++ b/restored-src/src/tools/WorkflowTool/constants.ts @@ -0,0 +1 @@ +export const WORKFLOW_TOOL_NAME = 'WorkflowTool' diff --git a/restored-src/src/tools/WorkflowTool/createWorkflowCommand.ts b/restored-src/src/tools/WorkflowTool/createWorkflowCommand.ts new file mode 100644 index 000000000..a042354d1 --- /dev/null +++ b/restored-src/src/tools/WorkflowTool/createWorkflowCommand.ts @@ -0,0 +1,3 @@ +export function getWorkflowCommands() { + return [] +} diff --git a/restored-src/src/types/connectorText.ts b/restored-src/src/types/connectorText.ts new file mode 100644 index 000000000..0b99904fe --- /dev/null +++ b/restored-src/src/types/connectorText.ts @@ -0,0 +1,22 @@ +export type ConnectorTextBlock = { + type: 'connector_text' + connector_text: string +} + +export type ConnectorTextDelta = { + type: 'connector_text_delta' + connector_text: string +} + +export function isConnectorTextBlock( + value: unknown, +): value is ConnectorTextBlock { + return ( + typeof value === 'object' && + value !== null && + 'type' in value && + (value as { type?: unknown }).type === 'connector_text' && + 'connector_text' in value && + typeof (value as { connector_text?: unknown }).connector_text === 'string' + ) +} diff --git a/restored-src/src/utils/diff.ts b/restored-src/src/utils/diff.ts index 38e7c1bf6..24628d74e 100644 --- a/restored-src/src/utils/diff.ts +++ b/restored-src/src/utils/diff.ts @@ -1,4 +1,5 @@ -import { type StructuredPatchHunk, structuredPatch } from 'diff' +import type { StructuredPatchHunk } from 'diff' +import { structuredPatch } from 'diff/libesm/patch/create.js' import { logEvent } from 'src/services/analytics/index.js' import { getLocCounter } from '../bootstrap/state.js' import { addToTotalLinesChanged } from '../cost-tracker.js' diff --git a/restored-src/src/utils/execFileNoThrow.ts b/restored-src/src/utils/execFileNoThrow.ts index c21a6f01d..fbe0fbdb0 100644 --- a/restored-src/src/utils/execFileNoThrow.ts +++ b/restored-src/src/utils/execFileNoThrow.ts @@ -1,8 +1,9 @@ -// This file represents useful wrappers over node:child_process -// These wrappers ease error handling and cross-platform compatbility -// By using execa, Windows automatically gets shell escaping + BAT / CMD handling +// This file represents useful wrappers over node:child_process. +// It intentionally avoids shell semantics by default: callers pass an +// executable plus argv, so spawning the file directly is both safer and more +// predictable than routing through cross-spawn/cmd.exe. -import { type ExecaError, execa } from 'execa' +import { spawn } from 'child_process' import { getCwd } from '../utils/cwd.js' import { logError } from './log.js' @@ -106,45 +107,123 @@ export function execFileNoThrowWithCwd( }, ): Promise<{ stdout: string; stderr: string; code: number; error?: string }> { return new Promise(resolve => { - // Use execa for cross-platform .bat/.cmd compatibility on Windows - execa(file, args, { - maxBuffer, - signal: abortSignal, - timeout: finalTimeout, - cwd: finalCwd, - env: finalEnv, - shell, - stdin: finalStdin, - input: finalInput, - reject: false, // Don't throw on non-zero exit codes - }) - .then(result => { - if (result.failed) { - if (finalPreserveOutput) { - const errorCode = result.exitCode ?? 1 - void resolve({ - stdout: result.stdout || '', - stderr: result.stderr || '', - code: errorCode, - error: getErrorMessage( - result as unknown as ExecaResultWithError, - errorCode, - ), - }) - } else { - void resolve({ stdout: '', stderr: '', code: result.exitCode ?? 1 }) - } - } else { - void resolve({ - stdout: result.stdout, - stderr: result.stderr, - code: 0, - }) - } + const stdinMode = finalInput !== undefined ? 'pipe' : (finalStdin ?? 'pipe') + let child + try { + child = spawn(file, args, { + cwd: finalCwd, + env: finalEnv, + shell, + signal: abortSignal, + stdio: [stdinMode, 'pipe', 'pipe'], + windowsHide: true, }) - .catch((error: ExecaError) => { - logError(error) - void resolve({ stdout: '', stderr: '', code: 1 }) + } catch (error) { + logError(error) + resolve({ + stdout: '', + stderr: '', + code: 1, + error: error instanceof Error ? error.message : String(error), }) + return + } + + let stdout = '' + let stderr = '' + let settled = false + let timedOut = false + let timer: ReturnType | undefined + + const finish = (result: { + stdout: string + stderr: string + code: number + error?: string + }) => { + if (settled) return + settled = true + clearTimeout(timer) + resolve(result) + } + + const appendChunk = ( + current: string, + chunk: Buffer | string, + ): { next: string; overflowed: boolean } => { + const text = typeof chunk === 'string' ? chunk : chunk.toString('utf8') + if (maxBuffer === undefined) { + return { next: current + text, overflowed: false } + } + const next = current + text + if (next.length <= maxBuffer) { + return { next, overflowed: false } + } + return { + next: next.slice(0, maxBuffer), + overflowed: true, + } + } + + child.stdout?.on('data', chunk => { + const result = appendChunk(stdout, chunk) + stdout = result.next + if (result.overflowed) { + child.kill() + } + }) + + child.stderr?.on('data', chunk => { + const result = appendChunk(stderr, chunk) + stderr = result.next + if (result.overflowed) { + child.kill() + } + }) + + child.on('error', error => { + logError(error) + finish({ stdout: '', stderr: '', code: 1, error: error.message }) + }) + + child.on('close', (code, signal) => { + const exitCode = typeof code === 'number' ? code : 1 + if (exitCode === 0 && !signal && !timedOut) { + finish({ stdout, stderr, code: 0 }) + return + } + + const output = finalPreserveOutput ? { stdout, stderr } : { stdout: '', stderr: '' } + const signalName = typeof signal === 'string' ? signal : undefined + finish({ + ...output, + code: exitCode, + error: timedOut + ? `timed out after ${finalTimeout}ms` + : getErrorMessage( + { + shortMessage: + output.stderr.trim() || output.stdout.trim() || undefined, + signal: signalName, + }, + exitCode, + ), + }) + }) + + if (finalInput !== undefined && child.stdin) { + child.stdin.end(finalInput) + } + + if (stdinMode === 'ignore') { + child.stdin?.end() + } + + if (finalTimeout !== undefined && finalTimeout > 0) { + timer = setTimeout(() => { + timedOut = true + child.kill() + }, finalTimeout) + } }) } diff --git a/restored-src/src/utils/fileHistory.ts b/restored-src/src/utils/fileHistory.ts index 4e227d997..4849b2c11 100644 --- a/restored-src/src/utils/fileHistory.ts +++ b/restored-src/src/utils/fileHistory.ts @@ -1,5 +1,5 @@ import { createHash, type UUID } from 'crypto' -import { diffLines } from 'diff' +import { diffLines } from 'diff/libesm/diff/line.js' import type { Stats } from 'fs' import { chmod, diff --git a/restored-src/src/utils/ripgrep.ts b/restored-src/src/utils/ripgrep.ts index 683da0516..06d128e6b 100644 --- a/restored-src/src/utils/ripgrep.ts +++ b/restored-src/src/utils/ripgrep.ts @@ -1,5 +1,6 @@ import type { ChildProcess, ExecFileException } from 'child_process' import { execFile, spawn } from 'child_process' +import { existsSync } from 'fs' import memoize from 'lodash-es/memoize.js' import { homedir } from 'os' import * as path from 'path' @@ -61,6 +62,17 @@ const getRipgrepConfig = memoize((): RipgrepConfig => { ? path.resolve(rgRoot, `${process.arch}-win32`, 'rg.exe') : path.resolve(rgRoot, `${process.arch}-${process.platform}`, 'rg') + if (existsSync(command)) { + return { mode: 'builtin', command, args: [] } + } + + // Restored-source/dev shells may not carry the vendored ripgrep artifact. + // Fall back to a system rg if one is available rather than hard-failing. + const { cmd: fallbackSystemPath } = findExecutable('rg', []) + if (fallbackSystemPath !== 'rg') { + return { mode: 'system', command: 'rg', args: [] } + } + return { mode: 'builtin', command, args: [] } }) diff --git a/restored-src/src/utils/sandbox/sandbox-adapter.ts b/restored-src/src/utils/sandbox/sandbox-adapter.ts index 170ecac78..aac8813ad 100644 --- a/restored-src/src/utils/sandbox/sandbox-adapter.ts +++ b/restored-src/src/utils/sandbox/sandbox-adapter.ts @@ -22,7 +22,7 @@ import { } from '@anthropic-ai/sandbox-runtime' import { rmSync, statSync } from 'fs' import { readFile } from 'fs/promises' -import { memoize } from 'lodash-es' +import memoize from 'lodash-es/memoize.js' import { join, resolve, sep } from 'path' import { getAdditionalDirectoriesForClaudeMd, diff --git a/restored-src/src/utils/settings/mdm/rawRead.ts b/restored-src/src/utils/settings/mdm/rawRead.ts index 18aeacafd..ef067398a 100644 --- a/restored-src/src/utils/settings/mdm/rawRead.ts +++ b/restored-src/src/utils/settings/mdm/rawRead.ts @@ -34,15 +34,21 @@ function execFilePromise( args: string[], ): Promise<{ stdout: string; code: number | null }> { return new Promise(resolve => { - execFile( - cmd, - args, - { encoding: 'utf-8', timeout: MDM_SUBPROCESS_TIMEOUT_MS }, - (err, stdout) => { - // biome-ignore lint/nursery/noFloatingPromises: resolve() is not a floating promise - resolve({ stdout: stdout ?? '', code: err ? 1 : 0 }) - }, - ) + try { + execFile( + cmd, + args, + { encoding: 'utf-8', timeout: MDM_SUBPROCESS_TIMEOUT_MS }, + (err, stdout) => { + // biome-ignore lint/nursery/noFloatingPromises: resolve() is not a floating promise + resolve({ stdout: stdout ?? '', code: err ? 1 : 0 }) + }, + ) + } catch { + // Fail open: MDM startup probes must never block the CLI if the host + // forbids spawning platform helpers such as `reg`/`plutil`. + resolve({ stdout: '', code: 1 }) + } }) } diff --git a/restored-src/src/utils/windowsPaths.ts b/restored-src/src/utils/windowsPaths.ts index c0774ea87..4a2635fe6 100644 --- a/restored-src/src/utils/windowsPaths.ts +++ b/restored-src/src/utils/windowsPaths.ts @@ -1,24 +1,20 @@ +import { existsSync } from 'fs' import memoize from 'lodash-es/memoize.js' import * as path from 'path' import * as pathWin32 from 'path/win32' import { getCwd } from './cwd.js' import { logForDebugging } from './debug.js' -import { execSync_DEPRECATED } from './execSyncWrapper.js' import { memoizeWithLRU } from './memoize.js' import { getPlatform } from './platform.js' +import { whichSync } from './which.js' /** - * Check if a file or directory exists on Windows using the dir command + * Check if a file or directory exists on Windows. * @param path - The path to check * @returns true if the path exists, false otherwise */ function checkPathExists(path: string): boolean { - try { - execSync_DEPRECATED(`dir "${path}"`, { stdio: 'pipe' }) - return true - } catch { - return false - } + return existsSync(path) } /** @@ -44,39 +40,26 @@ function findExecutable(executable: string): string | null { } } - // Fall back to where.exe - try { - const result = execSync_DEPRECATED(`where.exe ${executable}`, { - stdio: 'pipe', - encoding: 'utf8', - }).trim() - - // SECURITY: Filter out any results from the current directory - // to prevent executing malicious git.bat/cmd/exe files - const paths = result.split('\r\n').filter(Boolean) - const cwd = getCwd().toLowerCase() - - for (const candidatePath of paths) { - // Normalize and compare paths to ensure we're not in current directory - const normalizedPath = path.resolve(candidatePath).toLowerCase() - const pathDir = path.dirname(normalizedPath).toLowerCase() - - // Skip if the executable is in the current working directory - if (pathDir === cwd || normalizedPath.startsWith(cwd + path.sep)) { - logForDebugging( - `Skipping potentially malicious executable in current directory: ${candidatePath}`, - ) - continue - } + const candidatePath = whichSync(executable) + if (!candidatePath) { + return null + } - // Return the first valid path that's not in the current directory - return candidatePath - } + // SECURITY: Filter out any results from the current directory + // to prevent executing malicious git.bat/cmd/exe files + const cwd = getCwd().toLowerCase() + const normalizedPath = path.resolve(candidatePath).toLowerCase() + const pathDir = path.dirname(normalizedPath).toLowerCase() - return null - } catch { + // Skip if the executable is in the current working directory + if (pathDir === cwd || normalizedPath.startsWith(cwd + path.sep)) { + logForDebugging( + `Skipping potentially malicious executable in current directory: ${candidatePath}`, + ) return null } + + return candidatePath } /** diff --git a/restored-src/tsconfig.json b/restored-src/tsconfig.json new file mode 100644 index 000000000..9fbf8dc02 --- /dev/null +++ b/restored-src/tsconfig.json @@ -0,0 +1,18 @@ +{ + "compilerOptions": { + "target": "ESNext", + "module": "ESNext", + "moduleResolution": "Bundler", + "jsx": "react-jsx", + "allowJs": true, + "checkJs": false, + "baseUrl": ".", + "paths": { + "src/*": [ + "src/*" + ] + }, + "skipLibCheck": true, + "noEmit": true + } +}