Decoupled logging for libraries
npm install shared-log



> Decoupled logging for libraries
Libraries should import shared-log and treat it as write-only.
"Reading" the log (via event listener) is reserved for the end user.
``ts
import log from 'shared-log'
// The log function is console.log by default
log('all arguments', 'are passed thru')
// Log methods exist for each log level
log.error(new Error('ruh roh'))
log.warn(...)
log.info(...)
log.verbose(...)
log.debug(...)
`
The end user hooks up their logging library of choice.
`ts
import log from 'shared-log'
// Listen to every log level
log.on('all', (level, args, filename) => {...})
// or a specific log level
log.on('error', (args, filename) => {...})
`
If the end user doesn't add a log listener, the console is used by default, but the debug and verbose` log levels are ignored by default.