node/deps/npm/lib/utils/setup-log.js
Myles Borins 2e54524955
deps: update npm to 7.0.0-rc.3
PR-URL: https://github.com/nodejs/node/pull/35474
Reviewed-By: Ruy Adorno <ruyadorno@github.com>
Reviewed-By: Ujjwal Sharma <ryzokuken@disroot.org>
Reviewed-By: Ben Coe <bencoe@gmail.com>
Reviewed-By: Geoffrey Booth <webmaster@geoffreybooth.com>
Reviewed-By: Rich Trott <rtrott@gmail.com>
Reviewed-By: Shelley Vohr <codebytere@gmail.com>
Reviewed-By: Guy Bedford <guybedford@gmail.com>
Reviewed-By: Matteo Collina <matteo.collina@gmail.com>
2020-10-07 09:59:49 -04:00

68 lines
1.8 KiB
JavaScript

// module to set the appropriate log settings based on configs
// returns a boolean to say whether we should enable color on
// stdout or not.
//
// Also (and this is a really inexcusable kludge), we patch the
// log.warn() method so that when we see a peerDep override
// explanation from Arborist, we can replace the object with a
// highly abbreviated explanation of what's being overridden.
const log = require('npmlog')
const { explain } = require('./explain-eresolve.js')
module.exports = (config) => {
const color = config.get('color')
const { warn } = log
log.warn = (heading, ...args) => {
if (heading === 'ERESOLVE' && args[1] && typeof args[1] === 'object') {
warn(heading, args[0])
return warn('', explain(args[1]))
}
return warn(heading, ...args)
}
if (config.get('timing') && config.get('loglevel') === 'notice') {
log.level = 'timing'
} else {
log.level = config.get('loglevel')
}
log.heading = config.get('heading') || 'npm'
const stdoutTTY = process.stdout.isTTY
const stderrTTY = process.stderr.isTTY
const dumbTerm = process.env.TERM === 'dumb'
const stderrNotDumb = stderrTTY && !dumbTerm
const enableColorStderr = color === 'always' ? true
: color === false ? false
: stderrTTY
const enableColorStdout = color === 'always' ? true
: color === false ? false
: stdoutTTY
if (enableColorStderr) {
log.enableColor()
} else {
log.disableColor()
}
if (config.get('unicode')) {
log.enableUnicode()
} else {
log.disableUnicode()
}
// if it's more than error, don't show progress
const quiet = log.levels[log.level] > log.levels.error
if (config.get('progress') && stderrNotDumb && !quiet) {
log.enableProgress()
} else {
log.disableProgress()
}
return enableColorStdout
}