mirror of
https://gitea.wildfiregames.com/0ad/0ad
synced 2026-06-16 05:13:58 -07:00
Up to now `eslint-plugin-brace-rules` was used to enforce a common brace style for JavaScript code. This plugin was however updated the last time over 9 years ago and will be incompatible with ESLint v10, as that [removes `context.getSourceCode()`][1], the plugin relies on. To keep the eslint config working with ESLint v10, this replaces `eslint-plugin-brace-rules` with the [`@stylistic/brace-style`][2] rule from `@stylistic/eslint-plugin`, a package we already use. While `@stylistic/brace-style` doesn't offer an option to format braces in exactly the same way as before, the "allman" style seems to be the one closest to the existing code. [1]: https://eslint.org/blog/2025/11/eslint-v10.0.0-alpha.0-released/#removed-deprecated-rule-context-members [2]: https://eslint.style/rules/brace-style
55 lines
935 B
JavaScript
55 lines
935 B
JavaScript
class Logger
|
|
{
|
|
levels = ['trace', 'debug', 'info', 'warn', 'error'];
|
|
// Default = 'info'.
|
|
levelIndex = 2;
|
|
|
|
setLevel(level)
|
|
{
|
|
const index = this.levels.indexOf(level);
|
|
if (index === -1)
|
|
{
|
|
throw new Error(`Invalid log level: ${level}`);
|
|
}
|
|
this.levelIndex = index;
|
|
}
|
|
|
|
constructor()
|
|
{
|
|
this.levels.forEach((level, index) =>
|
|
{
|
|
this[level] = (...args) =>
|
|
{
|
|
if (index < this.levelIndex)
|
|
return;
|
|
|
|
if (level === 'error')
|
|
error(`${args.join(' ')}`);
|
|
else if (level === 'warn')
|
|
warn(`${args.join(' ')}`);
|
|
else
|
|
log(`[${level.toUpperCase()}] ${args.join(' ')}`);
|
|
};
|
|
});
|
|
}
|
|
|
|
getLevel()
|
|
{
|
|
return this.levels[this.levelIndex];
|
|
}
|
|
|
|
getLogger(className)
|
|
{
|
|
const scopedLogger = {};
|
|
this.levels.forEach((level) =>
|
|
{
|
|
scopedLogger[level] = (msg) =>
|
|
{
|
|
this[level](`[${className}]`, msg);
|
|
};
|
|
});
|
|
return scopedLogger;
|
|
}
|
|
}
|
|
|
|
export const logger = new Logger();
|