@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 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
- 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);
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 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");
25
+ return o.extends = void 0, o;
122
26
  }
@@ -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: 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;
8
+ export declare function loadTsConfig(filePath?: string): Promise<TsConfigJson>;
package/dist/tsconfig.mjs CHANGED
@@ -1,4 +1 @@
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")}
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
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@stryke/fs",
3
- "version": "0.19.0",
3
+ "version": "0.20.0",
4
4
  "type": "module",
5
5
  "description": "A package containing various file system utilities that expand the functionality of NodeJs's built-in `fs` module.",
6
6
  "repository": {