47 lines
1.1 KiB
JavaScript
47 lines
1.1 KiB
JavaScript
|
/*
|
||
|
MIT License http://www.opensource.org/licenses/mit-license.php
|
||
|
Author Tobias Koppers @sokra
|
||
|
*/
|
||
|
|
||
|
"use strict";
|
||
|
|
||
|
const { SyncBailHook } = require("tapable");
|
||
|
const { Logger } = require("./Logger");
|
||
|
const createConsoleLogger = require("./createConsoleLogger");
|
||
|
|
||
|
/** @type {createConsoleLogger.LoggerOptions} */
|
||
|
let currentDefaultLoggerOptions = {
|
||
|
level: "info",
|
||
|
debug: false,
|
||
|
console
|
||
|
};
|
||
|
let currentDefaultLogger = createConsoleLogger(currentDefaultLoggerOptions);
|
||
|
|
||
|
/**
|
||
|
* @param {string} name name of the logger
|
||
|
* @returns {Logger} a logger
|
||
|
*/
|
||
|
exports.getLogger = name => {
|
||
|
return new Logger(
|
||
|
(type, args) => {
|
||
|
if (exports.hooks.log.call(name, type, args) === undefined) {
|
||
|
currentDefaultLogger(name, type, args);
|
||
|
}
|
||
|
},
|
||
|
childName => exports.getLogger(`${name}/${childName}`)
|
||
|
);
|
||
|
};
|
||
|
|
||
|
/**
|
||
|
* @param {createConsoleLogger.LoggerOptions} options new options, merge with old options
|
||
|
* @returns {void}
|
||
|
*/
|
||
|
exports.configureDefaultLogger = options => {
|
||
|
Object.assign(currentDefaultLoggerOptions, options);
|
||
|
currentDefaultLogger = createConsoleLogger(currentDefaultLoggerOptions);
|
||
|
};
|
||
|
|
||
|
exports.hooks = {
|
||
|
log: new SyncBailHook(["origin", "type", "args"])
|
||
|
};
|