Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@pagedip/util-logger

Package Overview
Dependencies
Maintainers
1
Versions
38
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@pagedip/util-logger - npm Package Compare versions

Comparing version 2.2.3 to 2.2.4

11

CHANGELOG.md

@@ -0,1 +1,12 @@

## [2.2.4](https://github.com/pagedip/pagedip-framework/tree/release/102/util/logger) - Apr 3, 2019
### Dependencies
- [@pagedip/util-prop-helpers](https://github.com/pagedip/pagedip-framework/tree/release/102/util/prop-helpers): `^1.2.5` → `^1.2.6`
- @babel/cli: `^7.2.3` → `^7.4.3`
### Commits
[`b598d737..2c04b76d`](https://github.com/pagedip/pagedip-framework/compare/b598d7371ad921fcb10ee26200222d1e24b3a83a..2c04b76d1ecc71949e8c3336a675a85e89d0c6b7)
- [`e2e4efa7`](https://github.com/pagedip/pagedip-framework/commit/e2e4efa7f8b47ea32baf6c2ed8a8d51b7ca75def) update deps
## [2.2.3](https://github.com/pagedip/pagedip-framework/tree/release/99/util/logger) - Mar 30, 2019

@@ -2,0 +13,0 @@

12

lib/index.js

@@ -9,3 +9,3 @@ /* eslint-disable */

enumerable: true,
get: function get() {
get: function () {
return _logger.default;

@@ -16,3 +16,3 @@ }

enumerable: true,
get: function get() {
get: function () {
return _progress.default;

@@ -29,7 +29,7 @@ }

var log = new _logger.default();
const log = new _logger.default();
var _default = log; // the default level of the built-in instance
exports.default = _default;
var globalLevel; // check localStorage first as the user may have directly set this and wants to
let globalLevel; // check localStorage first as the user may have directly set this and wants to
// override the built in value

@@ -63,3 +63,3 @@

var stderr = process && process.stderr;
const stderr = process && process.stderr;
log.use((0, _progress.default)({

@@ -69,2 +69,2 @@ enabled: Boolean(stderr && stderr.isTTY),

}));
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmRleC5qcyJdLCJuYW1lcyI6WyJsb2ciLCJMb2dnZXIiLCJnbG9iYWxMZXZlbCIsIndpbmRvdyIsImxvY2FsU3RvcmFnZSIsImdldEl0ZW0iLCJwcm9jZXNzIiwiZW52IiwiUEFHRURJUF9MT0dMRVZFTCIsImxldmVsIiwiZSIsIndhcm4iLCJzdGRlcnIiLCJ1c2UiLCJlbmFibGVkIiwiQm9vbGVhbiIsImlzVFRZIiwic3RyZWFtIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBOztBQUNBOzs7O0FBSUEsSUFBTUEsR0FBRyxHQUFHLElBQUlDLGVBQUosRUFBWjtlQUNlRCxHLEVBRWY7OztBQUNPLElBQUlFLFdBQUosQyxDQUVQO0FBQ0E7Ozs7QUFDQSxJQUFJLE9BQU9DLE1BQVAsS0FBa0IsV0FBbEIsSUFBaUNBLE1BQU0sQ0FBQ0MsWUFBNUMsRUFBMEQ7QUFDeEQsd0JBQUFGLFdBQVcsR0FBR0MsTUFBTSxDQUFDQyxZQUFQLENBQW9CQyxPQUFwQixDQUE0QixrQkFBNUIsQ0FBZDtBQUNELEMsQ0FFRDtBQUNBO0FBQ0E7OztBQUNBLElBQUksQ0FBQ0gsV0FBRCxJQUFnQkksT0FBaEIsSUFBMkJBLE9BQU8sQ0FBQ0MsR0FBdkMsRUFBNEM7QUFDMUMsd0JBQUFMLFdBQVcsR0FBR0ksT0FBTyxDQUFDQyxHQUFSLENBQVlDLGdCQUExQjtBQUNELEMsQ0FFRDs7O0FBQ0EsSUFBSSxDQUFDTixXQUFMLEVBQWtCO0FBQ2hCLHdCQUFBQSxXQUFXLEdBQUcsTUFBZDtBQUNELEMsQ0FFRDs7O0FBQ0EsSUFBSTtBQUNGRixFQUFBQSxHQUFHLENBQUNTLEtBQUosR0FBWVAsV0FBWjtBQUNELENBRkQsQ0FFRSxPQUFNUSxDQUFOLEVBQVM7QUFDVFYsRUFBQUEsR0FBRyxDQUFDVyxJQUFKLENBQVMsUUFBVCxFQUFtQix1QkFBbkIsRUFBNENULFdBQTVDO0FBQ0QsQyxDQUVEOzs7QUFDQSxJQUFNVSxNQUFNLEdBQUdOLE9BQU8sSUFBSUEsT0FBTyxDQUFDTSxNQUFsQztBQUNBWixHQUFHLENBQUNhLEdBQUosQ0FBUSx1QkFBUztBQUNmQyxFQUFBQSxPQUFPLEVBQUVDLE9BQU8sQ0FBQ0gsTUFBTSxJQUFJQSxNQUFNLENBQUNJLEtBQWxCLENBREQ7QUFFZkMsRUFBQUEsTUFBTSxFQUFFTDtBQUZPLENBQVQsQ0FBUiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBMb2dnZXIgZnJvbSBcIi4vbG9nZ2VyXCI7XG5pbXBvcnQgcHJvZ3Jlc3MgZnJvbSBcIi4vcHJvZ3Jlc3NcIjtcblxuZXhwb3J0IHtMb2dnZXIscHJvZ3Jlc3N9O1xuXG5jb25zdCBsb2cgPSBuZXcgTG9nZ2VyKCk7XG5leHBvcnQgZGVmYXVsdCBsb2c7XG5cbi8vIHRoZSBkZWZhdWx0IGxldmVsIG9mIHRoZSBidWlsdC1pbiBpbnN0YW5jZVxuZXhwb3J0IGxldCBnbG9iYWxMZXZlbDtcblxuLy8gY2hlY2sgbG9jYWxTdG9yYWdlIGZpcnN0IGFzIHRoZSB1c2VyIG1heSBoYXZlIGRpcmVjdGx5IHNldCB0aGlzIGFuZCB3YW50cyB0b1xuLy8gb3ZlcnJpZGUgdGhlIGJ1aWx0IGluIHZhbHVlXG5pZiAodHlwZW9mIHdpbmRvdyAhPT0gXCJ1bmRlZmluZWRcIiAmJiB3aW5kb3cubG9jYWxTdG9yYWdlKSB7XG4gIGdsb2JhbExldmVsID0gd2luZG93LmxvY2FsU3RvcmFnZS5nZXRJdGVtKFwiUEFHRURJUF9MT0dMRVZFTFwiKTtcbn1cblxuLy8gY2hlY2sgcHJvY3NzLmVudiBuZXh0OyBpbiBOb2RlLCB0aGUgdXNlciB3YW50cyB0byBvdmVycmlkZTsgaW4gdGhlIGJyb3dzZXIsXG4vLyB0aGlzIGlzIHVzdWFsbHkgc2hpcHBlZCB3aXRoIHRoZSBidW5kbGUgZnJvbSBjb21waWxlIHRpbWUgYW5kIGlzIGVmZmVjdGl2ZWx5XG4vLyB0aGUgc3lzdGVtIGRlZmF1bHRcbmlmICghZ2xvYmFsTGV2ZWwgJiYgcHJvY2VzcyAmJiBwcm9jZXNzLmVudikge1xuICBnbG9iYWxMZXZlbCA9IHByb2Nlc3MuZW52LlBBR0VESVBfTE9HTEVWRUw7XG59XG5cbi8vIGFic29sdXRlIGRlZmF1bHQgaXMgaW5mb1xuaWYgKCFnbG9iYWxMZXZlbCkge1xuICBnbG9iYWxMZXZlbCA9IFwiaW5mb1wiO1xufVxuXG4vLyBzZXQgdGhlIGxvZyBsZXZlbFxudHJ5IHtcbiAgbG9nLmxldmVsID0gZ2xvYmFsTGV2ZWw7XG59IGNhdGNoKGUpIHtcbiAgbG9nLndhcm4oXCJsb2dnZXJcIiwgXCJ1bmtub3duIGxvZ2xldmVsICclcydcIiwgZ2xvYmFsTGV2ZWwpO1xufVxuXG4vLyBhZGQgcHJvZ3Jlc3MgcGx1Z2luXG5jb25zdCBzdGRlcnIgPSBwcm9jZXNzICYmIHByb2Nlc3Muc3RkZXJyO1xubG9nLnVzZShwcm9ncmVzcyh7XG4gIGVuYWJsZWQ6IEJvb2xlYW4oc3RkZXJyICYmIHN0ZGVyci5pc1RUWSksXG4gIHN0cmVhbTogc3RkZXJyXG59KSk7XG4iXX0=
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmRleC5qcyJdLCJuYW1lcyI6WyJsb2ciLCJMb2dnZXIiLCJnbG9iYWxMZXZlbCIsIndpbmRvdyIsImxvY2FsU3RvcmFnZSIsImdldEl0ZW0iLCJwcm9jZXNzIiwiZW52IiwiUEFHRURJUF9MT0dMRVZFTCIsImxldmVsIiwiZSIsIndhcm4iLCJzdGRlcnIiLCJ1c2UiLCJlbmFibGVkIiwiQm9vbGVhbiIsImlzVFRZIiwic3RyZWFtIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBOztBQUNBOzs7O0FBSUEsTUFBTUEsR0FBRyxHQUFHLElBQUlDLGVBQUosRUFBWjtlQUNlRCxHLEVBRWY7OztBQUNPLElBQUlFLFdBQUosQyxDQUVQO0FBQ0E7Ozs7QUFDQSxJQUFJLE9BQU9DLE1BQVAsS0FBa0IsV0FBbEIsSUFBaUNBLE1BQU0sQ0FBQ0MsWUFBNUMsRUFBMEQ7QUFDeEQsd0JBQUFGLFdBQVcsR0FBR0MsTUFBTSxDQUFDQyxZQUFQLENBQW9CQyxPQUFwQixDQUE0QixrQkFBNUIsQ0FBZDtBQUNELEMsQ0FFRDtBQUNBO0FBQ0E7OztBQUNBLElBQUksQ0FBQ0gsV0FBRCxJQUFnQkksT0FBaEIsSUFBMkJBLE9BQU8sQ0FBQ0MsR0FBdkMsRUFBNEM7QUFDMUMsd0JBQUFMLFdBQVcsR0FBR0ksT0FBTyxDQUFDQyxHQUFSLENBQVlDLGdCQUExQjtBQUNELEMsQ0FFRDs7O0FBQ0EsSUFBSSxDQUFDTixXQUFMLEVBQWtCO0FBQ2hCLHdCQUFBQSxXQUFXLEdBQUcsTUFBZDtBQUNELEMsQ0FFRDs7O0FBQ0EsSUFBSTtBQUNGRixFQUFBQSxHQUFHLENBQUNTLEtBQUosR0FBWVAsV0FBWjtBQUNELENBRkQsQ0FFRSxPQUFNUSxDQUFOLEVBQVM7QUFDVFYsRUFBQUEsR0FBRyxDQUFDVyxJQUFKLENBQVMsUUFBVCxFQUFtQix1QkFBbkIsRUFBNENULFdBQTVDO0FBQ0QsQyxDQUVEOzs7QUFDQSxNQUFNVSxNQUFNLEdBQUdOLE9BQU8sSUFBSUEsT0FBTyxDQUFDTSxNQUFsQztBQUNBWixHQUFHLENBQUNhLEdBQUosQ0FBUSx1QkFBUztBQUNmQyxFQUFBQSxPQUFPLEVBQUVDLE9BQU8sQ0FBQ0gsTUFBTSxJQUFJQSxNQUFNLENBQUNJLEtBQWxCLENBREQ7QUFFZkMsRUFBQUEsTUFBTSxFQUFFTDtBQUZPLENBQVQsQ0FBUiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBMb2dnZXIgZnJvbSBcIi4vbG9nZ2VyXCI7XG5pbXBvcnQgcHJvZ3Jlc3MgZnJvbSBcIi4vcHJvZ3Jlc3NcIjtcblxuZXhwb3J0IHtMb2dnZXIscHJvZ3Jlc3N9O1xuXG5jb25zdCBsb2cgPSBuZXcgTG9nZ2VyKCk7XG5leHBvcnQgZGVmYXVsdCBsb2c7XG5cbi8vIHRoZSBkZWZhdWx0IGxldmVsIG9mIHRoZSBidWlsdC1pbiBpbnN0YW5jZVxuZXhwb3J0IGxldCBnbG9iYWxMZXZlbDtcblxuLy8gY2hlY2sgbG9jYWxTdG9yYWdlIGZpcnN0IGFzIHRoZSB1c2VyIG1heSBoYXZlIGRpcmVjdGx5IHNldCB0aGlzIGFuZCB3YW50cyB0b1xuLy8gb3ZlcnJpZGUgdGhlIGJ1aWx0IGluIHZhbHVlXG5pZiAodHlwZW9mIHdpbmRvdyAhPT0gXCJ1bmRlZmluZWRcIiAmJiB3aW5kb3cubG9jYWxTdG9yYWdlKSB7XG4gIGdsb2JhbExldmVsID0gd2luZG93LmxvY2FsU3RvcmFnZS5nZXRJdGVtKFwiUEFHRURJUF9MT0dMRVZFTFwiKTtcbn1cblxuLy8gY2hlY2sgcHJvY3NzLmVudiBuZXh0OyBpbiBOb2RlLCB0aGUgdXNlciB3YW50cyB0byBvdmVycmlkZTsgaW4gdGhlIGJyb3dzZXIsXG4vLyB0aGlzIGlzIHVzdWFsbHkgc2hpcHBlZCB3aXRoIHRoZSBidW5kbGUgZnJvbSBjb21waWxlIHRpbWUgYW5kIGlzIGVmZmVjdGl2ZWx5XG4vLyB0aGUgc3lzdGVtIGRlZmF1bHRcbmlmICghZ2xvYmFsTGV2ZWwgJiYgcHJvY2VzcyAmJiBwcm9jZXNzLmVudikge1xuICBnbG9iYWxMZXZlbCA9IHByb2Nlc3MuZW52LlBBR0VESVBfTE9HTEVWRUw7XG59XG5cbi8vIGFic29sdXRlIGRlZmF1bHQgaXMgaW5mb1xuaWYgKCFnbG9iYWxMZXZlbCkge1xuICBnbG9iYWxMZXZlbCA9IFwiaW5mb1wiO1xufVxuXG4vLyBzZXQgdGhlIGxvZyBsZXZlbFxudHJ5IHtcbiAgbG9nLmxldmVsID0gZ2xvYmFsTGV2ZWw7XG59IGNhdGNoKGUpIHtcbiAgbG9nLndhcm4oXCJsb2dnZXJcIiwgXCJ1bmtub3duIGxvZ2xldmVsICclcydcIiwgZ2xvYmFsTGV2ZWwpO1xufVxuXG4vLyBhZGQgcHJvZ3Jlc3MgcGx1Z2luXG5jb25zdCBzdGRlcnIgPSBwcm9jZXNzICYmIHByb2Nlc3Muc3RkZXJyO1xubG9nLnVzZShwcm9ncmVzcyh7XG4gIGVuYWJsZWQ6IEJvb2xlYW4oc3RkZXJyICYmIHN0ZGVyci5pc1RUWSksXG4gIHN0cmVhbTogc3RkZXJyXG59KSk7XG4iXX0=

@@ -23,40 +23,14 @@ /* eslint-disable */

function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); }
function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }
function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
var Logger =
/*#__PURE__*/
function (_EventEmitter) {
_inherits(Logger, _EventEmitter);
class Logger extends _events.EventEmitter {
constructor(opts) {
super();
function Logger(opts) {
var _this;
_defineProperty(this, "levels", {});
_classCallCheck(this, Logger);
_defineProperty(this, "priorities", []);
_this = _possibleConstructorReturn(this, _getPrototypeOf(Logger).call(this));
_defineProperty(_assertThisInitialized(_this), "levels", {});
_defineProperty(_assertThisInitialized(_this), "priorities", []);
opts = _this.options = Object.assign({}, Logger.defaults, opts);
(0, _utilPropHelpers.hidden)(_assertThisInitialized(_this), {
opts = this.options = Object.assign({}, Logger.defaults, opts);
(0, _utilPropHelpers.hidden)(this, {
_priority: 0

@@ -66,305 +40,249 @@ });

if (typeof opts.write === "function") {
_this.write = opts.write;
this.write = opts.write;
}
_this.color = new _chalk.default.constructor({
this.color = new _chalk.default.constructor({
enabled: opts.colors != null ? opts.colors : !!_supportsColor.default.stderr,
level: _supportsColor.default.stderr ? _supportsColor.default.stderr.level : 0
});
this.addLevel(opts.levels);
_this.addLevel(opts.levels);
if (isValidPriority(opts.priority)) {
_this.priority = opts.priority;
this.priority = opts.priority;
} else if (opts.level) {
_this.level = opts.level;
this.level = opts.level;
} else {
_this.priority = Logger.defaultPriority;
this.priority = Logger.defaultPriority;
}
}
return _this;
get __pagedip_logger__() {
return true;
}
_createClass(Logger, [{
key: "use",
value: function use(fn) {
var _this2 = this;
static isLogger(v) {
return Boolean(v && v["__pagedip_logger__"]);
}
if (Array.isArray(fn)) {
fn.forEach(function (f) {
return _this2.use(f);
});
} else if (typeof fn === "function") {
fn.call(this, this);
}
use(fn) {
if (Array.isArray(fn)) {
fn.forEach(f => this.use(f));
} else if (typeof fn === "function") {
fn.call(this, this);
}
return this;
return this;
}
get priority() {
return this._priority;
}
set priority(priority) {
if (typeof priority !== "number" || isNaN(priority)) {
throw new Error("Expecting number for priority");
}
}, {
key: "addLevel",
value: function addLevel(name, spec) {
var _this3 = this;
if (_typeof(name) === "object" && name != null) {
Object.keys(name).forEach(function (n) {
return _this3.addLevel(n, name[n]);
});
return this;
}
this._priority = priority;
}
if (typeof name !== "string") {
throw new Error("Expecting string for level name.");
}
get level() {
return this.priorityToLevel(this.priority);
}
if (name === "silent" || name === "all") {
throw new Error("Invalid level name.");
}
set level(level) {
const priority = this.levelToPriority(level);
spec = spec || {};
this.levels[name] = spec;
if (priority == null) {
throw new Error("Expecting a valid level name.");
}
if (isValidPriority(spec.priority)) {
var index = (0, _lodash.sortedIndexBy)(this.priorities, name, function (n) {
var lspec = _this3.levels[n];
return lspec && isValidPriority(lspec.priority) ? lspec.priority : Infinity;
});
this.priorities.splice(index, 0, name);
}
this.priority = priority;
}
[name].concat(spec.alias).forEach(function (m) {
if (m && typeof _this3[m] === "undefined") {
(0, _utilPropHelpers.hidden)(_this3, m, function () {
for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
args[_key] = arguments[_key];
}
return _this3.printf.apply(_this3, [name].concat(args));
});
}
});
addLevel(name, spec) {
if (typeof name === "object" && name != null) {
Object.keys(name).forEach(n => this.addLevel(n, name[n]));
return this;
}
}, {
key: "priorityToLevel",
value: function priorityToLevel(priority) {
if (!isValidPriority(priority)) {
throw new Error("Expecting valid priority.");
}
for (var i = 0; i < this.priorities.length; i++) {
var level = this.priorities[i];
var spec = this.levels[level];
if (typeof name !== "string") {
throw new Error("Expecting string for level name.");
}
if (spec && isValidPriority(spec.priority) && priority <= spec.priority) {
return level;
}
}
if (name === "silent" || name === "all") {
throw new Error("Invalid level name.");
}
}, {
key: "levelToPriority",
value: function levelToPriority(level) {
var _this4 = this;
// very special levels that aren't actually levels
if (level === "silent") return Infinity;else if (level === "all") return -Infinity;
var spec = this.levels[level];
spec = spec || {};
this.levels[name] = spec;
if (!spec) {
Object.keys(this.levels).some(function (l) {
var ls = _this4.levels[l];
if (isValidPriority(spec.priority)) {
const index = (0, _lodash.sortedIndexBy)(this.priorities, name, n => {
const lspec = this.levels[n];
return lspec && isValidPriority(lspec.priority) ? lspec.priority : Infinity;
});
this.priorities.splice(index, 0, name);
}
if (ls && ls.alias && [].concat(ls.alias).includes(level)) {
spec = ls;
return true;
}
[name].concat(spec.alias).forEach(m => {
if (m && typeof this[m] === "undefined") {
(0, _utilPropHelpers.hidden)(this, m, (...args) => {
return this.printf(name, ...args);
});
}
});
return this;
}
if (spec && isValidPriority(spec.priority)) {
return spec.priority;
}
priorityToLevel(priority) {
if (!isValidPriority(priority)) {
throw new Error("Expecting valid priority.");
}
}, {
key: "toLevel",
value: function toLevel(v) {
if (typeof v === "string") {
var spec = this.levels[v];
if (spec != null) return v;
} else if (isValidPriority(v)) {
return this.priorityToLevel(v);
for (let i = 0; i < this.priorities.length; i++) {
const level = this.priorities[i];
const spec = this.levels[level];
if (spec && isValidPriority(spec.priority) && priority <= spec.priority) {
return level;
}
}
}, {
key: "toPriority",
value: function toPriority(v) {
if (typeof v === "string") {
return this.levelToPriority(v);
} else if (isValidPriority(v)) {
return v;
}
}
}, {
key: "hasPriority",
value: function hasPriority(priority) {
if (typeof priority === "string") {
var level = priority;
priority = this.levelToPriority(level); // if the level exists but has no priority, then this passes
}
if (!isValidPriority(priority) && this.levels[level]) {
levelToPriority(level) {
// very special levels that aren't actually levels
if (level === "silent") return Infinity;else if (level === "all") return -Infinity;
let spec = this.levels[level];
if (!spec) {
Object.keys(this.levels).some(l => {
const ls = this.levels[l];
if (ls && ls.alias && [].concat(ls.alias).includes(level)) {
spec = ls;
return true;
}
}
});
}
if (!isValidPriority(priority)) {
throw new Error("Expecting valid priority or level name.");
}
if (spec && isValidPriority(spec.priority)) {
return spec.priority;
}
}
return priority >= this.priority;
toLevel(v) {
if (typeof v === "string") {
const spec = this.levels[v];
if (spec != null) return v;
} else if (isValidPriority(v)) {
return this.priorityToLevel(v);
}
}, {
key: "write",
value: function write() {// base write is a noop
}
toPriority(v) {
if (typeof v === "string") {
return this.levelToPriority(v);
} else if (isValidPriority(v)) {
return v;
}
}, {
key: "format",
value: function format(type) {
for (var _len2 = arguments.length, args = new Array(_len2 > 1 ? _len2 - 1 : 0), _key2 = 1; _key2 < _len2; _key2++) {
args[_key2 - 1] = arguments[_key2];
}
}
var method = (0, _lodash.get)(this.options, "format." + type);
hasPriority(priority) {
if (typeof priority === "string") {
const level = priority;
priority = this.levelToPriority(level); // if the level exists but has no priority, then this passes
if (args.length === 1 && typeof args[0] === "function") {
var a = args[0].call(this);
args = Array.isArray(a) ? a : [a];
if (!isValidPriority(priority) && this.levels[level]) {
return true;
}
}
if (typeof method === "function") {
return method.apply(this, args);
} else {
return args.join(" ");
}
if (!isValidPriority(priority)) {
throw new Error("Expecting valid priority or level name.");
}
}, {
key: "printf",
value: function printf(level, prefix) {
for (var _len3 = arguments.length, args = new Array(_len3 > 2 ? _len3 - 2 : 0), _key3 = 2; _key3 < _len3; _key3++) {
args[_key3 - 2] = arguments[_key3];
}
var log = this.sprintf.apply(this, [level, prefix].concat(args));
return priority >= this.priority;
}
if (this.hasPriority(level)) {
this.write(log);
}
write() {// base write is a noop
}
return this;
format(type, ...args) {
const method = (0, _lodash.get)(this.options, "format." + type);
if (args.length === 1 && typeof args[0] === "function") {
const a = args[0].call(this);
args = Array.isArray(a) ? a : [a];
}
}, {
key: "sprintf",
value: function sprintf(level, prefix) {
var parts = [];
if (this.options.heading) {
parts.push(this.format("heading", this.options.heading));
}
if (typeof method === "function") {
return method.apply(this, args);
} else {
return args.join(" ");
}
}
var spec = this.levels[this.toLevel(level)];
printf(level, prefix, ...args) {
const log = this.sprintf(level, prefix, ...args);
if (spec && spec.display) {
parts.push(this.format("level", spec.display));
}
if (this.hasPriority(level)) {
this.write(log);
}
if (prefix) {
parts.push(this.format("prefix", prefix));
}
return this;
}
for (var _len4 = arguments.length, args = new Array(_len4 > 2 ? _len4 - 2 : 0), _key4 = 2; _key4 < _len4; _key4++) {
args[_key4 - 2] = arguments[_key4];
}
sprintf(level, prefix, ...args) {
const parts = [];
parts.push(this.format.apply(this, ["log"].concat(args)));
var log = parts.filter(Boolean).join(" ");
this.emit("log", log, level, prefix);
this.emit("log:" + level, log, level, prefix);
if (prefix) this.emit(prefix, log, level, prefix);
return log;
if (this.options.heading) {
parts.push(this.format("heading", this.options.heading));
}
}, {
key: "prefix",
value: function prefix(_prefix) {
var _this5 = this;
var self = this;
const spec = this.levels[this.toLevel(level)];
function printf(level) {
for (var _len5 = arguments.length, args = new Array(_len5 > 1 ? _len5 - 1 : 0), _key5 = 1; _key5 < _len5; _key5++) {
args[_key5 - 1] = arguments[_key5];
}
if (spec && spec.display) {
parts.push(this.format("level", spec.display));
}
self.printf.apply(self, [level, _prefix].concat(args));
return printf;
}
if (prefix) {
parts.push(this.format("prefix", prefix));
}
Object.keys(this.levels).forEach(function (k) {
var spec = _this5.levels[k];
if (!spec) return;
[k].concat(spec.alias).forEach(function (m) {
if (!m) return;
parts.push(this.format("log", ...args));
const log = parts.filter(Boolean).join(" ");
this.emit("log", log, level, prefix);
this.emit("log:" + level, log, level, prefix);
if (prefix) this.emit(prefix, log, level, prefix);
return log;
}
printf[m] = function () {
for (var _len6 = arguments.length, args = new Array(_len6), _key6 = 0; _key6 < _len6; _key6++) {
args[_key6] = arguments[_key6];
}
prefix(prefix) {
const self = this;
return printf.apply(void 0, [k].concat(args));
};
});
});
printf.prefixed = _prefix;
printf.logger = this;
this.emit("prefix", printf);
function printf(level, ...args) {
self.printf(level, prefix, ...args);
return printf;
}
}, {
key: "__pagedip_logger__",
get: function get() {
return true;
}
}, {
key: "priority",
get: function get() {
return this._priority;
},
set: function set(priority) {
if (typeof priority !== "number" || isNaN(priority)) {
throw new Error("Expecting number for priority");
}
this._priority = priority;
}
}, {
key: "level",
get: function get() {
return this.priorityToLevel(this.priority);
},
set: function set(level) {
var priority = this.levelToPriority(level);
Object.keys(this.levels).forEach(k => {
const spec = this.levels[k];
if (!spec) return;
[k].concat(spec.alias).forEach(m => {
if (!m) return;
if (priority == null) {
throw new Error("Expecting a valid level name.");
}
printf[m] = function (...args) {
return printf(k, ...args);
};
});
});
printf.prefixed = prefix;
printf.logger = this;
this.emit("prefix", printf);
return printf;
}
this.priority = priority;
}
}], [{
key: "isLogger",
value: function isLogger(v) {
return Boolean(v && v["__pagedip_logger__"]);
}
}]);
}
return Logger;
}(_events.EventEmitter);
exports.default = Logger;

@@ -376,11 +294,13 @@

error: {
display: function display() {
display() {
return this.color.bgBlack.red("ERR!");
},
priority: 6000
},
warn: {
display: function display() {
display() {
return this.color.bgYellow.black("WARN");
},
priority: 5000

@@ -393,17 +313,20 @@ },

debug: {
display: function display() {
display() {
return this.color.bgCyan.black("DBUG");
},
priority: 3000
},
verbose: {
display: function display() {
display() {
return this.color.bgBlack.cyan("VERB");
},
priority: 2000
},
silly: {
display: function display() {
display() {
return this.color.inverse("SILL");
},
priority: 1000

@@ -417,23 +340,19 @@ }

format: {
prefix: function prefix(_prefix2) {
var show = typeof this.options.displayPrefix === "boolean" ? this.options.displayPrefix : this.hasPriority("verbose");
return show ? this.color.magenta(_prefix2) : null;
prefix(prefix) {
const show = typeof this.options.displayPrefix === "boolean" ? this.options.displayPrefix : this.hasPriority("verbose");
return show ? this.color.magenta(prefix) : null;
},
heading: function heading(_heading) {
return this.color.bgBlack.white(_heading);
heading(heading) {
return this.color.bgBlack.white(heading);
},
log: function log() {
var _this6 = this;
for (var _len7 = arguments.length, args = new Array(_len7), _key7 = 0; _key7 < _len7; _key7++) {
args[_key7] = arguments[_key7];
}
log(...args) {
args = args.slice(0);
if (args.length) {
var msg = args.shift();
let msg = args.shift();
if (msg instanceof Error) {
var showStack = typeof this.options.traceErrors === "boolean" ? this.options.traceErrors : this.hasPriority("debug");
const showStack = typeof this.options.traceErrors === "boolean" ? this.options.traceErrors : this.hasPriority("debug");

@@ -450,7 +369,7 @@ if (showStack && msg.stack) {

return _util.format.apply(null, args.map(function (a) {
return _util.format.apply(null, args.map(a => {
if (typeof a !== "string") {
a = (0, _util.inspect)(a, {
colors: _this6.color.enabled,
depth: typeof _this6.options.inspectDepth === "number" ? _this6.options.inspectDepth : 5
colors: this.color.enabled,
depth: typeof this.options.inspectDepth === "number" ? this.options.inspectDepth : 5
});

@@ -462,4 +381,6 @@ }

}
},
write: function write(log) {
write(log) {
if (process.stderr && process.stderr.write) {

@@ -471,2 +392,3 @@ process.stderr.write(log + "\n");

}
});

@@ -479,2 +401,2 @@

module.exports = exports.default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/logger.js"],"names":["Logger","opts","options","Object","assign","defaults","_priority","write","color","chalk","constructor","enabled","colors","supportsColor","stderr","level","addLevel","levels","isValidPriority","priority","defaultPriority","fn","Array","isArray","forEach","f","use","call","name","spec","keys","n","Error","index","priorities","lspec","Infinity","splice","concat","alias","m","args","printf","i","length","some","l","ls","includes","v","priorityToLevel","levelToPriority","type","method","a","apply","join","prefix","log","sprintf","hasPriority","parts","heading","push","format","toLevel","display","filter","Boolean","emit","self","k","prefixed","logger","isNaN","EventEmitter","error","bgBlack","red","warn","bgYellow","black","info","debug","bgCyan","verbose","cyan","silly","inverse","multiline","defaultLevels","show","displayPrefix","magenta","white","slice","msg","shift","showStack","traceErrors","stack","toString","message","unshift","map","depth","inspectDepth","process","console"],"mappings":"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","sourcesContent":["import chalk from \"chalk\";\nimport {sortedIndexBy,get} from \"lodash\";\nimport {hidden} from \"@pagedip/util-prop-helpers\";\nimport {format,inspect} from \"util\";\nimport {EventEmitter} from \"events\";\nimport supportsColor from \"supports-color\";\n\nexport default class Logger extends EventEmitter {\n  constructor(opts) {\n    super();\n    opts = this.options = Object.assign({}, Logger.defaults, opts);\n\n    hidden(this, {\n      _priority: 0\n    });\n\n    if (typeof opts.write === \"function\") {\n      this.write = opts.write;\n    }\n\n    this.color = new chalk.constructor({\n      enabled: opts.colors != null ? opts.colors : !!supportsColor.stderr,\n      level: supportsColor.stderr ? supportsColor.stderr.level : 0\n    });\n\n    this.addLevel(opts.levels);\n\n    if (isValidPriority(opts.priority)) {\n      this.priority = opts.priority;\n    } else if (opts.level) {\n      this.level = opts.level;\n    } else {\n      this.priority = Logger.defaultPriority;\n    }\n  }\n\n  get __pagedip_logger__() {\n    return true;\n  }\n\n  static isLogger(v) {\n    return Boolean(v && v[\"__pagedip_logger__\"]);\n  }\n\n  use(fn) {\n    if (Array.isArray(fn)) {\n      fn.forEach(f => this.use(f));\n    } else if (typeof fn === \"function\") {\n      fn.call(this, this);\n    }\n\n    return this;\n  }\n\n  static defaultPriority = 4000;\n  static defaultLevels = {\n    error: {\n      display() {\n        return this.color.bgBlack.red(\"ERR!\");\n      },\n      priority: 6000\n    },\n    warn: {\n      display() {\n        return this.color.bgYellow.black(\"WARN\");\n      },\n      priority: 5000\n    },\n    info: {\n      alias: [ \"log\" ],\n      priority: 4000\n    },\n    debug: {\n      display() {\n        return this.color.bgCyan.black(\"DBUG\");\n      },\n      priority: 3000\n    },\n    verbose: {\n      display() {\n        return this.color.bgBlack.cyan(\"VERB\");\n      },\n      priority: 2000\n    },\n    silly: {\n      display() {\n        return this.color.inverse(\"SILL\");\n      },\n      priority: 1000\n    }\n  }\n\n  static defaults = {\n    multiline: true,\n    levels: Logger.defaultLevels,\n    format: {\n      prefix(prefix) {\n        const show = typeof this.options.displayPrefix === \"boolean\" ?\n          this.options.displayPrefix :\n          this.hasPriority(\"verbose\");\n\n        return show ? this.color.magenta(prefix) : null;\n      },\n      heading(heading) {\n        return this.color.bgBlack.white(heading);\n      },\n      log(...args) {\n        args = args.slice(0);\n\n        if (args.length) {\n          let msg = args.shift();\n\n          if (msg instanceof Error) {\n            const showStack = typeof this.options.traceErrors === \"boolean\" ?\n              this.options.traceErrors :\n              this.hasPriority(\"debug\");\n\n            if (showStack && msg.stack) {\n              msg = msg.stack;\n            } else {\n              msg = msg.toString ? msg.toString() : msg.message || msg;\n            }\n          }\n\n          args.unshift(msg);\n        }\n\n        return format.apply(null, args.map(a => {\n          if (typeof a !== \"string\") {\n            a = inspect(a, {\n              colors: this.color.enabled,\n              depth: typeof this.options.inspectDepth === \"number\" ?\n                this.options.inspectDepth : 5\n            });\n          }\n\n          return a;\n        }));\n      },\n    },\n    write(log) {\n      if (process.stderr && process.stderr.write) {\n        process.stderr.write(log + \"\\n\");\n      } else {\n        console.log(log);\n      }\n    }\n  }\n\n  levels = {}\n  priorities = []\n\n  get priority() {\n    return this._priority;\n  }\n\n  set priority(priority) {\n    if (typeof priority !== \"number\" || isNaN(priority)) {\n      throw new Error(\"Expecting number for priority\");\n    }\n\n    this._priority = priority;\n  }\n\n  get level() {\n    return this.priorityToLevel(this.priority);\n  }\n\n  set level(level) {\n    const priority = this.levelToPriority(level);\n\n    if (priority == null) {\n      throw new Error(\"Expecting a valid level name.\");\n    }\n\n    this.priority = priority;\n  }\n\n  addLevel(name, spec) {\n    if (typeof name === \"object\" && name != null) {\n      Object.keys(name).forEach(n => this.addLevel(n, name[n]));\n      return this;\n    }\n\n    if (typeof name !== \"string\") {\n      throw new Error(\"Expecting string for level name.\");\n    }\n\n    if (name === \"silent\" || name === \"all\") {\n      throw new Error(\"Invalid level name.\");\n    }\n\n    spec = spec || {};\n    this.levels[name] = spec;\n\n    if (isValidPriority(spec.priority)) {\n      const index = sortedIndexBy(this.priorities, name, (n) => {\n        const lspec = this.levels[n];\n        return lspec && isValidPriority(lspec.priority) ?\n          lspec.priority :\n          Infinity;\n      });\n\n      this.priorities.splice(index, 0, name);\n    }\n\n    [name].concat(spec.alias).forEach(m => {\n      if (m && typeof this[m] === \"undefined\") {\n        hidden(this, m, (...args) => {\n          return this.printf(name, ...args);\n        });\n      }\n    });\n\n    return this;\n  }\n\n  priorityToLevel(priority) {\n    if (!isValidPriority(priority)) {\n      throw new Error(\"Expecting valid priority.\");\n    }\n\n    for (let i = 0; i < this.priorities.length; i++) {\n      const level = this.priorities[i];\n      const spec = this.levels[level];\n\n      if (\n        spec &&\n        isValidPriority(spec.priority) &&\n        priority <= spec.priority\n      ) {\n        return level;\n      }\n    }\n  }\n\n  levelToPriority(level) {\n    // very special levels that aren't actually levels\n    if (level === \"silent\") return Infinity;\n    else if (level === \"all\") return -Infinity;\n\n    let spec = this.levels[level];\n\n    if (!spec) {\n      Object.keys(this.levels).some(l => {\n        const ls = this.levels[l];\n        if (ls && ls.alias && [].concat(ls.alias).includes(level)) {\n          spec = ls;\n          return true;\n        }\n      });\n    }\n\n    if (spec && isValidPriority(spec.priority)) {\n      return spec.priority;\n    }\n  }\n\n  toLevel(v) {\n    if (typeof v === \"string\") {\n      const spec = this.levels[v];\n      if (spec != null) return v;\n    } else if (isValidPriority(v)) {\n      return this.priorityToLevel(v);\n    }\n  }\n\n  toPriority(v) {\n    if (typeof v === \"string\") {\n      return this.levelToPriority(v);\n    } else if (isValidPriority(v)) {\n      return v;\n    }\n  }\n\n  hasPriority(priority) {\n    if (typeof priority === \"string\") {\n      const level = priority;\n      priority = this.levelToPriority(level);\n\n      // if the level exists but has no priority, then this passes\n      if (!isValidPriority(priority) && this.levels[level]) {\n        return true;\n      }\n    }\n\n    if (!isValidPriority(priority)) {\n      throw new Error(\"Expecting valid priority or level name.\");\n    }\n\n    return priority >= this.priority;\n  }\n\n  write() {\n    // base write is a noop\n  }\n\n  format(type, ...args) {\n    const method = get(this.options, \"format.\" + type);\n\n    if (args.length === 1 && typeof args[0] === \"function\") {\n      const a = args[0].call(this);\n      args = Array.isArray(a) ? a : [ a ];\n    }\n\n    if (typeof method === \"function\") {\n      return method.apply(this, args);\n    } else {\n      return args.join(\" \");\n    }\n  }\n\n  printf(level, prefix, ...args) {\n    const log = this.sprintf(level, prefix, ...args);\n\n    if (this.hasPriority(level)) {\n      this.write(log);\n    }\n\n    return this;\n  }\n\n  sprintf(level, prefix, ...args) {\n    const parts = [];\n\n    if (this.options.heading) {\n      parts.push(this.format(\"heading\", this.options.heading));\n    }\n\n    const spec = this.levels[this.toLevel(level)];\n    if (spec && spec.display) {\n      parts.push(this.format(\"level\", spec.display));\n    }\n\n    if (prefix) {\n      parts.push(this.format(\"prefix\", prefix));\n    }\n\n    parts.push(this.format(\"log\", ...args));\n\n    const log = parts.filter(Boolean).join(\" \");\n    this.emit(\"log\", log, level, prefix);\n    this.emit(\"log:\" + level, log, level, prefix);\n    if (prefix) this.emit(prefix, log, level, prefix);\n    return log;\n  }\n\n  prefix(prefix) {\n    const self = this;\n\n    function printf(level, ...args) {\n      self.printf(level, prefix, ...args);\n      return printf;\n    }\n\n    Object.keys(this.levels).forEach(k => {\n      const spec = this.levels[k];\n      if (!spec) return;\n\n      [k].concat(spec.alias).forEach(m => {\n        if (!m) return;\n        printf[m] = function(...args) {\n          return printf(k, ...args);\n        };\n      });\n    });\n\n    printf.prefixed = prefix;\n    printf.logger = this;\n    this.emit(\"prefix\", printf);\n\n    return printf;\n  }\n}\n\nfunction isValidPriority(priority) {\n  return typeof priority === \"number\" && !isNaN(priority);\n}\n"]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/logger.js"],"names":["Logger","EventEmitter","constructor","opts","options","Object","assign","defaults","_priority","write","color","chalk","enabled","colors","supportsColor","stderr","level","addLevel","levels","isValidPriority","priority","defaultPriority","__pagedip_logger__","isLogger","v","Boolean","use","fn","Array","isArray","forEach","f","call","isNaN","Error","priorityToLevel","levelToPriority","name","spec","keys","n","index","priorities","lspec","Infinity","splice","concat","alias","m","args","printf","i","length","some","l","ls","includes","toLevel","toPriority","hasPriority","format","type","method","a","apply","join","prefix","log","sprintf","parts","heading","push","display","filter","emit","self","k","prefixed","logger","error","bgBlack","red","warn","bgYellow","black","info","debug","bgCyan","verbose","cyan","silly","inverse","multiline","defaultLevels","show","displayPrefix","magenta","white","slice","msg","shift","showStack","traceErrors","stack","toString","message","unshift","map","depth","inspectDepth","process","console"],"mappings":";;;;;;;;AAAA;;AACA;;AACA;;AACA;;AACA;;AACA;;;;;;AAEe,MAAMA,MAAN,SAAqBC,oBAArB,CAAkC;AAC/CC,EAAAA,WAAW,CAACC,IAAD,EAAO;AAChB;;AADgB,oCA6IT,EA7IS;;AAAA,wCA8IL,EA9IK;;AAEhBA,IAAAA,IAAI,GAAG,KAAKC,OAAL,GAAeC,MAAM,CAACC,MAAP,CAAc,EAAd,EAAkBN,MAAM,CAACO,QAAzB,EAAmCJ,IAAnC,CAAtB;AAEA,iCAAO,IAAP,EAAa;AACXK,MAAAA,SAAS,EAAE;AADA,KAAb;;AAIA,QAAI,OAAOL,IAAI,CAACM,KAAZ,KAAsB,UAA1B,EAAsC;AACpC,WAAKA,KAAL,GAAaN,IAAI,CAACM,KAAlB;AACD;;AAED,SAAKC,KAAL,GAAa,IAAIC,eAAMT,WAAV,CAAsB;AACjCU,MAAAA,OAAO,EAAET,IAAI,CAACU,MAAL,IAAe,IAAf,GAAsBV,IAAI,CAACU,MAA3B,GAAoC,CAAC,CAACC,uBAAcC,MAD5B;AAEjCC,MAAAA,KAAK,EAAEF,uBAAcC,MAAd,GAAuBD,uBAAcC,MAAd,CAAqBC,KAA5C,GAAoD;AAF1B,KAAtB,CAAb;AAKA,SAAKC,QAAL,CAAcd,IAAI,CAACe,MAAnB;;AAEA,QAAIC,eAAe,CAAChB,IAAI,CAACiB,QAAN,CAAnB,EAAoC;AAClC,WAAKA,QAAL,GAAgBjB,IAAI,CAACiB,QAArB;AACD,KAFD,MAEO,IAAIjB,IAAI,CAACa,KAAT,EAAgB;AACrB,WAAKA,KAAL,GAAab,IAAI,CAACa,KAAlB;AACD,KAFM,MAEA;AACL,WAAKI,QAAL,GAAgBpB,MAAM,CAACqB,eAAvB;AACD;AACF;;AAED,MAAIC,kBAAJ,GAAyB;AACvB,WAAO,IAAP;AACD;;AAED,SAAOC,QAAP,CAAgBC,CAAhB,EAAmB;AACjB,WAAOC,OAAO,CAACD,CAAC,IAAIA,CAAC,CAAC,oBAAD,CAAP,CAAd;AACD;;AAEDE,EAAAA,GAAG,CAACC,EAAD,EAAK;AACN,QAAIC,KAAK,CAACC,OAAN,CAAcF,EAAd,CAAJ,EAAuB;AACrBA,MAAAA,EAAE,CAACG,OAAH,CAAWC,CAAC,IAAI,KAAKL,GAAL,CAASK,CAAT,CAAhB;AACD,KAFD,MAEO,IAAI,OAAOJ,EAAP,KAAc,UAAlB,EAA8B;AACnCA,MAAAA,EAAE,CAACK,IAAH,CAAQ,IAAR,EAAc,IAAd;AACD;;AAED,WAAO,IAAP;AACD;;AAoGD,MAAIZ,QAAJ,GAAe;AACb,WAAO,KAAKZ,SAAZ;AACD;;AAED,MAAIY,QAAJ,CAAaA,QAAb,EAAuB;AACrB,QAAI,OAAOA,QAAP,KAAoB,QAApB,IAAgCa,KAAK,CAACb,QAAD,CAAzC,EAAqD;AACnD,YAAM,IAAIc,KAAJ,CAAU,+BAAV,CAAN;AACD;;AAED,SAAK1B,SAAL,GAAiBY,QAAjB;AACD;;AAED,MAAIJ,KAAJ,GAAY;AACV,WAAO,KAAKmB,eAAL,CAAqB,KAAKf,QAA1B,CAAP;AACD;;AAED,MAAIJ,KAAJ,CAAUA,KAAV,EAAiB;AACf,UAAMI,QAAQ,GAAG,KAAKgB,eAAL,CAAqBpB,KAArB,CAAjB;;AAEA,QAAII,QAAQ,IAAI,IAAhB,EAAsB;AACpB,YAAM,IAAIc,KAAJ,CAAU,+BAAV,CAAN;AACD;;AAED,SAAKd,QAAL,GAAgBA,QAAhB;AACD;;AAEDH,EAAAA,QAAQ,CAACoB,IAAD,EAAOC,IAAP,EAAa;AACnB,QAAI,OAAOD,IAAP,KAAgB,QAAhB,IAA4BA,IAAI,IAAI,IAAxC,EAA8C;AAC5ChC,MAAAA,MAAM,CAACkC,IAAP,CAAYF,IAAZ,EAAkBP,OAAlB,CAA0BU,CAAC,IAAI,KAAKvB,QAAL,CAAcuB,CAAd,EAAiBH,IAAI,CAACG,CAAD,CAArB,CAA/B;AACA,aAAO,IAAP;AACD;;AAED,QAAI,OAAOH,IAAP,KAAgB,QAApB,EAA8B;AAC5B,YAAM,IAAIH,KAAJ,CAAU,kCAAV,CAAN;AACD;;AAED,QAAIG,IAAI,KAAK,QAAT,IAAqBA,IAAI,KAAK,KAAlC,EAAyC;AACvC,YAAM,IAAIH,KAAJ,CAAU,qBAAV,CAAN;AACD;;AAEDI,IAAAA,IAAI,GAAGA,IAAI,IAAI,EAAf;AACA,SAAKpB,MAAL,CAAYmB,IAAZ,IAAoBC,IAApB;;AAEA,QAAInB,eAAe,CAACmB,IAAI,CAAClB,QAAN,CAAnB,EAAoC;AAClC,YAAMqB,KAAK,GAAG,2BAAc,KAAKC,UAAnB,EAA+BL,IAA/B,EAAsCG,CAAD,IAAO;AACxD,cAAMG,KAAK,GAAG,KAAKzB,MAAL,CAAYsB,CAAZ,CAAd;AACA,eAAOG,KAAK,IAAIxB,eAAe,CAACwB,KAAK,CAACvB,QAAP,CAAxB,GACLuB,KAAK,CAACvB,QADD,GAELwB,QAFF;AAGD,OALa,CAAd;AAOA,WAAKF,UAAL,CAAgBG,MAAhB,CAAuBJ,KAAvB,EAA8B,CAA9B,EAAiCJ,IAAjC;AACD;;AAED,KAACA,IAAD,EAAOS,MAAP,CAAcR,IAAI,CAACS,KAAnB,EAA0BjB,OAA1B,CAAkCkB,CAAC,IAAI;AACrC,UAAIA,CAAC,IAAI,OAAO,KAAKA,CAAL,CAAP,KAAmB,WAA5B,EAAyC;AACvC,qCAAO,IAAP,EAAaA,CAAb,EAAgB,CAAC,GAAGC,IAAJ,KAAa;AAC3B,iBAAO,KAAKC,MAAL,CAAYb,IAAZ,EAAkB,GAAGY,IAArB,CAAP;AACD,SAFD;AAGD;AACF,KAND;AAQA,WAAO,IAAP;AACD;;AAEDd,EAAAA,eAAe,CAACf,QAAD,EAAW;AACxB,QAAI,CAACD,eAAe,CAACC,QAAD,CAApB,EAAgC;AAC9B,YAAM,IAAIc,KAAJ,CAAU,2BAAV,CAAN;AACD;;AAED,SAAK,IAAIiB,CAAC,GAAG,CAAb,EAAgBA,CAAC,GAAG,KAAKT,UAAL,CAAgBU,MAApC,EAA4CD,CAAC,EAA7C,EAAiD;AAC/C,YAAMnC,KAAK,GAAG,KAAK0B,UAAL,CAAgBS,CAAhB,CAAd;AACA,YAAMb,IAAI,GAAG,KAAKpB,MAAL,CAAYF,KAAZ,CAAb;;AAEA,UACEsB,IAAI,IACJnB,eAAe,CAACmB,IAAI,CAAClB,QAAN,CADf,IAEAA,QAAQ,IAAIkB,IAAI,CAAClB,QAHnB,EAIE;AACA,eAAOJ,KAAP;AACD;AACF;AACF;;AAEDoB,EAAAA,eAAe,CAACpB,KAAD,EAAQ;AACrB;AACA,QAAIA,KAAK,KAAK,QAAd,EAAwB,OAAO4B,QAAP,CAAxB,KACK,IAAI5B,KAAK,KAAK,KAAd,EAAqB,OAAO,CAAC4B,QAAR;AAE1B,QAAIN,IAAI,GAAG,KAAKpB,MAAL,CAAYF,KAAZ,CAAX;;AAEA,QAAI,CAACsB,IAAL,EAAW;AACTjC,MAAAA,MAAM,CAACkC,IAAP,CAAY,KAAKrB,MAAjB,EAAyBmC,IAAzB,CAA8BC,CAAC,IAAI;AACjC,cAAMC,EAAE,GAAG,KAAKrC,MAAL,CAAYoC,CAAZ,CAAX;;AACA,YAAIC,EAAE,IAAIA,EAAE,CAACR,KAAT,IAAkB,GAAGD,MAAH,CAAUS,EAAE,CAACR,KAAb,EAAoBS,QAApB,CAA6BxC,KAA7B,CAAtB,EAA2D;AACzDsB,UAAAA,IAAI,GAAGiB,EAAP;AACA,iBAAO,IAAP;AACD;AACF,OAND;AAOD;;AAED,QAAIjB,IAAI,IAAInB,eAAe,CAACmB,IAAI,CAAClB,QAAN,CAA3B,EAA4C;AAC1C,aAAOkB,IAAI,CAAClB,QAAZ;AACD;AACF;;AAEDqC,EAAAA,OAAO,CAACjC,CAAD,EAAI;AACT,QAAI,OAAOA,CAAP,KAAa,QAAjB,EAA2B;AACzB,YAAMc,IAAI,GAAG,KAAKpB,MAAL,CAAYM,CAAZ,CAAb;AACA,UAAIc,IAAI,IAAI,IAAZ,EAAkB,OAAOd,CAAP;AACnB,KAHD,MAGO,IAAIL,eAAe,CAACK,CAAD,CAAnB,EAAwB;AAC7B,aAAO,KAAKW,eAAL,CAAqBX,CAArB,CAAP;AACD;AACF;;AAEDkC,EAAAA,UAAU,CAAClC,CAAD,EAAI;AACZ,QAAI,OAAOA,CAAP,KAAa,QAAjB,EAA2B;AACzB,aAAO,KAAKY,eAAL,CAAqBZ,CAArB,CAAP;AACD,KAFD,MAEO,IAAIL,eAAe,CAACK,CAAD,CAAnB,EAAwB;AAC7B,aAAOA,CAAP;AACD;AACF;;AAEDmC,EAAAA,WAAW,CAACvC,QAAD,EAAW;AACpB,QAAI,OAAOA,QAAP,KAAoB,QAAxB,EAAkC;AAChC,YAAMJ,KAAK,GAAGI,QAAd;AACAA,MAAAA,QAAQ,GAAG,KAAKgB,eAAL,CAAqBpB,KAArB,CAAX,CAFgC,CAIhC;;AACA,UAAI,CAACG,eAAe,CAACC,QAAD,CAAhB,IAA8B,KAAKF,MAAL,CAAYF,KAAZ,CAAlC,EAAsD;AACpD,eAAO,IAAP;AACD;AACF;;AAED,QAAI,CAACG,eAAe,CAACC,QAAD,CAApB,EAAgC;AAC9B,YAAM,IAAIc,KAAJ,CAAU,yCAAV,CAAN;AACD;;AAED,WAAOd,QAAQ,IAAI,KAAKA,QAAxB;AACD;;AAEDX,EAAAA,KAAK,GAAG,CACN;AACD;;AAEDmD,EAAAA,MAAM,CAACC,IAAD,EAAO,GAAGZ,IAAV,EAAgB;AACpB,UAAMa,MAAM,GAAG,iBAAI,KAAK1D,OAAT,EAAkB,YAAYyD,IAA9B,CAAf;;AAEA,QAAIZ,IAAI,CAACG,MAAL,KAAgB,CAAhB,IAAqB,OAAOH,IAAI,CAAC,CAAD,CAAX,KAAmB,UAA5C,EAAwD;AACtD,YAAMc,CAAC,GAAGd,IAAI,CAAC,CAAD,CAAJ,CAAQjB,IAAR,CAAa,IAAb,CAAV;AACAiB,MAAAA,IAAI,GAAGrB,KAAK,CAACC,OAAN,CAAckC,CAAd,IAAmBA,CAAnB,GAAuB,CAAEA,CAAF,CAA9B;AACD;;AAED,QAAI,OAAOD,MAAP,KAAkB,UAAtB,EAAkC;AAChC,aAAOA,MAAM,CAACE,KAAP,CAAa,IAAb,EAAmBf,IAAnB,CAAP;AACD,KAFD,MAEO;AACL,aAAOA,IAAI,CAACgB,IAAL,CAAU,GAAV,CAAP;AACD;AACF;;AAEDf,EAAAA,MAAM,CAAClC,KAAD,EAAQkD,MAAR,EAAgB,GAAGjB,IAAnB,EAAyB;AAC7B,UAAMkB,GAAG,GAAG,KAAKC,OAAL,CAAapD,KAAb,EAAoBkD,MAApB,EAA4B,GAAGjB,IAA/B,CAAZ;;AAEA,QAAI,KAAKU,WAAL,CAAiB3C,KAAjB,CAAJ,EAA6B;AAC3B,WAAKP,KAAL,CAAW0D,GAAX;AACD;;AAED,WAAO,IAAP;AACD;;AAEDC,EAAAA,OAAO,CAACpD,KAAD,EAAQkD,MAAR,EAAgB,GAAGjB,IAAnB,EAAyB;AAC9B,UAAMoB,KAAK,GAAG,EAAd;;AAEA,QAAI,KAAKjE,OAAL,CAAakE,OAAjB,EAA0B;AACxBD,MAAAA,KAAK,CAACE,IAAN,CAAW,KAAKX,MAAL,CAAY,SAAZ,EAAuB,KAAKxD,OAAL,CAAakE,OAApC,CAAX;AACD;;AAED,UAAMhC,IAAI,GAAG,KAAKpB,MAAL,CAAY,KAAKuC,OAAL,CAAazC,KAAb,CAAZ,CAAb;;AACA,QAAIsB,IAAI,IAAIA,IAAI,CAACkC,OAAjB,EAA0B;AACxBH,MAAAA,KAAK,CAACE,IAAN,CAAW,KAAKX,MAAL,CAAY,OAAZ,EAAqBtB,IAAI,CAACkC,OAA1B,CAAX;AACD;;AAED,QAAIN,MAAJ,EAAY;AACVG,MAAAA,KAAK,CAACE,IAAN,CAAW,KAAKX,MAAL,CAAY,QAAZ,EAAsBM,MAAtB,CAAX;AACD;;AAEDG,IAAAA,KAAK,CAACE,IAAN,CAAW,KAAKX,MAAL,CAAY,KAAZ,EAAmB,GAAGX,IAAtB,CAAX;AAEA,UAAMkB,GAAG,GAAGE,KAAK,CAACI,MAAN,CAAahD,OAAb,EAAsBwC,IAAtB,CAA2B,GAA3B,CAAZ;AACA,SAAKS,IAAL,CAAU,KAAV,EAAiBP,GAAjB,EAAsBnD,KAAtB,EAA6BkD,MAA7B;AACA,SAAKQ,IAAL,CAAU,SAAS1D,KAAnB,EAA0BmD,GAA1B,EAA+BnD,KAA/B,EAAsCkD,MAAtC;AACA,QAAIA,MAAJ,EAAY,KAAKQ,IAAL,CAAUR,MAAV,EAAkBC,GAAlB,EAAuBnD,KAAvB,EAA8BkD,MAA9B;AACZ,WAAOC,GAAP;AACD;;AAEDD,EAAAA,MAAM,CAACA,MAAD,EAAS;AACb,UAAMS,IAAI,GAAG,IAAb;;AAEA,aAASzB,MAAT,CAAgBlC,KAAhB,EAAuB,GAAGiC,IAA1B,EAAgC;AAC9B0B,MAAAA,IAAI,CAACzB,MAAL,CAAYlC,KAAZ,EAAmBkD,MAAnB,EAA2B,GAAGjB,IAA9B;AACA,aAAOC,MAAP;AACD;;AAED7C,IAAAA,MAAM,CAACkC,IAAP,CAAY,KAAKrB,MAAjB,EAAyBY,OAAzB,CAAiC8C,CAAC,IAAI;AACpC,YAAMtC,IAAI,GAAG,KAAKpB,MAAL,CAAY0D,CAAZ,CAAb;AACA,UAAI,CAACtC,IAAL,EAAW;AAEX,OAACsC,CAAD,EAAI9B,MAAJ,CAAWR,IAAI,CAACS,KAAhB,EAAuBjB,OAAvB,CAA+BkB,CAAC,IAAI;AAClC,YAAI,CAACA,CAAL,EAAQ;;AACRE,QAAAA,MAAM,CAACF,CAAD,CAAN,GAAY,UAAS,GAAGC,IAAZ,EAAkB;AAC5B,iBAAOC,MAAM,CAAC0B,CAAD,EAAI,GAAG3B,IAAP,CAAb;AACD,SAFD;AAGD,OALD;AAMD,KAVD;AAYAC,IAAAA,MAAM,CAAC2B,QAAP,GAAkBX,MAAlB;AACAhB,IAAAA,MAAM,CAAC4B,MAAP,GAAgB,IAAhB;AACA,SAAKJ,IAAL,CAAU,QAAV,EAAoBxB,MAApB;AAEA,WAAOA,MAAP;AACD;;AA7W8C;;;;gBAA5BlD,M,qBA+CM,I;;gBA/CNA,M,mBAgDI;AACrB+E,EAAAA,KAAK,EAAE;AACLP,IAAAA,OAAO,GAAG;AACR,aAAO,KAAK9D,KAAL,CAAWsE,OAAX,CAAmBC,GAAnB,CAAuB,MAAvB,CAAP;AACD,KAHI;;AAIL7D,IAAAA,QAAQ,EAAE;AAJL,GADc;AAOrB8D,EAAAA,IAAI,EAAE;AACJV,IAAAA,OAAO,GAAG;AACR,aAAO,KAAK9D,KAAL,CAAWyE,QAAX,CAAoBC,KAApB,CAA0B,MAA1B,CAAP;AACD,KAHG;;AAIJhE,IAAAA,QAAQ,EAAE;AAJN,GAPe;AAarBiE,EAAAA,IAAI,EAAE;AACJtC,IAAAA,KAAK,EAAE,CAAE,KAAF,CADH;AAEJ3B,IAAAA,QAAQ,EAAE;AAFN,GAbe;AAiBrBkE,EAAAA,KAAK,EAAE;AACLd,IAAAA,OAAO,GAAG;AACR,aAAO,KAAK9D,KAAL,CAAW6E,MAAX,CAAkBH,KAAlB,CAAwB,MAAxB,CAAP;AACD,KAHI;;AAILhE,IAAAA,QAAQ,EAAE;AAJL,GAjBc;AAuBrBoE,EAAAA,OAAO,EAAE;AACPhB,IAAAA,OAAO,GAAG;AACR,aAAO,KAAK9D,KAAL,CAAWsE,OAAX,CAAmBS,IAAnB,CAAwB,MAAxB,CAAP;AACD,KAHM;;AAIPrE,IAAAA,QAAQ,EAAE;AAJH,GAvBY;AA6BrBsE,EAAAA,KAAK,EAAE;AACLlB,IAAAA,OAAO,GAAG;AACR,aAAO,KAAK9D,KAAL,CAAWiF,OAAX,CAAmB,MAAnB,CAAP;AACD,KAHI;;AAILvE,IAAAA,QAAQ,EAAE;AAJL;AA7Bc,C;;gBAhDJpB,M,cAqFD;AAChB4F,EAAAA,SAAS,EAAE,IADK;AAEhB1E,EAAAA,MAAM,EAAElB,MAAM,CAAC6F,aAFC;AAGhBjC,EAAAA,MAAM,EAAE;AACNM,IAAAA,MAAM,CAACA,MAAD,EAAS;AACb,YAAM4B,IAAI,GAAG,OAAO,KAAK1F,OAAL,CAAa2F,aAApB,KAAsC,SAAtC,GACX,KAAK3F,OAAL,CAAa2F,aADF,GAEX,KAAKpC,WAAL,CAAiB,SAAjB,CAFF;AAIA,aAAOmC,IAAI,GAAG,KAAKpF,KAAL,CAAWsF,OAAX,CAAmB9B,MAAnB,CAAH,GAAgC,IAA3C;AACD,KAPK;;AAQNI,IAAAA,OAAO,CAACA,OAAD,EAAU;AACf,aAAO,KAAK5D,KAAL,CAAWsE,OAAX,CAAmBiB,KAAnB,CAAyB3B,OAAzB,CAAP;AACD,KAVK;;AAWNH,IAAAA,GAAG,CAAC,GAAGlB,IAAJ,EAAU;AACXA,MAAAA,IAAI,GAAGA,IAAI,CAACiD,KAAL,CAAW,CAAX,CAAP;;AAEA,UAAIjD,IAAI,CAACG,MAAT,EAAiB;AACf,YAAI+C,GAAG,GAAGlD,IAAI,CAACmD,KAAL,EAAV;;AAEA,YAAID,GAAG,YAAYjE,KAAnB,EAA0B;AACxB,gBAAMmE,SAAS,GAAG,OAAO,KAAKjG,OAAL,CAAakG,WAApB,KAAoC,SAApC,GAChB,KAAKlG,OAAL,CAAakG,WADG,GAEhB,KAAK3C,WAAL,CAAiB,OAAjB,CAFF;;AAIA,cAAI0C,SAAS,IAAIF,GAAG,CAACI,KAArB,EAA4B;AAC1BJ,YAAAA,GAAG,GAAGA,GAAG,CAACI,KAAV;AACD,WAFD,MAEO;AACLJ,YAAAA,GAAG,GAAGA,GAAG,CAACK,QAAJ,GAAeL,GAAG,CAACK,QAAJ,EAAf,GAAgCL,GAAG,CAACM,OAAJ,IAAeN,GAArD;AACD;AACF;;AAEDlD,QAAAA,IAAI,CAACyD,OAAL,CAAaP,GAAb;AACD;;AAED,aAAOvC,aAAOI,KAAP,CAAa,IAAb,EAAmBf,IAAI,CAAC0D,GAAL,CAAS5C,CAAC,IAAI;AACtC,YAAI,OAAOA,CAAP,KAAa,QAAjB,EAA2B;AACzBA,UAAAA,CAAC,GAAG,mBAAQA,CAAR,EAAW;AACblD,YAAAA,MAAM,EAAE,KAAKH,KAAL,CAAWE,OADN;AAEbgG,YAAAA,KAAK,EAAE,OAAO,KAAKxG,OAAL,CAAayG,YAApB,KAAqC,QAArC,GACL,KAAKzG,OAAL,CAAayG,YADR,GACuB;AAHjB,WAAX,CAAJ;AAKD;;AAED,eAAO9C,CAAP;AACD,OAVyB,CAAnB,CAAP;AAWD;;AA3CK,GAHQ;;AAgDhBtD,EAAAA,KAAK,CAAC0D,GAAD,EAAM;AACT,QAAI2C,OAAO,CAAC/F,MAAR,IAAkB+F,OAAO,CAAC/F,MAAR,CAAeN,KAArC,EAA4C;AAC1CqG,MAAAA,OAAO,CAAC/F,MAAR,CAAeN,KAAf,CAAqB0D,GAAG,GAAG,IAA3B;AACD,KAFD,MAEO;AACL4C,MAAAA,OAAO,CAAC5C,GAAR,CAAYA,GAAZ;AACD;AACF;;AAtDe,C;;AA2RpB,SAAShD,eAAT,CAAyBC,QAAzB,EAAmC;AACjC,SAAO,OAAOA,QAAP,KAAoB,QAApB,IAAgC,CAACa,KAAK,CAACb,QAAD,CAA7C;AACD","sourcesContent":["import chalk from \"chalk\";\nimport {sortedIndexBy,get} from \"lodash\";\nimport {hidden} from \"@pagedip/util-prop-helpers\";\nimport {format,inspect} from \"util\";\nimport {EventEmitter} from \"events\";\nimport supportsColor from \"supports-color\";\n\nexport default class Logger extends EventEmitter {\n  constructor(opts) {\n    super();\n    opts = this.options = Object.assign({}, Logger.defaults, opts);\n\n    hidden(this, {\n      _priority: 0\n    });\n\n    if (typeof opts.write === \"function\") {\n      this.write = opts.write;\n    }\n\n    this.color = new chalk.constructor({\n      enabled: opts.colors != null ? opts.colors : !!supportsColor.stderr,\n      level: supportsColor.stderr ? supportsColor.stderr.level : 0\n    });\n\n    this.addLevel(opts.levels);\n\n    if (isValidPriority(opts.priority)) {\n      this.priority = opts.priority;\n    } else if (opts.level) {\n      this.level = opts.level;\n    } else {\n      this.priority = Logger.defaultPriority;\n    }\n  }\n\n  get __pagedip_logger__() {\n    return true;\n  }\n\n  static isLogger(v) {\n    return Boolean(v && v[\"__pagedip_logger__\"]);\n  }\n\n  use(fn) {\n    if (Array.isArray(fn)) {\n      fn.forEach(f => this.use(f));\n    } else if (typeof fn === \"function\") {\n      fn.call(this, this);\n    }\n\n    return this;\n  }\n\n  static defaultPriority = 4000;\n  static defaultLevels = {\n    error: {\n      display() {\n        return this.color.bgBlack.red(\"ERR!\");\n      },\n      priority: 6000\n    },\n    warn: {\n      display() {\n        return this.color.bgYellow.black(\"WARN\");\n      },\n      priority: 5000\n    },\n    info: {\n      alias: [ \"log\" ],\n      priority: 4000\n    },\n    debug: {\n      display() {\n        return this.color.bgCyan.black(\"DBUG\");\n      },\n      priority: 3000\n    },\n    verbose: {\n      display() {\n        return this.color.bgBlack.cyan(\"VERB\");\n      },\n      priority: 2000\n    },\n    silly: {\n      display() {\n        return this.color.inverse(\"SILL\");\n      },\n      priority: 1000\n    }\n  }\n\n  static defaults = {\n    multiline: true,\n    levels: Logger.defaultLevels,\n    format: {\n      prefix(prefix) {\n        const show = typeof this.options.displayPrefix === \"boolean\" ?\n          this.options.displayPrefix :\n          this.hasPriority(\"verbose\");\n\n        return show ? this.color.magenta(prefix) : null;\n      },\n      heading(heading) {\n        return this.color.bgBlack.white(heading);\n      },\n      log(...args) {\n        args = args.slice(0);\n\n        if (args.length) {\n          let msg = args.shift();\n\n          if (msg instanceof Error) {\n            const showStack = typeof this.options.traceErrors === \"boolean\" ?\n              this.options.traceErrors :\n              this.hasPriority(\"debug\");\n\n            if (showStack && msg.stack) {\n              msg = msg.stack;\n            } else {\n              msg = msg.toString ? msg.toString() : msg.message || msg;\n            }\n          }\n\n          args.unshift(msg);\n        }\n\n        return format.apply(null, args.map(a => {\n          if (typeof a !== \"string\") {\n            a = inspect(a, {\n              colors: this.color.enabled,\n              depth: typeof this.options.inspectDepth === \"number\" ?\n                this.options.inspectDepth : 5\n            });\n          }\n\n          return a;\n        }));\n      },\n    },\n    write(log) {\n      if (process.stderr && process.stderr.write) {\n        process.stderr.write(log + \"\\n\");\n      } else {\n        console.log(log);\n      }\n    }\n  }\n\n  levels = {}\n  priorities = []\n\n  get priority() {\n    return this._priority;\n  }\n\n  set priority(priority) {\n    if (typeof priority !== \"number\" || isNaN(priority)) {\n      throw new Error(\"Expecting number for priority\");\n    }\n\n    this._priority = priority;\n  }\n\n  get level() {\n    return this.priorityToLevel(this.priority);\n  }\n\n  set level(level) {\n    const priority = this.levelToPriority(level);\n\n    if (priority == null) {\n      throw new Error(\"Expecting a valid level name.\");\n    }\n\n    this.priority = priority;\n  }\n\n  addLevel(name, spec) {\n    if (typeof name === \"object\" && name != null) {\n      Object.keys(name).forEach(n => this.addLevel(n, name[n]));\n      return this;\n    }\n\n    if (typeof name !== \"string\") {\n      throw new Error(\"Expecting string for level name.\");\n    }\n\n    if (name === \"silent\" || name === \"all\") {\n      throw new Error(\"Invalid level name.\");\n    }\n\n    spec = spec || {};\n    this.levels[name] = spec;\n\n    if (isValidPriority(spec.priority)) {\n      const index = sortedIndexBy(this.priorities, name, (n) => {\n        const lspec = this.levels[n];\n        return lspec && isValidPriority(lspec.priority) ?\n          lspec.priority :\n          Infinity;\n      });\n\n      this.priorities.splice(index, 0, name);\n    }\n\n    [name].concat(spec.alias).forEach(m => {\n      if (m && typeof this[m] === \"undefined\") {\n        hidden(this, m, (...args) => {\n          return this.printf(name, ...args);\n        });\n      }\n    });\n\n    return this;\n  }\n\n  priorityToLevel(priority) {\n    if (!isValidPriority(priority)) {\n      throw new Error(\"Expecting valid priority.\");\n    }\n\n    for (let i = 0; i < this.priorities.length; i++) {\n      const level = this.priorities[i];\n      const spec = this.levels[level];\n\n      if (\n        spec &&\n        isValidPriority(spec.priority) &&\n        priority <= spec.priority\n      ) {\n        return level;\n      }\n    }\n  }\n\n  levelToPriority(level) {\n    // very special levels that aren't actually levels\n    if (level === \"silent\") return Infinity;\n    else if (level === \"all\") return -Infinity;\n\n    let spec = this.levels[level];\n\n    if (!spec) {\n      Object.keys(this.levels).some(l => {\n        const ls = this.levels[l];\n        if (ls && ls.alias && [].concat(ls.alias).includes(level)) {\n          spec = ls;\n          return true;\n        }\n      });\n    }\n\n    if (spec && isValidPriority(spec.priority)) {\n      return spec.priority;\n    }\n  }\n\n  toLevel(v) {\n    if (typeof v === \"string\") {\n      const spec = this.levels[v];\n      if (spec != null) return v;\n    } else if (isValidPriority(v)) {\n      return this.priorityToLevel(v);\n    }\n  }\n\n  toPriority(v) {\n    if (typeof v === \"string\") {\n      return this.levelToPriority(v);\n    } else if (isValidPriority(v)) {\n      return v;\n    }\n  }\n\n  hasPriority(priority) {\n    if (typeof priority === \"string\") {\n      const level = priority;\n      priority = this.levelToPriority(level);\n\n      // if the level exists but has no priority, then this passes\n      if (!isValidPriority(priority) && this.levels[level]) {\n        return true;\n      }\n    }\n\n    if (!isValidPriority(priority)) {\n      throw new Error(\"Expecting valid priority or level name.\");\n    }\n\n    return priority >= this.priority;\n  }\n\n  write() {\n    // base write is a noop\n  }\n\n  format(type, ...args) {\n    const method = get(this.options, \"format.\" + type);\n\n    if (args.length === 1 && typeof args[0] === \"function\") {\n      const a = args[0].call(this);\n      args = Array.isArray(a) ? a : [ a ];\n    }\n\n    if (typeof method === \"function\") {\n      return method.apply(this, args);\n    } else {\n      return args.join(\" \");\n    }\n  }\n\n  printf(level, prefix, ...args) {\n    const log = this.sprintf(level, prefix, ...args);\n\n    if (this.hasPriority(level)) {\n      this.write(log);\n    }\n\n    return this;\n  }\n\n  sprintf(level, prefix, ...args) {\n    const parts = [];\n\n    if (this.options.heading) {\n      parts.push(this.format(\"heading\", this.options.heading));\n    }\n\n    const spec = this.levels[this.toLevel(level)];\n    if (spec && spec.display) {\n      parts.push(this.format(\"level\", spec.display));\n    }\n\n    if (prefix) {\n      parts.push(this.format(\"prefix\", prefix));\n    }\n\n    parts.push(this.format(\"log\", ...args));\n\n    const log = parts.filter(Boolean).join(\" \");\n    this.emit(\"log\", log, level, prefix);\n    this.emit(\"log:\" + level, log, level, prefix);\n    if (prefix) this.emit(prefix, log, level, prefix);\n    return log;\n  }\n\n  prefix(prefix) {\n    const self = this;\n\n    function printf(level, ...args) {\n      self.printf(level, prefix, ...args);\n      return printf;\n    }\n\n    Object.keys(this.levels).forEach(k => {\n      const spec = this.levels[k];\n      if (!spec) return;\n\n      [k].concat(spec.alias).forEach(m => {\n        if (!m) return;\n        printf[m] = function(...args) {\n          return printf(k, ...args);\n        };\n      });\n    });\n\n    printf.prefixed = prefix;\n    printf.logger = this;\n    this.emit(\"prefix\", printf);\n\n    return printf;\n  }\n}\n\nfunction isValidPriority(priority) {\n  return typeof priority === \"number\" && !isNaN(priority);\n}\n"]}

@@ -19,4 +19,4 @@ /* eslint-disable */

options = options || {};
var methods = {
enableProgress: function enableProgress(stream) {
const methods = {
enableProgress(stream) {
this.disableProgress();

@@ -26,7 +26,7 @@ stream = stream || options.stream;

if (!stream) {
throw new Error("Expecting writeable stream to attach progress bar too");
throw new Error(`Expecting writeable stream to attach progress bar too`);
}
if (typeof _gauge.default !== "function") {
this.warn("logger", "attempted to attach progress bar in an incompatible environment");
this.warn("logger", `attempted to attach progress bar in an incompatible environment`);
} else {

@@ -42,3 +42,4 @@ this.gauge = new _gauge.default(stream, _objectSpread({

},
disableProgress: function disableProgress() {
disableProgress() {
this.endProgress();

@@ -48,3 +49,4 @@ delete this.gauge;

},
startProgress: function startProgress() {
startProgress() {
if (this.gauge) {

@@ -57,3 +59,4 @@ this.gauge.enable();

},
progress: function progress(prefix, section, completed) {
progress(prefix, section, completed) {
prefix = this.format("prefix", prefix);

@@ -64,15 +67,14 @@ section = [prefix, section].filter(Boolean).join(" ");

},
pulse: function pulse() {
for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
args[_key] = arguments[_key];
}
var msg = this.format.apply(this, ["log"].concat(args));
pulse(...args) {
const msg = this.format("log", ...args);
if (this.gauge) this.gauge.pulse(msg);
return this;
},
endProgress: function endProgress() {
endProgress() {
if (this.gauge) this.gauge.disable();
return this;
}
};

@@ -82,7 +84,7 @@ return function (logger) {

var write = logger.write;
const write = logger.write;
logger.write = function () {
if (this.gauge) this.gauge.hide();
var result = write.apply(this, arguments);
const result = write.apply(this, arguments);
if (this.gauge) this.gauge.show();

@@ -92,13 +94,7 @@ return result;

logger.on("prefix", function (printf) {
Object.keys(methods).forEach(function (k) {
logger.on("prefix", printf => {
Object.keys(methods).forEach(k => {
if (k === "progress") {
printf[k] = function () {
var _printf$logger;
for (var _len2 = arguments.length, args = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {
args[_key2] = arguments[_key2];
}
return (_printf$logger = printf.logger)[k].apply(_printf$logger, [printf.prefixed].concat(args));
printf[k] = function (...args) {
return printf.logger[k](printf.prefixed, ...args);
};

@@ -120,2 +116,2 @@ } else {

module.exports = exports.default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9wcm9ncmVzcy5qcyJdLCJuYW1lcyI6WyJvcHRpb25zIiwibWV0aG9kcyIsImVuYWJsZVByb2dyZXNzIiwic3RyZWFtIiwiZGlzYWJsZVByb2dyZXNzIiwiRXJyb3IiLCJHYXVnZSIsIndhcm4iLCJnYXVnZSIsInVwZGF0ZUludGVydmFsIiwiZW5hYmxlZCIsImVuZFByb2dyZXNzIiwic3RhcnRQcm9ncmVzcyIsImVuYWJsZSIsImhpZGUiLCJwcm9ncmVzcyIsInByZWZpeCIsInNlY3Rpb24iLCJjb21wbGV0ZWQiLCJmb3JtYXQiLCJmaWx0ZXIiLCJCb29sZWFuIiwiam9pbiIsInNob3ciLCJwdWxzZSIsImFyZ3MiLCJtc2ciLCJkaXNhYmxlIiwibG9nZ2VyIiwiT2JqZWN0IiwiYXNzaWduIiwid3JpdGUiLCJyZXN1bHQiLCJhcHBseSIsImFyZ3VtZW50cyIsIm9uIiwicHJpbnRmIiwia2V5cyIsImZvckVhY2giLCJrIiwicHJlZml4ZWQiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7O0FBQUE7Ozs7Ozs7O0FBRWUsa0JBQVNBLE9BQVQsRUFBa0I7QUFDL0JBLEVBQUFBLE9BQU8sR0FBR0EsT0FBTyxJQUFJLEVBQXJCO0FBRUEsTUFBTUMsT0FBTyxHQUFHO0FBQ2RDLElBQUFBLGNBRGMsMEJBQ0NDLE1BREQsRUFDUztBQUNyQixXQUFLQyxlQUFMO0FBRUFELE1BQUFBLE1BQU0sR0FBR0EsTUFBTSxJQUFJSCxPQUFPLENBQUNHLE1BQTNCOztBQUNBLFVBQUksQ0FBQ0EsTUFBTCxFQUFhO0FBQ1gsY0FBTSxJQUFJRSxLQUFKLHlEQUFOO0FBQ0Q7O0FBRUQsVUFBSSxPQUFPQyxjQUFQLEtBQWlCLFVBQXJCLEVBQWlDO0FBQy9CLGFBQUtDLElBQUwsQ0FBVSxRQUFWO0FBQ0QsT0FGRCxNQUVPO0FBQ0wsYUFBS0MsS0FBTCxHQUFhLElBQUlGLGNBQUosQ0FBVUgsTUFBVjtBQUNYTSxVQUFBQSxjQUFjLEVBQUUsT0FBTztBQURaLFdBRVJULE9BQU8sQ0FBQ1Es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QkcsTUFBTSxDQUFDUixNQUE5QixFQUFzQ00sU0FBdEMsQ0FBUDtBQUNELFdBRkQ7QUFHRDtBQUNGLE9BVkQ7QUFXRCxLQVpEOztBQWNBLFFBQUlsQyxPQUFPLENBQUNVLE9BQVosRUFBcUI7QUFDbkJrQixNQUFBQSxNQUFNLENBQUMxQixjQUFQO0FBQ0Q7QUFDRixHQTdCRDtBQThCRCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBHYXVnZSBmcm9tIFwiZ2F1Z2VcIjtcblxuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24ob3B0aW9ucykge1xuICBvcHRpb25zID0gb3B0aW9ucyB8fCB7fTtcblxuICBjb25zdCBtZXRob2RzID0ge1xuICAgIGVuYWJsZVByb2dyZXNzKHN0cmVhbSkge1xuICAgICAgdGhpcy5kaXNhYmxlUHJvZ3Jlc3MoKTtcblxuICAgICAgc3RyZWFtID0gc3RyZWFtIHx8IG9wdGlvbnMuc3RyZWFtO1xuICAgICAgaWYgKCFzdHJlYW0pIHtcbiAgICAgICAgdGhyb3cgbmV3IEVycm9yKGBFeHBlY3Rpbmcgd3JpdGVhYmxlIHN0cmVhbSB0byBhdHRhY2ggcHJvZ3Jlc3MgYmFyIHRvb2ApO1xuICAgICAgfVxuXG4gICAgICBpZiAodHlwZW9mIEdhdWdlICE9PSBcImZ1bmN0aW9uXCIpIHtcbiAgICAgICAgdGhpcy53YXJuKFwibG9nZ2VyXCIsIGBhdHRlbXB0ZWQgdG8gYXR0YWNoIHByb2dyZXNzIGJhciBpbiBhbiBpbmNvbXBhdGlibGUgZW52aXJvbm1lbnRgKTtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIHRoaXMuZ2F1Z2UgPSBuZXcgR2F1Z2Uoc3RyZWFtLCB7XG4gICAgICAgICAgdXBkYXRlSW50ZXJ2YWw6IDEwMDAgLyAxMCxcbiAgICAgICAgICAuLi5vcHRpb25zLmdhdWdlLFxuICAgICAgICAgIGVuYWJsZWQ6IGZhbHNlXG4gICAgICAgIH0pO1xuICAgICAgfVxuXG4gICAgICByZXR1cm4gdGhpcztcbiAgICB9LFxuXG4gICAgZGlzYWJsZVByb2dyZXNzKCkge1xuICAgICAgdGhpcy5lbmRQcm9ncmVzcygpO1xuICAgICAgZGVsZXRlIHRoaXMuZ2F1Z2U7XG4gICAgICByZXR1cm4gdGhpcztcbiAgICB9LFxuXG4gICAgc3RhcnRQcm9ncmVzcygpIHtcbiAgICAgIGlmICh0aGlzLmdhdWdlKSB7XG4gICAgICAgIHRoaXMuZ2F1Z2UuZW5hYmxlKCk7XG4gICAgICAgIHRoaXMuZ2F1Z2UuaGlkZSgpO1xuICAgICAgfVxuXG4gICAgICByZXR1cm4gdGhpcztcbiAgICB9LFxuXG4gICAgcHJvZ3Jlc3MocHJlZml4LCBzZWN0aW9uLCBjb21wbGV0ZWQpIHtcbiAgICAgIHByZWZpeCA9IHRoaXMuZm9ybWF0KFwicHJlZml4XCIsIHByZWZpeCk7XG4gICAgICBzZWN0aW9uID0gW3ByZWZpeCxzZWN0aW9uXS5maWx0ZXIoQm9vbGVhbikuam9pbihcIiBcIik7XG4gICAgICBpZiAodGhpcy5nYXVnZSkgdGhpcy5nYXVnZS5zaG93KHNlY3Rpb24sIGNvbXBsZXRlZCk7XG4gICAgICByZXR1cm4gdGhpcztcbiAgICB9LFxuXG4gICAgcHVsc2UoLi4uYXJncykge1xuICAgICAgY29uc3QgbXNnID0gdGhpcy5mb3JtYXQoXCJsb2dcIiwgLi4uYXJncyk7XG4gICAgICBpZiAodGhpcy5nYXVnZSkgdGhpcy5nYXVnZS5wdWxzZShtc2cpO1xuICAgICAgcmV0dXJuIHRoaXM7XG4gICAgfSxcblxuICAgIGVuZFByb2dyZXNzKCkge1xuICAgICAgaWYgKHRoaXMuZ2F1Z2UpIHRoaXMuZ2F1Z2UuZGlzYWJsZSgpO1xuICAgICAgcmV0dXJuIHRoaXM7XG4gICAgfVxuICB9O1xuXG4gIHJldHVybiBmdW5jdGlvbihsb2dnZXIpIHtcbiAgICBPYmplY3QuYXNzaWduKGxvZ2dlciwgbWV0aG9kcyk7XG5cbiAgICAvLyBtb2RpZnkgdGhlIHdyaXRlIG1ldGhvZCB0byBwYXVzZSBnYXVnZSBvbiBub3JtYWwgbG9nc1xuICAgIGNvbnN0IHdyaXRlID0gbG9nZ2VyLndyaXRlO1xuICAgIGxvZ2dlci53cml0ZSA9IGZ1bmN0aW9uKCkge1xuICAgICAgaWYgKHRoaXMuZ2F1Z2UpIHRoaXMuZ2F1Z2UuaGlkZSgpO1xuICAgICAgY29uc3QgcmVzdWx0ID0gd3JpdGUuYXBwbHkodGhpcywgYXJndW1lbnRzKTtcbiAgICAgIGlmICh0aGlzLmdhdWdlKSB0aGlzLmdhdWdlLnNob3coKTtcbiAgICAgIHJldHVybiByZXN1bHQ7XG4gICAgfTtcblxuICAgIGxvZ2dlci5vbihcInByZWZpeFwiLCAocHJpbnRmKSA9PiB7XG4gICAgICBPYmplY3Qua2V5cyhtZXRob2RzKS5mb3JFYWNoKGsgPT4ge1xuICAgICAgICBpZiAoayA9PT0gXCJwcm9ncmVzc1wiKSB7XG4gICAgICAgICAgcHJpbnRmW2tdID0gZnVuY3Rpb24oLi4uYXJncykge1xuICAgICAgICAgICAgcmV0dXJuIHByaW50Zi5sb2dnZXJba10ocHJpbnRmLnByZWZpeGVkLCAuLi5hcmdzKTtcbiAgICAgICAgICB9O1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIHByaW50ZltrXSA9IGZ1bmN0aW9uKCkge1xuICAgICAgICAgICAgcmV0dXJuIHByaW50Zi5sb2dnZXJba10uYXBwbHkocHJpbnRmLmxvZ2dlciwgYXJndW1lbnRzKTtcbiAgICAgICAgICB9O1xuICAgICAgICB9XG4gICAgICB9KTtcbiAgICB9KTtcblxuICAgIGlmIChvcHRpb25zLmVuYWJsZWQpIHtcbiAgICAgIGxvZ2dlci5lbmFibGVQcm9ncmVzcygpO1xuICAgIH1cbiAgfTtcbn1cbiJdfQ==
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9wcm9ncmVzcy5qcyJdLCJuYW1lcyI6WyJvcHRpb25zIiwibWV0aG9kcyIsImVuYWJsZVByb2dyZXNzIiwic3RyZWFtIiwiZGlzYWJsZVByb2dyZXNzIiwiRXJyb3IiLCJHYXVnZSIsIndhcm4iLCJnYXVnZSIsInVwZGF0ZUludGVydmFsIiwiZW5hYmxlZCIsImVuZFByb2dyZXNzIiwic3RhcnRQcm9ncmVzcyIsImVuYWJsZSIsImhpZGUiLCJwcm9ncmVzcyIsInByZWZpeCIsInNlY3Rpb24iLCJjb21wbGV0ZWQiLCJmb3JtYXQiLCJmaWx0ZXIiLCJCb29sZWFuIiwiam9pbiIsInNob3ciLCJwdWxzZSIsImFyZ3MiLCJtc2ciLCJkaXNhYmxlIiwibG9nZ2VyIiwiT2JqZWN0IiwiYXNzaWduIiwid3JpdGUiLCJyZXN1bHQiLCJhcHBseSIsImFyZ3VtZW50cyIsIm9uIiwicHJpbnRmIiwia2V5cyIsImZvckVhY2giLCJrIiwicHJlZml4ZWQiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7O0FBQUE7Ozs7Ozs7O0FBRWUsa0JBQVNBLE9BQVQsRUFBa0I7QUFDL0JBLEVBQUFBLE9BQU8sR0FBR0EsT0FBTyxJQUFJLEVBQXJCO0FBRUEsUUFBTUMsT0FBTyxHQUFHO0FBQ2RDLElBQUFBLGNBQWMsQ0FBQ0MsTUFBRCxFQUFTO0FBQ3JCLFdBQUtDLGVBQUw7QUFFQUQsTUFBQUEsTUFBTSxHQUFHQSxNQUFNLElBQUlILE9BQU8sQ0FBQ0csTUFBM0I7O0FBQ0EsVUFBSSxDQUFDQSxNQUFMLEVBQWE7QUFDWCxjQUFNLElBQUlFLEtBQUosQ0FBVyx1REFBWCxDQUFOO0FBQ0Q7O0FBRUQsVUFBSSxPQUFPQyxjQUFQLEtBQWlCLFVBQXJCLEVBQWlDO0FBQy9CLGFBQUtDLElBQUwsQ0FBVSxRQUFWLEVBQXFCLGlFQUFyQjtBQUNELE9BRkQsTUFFTztBQUNMLGFBQUtDLEtBQUwsR0FBYSxJQUFJRixjQUFKLENBQVVILE1BQVY7QUFDWE0sVUFBQUEsY0FBYyxFQUFFLE9BQU87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O0FBQ0YsT0FWRDtBQVdELEtBWkQ7O0FBY0EsUUFBSWxDLE9BQU8sQ0FBQ1UsT0FBWixFQUFxQjtBQUNuQmtCLE1BQUFBLE1BQU0sQ0FBQzFCLGNBQVA7QUFDRDtBQUNGLEdBN0JEO0FBOEJEIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IEdhdWdlIGZyb20gXCJnYXVnZVwiO1xuXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbihvcHRpb25zKSB7XG4gIG9wdGlvbnMgPSBvcHRpb25zIHx8IHt9O1xuXG4gIGNvbnN0IG1ldGhvZHMgPSB7XG4gICAgZW5hYmxlUHJvZ3Jlc3Moc3RyZWFtKSB7XG4gICAgICB0aGlzLmRpc2FibGVQcm9ncmVzcygpO1xuXG4gICAgICBzdHJlYW0gPSBzdHJlYW0gfHwgb3B0aW9ucy5zdHJlYW07XG4gICAgICBpZiAoIXN0cmVhbSkge1xuICAgICAgICB0aHJvdyBuZXcgRXJyb3IoYEV4cGVjdGluZyB3cml0ZWFibGUgc3RyZWFtIHRvIGF0dGFjaCBwcm9ncmVzcyBiYXIgdG9vYCk7XG4gICAgICB9XG5cbiAgICAgIGlmICh0eXBlb2YgR2F1Z2UgIT09IFwiZnVuY3Rpb25cIikge1xuICAgICAgICB0aGlzLndhcm4oXCJsb2dnZXJcIiwgYGF0dGVtcHRlZCB0byBhdHRhY2ggcHJvZ3Jlc3MgYmFyIGluIGFuIGluY29tcGF0aWJsZSBlbnZpcm9ubWVudGApO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgdGhpcy5nYXVnZSA9IG5ldyBHYXVnZShzdHJlYW0sIHtcbiAgICAgICAgICB1cGRhdGVJbnRlcnZhbDogMTAwMCAvIDEwLFxuICAgICAgICAgIC4uLm9wdGlvbnMuZ2F1Z2UsXG4gICAgICAgICAgZW5hYmxlZDogZmFsc2VcbiAgICAgICAgfSk7XG4gICAgICB9XG5cbiAgICAgIHJldHVybiB0aGlzO1xuICAgIH0sXG5cbiAgICBkaXNhYmxlUHJvZ3Jlc3MoKSB7XG4gICAgICB0aGlzLmVuZFByb2dyZXNzKCk7XG4gICAgICBkZWxldGUgdGhpcy5nYXVnZTtcbiAgICAgIHJldHVybiB0aGlzO1xuICAgIH0sXG5cbiAgICBzdGFydFByb2dyZXNzKCkge1xuICAgICAgaWYgKHRoaXMuZ2F1Z2UpIHtcbiAgICAgICAgdGhpcy5nYXVnZS5lbmFibGUoKTtcbiAgICAgICAgdGhpcy5nYXVnZS5oaWRlKCk7XG4gICAgICB9XG5cbiAgICAgIHJldHVybiB0aGlzO1xuICAgIH0sXG5cbiAgICBwcm9ncmVzcyhwcmVmaXgsIHNlY3Rpb24sIGNvbXBsZXRlZCkge1xuICAgICAgcHJlZml4ID0gdGhpcy5mb3JtYXQoXCJwcmVmaXhcIiwgcHJlZml4KTtcbiAgICAgIHNlY3Rpb24gPSBbcHJlZml4LHNlY3Rpb25dLmZpbHRlcihCb29sZWFuKS5qb2luKFwiIFwiKTtcbiAgICAgIGlmICh0aGlzLmdhdWdlKSB0aGlzLmdhdWdlLnNob3coc2VjdGlvbiwgY29tcGxldGVkKTtcbiAgICAgIHJldHVybiB0aGlzO1xuICAgIH0sXG5cbiAgICBwdWxzZSguLi5hcmdzKSB7XG4gICAgICBjb25zdCBtc2cgPSB0aGlzLmZvcm1hdChcImxvZ1wiLCAuLi5hcmdzKTtcbiAgICAgIGlmICh0aGlzLmdhdWdlKSB0aGlzLmdhdWdlLnB1bHNlKG1zZyk7XG4gICAgICByZXR1cm4gdGhpcztcbiAgICB9LFxuXG4gICAgZW5kUHJvZ3Jlc3MoKSB7XG4gICAgICBpZiAodGhpcy5nYXVnZSkgdGhpcy5nYXVnZS5kaXNhYmxlKCk7XG4gICAgICByZXR1cm4gdGhpcztcbiAgICB9XG4gIH07XG5cbiAgcmV0dXJuIGZ1bmN0aW9uKGxvZ2dlcikge1xuICAgIE9iamVjdC5hc3NpZ24obG9nZ2VyLCBtZXRob2RzKTtcblxuICAgIC8vIG1vZGlmeSB0aGUgd3JpdGUgbWV0aG9kIHRvIHBhdXNlIGdhdWdlIG9uIG5vcm1hbCBsb2dzXG4gICAgY29uc3Qgd3JpdGUgPSBsb2dnZXIud3JpdGU7XG4gICAgbG9nZ2VyLndyaXRlID0gZnVuY3Rpb24oKSB7XG4gICAgICBpZiAodGhpcy5nYXVnZSkgdGhpcy5nYXVnZS5oaWRlKCk7XG4gICAgICBjb25zdCByZXN1bHQgPSB3cml0ZS5hcHBseSh0aGlzLCBhcmd1bWVudHMpO1xuICAgICAgaWYgKHRoaXMuZ2F1Z2UpIHRoaXMuZ2F1Z2Uuc2hvdygpO1xuICAgICAgcmV0dXJuIHJlc3VsdDtcbiAgICB9O1xuXG4gICAgbG9nZ2VyLm9uKFwicHJlZml4XCIsIChwcmludGYpID0+IHtcbiAgICAgIE9iamVjdC5rZXlzKG1ldGhvZHMpLmZvckVhY2goayA9PiB7XG4gICAgICAgIGlmIChrID09PSBcInByb2dyZXNzXCIpIHtcbiAgICAgICAgICBwcmludGZba10gPSBmdW5jdGlvbiguLi5hcmdzKSB7XG4gICAgICAgICAgICByZXR1cm4gcHJpbnRmLmxvZ2dlcltrXShwcmludGYucHJlZml4ZWQsIC4uLmFyZ3MpO1xuICAgICAgICAgIH07XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgcHJpbnRmW2tdID0gZnVuY3Rpb24oKSB7XG4gICAgICAgICAgICByZXR1cm4gcHJpbnRmLmxvZ2dlcltrXS5hcHBseShwcmludGYubG9nZ2VyLCBhcmd1bWVudHMpO1xuICAgICAgICAgIH07XG4gICAgICAgIH1cbiAgICAgIH0pO1xuICAgIH0pO1xuXG4gICAgaWYgKG9wdGlvbnMuZW5hYmxlZCkge1xuICAgICAgbG9nZ2VyLmVuYWJsZVByb2dyZXNzKCk7XG4gICAgfVxuICB9O1xufVxuIl19
{
"name": "@pagedip/util-logger",
"version": "2.2.3",
"version": "2.2.4",
"repository": {

@@ -20,3 +20,3 @@ "type": "git",

"dependencies": {
"@pagedip/util-prop-helpers": "^1.2.5",
"@pagedip/util-prop-helpers": "^1.2.6",
"chalk": "^2.4.2",

@@ -28,3 +28,3 @@ "gauge": "^2.7.4",

"devDependencies": {
"@babel/cli": "^7.2.3",
"@babel/cli": "^7.4.3",
"npm-run-all": "^4.1.5",

@@ -38,3 +38,3 @@ "shx": "^0.3.2",

],
"gitHead": "b598d7371ad921fcb10ee26200222d1e24b3a83a"
"gitHead": "aa11326ab94d776dfbe019641955b4dc77e29e98"
}
SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc