@idlebox/node 1.3.3 → 1.3.5
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/lib/cjs/__create_index.generated.d.cts +3 -1
- package/lib/cjs/asyncLoad.cjs +25 -8
- package/lib/cjs/asyncLoad.cjs.map +1 -1
- package/lib/cjs/fs/exists.cjs +1 -1
- package/lib/cjs/fs/exists.cjs.map +1 -1
- package/lib/esm/__create_index.generated.d.mts +3 -1
- package/lib/esm/asyncLoad.mjs +25 -8
- package/lib/esm/asyncLoad.mjs.map +1 -1
- package/lib/esm/fs/exists.mjs +1 -1
- package/lib/esm/fs/exists.mjs.map +1 -1
- package/package.json +3 -3
- package/src/asyncLoad.ts +27 -10
- package/src/fs/exists.ts +1 -1
|
@@ -278,6 +278,8 @@ export declare interface NormalizePathFunction {
|
|
|
278
278
|
(path: string): string;
|
|
279
279
|
}
|
|
280
280
|
|
|
281
|
+
declare type OnExit = (error?: Error) => Promise<any>;
|
|
282
|
+
|
|
281
283
|
export declare function osTempDir(name?: string): string;
|
|
282
284
|
|
|
283
285
|
export declare const PATH_SEPARATOR: string;
|
|
@@ -336,7 +338,7 @@ export declare function respawnInScope(mainFunc: Function): unknown | never;
|
|
|
336
338
|
* setErrorLogRoot(require('path').dirname(__dirname));
|
|
337
339
|
* ```
|
|
338
340
|
**/
|
|
339
|
-
export declare function runMain(main: AsyncMainFunction): void;
|
|
341
|
+
export declare function runMain(main: AsyncMainFunction, onExit?: OnExit): void;
|
|
340
342
|
|
|
341
343
|
export declare function sha256(data: Buffer): string;
|
|
342
344
|
|
package/lib/cjs/asyncLoad.cjs
CHANGED
|
@@ -16,19 +16,36 @@ exports.ExitError = ExitError;
|
|
|
16
16
|
* setErrorLogRoot(require('path').dirname(__dirname));
|
|
17
17
|
* ```
|
|
18
18
|
**/
|
|
19
|
-
function runMain(main) {
|
|
19
|
+
function runMain(main, onExit) {
|
|
20
20
|
Promise.resolve()
|
|
21
|
-
.then(
|
|
21
|
+
.then(async () => {
|
|
22
|
+
try {
|
|
23
|
+
await main();
|
|
24
|
+
await onExit?.();
|
|
25
|
+
}
|
|
26
|
+
catch (e) {
|
|
27
|
+
await onExit?.(e);
|
|
28
|
+
throw e;
|
|
29
|
+
}
|
|
30
|
+
})
|
|
22
31
|
.catch((e) => {
|
|
23
32
|
if (e instanceof ExitError) {
|
|
24
|
-
|
|
25
|
-
|
|
33
|
+
if (e.code) {
|
|
34
|
+
console.error('[exit] %s', e.message);
|
|
35
|
+
process.exitCode = e.code;
|
|
36
|
+
}
|
|
37
|
+
else {
|
|
38
|
+
process.exitCode = 0;
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
else {
|
|
42
|
+
(0, common_1.prettyPrintError)('main', e);
|
|
26
43
|
}
|
|
27
|
-
(
|
|
28
|
-
|
|
44
|
+
if (!process.exitCode)
|
|
45
|
+
process.exitCode = 1;
|
|
29
46
|
})
|
|
30
|
-
.
|
|
31
|
-
process.exit(
|
|
47
|
+
.finally(() => {
|
|
48
|
+
process.exit();
|
|
32
49
|
});
|
|
33
50
|
}
|
|
34
51
|
exports.runMain = runMain;
|
|
@@ -6,5 +6,5 @@
|
|
|
6
6
|
"../../src/asyncLoad.ts"
|
|
7
7
|
],
|
|
8
8
|
"names": [],
|
|
9
|
-
"mappings": ";;;AAAA,4CAAmD;AAInD,MAAa,SAAU,SAAQ,KAAK;
|
|
9
|
+
"mappings": ";;;AAAA,4CAAmD;AAInD,MAAa,SAAU,SAAQ,KAAK;IAGlB;IAFjB,YACC,OAAe,EACC,OAAe,CAAC;QAEhC,KAAK,CAAC,OAAO,CAAC,CAAC;QAFC,SAAI,GAAJ,IAAI,CAAY;IAGjC,CAAC;CACD;AAPD,8BAOC;AAID;;;;;IAKI;AACJ,SAAgB,OAAO,CAAC,IAAuB,EAAE,MAAe;IAC/D,OAAO,CAAC,OAAO,EAAE;SACf,IAAI,CAAC,KAAK,IAAI,EAAE;QAChB,IAAI;YACH,MAAM,IAAI,EAAE,CAAC;YACb,MAAM,MAAM,EAAE,EAAE,CAAC;SACjB;QAAC,OAAO,CAAM,EAAE;YAChB,MAAM,MAAM,EAAE,CAAC,CAAC,CAAC,CAAC;YAClB,MAAM,CAAC,CAAC;SACR;IACF,CAAC,CAAC;SACD,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE;QACZ,IAAI,CAAC,YAAY,SAAS,EAAE;YAC3B,IAAI,CAAC,CAAC,IAAI,EAAE;gBACX,OAAO,CAAC,KAAK,CAAC,WAAW,EAAE,CAAC,CAAC,OAAO,CAAC,CAAC;gBACtC,OAAO,CAAC,QAAQ,GAAG,CAAC,CAAC,IAAI,CAAC;aAC1B;iBAAM;gBACN,OAAO,CAAC,QAAQ,GAAG,CAAC,CAAC;aACrB;SACD;aAAM;YACN,IAAA,yBAAgB,EAAC,MAAM,EAAE,CAAC,CAAC,CAAC;SAC5B;QACD,IAAI,CAAC,OAAO,CAAC,QAAQ;YAAE,OAAO,CAAC,QAAQ,GAAG,CAAC,CAAC;IAC7C,CAAC,CAAC;SACD,OAAO,CAAC,GAAG,EAAE;QACb,OAAO,CAAC,IAAI,EAAE,CAAC;IAChB,CAAC,CAAC,CAAC;AACL,CAAC;AA3BD,0BA2BC"
|
|
10
10
|
}
|
package/lib/cjs/fs/exists.cjs
CHANGED
|
@@ -6,7 +6,7 @@ var fs_1 = require("fs");
|
|
|
6
6
|
Object.defineProperty(exports, "existsSync", { enumerable: true, get: function () { return fs_1.existsSync; } });
|
|
7
7
|
async function exists(path) {
|
|
8
8
|
try {
|
|
9
|
-
(0, promises_1.access)(path);
|
|
9
|
+
await (0, promises_1.access)(path);
|
|
10
10
|
return true;
|
|
11
11
|
}
|
|
12
12
|
catch (e) {
|
|
@@ -6,5 +6,5 @@
|
|
|
6
6
|
"../../../src/fs/exists.ts"
|
|
7
7
|
],
|
|
8
8
|
"names": [],
|
|
9
|
-
"mappings": ";;;AACA,0CAA+C;AAC/C,yBAAgC;AAAvB,gGAAA,UAAU,OAAA;AAEZ,KAAK,UAAU,MAAM,CAAC,IAAY;IACxC,IAAI;QACH,IAAA,iBAAM,EAAC,IAAI,CAAC,CAAC;
|
|
9
|
+
"mappings": ";;;AACA,0CAA+C;AAC/C,yBAAgC;AAAvB,gGAAA,UAAU,OAAA;AAEZ,KAAK,UAAU,MAAM,CAAC,IAAY;IACxC,IAAI;QACH,MAAM,IAAA,iBAAM,EAAC,IAAI,CAAC,CAAC;QACnB,OAAO,IAAI,CAAC;KACZ;IAAC,OAAO,CAAM,EAAE;QAChB,IAAI,gBAAgB,CAAC,CAAC,CAAC;YAAE,OAAO,KAAK,CAAC;QACtC,MAAM,CAAC,CAAC;KACR;AACF,CAAC;AARD,wBAQC;AAEY,QAAA,gBAAgB,GAAoB,iBAAwB,CAAC;AAE1E,KAAK,UAAU,iBAAiB,CAAC,IAAY,EAAE,QAAwD;IACtG,IAAI;QACH,OAAO,MAAM,IAAA,mBAAQ,EAAC,IAAI,EAAE,QAAQ,CAAC,CAAC;KACtC;IAAC,OAAO,CAAM,EAAE;QAChB,IAAI,gBAAgB,CAAC,CAAC,CAAC,EAAE;YACxB,IAAI,OAAO,QAAQ,KAAK,QAAQ,IAAI,OAAO,QAAQ,EAAE,QAAQ,KAAK,QAAQ,EAAE;gBAC3E,OAAO,EAAE,CAAC;aACV;iBAAM;gBACN,OAAO,MAAM,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;aAC7B;SACD;QACD,MAAM,CAAC,CAAC;KACR;AACF,CAAC;AAED,SAAgB,gBAAgB,CAAC,CAAM;IACtC,OAAO,CAAC,CAAC,IAAI,KAAK,QAAQ,CAAC;AAC5B,CAAC;AAFD,4CAEC;AAED,SAAgB,aAAa,CAAC,CAAM;IACnC,OAAO,CAAC,CAAC,IAAI,KAAK,QAAQ,CAAC;AAC5B,CAAC;AAFD,sCAEC;AAED,SAAgB,WAAW,CAAC,CAAM;IACjC,OAAO,CAAC,CAAC,IAAI,KAAK,QAAQ,IAAI,CAAC,CAAC,IAAI,KAAK,SAAS,CAAC;AACpD,CAAC;AAFD,kCAEC"
|
|
10
10
|
}
|
|
@@ -278,6 +278,8 @@ export declare interface NormalizePathFunction {
|
|
|
278
278
|
(path: string): string;
|
|
279
279
|
}
|
|
280
280
|
|
|
281
|
+
declare type OnExit = (error?: Error) => Promise<any>;
|
|
282
|
+
|
|
281
283
|
export declare function osTempDir(name?: string): string;
|
|
282
284
|
|
|
283
285
|
export declare const PATH_SEPARATOR: string;
|
|
@@ -336,7 +338,7 @@ export declare function respawnInScope(mainFunc: Function): unknown | never;
|
|
|
336
338
|
* setErrorLogRoot(require('path').dirname(__dirname));
|
|
337
339
|
* ```
|
|
338
340
|
**/
|
|
339
|
-
export declare function runMain(main: AsyncMainFunction): void;
|
|
341
|
+
export declare function runMain(main: AsyncMainFunction, onExit?: OnExit): void;
|
|
340
342
|
|
|
341
343
|
export declare function sha256(data: Buffer): string;
|
|
342
344
|
|
package/lib/esm/asyncLoad.mjs
CHANGED
|
@@ -12,19 +12,36 @@ export class ExitError extends Error {
|
|
|
12
12
|
* setErrorLogRoot(require('path').dirname(__dirname));
|
|
13
13
|
* ```
|
|
14
14
|
**/
|
|
15
|
-
export function runMain(main) {
|
|
15
|
+
export function runMain(main, onExit) {
|
|
16
16
|
Promise.resolve()
|
|
17
|
-
.then(
|
|
17
|
+
.then(async () => {
|
|
18
|
+
try {
|
|
19
|
+
await main();
|
|
20
|
+
await onExit?.();
|
|
21
|
+
}
|
|
22
|
+
catch (e) {
|
|
23
|
+
await onExit?.(e);
|
|
24
|
+
throw e;
|
|
25
|
+
}
|
|
26
|
+
})
|
|
18
27
|
.catch((e) => {
|
|
19
28
|
if (e instanceof ExitError) {
|
|
20
|
-
|
|
21
|
-
|
|
29
|
+
if (e.code) {
|
|
30
|
+
console.error('[exit] %s', e.message);
|
|
31
|
+
process.exitCode = e.code;
|
|
32
|
+
}
|
|
33
|
+
else {
|
|
34
|
+
process.exitCode = 0;
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
else {
|
|
38
|
+
prettyPrintError('main', e);
|
|
22
39
|
}
|
|
23
|
-
|
|
24
|
-
|
|
40
|
+
if (!process.exitCode)
|
|
41
|
+
process.exitCode = 1;
|
|
25
42
|
})
|
|
26
|
-
.
|
|
27
|
-
process.exit(
|
|
43
|
+
.finally(() => {
|
|
44
|
+
process.exit();
|
|
28
45
|
});
|
|
29
46
|
}
|
|
30
47
|
//# sourceMappingURL=asyncLoad.mjs.map
|
|
@@ -6,5 +6,5 @@
|
|
|
6
6
|
"../../src/asyncLoad.ts"
|
|
7
7
|
],
|
|
8
8
|
"names": [],
|
|
9
|
-
"mappings": "AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AAInD,MAAM,OAAO,SAAU,SAAQ,KAAK;
|
|
9
|
+
"mappings": "AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AAInD,MAAM,OAAO,SAAU,SAAQ,KAAK;IAGlB;IAFjB,YACC,OAAe,EACC,OAAe,CAAC;QAEhC,KAAK,CAAC,OAAO,CAAC,CAAC;QAFC,SAAI,GAAJ,IAAI,CAAY;IAGjC,CAAC;CACD;AAID;;;;;IAKI;AACJ,MAAM,UAAU,OAAO,CAAC,IAAuB,EAAE,MAAe;IAC/D,OAAO,CAAC,OAAO,EAAE;SACf,IAAI,CAAC,KAAK,IAAI,EAAE;QAChB,IAAI;YACH,MAAM,IAAI,EAAE,CAAC;YACb,MAAM,MAAM,EAAE,EAAE,CAAC;SACjB;QAAC,OAAO,CAAM,EAAE;YAChB,MAAM,MAAM,EAAE,CAAC,CAAC,CAAC,CAAC;YAClB,MAAM,CAAC,CAAC;SACR;IACF,CAAC,CAAC;SACD,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE;QACZ,IAAI,CAAC,YAAY,SAAS,EAAE;YAC3B,IAAI,CAAC,CAAC,IAAI,EAAE;gBACX,OAAO,CAAC,KAAK,CAAC,WAAW,EAAE,CAAC,CAAC,OAAO,CAAC,CAAC;gBACtC,OAAO,CAAC,QAAQ,GAAG,CAAC,CAAC,IAAI,CAAC;aAC1B;iBAAM;gBACN,OAAO,CAAC,QAAQ,GAAG,CAAC,CAAC;aACrB;SACD;aAAM;YACN,gBAAgB,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;SAC5B;QACD,IAAI,CAAC,OAAO,CAAC,QAAQ;YAAE,OAAO,CAAC,QAAQ,GAAG,CAAC,CAAC;IAC7C,CAAC,CAAC;SACD,OAAO,CAAC,GAAG,EAAE;QACb,OAAO,CAAC,IAAI,EAAE,CAAC;IAChB,CAAC,CAAC,CAAC;AACL,CAAC"
|
|
10
10
|
}
|
package/lib/esm/fs/exists.mjs
CHANGED
|
@@ -6,5 +6,5 @@
|
|
|
6
6
|
"../../../src/fs/exists.ts"
|
|
7
7
|
],
|
|
8
8
|
"names": [],
|
|
9
|
-
"mappings": "AACA,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AAC/C,OAAO,EAAE,UAAU,EAAE,MAAM,IAAI,CAAC;AAEhC,MAAM,CAAC,KAAK,UAAU,MAAM,CAAC,IAAY;IACxC,IAAI;QACH,MAAM,CAAC,IAAI,CAAC,CAAC;
|
|
9
|
+
"mappings": "AACA,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AAC/C,OAAO,EAAE,UAAU,EAAE,MAAM,IAAI,CAAC;AAEhC,MAAM,CAAC,KAAK,UAAU,MAAM,CAAC,IAAY;IACxC,IAAI;QACH,MAAM,MAAM,CAAC,IAAI,CAAC,CAAC;QACnB,OAAO,IAAI,CAAC;KACZ;IAAC,OAAO,CAAM,EAAE;QAChB,IAAI,gBAAgB,CAAC,CAAC,CAAC;YAAE,OAAO,KAAK,CAAC;QACtC,MAAM,CAAC,CAAC;KACR;AACF,CAAC;AAED,MAAM,CAAC,MAAM,gBAAgB,GAAoB,iBAAwB,CAAC;AAE1E,KAAK,UAAU,iBAAiB,CAAC,IAAY,EAAE,QAAwD;IACtG,IAAI;QACH,OAAO,MAAM,QAAQ,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC;KACtC;IAAC,OAAO,CAAM,EAAE;QAChB,IAAI,gBAAgB,CAAC,CAAC,CAAC,EAAE;YACxB,IAAI,OAAO,QAAQ,KAAK,QAAQ,IAAI,OAAO,QAAQ,EAAE,QAAQ,KAAK,QAAQ,EAAE;gBAC3E,OAAO,EAAE,CAAC;aACV;iBAAM;gBACN,OAAO,MAAM,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;aAC7B;SACD;QACD,MAAM,CAAC,CAAC;KACR;AACF,CAAC;AAED,MAAM,UAAU,gBAAgB,CAAC,CAAM;IACtC,OAAO,CAAC,CAAC,IAAI,KAAK,QAAQ,CAAC;AAC5B,CAAC;AAED,MAAM,UAAU,aAAa,CAAC,CAAM;IACnC,OAAO,CAAC,CAAC,IAAI,KAAK,QAAQ,CAAC;AAC5B,CAAC;AAED,MAAM,UAAU,WAAW,CAAC,CAAM;IACjC,OAAO,CAAC,CAAC,IAAI,KAAK,QAAQ,IAAI,CAAC,CAAC,IAAI,KAAK,SAAS,CAAC;AACpD,CAAC"
|
|
10
10
|
}
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@idlebox/node",
|
|
3
3
|
"type": "module",
|
|
4
|
-
"version": "1.3.
|
|
4
|
+
"version": "1.3.5",
|
|
5
5
|
"license": "MIT",
|
|
6
6
|
"main": "./lib/cjs/__create_index.generated.cjs",
|
|
7
7
|
"module": "./lib/esm/__create_index.generated.mjs",
|
|
@@ -27,8 +27,8 @@
|
|
|
27
27
|
"@types/node": "^20.4.5",
|
|
28
28
|
"chai": "^4.3.7",
|
|
29
29
|
"mocha": "^10.2.0",
|
|
30
|
-
"@
|
|
31
|
-
"@
|
|
30
|
+
"@internal/dualstack-rig": "^1.0.1",
|
|
31
|
+
"@build-script/single-dog-asset": "^1.0.28"
|
|
32
32
|
},
|
|
33
33
|
"peerDependencies": {
|
|
34
34
|
"fix-esm": "^1.0.1"
|
package/src/asyncLoad.ts
CHANGED
|
@@ -3,30 +3,47 @@ import { prettyPrintError } from '@idlebox/common';
|
|
|
3
3
|
export type AsyncMainFunction = () => Promise<void | number>;
|
|
4
4
|
|
|
5
5
|
export class ExitError extends Error {
|
|
6
|
-
constructor(
|
|
6
|
+
constructor(
|
|
7
|
+
message: string,
|
|
8
|
+
public readonly code: number = 1,
|
|
9
|
+
) {
|
|
7
10
|
super(message);
|
|
8
11
|
}
|
|
9
12
|
}
|
|
10
13
|
|
|
14
|
+
type OnExit = (error?: Error) => Promise<any>;
|
|
15
|
+
|
|
11
16
|
/**
|
|
12
17
|
* should do this before:
|
|
13
18
|
* ```
|
|
14
19
|
* setErrorLogRoot(require('path').dirname(__dirname));
|
|
15
20
|
* ```
|
|
16
21
|
**/
|
|
17
|
-
export function runMain(main: AsyncMainFunction) {
|
|
22
|
+
export function runMain(main: AsyncMainFunction, onExit?: OnExit) {
|
|
18
23
|
Promise.resolve()
|
|
19
|
-
.then(
|
|
24
|
+
.then(async () => {
|
|
25
|
+
try {
|
|
26
|
+
await main();
|
|
27
|
+
await onExit?.();
|
|
28
|
+
} catch (e: any) {
|
|
29
|
+
await onExit?.(e);
|
|
30
|
+
throw e;
|
|
31
|
+
}
|
|
32
|
+
})
|
|
20
33
|
.catch((e) => {
|
|
21
34
|
if (e instanceof ExitError) {
|
|
22
|
-
|
|
23
|
-
|
|
35
|
+
if (e.code) {
|
|
36
|
+
console.error('[exit] %s', e.message);
|
|
37
|
+
process.exitCode = e.code;
|
|
38
|
+
} else {
|
|
39
|
+
process.exitCode = 0;
|
|
40
|
+
}
|
|
41
|
+
} else {
|
|
42
|
+
prettyPrintError('main', e);
|
|
24
43
|
}
|
|
25
|
-
|
|
26
|
-
prettyPrintError('build-script', e);
|
|
27
|
-
return e.code || 1;
|
|
44
|
+
if (!process.exitCode) process.exitCode = 1;
|
|
28
45
|
})
|
|
29
|
-
.
|
|
30
|
-
process.exit(
|
|
46
|
+
.finally(() => {
|
|
47
|
+
process.exit();
|
|
31
48
|
});
|
|
32
49
|
}
|