@stryke/fs 0.19.0 → 0.20.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/dist/tsconfig.cjs +10 -106
- package/dist/tsconfig.d.ts +1 -15
- package/dist/tsconfig.mjs +1 -4
- package/package.json +1 -1
package/dist/tsconfig.cjs
CHANGED
|
@@ -4,119 +4,23 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
6
|
exports.loadTsConfig = loadTsConfig;
|
|
7
|
-
exports.loadTsConfigSync = loadTsConfigSync;
|
|
8
7
|
var _path = require("@stryke/path");
|
|
9
8
|
var _exists = require("@stryke/path/exists");
|
|
10
9
|
var _filePathFns = require("@stryke/path/file-path-fns");
|
|
11
10
|
var _joinPaths = require("@stryke/path/join-paths");
|
|
12
|
-
var _base = require("@stryke/types/base");
|
|
13
11
|
var _defu = _interopRequireDefault(require("defu"));
|
|
14
|
-
var _nodeModule = require("node:module");
|
|
15
12
|
var _readFile = require("./read-file.cjs");
|
|
16
13
|
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
},
|
|
27
|
-
v = (e, {
|
|
28
|
-
whitespace: t = !0,
|
|
29
|
-
trailingCommas: o = !1
|
|
30
|
-
} = {}) => {
|
|
31
|
-
if (typeof e != "string") throw new TypeError(`Expected argument \`jsonString\` to be a \`string\`, got \`${typeof e}\``);
|
|
32
|
-
const i = t ? k : E;
|
|
33
|
-
let s = !1,
|
|
34
|
-
l = !1,
|
|
35
|
-
r = 0,
|
|
36
|
-
f = "",
|
|
37
|
-
u = "",
|
|
38
|
-
c = -1;
|
|
39
|
-
for (let n = 0; n < e.length; n++) {
|
|
40
|
-
const a = e[n],
|
|
41
|
-
m = e[n + 1];
|
|
42
|
-
!l && a === '"' && ($(e, n) || (s = !s)), !s && (!l && a + (m ?? _base.EMPTY_STRING) === "//" ? (f += e.slice(r, n), r = n, l = x, n++) : l === x && a + (m ?? _base.EMPTY_STRING) === `\r
|
|
43
|
-
` ? (n++, l = !1, f += i(e, r, n), r = n) : l === x && a === `
|
|
44
|
-
` ? (l = !1, f += i(e, r, n), r = n) : !l && a + (m ?? _base.EMPTY_STRING) === "/*" ? (f += e.slice(r, n), r = n, l = L, n++) : l === L && a + (m ?? _base.EMPTY_STRING) === "*/" ? (n++, l = !1, f += i(e, r, n + 1), r = n + 1) : o && !l && (c !== -1 ? a === "}" || a === "]" ? (f += e.slice(r, n), u += i(f, 0, 1) + f.slice(1), f = "", r = n, c = -1) : a !== " " && a !== " " && a !== "\r" && a !== `
|
|
45
|
-
` && (f += e.slice(r, n), r = n, c = -1) : a === "," && (u += f + e.slice(r, n), f = "", r = n, c = n)));
|
|
46
|
-
}
|
|
47
|
-
return u + f + (l ? i(e.slice(r)) : e.slice(r));
|
|
48
|
-
},
|
|
49
|
-
P = e => {
|
|
50
|
-
try {
|
|
51
|
-
return new Function(`return ${v(e).trim()}`)();
|
|
52
|
-
} catch {
|
|
53
|
-
return {};
|
|
54
|
-
}
|
|
55
|
-
},
|
|
56
|
-
J = (0, _nodeModule.createRequire)(require('url').pathToFileURL(__filename).toString());
|
|
57
|
-
function R(e, t) {
|
|
58
|
-
if ((0, _path.isAbsolutePath)(t)) return (0, _exists.existsSync)(t) ? t : null;
|
|
59
|
-
const o = t.endsWith(".json") ? t : `${t}.json`;
|
|
60
|
-
return (0, _exists.existsSync)((0, _joinPaths.joinPaths)(e, o)) ? (0, _joinPaths.joinPaths)(e, o) : (0, _path.getParentPath)(o, e, {
|
|
61
|
-
ignoreCase: !0,
|
|
62
|
-
skipCwd: !0,
|
|
63
|
-
targetType: "file"
|
|
64
|
-
});
|
|
65
|
-
}
|
|
66
|
-
function W(e, t) {
|
|
67
|
-
if ((0, _path.isAbsolutePath)(t)) return (0, _exists.existsSync)(t) ? t : null;
|
|
68
|
-
const o = t.endsWith(".json") ? t : `${t}.json`;
|
|
69
|
-
return (0, _exists.existsSync)((0, _joinPaths.joinPaths)(e, o)) ? (0, _joinPaths.joinPaths)(e, o) : o.startsWith(".") ? (0, _path.getParentPath)((0, _filePathFns.findFileName)(o), e, {
|
|
70
|
-
ignoreCase: !0,
|
|
71
|
-
skipCwd: !1,
|
|
72
|
-
targetType: "file"
|
|
73
|
-
}) : J.resolve(t, {
|
|
74
|
-
paths: [e]
|
|
75
|
-
});
|
|
76
|
-
}
|
|
77
|
-
async function I(e, t, o = !1) {
|
|
78
|
-
const i = o ? W((0, _path.slash)(e), t) : R((0, _path.slash)(e), t);
|
|
79
|
-
if (!i) return null;
|
|
80
|
-
let s = P(await (0, _readFile.readFile)(i));
|
|
81
|
-
const l = (0, _filePathFns.findFilePath)(i);
|
|
82
|
-
s?.compilerOptions?.baseUrl && (s.compilerOptions.baseUrl = (0, _joinPaths.joinPaths)(l, s.compilerOptions.baseUrl));
|
|
83
|
-
const r = [];
|
|
84
|
-
if (s.extends) {
|
|
85
|
-
const f = Array.isArray(s.extends) ? s.extends : [s.extends];
|
|
86
|
-
for (const u of f) {
|
|
87
|
-
const c = await I(l, u, !0);
|
|
88
|
-
c && (s = (0, _defu.default)(s, c.data ?? {}), r.push(...c.files));
|
|
89
|
-
}
|
|
90
|
-
}
|
|
91
|
-
return s.extends = void 0, {
|
|
92
|
-
path: i,
|
|
93
|
-
data: s,
|
|
94
|
-
files: [...r, i]
|
|
95
|
-
};
|
|
96
|
-
}
|
|
97
|
-
function O(e, t, o = !1) {
|
|
98
|
-
const i = o ? W((0, _path.slash)(e), t) : R((0, _path.slash)(e), t);
|
|
99
|
-
if (!i) return null;
|
|
100
|
-
let s = P((0, _readFile.readFileSync)(i));
|
|
101
|
-
const l = (0, _filePathFns.findFilePath)(i);
|
|
102
|
-
s?.compilerOptions?.baseUrl && (s.compilerOptions.baseUrl = (0, _joinPaths.joinPaths)(l, s.compilerOptions.baseUrl));
|
|
103
|
-
const r = [];
|
|
104
|
-
if (s.extends) {
|
|
105
|
-
const f = Array.isArray(s.extends) ? s.extends : [s.extends];
|
|
106
|
-
for (const u of f) {
|
|
107
|
-
const c = O(l, u, !0);
|
|
108
|
-
c && (s = (0, _defu.default)(s, c.data ?? {}), r.push(...c.files));
|
|
14
|
+
async function loadTsConfig(e = process.cwd()) {
|
|
15
|
+
const s = (0, _path.isFile)(e) ? e : (0, _joinPaths.joinPaths)(e, "tsconfig.json");
|
|
16
|
+
if (!(0, _exists.existsSync)(s)) throw new Error(`tsconfig.json not found at ${s}. Please ensure the file exists.`);
|
|
17
|
+
let o = await (0, _readFile.readJsonFile)(s);
|
|
18
|
+
if (o?.compilerOptions?.baseUrl && (o.compilerOptions.baseUrl = (0, _joinPaths.joinPaths)((0, _filePathFns.findFilePath)(s), o.compilerOptions.baseUrl)), o?.extends) {
|
|
19
|
+
const r = Array.isArray(o.extends) ? o.extends : [o.extends];
|
|
20
|
+
for (const f of r) {
|
|
21
|
+
const t = await loadTsConfig((0, _joinPaths.joinPaths)((0, _filePathFns.findFilePath)(s), f));
|
|
22
|
+
t && (o = (0, _defu.default)(o, t ?? {}));
|
|
109
23
|
}
|
|
110
24
|
}
|
|
111
|
-
return
|
|
112
|
-
path: i,
|
|
113
|
-
data: s,
|
|
114
|
-
files: [...r, i]
|
|
115
|
-
};
|
|
116
|
-
}
|
|
117
|
-
async function loadTsConfig(e, t) {
|
|
118
|
-
return I((0, _filePathFns.findFilePath)(e) ? (0, _filePathFns.findFilePath)(e) : process.cwd(), t ? (0, _filePathFns.findFileName)(t) : "tsconfig.json");
|
|
119
|
-
}
|
|
120
|
-
function loadTsConfigSync(e, t) {
|
|
121
|
-
return O((0, _filePathFns.findFilePath)(e) ? (0, _filePathFns.findFilePath)(e) : process.cwd(), t ? (0, _filePathFns.findFileName)(t) : "tsconfig.json");
|
|
25
|
+
return o.extends = void 0, o;
|
|
122
26
|
}
|
package/dist/tsconfig.d.ts
CHANGED
|
@@ -1,22 +1,8 @@
|
|
|
1
1
|
import type { TsConfigJson } from "@stryke/types/tsconfig";
|
|
2
|
-
export interface LoadTsConfigResult {
|
|
3
|
-
path: string;
|
|
4
|
-
data: TsConfigJson;
|
|
5
|
-
files: string[];
|
|
6
|
-
}
|
|
7
2
|
/**
|
|
8
3
|
* Loads a tsconfig.json file and returns the parsed JSON object.
|
|
9
4
|
*
|
|
10
5
|
* @param filePath - The directory to start searching for the tsconfig.json file.
|
|
11
|
-
* @param fileName - The name of the tsconfig.json file.
|
|
12
6
|
* @returns The parsed tsconfig.json object or null if not found.
|
|
13
7
|
*/
|
|
14
|
-
export declare function loadTsConfig(filePath
|
|
15
|
-
/**
|
|
16
|
-
* Synchronously loads a tsconfig.json file and returns the parsed JSON object.
|
|
17
|
-
*
|
|
18
|
-
* @param filePath - The directory to start searching for the tsconfig.json file.
|
|
19
|
-
* @param fileName - The name of the tsconfig.json file.
|
|
20
|
-
* @returns The parsed tsconfig.json object or null if not found.
|
|
21
|
-
*/
|
|
22
|
-
export declare function loadTsConfigSync(filePath: string, fileName?: string): LoadTsConfigResult | null;
|
|
8
|
+
export declare function loadTsConfig(filePath?: string): Promise<TsConfigJson>;
|
package/dist/tsconfig.mjs
CHANGED
|
@@ -1,4 +1 @@
|
|
|
1
|
-
import{
|
|
2
|
-
`?(n++,l=!1,f+=i(e,r,n),r=n):l===x&&a===`
|
|
3
|
-
`?(l=!1,f+=i(e,r,n),r=n):!l&&a+(m??h)==="/*"?(f+=e.slice(r,n),r=n,l=L,n++):l===L&&a+(m??h)==="*/"?(n++,l=!1,f+=i(e,r,n+1),r=n+1):o&&!l&&(c!==-1?a==="}"||a==="]"?(f+=e.slice(r,n),u+=i(f,0,1)+f.slice(1),f="",r=n,c=-1):a!==" "&&a!==" "&&a!=="\r"&&a!==`
|
|
4
|
-
`&&(f+=e.slice(r,n),r=n,c=-1):a===","&&(u+=f+e.slice(r,n),f="",r=n,c=n)))}return u+f+(l?i(e.slice(r)):e.slice(r))},P=e=>{try{return new Function(`return ${v(e).trim()}`)()}catch{return{}}},J=U(import.meta.url);function R(e,t){if(T(t))return C(t)?t:null;const o=t.endsWith(".json")?t:`${t}.json`;return C(d(e,o))?d(e,o):b(o,e,{ignoreCase:!0,skipCwd:!0,targetType:"file"})}function W(e,t){if(T(t))return C(t)?t:null;const o=t.endsWith(".json")?t:`${t}.json`;return C(d(e,o))?d(e,o):o.startsWith(".")?b(y(o),e,{ignoreCase:!0,skipCwd:!1,targetType:"file"}):J.resolve(t,{paths:[e]})}async function I(e,t,o=!1){const i=o?W(g(e),t):R(g(e),t);if(!i)return null;let s=P(await w(i));const l=p(i);s?.compilerOptions?.baseUrl&&(s.compilerOptions.baseUrl=d(l,s.compilerOptions.baseUrl));const r=[];if(s.extends){const f=Array.isArray(s.extends)?s.extends:[s.extends];for(const u of f){const c=await I(l,u,!0);c&&(s=F(s,c.data??{}),r.push(...c.files))}}return s.extends=void 0,{path:i,data:s,files:[...r,i]}}function O(e,t,o=!1){const i=o?W(g(e),t):R(g(e),t);if(!i)return null;let s=P(A(i));const l=p(i);s?.compilerOptions?.baseUrl&&(s.compilerOptions.baseUrl=d(l,s.compilerOptions.baseUrl));const r=[];if(s.extends){const f=Array.isArray(s.extends)?s.extends:[s.extends];for(const u of f){const c=O(l,u,!0);c&&(s=F(s,c.data??{}),r.push(...c.files))}}return s.extends=void 0,{path:i,data:s,files:[...r,i]}}export async function loadTsConfig(e,t){return I(p(e)?p(e):process.cwd(),t?y(t):"tsconfig.json")}export function loadTsConfigSync(e,t){return O(p(e)?p(e):process.cwd(),t?y(t):"tsconfig.json")}
|
|
1
|
+
import{isFile as m}from"@stryke/path";import{existsSync as p}from"@stryke/path/exists";import{findFilePath as i}from"@stryke/path/file-path-fns";import{joinPaths as n}from"@stryke/path/join-paths";import a from"defu";import{readJsonFile as c}from"./read-file";export async function loadTsConfig(e=process.cwd()){const s=m(e)?e:n(e,"tsconfig.json");if(!p(s))throw new Error(`tsconfig.json not found at ${s}. Please ensure the file exists.`);let o=await c(s);if(o?.compilerOptions?.baseUrl&&(o.compilerOptions.baseUrl=n(i(s),o.compilerOptions.baseUrl)),o?.extends){const r=Array.isArray(o.extends)?o.extends:[o.extends];for(const f of r){const t=await loadTsConfig(n(i(s),f));t&&(o=a(o,t??{}))}}return o.extends=void 0,o}
|
package/package.json
CHANGED