$ cnpm install logger-clearable
A logger that is clearable
'use strict'
// create our clearable logger
const logger = require('logger-clearable').create()
const method = 'log'
// log the date every second
const timer = setInterval(function () {
if (method === 'log') {
const date = new Date()
const time = date.toISOString()
logger.log(time)
} else {
// the above will actually call: logger.queue(() => time)
// instead, we can use queue directly:
// using queue direclty is more performant as
// any setup for our particular message will happen only if that message will be written
// this is applicable as logger won't bother writing messages that would be cleared instantly
// e.g. logger.log('hello').log('world') would otherwise write 'hello' then have to clear it right away
// instead, logger just skips writing 'hello' and will just write 'world'
logger.queue(function () {
const date = new Date()
const time = date.toISOString()
return time
})
}
}, 100)
// on ctrl+c close the timer and discard any upcoming logs
process.on('SIGINT', () => {
// stop any more calls to logger
clearInterval(timer)
// discard any logger queued updated
logger.discard()
// and clear the log
logger.clear()
})
npm install --save logger-clearableimport * as pkg from ('logger-clearable')const pkg = require('logger-clearable')This package is published with the following editions:
logger-clearable aliases logger-clearable/index.cjs which uses the Editions Autoloader to automatically select the correct edition for the consumer's environmentlogger-clearable/source/index.js is ESNext source code for Node.js 6 || 8 || 10 || 12 || 14 || 16 || 18 || 20 || 21 with Require for moduleslogger-clearable/edition-node-4/index.js is ESNext compiled for Node.js 4 || 6 || 8 || 10 || 12 || 14 || 16 || 18 || 20 || 21 with Require for modulesThis project provides its type information via inline JSDoc Comments. To make use of this in TypeScript, set your maxNodeModuleJsDepth compiler option to 5 or thereabouts. You can accomplish this via your tsconfig.json file like so:
{
"compilerOptions": {
"maxNodeModuleJsDepth": 5
}
}
Discover the release history by heading on over to the HISTORY.md file.
Discover how to contribute via the CONTRIBUTING.md file.
Unless stated otherwise all works are:
and licensed under:
Copyright 2013 - present © cnpmjs.org | Home |