@docusaurus/logger 0.0.0-6105 → 0.0.0-6109
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/index.d.ts +1 -0
- package/lib/index.d.ts.map +1 -1
- package/lib/logger.d.ts +1 -0
- package/lib/logger.d.ts.map +1 -1
- package/lib/logger.js +1 -0
- package/lib/logger.js.map +1 -1
- package/lib/perfLogger.d.ts.map +1 -1
- package/lib/perfLogger.js +56 -12
- package/lib/perfLogger.js.map +1 -1
- package/package.json +2 -2
- package/src/logger.ts +1 -0
- package/src/perfLogger.ts +90 -12
package/lib/index.d.ts
CHANGED
|
@@ -10,6 +10,7 @@ export declare const logger: {
|
|
|
10
10
|
red: (msg: string | number) => string;
|
|
11
11
|
yellow: (msg: string | number) => string;
|
|
12
12
|
green: (msg: string | number) => string;
|
|
13
|
+
cyan: (msg: string | number) => string;
|
|
13
14
|
bold: (msg: string | number) => string;
|
|
14
15
|
dim: (msg: string | number) => string;
|
|
15
16
|
path: (msg: unknown) => string;
|
package/lib/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,cAAc,MAAM,UAAU,CAAC;AAEtC,eAAe,cAAc,CAAC;AAM9B,eAAO,MAAM,MAAM
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,cAAc,MAAM,UAAU,CAAC;AAEtC,eAAe,cAAc,CAAC;AAM9B,eAAO,MAAM,MAAM;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAAiB,CAAC;AAErC,OAAO,EAAC,UAAU,EAAC,MAAM,cAAc,CAAC"}
|
package/lib/logger.d.ts
CHANGED
|
@@ -35,6 +35,7 @@ declare const logger: {
|
|
|
35
35
|
red: (msg: string | number) => string;
|
|
36
36
|
yellow: (msg: string | number) => string;
|
|
37
37
|
green: (msg: string | number) => string;
|
|
38
|
+
cyan: (msg: string | number) => string;
|
|
38
39
|
bold: (msg: string | number) => string;
|
|
39
40
|
dim: (msg: string | number) => string;
|
|
40
41
|
path: (msg: unknown) => string;
|
package/lib/logger.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"logger.d.ts","sourceRoot":"","sources":["../src/logger.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAGH,OAAO,KAAK,EAAC,iBAAiB,EAAC,MAAM,mBAAmB,CAAC;AAEzD,KAAK,mBAAmB,GAAG,MAAM,GAAG,MAAM,GAAG,CAAC,MAAM,GAAG,MAAM,CAAC,EAAE,CAAC;AASjE,iBAAS,WAAW,CAClB,IAAI,EAAE,oBAAoB,EAC1B,GAAG,MAAM,EAAE,mBAAmB,EAAE,GAC/B,MAAM,CAkCR;AAYD,iBAAS,IAAI,CAAC,GAAG,EAAE,OAAO,GAAG,IAAI,CAAC;AAClC,iBAAS,IAAI,CACX,GAAG,EAAE,oBAAoB,EACzB,GAAG,MAAM,EAAE,CAAC,mBAAmB,EAAE,GAAG,mBAAmB,EAAE,CAAC,GACzD,IAAI,CAAC;AAUR,iBAAS,IAAI,CAAC,GAAG,EAAE,OAAO,GAAG,IAAI,CAAC;AAClC,iBAAS,IAAI,CACX,GAAG,EAAE,oBAAoB,EACzB,GAAG,MAAM,EAAE,CAAC,mBAAmB,EAAE,GAAG,mBAAmB,EAAE,CAAC,GACzD,IAAI,CAAC;AAYR,iBAAS,KAAK,CAAC,GAAG,EAAE,OAAO,GAAG,IAAI,CAAC;AACnC,iBAAS,KAAK,CACZ,GAAG,EAAE,oBAAoB,EACzB,GAAG,MAAM,EAAE,CAAC,mBAAmB,EAAE,GAAG,mBAAmB,EAAE,CAAC,GACzD,IAAI,CAAC;AAYR,iBAAS,OAAO,CAAC,GAAG,EAAE,OAAO,GAAG,IAAI,CAAC;AACrC,iBAAS,OAAO,CACd,GAAG,EAAE,oBAAoB,EACzB,GAAG,MAAM,EAAE,CAAC,mBAAmB,EAAE,GAAG,mBAAmB,EAAE,CAAC,GACzD,IAAI,CAAC;AAuBR,iBAAS,OAAO,IAAI,IAAI,CAEvB;AAED;;;;;;;;;;;;;GAaG;AACH,iBAAS,MAAM,CAAC,iBAAiB,EAAE,iBAAiB,GAAG,OAAO,OAAO,CAepE;AAED,QAAA,MAAM,MAAM;eACC,MAAM,GAAG,MAAM,KAAG,MAAM;kBACrB,MAAM,GAAG,MAAM,KAAG,MAAM;iBACzB,MAAM,GAAG,MAAM,KAAG,MAAM;gBACzB,MAAM,GAAG,MAAM,KAAG,MAAM;eACzB,MAAM,GAAG,MAAM,KAAG,MAAM;
|
|
1
|
+
{"version":3,"file":"logger.d.ts","sourceRoot":"","sources":["../src/logger.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAGH,OAAO,KAAK,EAAC,iBAAiB,EAAC,MAAM,mBAAmB,CAAC;AAEzD,KAAK,mBAAmB,GAAG,MAAM,GAAG,MAAM,GAAG,CAAC,MAAM,GAAG,MAAM,CAAC,EAAE,CAAC;AASjE,iBAAS,WAAW,CAClB,IAAI,EAAE,oBAAoB,EAC1B,GAAG,MAAM,EAAE,mBAAmB,EAAE,GAC/B,MAAM,CAkCR;AAYD,iBAAS,IAAI,CAAC,GAAG,EAAE,OAAO,GAAG,IAAI,CAAC;AAClC,iBAAS,IAAI,CACX,GAAG,EAAE,oBAAoB,EACzB,GAAG,MAAM,EAAE,CAAC,mBAAmB,EAAE,GAAG,mBAAmB,EAAE,CAAC,GACzD,IAAI,CAAC;AAUR,iBAAS,IAAI,CAAC,GAAG,EAAE,OAAO,GAAG,IAAI,CAAC;AAClC,iBAAS,IAAI,CACX,GAAG,EAAE,oBAAoB,EACzB,GAAG,MAAM,EAAE,CAAC,mBAAmB,EAAE,GAAG,mBAAmB,EAAE,CAAC,GACzD,IAAI,CAAC;AAYR,iBAAS,KAAK,CAAC,GAAG,EAAE,OAAO,GAAG,IAAI,CAAC;AACnC,iBAAS,KAAK,CACZ,GAAG,EAAE,oBAAoB,EACzB,GAAG,MAAM,EAAE,CAAC,mBAAmB,EAAE,GAAG,mBAAmB,EAAE,CAAC,GACzD,IAAI,CAAC;AAYR,iBAAS,OAAO,CAAC,GAAG,EAAE,OAAO,GAAG,IAAI,CAAC;AACrC,iBAAS,OAAO,CACd,GAAG,EAAE,oBAAoB,EACzB,GAAG,MAAM,EAAE,CAAC,mBAAmB,EAAE,GAAG,mBAAmB,EAAE,CAAC,GACzD,IAAI,CAAC;AAuBR,iBAAS,OAAO,IAAI,IAAI,CAEvB;AAED;;;;;;;;;;;;;GAaG;AACH,iBAAS,MAAM,CAAC,iBAAiB,EAAE,iBAAiB,GAAG,OAAO,OAAO,CAepE;AAED,QAAA,MAAM,MAAM;eACC,MAAM,GAAG,MAAM,KAAG,MAAM;kBACrB,MAAM,GAAG,MAAM,KAAG,MAAM;iBACzB,MAAM,GAAG,MAAM,KAAG,MAAM;gBACzB,MAAM,GAAG,MAAM,KAAG,MAAM;gBACxB,MAAM,GAAG,MAAM,KAAG,MAAM;eACzB,MAAM,GAAG,MAAM,KAAG,MAAM;gBA1KlB,OAAO,KAAG,MAAM;eACjB,OAAO,KAAG,MAAM;gBACf,OAAO,KAAG,MAAM;gBAChB,OAAO,KAAG,MAAM;kBACd,OAAO,KAAG,MAAM;eACnB,OAAO,KAAG,MAAM;;;;;;;;CAmLjC,CAAC;AAEF,eAAe,MAAM,CAAC"}
|
package/lib/logger.js
CHANGED
|
@@ -114,6 +114,7 @@ const logger = {
|
|
|
114
114
|
red: (msg) => chalk_1.default.red(msg),
|
|
115
115
|
yellow: (msg) => chalk_1.default.yellow(msg),
|
|
116
116
|
green: (msg) => chalk_1.default.green(msg),
|
|
117
|
+
cyan: (msg) => chalk_1.default.cyan(msg),
|
|
117
118
|
bold: (msg) => chalk_1.default.bold(msg),
|
|
118
119
|
dim: (msg) => chalk_1.default.dim(msg),
|
|
119
120
|
path,
|
package/lib/logger.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"logger.js","sourceRoot":"","sources":["../src/logger.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"logger.js","sourceRoot":"","sources":["../src/logger.ts"],"names":[],"mappings":"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"}
|
package/lib/perfLogger.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"perfLogger.d.ts","sourceRoot":"","sources":["../src/perfLogger.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"perfLogger.d.ts","sourceRoot":"","sources":["../src/perfLogger.ts"],"names":[],"mappings":"AA8BA,KAAK,aAAa,GAAG;IACnB,KAAK,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IAC/B,GAAG,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IAC7B,GAAG,EAAE,CAAC,OAAO,EAAE,MAAM,KAAK,IAAI,CAAC;IAC/B,KAAK,EAAE,CAAC,MAAM,EACZ,KAAK,EAAE,MAAM,EACb,OAAO,EAAE,MAAM,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,KACpC,OAAO,CAAC,MAAM,CAAC,CAAC;CACtB,CAAC;AAuIF,eAAO,MAAM,UAAU,EAAE,aAAkC,CAAC"}
|
package/lib/perfLogger.js
CHANGED
|
@@ -12,13 +12,13 @@ const async_hooks_1 = require("async_hooks");
|
|
|
12
12
|
const logger_1 = tslib_1.__importDefault(require("./logger"));
|
|
13
13
|
// For now this is a private env variable we use internally
|
|
14
14
|
// But we'll want to expose this feature officially some day
|
|
15
|
-
const PerfDebuggingEnabled =
|
|
15
|
+
const PerfDebuggingEnabled = process.env.DOCUSAURUS_PERF_LOGGER === 'true';
|
|
16
16
|
const Thresholds = {
|
|
17
17
|
min: 5,
|
|
18
18
|
yellow: 100,
|
|
19
19
|
red: 1000,
|
|
20
20
|
};
|
|
21
|
-
const PerfPrefix = logger_1.default.yellow(`[PERF]
|
|
21
|
+
const PerfPrefix = logger_1.default.yellow(`[PERF]`);
|
|
22
22
|
// This is what enables to "see the parent stack" for each log
|
|
23
23
|
// Parent1 > Parent2 > Parent3 > child trace
|
|
24
24
|
const ParentPrefix = new async_hooks_1.AsyncLocalStorage();
|
|
@@ -26,6 +26,12 @@ function applyParentPrefix(label) {
|
|
|
26
26
|
const parentPrefix = ParentPrefix.getStore();
|
|
27
27
|
return parentPrefix ? `${parentPrefix} > ${label}` : label;
|
|
28
28
|
}
|
|
29
|
+
function getMemory() {
|
|
30
|
+
// Before reading memory stats, we explicitly call the GC
|
|
31
|
+
// Note: this only works when Node.js option "--expose-gc" is provided
|
|
32
|
+
globalThis.gc?.();
|
|
33
|
+
return process.memoryUsage();
|
|
34
|
+
}
|
|
29
35
|
function createPerfLogger() {
|
|
30
36
|
if (!PerfDebuggingEnabled) {
|
|
31
37
|
const noop = () => { };
|
|
@@ -47,26 +53,64 @@ function createPerfLogger() {
|
|
|
47
53
|
return logger_1.default.green(`${duration.toFixed(2)} ms`);
|
|
48
54
|
}
|
|
49
55
|
};
|
|
50
|
-
const
|
|
56
|
+
const formatMemory = (memory) => {
|
|
57
|
+
const fmtHead = (bytes) => logger_1.default.cyan(`${(bytes / 1000000).toFixed(0)}mb`);
|
|
58
|
+
return logger_1.default.dim(`(${fmtHead(memory.before.heapUsed)} -> ${fmtHead(memory.after.heapUsed)})`);
|
|
59
|
+
};
|
|
60
|
+
const formatStatus = (error) => {
|
|
61
|
+
return error ? logger_1.default.red('[KO]') : ''; // logger.green('[OK]');
|
|
62
|
+
};
|
|
63
|
+
const printPerfLog = ({ label, duration, memory, error, }) => {
|
|
51
64
|
if (duration < Thresholds.min) {
|
|
52
65
|
return;
|
|
53
66
|
}
|
|
54
|
-
console.log(`${PerfPrefix
|
|
67
|
+
console.log(`${PerfPrefix}${formatStatus(error)} ${label} - ${formatDuration(duration)} - ${formatMemory(memory)}`);
|
|
55
68
|
};
|
|
56
|
-
const start = (label) => performance.mark(label
|
|
69
|
+
const start = (label) => performance.mark(label, {
|
|
70
|
+
detail: {
|
|
71
|
+
memoryUsage: getMemory(),
|
|
72
|
+
},
|
|
73
|
+
});
|
|
57
74
|
const end = (label) => {
|
|
58
|
-
const { duration } = performance.measure(label);
|
|
75
|
+
const { duration, detail: { memoryUsage }, } = performance.measure(label);
|
|
59
76
|
performance.clearMarks(label);
|
|
60
|
-
|
|
77
|
+
printPerfLog({
|
|
78
|
+
label: applyParentPrefix(label),
|
|
79
|
+
duration,
|
|
80
|
+
memory: {
|
|
81
|
+
before: memoryUsage,
|
|
82
|
+
after: getMemory(),
|
|
83
|
+
},
|
|
84
|
+
error: undefined,
|
|
85
|
+
});
|
|
61
86
|
};
|
|
62
|
-
const log = (label) => console.log(PerfPrefix
|
|
87
|
+
const log = (label) => console.log(`${PerfPrefix} ${applyParentPrefix(label)}`);
|
|
63
88
|
const async = async (label, asyncFn) => {
|
|
64
89
|
const finalLabel = applyParentPrefix(label);
|
|
65
90
|
const before = performance.now();
|
|
66
|
-
const
|
|
67
|
-
const
|
|
68
|
-
|
|
69
|
-
|
|
91
|
+
const memoryBefore = getMemory();
|
|
92
|
+
const asyncEnd = ({ error }) => {
|
|
93
|
+
const memoryAfter = getMemory();
|
|
94
|
+
const duration = performance.now() - before;
|
|
95
|
+
printPerfLog({
|
|
96
|
+
error,
|
|
97
|
+
label: finalLabel,
|
|
98
|
+
duration,
|
|
99
|
+
memory: {
|
|
100
|
+
before: memoryBefore,
|
|
101
|
+
after: memoryAfter,
|
|
102
|
+
},
|
|
103
|
+
});
|
|
104
|
+
};
|
|
105
|
+
try {
|
|
106
|
+
const result = await ParentPrefix.run(finalLabel, () => asyncFn());
|
|
107
|
+
asyncEnd({ error: undefined });
|
|
108
|
+
return result;
|
|
109
|
+
}
|
|
110
|
+
catch (e) {
|
|
111
|
+
asyncEnd({ error: e });
|
|
112
|
+
throw e;
|
|
113
|
+
}
|
|
70
114
|
};
|
|
71
115
|
return {
|
|
72
116
|
start,
|
package/lib/perfLogger.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"perfLogger.js","sourceRoot":"","sources":["../src/perfLogger.ts"],"names":[],"mappings":";;;;AAAA;;;;;GAKG;AACH,6CAA8C;AAC9C,8DAA8B;AAE9B,2DAA2D;AAC3D,4DAA4D;AAC5D,MAAM,oBAAoB,
|
|
1
|
+
{"version":3,"file":"perfLogger.js","sourceRoot":"","sources":["../src/perfLogger.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@docusaurus/logger",
|
|
3
|
-
"version": "0.0.0-
|
|
3
|
+
"version": "0.0.0-6109",
|
|
4
4
|
"description": "An encapsulated logger for semantically formatting console messages.",
|
|
5
5
|
"main": "./lib/index.js",
|
|
6
6
|
"repository": {
|
|
@@ -29,5 +29,5 @@
|
|
|
29
29
|
"devDependencies": {
|
|
30
30
|
"@types/supports-color": "^8.1.1"
|
|
31
31
|
},
|
|
32
|
-
"gitHead": "
|
|
32
|
+
"gitHead": "d1f5cd6af4cb380de04e370bdf94781615cecd58"
|
|
33
33
|
}
|
package/src/logger.ts
CHANGED
|
@@ -178,6 +178,7 @@ const logger = {
|
|
|
178
178
|
red: (msg: string | number): string => chalk.red(msg),
|
|
179
179
|
yellow: (msg: string | number): string => chalk.yellow(msg),
|
|
180
180
|
green: (msg: string | number): string => chalk.green(msg),
|
|
181
|
+
cyan: (msg: string | number): string => chalk.cyan(msg),
|
|
181
182
|
bold: (msg: string | number): string => chalk.bold(msg),
|
|
182
183
|
dim: (msg: string | number): string => chalk.dim(msg),
|
|
183
184
|
path,
|
package/src/perfLogger.ts
CHANGED
|
@@ -9,7 +9,8 @@ import logger from './logger';
|
|
|
9
9
|
|
|
10
10
|
// For now this is a private env variable we use internally
|
|
11
11
|
// But we'll want to expose this feature officially some day
|
|
12
|
-
const PerfDebuggingEnabled: boolean =
|
|
12
|
+
const PerfDebuggingEnabled: boolean =
|
|
13
|
+
process.env.DOCUSAURUS_PERF_LOGGER === 'true';
|
|
13
14
|
|
|
14
15
|
const Thresholds = {
|
|
15
16
|
min: 5,
|
|
@@ -17,7 +18,7 @@ const Thresholds = {
|
|
|
17
18
|
red: 1000,
|
|
18
19
|
};
|
|
19
20
|
|
|
20
|
-
const PerfPrefix = logger.yellow(`[PERF]
|
|
21
|
+
const PerfPrefix = logger.yellow(`[PERF]`);
|
|
21
22
|
|
|
22
23
|
// This is what enables to "see the parent stack" for each log
|
|
23
24
|
// Parent1 > Parent2 > Parent3 > child trace
|
|
@@ -37,6 +38,19 @@ type PerfLoggerAPI = {
|
|
|
37
38
|
) => Promise<Result>;
|
|
38
39
|
};
|
|
39
40
|
|
|
41
|
+
type Memory = {
|
|
42
|
+
before: NodeJS.MemoryUsage;
|
|
43
|
+
after: NodeJS.MemoryUsage;
|
|
44
|
+
};
|
|
45
|
+
|
|
46
|
+
function getMemory(): NodeJS.MemoryUsage {
|
|
47
|
+
// Before reading memory stats, we explicitly call the GC
|
|
48
|
+
// Note: this only works when Node.js option "--expose-gc" is provided
|
|
49
|
+
globalThis.gc?.();
|
|
50
|
+
|
|
51
|
+
return process.memoryUsage();
|
|
52
|
+
}
|
|
53
|
+
|
|
40
54
|
function createPerfLogger(): PerfLoggerAPI {
|
|
41
55
|
if (!PerfDebuggingEnabled) {
|
|
42
56
|
const noop = () => {};
|
|
@@ -58,31 +72,95 @@ function createPerfLogger(): PerfLoggerAPI {
|
|
|
58
72
|
}
|
|
59
73
|
};
|
|
60
74
|
|
|
61
|
-
const
|
|
75
|
+
const formatMemory = (memory: Memory): string => {
|
|
76
|
+
const fmtHead = (bytes: number) =>
|
|
77
|
+
logger.cyan(`${(bytes / 1000000).toFixed(0)}mb`);
|
|
78
|
+
return logger.dim(
|
|
79
|
+
`(${fmtHead(memory.before.heapUsed)} -> ${fmtHead(
|
|
80
|
+
memory.after.heapUsed,
|
|
81
|
+
)})`,
|
|
82
|
+
);
|
|
83
|
+
};
|
|
84
|
+
|
|
85
|
+
const formatStatus = (error: Error | undefined): string => {
|
|
86
|
+
return error ? logger.red('[KO]') : ''; // logger.green('[OK]');
|
|
87
|
+
};
|
|
88
|
+
|
|
89
|
+
const printPerfLog = ({
|
|
90
|
+
label,
|
|
91
|
+
duration,
|
|
92
|
+
memory,
|
|
93
|
+
error,
|
|
94
|
+
}: {
|
|
95
|
+
label: string;
|
|
96
|
+
duration: number;
|
|
97
|
+
memory: Memory;
|
|
98
|
+
error: Error | undefined;
|
|
99
|
+
}) => {
|
|
62
100
|
if (duration < Thresholds.min) {
|
|
63
101
|
return;
|
|
64
102
|
}
|
|
65
|
-
console.log(
|
|
103
|
+
console.log(
|
|
104
|
+
`${PerfPrefix}${formatStatus(error)} ${label} - ${formatDuration(
|
|
105
|
+
duration,
|
|
106
|
+
)} - ${formatMemory(memory)}`,
|
|
107
|
+
);
|
|
66
108
|
};
|
|
67
109
|
|
|
68
|
-
const start: PerfLoggerAPI['start'] = (label) =>
|
|
110
|
+
const start: PerfLoggerAPI['start'] = (label) =>
|
|
111
|
+
performance.mark(label, {
|
|
112
|
+
detail: {
|
|
113
|
+
memoryUsage: getMemory(),
|
|
114
|
+
},
|
|
115
|
+
});
|
|
69
116
|
|
|
70
117
|
const end: PerfLoggerAPI['end'] = (label) => {
|
|
71
|
-
const {
|
|
118
|
+
const {
|
|
119
|
+
duration,
|
|
120
|
+
detail: {memoryUsage},
|
|
121
|
+
} = performance.measure(label);
|
|
72
122
|
performance.clearMarks(label);
|
|
73
|
-
|
|
123
|
+
printPerfLog({
|
|
124
|
+
label: applyParentPrefix(label),
|
|
125
|
+
duration,
|
|
126
|
+
memory: {
|
|
127
|
+
before: memoryUsage,
|
|
128
|
+
after: getMemory(),
|
|
129
|
+
},
|
|
130
|
+
error: undefined,
|
|
131
|
+
});
|
|
74
132
|
};
|
|
75
133
|
|
|
76
134
|
const log: PerfLoggerAPI['log'] = (label: string) =>
|
|
77
|
-
console.log(PerfPrefix
|
|
135
|
+
console.log(`${PerfPrefix} ${applyParentPrefix(label)}`);
|
|
78
136
|
|
|
79
137
|
const async: PerfLoggerAPI['async'] = async (label, asyncFn) => {
|
|
80
138
|
const finalLabel = applyParentPrefix(label);
|
|
81
139
|
const before = performance.now();
|
|
82
|
-
const
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
140
|
+
const memoryBefore = getMemory();
|
|
141
|
+
|
|
142
|
+
const asyncEnd = ({error}: {error: Error | undefined}) => {
|
|
143
|
+
const memoryAfter = getMemory();
|
|
144
|
+
const duration = performance.now() - before;
|
|
145
|
+
printPerfLog({
|
|
146
|
+
error,
|
|
147
|
+
label: finalLabel,
|
|
148
|
+
duration,
|
|
149
|
+
memory: {
|
|
150
|
+
before: memoryBefore,
|
|
151
|
+
after: memoryAfter,
|
|
152
|
+
},
|
|
153
|
+
});
|
|
154
|
+
};
|
|
155
|
+
|
|
156
|
+
try {
|
|
157
|
+
const result = await ParentPrefix.run(finalLabel, () => asyncFn());
|
|
158
|
+
asyncEnd({error: undefined});
|
|
159
|
+
return result;
|
|
160
|
+
} catch (e) {
|
|
161
|
+
asyncEnd({error: e as Error});
|
|
162
|
+
throw e;
|
|
163
|
+
}
|
|
86
164
|
};
|
|
87
165
|
|
|
88
166
|
return {
|