mirror of
https://github.com/shishantbiswas/bknd.git
synced 2026-03-16 12:37:20 +00:00
58 lines
1.4 KiB
TypeScript
58 lines
1.4 KiB
TypeScript
import { $console } from "./console";
|
|
|
|
type ConsoleSeverity = "log" | "warn" | "error";
|
|
const _oldConsoles = {
|
|
log: console.log,
|
|
warn: console.warn,
|
|
error: console.error,
|
|
};
|
|
|
|
export async function withDisabledConsole<R>(
|
|
fn: () => Promise<R>,
|
|
severities: ConsoleSeverity[] = ["log", "warn", "error"],
|
|
): Promise<R> {
|
|
const _oldConsoles = {
|
|
log: console.log,
|
|
warn: console.warn,
|
|
error: console.error,
|
|
};
|
|
disableConsoleLog(severities);
|
|
const enable = () => {
|
|
Object.entries(_oldConsoles).forEach(([severity, fn]) => {
|
|
console[severity as ConsoleSeverity] = fn;
|
|
});
|
|
};
|
|
try {
|
|
const result = await fn();
|
|
enable();
|
|
return result;
|
|
} catch (e) {
|
|
enable();
|
|
throw e;
|
|
}
|
|
}
|
|
|
|
export function disableConsoleLog(severities: ConsoleSeverity[] = ["log", "warn"]) {
|
|
severities.forEach((severity) => {
|
|
console[severity] = () => null;
|
|
});
|
|
$console?.setLevel("critical");
|
|
}
|
|
|
|
export function enableConsoleLog() {
|
|
Object.entries(_oldConsoles).forEach(([severity, fn]) => {
|
|
console[severity as ConsoleSeverity] = fn;
|
|
});
|
|
$console?.resetLevel();
|
|
}
|
|
|
|
export function formatMemoryUsage() {
|
|
const usage = process.memoryUsage();
|
|
return {
|
|
rss: usage.rss / 1024 / 1024,
|
|
heapUsed: usage.heapUsed / 1024 / 1024,
|
|
external: usage.external / 1024 / 1024,
|
|
arrayBuffers: usage.arrayBuffers / 1024 / 1024,
|
|
};
|
|
}
|