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