Files
bun.sh/src/codegen/client-js.ts
2025-05-28 17:04:37 -07:00

44 lines
1.8 KiB
TypeScript

import { pathToUpperSnakeCase } from "./helpers";
// This is the implementation for $debug
// TODO: interop with $BUN_DEBUG
export function createLogClientJS(filepath: string, publicName: string) {
return `
let $debug_trace = Bun.env.TRACE && Bun.env.TRACE === '1';
let $debug_log_enabled = ((env) => (
// The rationale for checking all these variables is just so you don't have to exactly remember which one you set.
(env.BUN_DEBUG_ALL && env.BUN_DEBUG_ALL !== '0')
|| (env.BUN_DEBUG_JS && env.BUN_DEBUG_JS !== '0')
|| (env.BUN_DEBUG_${pathToUpperSnakeCase(publicName)} === '1')
|| (env.DEBUG_${pathToUpperSnakeCase(filepath)} === '1')
))(Bun.env);
let $debug_pid_prefix = Bun.env.SHOW_PID === '1';
let $debug_log = $debug_log_enabled ? (...args) => {
// warn goes to stderr without colorizing
console[$debug_trace ? 'trace' : 'warn'](($debug_pid_prefix ? \`[\${process.pid}] \` : '') + (Bun.enableANSIColors ? '\\x1b[90m[${publicName}]\\x1b[0m' : '[${publicName}]'), ...args);
} : () => {};
`;
}
export function createAssertClientJS(publicName: string) {
return `
let $assert = function(check, sourceString, ...message) {
if (!check) {
const prevPrepareStackTrace = Error.prepareStackTrace;
Error.prepareStackTrace = (e, stack) => {
return e.name + ': ' + e.message + '\\n' + stack.slice(1).map(x => ' at ' + x.toString()).join('\\n');
};
const e = new Error(sourceString);
e.stack; // materialize stack
e.name = 'AssertionError';
Error.prepareStackTrace = prevPrepareStackTrace;
console.error('[${publicName}] ASSERTION FAILED: ' + sourceString);
if (message.length) console.warn(...message);
console.warn(e.stack.split('\\n')[1] + '\\n');
if (Bun.env.ASSERT === 'CRASH') process.exit(0xAA);
throw e;
}
}
`;
}