0ad/binaries/data/mods/mod/tools/dap/logger.js
Dunedan 93ce94655d
Use @stylistic/brace-style for eslint
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
2026-01-12 21:33:52 +01:00

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();