lognext
The logger nobody asked for
Installation
npm install lognext
Usage
Getting Started
Require the module and instantiate an instance. The topic name is used when tracing messages to help identify their source.
const Lognext = require('lognext');
const log = new Lognext('topic-name');
Learn by example!
Standard stuff
log.writeBox('Standard trace messages');
log.error('This is an error');
log.warn('You have been warned');
log.info('This is informational');
log.verbose('This message is really a lot more information than you probably wanted');
log.debug('This message is for debugging');
log.silly('Tee hee hee!');
data:image/s3,"s3://crabby-images/b7330/b7330ce3ee437db4f8629be3ccfc13055bcadee4" alt="img"
Objects can be traced out too!
log.writeBox('Tracing with objects');
log.error(new Error('This is an error'));
let data = { prop1: 'val1', prop2: ['a', 'b', 'c']};
log.info('Data: ', data);
log.debug('Data: ', data);
data:image/s3,"s3://crabby-images/6fd48/6fd4830a06c777efc0d3f8a19ba4816189183e63" alt="img"
Color can be turned off for output windows that don't support ANSI colors.
log.setUseColor(false);
log.error('This is an error');
log.warn('You have been warned');
log.info('This is informational');
log.verbose('This message is really a lot more information than you probably wanted');
log.debug('This message is for debugging');
log.silly('Tee hee hee!');
data:image/s3,"s3://crabby-images/f7c17/f7c179af4e6de776ba886f9b87c7de6ffd1d4c8f" alt="img"
Trace levels can be controlled to disable traces above the set level.
log.writeBox('Log Level Examples');
['error', 'warn', 'info', 'verbose', 'debug', 'silly'].forEach((level) => {
console.log(`+++ Log level => ${level}`);
log.setLogLevel(level);
log.error('This is an error');
log.warn('You have been warned');
log.info('This is informational');
log.verbose('This message is really a lot more information than you probably wanted');
log.debug('This message is for debugging');
log.silly('Tee hee hee!');
});
data:image/s3,"s3://crabby-images/32bc4/32bc4f8cf0a241e9c38ef3bffe419e0dd209c547" alt="img"
Profile a string to measure time!
log.profile('foo');
log.writeBox('Let\'s profile!');
setTimeout(()=>{log.profile('foo');}, 100);
data:image/s3,"s3://crabby-images/4543c/4543c9b8c0f1fb8490f4e314b45de25747abf9fd" alt="img"