Skip to content
Permalink
ffd96b38fb
Switch branches/tags

Name already in use

A tag already exists with the provided branch name. Many Git commands accept both tag and branch names, so creating this branch may cause unexpected behavior. Are you sure you want to create this branch?
Go to file
0 contributors

Users who have contributed to this file

46 lines (35 sloc) 1.07 KB
'use strict'
var util = require('util')
var levels = ['trace', 'debug', 'info', 'warn', 'error', 'fatal']
var noop = function () {}
module.exports = function (opts) {
opts = opts || {}
opts.level = opts.level || 'info'
var logger = {}
var shouldLog = function (level) {
return levels.indexOf(level) >= levels.indexOf(opts.level)
}
levels.forEach(function (level) {
logger[level] = shouldLog(level) ? log : noop
function log () {
var prefix = opts.prefix
var normalizedLevel
if (opts.stderr) {
normalizedLevel = 'error'
} else {
switch (level) {
case 'trace': normalizedLevel = 'info'; break
case 'debug': normalizedLevel = 'info'; break
case 'fatal': normalizedLevel = 'error'; break
default: normalizedLevel = level
}
}
if (prefix) {
if (typeof prefix === 'function') prefix = prefix(level)
arguments[0] = util.format(prefix, arguments[0])
}
console[normalizedLevel](util.format.apply(util, arguments))
}
})
return logger
}