@visulima/package 1.3.4 → 1.4.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +15 -0
- package/README.md +22 -14
- package/dist/{chunk-EVIAOYPI.js → chunk-5ZQIFU6S.js} +3 -3
- package/dist/chunk-5ZQIFU6S.js.map +1 -0
- package/dist/chunk-BGBPBHAL.cjs +27 -0
- package/dist/chunk-BGBPBHAL.cjs.map +1 -0
- package/dist/chunk-F63DY4KL.js +15 -0
- package/dist/chunk-F63DY4KL.js.map +1 -0
- package/dist/{chunk-S35C7FTW.js → chunk-G767QS5X.js} +3 -3
- package/dist/chunk-G767QS5X.js.map +1 -0
- package/dist/chunk-L6J2NRQY.cjs +12 -0
- package/dist/chunk-L6J2NRQY.cjs.map +1 -0
- package/dist/chunk-TM6ZD56C.cjs +16 -0
- package/dist/chunk-TM6ZD56C.cjs.map +1 -0
- package/dist/chunk-TUN46UZB.js +12 -0
- package/dist/chunk-TUN46UZB.js.map +1 -0
- package/dist/chunk-VAMRQCZW.cjs +11 -0
- package/dist/chunk-VAMRQCZW.cjs.map +1 -0
- package/dist/chunk-VQCWTT2B.cjs +22 -0
- package/dist/chunk-VQCWTT2B.cjs.map +1 -0
- package/dist/{chunk-JUT7NLYV.js → chunk-XKKPPOYW.js} +3 -3
- package/dist/chunk-XKKPPOYW.js.map +1 -0
- package/dist/index.cjs +34 -18
- package/dist/index.d.cts +12 -4
- package/dist/index.d.ts +12 -4
- package/dist/index.js +5 -5
- package/dist/monorepo.cjs +4 -4
- package/dist/monorepo.js +3 -3
- package/dist/package-json.cjs +6 -6
- package/dist/package-json.d.cts +23 -3
- package/dist/package-json.d.ts +23 -3
- package/dist/package-json.js +1 -1
- package/dist/package-manager.cjs +6 -6
- package/dist/package-manager.js +2 -2
- package/dist/package.cjs +4 -4
- package/dist/package.js +3 -3
- package/dist/tsconfig.cjs +19 -3
- package/dist/tsconfig.d.cts +19 -4
- package/dist/tsconfig.d.ts +19 -4
- package/dist/tsconfig.js +1 -1
- package/dist/types-hoigZ9HA.d.cts +9 -0
- package/dist/types-hoigZ9HA.d.ts +9 -0
- package/package.json +16 -9
- package/dist/chunk-3BB7IH7P.cjs +0 -22
- package/dist/chunk-3BB7IH7P.cjs.map +0 -1
- package/dist/chunk-EVIAOYPI.js.map +0 -1
- package/dist/chunk-JUT7NLYV.js.map +0 -1
- package/dist/chunk-KG4KEP7W.cjs +0 -16
- package/dist/chunk-KG4KEP7W.cjs.map +0 -1
- package/dist/chunk-OIPHYJAS.js +0 -12
- package/dist/chunk-OIPHYJAS.js.map +0 -1
- package/dist/chunk-QNXGZOH4.js +0 -10
- package/dist/chunk-QNXGZOH4.js.map +0 -1
- package/dist/chunk-S35C7FTW.js.map +0 -1
- package/dist/chunk-WKLGTORJ.cjs +0 -12
- package/dist/chunk-WKLGTORJ.cjs.map +0 -1
- package/dist/chunk-WOH32CRU.cjs +0 -13
- package/dist/chunk-WOH32CRU.cjs.map +0 -1
- package/dist/chunk-X65BTKB7.cjs +0 -11
- package/dist/chunk-X65BTKB7.cjs.map +0 -1
- package/dist/package-json-MvdYC-nU.d.cts +0 -23
- package/dist/package-json-MvdYC-nU.d.ts +0 -23
package/CHANGELOG.md
CHANGED
|
@@ -1,3 +1,18 @@
|
|
|
1
|
+
## @visulima/package [1.4.0](https://github.com/visulima/visulima/compare/@visulima/package@1.3.5...@visulima/package@1.4.0) (2024-03-22)
|
|
2
|
+
|
|
3
|
+
|
|
4
|
+
### Features
|
|
5
|
+
|
|
6
|
+
* switched get-tsconfig with internal code, add cache ([#360](https://github.com/visulima/visulima/issues/360)) ([3cdd387](https://github.com/visulima/visulima/commit/3cdd38793f6413edfbbc1af48a5a27fc8d4a9172))
|
|
7
|
+
|
|
8
|
+
## @visulima/package [1.3.5](https://github.com/visulima/visulima/compare/@visulima/package@1.3.4...@visulima/package@1.3.5) (2024-03-20)
|
|
9
|
+
|
|
10
|
+
|
|
11
|
+
|
|
12
|
+
### Dependencies
|
|
13
|
+
|
|
14
|
+
* **@visulima/fs:** upgraded to 1.11.0
|
|
15
|
+
|
|
1
16
|
## @visulima/package [1.3.4](https://github.com/visulima/visulima/compare/@visulima/package@1.3.3...@visulima/package@1.3.4) (2024-03-19)
|
|
2
17
|
|
|
3
18
|
|
package/README.md
CHANGED
|
@@ -3,11 +3,12 @@
|
|
|
3
3
|
<p>
|
|
4
4
|
One Package to rule them all, finds your root-dir, monorepo, package manager or tsconfig.json is built on top of
|
|
5
5
|
|
|
6
|
-
[
|
|
7
|
-
[
|
|
8
|
-
[
|
|
9
|
-
[
|
|
10
|
-
[
|
|
6
|
+
[@visulima/fs](https://github.com/visulima/visulima/tree/main/packages/fs),
|
|
7
|
+
[jsonc-parser](https://github.com/microsoft/node-jsonc-parser),
|
|
8
|
+
[normalize-package-data](https://github.com/npm/normalize-package-data),
|
|
9
|
+
[pathe](https://github.com/unjs/pathe),
|
|
10
|
+
[resolve-pkg-maps](https://github.com/privatenumber/resolve-pkg-maps) and
|
|
11
|
+
[type-fest](https://github.com/sindresorhus/type-fest)
|
|
11
12
|
|
|
12
13
|
</p>
|
|
13
14
|
</div>
|
|
@@ -139,26 +140,26 @@ import { getPackageManagerVersion } from "@visulima/package";
|
|
|
139
140
|
const version = await getPackageManagerVersion("npm"); // => 7.5.4
|
|
140
141
|
```
|
|
141
142
|
|
|
142
|
-
###
|
|
143
|
+
### findTsConfig
|
|
143
144
|
|
|
144
|
-
Retrieves the
|
|
145
|
+
Retrieves the TsConfig by searching for the "tsconfig.json" file from a given current working directory.
|
|
145
146
|
|
|
146
147
|
```ts
|
|
147
|
-
import {
|
|
148
|
-
// or import {
|
|
148
|
+
import { findTsConfig } from "@visulima/package";
|
|
149
|
+
// or import { findTsConfig } from '@visulima/package/tsconfig';
|
|
149
150
|
|
|
150
|
-
const tsconfig = await
|
|
151
|
+
const tsconfig = await findTsConfig(); // => { path: "/Users/../Projects/visulima/packages/package/tsconfig.json", config: { compilerOptions: { ... } } }
|
|
151
152
|
```
|
|
152
153
|
|
|
153
|
-
###
|
|
154
|
+
### writeTsConfig
|
|
154
155
|
|
|
155
156
|
Writes the provided TypeScript configuration object to a tsconfig.json file.
|
|
156
157
|
|
|
157
158
|
```ts
|
|
158
|
-
import {
|
|
159
|
-
// or import {
|
|
159
|
+
import { writeTsConfig } from '@visulima/package';
|
|
160
|
+
// or import { writeTsConfig } from '@visulima/package/tsconfig';
|
|
160
161
|
|
|
161
|
-
|
|
162
|
+
writeTsConfig({ compilerOptions: { ... } }/* ,{ cwd: "./" }*/);
|
|
162
163
|
```
|
|
163
164
|
|
|
164
165
|
## Supported Node.js Versions
|
|
@@ -177,6 +178,13 @@ If you would like to help take a look at the [list of issues](https://github.com
|
|
|
177
178
|
- [Daniel Bannert](https://github.com/prisis)
|
|
178
179
|
- [All Contributors](https://github.com/visulima/visulima/graphs/contributors)
|
|
179
180
|
|
|
181
|
+
## About
|
|
182
|
+
|
|
183
|
+
### Related Projects
|
|
184
|
+
|
|
185
|
+
- [get-tsconfig](https://github.com/privatenumber/get-tsconfig) - Get the TypeScript configuration from a project.
|
|
186
|
+
- [read-pkg](https://github.com/sindresorhus/read-pkg) - Read a package.json file.
|
|
187
|
+
|
|
180
188
|
## License
|
|
181
189
|
|
|
182
190
|
The visulima package is open-sourced software licensed under the [MIT][license-url]
|
|
@@ -1,11 +1,11 @@
|
|
|
1
|
-
import { e } from './chunk-
|
|
1
|
+
import { e } from './chunk-TUN46UZB.js';
|
|
2
2
|
import { execSync } from 'node:child_process';
|
|
3
3
|
import { existsSync, readFileSync } from 'node:fs';
|
|
4
|
-
import { join, dirname } from 'node:path';
|
|
5
4
|
import { findUp } from '@visulima/fs';
|
|
5
|
+
import { join, dirname } from 'pathe';
|
|
6
6
|
|
|
7
7
|
var f=["yarn.lock","package-lock.json","pnpm-lock.yaml","npm-shrinkwrap.json","bun.lockb"],x=async a=>{let n=await findUp(f,{type:"file",...a&&{cwd:a}});if(!n)throw new Error("Could not find lock file");return n},w=async a=>{let n=await findUp(e$1=>{let t;if(f.forEach(i=>{!t&&existsSync(join(e$1,i))&&(t=join(e$1,i));}),t)return t;let r=join(e$1,"package.json");if(existsSync(r)&&e(readFileSync(r,"utf8")).packageManager!==void 0)return r},{...a&&{cwd:a}});if(!n)throw new Error("Could not find lock file");if(n.endsWith("package.json")){let e$1=e(n);if(e$1.packageManager){let r=["npm","yarn","pnpm","bun"].find(i=>e$1.packageManager.startsWith(i));if(r)return {packageManager:r,path:dirname(n)}}}if(n.endsWith("yarn.lock"))return {packageManager:"yarn",path:dirname(n)};if(n.endsWith("package-lock.json")||n.endsWith("npm-shrinkwrap.json"))return {packageManager:"npm",path:dirname(n)};if(n.endsWith("pnpm-lock.yaml"))return {packageManager:"pnpm",path:dirname(n)};if(n.endsWith("bun.lockb"))return {packageManager:"bun",path:dirname(n)};throw new Error("Could not find lock file")},b=a=>execSync(`${a} --version`).toString("utf8").trim(),j=async()=>{if(!process.env.npm_config_user_agent)return;let a=process.env.npm_config_user_agent.split(" ")[0],n=a.lastIndexOf("/"),e=a.slice(0,Math.max(0,n));return {name:e==="npminstall"?"cnpm":e,version:a.slice(Math.max(0,n+1))}};
|
|
8
8
|
|
|
9
9
|
export { x as a, w as b, b as c, j as d };
|
|
10
10
|
//# sourceMappingURL=out.js.map
|
|
11
|
-
//# sourceMappingURL=chunk-
|
|
11
|
+
//# sourceMappingURL=chunk-5ZQIFU6S.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/package-manager.ts"],"names":["execSync","existsSync","readFileSync","findUp","dirname","join","lockFileNames","findLockFile","cwd","filePath","findPackageManager","foundFile","directory","lockFile","lockFileName","packageJsonFilePath","parsePackageJson","packageJson","foundPackageManager","prefix","getPackageManagerVersion","name","identifyInitiatingPackageManager","pmSpec","separatorPos"],"mappings":"wCAAA,OAAS,YAAAA,MAAgB,qBACzB,OAAS,cAAAC,EAAY,gBAAAC,MAAoB,UAEzC,OAAS,UAAAC,MAAc,eACvB,OAAS,WAAAC,EAAS,QAAAC,MAAY,QAI9B,IAAMC,EAAgB,CAAC,YAAa,oBAAqB,iBAAkB,sBAAuB,WAAW,EAWhGC,EAAe,MAAOC,GAAwC,CACvE,IAAMC,EAAW,MAAMN,EAAOG,EAAe,CACzC,KAAM,OACN,GAAIE,GAAO,CAAE,IAAAA,CAAI,CACrB,CAAC,EAED,GAAI,CAACC,EACD,MAAM,IAAI,MAAM,0BAA0B,EAG9C,OAAOA,CACX,EAqBaC,EAAqB,MAAOF,GAAsD,CAC3F,IAAMG,EAAY,MAAMR,EACnBS,GAAsB,CACnB,IAAIC,EASJ,GAPAP,EAAc,QAASQ,GAAiB,CAEhC,CAACD,GAAYZ,EAAWI,EAAKO,EAAWE,CAAY,CAAC,IACrDD,EAAWR,EAAKO,EAAWE,CAAY,EAE/C,CAAC,EAEGD,EACA,OAAOA,EAGX,IAAME,EAAsBV,EAAKO,EAAW,cAAc,EAE1D,GAAIX,EAAWc,CAAmB,GAEVC,EAAiBd,EAAaa,EAAqB,MAAM,CAAC,EAE9D,iBAAmB,OAC/B,OAAOA,CAKnB,EACA,CACI,GAAIP,GAAO,CAAE,IAAAA,CAAI,CACrB,CACJ,EAEA,GAAI,CAACG,EACD,MAAM,IAAI,MAAM,0BAA0B,EAG9C,GAAIA,EAAU,SAAS,cAAc,EAAG,CACpC,IAAMM,EAAcD,EAAiBL,CAAS,EAE9C,GAAIM,EAAY,eAAgB,CAE5B,IAAMC,EADsB,CAAC,MAAO,OAAQ,OAAQ,KAAK,EACT,KAAMC,GAAYF,EAAY,eAA0B,WAAWE,CAAM,CAAC,EAE1H,GAAID,EACA,MAAO,CACH,eAAgBA,EAChB,KAAMd,EAAQO,CAAS,CAC3B,CAER,CACJ,CAEA,GAAIA,EAAU,SAAS,WAAW,EAC9B,MAAO,CACH,eAAgB,OAChB,KAAMP,EAAQO,CAAS,CAC3B,EAGJ,GAAIA,EAAU,SAAS,mBAAmB,GAAKA,EAAU,SAAS,qBAAqB,EACnF,MAAO,CACH,eAAgB,MAChB,KAAMP,EAAQO,CAAS,CAC3B,EAGJ,GAAIA,EAAU,SAAS,gBAAgB,EACnC,MAAO,CACH,eAAgB,OAChB,KAAMP,EAAQO,CAAS,CAC3B,EAGJ,GAAIA,EAAU,SAAS,WAAW,EAC9B,MAAO,CACH,eAAgB,MAChB,KAAMP,EAAQO,CAAS,CAC3B,EAGJ,MAAM,IAAI,MAAM,0BAA0B,CAC9C,EAQaS,EAA4BC,GAAyBrB,EAAS,GAAGqB,CAAI,YAAY,EAAE,SAAS,MAAM,EAAE,KAAK,EAWzGC,EAAmC,SAM3C,CACD,GAAI,CAAC,QAAQ,IAAI,sBACb,OAGJ,IAAMC,EAAS,QAAQ,IAAI,sBAAyB,MAAM,GAAG,EAAE,CAAC,EAC1DC,EAAeD,EAAO,YAAY,GAAG,EACrCF,EAAOE,EAAO,MAAM,EAAG,KAAK,IAAI,EAAGC,CAAY,CAAC,EAEtD,MAAO,CACH,KAAMH,IAAS,aAAe,OAAUA,EACxC,QAASE,EAAO,MAAM,KAAK,IAAI,EAAGC,EAAe,CAAC,CAAC,CACvD,CACJ","sourcesContent":["import { execSync } from \"node:child_process\";\nimport { existsSync, readFileSync } from \"node:fs\";\n\nimport { findUp } from \"@visulima/fs\";\nimport { dirname, join } from \"pathe\";\n\nimport { parsePackageJson } from \"./package-json\";\n\nconst lockFileNames = [\"yarn.lock\", \"package-lock.json\", \"pnpm-lock.yaml\", \"npm-shrinkwrap.json\", \"bun.lockb\"];\n\n/**\n * An asynchronous function that finds a lock file in the specified directory or any of its parent directories.\n *\n * @param cwd - Optional. The directory path to start the search from. The type of `cwd` is part of an `Options` type,\n * specifically `URL | string`. Defaults to the current working directory.\n * @returns A `Promise` that resolves with the path of the found lock file.\n * The type of the returned promise is `Promise<string>`.\n * @throws An `Error` if no lock file is found.\n */\nexport const findLockFile = async (cwd?: URL | string): Promise<string> => {\n const filePath = await findUp(lockFileNames, {\n type: \"file\",\n ...(cwd && { cwd }),\n });\n\n if (!filePath) {\n throw new Error(\"Could not find lock file\");\n }\n\n return filePath;\n};\n\nexport type PackageManager = \"bun\" | \"npm\" | \"pnpm\" | \"yarn\";\n\nexport type PackageManagerResult = {\n packageManager: PackageManager;\n path: string;\n};\n\n/**\n * An asynchronous function that finds the package manager used in a project based on the presence of lock files\n * or package.json configuration. If found, it returns the package manager and the path to the lock file or package.json.\n * Throws an error if no lock file or package.json is found.\n *\n * @param cwd - Optional. The current working directory to start the search from. The type of `cwd` is part of an `Options`\n * type, specifically `URL | string`.\n * @returns A `Promise` that resolves to an object containing the package manager and path.\n * The return type of the function is `Promise<PackageManagerResult>`.\n * @throws An `Error` if no lock file or package.json is found.\n */\n// eslint-disable-next-line sonarjs/cognitive-complexity\nexport const findPackageManager = async (cwd?: URL | string): Promise<PackageManagerResult> => {\n const foundFile = await findUp(\n (directory: string) => {\n let lockFile: string | undefined;\n\n lockFileNames.forEach((lockFileName) => {\n // eslint-disable-next-line security/detect-non-literal-fs-filename\n if (!lockFile && existsSync(join(directory, lockFileName))) {\n lockFile = join(directory, lockFileName);\n }\n });\n\n if (lockFile) {\n return lockFile;\n }\n\n const packageJsonFilePath = join(directory, \"package.json\");\n // eslint-disable-next-line security/detect-non-literal-fs-filename\n if (existsSync(packageJsonFilePath)) {\n // eslint-disable-next-line security/detect-non-literal-fs-filename\n const packageJson = parsePackageJson(readFileSync(packageJsonFilePath, \"utf8\"));\n\n if (packageJson.packageManager !== undefined) {\n return packageJsonFilePath;\n }\n }\n\n return undefined;\n },\n {\n ...(cwd && { cwd }),\n },\n );\n\n if (!foundFile) {\n throw new Error(\"Could not find lock file\");\n }\n\n if (foundFile.endsWith(\"package.json\")) {\n const packageJson = parsePackageJson(foundFile);\n\n if (packageJson.packageManager) {\n const packageManagerNames = [\"npm\", \"yarn\", \"pnpm\", \"bun\"] as const;\n const foundPackageManager = packageManagerNames.find((prefix) => (packageJson.packageManager as string).startsWith(prefix));\n\n if (foundPackageManager) {\n return {\n packageManager: foundPackageManager,\n path: dirname(foundFile),\n };\n }\n }\n }\n\n if (foundFile.endsWith(\"yarn.lock\")) {\n return {\n packageManager: \"yarn\",\n path: dirname(foundFile),\n };\n }\n\n if (foundFile.endsWith(\"package-lock.json\") || foundFile.endsWith(\"npm-shrinkwrap.json\")) {\n return {\n packageManager: \"npm\",\n path: dirname(foundFile),\n };\n }\n\n if (foundFile.endsWith(\"pnpm-lock.yaml\")) {\n return {\n packageManager: \"pnpm\",\n path: dirname(foundFile),\n };\n }\n\n if (foundFile.endsWith(\"bun.lockb\")) {\n return {\n packageManager: \"bun\",\n path: dirname(foundFile),\n };\n }\n\n throw new Error(\"Could not find lock file\");\n};\n\n/**\n * Function that retrieves the version of the specified package manager.\n *\n * @param name - The name of the package manager. The type of `name` is `string`.\n * @returns The version of the package manager. The return type of the function is `string`.\n */\nexport const getPackageManagerVersion = (name: string): string => execSync(`${name} --version`).toString(\"utf8\").trim();\n\n/**\n * An asynchronous function that detects what package manager executes the process.\n *\n * Supports npm, pnpm, Yarn, cnpm, and bun. And also any other package manager that sets the npm_config_user_agent env variable.\n *\n * @returns A `Promise` that resolves to an object containing the name and version of the package manager,\n * or undefined if the package manager information cannot be determined. The return type of the function\n * is `Promise<{ name: PackageManager | \"cnpm\"; version: string } | undefined>`.\n */\nexport const identifyInitiatingPackageManager = async (): Promise<\n | {\n name: PackageManager | \"cnpm\";\n version: string;\n }\n | undefined\n> => {\n if (!process.env[\"npm_config_user_agent\"]) {\n return undefined;\n }\n\n const pmSpec = process.env[\"npm_config_user_agent\"].split(\" \")[0] as string;\n const separatorPos = pmSpec.lastIndexOf(\"/\");\n const name = pmSpec.slice(0, Math.max(0, separatorPos));\n\n return {\n name: name === \"npminstall\" ? \"cnpm\" : (name as PackageManager),\n version: pmSpec.slice(Math.max(0, separatorPos + 1)),\n };\n};\n"]}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var fs = require('@visulima/fs');
|
|
4
|
+
var error = require('@visulima/fs/error');
|
|
5
|
+
var utils = require('@visulima/fs/utils');
|
|
6
|
+
var pathe = require('pathe');
|
|
7
|
+
var fs$1 = require('fs');
|
|
8
|
+
var jsoncParser = require('jsonc-parser');
|
|
9
|
+
var A = require('module');
|
|
10
|
+
var path = require('path');
|
|
11
|
+
var resolvePkgMaps = require('resolve-pkg-maps');
|
|
12
|
+
|
|
13
|
+
function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
|
|
14
|
+
|
|
15
|
+
var A__default = /*#__PURE__*/_interopDefault(A);
|
|
16
|
+
|
|
17
|
+
var z=s=>jsoncParser.parse(fs.readFileSync(s)),_=()=>{let{findPnpApi:s}=A__default.default;return s?.(process.cwd())},v=(s,o,l,n)=>{let t=`resolveFromPackageJsonPath:${s}:${o}:${l}`;if(n?.has(t))return n.get(t);let i=z(s);if(!i)return;let e=o||"tsconfig.json";if(!l&&i.exports)try{let[a]=resolvePkgMaps.resolveExports(i.exports,o,["require","types"]);e=a;}catch{return !1}else !o&&i.tsconfig&&(e=i.tsconfig);return e=path.join(s,"..",e),n?.set(t,e),e},P="package.json",T="tsconfig.json",L=(s,o,l)=>{let n=s;if(s===".."&&(n=path.join(n,T)),s.startsWith(".")&&(n=path.resolve(o,n)),path.isAbsolute(n)){if(fs$1.existsSync(n)){if(fs$1.statSync(n).isFile())return n}else if(!n.endsWith(".json")){let c=`${n}.json`;if(fs$1.existsSync(c))return c}return}let[t,...i]=s.split("/"),e=t.startsWith("@")?`${t}/${i.shift()}`:t,a=i.join("/"),r=_();if(r){let{resolveRequest:c}=r;try{if(e===s){let p=c(path.join(e,P),o);if(p){let h=v(p,a,!1,l);if(h&&fs$1.existsSync(h))return h}}else {let p;try{p=c(s,o,{extensions:[".json"]});}catch{p=c(path.join(s,T),o);}if(p)return p}}catch{}}let f=fs.findUpSync(c=>{let p=path.join(c,"node_modules",e);if(fs$1.existsSync(p))return path.join("node_modules",e)},{cwd:o,type:"directory"});if(!f||!fs$1.statSync(f).isDirectory())return;let g=path.join(f,P);if(fs$1.existsSync(g)){let c=v(g,a,!1,l);if(c===!1)return;if(c&&fs$1.existsSync(c)&&fs$1.statSync(c).isFile())return c}let m=path.join(f,a),C=m.endsWith(".json");if(!C){let c=`${m}.json`;if(fs$1.existsSync(c))return c}if(fs$1.existsSync(m)){if(fs$1.statSync(m).isDirectory()){let c=path.join(m,P);if(fs$1.existsSync(c)){let h=v(c,"",!0,l);if(h&&fs$1.existsSync(h))return h}let p=path.join(m,T);if(fs$1.existsSync(p))return p}else if(C)return m}},j=L;var Y=Symbol("implicitBaseUrl"),Z=s=>jsoncParser.parse(fs.readFileSync(s)),O=s=>pathe.toNamespacedPath(/^\.{1,2}(?:\/.*)?$/.test(s)?s:`./${s}`),q=(s,o,l,n)=>{let t=j(s,o);if(!t)throw new error.NotFoundError(`for '${s}' found.`);if(l.has(t))throw new Error(`Circularity detected while resolving configuration: ${t}`);l.add(t);let i=pathe.dirname(t),e=k(t,n,l);delete e.references;let{compilerOptions:a}=e;if(a){let r=["baseUrl","outDir"];for(let f of r){let g=a[f];g&&(a[f]=pathe.relative(o,pathe.join(i,g)).replaceAll("\\","/")||"./");}}return e.files&&(e.files=e.files.map(r=>pathe.relative(o,pathe.join(i,r)))),e.include&&(e.include=e.include.map(r=>pathe.relative(o,pathe.join(i,r)))),e.exclude&&(e.exclude=e.exclude.map(r=>pathe.relative(o,pathe.join(i,r)))),e},k=(s,o,l=new Set)=>{let n;try{n=fs$1.realpathSync(s);}catch{throw new Error(`Cannot resolve tsconfig at path: ${s}`)}let t=Z(n)||{};if(typeof t!="object")throw new SyntaxError(`Failed to parse tsconfig at: ${s}`);let i=pathe.dirname(n);if(t.compilerOptions){let{compilerOptions:e}=t;e.paths&&!e.baseUrl&&(e[Y]=i);}if(t.extends){let e=Array.isArray(t.extends)?t.extends:[t.extends];delete t.extends;for(let a of e.reverse()){let r=q(a,i,new Set(l),o),f={...r,...t,compilerOptions:{...r.compilerOptions,...t.compilerOptions}};r.watchOptions&&(f.watchOptions={...r.watchOptions,...t.watchOptions}),t=f;}}if(t.compilerOptions){let{compilerOptions:e}=t,a=["baseUrl","rootDir"];for(let f of a){let g=e[f];if(g){let m=pathe.resolve(i,g),C=pathe.relative(i,m);e[f]=O(C);}}let{outDir:r}=e;r&&(Array.isArray(t.exclude)||(t.exclude=[]),t.exclude.includes(r)||t.exclude.push(r),e.outDir=O(r)),o?.tscCompatible&&e.module==="node16"&&(e.allowSyntheticDefaultImports=e.allowSyntheticDefaultImports??!0,e.esModuleInterop=e.esModuleInterop??!0,e.moduleDetection=e.moduleDetection??"force",e.moduleResolution=e.moduleResolution??"node16",e.target=e.target??"es2022",e.useDefineForClassFields=e.useDefineForClassFields??!0),o?.tscCompatible&&e.strict&&(e.noImplicitAny=e.noImplicitAny??!0,e.noImplicitThis=e.noImplicitThis??!0,e.strictNullChecks=e.strictNullChecks??!0,e.strictFunctionTypes=e.strictFunctionTypes??!0,e.strictBindCallApply=e.strictBindCallApply??!0,e.strictPropertyInitialization=e.strictPropertyInitialization??!0,e.alwaysStrict=e.alwaysStrict??!0,e.useUnknownInCatchVariables=e.useUnknownInCatchVariables??!0),o?.tscCompatible&&e.isolatedModules&&(e.preserveConstEnums=e.preserveConstEnums??!0),o?.tscCompatible&&e.esModuleInterop&&(e.allowSyntheticDefaultImports=e.allowSyntheticDefaultImports??!0),o?.tscCompatible&&e.target==="esnext"&&(e.useDefineForClassFields=e.useDefineForClassFields??!0);}else t.compilerOptions={};if(t.files&&(t.files=t.files.map(e=>O(e))),t.include&&(t.include=t.include.map(e=>pathe.normalize(e))),t.watchOptions){let{watchOptions:e}=t;e.excludeDirectories&&(e.excludeDirectories=e.excludeDirectories.map(a=>pathe.resolve(i,a)));}return t},ee=(s,o)=>k(s,o),J=ee;var D=new Map,ne=async(s,o={})=>{let l=o.configFileName??"tsconfig.json",n=await fs.findUp(l,{...s&&{cwd:s},type:"file"});if(n||(n=await fs.findUp("jsconfig.json",{...s&&{cwd:s},type:"file"})),!n)throw new error.NotFoundError(`for ${l} or jsconfig.json found.`);let t=o.cache&&typeof o.cache!="boolean"?o.cache:D;if(o.cache&&t.has(n))return t.get(n);let i={config:J(n),path:n};return o.cache&&t.set(n,i),i},Fe=ne,ie=(s,o={})=>{let l=o.configFileName??"tsconfig.json",n=fs.findUpSync(l,{...s&&{cwd:s},type:"file"});if(n||(n=fs.findUpSync("jsconfig.json",{...s&&{cwd:s},type:"file"})),!n)throw new error.NotFoundError(`for ${l} or jsconfig.json found.`);let t=o.cache&&typeof o.cache!="boolean"?o.cache:D;if(o.cache&&t.has(n))return t.get(n);let i={config:J(n),path:n};return o.cache&&t.set(n,i),i},be=ie,re=async(s,o={})=>{let{cwd:l,...n}=o,t=utils.toPath(o.cwd??process.cwd());await fs.writeJson(pathe.join(t,"tsconfig.json"),s,n);},ke=re;
|
|
18
|
+
|
|
19
|
+
exports.a = J;
|
|
20
|
+
exports.b = ne;
|
|
21
|
+
exports.c = Fe;
|
|
22
|
+
exports.d = ie;
|
|
23
|
+
exports.e = be;
|
|
24
|
+
exports.f = re;
|
|
25
|
+
exports.g = ke;
|
|
26
|
+
//# sourceMappingURL=out.js.map
|
|
27
|
+
//# sourceMappingURL=chunk-BGBPBHAL.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/tsconfig.ts","../src/read-tsconfig.ts","../src/utils/resolve-extends-path.ts"],"names":["findUp","findUpSync","writeJson","NotFoundError","toPath","join","realpathSync","readFileSync","parse","dirname","normalize","relative","resolve","toNamespacedPath","existsSync","statSync","Module","isAbsolute","resolveExports","readJsonc","jsonPath","getPnpApi","findPnpApi","resolveFromPackageJsonPath","packageJsonPath","subpath","ignoreExports","cache","cacheKey","packageJson","resolvedPath","resolvedExport","PACKAGE_JSON","TS_CONFIG_JSON","resolveExtendsPath","requestedPath","directoryPath","filePath","orgOrName","remaining","packageName","pnpApi","resolveWithPnp","resolved","packagePath","directory","path","fullPackagePath","jsonExtension","fullPackagePathWithJson","fullPackageJsonPath","tsconfigPath","resolve_extends_path_default","implicitBaseUrlSymbol","normalizePath","resolveExtends","extendsPath","fromDirectoryPath","circularExtendsTracker","options","resolvedExtendsPath","extendsDirectoryPath","extendsConfig","internalParseTsConfig","compilerOptions","resolvePaths","property","unresolvedPath","file","realTsconfigPath","config","extendsPathList","merged","normalizedPaths","resolvedBaseUrl","relativeBaseUrl","outDir","element","watchOptions","excludePath","readTsConfig","read_tsconfig_default","TsConfigFileCache","findTsConfig","cwd","configFileName","output","findTSConfig","findTsConfigSync","findTSConfigSync","writeTsConfig","data","writeOptions","writeTSConfig"],"mappings":"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","sourcesContent":["import type { WriteJsonOptions } from \"@visulima/fs\";\nimport { findUp, findUpSync, writeJson } from \"@visulima/fs\";\nimport { NotFoundError } from \"@visulima/fs/error\";\nimport { toPath } from \"@visulima/fs/utils\";\nimport { join } from \"pathe\";\nimport type { TsConfigJson } from \"type-fest\";\n\nimport readTsConfig from \"./read-tsconfig\";\nimport type { TsConfigJsonResolved } from \"./types\";\n\ntype Options = {\n cache?: Map<string, TsConfigJsonResolved> | boolean;\n configFileName?: string;\n};\n\nconst TsConfigFileCache = new Map<string, TsConfigResult>();\n\nexport type TsConfigResult = {\n config: TsConfigJsonResolved;\n path: string;\n};\n\n/**\n * An asynchronous function that retrieves the TSConfig by searching for the \"tsconfig.json\" first,\n * second attempt is to look for the \"jsconfig.json\" file from a given current working directory.\n *\n * @param cwd - Optional. The current working directory from which to search for the \"tsconfig.json\" file.\n * The type of `cwd` is `string`.\n * @returns A `Promise` that resolves to the TSConfig result object.\n * The return type of the function is `Promise<TsConfigResult>`.\n * @throws An `Error` when the \"tsconfig.json\" file is not found.\n */\nexport const findTsConfig = async (cwd?: URL | string, options: Options = {}): Promise<TsConfigResult> => {\n const configFileName = options.configFileName ?? \"tsconfig.json\";\n\n let filePath = await findUp(configFileName, {\n ...(cwd && { cwd }),\n type: \"file\",\n });\n\n if (!filePath) {\n filePath = await findUp(\"jsconfig.json\", {\n ...(cwd && { cwd }),\n type: \"file\",\n });\n }\n\n if (!filePath) {\n throw new NotFoundError(`for ${configFileName} or jsconfig.json found.`);\n }\n\n const cache = options.cache && typeof options.cache !== \"boolean\" ? options.cache : TsConfigFileCache;\n\n if (options.cache && cache.has(filePath)) {\n return cache.get(filePath) as TsConfigResult;\n }\n\n const output = {\n config: readTsConfig(filePath),\n path: filePath,\n };\n\n if (options.cache) {\n cache.set(filePath, output);\n }\n\n return output;\n};\n\n// @deprecate Please use `findTsConfig` instead.\nexport const findTSConfig = findTsConfig;\n\nexport const findTsConfigSync = (cwd?: URL | string, options: Options = {}): TsConfigResult => {\n const configFileName = options.configFileName ?? \"tsconfig.json\";\n\n let filePath = findUpSync(configFileName, {\n ...(cwd && { cwd }),\n type: \"file\",\n });\n\n if (!filePath) {\n filePath = findUpSync(\"jsconfig.json\", {\n ...(cwd && { cwd }),\n type: \"file\",\n });\n }\n\n if (!filePath) {\n throw new NotFoundError(`for ${configFileName} or jsconfig.json found.`);\n }\n\n const cache = options.cache && typeof options.cache !== \"boolean\" ? options.cache : TsConfigFileCache;\n\n if (options.cache && cache.has(filePath)) {\n return cache.get(filePath) as TsConfigResult;\n }\n\n const output = {\n config: readTsConfig(filePath),\n path: filePath,\n };\n\n if (options.cache) {\n cache.set(filePath, output);\n }\n\n return output;\n};\n\n// @deprecate Please use `findTsConfigSync` instead.\nexport const findTSConfigSync = findTsConfigSync;\n\n/**\n * An asynchronous function that writes the provided TypeScript configuration object to a tsconfig.json file.\n *\n * @param tsConfig - The TypeScript configuration object to write. The type of `tsConfig` is `TsConfigJson`.\n * @param options - Optional. The write options and the current working directory. The type of `options` is an\n * intersection type of `WriteOptions` and a Record type with an optional `cwd` key of type `string`.\n * @returns A `Promise` that resolves when the tsconfig.json file has been written.\n * The return type of function is `Promise<void>`.\n */\nexport const writeTsConfig = async (data: TsConfigJson, options: WriteJsonOptions & { cwd?: URL | string } = {}): Promise<void> => {\n const { cwd, ...writeOptions } = options;\n\n const directory = toPath(options.cwd ?? process.cwd());\n\n await writeJson(join(directory, \"tsconfig.json\"), data, writeOptions);\n};\n\n// @deprecate Please use `writeTsconfig` instead.\nexport const writeTSConfig = writeTsConfig;\n","/**\n * A modified version of `readTsconfig` from `https://github.com/privatenumber/get-tsconfig/blob/develop/src/parse-tsconfig/index.ts`\n *\n * MIT License\n * Copyright (c) Hiroki Osame <hiroki.osame@gmail.com>\n */\nimport { realpathSync } from \"node:fs\";\n\nimport { readFileSync } from \"@visulima/fs\";\nimport { NotFoundError } from \"@visulima/fs/error\";\nimport { parse } from \"jsonc-parser\";\nimport { dirname, join, normalize, relative, resolve, toNamespacedPath } from \"pathe\";\nimport type { TsConfigJson } from \"type-fest\";\n\nimport type { TsConfigJsonResolved } from \"./types\";\nimport resolveExtendsPath from \"./utils/resolve-extends-path\";\n\ntype Options = {\n tscCompatible?: boolean;\n};\n\nconst implicitBaseUrlSymbol = Symbol(\"implicitBaseUrl\");\n\nconst readJsonc = (jsonPath: string) => parse(readFileSync(jsonPath) as string) as unknown;\n// eslint-disable-next-line security/detect-unsafe-regex\nconst normalizePath = (path: string): string => toNamespacedPath(/^\\.{1,2}(?:\\/.*)?$/.test(path) ? path : `./${path}`);\n\nconst resolveExtends = (extendsPath: string, fromDirectoryPath: string, circularExtendsTracker: Set<string>, options?: Options) => {\n const resolvedExtendsPath = resolveExtendsPath(extendsPath, fromDirectoryPath);\n\n if (!resolvedExtendsPath) {\n throw new NotFoundError(`for '${extendsPath}' found.`);\n }\n\n if (circularExtendsTracker.has(resolvedExtendsPath)) {\n throw new Error(`Circularity detected while resolving configuration: ${resolvedExtendsPath}`);\n }\n\n circularExtendsTracker.add(resolvedExtendsPath);\n\n const extendsDirectoryPath = dirname(resolvedExtendsPath);\n // eslint-disable-next-line @typescript-eslint/no-use-before-define\n const extendsConfig = internalParseTsConfig(resolvedExtendsPath, options, circularExtendsTracker);\n\n delete extendsConfig.references;\n\n const { compilerOptions } = extendsConfig;\n\n if (compilerOptions) {\n const resolvePaths = [\"baseUrl\", \"outDir\"] as const;\n\n // eslint-disable-next-line no-loops/no-loops,no-restricted-syntax\n for (const property of resolvePaths) {\n // eslint-disable-next-line security/detect-object-injection\n const unresolvedPath = compilerOptions[property];\n\n if (unresolvedPath) {\n // eslint-disable-next-line security/detect-object-injection\n compilerOptions[property] = relative(fromDirectoryPath, join(extendsDirectoryPath, unresolvedPath)).replaceAll(\"\\\\\", \"/\") || \"./\";\n }\n }\n }\n\n if (extendsConfig.files) {\n extendsConfig.files = extendsConfig.files.map((file) => relative(fromDirectoryPath, join(extendsDirectoryPath, file)));\n }\n\n if (extendsConfig.include) {\n extendsConfig.include = extendsConfig.include.map((file) => relative(fromDirectoryPath, join(extendsDirectoryPath, file)));\n }\n\n if (extendsConfig.exclude) {\n extendsConfig.exclude = extendsConfig.exclude.map((file) => relative(fromDirectoryPath, join(extendsDirectoryPath, file)));\n }\n\n return extendsConfig;\n};\n\n// eslint-disable-next-line sonarjs/cognitive-complexity\nconst internalParseTsConfig = (tsconfigPath: string, options?: Options, circularExtendsTracker = new Set<string>()): TsConfigJsonResolved => {\n let realTsconfigPath: string;\n\n try {\n // eslint-disable-next-line security/detect-non-literal-fs-filename\n realTsconfigPath = realpathSync(tsconfigPath) as string;\n } catch {\n throw new Error(`Cannot resolve tsconfig at path: ${tsconfigPath}`);\n }\n\n /**\n * Decided not to cache the TsConfigJsonResolved object because it's\n * mutable.\n *\n * Note how `resolveExtends` can call `readTsconfig` rescursively\n * and actually mutates the object. It can also be mutated in\n * user-land.\n *\n * By only caching fs results, we can avoid serving mutated objects\n */\n let config: TsConfigJson = readJsonc(realTsconfigPath) || {};\n\n if (typeof config !== \"object\") {\n throw new SyntaxError(`Failed to parse tsconfig at: ${tsconfigPath}`);\n }\n\n const directoryPath = dirname(realTsconfigPath);\n\n if (config.compilerOptions) {\n const { compilerOptions } = config;\n if (compilerOptions.paths && !compilerOptions.baseUrl) {\n type WithImplicitBaseUrl = TsConfigJson.CompilerOptions & {\n [implicitBaseUrlSymbol]: string;\n };\n // eslint-disable-next-line security/detect-object-injection\n (compilerOptions as WithImplicitBaseUrl)[implicitBaseUrlSymbol] = directoryPath;\n }\n }\n\n if (config.extends) {\n const extendsPathList = Array.isArray(config.extends) ? config.extends : [config.extends];\n\n delete config.extends;\n\n // eslint-disable-next-line no-loops/no-loops,no-restricted-syntax,etc/no-assign-mutated-array\n for (const extendsPath of extendsPathList.reverse()) {\n const extendsConfig = resolveExtends(extendsPath, directoryPath, new Set(circularExtendsTracker), options);\n const merged = {\n ...extendsConfig,\n ...config,\n\n compilerOptions: {\n ...extendsConfig.compilerOptions,\n ...config.compilerOptions,\n },\n };\n\n if (extendsConfig.watchOptions) {\n merged.watchOptions = {\n ...extendsConfig.watchOptions,\n ...config.watchOptions,\n };\n }\n\n config = merged;\n }\n }\n\n if (config.compilerOptions) {\n const { compilerOptions } = config;\n const normalizedPaths = [\"baseUrl\", \"rootDir\"] as const;\n\n // eslint-disable-next-line no-loops/no-loops,no-restricted-syntax\n for (const property of normalizedPaths) {\n // eslint-disable-next-line security/detect-object-injection\n const unresolvedPath = compilerOptions[property];\n\n if (unresolvedPath) {\n const resolvedBaseUrl = resolve(directoryPath, unresolvedPath);\n const relativeBaseUrl = relative(directoryPath, resolvedBaseUrl);\n\n // eslint-disable-next-line security/detect-object-injection\n compilerOptions[property] = normalizePath(relativeBaseUrl);\n }\n }\n\n const { outDir } = compilerOptions;\n\n if (outDir) {\n if (!Array.isArray(config.exclude)) {\n config.exclude = [];\n }\n\n if (!config.exclude.includes(outDir)) {\n config.exclude.push(outDir);\n }\n\n compilerOptions.outDir = normalizePath(outDir);\n }\n\n if (options?.tscCompatible && compilerOptions.module === \"node16\") {\n compilerOptions.allowSyntheticDefaultImports = compilerOptions.allowSyntheticDefaultImports ?? true;\n compilerOptions.esModuleInterop = compilerOptions.esModuleInterop ?? true;\n compilerOptions.moduleDetection = compilerOptions.moduleDetection ?? \"force\";\n compilerOptions.moduleResolution = compilerOptions.moduleResolution ?? \"node16\";\n compilerOptions.target = compilerOptions.target ?? \"es2022\";\n compilerOptions.useDefineForClassFields = compilerOptions.useDefineForClassFields ?? true;\n }\n\n if (options?.tscCompatible && compilerOptions.strict) {\n compilerOptions.noImplicitAny = compilerOptions.noImplicitAny ?? true;\n compilerOptions.noImplicitThis = compilerOptions.noImplicitThis ?? true;\n compilerOptions.strictNullChecks = compilerOptions.strictNullChecks ?? true;\n compilerOptions.strictFunctionTypes = compilerOptions.strictFunctionTypes ?? true;\n compilerOptions.strictBindCallApply = compilerOptions.strictBindCallApply ?? true;\n compilerOptions.strictPropertyInitialization = compilerOptions.strictPropertyInitialization ?? true;\n compilerOptions.alwaysStrict = compilerOptions.alwaysStrict ?? true;\n compilerOptions.useUnknownInCatchVariables = compilerOptions.useUnknownInCatchVariables ?? true;\n }\n\n if (options?.tscCompatible && compilerOptions.isolatedModules) {\n compilerOptions.preserveConstEnums = compilerOptions.preserveConstEnums ?? true;\n }\n\n if (options?.tscCompatible && compilerOptions.esModuleInterop) {\n compilerOptions.allowSyntheticDefaultImports = compilerOptions.allowSyntheticDefaultImports ?? true;\n }\n\n if (options?.tscCompatible && compilerOptions.target === \"esnext\") {\n compilerOptions.useDefineForClassFields = compilerOptions.useDefineForClassFields ?? true;\n }\n } else {\n config.compilerOptions = {};\n }\n\n if (config.files) {\n config.files = config.files.map((element) => normalizePath(element));\n }\n\n if (config.include) {\n config.include = config.include.map((element) => normalize(element));\n }\n\n if (config.watchOptions) {\n const { watchOptions } = config;\n\n if (watchOptions.excludeDirectories) {\n watchOptions.excludeDirectories = watchOptions.excludeDirectories.map((excludePath) => resolve(directoryPath, excludePath));\n }\n }\n\n return config;\n};\n\nconst readTsConfig = (tsconfigPath: string, options?: Options): TsConfigJsonResolved => internalParseTsConfig(tsconfigPath, options);\n\nexport default readTsConfig;\n","/**\n * A modified version of `resolveExtendsPath` from `https://github.com/privatenumber/get-tsconfig/blob/develop/src/parse-tsconfig/resolve-extends-path.ts`\n *\n * MIT License\n * Copyright (c) Hiroki Osame <hiroki.osame@gmail.com>\n */\nimport { existsSync, statSync } from \"node:fs\";\nimport Module from \"node:module\";\nimport { isAbsolute, join, resolve } from \"node:path\";\n\nimport { findUpSync, readFileSync } from \"@visulima/fs\";\nimport { parse } from \"jsonc-parser\";\nimport type { PathConditions } from \"resolve-pkg-maps\";\nimport { resolveExports } from \"resolve-pkg-maps\";\nimport type { PackageJson } from \"type-fest\";\n\nimport type { Cache } from \"../types\";\n\nconst readJsonc = (jsonPath: string) => parse(readFileSync(jsonPath) as string) as unknown;\n\nconst getPnpApi = () => {\n const { findPnpApi } = Module;\n\n // https://yarnpkg.com/advanced/pnpapi/#requirepnpapi\n return findPnpApi?.(process.cwd());\n};\n\nconst resolveFromPackageJsonPath = (packageJsonPath: string, subpath: string, ignoreExports?: boolean, cache?: Cache<string>) => {\n const cacheKey = `resolveFromPackageJsonPath:${packageJsonPath}:${subpath}:${ignoreExports}`;\n\n if (cache?.has(cacheKey)) {\n return cache.get(cacheKey);\n }\n\n const packageJson = readJsonc(packageJsonPath);\n\n if (!packageJson) {\n return undefined;\n }\n\n let resolvedPath = subpath || \"tsconfig.json\";\n\n if (!ignoreExports && (packageJson as PackageJson).exports) {\n try {\n const [resolvedExport] = resolveExports((packageJson as PackageJson).exports as PathConditions, subpath, [\"require\", \"types\"]);\n\n resolvedPath = resolvedExport as string;\n } catch {\n // Block\n return false;\n }\n } else if (!subpath && (packageJson as PackageJson)[\"tsconfig\"]) {\n resolvedPath = (packageJson as PackageJson)[\"tsconfig\"] as string;\n }\n\n resolvedPath = join(packageJsonPath, \"..\", resolvedPath);\n\n cache?.set(cacheKey, resolvedPath);\n\n return resolvedPath;\n};\n\nconst PACKAGE_JSON = \"package.json\";\nconst TS_CONFIG_JSON = \"tsconfig.json\";\n\n// eslint-disable-next-line sonarjs/cognitive-complexity\nconst resolveExtendsPath = (requestedPath: string, directoryPath: string, cache?: Cache<string>): string | undefined => {\n let filePath = requestedPath;\n\n if (requestedPath === \"..\") {\n filePath = join(filePath, TS_CONFIG_JSON);\n }\n\n if (requestedPath.startsWith(\".\")) {\n filePath = resolve(directoryPath, filePath);\n }\n\n if (isAbsolute(filePath)) {\n // eslint-disable-next-line security/detect-non-literal-fs-filename\n if (existsSync(filePath)) {\n // eslint-disable-next-line security/detect-non-literal-fs-filename\n if (statSync(filePath).isFile()) {\n return filePath;\n }\n } else if (!filePath.endsWith(\".json\")) {\n const jsonPath = `${filePath}.json`;\n\n // eslint-disable-next-line security/detect-non-literal-fs-filename\n if (existsSync(jsonPath)) {\n return jsonPath;\n }\n }\n\n return undefined;\n }\n\n const [orgOrName, ...remaining] = requestedPath.split(\"/\");\n const packageName = ((orgOrName as string).startsWith(\"@\") ? `${orgOrName}/${remaining.shift()}` : orgOrName) as string;\n const subpath = remaining.join(\"/\");\n\n const pnpApi = getPnpApi();\n\n if (pnpApi) {\n const { resolveRequest: resolveWithPnp } = pnpApi;\n\n try {\n if (packageName === requestedPath) {\n const packageJsonPath = resolveWithPnp(join(packageName, PACKAGE_JSON), directoryPath);\n\n if (packageJsonPath) {\n const resolvedPath = resolveFromPackageJsonPath(packageJsonPath, subpath, false, cache);\n\n // eslint-disable-next-line security/detect-non-literal-fs-filename\n if (resolvedPath && existsSync(resolvedPath)) {\n return resolvedPath;\n }\n }\n } else {\n let resolved: string | null;\n\n try {\n resolved = resolveWithPnp(requestedPath, directoryPath, { extensions: [\".json\"] });\n } catch {\n resolved = resolveWithPnp(join(requestedPath, TS_CONFIG_JSON), directoryPath);\n }\n\n if (resolved) {\n return resolved;\n }\n }\n } catch {\n /* empty */\n }\n }\n\n const packagePath = findUpSync((directory) => {\n const path = join(directory, \"node_modules\", packageName);\n\n // eslint-disable-next-line security/detect-non-literal-fs-filename\n if (existsSync(path)) {\n return join(\"node_modules\", packageName);\n }\n\n return undefined;\n }, {\n cwd: directoryPath,\n type: \"directory\"\n });\n\n // eslint-disable-next-line security/detect-non-literal-fs-filename\n if (!packagePath || !statSync(packagePath).isDirectory()) {\n return undefined;\n }\n\n const packageJsonPath = join(packagePath, PACKAGE_JSON);\n\n // eslint-disable-next-line security/detect-non-literal-fs-filename\n if (existsSync(packageJsonPath)) {\n const resolvedPath = resolveFromPackageJsonPath(packageJsonPath, subpath, false, cache);\n\n // Blocked\n if (resolvedPath === false) {\n return undefined;\n }\n\n // eslint-disable-next-line security/detect-non-literal-fs-filename\n if (resolvedPath && existsSync(resolvedPath) && statSync(resolvedPath).isFile()) {\n return resolvedPath;\n }\n }\n\n const fullPackagePath = join(packagePath, subpath);\n const jsonExtension = fullPackagePath.endsWith(\".json\");\n\n if (!jsonExtension) {\n const fullPackagePathWithJson = `${fullPackagePath}.json`;\n\n // eslint-disable-next-line security/detect-non-literal-fs-filename\n if (existsSync(fullPackagePathWithJson)) {\n return fullPackagePathWithJson;\n }\n }\n\n // eslint-disable-next-line security/detect-non-literal-fs-filename\n if (!existsSync(fullPackagePath)) {\n return undefined;\n }\n\n // eslint-disable-next-line security/detect-non-literal-fs-filename\n if (statSync(fullPackagePath).isDirectory()) {\n const fullPackageJsonPath = join(fullPackagePath, PACKAGE_JSON);\n\n // eslint-disable-next-line security/detect-non-literal-fs-filename\n if (existsSync(fullPackageJsonPath)) {\n const resolvedPath = resolveFromPackageJsonPath(fullPackageJsonPath, \"\", true, cache);\n\n // eslint-disable-next-line security/detect-non-literal-fs-filename\n if (resolvedPath && existsSync(resolvedPath)) {\n return resolvedPath;\n }\n }\n\n const tsconfigPath = join(fullPackagePath, TS_CONFIG_JSON);\n\n // eslint-disable-next-line security/detect-non-literal-fs-filename\n if (existsSync(tsconfigPath)) {\n return tsconfigPath;\n }\n } else if (jsonExtension) {\n return fullPackagePath;\n }\n\n return undefined;\n};\n\nexport default resolveExtendsPath;\n"]}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { findUp, findUpSync, writeJson, readFileSync } from '@visulima/fs';
|
|
2
|
+
import { NotFoundError } from '@visulima/fs/error';
|
|
3
|
+
import { toPath } from '@visulima/fs/utils';
|
|
4
|
+
import { join, dirname, resolve, relative, normalize, toNamespacedPath } from 'pathe';
|
|
5
|
+
import { realpathSync, existsSync, statSync } from 'node:fs';
|
|
6
|
+
import { parse } from 'jsonc-parser';
|
|
7
|
+
import N from 'node:module';
|
|
8
|
+
import { join as join$1, resolve as resolve$1, isAbsolute } from 'node:path';
|
|
9
|
+
import { resolveExports } from 'resolve-pkg-maps';
|
|
10
|
+
|
|
11
|
+
var _=s=>parse(readFileSync(s)),L=()=>{let{findPnpApi:s}=N;return s?.(process.cwd())},v=(s,o,l,n)=>{let t=`resolveFromPackageJsonPath:${s}:${o}:${l}`;if(n?.has(t))return n.get(t);let i=_(s);if(!i)return;let e=o||"tsconfig.json";if(!l&&i.exports)try{let[a]=resolveExports(i.exports,o,["require","types"]);e=a;}catch{return !1}else !o&&i.tsconfig&&(e=i.tsconfig);return e=join$1(s,"..",e),n?.set(t,e),e},P="package.json",T="tsconfig.json",G=(s,o,l)=>{let n=s;if(s===".."&&(n=join$1(n,T)),s.startsWith(".")&&(n=resolve$1(o,n)),isAbsolute(n)){if(existsSync(n)){if(statSync(n).isFile())return n}else if(!n.endsWith(".json")){let c=`${n}.json`;if(existsSync(c))return c}return}let[t,...i]=s.split("/"),e=t.startsWith("@")?`${t}/${i.shift()}`:t,a=i.join("/"),r=L();if(r){let{resolveRequest:c}=r;try{if(e===s){let p=c(join$1(e,P),o);if(p){let h=v(p,a,!1,l);if(h&&existsSync(h))return h}}else {let p;try{p=c(s,o,{extensions:[".json"]});}catch{p=c(join$1(s,T),o);}if(p)return p}}catch{}}let f=findUpSync(c=>{let p=join$1(c,"node_modules",e);if(existsSync(p))return join$1("node_modules",e)},{cwd:o,type:"directory"});if(!f||!statSync(f).isDirectory())return;let g=join$1(f,P);if(existsSync(g)){let c=v(g,a,!1,l);if(c===!1)return;if(c&&existsSync(c)&&statSync(c).isFile())return c}let m=join$1(f,a),C=m.endsWith(".json");if(!C){let c=`${m}.json`;if(existsSync(c))return c}if(existsSync(m)){if(statSync(m).isDirectory()){let c=join$1(m,P);if(existsSync(c)){let h=v(c,"",!0,l);if(h&&existsSync(h))return h}let p=join$1(m,T);if(existsSync(p))return p}else if(C)return m}},F=G;var Z=Symbol("implicitBaseUrl"),q=s=>parse(readFileSync(s)),O=s=>toNamespacedPath(/^\.{1,2}(?:\/.*)?$/.test(s)?s:`./${s}`),ee=(s,o,l,n)=>{let t=F(s,o);if(!t)throw new NotFoundError(`for '${s}' found.`);if(l.has(t))throw new Error(`Circularity detected while resolving configuration: ${t}`);l.add(t);let i=dirname(t),e=I(t,n,l);delete e.references;let{compilerOptions:a}=e;if(a){let r=["baseUrl","outDir"];for(let f of r){let g=a[f];g&&(a[f]=relative(o,join(i,g)).replaceAll("\\","/")||"./");}}return e.files&&(e.files=e.files.map(r=>relative(o,join(i,r)))),e.include&&(e.include=e.include.map(r=>relative(o,join(i,r)))),e.exclude&&(e.exclude=e.exclude.map(r=>relative(o,join(i,r)))),e},I=(s,o,l=new Set)=>{let n;try{n=realpathSync(s);}catch{throw new Error(`Cannot resolve tsconfig at path: ${s}`)}let t=q(n)||{};if(typeof t!="object")throw new SyntaxError(`Failed to parse tsconfig at: ${s}`);let i=dirname(n);if(t.compilerOptions){let{compilerOptions:e}=t;e.paths&&!e.baseUrl&&(e[Z]=i);}if(t.extends){let e=Array.isArray(t.extends)?t.extends:[t.extends];delete t.extends;for(let a of e.reverse()){let r=ee(a,i,new Set(l),o),f={...r,...t,compilerOptions:{...r.compilerOptions,...t.compilerOptions}};r.watchOptions&&(f.watchOptions={...r.watchOptions,...t.watchOptions}),t=f;}}if(t.compilerOptions){let{compilerOptions:e}=t,a=["baseUrl","rootDir"];for(let f of a){let g=e[f];if(g){let m=resolve(i,g),C=relative(i,m);e[f]=O(C);}}let{outDir:r}=e;r&&(Array.isArray(t.exclude)||(t.exclude=[]),t.exclude.includes(r)||t.exclude.push(r),e.outDir=O(r)),o?.tscCompatible&&e.module==="node16"&&(e.allowSyntheticDefaultImports=e.allowSyntheticDefaultImports??!0,e.esModuleInterop=e.esModuleInterop??!0,e.moduleDetection=e.moduleDetection??"force",e.moduleResolution=e.moduleResolution??"node16",e.target=e.target??"es2022",e.useDefineForClassFields=e.useDefineForClassFields??!0),o?.tscCompatible&&e.strict&&(e.noImplicitAny=e.noImplicitAny??!0,e.noImplicitThis=e.noImplicitThis??!0,e.strictNullChecks=e.strictNullChecks??!0,e.strictFunctionTypes=e.strictFunctionTypes??!0,e.strictBindCallApply=e.strictBindCallApply??!0,e.strictPropertyInitialization=e.strictPropertyInitialization??!0,e.alwaysStrict=e.alwaysStrict??!0,e.useUnknownInCatchVariables=e.useUnknownInCatchVariables??!0),o?.tscCompatible&&e.isolatedModules&&(e.preserveConstEnums=e.preserveConstEnums??!0),o?.tscCompatible&&e.esModuleInterop&&(e.allowSyntheticDefaultImports=e.allowSyntheticDefaultImports??!0),o?.tscCompatible&&e.target==="esnext"&&(e.useDefineForClassFields=e.useDefineForClassFields??!0);}else t.compilerOptions={};if(t.files&&(t.files=t.files.map(e=>O(e))),t.include&&(t.include=t.include.map(e=>normalize(e))),t.watchOptions){let{watchOptions:e}=t;e.excludeDirectories&&(e.excludeDirectories=e.excludeDirectories.map(a=>resolve(i,a)));}return t},te=(s,o)=>I(s,o),J=te;var A=new Map,ie=async(s,o={})=>{let l=o.configFileName??"tsconfig.json",n=await findUp(l,{...s&&{cwd:s},type:"file"});if(n||(n=await findUp("jsconfig.json",{...s&&{cwd:s},type:"file"})),!n)throw new NotFoundError(`for ${l} or jsconfig.json found.`);let t=o.cache&&typeof o.cache!="boolean"?o.cache:A;if(o.cache&&t.has(n))return t.get(n);let i={config:J(n),path:n};return o.cache&&t.set(n,i),i},be=ie,re=(s,o={})=>{let l=o.configFileName??"tsconfig.json",n=findUpSync(l,{...s&&{cwd:s},type:"file"});if(n||(n=findUpSync("jsconfig.json",{...s&&{cwd:s},type:"file"})),!n)throw new NotFoundError(`for ${l} or jsconfig.json found.`);let t=o.cache&&typeof o.cache!="boolean"?o.cache:A;if(o.cache&&t.has(n))return t.get(n);let i={config:J(n),path:n};return o.cache&&t.set(n,i),i},ke=re,ce=async(s,o={})=>{let{cwd:l,...n}=o,t=toPath(o.cwd??process.cwd());await writeJson(join(t,"tsconfig.json"),s,n);},Ie=ce;
|
|
12
|
+
|
|
13
|
+
export { J as a, ie as b, be as c, re as d, ke as e, ce as f, Ie as g };
|
|
14
|
+
//# sourceMappingURL=out.js.map
|
|
15
|
+
//# sourceMappingURL=chunk-F63DY4KL.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/tsconfig.ts","../src/read-tsconfig.ts","../src/utils/resolve-extends-path.ts"],"names":["findUp","findUpSync","writeJson","NotFoundError","toPath","join","realpathSync","readFileSync","parse","dirname","normalize","relative","resolve","toNamespacedPath","existsSync","statSync","Module","isAbsolute","resolveExports","readJsonc","jsonPath","getPnpApi","findPnpApi","resolveFromPackageJsonPath","packageJsonPath","subpath","ignoreExports","cache","cacheKey","packageJson","resolvedPath","resolvedExport","PACKAGE_JSON","TS_CONFIG_JSON","resolveExtendsPath","requestedPath","directoryPath","filePath","orgOrName","remaining","packageName","pnpApi","resolveWithPnp","resolved","packagePath","directory","path","fullPackagePath","jsonExtension","fullPackagePathWithJson","fullPackageJsonPath","tsconfigPath","resolve_extends_path_default","implicitBaseUrlSymbol","normalizePath","resolveExtends","extendsPath","fromDirectoryPath","circularExtendsTracker","options","resolvedExtendsPath","extendsDirectoryPath","extendsConfig","internalParseTsConfig","compilerOptions","resolvePaths","property","unresolvedPath","file","realTsconfigPath","config","extendsPathList","merged","normalizedPaths","resolvedBaseUrl","relativeBaseUrl","outDir","element","watchOptions","excludePath","readTsConfig","read_tsconfig_default","TsConfigFileCache","findTsConfig","cwd","configFileName","output","findTSConfig","findTsConfigSync","findTSConfigSync","writeTsConfig","data","writeOptions","writeTSConfig"],"mappings":"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","sourcesContent":["import type { WriteJsonOptions } from \"@visulima/fs\";\nimport { findUp, findUpSync, writeJson } from \"@visulima/fs\";\nimport { NotFoundError } from \"@visulima/fs/error\";\nimport { toPath } from \"@visulima/fs/utils\";\nimport { join } from \"pathe\";\nimport type { TsConfigJson } from \"type-fest\";\n\nimport readTsConfig from \"./read-tsconfig\";\nimport type { TsConfigJsonResolved } from \"./types\";\n\ntype Options = {\n cache?: Map<string, TsConfigJsonResolved> | boolean;\n configFileName?: string;\n};\n\nconst TsConfigFileCache = new Map<string, TsConfigResult>();\n\nexport type TsConfigResult = {\n config: TsConfigJsonResolved;\n path: string;\n};\n\n/**\n * An asynchronous function that retrieves the TSConfig by searching for the \"tsconfig.json\" first,\n * second attempt is to look for the \"jsconfig.json\" file from a given current working directory.\n *\n * @param cwd - Optional. The current working directory from which to search for the \"tsconfig.json\" file.\n * The type of `cwd` is `string`.\n * @returns A `Promise` that resolves to the TSConfig result object.\n * The return type of the function is `Promise<TsConfigResult>`.\n * @throws An `Error` when the \"tsconfig.json\" file is not found.\n */\nexport const findTsConfig = async (cwd?: URL | string, options: Options = {}): Promise<TsConfigResult> => {\n const configFileName = options.configFileName ?? \"tsconfig.json\";\n\n let filePath = await findUp(configFileName, {\n ...(cwd && { cwd }),\n type: \"file\",\n });\n\n if (!filePath) {\n filePath = await findUp(\"jsconfig.json\", {\n ...(cwd && { cwd }),\n type: \"file\",\n });\n }\n\n if (!filePath) {\n throw new NotFoundError(`for ${configFileName} or jsconfig.json found.`);\n }\n\n const cache = options.cache && typeof options.cache !== \"boolean\" ? options.cache : TsConfigFileCache;\n\n if (options.cache && cache.has(filePath)) {\n return cache.get(filePath) as TsConfigResult;\n }\n\n const output = {\n config: readTsConfig(filePath),\n path: filePath,\n };\n\n if (options.cache) {\n cache.set(filePath, output);\n }\n\n return output;\n};\n\n// @deprecate Please use `findTsConfig` instead.\nexport const findTSConfig = findTsConfig;\n\nexport const findTsConfigSync = (cwd?: URL | string, options: Options = {}): TsConfigResult => {\n const configFileName = options.configFileName ?? \"tsconfig.json\";\n\n let filePath = findUpSync(configFileName, {\n ...(cwd && { cwd }),\n type: \"file\",\n });\n\n if (!filePath) {\n filePath = findUpSync(\"jsconfig.json\", {\n ...(cwd && { cwd }),\n type: \"file\",\n });\n }\n\n if (!filePath) {\n throw new NotFoundError(`for ${configFileName} or jsconfig.json found.`);\n }\n\n const cache = options.cache && typeof options.cache !== \"boolean\" ? options.cache : TsConfigFileCache;\n\n if (options.cache && cache.has(filePath)) {\n return cache.get(filePath) as TsConfigResult;\n }\n\n const output = {\n config: readTsConfig(filePath),\n path: filePath,\n };\n\n if (options.cache) {\n cache.set(filePath, output);\n }\n\n return output;\n};\n\n// @deprecate Please use `findTsConfigSync` instead.\nexport const findTSConfigSync = findTsConfigSync;\n\n/**\n * An asynchronous function that writes the provided TypeScript configuration object to a tsconfig.json file.\n *\n * @param tsConfig - The TypeScript configuration object to write. The type of `tsConfig` is `TsConfigJson`.\n * @param options - Optional. The write options and the current working directory. The type of `options` is an\n * intersection type of `WriteOptions` and a Record type with an optional `cwd` key of type `string`.\n * @returns A `Promise` that resolves when the tsconfig.json file has been written.\n * The return type of function is `Promise<void>`.\n */\nexport const writeTsConfig = async (data: TsConfigJson, options: WriteJsonOptions & { cwd?: URL | string } = {}): Promise<void> => {\n const { cwd, ...writeOptions } = options;\n\n const directory = toPath(options.cwd ?? process.cwd());\n\n await writeJson(join(directory, \"tsconfig.json\"), data, writeOptions);\n};\n\n// @deprecate Please use `writeTsconfig` instead.\nexport const writeTSConfig = writeTsConfig;\n","/**\n * A modified version of `readTsconfig` from `https://github.com/privatenumber/get-tsconfig/blob/develop/src/parse-tsconfig/index.ts`\n *\n * MIT License\n * Copyright (c) Hiroki Osame <hiroki.osame@gmail.com>\n */\nimport { realpathSync } from \"node:fs\";\n\nimport { readFileSync } from \"@visulima/fs\";\nimport { NotFoundError } from \"@visulima/fs/error\";\nimport { parse } from \"jsonc-parser\";\nimport { dirname, join, normalize, relative, resolve, toNamespacedPath } from \"pathe\";\nimport type { TsConfigJson } from \"type-fest\";\n\nimport type { TsConfigJsonResolved } from \"./types\";\nimport resolveExtendsPath from \"./utils/resolve-extends-path\";\n\ntype Options = {\n tscCompatible?: boolean;\n};\n\nconst implicitBaseUrlSymbol = Symbol(\"implicitBaseUrl\");\n\nconst readJsonc = (jsonPath: string) => parse(readFileSync(jsonPath) as string) as unknown;\n// eslint-disable-next-line security/detect-unsafe-regex\nconst normalizePath = (path: string): string => toNamespacedPath(/^\\.{1,2}(?:\\/.*)?$/.test(path) ? path : `./${path}`);\n\nconst resolveExtends = (extendsPath: string, fromDirectoryPath: string, circularExtendsTracker: Set<string>, options?: Options) => {\n const resolvedExtendsPath = resolveExtendsPath(extendsPath, fromDirectoryPath);\n\n if (!resolvedExtendsPath) {\n throw new NotFoundError(`for '${extendsPath}' found.`);\n }\n\n if (circularExtendsTracker.has(resolvedExtendsPath)) {\n throw new Error(`Circularity detected while resolving configuration: ${resolvedExtendsPath}`);\n }\n\n circularExtendsTracker.add(resolvedExtendsPath);\n\n const extendsDirectoryPath = dirname(resolvedExtendsPath);\n // eslint-disable-next-line @typescript-eslint/no-use-before-define\n const extendsConfig = internalParseTsConfig(resolvedExtendsPath, options, circularExtendsTracker);\n\n delete extendsConfig.references;\n\n const { compilerOptions } = extendsConfig;\n\n if (compilerOptions) {\n const resolvePaths = [\"baseUrl\", \"outDir\"] as const;\n\n // eslint-disable-next-line no-loops/no-loops,no-restricted-syntax\n for (const property of resolvePaths) {\n // eslint-disable-next-line security/detect-object-injection\n const unresolvedPath = compilerOptions[property];\n\n if (unresolvedPath) {\n // eslint-disable-next-line security/detect-object-injection\n compilerOptions[property] = relative(fromDirectoryPath, join(extendsDirectoryPath, unresolvedPath)).replaceAll(\"\\\\\", \"/\") || \"./\";\n }\n }\n }\n\n if (extendsConfig.files) {\n extendsConfig.files = extendsConfig.files.map((file) => relative(fromDirectoryPath, join(extendsDirectoryPath, file)));\n }\n\n if (extendsConfig.include) {\n extendsConfig.include = extendsConfig.include.map((file) => relative(fromDirectoryPath, join(extendsDirectoryPath, file)));\n }\n\n if (extendsConfig.exclude) {\n extendsConfig.exclude = extendsConfig.exclude.map((file) => relative(fromDirectoryPath, join(extendsDirectoryPath, file)));\n }\n\n return extendsConfig;\n};\n\n// eslint-disable-next-line sonarjs/cognitive-complexity\nconst internalParseTsConfig = (tsconfigPath: string, options?: Options, circularExtendsTracker = new Set<string>()): TsConfigJsonResolved => {\n let realTsconfigPath: string;\n\n try {\n // eslint-disable-next-line security/detect-non-literal-fs-filename\n realTsconfigPath = realpathSync(tsconfigPath) as string;\n } catch {\n throw new Error(`Cannot resolve tsconfig at path: ${tsconfigPath}`);\n }\n\n /**\n * Decided not to cache the TsConfigJsonResolved object because it's\n * mutable.\n *\n * Note how `resolveExtends` can call `readTsconfig` rescursively\n * and actually mutates the object. It can also be mutated in\n * user-land.\n *\n * By only caching fs results, we can avoid serving mutated objects\n */\n let config: TsConfigJson = readJsonc(realTsconfigPath) || {};\n\n if (typeof config !== \"object\") {\n throw new SyntaxError(`Failed to parse tsconfig at: ${tsconfigPath}`);\n }\n\n const directoryPath = dirname(realTsconfigPath);\n\n if (config.compilerOptions) {\n const { compilerOptions } = config;\n if (compilerOptions.paths && !compilerOptions.baseUrl) {\n type WithImplicitBaseUrl = TsConfigJson.CompilerOptions & {\n [implicitBaseUrlSymbol]: string;\n };\n // eslint-disable-next-line security/detect-object-injection\n (compilerOptions as WithImplicitBaseUrl)[implicitBaseUrlSymbol] = directoryPath;\n }\n }\n\n if (config.extends) {\n const extendsPathList = Array.isArray(config.extends) ? config.extends : [config.extends];\n\n delete config.extends;\n\n // eslint-disable-next-line no-loops/no-loops,no-restricted-syntax,etc/no-assign-mutated-array\n for (const extendsPath of extendsPathList.reverse()) {\n const extendsConfig = resolveExtends(extendsPath, directoryPath, new Set(circularExtendsTracker), options);\n const merged = {\n ...extendsConfig,\n ...config,\n\n compilerOptions: {\n ...extendsConfig.compilerOptions,\n ...config.compilerOptions,\n },\n };\n\n if (extendsConfig.watchOptions) {\n merged.watchOptions = {\n ...extendsConfig.watchOptions,\n ...config.watchOptions,\n };\n }\n\n config = merged;\n }\n }\n\n if (config.compilerOptions) {\n const { compilerOptions } = config;\n const normalizedPaths = [\"baseUrl\", \"rootDir\"] as const;\n\n // eslint-disable-next-line no-loops/no-loops,no-restricted-syntax\n for (const property of normalizedPaths) {\n // eslint-disable-next-line security/detect-object-injection\n const unresolvedPath = compilerOptions[property];\n\n if (unresolvedPath) {\n const resolvedBaseUrl = resolve(directoryPath, unresolvedPath);\n const relativeBaseUrl = relative(directoryPath, resolvedBaseUrl);\n\n // eslint-disable-next-line security/detect-object-injection\n compilerOptions[property] = normalizePath(relativeBaseUrl);\n }\n }\n\n const { outDir } = compilerOptions;\n\n if (outDir) {\n if (!Array.isArray(config.exclude)) {\n config.exclude = [];\n }\n\n if (!config.exclude.includes(outDir)) {\n config.exclude.push(outDir);\n }\n\n compilerOptions.outDir = normalizePath(outDir);\n }\n\n if (options?.tscCompatible && compilerOptions.module === \"node16\") {\n compilerOptions.allowSyntheticDefaultImports = compilerOptions.allowSyntheticDefaultImports ?? true;\n compilerOptions.esModuleInterop = compilerOptions.esModuleInterop ?? true;\n compilerOptions.moduleDetection = compilerOptions.moduleDetection ?? \"force\";\n compilerOptions.moduleResolution = compilerOptions.moduleResolution ?? \"node16\";\n compilerOptions.target = compilerOptions.target ?? \"es2022\";\n compilerOptions.useDefineForClassFields = compilerOptions.useDefineForClassFields ?? true;\n }\n\n if (options?.tscCompatible && compilerOptions.strict) {\n compilerOptions.noImplicitAny = compilerOptions.noImplicitAny ?? true;\n compilerOptions.noImplicitThis = compilerOptions.noImplicitThis ?? true;\n compilerOptions.strictNullChecks = compilerOptions.strictNullChecks ?? true;\n compilerOptions.strictFunctionTypes = compilerOptions.strictFunctionTypes ?? true;\n compilerOptions.strictBindCallApply = compilerOptions.strictBindCallApply ?? true;\n compilerOptions.strictPropertyInitialization = compilerOptions.strictPropertyInitialization ?? true;\n compilerOptions.alwaysStrict = compilerOptions.alwaysStrict ?? true;\n compilerOptions.useUnknownInCatchVariables = compilerOptions.useUnknownInCatchVariables ?? true;\n }\n\n if (options?.tscCompatible && compilerOptions.isolatedModules) {\n compilerOptions.preserveConstEnums = compilerOptions.preserveConstEnums ?? true;\n }\n\n if (options?.tscCompatible && compilerOptions.esModuleInterop) {\n compilerOptions.allowSyntheticDefaultImports = compilerOptions.allowSyntheticDefaultImports ?? true;\n }\n\n if (options?.tscCompatible && compilerOptions.target === \"esnext\") {\n compilerOptions.useDefineForClassFields = compilerOptions.useDefineForClassFields ?? true;\n }\n } else {\n config.compilerOptions = {};\n }\n\n if (config.files) {\n config.files = config.files.map((element) => normalizePath(element));\n }\n\n if (config.include) {\n config.include = config.include.map((element) => normalize(element));\n }\n\n if (config.watchOptions) {\n const { watchOptions } = config;\n\n if (watchOptions.excludeDirectories) {\n watchOptions.excludeDirectories = watchOptions.excludeDirectories.map((excludePath) => resolve(directoryPath, excludePath));\n }\n }\n\n return config;\n};\n\nconst readTsConfig = (tsconfigPath: string, options?: Options): TsConfigJsonResolved => internalParseTsConfig(tsconfigPath, options);\n\nexport default readTsConfig;\n","/**\n * A modified version of `resolveExtendsPath` from `https://github.com/privatenumber/get-tsconfig/blob/develop/src/parse-tsconfig/resolve-extends-path.ts`\n *\n * MIT License\n * Copyright (c) Hiroki Osame <hiroki.osame@gmail.com>\n */\nimport { existsSync, statSync } from \"node:fs\";\nimport Module from \"node:module\";\nimport { isAbsolute, join, resolve } from \"node:path\";\n\nimport { findUpSync, readFileSync } from \"@visulima/fs\";\nimport { parse } from \"jsonc-parser\";\nimport type { PathConditions } from \"resolve-pkg-maps\";\nimport { resolveExports } from \"resolve-pkg-maps\";\nimport type { PackageJson } from \"type-fest\";\n\nimport type { Cache } from \"../types\";\n\nconst readJsonc = (jsonPath: string) => parse(readFileSync(jsonPath) as string) as unknown;\n\nconst getPnpApi = () => {\n const { findPnpApi } = Module;\n\n // https://yarnpkg.com/advanced/pnpapi/#requirepnpapi\n return findPnpApi?.(process.cwd());\n};\n\nconst resolveFromPackageJsonPath = (packageJsonPath: string, subpath: string, ignoreExports?: boolean, cache?: Cache<string>) => {\n const cacheKey = `resolveFromPackageJsonPath:${packageJsonPath}:${subpath}:${ignoreExports}`;\n\n if (cache?.has(cacheKey)) {\n return cache.get(cacheKey);\n }\n\n const packageJson = readJsonc(packageJsonPath);\n\n if (!packageJson) {\n return undefined;\n }\n\n let resolvedPath = subpath || \"tsconfig.json\";\n\n if (!ignoreExports && (packageJson as PackageJson).exports) {\n try {\n const [resolvedExport] = resolveExports((packageJson as PackageJson).exports as PathConditions, subpath, [\"require\", \"types\"]);\n\n resolvedPath = resolvedExport as string;\n } catch {\n // Block\n return false;\n }\n } else if (!subpath && (packageJson as PackageJson)[\"tsconfig\"]) {\n resolvedPath = (packageJson as PackageJson)[\"tsconfig\"] as string;\n }\n\n resolvedPath = join(packageJsonPath, \"..\", resolvedPath);\n\n cache?.set(cacheKey, resolvedPath);\n\n return resolvedPath;\n};\n\nconst PACKAGE_JSON = \"package.json\";\nconst TS_CONFIG_JSON = \"tsconfig.json\";\n\n// eslint-disable-next-line sonarjs/cognitive-complexity\nconst resolveExtendsPath = (requestedPath: string, directoryPath: string, cache?: Cache<string>): string | undefined => {\n let filePath = requestedPath;\n\n if (requestedPath === \"..\") {\n filePath = join(filePath, TS_CONFIG_JSON);\n }\n\n if (requestedPath.startsWith(\".\")) {\n filePath = resolve(directoryPath, filePath);\n }\n\n if (isAbsolute(filePath)) {\n // eslint-disable-next-line security/detect-non-literal-fs-filename\n if (existsSync(filePath)) {\n // eslint-disable-next-line security/detect-non-literal-fs-filename\n if (statSync(filePath).isFile()) {\n return filePath;\n }\n } else if (!filePath.endsWith(\".json\")) {\n const jsonPath = `${filePath}.json`;\n\n // eslint-disable-next-line security/detect-non-literal-fs-filename\n if (existsSync(jsonPath)) {\n return jsonPath;\n }\n }\n\n return undefined;\n }\n\n const [orgOrName, ...remaining] = requestedPath.split(\"/\");\n const packageName = ((orgOrName as string).startsWith(\"@\") ? `${orgOrName}/${remaining.shift()}` : orgOrName) as string;\n const subpath = remaining.join(\"/\");\n\n const pnpApi = getPnpApi();\n\n if (pnpApi) {\n const { resolveRequest: resolveWithPnp } = pnpApi;\n\n try {\n if (packageName === requestedPath) {\n const packageJsonPath = resolveWithPnp(join(packageName, PACKAGE_JSON), directoryPath);\n\n if (packageJsonPath) {\n const resolvedPath = resolveFromPackageJsonPath(packageJsonPath, subpath, false, cache);\n\n // eslint-disable-next-line security/detect-non-literal-fs-filename\n if (resolvedPath && existsSync(resolvedPath)) {\n return resolvedPath;\n }\n }\n } else {\n let resolved: string | null;\n\n try {\n resolved = resolveWithPnp(requestedPath, directoryPath, { extensions: [\".json\"] });\n } catch {\n resolved = resolveWithPnp(join(requestedPath, TS_CONFIG_JSON), directoryPath);\n }\n\n if (resolved) {\n return resolved;\n }\n }\n } catch {\n /* empty */\n }\n }\n\n const packagePath = findUpSync((directory) => {\n const path = join(directory, \"node_modules\", packageName);\n\n // eslint-disable-next-line security/detect-non-literal-fs-filename\n if (existsSync(path)) {\n return join(\"node_modules\", packageName);\n }\n\n return undefined;\n }, {\n cwd: directoryPath,\n type: \"directory\"\n });\n\n // eslint-disable-next-line security/detect-non-literal-fs-filename\n if (!packagePath || !statSync(packagePath).isDirectory()) {\n return undefined;\n }\n\n const packageJsonPath = join(packagePath, PACKAGE_JSON);\n\n // eslint-disable-next-line security/detect-non-literal-fs-filename\n if (existsSync(packageJsonPath)) {\n const resolvedPath = resolveFromPackageJsonPath(packageJsonPath, subpath, false, cache);\n\n // Blocked\n if (resolvedPath === false) {\n return undefined;\n }\n\n // eslint-disable-next-line security/detect-non-literal-fs-filename\n if (resolvedPath && existsSync(resolvedPath) && statSync(resolvedPath).isFile()) {\n return resolvedPath;\n }\n }\n\n const fullPackagePath = join(packagePath, subpath);\n const jsonExtension = fullPackagePath.endsWith(\".json\");\n\n if (!jsonExtension) {\n const fullPackagePathWithJson = `${fullPackagePath}.json`;\n\n // eslint-disable-next-line security/detect-non-literal-fs-filename\n if (existsSync(fullPackagePathWithJson)) {\n return fullPackagePathWithJson;\n }\n }\n\n // eslint-disable-next-line security/detect-non-literal-fs-filename\n if (!existsSync(fullPackagePath)) {\n return undefined;\n }\n\n // eslint-disable-next-line security/detect-non-literal-fs-filename\n if (statSync(fullPackagePath).isDirectory()) {\n const fullPackageJsonPath = join(fullPackagePath, PACKAGE_JSON);\n\n // eslint-disable-next-line security/detect-non-literal-fs-filename\n if (existsSync(fullPackageJsonPath)) {\n const resolvedPath = resolveFromPackageJsonPath(fullPackageJsonPath, \"\", true, cache);\n\n // eslint-disable-next-line security/detect-non-literal-fs-filename\n if (resolvedPath && existsSync(resolvedPath)) {\n return resolvedPath;\n }\n }\n\n const tsconfigPath = join(fullPackagePath, TS_CONFIG_JSON);\n\n // eslint-disable-next-line security/detect-non-literal-fs-filename\n if (existsSync(tsconfigPath)) {\n return tsconfigPath;\n }\n } else if (jsonExtension) {\n return fullPackagePath;\n }\n\n return undefined;\n};\n\nexport default resolveExtendsPath;\n"]}
|
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
import { a } from './chunk-
|
|
2
|
-
import { dirname } from 'node:path';
|
|
1
|
+
import { a } from './chunk-5ZQIFU6S.js';
|
|
3
2
|
import { findUp } from '@visulima/fs';
|
|
3
|
+
import { dirname } from 'pathe';
|
|
4
4
|
|
|
5
5
|
var p=async t=>{try{let a$1=await a(t);return dirname(a$1)}catch{}let o=await findUp(".git/config",{...t&&{cwd:t},type:"file"});if(o)return dirname(dirname(o));let r=await findUp("package.json",{...t&&{cwd:t},type:"file"});if(r)return dirname(r);throw new Error("Could not find root directory")};
|
|
6
6
|
|
|
7
7
|
export { p as a };
|
|
8
8
|
//# sourceMappingURL=out.js.map
|
|
9
|
-
//# sourceMappingURL=chunk-
|
|
9
|
+
//# sourceMappingURL=chunk-G767QS5X.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/package.ts"],"names":["findUp","dirname","findPackageRoot","cwd","lockFile","findLockFile","gitConfig","filePath"],"mappings":"wCAAA,OAAS,UAAAA,MAAc,eACvB,OAAS,WAAAC,MAAe,QAgBjB,IAAMC,EAAkB,MAAOC,GAAwC,CAE1E,GAAI,CACA,IAAMC,EAAW,MAAMC,EAAaF,CAAG,EAEvC,OAAOF,EAAQG,CAAQ,CAC3B,MAAQ,CAER,CAGA,IAAME,EAAY,MAAMN,EAAO,cAAe,CAC1C,GAAIG,GAAO,CAAE,IAAAA,CAAI,EACjB,KAAM,MACV,CAAC,EAED,GAAIG,EACA,OAAOL,EAAQA,EAAQK,CAAS,CAAC,EAIrC,IAAMC,EAAW,MAAMP,EAAO,eAAgB,CAC1C,GAAIG,GAAO,CAAE,IAAAA,CAAI,EACjB,KAAM,MACV,CAAC,EAED,GAAII,EACA,OAAON,EAAQM,CAAQ,EAG3B,MAAM,IAAI,MAAM,+BAA+B,CACnD","sourcesContent":["import { findUp } from \"@visulima/fs\";\nimport { dirname } from \"pathe\";\n\nimport { findLockFile } from \"./package-manager\";\n\n/**\n * An asynchronous function that finds the root directory of a project based on certain lookup criteria.\n *\n * @param cwd - Optional. The current working directory to start the search from. The type of `cwd` is `string`.\n * @returns A `Promise` that resolves to the path of the root directory. The type of the returned promise is `Promise<string>`.\n * @throws An `Error` if the root directory could not be found.\n *\n * @example\n * const rootDirectory = await findPackageRoot();\n * console.log(rootDirectory); // '/path/to/project'\n */\n// eslint-disable-next-line import/prefer-default-export\nexport const findPackageRoot = async (cwd?: URL | string): Promise<string> => {\n // Lookdown for lockfile\n try {\n const lockFile = await findLockFile(cwd);\n\n return dirname(lockFile);\n } catch {\n /* empty */\n }\n\n // Lookup for .git/config\n const gitConfig = await findUp(\".git/config\", {\n ...(cwd && { cwd }),\n type: \"file\",\n });\n\n if (gitConfig) {\n return dirname(dirname(gitConfig));\n }\n\n // Lookdown for package.json\n const filePath = await findUp(\"package.json\", {\n ...(cwd && { cwd }),\n type: \"file\",\n });\n\n if (filePath) {\n return dirname(filePath);\n }\n\n throw new Error(\"Could not find root directory\");\n};\n"]}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var chunkTM6ZD56C_cjs = require('./chunk-TM6ZD56C.cjs');
|
|
4
|
+
var fs$1 = require('fs');
|
|
5
|
+
var fs = require('@visulima/fs');
|
|
6
|
+
var pathe = require('pathe');
|
|
7
|
+
|
|
8
|
+
var b=async e=>{let n=await fs.findUp(["lerna.json","turbo.json"],{type:"file",...e&&{cwd:e}});if(n?.endsWith("lerna.json")){let o=await fs.readJson(n);if(o.useWorkspaces||o.packages)return {path:pathe.dirname(n),strategy:"lerna"}}let s=n?.endsWith("turbo.json");try{let{packageManager:o,path:r}=await chunkTM6ZD56C_cjs.b(e);if(["npm","yarn"].includes(o)){let a=pathe.join(r,"package.json");if(fs$1.existsSync(a)&&fs$1.readFileSync(pathe.join(r,"package.json"),"utf8").includes("workspaces"))return {path:r,strategy:s?"turbo":o}}else if(o==="pnpm"){let a=pathe.join(r,"pnpm-workspace.yaml");if(fs$1.existsSync(a))return {path:r,strategy:s?"turbo":"pnpm"}}}catch(o){if(!o.message.includes("Could not find lock file"))throw o}throw new Error(`No monorepo root could be found upwards from the directory ${e} using lerna, yarn, pnpm, or npm as indicators.`)};
|
|
9
|
+
|
|
10
|
+
exports.a = b;
|
|
11
|
+
//# sourceMappingURL=out.js.map
|
|
12
|
+
//# sourceMappingURL=chunk-L6J2NRQY.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/monorepo.ts"],"names":["existsSync","readFileSync","findUp","readJson","dirname","join","findMonorepoRoot","cwd","workspaceFilePath","lerna","isTurbo","packageManager","path","findPackageManager","packageJsonFilePath","pnpmWorkspacesFilePath","error"],"mappings":"yCAAA,OAAS,cAAAA,EAAY,gBAAAC,MAAoB,KAEzC,OAAS,UAAAC,EAAQ,YAAAC,MAAgB,eACjC,OAAS,WAAAC,EAAS,QAAAC,MAAY,QAsBvB,IAAMC,EAAmB,MAAOC,GAA8C,CACjF,IAAMC,EAAoB,MAAMN,EAAO,CAAC,aAAc,YAAY,EAAG,CACjE,KAAM,OACN,GAAIK,GAAO,CAAE,IAAAA,CAAI,CACrB,CAAC,EAED,GAAIC,GAAmB,SAAS,YAAY,EAAG,CAC3C,IAAMC,EAAQ,MAAMN,EAA2DK,CAAiB,EAEhG,GAAIC,EAAM,eAAiBA,EAAM,SAC7B,MAAO,CACH,KAAML,EAAQI,CAAiB,EAC/B,SAAU,OACd,CAER,CAEA,IAAME,EAAUF,GAAmB,SAAS,YAAY,EAExD,GAAI,CACA,GAAM,CAAE,eAAAG,EAAgB,KAAAC,CAAK,EAAI,MAAMC,EAAmBN,CAAG,EAE7D,GAAI,CAAC,MAAO,MAAM,EAAE,SAASI,CAAc,EAAG,CAC1C,IAAMG,EAAsBT,EAAKO,EAAM,cAAc,EAGrD,GAAIZ,EAAWc,CAAmB,GAEVb,EAAaI,EAAKO,EAAM,cAAc,EAAG,MAAM,EAEnD,SAAS,YAAY,EACjC,MAAO,CACH,KAAAA,EACA,SAAUF,EAAU,QAAWC,CACnC,CAGZ,SAAWA,IAAmB,OAAQ,CAClC,IAAMI,EAAyBV,EAAKO,EAAM,qBAAqB,EAG/D,GAAIZ,EAAWe,CAAsB,EACjC,MAAO,CACH,KAAAH,EACA,SAAUF,EAAU,QAAU,MAClC,CAER,CAEJ,OAASM,EAAY,CAGjB,GAAI,CAACA,EAAM,QAAQ,SAAS,0BAA0B,EAClD,MAAMA,CAEd,CAEA,MAAM,IAAI,MAAM,8DAA8DT,CAAa,iDAAiD,CAChJ","sourcesContent":["import { existsSync, readFileSync } from \"node:fs\";\n\nimport { findUp, readJson } from \"@visulima/fs\";\nimport { dirname, join } from \"pathe\";\n\nimport { findPackageManager } from \"./package-manager\";\n\nexport type Strategy = \"lerna\" | \"npm\" | \"pnpm\" | \"turbo\" | \"yarn\";\n\nexport interface RootMonorepo<T extends Strategy = Strategy> {\n path: string;\n strategy: T;\n}\n\n/**\n * An asynchronous function to find the root directory path and strategy for a monorepo based on\n * the given current working directory (cwd).\n *\n * @param cwd - The current working directory. The type of `cwd` is part of an `Options` type, specifically `Options[\"cwd\"]`.\n * Default is undefined.\n * @returns A `Promise` that resolves to the root directory path and strategy for the monorepo.\n * The type of the returned promise is `Promise<RootMonorepo>`.\n * @throws An `Error` if no monorepo root can be found using lerna, yarn, pnpm, or npm as indicators.\n */\n// eslint-disable-next-line sonarjs/cognitive-complexity\nexport const findMonorepoRoot = async (cwd?: URL | string): Promise<RootMonorepo> => {\n const workspaceFilePath = await findUp([\"lerna.json\", \"turbo.json\"], {\n type: \"file\",\n ...(cwd && { cwd }),\n });\n\n if (workspaceFilePath?.endsWith(\"lerna.json\")) {\n const lerna = await readJson<{ packages?: string[]; useWorkspaces?: boolean }>(workspaceFilePath);\n\n if (lerna.useWorkspaces || lerna.packages) {\n return {\n path: dirname(workspaceFilePath),\n strategy: \"lerna\",\n };\n }\n }\n\n const isTurbo = workspaceFilePath?.endsWith(\"turbo.json\");\n\n try {\n const { packageManager, path } = await findPackageManager(cwd);\n\n if ([\"npm\", \"yarn\"].includes(packageManager)) {\n const packageJsonFilePath = join(path, \"package.json\");\n\n // eslint-disable-next-line security/detect-non-literal-fs-filename\n if (existsSync(packageJsonFilePath)) {\n // eslint-disable-next-line security/detect-non-literal-fs-filename\n const packageJson = readFileSync(join(path, \"package.json\"), \"utf8\");\n\n if (packageJson.includes(\"workspaces\")) {\n return {\n path,\n strategy: isTurbo ? \"turbo\" : (packageManager as \"npm\" | \"yarn\"),\n };\n }\n }\n } else if (packageManager === \"pnpm\") {\n const pnpmWorkspacesFilePath = join(path, \"pnpm-workspace.yaml\");\n\n // eslint-disable-next-line security/detect-non-literal-fs-filename\n if (existsSync(pnpmWorkspacesFilePath)) {\n return {\n path,\n strategy: isTurbo ? \"turbo\" : \"pnpm\",\n };\n }\n }\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n } catch (error: any) {\n // Skip this error to show the error message from the next block\n // eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access\n if (!error.message.includes(\"Could not find lock file\")) {\n throw error;\n }\n }\n\n throw new Error(`No monorepo root could be found upwards from the directory ${cwd as string} using lerna, yarn, pnpm, or npm as indicators.`);\n};\n"]}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var chunkVQCWTT2B_cjs = require('./chunk-VQCWTT2B.cjs');
|
|
4
|
+
var child_process = require('child_process');
|
|
5
|
+
var fs$1 = require('fs');
|
|
6
|
+
var fs = require('@visulima/fs');
|
|
7
|
+
var pathe = require('pathe');
|
|
8
|
+
|
|
9
|
+
var f=["yarn.lock","package-lock.json","pnpm-lock.yaml","npm-shrinkwrap.json","bun.lockb"],y=async a=>{let n=await fs.findUp(f,{type:"file",...a&&{cwd:a}});if(!n)throw new Error("Could not find lock file");return n},x=async a=>{let n=await fs.findUp(e=>{let t;if(f.forEach(i=>{!t&&fs$1.existsSync(pathe.join(e,i))&&(t=pathe.join(e,i));}),t)return t;let r=pathe.join(e,"package.json");if(fs$1.existsSync(r)&&chunkVQCWTT2B_cjs.e(fs$1.readFileSync(r,"utf8")).packageManager!==void 0)return r},{...a&&{cwd:a}});if(!n)throw new Error("Could not find lock file");if(n.endsWith("package.json")){let e=chunkVQCWTT2B_cjs.e(n);if(e.packageManager){let r=["npm","yarn","pnpm","bun"].find(i=>e.packageManager.startsWith(i));if(r)return {packageManager:r,path:pathe.dirname(n)}}}if(n.endsWith("yarn.lock"))return {packageManager:"yarn",path:pathe.dirname(n)};if(n.endsWith("package-lock.json")||n.endsWith("npm-shrinkwrap.json"))return {packageManager:"npm",path:pathe.dirname(n)};if(n.endsWith("pnpm-lock.yaml"))return {packageManager:"pnpm",path:pathe.dirname(n)};if(n.endsWith("bun.lockb"))return {packageManager:"bun",path:pathe.dirname(n)};throw new Error("Could not find lock file")},w=a=>child_process.execSync(`${a} --version`).toString("utf8").trim(),b=async()=>{if(!process.env.npm_config_user_agent)return;let a=process.env.npm_config_user_agent.split(" ")[0],n=a.lastIndexOf("/"),e=a.slice(0,Math.max(0,n));return {name:e==="npminstall"?"cnpm":e,version:a.slice(Math.max(0,n+1))}};
|
|
10
|
+
|
|
11
|
+
exports.a = y;
|
|
12
|
+
exports.b = x;
|
|
13
|
+
exports.c = w;
|
|
14
|
+
exports.d = b;
|
|
15
|
+
//# sourceMappingURL=out.js.map
|
|
16
|
+
//# sourceMappingURL=chunk-TM6ZD56C.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/package-manager.ts"],"names":["execSync","existsSync","readFileSync","findUp","dirname","join","lockFileNames","findLockFile","cwd","filePath","findPackageManager","foundFile","directory","lockFile","lockFileName","packageJsonFilePath","parsePackageJson","packageJson","foundPackageManager","prefix","getPackageManagerVersion","name","identifyInitiatingPackageManager","pmSpec","separatorPos"],"mappings":"yCAAA,OAAS,YAAAA,MAAgB,gBACzB,OAAS,cAAAC,EAAY,gBAAAC,MAAoB,KAEzC,OAAS,UAAAC,MAAc,eACvB,OAAS,WAAAC,EAAS,QAAAC,MAAY,QAI9B,IAAMC,EAAgB,CAAC,YAAa,oBAAqB,iBAAkB,sBAAuB,WAAW,EAWhGC,EAAe,MAAOC,GAAwC,CACvE,IAAMC,EAAW,MAAMN,EAAOG,EAAe,CACzC,KAAM,OACN,GAAIE,GAAO,CAAE,IAAAA,CAAI,CACrB,CAAC,EAED,GAAI,CAACC,EACD,MAAM,IAAI,MAAM,0BAA0B,EAG9C,OAAOA,CACX,EAqBaC,EAAqB,MAAOF,GAAsD,CAC3F,IAAMG,EAAY,MAAMR,EACnBS,GAAsB,CACnB,IAAIC,EASJ,GAPAP,EAAc,QAASQ,GAAiB,CAEhC,CAACD,GAAYZ,EAAWI,EAAKO,EAAWE,CAAY,CAAC,IACrDD,EAAWR,EAAKO,EAAWE,CAAY,EAE/C,CAAC,EAEGD,EACA,OAAOA,EAGX,IAAME,EAAsBV,EAAKO,EAAW,cAAc,EAE1D,GAAIX,EAAWc,CAAmB,GAEVC,EAAiBd,EAAaa,EAAqB,MAAM,CAAC,EAE9D,iBAAmB,OAC/B,OAAOA,CAKnB,EACA,CACI,GAAIP,GAAO,CAAE,IAAAA,CAAI,CACrB,CACJ,EAEA,GAAI,CAACG,EACD,MAAM,IAAI,MAAM,0BAA0B,EAG9C,GAAIA,EAAU,SAAS,cAAc,EAAG,CACpC,IAAMM,EAAcD,EAAiBL,CAAS,EAE9C,GAAIM,EAAY,eAAgB,CAE5B,IAAMC,EADsB,CAAC,MAAO,OAAQ,OAAQ,KAAK,EACT,KAAMC,GAAYF,EAAY,eAA0B,WAAWE,CAAM,CAAC,EAE1H,GAAID,EACA,MAAO,CACH,eAAgBA,EAChB,KAAMd,EAAQO,CAAS,CAC3B,CAER,CACJ,CAEA,GAAIA,EAAU,SAAS,WAAW,EAC9B,MAAO,CACH,eAAgB,OAChB,KAAMP,EAAQO,CAAS,CAC3B,EAGJ,GAAIA,EAAU,SAAS,mBAAmB,GAAKA,EAAU,SAAS,qBAAqB,EACnF,MAAO,CACH,eAAgB,MAChB,KAAMP,EAAQO,CAAS,CAC3B,EAGJ,GAAIA,EAAU,SAAS,gBAAgB,EACnC,MAAO,CACH,eAAgB,OAChB,KAAMP,EAAQO,CAAS,CAC3B,EAGJ,GAAIA,EAAU,SAAS,WAAW,EAC9B,MAAO,CACH,eAAgB,MAChB,KAAMP,EAAQO,CAAS,CAC3B,EAGJ,MAAM,IAAI,MAAM,0BAA0B,CAC9C,EAQaS,EAA4BC,GAAyBrB,EAAS,GAAGqB,CAAI,YAAY,EAAE,SAAS,MAAM,EAAE,KAAK,EAWzGC,EAAmC,SAM3C,CACD,GAAI,CAAC,QAAQ,IAAI,sBACb,OAGJ,IAAMC,EAAS,QAAQ,IAAI,sBAAyB,MAAM,GAAG,EAAE,CAAC,EAC1DC,EAAeD,EAAO,YAAY,GAAG,EACrCF,EAAOE,EAAO,MAAM,EAAG,KAAK,IAAI,EAAGC,CAAY,CAAC,EAEtD,MAAO,CACH,KAAMH,IAAS,aAAe,OAAUA,EACxC,QAASE,EAAO,MAAM,KAAK,IAAI,EAAGC,EAAe,CAAC,CAAC,CACvD,CACJ","sourcesContent":["import { execSync } from \"node:child_process\";\nimport { existsSync, readFileSync } from \"node:fs\";\n\nimport { findUp } from \"@visulima/fs\";\nimport { dirname, join } from \"pathe\";\n\nimport { parsePackageJson } from \"./package-json\";\n\nconst lockFileNames = [\"yarn.lock\", \"package-lock.json\", \"pnpm-lock.yaml\", \"npm-shrinkwrap.json\", \"bun.lockb\"];\n\n/**\n * An asynchronous function that finds a lock file in the specified directory or any of its parent directories.\n *\n * @param cwd - Optional. The directory path to start the search from. The type of `cwd` is part of an `Options` type,\n * specifically `URL | string`. Defaults to the current working directory.\n * @returns A `Promise` that resolves with the path of the found lock file.\n * The type of the returned promise is `Promise<string>`.\n * @throws An `Error` if no lock file is found.\n */\nexport const findLockFile = async (cwd?: URL | string): Promise<string> => {\n const filePath = await findUp(lockFileNames, {\n type: \"file\",\n ...(cwd && { cwd }),\n });\n\n if (!filePath) {\n throw new Error(\"Could not find lock file\");\n }\n\n return filePath;\n};\n\nexport type PackageManager = \"bun\" | \"npm\" | \"pnpm\" | \"yarn\";\n\nexport type PackageManagerResult = {\n packageManager: PackageManager;\n path: string;\n};\n\n/**\n * An asynchronous function that finds the package manager used in a project based on the presence of lock files\n * or package.json configuration. If found, it returns the package manager and the path to the lock file or package.json.\n * Throws an error if no lock file or package.json is found.\n *\n * @param cwd - Optional. The current working directory to start the search from. The type of `cwd` is part of an `Options`\n * type, specifically `URL | string`.\n * @returns A `Promise` that resolves to an object containing the package manager and path.\n * The return type of the function is `Promise<PackageManagerResult>`.\n * @throws An `Error` if no lock file or package.json is found.\n */\n// eslint-disable-next-line sonarjs/cognitive-complexity\nexport const findPackageManager = async (cwd?: URL | string): Promise<PackageManagerResult> => {\n const foundFile = await findUp(\n (directory: string) => {\n let lockFile: string | undefined;\n\n lockFileNames.forEach((lockFileName) => {\n // eslint-disable-next-line security/detect-non-literal-fs-filename\n if (!lockFile && existsSync(join(directory, lockFileName))) {\n lockFile = join(directory, lockFileName);\n }\n });\n\n if (lockFile) {\n return lockFile;\n }\n\n const packageJsonFilePath = join(directory, \"package.json\");\n // eslint-disable-next-line security/detect-non-literal-fs-filename\n if (existsSync(packageJsonFilePath)) {\n // eslint-disable-next-line security/detect-non-literal-fs-filename\n const packageJson = parsePackageJson(readFileSync(packageJsonFilePath, \"utf8\"));\n\n if (packageJson.packageManager !== undefined) {\n return packageJsonFilePath;\n }\n }\n\n return undefined;\n },\n {\n ...(cwd && { cwd }),\n },\n );\n\n if (!foundFile) {\n throw new Error(\"Could not find lock file\");\n }\n\n if (foundFile.endsWith(\"package.json\")) {\n const packageJson = parsePackageJson(foundFile);\n\n if (packageJson.packageManager) {\n const packageManagerNames = [\"npm\", \"yarn\", \"pnpm\", \"bun\"] as const;\n const foundPackageManager = packageManagerNames.find((prefix) => (packageJson.packageManager as string).startsWith(prefix));\n\n if (foundPackageManager) {\n return {\n packageManager: foundPackageManager,\n path: dirname(foundFile),\n };\n }\n }\n }\n\n if (foundFile.endsWith(\"yarn.lock\")) {\n return {\n packageManager: \"yarn\",\n path: dirname(foundFile),\n };\n }\n\n if (foundFile.endsWith(\"package-lock.json\") || foundFile.endsWith(\"npm-shrinkwrap.json\")) {\n return {\n packageManager: \"npm\",\n path: dirname(foundFile),\n };\n }\n\n if (foundFile.endsWith(\"pnpm-lock.yaml\")) {\n return {\n packageManager: \"pnpm\",\n path: dirname(foundFile),\n };\n }\n\n if (foundFile.endsWith(\"bun.lockb\")) {\n return {\n packageManager: \"bun\",\n path: dirname(foundFile),\n };\n }\n\n throw new Error(\"Could not find lock file\");\n};\n\n/**\n * Function that retrieves the version of the specified package manager.\n *\n * @param name - The name of the package manager. The type of `name` is `string`.\n * @returns The version of the package manager. The return type of the function is `string`.\n */\nexport const getPackageManagerVersion = (name: string): string => execSync(`${name} --version`).toString(\"utf8\").trim();\n\n/**\n * An asynchronous function that detects what package manager executes the process.\n *\n * Supports npm, pnpm, Yarn, cnpm, and bun. And also any other package manager that sets the npm_config_user_agent env variable.\n *\n * @returns A `Promise` that resolves to an object containing the name and version of the package manager,\n * or undefined if the package manager information cannot be determined. The return type of the function\n * is `Promise<{ name: PackageManager | \"cnpm\"; version: string } | undefined>`.\n */\nexport const identifyInitiatingPackageManager = async (): Promise<\n | {\n name: PackageManager | \"cnpm\";\n version: string;\n }\n | undefined\n> => {\n if (!process.env[\"npm_config_user_agent\"]) {\n return undefined;\n }\n\n const pmSpec = process.env[\"npm_config_user_agent\"].split(\" \")[0] as string;\n const separatorPos = pmSpec.lastIndexOf(\"/\");\n const name = pmSpec.slice(0, Math.max(0, separatorPos));\n\n return {\n name: name === \"npminstall\" ? \"cnpm\" : (name as PackageManager),\n version: pmSpec.slice(Math.max(0, separatorPos + 1)),\n };\n};\n"]}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { existsSync } from 'node:fs';
|
|
2
|
+
import { findUp, readJson, findUpSync, readJsonSync, writeJson, writeJsonSync } from '@visulima/fs';
|
|
3
|
+
import { NotFoundError } from '@visulima/fs/error';
|
|
4
|
+
import { toPath, parseJson } from '@visulima/fs/utils';
|
|
5
|
+
import r from 'normalize-package-data';
|
|
6
|
+
import { normalize, join } from 'pathe';
|
|
7
|
+
|
|
8
|
+
var m=new Map,S=async(e,o={})=>{let a=await findUp("package.json",{...e&&{cwd:e},type:"file"});if(!a)throw new NotFoundError("for package.json found.");let t=o.cache&&typeof o.cache!="boolean"?o.cache:m;if(o.cache&&t.has(a))return t.get(a);let s=await readJson(a);r(s);let n={packageJson:s,path:normalize(a)};return t.set(a,n),n},x=(e,o={})=>{let a=findUpSync("package.json",{...e&&{cwd:e},type:"file"});if(!a)throw new NotFoundError("for package.json found.");let t=o.cache&&typeof o.cache!="boolean"?o.cache:m;if(o.cache&&t.has(a))return t.get(a);let s=readJsonSync(a);r(s);let n={packageJson:s,path:a};return t.set(a,n),n},U=async(e,o={})=>{let{cwd:a,...t}=o,s=toPath(o.cwd??process.cwd());await writeJson(join(s,"package.json"),e,t);},T=(e,o={})=>{let{cwd:a,...t}=o,s=toPath(o.cwd??process.cwd());writeJsonSync(join(s,"package.json"),e,t);},C=e=>{let o=e!==null&&typeof e=="object"&&!Array.isArray(e);if(!o&&!(typeof e=="string"))throw new TypeError("`packageFile` should be either an `object` or a `string`.");let t=o?structuredClone(e):existsSync(e)?readJsonSync(e):parseJson(e);return r(t),t};
|
|
9
|
+
|
|
10
|
+
export { S as a, x as b, U as c, T as d, C as e };
|
|
11
|
+
//# sourceMappingURL=out.js.map
|
|
12
|
+
//# sourceMappingURL=chunk-TUN46UZB.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/package-json.ts"],"names":["existsSync","findUp","findUpSync","readJson","readJsonSync","writeJson","writeJsonSync","NotFoundError","parseJson","toPath","normalizeData","join","normalize","PackageJsonFileCache","findPackageJson","cwd","options","filePath","cache","packageJson","output","findPackageJsonSync","writePackageJson","data","writeOptions","directory","writePackageJsonSync","parsePackageJson","packageFile","isObject","json"],"mappings":"AAAA,OAAS,cAAAA,MAAkB,UAG3B,OAAS,UAAAC,EAAQ,cAAAC,EAAY,YAAAC,EAAU,gBAAAC,EAAc,aAAAC,EAAW,iBAAAC,MAAqB,eACrF,OAAS,iBAAAC,MAAqB,qBAC9B,OAAS,aAAAC,EAAW,UAAAC,MAAc,qBAElC,OAAOC,MAAmB,yBAC1B,OAAS,QAAAC,EAAM,aAAAC,MAAiB,QAShC,IAAMC,EAAuB,IAAI,IAepBC,EAAkB,MAAOC,EAAoBC,EAAuB,CAAC,IAAqC,CACnH,IAAMC,EAAW,MAAMhB,EAAO,eAAgB,CAC1C,GAAIc,GAAO,CAAE,IAAAA,CAAI,EACjB,KAAM,MACV,CAAC,EAED,GAAI,CAACE,EACD,MAAM,IAAIV,EAAc,yBAAyB,EAGrD,IAAMW,EAAQF,EAAQ,OAAS,OAAOA,EAAQ,OAAU,UAAYA,EAAQ,MAAQH,EAEpF,GAAIG,EAAQ,OAASE,EAAM,IAAID,CAAQ,EACnC,OAAOC,EAAM,IAAID,CAAQ,EAG7B,IAAME,EAAc,MAAMhB,EAASc,CAAQ,EAE3CP,EAAcS,CAAoB,EAElC,IAAMC,EAAS,CACX,YAAaD,EAEb,KAAMP,EAAUK,CAAQ,CAC5B,EAEA,OAAAC,EAAM,IAAID,EAAUG,CAAM,EAEnBA,CACX,EAEaC,EAAsB,CAACN,EAAoBC,EAAuB,CAAC,IAA4B,CACxG,IAAMC,EAAWf,EAAW,eAAgB,CACxC,GAAIa,GAAO,CAAE,IAAAA,CAAI,EACjB,KAAM,MACV,CAAC,EAED,GAAI,CAACE,EACD,MAAM,IAAIV,EAAc,yBAAyB,EAGrD,IAAMW,EAAQF,EAAQ,OAAS,OAAOA,EAAQ,OAAU,UAAYA,EAAQ,MAAQH,EAEpF,GAAIG,EAAQ,OAASE,EAAM,IAAID,CAAQ,EACnC,OAAOC,EAAM,IAAID,CAAQ,EAG7B,IAAME,EAAcf,EAAaa,CAAQ,EAEzCP,EAAcS,CAAoB,EAElC,IAAMC,EAAS,CACX,YAAaD,EACb,KAAMF,CACV,EAEA,OAAAC,EAAM,IAAID,EAAUG,CAAM,EAEnBA,CACX,EAYaE,EAAmB,MAAwBC,EAASP,EAAqD,CAAC,IAAqB,CACxI,GAAM,CAAE,IAAAD,EAAK,GAAGS,CAAa,EAAIR,EAC3BS,EAAYhB,EAAOO,EAAQ,KAAO,QAAQ,IAAI,CAAC,EAErD,MAAMX,EAAUM,EAAKc,EAAW,cAAc,EAAGF,EAAMC,CAAY,CACvE,EAEaE,EAAuB,CAAkBH,EAASP,EAAqD,CAAC,IAAY,CAC7H,GAAM,CAAE,IAAAD,EAAK,GAAGS,CAAa,EAAIR,EAC3BS,EAAYhB,EAAOO,EAAQ,KAAO,QAAQ,IAAI,CAAC,EAErDV,EAAcK,EAAKc,EAAW,cAAc,EAAGF,EAAMC,CAAY,CACrE,EAEaG,EAAoBC,GAA4D,CAEzF,IAAMC,EAAWD,IAAgB,MAAQ,OAAOA,GAAgB,UAAY,CAAC,MAAM,QAAQA,CAAW,EAGtG,GAAI,CAACC,GAAY,EAFA,OAAOD,GAAgB,UAGpC,MAAM,IAAI,UAAU,2DAA2D,EAGnF,IAAME,EAAOD,EACP,gBAAgBD,CAAW,EAE3B5B,EAAW4B,CAAqB,EAC9BxB,EAAawB,CAAqB,EAClCpB,EAAUoB,CAAqB,EAEvC,OAAAlB,EAAcoB,CAAa,EAEpBA,CACX","sourcesContent":["import { existsSync } from \"node:fs\";\n\nimport type { WriteJsonOptions } from \"@visulima/fs\";\nimport { findUp, findUpSync, readJson, readJsonSync, writeJson, writeJsonSync } from \"@visulima/fs\";\nimport { NotFoundError } from \"@visulima/fs/error\";\nimport { parseJson, toPath } from \"@visulima/fs/utils\";\nimport type { Input } from \"normalize-package-data\";\nimport normalizeData from \"normalize-package-data\";\nimport { join, normalize } from \"pathe\";\nimport type { JsonObject } from \"type-fest\";\n\nimport type { Cache, NormalizedPackageJson, PackageJson } from \"./types\";\n\ntype ReadOptions = {\n cache?: Cache<NormalizedReadResult> | boolean;\n};\n\nconst PackageJsonFileCache = new Map<string, NormalizedReadResult>();\n\nexport type NormalizedReadResult = {\n packageJson: NormalizedPackageJson;\n path: string;\n};\n\n/**\n * An asynchronous function to find the package.json file in the specified directory or its parent directories.\n *\n * @param cwd - The current working directory.\n * @returns A `Promise` that resolves to an object containing the parsed package.json data and the file path.\n * The type of the returned promise is `Promise<NormalizedReadResult>`.\n * @throws An `Error` if the package.json file cannot be found.\n */\nexport const findPackageJson = async (cwd?: URL | string, options: ReadOptions = {}): Promise<NormalizedReadResult> => {\n const filePath = await findUp(\"package.json\", {\n ...(cwd && { cwd }),\n type: \"file\",\n });\n\n if (!filePath) {\n throw new NotFoundError(\"for package.json found.\");\n }\n\n const cache = options.cache && typeof options.cache !== \"boolean\" ? options.cache : PackageJsonFileCache;\n\n if (options.cache && cache.has(filePath)) {\n return cache.get(filePath) as NormalizedReadResult;\n }\n\n const packageJson = await readJson(filePath);\n\n normalizeData(packageJson as Input);\n\n const output = {\n packageJson: packageJson as NormalizedPackageJson,\n // @TODO Remove this after @visulima/fs use pathe\n path: normalize(filePath),\n };\n\n cache.set(filePath, output);\n\n return output;\n};\n\nexport const findPackageJsonSync = (cwd?: URL | string, options: ReadOptions = {}): NormalizedReadResult => {\n const filePath = findUpSync(\"package.json\", {\n ...(cwd && { cwd }),\n type: \"file\",\n });\n\n if (!filePath) {\n throw new NotFoundError(\"for package.json found.\");\n }\n\n const cache = options.cache && typeof options.cache !== \"boolean\" ? options.cache : PackageJsonFileCache;\n\n if (options.cache && cache.has(filePath)) {\n return cache.get(filePath) as NormalizedReadResult;\n }\n\n const packageJson = readJsonSync(filePath);\n\n normalizeData(packageJson as Input);\n\n const output = {\n packageJson: packageJson as NormalizedPackageJson,\n path: filePath,\n };\n\n cache.set(filePath, output);\n\n return output;\n};\n\n/**\n * An asynchronous function to write the package.json file with the given data.\n *\n * @param data - The package.json data to write. The data is an intersection type of `PackageJson` and a record where keys are `string` and values can be any type.\n * @param options - Optional. The options for writing the package.json. If not provided, an empty object will be used `{}`.\n * This is an intersection type of `WriteJsonOptions` and a record with an optional `cwd` key which type is `Options[\"cwd\"]`.\n * `cwd` represents the current working directory. If not specified, the default working directory will be used.\n * @returns A `Promise` that resolves once the package.json file has been written. The type of the returned promise is `Promise<void>`.\n */\n\nexport const writePackageJson = async <T = PackageJson>(data: T, options: WriteJsonOptions & { cwd?: URL | string } = {}): Promise<void> => {\n const { cwd, ...writeOptions } = options;\n const directory = toPath(options.cwd ?? process.cwd());\n\n await writeJson(join(directory, \"package.json\"), data, writeOptions);\n};\n\nexport const writePackageJsonSync = <T = PackageJson>(data: T, options: WriteJsonOptions & { cwd?: URL | string } = {}): void => {\n const { cwd, ...writeOptions } = options;\n const directory = toPath(options.cwd ?? process.cwd());\n\n writeJsonSync(join(directory, \"package.json\"), data, writeOptions);\n};\n\nexport const parsePackageJson = (packageFile: JsonObject | string): NormalizedPackageJson => {\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n const isObject = packageFile !== null && typeof packageFile === \"object\" && !Array.isArray(packageFile);\n const isString = typeof packageFile === \"string\";\n\n if (!isObject && !isString) {\n throw new TypeError(\"`packageFile` should be either an `object` or a `string`.\");\n }\n\n const json = isObject\n ? structuredClone(packageFile)\n : // eslint-disable-next-line security/detect-non-literal-fs-filename\n existsSync(packageFile as string)\n ? readJsonSync(packageFile as string)\n : parseJson(packageFile as string);\n\n normalizeData(json as Input);\n\n return json as NormalizedPackageJson;\n};\n"]}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var chunkTM6ZD56C_cjs = require('./chunk-TM6ZD56C.cjs');
|
|
4
|
+
var fs = require('@visulima/fs');
|
|
5
|
+
var pathe = require('pathe');
|
|
6
|
+
|
|
7
|
+
var m=async t=>{try{let a=await chunkTM6ZD56C_cjs.a(t);return pathe.dirname(a)}catch{}let o=await fs.findUp(".git/config",{...t&&{cwd:t},type:"file"});if(o)return pathe.dirname(pathe.dirname(o));let r=await fs.findUp("package.json",{...t&&{cwd:t},type:"file"});if(r)return pathe.dirname(r);throw new Error("Could not find root directory")};
|
|
8
|
+
|
|
9
|
+
exports.a = m;
|
|
10
|
+
//# sourceMappingURL=out.js.map
|
|
11
|
+
//# sourceMappingURL=chunk-VAMRQCZW.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/package.ts"],"names":["findUp","dirname","findPackageRoot","cwd","lockFile","findLockFile","gitConfig","filePath"],"mappings":"yCAAA,OAAS,UAAAA,MAAc,eACvB,OAAS,WAAAC,MAAe,QAgBjB,IAAMC,EAAkB,MAAOC,GAAwC,CAE1E,GAAI,CACA,IAAMC,EAAW,MAAMC,EAAaF,CAAG,EAEvC,OAAOF,EAAQG,CAAQ,CAC3B,MAAQ,CAER,CAGA,IAAME,EAAY,MAAMN,EAAO,cAAe,CAC1C,GAAIG,GAAO,CAAE,IAAAA,CAAI,EACjB,KAAM,MACV,CAAC,EAED,GAAIG,EACA,OAAOL,EAAQA,EAAQK,CAAS,CAAC,EAIrC,IAAMC,EAAW,MAAMP,EAAO,eAAgB,CAC1C,GAAIG,GAAO,CAAE,IAAAA,CAAI,EACjB,KAAM,MACV,CAAC,EAED,GAAII,EACA,OAAON,EAAQM,CAAQ,EAG3B,MAAM,IAAI,MAAM,+BAA+B,CACnD","sourcesContent":["import { findUp } from \"@visulima/fs\";\nimport { dirname } from \"pathe\";\n\nimport { findLockFile } from \"./package-manager\";\n\n/**\n * An asynchronous function that finds the root directory of a project based on certain lookup criteria.\n *\n * @param cwd - Optional. The current working directory to start the search from. The type of `cwd` is `string`.\n * @returns A `Promise` that resolves to the path of the root directory. The type of the returned promise is `Promise<string>`.\n * @throws An `Error` if the root directory could not be found.\n *\n * @example\n * const rootDirectory = await findPackageRoot();\n * console.log(rootDirectory); // '/path/to/project'\n */\n// eslint-disable-next-line import/prefer-default-export\nexport const findPackageRoot = async (cwd?: URL | string): Promise<string> => {\n // Lookdown for lockfile\n try {\n const lockFile = await findLockFile(cwd);\n\n return dirname(lockFile);\n } catch {\n /* empty */\n }\n\n // Lookup for .git/config\n const gitConfig = await findUp(\".git/config\", {\n ...(cwd && { cwd }),\n type: \"file\",\n });\n\n if (gitConfig) {\n return dirname(dirname(gitConfig));\n }\n\n // Lookdown for package.json\n const filePath = await findUp(\"package.json\", {\n ...(cwd && { cwd }),\n type: \"file\",\n });\n\n if (filePath) {\n return dirname(filePath);\n }\n\n throw new Error(\"Could not find root directory\");\n};\n"]}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var fs$1 = require('fs');
|
|
4
|
+
var fs = require('@visulima/fs');
|
|
5
|
+
var error = require('@visulima/fs/error');
|
|
6
|
+
var utils = require('@visulima/fs/utils');
|
|
7
|
+
var r = require('normalize-package-data');
|
|
8
|
+
var pathe = require('pathe');
|
|
9
|
+
|
|
10
|
+
function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
|
|
11
|
+
|
|
12
|
+
var r__default = /*#__PURE__*/_interopDefault(r);
|
|
13
|
+
|
|
14
|
+
var m=new Map,b=async(e,o={})=>{let a=await fs.findUp("package.json",{...e&&{cwd:e},type:"file"});if(!a)throw new error.NotFoundError("for package.json found.");let t=o.cache&&typeof o.cache!="boolean"?o.cache:m;if(o.cache&&t.has(a))return t.get(a);let s=await fs.readJson(a);r__default.default(s);let n={packageJson:s,path:pathe.normalize(a)};return t.set(a,n),n},S=(e,o={})=>{let a=fs.findUpSync("package.json",{...e&&{cwd:e},type:"file"});if(!a)throw new error.NotFoundError("for package.json found.");let t=o.cache&&typeof o.cache!="boolean"?o.cache:m;if(o.cache&&t.has(a))return t.get(a);let s=fs.readJsonSync(a);r__default.default(s);let n={packageJson:s,path:a};return t.set(a,n),n},x=async(e,o={})=>{let{cwd:a,...t}=o,s=utils.toPath(o.cwd??process.cwd());await fs.writeJson(pathe.join(s,"package.json"),e,t);},U=(e,o={})=>{let{cwd:a,...t}=o,s=utils.toPath(o.cwd??process.cwd());fs.writeJsonSync(pathe.join(s,"package.json"),e,t);},T=e=>{let o=e!==null&&typeof e=="object"&&!Array.isArray(e);if(!o&&!(typeof e=="string"))throw new TypeError("`packageFile` should be either an `object` or a `string`.");let t=o?structuredClone(e):fs$1.existsSync(e)?fs.readJsonSync(e):utils.parseJson(e);return r__default.default(t),t};
|
|
15
|
+
|
|
16
|
+
exports.a = b;
|
|
17
|
+
exports.b = S;
|
|
18
|
+
exports.c = x;
|
|
19
|
+
exports.d = U;
|
|
20
|
+
exports.e = T;
|
|
21
|
+
//# sourceMappingURL=out.js.map
|
|
22
|
+
//# sourceMappingURL=chunk-VQCWTT2B.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/package-json.ts"],"names":["existsSync","findUp","findUpSync","readJson","readJsonSync","writeJson","writeJsonSync","NotFoundError","parseJson","toPath","normalizeData","join","normalize","PackageJsonFileCache","findPackageJson","cwd","options","filePath","cache","packageJson","output","findPackageJsonSync","writePackageJson","data","writeOptions","directory","writePackageJsonSync","parsePackageJson","packageFile","isObject","json"],"mappings":"AAAA,OAAS,cAAAA,MAAkB,KAG3B,OAAS,UAAAC,EAAQ,cAAAC,EAAY,YAAAC,EAAU,gBAAAC,EAAc,aAAAC,EAAW,iBAAAC,MAAqB,eACrF,OAAS,iBAAAC,MAAqB,qBAC9B,OAAS,aAAAC,EAAW,UAAAC,MAAc,qBAElC,OAAOC,MAAmB,yBAC1B,OAAS,QAAAC,EAAM,aAAAC,MAAiB,QAShC,IAAMC,EAAuB,IAAI,IAepBC,EAAkB,MAAOC,EAAoBC,EAAuB,CAAC,IAAqC,CACnH,IAAMC,EAAW,MAAMhB,EAAO,eAAgB,CAC1C,GAAIc,GAAO,CAAE,IAAAA,CAAI,EACjB,KAAM,MACV,CAAC,EAED,GAAI,CAACE,EACD,MAAM,IAAIV,EAAc,yBAAyB,EAGrD,IAAMW,EAAQF,EAAQ,OAAS,OAAOA,EAAQ,OAAU,UAAYA,EAAQ,MAAQH,EAEpF,GAAIG,EAAQ,OAASE,EAAM,IAAID,CAAQ,EACnC,OAAOC,EAAM,IAAID,CAAQ,EAG7B,IAAME,EAAc,MAAMhB,EAASc,CAAQ,EAE3CP,EAAcS,CAAoB,EAElC,IAAMC,EAAS,CACX,YAAaD,EAEb,KAAMP,EAAUK,CAAQ,CAC5B,EAEA,OAAAC,EAAM,IAAID,EAAUG,CAAM,EAEnBA,CACX,EAEaC,EAAsB,CAACN,EAAoBC,EAAuB,CAAC,IAA4B,CACxG,IAAMC,EAAWf,EAAW,eAAgB,CACxC,GAAIa,GAAO,CAAE,IAAAA,CAAI,EACjB,KAAM,MACV,CAAC,EAED,GAAI,CAACE,EACD,MAAM,IAAIV,EAAc,yBAAyB,EAGrD,IAAMW,EAAQF,EAAQ,OAAS,OAAOA,EAAQ,OAAU,UAAYA,EAAQ,MAAQH,EAEpF,GAAIG,EAAQ,OAASE,EAAM,IAAID,CAAQ,EACnC,OAAOC,EAAM,IAAID,CAAQ,EAG7B,IAAME,EAAcf,EAAaa,CAAQ,EAEzCP,EAAcS,CAAoB,EAElC,IAAMC,EAAS,CACX,YAAaD,EACb,KAAMF,CACV,EAEA,OAAAC,EAAM,IAAID,EAAUG,CAAM,EAEnBA,CACX,EAYaE,EAAmB,MAAwBC,EAASP,EAAqD,CAAC,IAAqB,CACxI,GAAM,CAAE,IAAAD,EAAK,GAAGS,CAAa,EAAIR,EAC3BS,EAAYhB,EAAOO,EAAQ,KAAO,QAAQ,IAAI,CAAC,EAErD,MAAMX,EAAUM,EAAKc,EAAW,cAAc,EAAGF,EAAMC,CAAY,CACvE,EAEaE,EAAuB,CAAkBH,EAASP,EAAqD,CAAC,IAAY,CAC7H,GAAM,CAAE,IAAAD,EAAK,GAAGS,CAAa,EAAIR,EAC3BS,EAAYhB,EAAOO,EAAQ,KAAO,QAAQ,IAAI,CAAC,EAErDV,EAAcK,EAAKc,EAAW,cAAc,EAAGF,EAAMC,CAAY,CACrE,EAEaG,EAAoBC,GAA4D,CAEzF,IAAMC,EAAWD,IAAgB,MAAQ,OAAOA,GAAgB,UAAY,CAAC,MAAM,QAAQA,CAAW,EAGtG,GAAI,CAACC,GAAY,EAFA,OAAOD,GAAgB,UAGpC,MAAM,IAAI,UAAU,2DAA2D,EAGnF,IAAME,EAAOD,EACP,gBAAgBD,CAAW,EAE3B5B,EAAW4B,CAAqB,EAC9BxB,EAAawB,CAAqB,EAClCpB,EAAUoB,CAAqB,EAEvC,OAAAlB,EAAcoB,CAAa,EAEpBA,CACX","sourcesContent":["import { existsSync } from \"node:fs\";\n\nimport type { WriteJsonOptions } from \"@visulima/fs\";\nimport { findUp, findUpSync, readJson, readJsonSync, writeJson, writeJsonSync } from \"@visulima/fs\";\nimport { NotFoundError } from \"@visulima/fs/error\";\nimport { parseJson, toPath } from \"@visulima/fs/utils\";\nimport type { Input } from \"normalize-package-data\";\nimport normalizeData from \"normalize-package-data\";\nimport { join, normalize } from \"pathe\";\nimport type { JsonObject } from \"type-fest\";\n\nimport type { Cache, NormalizedPackageJson, PackageJson } from \"./types\";\n\ntype ReadOptions = {\n cache?: Cache<NormalizedReadResult> | boolean;\n};\n\nconst PackageJsonFileCache = new Map<string, NormalizedReadResult>();\n\nexport type NormalizedReadResult = {\n packageJson: NormalizedPackageJson;\n path: string;\n};\n\n/**\n * An asynchronous function to find the package.json file in the specified directory or its parent directories.\n *\n * @param cwd - The current working directory.\n * @returns A `Promise` that resolves to an object containing the parsed package.json data and the file path.\n * The type of the returned promise is `Promise<NormalizedReadResult>`.\n * @throws An `Error` if the package.json file cannot be found.\n */\nexport const findPackageJson = async (cwd?: URL | string, options: ReadOptions = {}): Promise<NormalizedReadResult> => {\n const filePath = await findUp(\"package.json\", {\n ...(cwd && { cwd }),\n type: \"file\",\n });\n\n if (!filePath) {\n throw new NotFoundError(\"for package.json found.\");\n }\n\n const cache = options.cache && typeof options.cache !== \"boolean\" ? options.cache : PackageJsonFileCache;\n\n if (options.cache && cache.has(filePath)) {\n return cache.get(filePath) as NormalizedReadResult;\n }\n\n const packageJson = await readJson(filePath);\n\n normalizeData(packageJson as Input);\n\n const output = {\n packageJson: packageJson as NormalizedPackageJson,\n // @TODO Remove this after @visulima/fs use pathe\n path: normalize(filePath),\n };\n\n cache.set(filePath, output);\n\n return output;\n};\n\nexport const findPackageJsonSync = (cwd?: URL | string, options: ReadOptions = {}): NormalizedReadResult => {\n const filePath = findUpSync(\"package.json\", {\n ...(cwd && { cwd }),\n type: \"file\",\n });\n\n if (!filePath) {\n throw new NotFoundError(\"for package.json found.\");\n }\n\n const cache = options.cache && typeof options.cache !== \"boolean\" ? options.cache : PackageJsonFileCache;\n\n if (options.cache && cache.has(filePath)) {\n return cache.get(filePath) as NormalizedReadResult;\n }\n\n const packageJson = readJsonSync(filePath);\n\n normalizeData(packageJson as Input);\n\n const output = {\n packageJson: packageJson as NormalizedPackageJson,\n path: filePath,\n };\n\n cache.set(filePath, output);\n\n return output;\n};\n\n/**\n * An asynchronous function to write the package.json file with the given data.\n *\n * @param data - The package.json data to write. The data is an intersection type of `PackageJson` and a record where keys are `string` and values can be any type.\n * @param options - Optional. The options for writing the package.json. If not provided, an empty object will be used `{}`.\n * This is an intersection type of `WriteJsonOptions` and a record with an optional `cwd` key which type is `Options[\"cwd\"]`.\n * `cwd` represents the current working directory. If not specified, the default working directory will be used.\n * @returns A `Promise` that resolves once the package.json file has been written. The type of the returned promise is `Promise<void>`.\n */\n\nexport const writePackageJson = async <T = PackageJson>(data: T, options: WriteJsonOptions & { cwd?: URL | string } = {}): Promise<void> => {\n const { cwd, ...writeOptions } = options;\n const directory = toPath(options.cwd ?? process.cwd());\n\n await writeJson(join(directory, \"package.json\"), data, writeOptions);\n};\n\nexport const writePackageJsonSync = <T = PackageJson>(data: T, options: WriteJsonOptions & { cwd?: URL | string } = {}): void => {\n const { cwd, ...writeOptions } = options;\n const directory = toPath(options.cwd ?? process.cwd());\n\n writeJsonSync(join(directory, \"package.json\"), data, writeOptions);\n};\n\nexport const parsePackageJson = (packageFile: JsonObject | string): NormalizedPackageJson => {\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n const isObject = packageFile !== null && typeof packageFile === \"object\" && !Array.isArray(packageFile);\n const isString = typeof packageFile === \"string\";\n\n if (!isObject && !isString) {\n throw new TypeError(\"`packageFile` should be either an `object` or a `string`.\");\n }\n\n const json = isObject\n ? structuredClone(packageFile)\n : // eslint-disable-next-line security/detect-non-literal-fs-filename\n existsSync(packageFile as string)\n ? readJsonSync(packageFile as string)\n : parseJson(packageFile as string);\n\n normalizeData(json as Input);\n\n return json as NormalizedPackageJson;\n};\n"]}
|
|
@@ -1,10 +1,10 @@
|
|
|
1
|
-
import { b } from './chunk-
|
|
1
|
+
import { b } from './chunk-5ZQIFU6S.js';
|
|
2
2
|
import { existsSync, readFileSync } from 'node:fs';
|
|
3
|
-
import { dirname, join } from 'node:path';
|
|
4
3
|
import { findUp, readJson } from '@visulima/fs';
|
|
4
|
+
import { dirname, join } from 'pathe';
|
|
5
5
|
|
|
6
6
|
var j=async e=>{let n=await findUp(["lerna.json","turbo.json"],{type:"file",...e&&{cwd:e}});if(n?.endsWith("lerna.json")){let o=await readJson(n);if(o.useWorkspaces||o.packages)return {path:dirname(n),strategy:"lerna"}}let s=n?.endsWith("turbo.json");try{let{packageManager:o,path:r}=await b(e);if(["npm","yarn"].includes(o)){let a=join(r,"package.json");if(existsSync(a)&&readFileSync(join(r,"package.json"),"utf8").includes("workspaces"))return {path:r,strategy:s?"turbo":o}}else if(o==="pnpm"){let a=join(r,"pnpm-workspace.yaml");if(existsSync(a))return {path:r,strategy:s?"turbo":"pnpm"}}}catch(o){if(!o.message.includes("Could not find lock file"))throw o}throw new Error(`No monorepo root could be found upwards from the directory ${e} using lerna, yarn, pnpm, or npm as indicators.`)};
|
|
7
7
|
|
|
8
8
|
export { j as a };
|
|
9
9
|
//# sourceMappingURL=out.js.map
|
|
10
|
-
//# sourceMappingURL=chunk-
|
|
10
|
+
//# sourceMappingURL=chunk-XKKPPOYW.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/monorepo.ts"],"names":["existsSync","readFileSync","findUp","readJson","dirname","join","findMonorepoRoot","cwd","workspaceFilePath","lerna","isTurbo","packageManager","path","findPackageManager","packageJsonFilePath","pnpmWorkspacesFilePath","error"],"mappings":"wCAAA,OAAS,cAAAA,EAAY,gBAAAC,MAAoB,UAEzC,OAAS,UAAAC,EAAQ,YAAAC,MAAgB,eACjC,OAAS,WAAAC,EAAS,QAAAC,MAAY,QAsBvB,IAAMC,EAAmB,MAAOC,GAA8C,CACjF,IAAMC,EAAoB,MAAMN,EAAO,CAAC,aAAc,YAAY,EAAG,CACjE,KAAM,OACN,GAAIK,GAAO,CAAE,IAAAA,CAAI,CACrB,CAAC,EAED,GAAIC,GAAmB,SAAS,YAAY,EAAG,CAC3C,IAAMC,EAAQ,MAAMN,EAA2DK,CAAiB,EAEhG,GAAIC,EAAM,eAAiBA,EAAM,SAC7B,MAAO,CACH,KAAML,EAAQI,CAAiB,EAC/B,SAAU,OACd,CAER,CAEA,IAAME,EAAUF,GAAmB,SAAS,YAAY,EAExD,GAAI,CACA,GAAM,CAAE,eAAAG,EAAgB,KAAAC,CAAK,EAAI,MAAMC,EAAmBN,CAAG,EAE7D,GAAI,CAAC,MAAO,MAAM,EAAE,SAASI,CAAc,EAAG,CAC1C,IAAMG,EAAsBT,EAAKO,EAAM,cAAc,EAGrD,GAAIZ,EAAWc,CAAmB,GAEVb,EAAaI,EAAKO,EAAM,cAAc,EAAG,MAAM,EAEnD,SAAS,YAAY,EACjC,MAAO,CACH,KAAAA,EACA,SAAUF,EAAU,QAAWC,CACnC,CAGZ,SAAWA,IAAmB,OAAQ,CAClC,IAAMI,EAAyBV,EAAKO,EAAM,qBAAqB,EAG/D,GAAIZ,EAAWe,CAAsB,EACjC,MAAO,CACH,KAAAH,EACA,SAAUF,EAAU,QAAU,MAClC,CAER,CAEJ,OAASM,EAAY,CAGjB,GAAI,CAACA,EAAM,QAAQ,SAAS,0BAA0B,EAClD,MAAMA,CAEd,CAEA,MAAM,IAAI,MAAM,8DAA8DT,CAAa,iDAAiD,CAChJ","sourcesContent":["import { existsSync, readFileSync } from \"node:fs\";\n\nimport { findUp, readJson } from \"@visulima/fs\";\nimport { dirname, join } from \"pathe\";\n\nimport { findPackageManager } from \"./package-manager\";\n\nexport type Strategy = \"lerna\" | \"npm\" | \"pnpm\" | \"turbo\" | \"yarn\";\n\nexport interface RootMonorepo<T extends Strategy = Strategy> {\n path: string;\n strategy: T;\n}\n\n/**\n * An asynchronous function to find the root directory path and strategy for a monorepo based on\n * the given current working directory (cwd).\n *\n * @param cwd - The current working directory. The type of `cwd` is part of an `Options` type, specifically `Options[\"cwd\"]`.\n * Default is undefined.\n * @returns A `Promise` that resolves to the root directory path and strategy for the monorepo.\n * The type of the returned promise is `Promise<RootMonorepo>`.\n * @throws An `Error` if no monorepo root can be found using lerna, yarn, pnpm, or npm as indicators.\n */\n// eslint-disable-next-line sonarjs/cognitive-complexity\nexport const findMonorepoRoot = async (cwd?: URL | string): Promise<RootMonorepo> => {\n const workspaceFilePath = await findUp([\"lerna.json\", \"turbo.json\"], {\n type: \"file\",\n ...(cwd && { cwd }),\n });\n\n if (workspaceFilePath?.endsWith(\"lerna.json\")) {\n const lerna = await readJson<{ packages?: string[]; useWorkspaces?: boolean }>(workspaceFilePath);\n\n if (lerna.useWorkspaces || lerna.packages) {\n return {\n path: dirname(workspaceFilePath),\n strategy: \"lerna\",\n };\n }\n }\n\n const isTurbo = workspaceFilePath?.endsWith(\"turbo.json\");\n\n try {\n const { packageManager, path } = await findPackageManager(cwd);\n\n if ([\"npm\", \"yarn\"].includes(packageManager)) {\n const packageJsonFilePath = join(path, \"package.json\");\n\n // eslint-disable-next-line security/detect-non-literal-fs-filename\n if (existsSync(packageJsonFilePath)) {\n // eslint-disable-next-line security/detect-non-literal-fs-filename\n const packageJson = readFileSync(join(path, \"package.json\"), \"utf8\");\n\n if (packageJson.includes(\"workspaces\")) {\n return {\n path,\n strategy: isTurbo ? \"turbo\" : (packageManager as \"npm\" | \"yarn\"),\n };\n }\n }\n } else if (packageManager === \"pnpm\") {\n const pnpmWorkspacesFilePath = join(path, \"pnpm-workspace.yaml\");\n\n // eslint-disable-next-line security/detect-non-literal-fs-filename\n if (existsSync(pnpmWorkspacesFilePath)) {\n return {\n path,\n strategy: isTurbo ? \"turbo\" : \"pnpm\",\n };\n }\n }\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n } catch (error: any) {\n // Skip this error to show the error message from the next block\n // eslint-disable-next-line @typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access\n if (!error.message.includes(\"Could not find lock file\")) {\n throw error;\n }\n }\n\n throw new Error(`No monorepo root could be found upwards from the directory ${cwd as string} using lerna, yarn, pnpm, or npm as indicators.`);\n};\n"]}
|