From 6907a72f0bd0900e13b61a91a07c295253410420 Mon Sep 17 00:00:00 2001 From: Phil Kunz Date: Thu, 16 Jun 2016 23:57:49 +0200 Subject: [PATCH] add .logReduced, closes #2 --- dist/beautylog.log.d.ts | 9 +++++++++ dist/beautylog.log.js | 23 ++++++++++++++++++++++- dist/index.d.ts | 2 +- dist/index.js | 3 ++- test/test.js | 12 +++++++++++- test/test.ts | 10 ++++++++++ ts/beautylog.log.ts | 22 +++++++++++++++++++++- ts/index.ts | 2 +- 8 files changed, 77 insertions(+), 6 deletions(-) diff --git a/dist/beautylog.log.d.ts b/dist/beautylog.log.d.ts index bce406b..e24d543 100644 --- a/dist/beautylog.log.d.ts +++ b/dist/beautylog.log.d.ts @@ -36,4 +36,13 @@ export declare let error: (logText: any) => void; * @returns {boolean} */ export declare let dir: (logText: any) => void; +/** + * creates a new empty line + * @param linesArg + * @returns void + */ export declare let newLine: (linesArg?: number) => void; +/** + * logs a reduced log that only logs changes of consequential log messages + */ +export declare let logReduced: (logTextArg: string, repeatEveryTimesArg?: number) => void; diff --git a/dist/beautylog.log.js b/dist/beautylog.log.js index e1739a2..7987fc7 100644 --- a/dist/beautylog.log.js +++ b/dist/beautylog.log.js @@ -51,11 +51,32 @@ exports.error = function (logText) { exports.dir = function (logText) { return beautylog_log_helpers_1.log(logText, 'dir'); }; +/** + * creates a new empty line + * @param linesArg + * @returns void + */ exports.newLine = function (linesArg) { if (linesArg === void 0) { linesArg = 1; } for (var i = 0; i < linesArg; i++) { console.log("\n"); } }; +/** + * logs a reduced log that only logs changes of consequential log messages + */ +exports.logReduced = function (logTextArg, repeatEveryTimesArg) { + if (repeatEveryTimesArg === void 0) { repeatEveryTimesArg = 0; } + if (logTextArg == previousMessage && (repeatEveryTimesArg == 0 || sameMessageCounter != repeatEveryTimesArg)) { + sameMessageCounter++; + } + else { + sameMessageCounter = 0; + previousMessage = logTextArg; + beautylog_log_helpers_1.log(logTextArg); + } +}; +var previousMessage = ""; +var sameMessageCounter = 0; -//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImJlYXV0eWxvZy5sb2cudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLFFBQU8sZ0JBQWdCLENBQUMsQ0FBQTtBQUV4QixzQ0FBa0IseUJBQXlCLENBQUMsQ0FBQTtBQUM1QyxzQ0FBa0IseUJBQXlCLENBQUM7QUFBcEMsMENBQW9DO0FBRTVDOzs7O0dBSUc7QUFDUSxZQUFJLEdBQUcsVUFBQyxPQUFPO0lBQ3RCLE1BQU0sQ0FBQywyQkFBRyxDQUFDLE9BQU8sRUFBRSxNQUFNLENBQUMsQ0FBQztBQUNoQyxDQUFDLENBQUM7QUFFRjs7OztHQUlHO0FBQ1EsVUFBRSxHQUFHLFVBQUMsT0FBTztJQUNwQixNQUFNLENBQUMsMkJBQUcsQ0FBQyxPQUFPLEVBQUUsSUFBSSxDQUFDLENBQUM7QUFDOUIsQ0FBQyxDQUFDO0FBRUY7Ozs7R0FJRztBQUNRLGVBQU8sR0FBRyxVQUFDLE9BQU87SUFDekIsTUFBTSxDQUFDLDJCQUFHLENBQUMsT0FBTyxFQUFFLFNBQVMsQ0FBQyxDQUFDO0FBQ25DLENBQUMsQ0FBQztBQUVGOzs7O0dBSUc7QUFDUSxZQUFJLEdBQUcsVUFBQyxPQUFPO0lBQ3RCLE1BQU0sQ0FBQywyQkFBRyxDQUFDLE9BQU8sRUFBRSxNQUFNLENBQUMsQ0FBQztBQUNoQyxDQUFDLENBQUM7QUFFRjs7OztHQUlHO0FBQ1EsYUFBSyxHQUFHLFVBQUMsT0FBTztJQUN2QixNQUFNLENBQUMsMkJBQUcsQ0FBQyxPQUFPLEVBQUUsT0FBTyxDQUFDLENBQUM7QUFDakMsQ0FBQyxDQUFDO0FBRUY7Ozs7R0FJRztBQUNRLFdBQUcsR0FBRyxVQUFDLE9BQU87SUFDckIsTUFBTSxDQUFDLDJCQUFHLENBQUMsT0FBTyxFQUFFLEtBQUssQ0FBQyxDQUFDO0FBQy9CLENBQUMsQ0FBQztBQUVTLGVBQU8sR0FBRyxVQUFDLFFBQW1CO0lBQW5CLHdCQUFtQixHQUFuQixZQUFtQjtJQUNyQyxHQUFHLENBQUEsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxHQUFHLFFBQVEsRUFBQyxDQUFDLEVBQUUsRUFBQyxDQUFDO1FBQzdCLE9BQU8sQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDdEIsQ0FBQztBQUNMLENBQUMsQ0FBQSIsImZpbGUiOiJiZWF1dHlsb2cubG9nLmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFwidHlwaW5ncy1nbG9iYWxcIjtcblxuaW1wb3J0IHtsb2d9IGZyb20gXCIuL2JlYXV0eWxvZy5sb2cuaGVscGVyc1wiO1xuZXhwb3J0IHtsb2d9IGZyb20gXCIuL2JlYXV0eWxvZy5sb2cuaGVscGVyc1wiO1xuXG4vKipcbiAqIGxvZ3MgYW4gaW5mbyB0byBjb25zb2xlXG4gKiBAcGFyYW0gbG9nVGV4dFxuICogQHJldHVybnMge2Jvb2xlYW59XG4gKi9cbmV4cG9ydCBsZXQgaW5mbyA9IChsb2dUZXh0KSA9PiB7XG4gICAgcmV0dXJuIGxvZyhsb2dUZXh0LCAnaW5mbycpO1xufTtcblxuLyoqXG4gKiBsb2dzIGFuICdPSyEnIG1lc3NhZ2UgdG8gY29uc29sZVxuICogQHBhcmFtIGxvZ1RleHRcbiAqIEByZXR1cm5zIHtib29sZWFufVxuICovXG5leHBvcnQgbGV0IG9rID0gKGxvZ1RleHQpID0+IHtcbiAgICByZXR1cm4gbG9nKGxvZ1RleHQsICdvaycpO1xufTtcblxuLyoqXG4gKiBsb2dzIGEgc3VjY2VzcyB0byBjb25zb2xlXG4gKiBAcGFyYW0gbG9nVGV4dCBzdHJpbmcgdG8gbG9nIGFzIGVycm9yXG4gKiBAcmV0dXJucyB7Ym9vbGVhbn1cbiAqL1xuZXhwb3J0IGxldCBzdWNjZXNzID0gKGxvZ1RleHQpID0+IHtcbiAgICByZXR1cm4gbG9nKGxvZ1RleHQsICdzdWNjZXNzJyk7XG59O1xuXG4vKipcbiAqIGxvZ3MgYSAnd2FybjonIG1lc3NhZ2UgdG8gY29uc29sZVxuICogQHBhcmFtIGxvZ1RleHQgc3RyaW5nIHRvIGxvZyBhcyBlcnJvclxuICogQHJldHVybnMge2Jvb2xlYW59XG4gKi9cbmV4cG9ydCBsZXQgd2FybiA9IChsb2dUZXh0KSA9PiB7XG4gICAgcmV0dXJuIGxvZyhsb2dUZXh0LCAnd2FybicpO1xufTtcblxuLyoqXG4gKiBsb2dzIGFuIGVycm9yIHRvIGNvbnNvbGVcbiAqIEBwYXJhbSBsb2dUZXh0XG4gKiBAcmV0dXJucyB7Ym9vbGVhbn1cbiAqL1xuZXhwb3J0IGxldCBlcnJvciA9IChsb2dUZXh0KSA9PiB7XG4gICAgcmV0dXJuIGxvZyhsb2dUZXh0LCAnZXJyb3InKTtcbn07XG5cbi8qKlxuICogbG9ncyBhbiBkaXJlY3RvcnkgdG8gY29uc29sZVxuICogQHBhcmFtIGxvZ1RleHRcbiAqIEByZXR1cm5zIHtib29sZWFufVxuICovXG5leHBvcnQgbGV0IGRpciA9IChsb2dUZXh0KSA9PiB7XG4gICAgcmV0dXJuIGxvZyhsb2dUZXh0LCAnZGlyJyk7XG59O1xuXG5leHBvcnQgbGV0IG5ld0xpbmUgPSAobGluZXNBcmc6bnVtYmVyID0gMSkgPT4ge1xuICAgIGZvcihsZXQgaSA9IDA7IGkgPCBsaW5lc0FyZztpKyspe1xuICAgICAgICBjb25zb2xlLmxvZyhcIlxcblwiKTtcbiAgICB9XG59Il19 +//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImJlYXV0eWxvZy5sb2cudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLFFBQU8sZ0JBQWdCLENBQUMsQ0FBQTtBQUV4QixzQ0FBa0IseUJBQXlCLENBQUMsQ0FBQTtBQUM1QyxzQ0FBa0IseUJBQXlCLENBQUM7QUFBcEMsMENBQW9DO0FBRTVDOzs7O0dBSUc7QUFDUSxZQUFJLEdBQUcsVUFBQyxPQUFPO0lBQ3RCLE1BQU0sQ0FBQywyQkFBRyxDQUFDLE9BQU8sRUFBRSxNQUFNLENBQUMsQ0FBQztBQUNoQyxDQUFDLENBQUM7QUFFRjs7OztHQUlHO0FBQ1EsVUFBRSxHQUFHLFVBQUMsT0FBTztJQUNwQixNQUFNLENBQUMsMkJBQUcsQ0FBQyxPQUFPLEVBQUUsSUFBSSxDQUFDLENBQUM7QUFDOUIsQ0FBQyxDQUFDO0FBRUY7Ozs7R0FJRztBQUNRLGVBQU8sR0FBRyxVQUFDLE9BQU87SUFDekIsTUFBTSxDQUFDLDJCQUFHLENBQUMsT0FBTyxFQUFFLFNBQVMsQ0FBQyxDQUFDO0FBQ25DLENBQUMsQ0FBQztBQUVGOzs7O0dBSUc7QUFDUSxZQUFJLEdBQUcsVUFBQyxPQUFPO0lBQ3RCLE1BQU0sQ0FBQywyQkFBRyxDQUFDLE9BQU8sRUFBRSxNQUFNLENBQUMsQ0FBQztBQUNoQyxDQUFDLENBQUM7QUFFRjs7OztHQUlHO0FBQ1EsYUFBSyxHQUFHLFVBQUMsT0FBTztJQUN2QixNQUFNLENBQUMsMkJBQUcsQ0FBQyxPQUFPLEVBQUUsT0FBTyxDQUFDLENBQUM7QUFDakMsQ0FBQyxDQUFDO0FBRUY7Ozs7R0FJRztBQUNRLFdBQUcsR0FBRyxVQUFDLE9BQU87SUFDckIsTUFBTSxDQUFDLDJCQUFHLENBQUMsT0FBTyxFQUFFLEtBQUssQ0FBQyxDQUFDO0FBQy9CLENBQUMsQ0FBQztBQUVGOzs7O0dBSUc7QUFDUSxlQUFPLEdBQUcsVUFBQyxRQUFtQjtJQUFuQix3QkFBbUIsR0FBbkIsWUFBbUI7SUFDckMsR0FBRyxDQUFBLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsR0FBRyxRQUFRLEVBQUMsQ0FBQyxFQUFFLEVBQUMsQ0FBQztRQUM3QixPQUFPLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ3RCLENBQUM7QUFDTCxDQUFDLENBQUE7QUFFRDs7R0FFRztBQUNRLGtCQUFVLEdBQUcsVUFBQyxVQUFpQixFQUFDLG1CQUE4QjtJQUE5QixtQ0FBOEIsR0FBOUIsdUJBQThCO0lBQ3JFLEVBQUUsQ0FBQSxDQUFDLFVBQVUsSUFBSSxlQUFlLElBQUksQ0FBQyxtQkFBbUIsSUFBSSxDQUFDLElBQUksa0JBQWtCLElBQUksbUJBQW1CLENBQUMsQ0FBQyxDQUFBLENBQUM7UUFDekcsa0JBQWtCLEVBQUUsQ0FBQztJQUN6QixDQUFDO0lBQUMsSUFBSSxDQUFDLENBQUM7UUFDSixrQkFBa0IsR0FBRyxDQUFDLENBQUM7UUFDdkIsZUFBZSxHQUFHLFVBQVUsQ0FBQztRQUM3QiwyQkFBRyxDQUFDLFVBQVUsQ0FBQyxDQUFDO0lBQ3BCLENBQUM7QUFDTCxDQUFDLENBQUM7QUFDRixJQUFJLGVBQWUsR0FBVSxFQUFFLENBQUM7QUFDaEMsSUFBSSxrQkFBa0IsR0FBVSxDQUFDLENBQUMiLCJmaWxlIjoiYmVhdXR5bG9nLmxvZy5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBcInR5cGluZ3MtZ2xvYmFsXCI7XG5cbmltcG9ydCB7bG9nfSBmcm9tIFwiLi9iZWF1dHlsb2cubG9nLmhlbHBlcnNcIjtcbmV4cG9ydCB7bG9nfSBmcm9tIFwiLi9iZWF1dHlsb2cubG9nLmhlbHBlcnNcIjtcblxuLyoqXG4gKiBsb2dzIGFuIGluZm8gdG8gY29uc29sZVxuICogQHBhcmFtIGxvZ1RleHRcbiAqIEByZXR1cm5zIHtib29sZWFufVxuICovXG5leHBvcnQgbGV0IGluZm8gPSAobG9nVGV4dCkgPT4ge1xuICAgIHJldHVybiBsb2cobG9nVGV4dCwgJ2luZm8nKTtcbn07XG5cbi8qKlxuICogbG9ncyBhbiAnT0shJyBtZXNzYWdlIHRvIGNvbnNvbGVcbiAqIEBwYXJhbSBsb2dUZXh0XG4gKiBAcmV0dXJucyB7Ym9vbGVhbn1cbiAqL1xuZXhwb3J0IGxldCBvayA9IChsb2dUZXh0KSA9PiB7XG4gICAgcmV0dXJuIGxvZyhsb2dUZXh0LCAnb2snKTtcbn07XG5cbi8qKlxuICogbG9ncyBhIHN1Y2Nlc3MgdG8gY29uc29sZVxuICogQHBhcmFtIGxvZ1RleHQgc3RyaW5nIHRvIGxvZyBhcyBlcnJvclxuICogQHJldHVybnMge2Jvb2xlYW59XG4gKi9cbmV4cG9ydCBsZXQgc3VjY2VzcyA9IChsb2dUZXh0KSA9PiB7XG4gICAgcmV0dXJuIGxvZyhsb2dUZXh0LCAnc3VjY2VzcycpO1xufTtcblxuLyoqXG4gKiBsb2dzIGEgJ3dhcm46JyBtZXNzYWdlIHRvIGNvbnNvbGVcbiAqIEBwYXJhbSBsb2dUZXh0IHN0cmluZyB0byBsb2cgYXMgZXJyb3JcbiAqIEByZXR1cm5zIHtib29sZWFufVxuICovXG5leHBvcnQgbGV0IHdhcm4gPSAobG9nVGV4dCkgPT4ge1xuICAgIHJldHVybiBsb2cobG9nVGV4dCwgJ3dhcm4nKTtcbn07XG5cbi8qKlxuICogbG9ncyBhbiBlcnJvciB0byBjb25zb2xlXG4gKiBAcGFyYW0gbG9nVGV4dFxuICogQHJldHVybnMge2Jvb2xlYW59XG4gKi9cbmV4cG9ydCBsZXQgZXJyb3IgPSAobG9nVGV4dCkgPT4ge1xuICAgIHJldHVybiBsb2cobG9nVGV4dCwgJ2Vycm9yJyk7XG59O1xuXG4vKipcbiAqIGxvZ3MgYW4gZGlyZWN0b3J5IHRvIGNvbnNvbGVcbiAqIEBwYXJhbSBsb2dUZXh0XG4gKiBAcmV0dXJucyB7Ym9vbGVhbn1cbiAqL1xuZXhwb3J0IGxldCBkaXIgPSAobG9nVGV4dCkgPT4ge1xuICAgIHJldHVybiBsb2cobG9nVGV4dCwgJ2RpcicpO1xufTtcblxuLyoqXG4gKiBjcmVhdGVzIGEgbmV3IGVtcHR5IGxpbmVcbiAqIEBwYXJhbSBsaW5lc0FyZ1xuICogQHJldHVybnMgdm9pZFxuICovXG5leHBvcnQgbGV0IG5ld0xpbmUgPSAobGluZXNBcmc6bnVtYmVyID0gMSkgPT4ge1xuICAgIGZvcihsZXQgaSA9IDA7IGkgPCBsaW5lc0FyZztpKyspe1xuICAgICAgICBjb25zb2xlLmxvZyhcIlxcblwiKTtcbiAgICB9XG59XG5cbi8qKlxuICogbG9ncyBhIHJlZHVjZWQgbG9nIHRoYXQgb25seSBsb2dzIGNoYW5nZXMgb2YgY29uc2VxdWVudGlhbCBsb2cgbWVzc2FnZXNcbiAqL1xuZXhwb3J0IGxldCBsb2dSZWR1Y2VkID0gKGxvZ1RleHRBcmc6c3RyaW5nLHJlcGVhdEV2ZXJ5VGltZXNBcmc6bnVtYmVyID0gMCkgPT4ge1xuICAgIGlmKGxvZ1RleHRBcmcgPT0gcHJldmlvdXNNZXNzYWdlICYmIChyZXBlYXRFdmVyeVRpbWVzQXJnID09IDAgfHwgc2FtZU1lc3NhZ2VDb3VudGVyICE9IHJlcGVhdEV2ZXJ5VGltZXNBcmcpKXtcbiAgICAgICAgc2FtZU1lc3NhZ2VDb3VudGVyKys7XG4gICAgfSBlbHNlIHtcbiAgICAgICAgc2FtZU1lc3NhZ2VDb3VudGVyID0gMDtcbiAgICAgICAgcHJldmlvdXNNZXNzYWdlID0gbG9nVGV4dEFyZztcbiAgICAgICAgbG9nKGxvZ1RleHRBcmcpO1xuICAgIH1cbn07XG5sZXQgcHJldmlvdXNNZXNzYWdlOnN0cmluZyA9IFwiXCI7XG5sZXQgc2FtZU1lc3NhZ2VDb3VudGVyOm51bWJlciA9IDA7Il19 diff --git a/dist/index.d.ts b/dist/index.d.ts index 479deb8..1362883 100644 --- a/dist/index.d.ts +++ b/dist/index.d.ts @@ -1,5 +1,5 @@ import "typings-global"; export { Table } from "./beautylog.classes.table"; export { Ora } from "./beautylog.classes.ora"; -export { dir, error, info, log, ok, success, warn, newLine } from "./beautylog.log"; +export { dir, error, info, log, logReduced, ok, success, warn, newLine } from "./beautylog.log"; export { figlet, figletSync } from "./beautylog.figlet"; diff --git a/dist/index.js b/dist/index.js index 36883d5..bf767a6 100644 --- a/dist/index.js +++ b/dist/index.js @@ -11,6 +11,7 @@ exports.dir = beautylog_log_1.dir; exports.error = beautylog_log_1.error; exports.info = beautylog_log_1.info; exports.log = beautylog_log_1.log; +exports.logReduced = beautylog_log_1.logReduced; exports.ok = beautylog_log_1.ok; exports.success = beautylog_log_1.success; exports.warn = beautylog_log_1.warn; @@ -19,4 +20,4 @@ var beautylog_figlet_1 = require("./beautylog.figlet"); exports.figlet = beautylog_figlet_1.figlet; exports.figletSync = beautylog_figlet_1.figletSync; -//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxRQUFPLGdCQUFnQixDQUFDLENBQUE7QUFLeEIsaUJBQWlCO0FBQ2pCLHdDQUFvQiwyQkFBMkIsQ0FBQztBQUF4QyxnREFBd0M7QUFDaEQsc0NBQWtCLHlCQUF5QixDQUFDO0FBQXBDLDBDQUFvQztBQUU1QyxpQkFBaUI7QUFDakIsOEJBQXlELGlCQUFpQixDQUFDO0FBQW5FLGtDQUFHO0FBQUMsc0NBQUs7QUFBQyxvQ0FBSTtBQUFDLGtDQUFHO0FBQUMsZ0NBQUU7QUFBQywwQ0FBTztBQUFDLG9DQUFJO0FBQUMsMENBQWdDO0FBQzNFLGlDQUFnQyxvQkFBb0IsQ0FBQztBQUE3QywyQ0FBTTtBQUFDLG1EQUFxQyIsImZpbGUiOiJpbmRleC5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBcInR5cGluZ3MtZ2xvYmFsXCI7XG5cbmltcG9ydCAqIGFzIHBsdWdpbnMgZnJvbSBcIi4vYmVhdXR5bG9nLnBsdWdpbnNcIjtcbmltcG9ydCAqIGFzIEJlYXV0eWxvZ0NvbnNvbGUgZnJvbSBcIi4vYmVhdXR5bG9nLmNvbnNvbGVcIjtcblxuLy8gZXhwb3J0IGNsYXNzZXNcbmV4cG9ydCB7VGFibGV9IGZyb20gXCIuL2JlYXV0eWxvZy5jbGFzc2VzLnRhYmxlXCI7XG5leHBvcnQge09yYX0gZnJvbSBcIi4vYmVhdXR5bG9nLmNsYXNzZXMub3JhXCI7XG5cbi8vIGV4cG9ydCBtZXRob2RzXG5leHBvcnQge2RpcixlcnJvcixpbmZvLGxvZyxvayxzdWNjZXNzLHdhcm4sbmV3TGluZX0gZnJvbSBcIi4vYmVhdXR5bG9nLmxvZ1wiO1xuZXhwb3J0IHtmaWdsZXQsZmlnbGV0U3luY30gZnJvbSBcIi4vYmVhdXR5bG9nLmZpZ2xldFwiIl19 +//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxRQUFPLGdCQUFnQixDQUFDLENBQUE7QUFLeEIsaUJBQWlCO0FBQ2pCLHdDQUFvQiwyQkFBMkIsQ0FBQztBQUF4QyxnREFBd0M7QUFDaEQsc0NBQWtCLHlCQUF5QixDQUFDO0FBQXBDLDBDQUFvQztBQUU1QyxpQkFBaUI7QUFDakIsOEJBQW9FLGlCQUFpQixDQUFDO0FBQTlFLGtDQUFHO0FBQUMsc0NBQUs7QUFBQyxvQ0FBSTtBQUFDLGtDQUFHO0FBQUMsZ0RBQVU7QUFBQyxnQ0FBRTtBQUFDLDBDQUFPO0FBQUMsb0NBQUk7QUFBQywwQ0FBZ0M7QUFDdEYsaUNBQWdDLG9CQUFvQixDQUFDO0FBQTdDLDJDQUFNO0FBQUMsbURBQXFDIiwiZmlsZSI6ImluZGV4LmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFwidHlwaW5ncy1nbG9iYWxcIjtcblxuaW1wb3J0ICogYXMgcGx1Z2lucyBmcm9tIFwiLi9iZWF1dHlsb2cucGx1Z2luc1wiO1xuaW1wb3J0ICogYXMgQmVhdXR5bG9nQ29uc29sZSBmcm9tIFwiLi9iZWF1dHlsb2cuY29uc29sZVwiO1xuXG4vLyBleHBvcnQgY2xhc3Nlc1xuZXhwb3J0IHtUYWJsZX0gZnJvbSBcIi4vYmVhdXR5bG9nLmNsYXNzZXMudGFibGVcIjtcbmV4cG9ydCB7T3JhfSBmcm9tIFwiLi9iZWF1dHlsb2cuY2xhc3Nlcy5vcmFcIjtcblxuLy8gZXhwb3J0IG1ldGhvZHNcbmV4cG9ydCB7ZGlyLGVycm9yLGluZm8sbG9nLGxvZ1JlZHVjZWQsb2ssc3VjY2Vzcyx3YXJuLG5ld0xpbmV9IGZyb20gXCIuL2JlYXV0eWxvZy5sb2dcIjtcbmV4cG9ydCB7ZmlnbGV0LGZpZ2xldFN5bmN9IGZyb20gXCIuL2JlYXV0eWxvZy5maWdsZXRcIiJdfQ== diff --git a/test/test.js b/test/test.js index f259aed..341d3e4 100644 --- a/test/test.js +++ b/test/test.js @@ -41,6 +41,16 @@ describe("beautylog", function () { beautylog.info('beautylog.dir(), with normal logText, without logType'); }); }); + describe(".logReduced(message)", function () { + it("should only log two messages", function () { + beautylog.logReduced("Message 1"); + beautylog.logReduced("Message 1"); + beautylog.logReduced("Message 1"); + beautylog.logReduced("Message 1"); + beautylog.logReduced("Message 2"); + beautylog.logReduced("Message 2"); + }); + }); describe(".ok(message)", function () { it("should display a green ok message", function () { beautylog.ok('beautylog.ok(), with normal logText, without logType'); @@ -100,4 +110,4 @@ describe("beautylog", function () { }); }); -//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["test.ts"],"names":[],"mappings":"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","file":"test.js","sourcesContent":["import \"typings-test\";\nimport beautylog = require('../dist/index');\n\ndescribe(\"beautylog\",function(){\n    describe(\".log(message,logtype)\",function(){\n        it(\"should log cyan text\",function(){\n            beautylog.log('beautylog.log(), with normal logText, without logType');\n        });\n        it(\"should print different log types dependent on logType\",function(){\n            beautylog.log('beautylog.log(), with normal logText, without logType');\n            beautylog.log('beautylog.log(), with normal logText, with logType \"dir\"','dir');\n            beautylog.log('beautylog.log(), with normal logText, with logType \"error\"','error');\n            beautylog.log('beautylog.log(), with normal logText, with logType \"info\"','info');\n            beautylog.log('beautylog.log(), with normal logText, with logType \"ok\"','ok');\n            beautylog.log('beautylog.log(), with normal logText, with logType \"success\"','success');\n            beautylog.log('beautylog.log(), with normal logText, with logType \"warn\"','warn');\n        });\n    });\n    describe(\".dir(message)\",function(){\n        it(\"should print a blue Dir message\",function(){\n            beautylog.dir('beautylog.dir(), with normal logText, without logType');\n        })\n    })\n    describe(\".error(message)\",function(){\n        it(\"should print a red error message\",function(){\n            beautylog.error('beautylog.error(), with normal logText, without logType');\n        });\n    });\n    describe(\".figlet\",function(){\n        it(\"should print nice fonts to console in yellow\",function(done){\n            beautylog.figlet(\"Async!\",{font:\"Star Wars\",color:\"yellow\"}).then(done);\n        })\n    });\n    describe(\".figletSync\",function(){\n        it(\"should print nice fonts to console in yellow\",function(){\n            beautylog.figletSync(\"Sync!\",{font:\"Star Wars\",color:\"blue\"});\n        })\n    });\n    describe(\".info(message)\",function(){\n        it(\"should display a purple info message\",function(){\n            beautylog.info('beautylog.dir(), with normal logText, without logType');\n        });\n    });\n    describe(\".ok(message)\",function(){\n        it(\"should display a green ok message\",function(){\n            beautylog.ok('beautylog.ok(), with normal logText, without logType');\n        });\n    });\n    describe(\".newLine(number)\",function(){\n        it(\"create specified amount of new lines\",function(){\n            beautylog.newLine(1);\n        });\n    });\n    describe(\".ora(text,color)\",function(){\n        it(\"should display, update, and end a message\",function(done){\n            this.timeout(10000);\n            let testOra = new beautylog.Ora(\"This is a test text\",\"green\",true);\n            setTimeout(function(){\n                testOra.text(\"updated text!\");\n                testOra.log(\"an intermediate log message\",\"info\");\n                beautylog.info(\"another log message that uses the normal log function\");\n                setTimeout(function(){\n                    testOra.endOk(\"Allright, ora works!\");\n                    done();\n                },2000);\n            },2000)\n        });\n        it(\"should display an error message when ended with error\",function(done){\n            this.timeout(10000);\n            let testOra = new beautylog.Ora(\"This is another test text\",\"green\");\n            setTimeout(function(){\n                testOra.endError(\"Allright, ora displays an error!\");\n                done();\n            },2000)\n        });\n    });\n    describe(\".success(message)\",function(){\n        it(\"should display an orange warn message\",function(){\n            beautylog.success('beautylog.success(), with normal logText, without logType');\n        })\n    });\n    describe(\".warn\",function(){\n        it(\"should display a orange warn message\",function(){\n            beautylog.warn('beautylog.warn(), with normal logText, without logType');\n        });\n    });\n    describe(\".Table\",function(){\n        it(\"should print a nice table\",function(){\n            (function(){\n                var testTable1 = new beautylog.Table(\"checks\");\n                testTable1.push(['check1','success']);\n                testTable1.push(['check2','error']);\n                testTable1.push(['check3','error']);\n                testTable1.print();\n\n                var testTable2 = new beautylog.Table(\"custom\",[\"Column1\".red,\"Column2\".blue,\"Column3\".cyan]);\n                testTable2.push([\"Hey\",\"this\",\"works\"]);\n                testTable2.print();\n            })();\n        });\n    });\n});\n\n\n"]} +//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["test.ts"],"names":[],"mappings":"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","file":"test.js","sourcesContent":["import \"typings-test\";\nimport beautylog = require('../dist/index');\n\ndescribe(\"beautylog\",function(){\n    describe(\".log(message,logtype)\",function(){\n        it(\"should log cyan text\",function(){\n            beautylog.log('beautylog.log(), with normal logText, without logType');\n        });\n        it(\"should print different log types dependent on logType\",function(){\n            beautylog.log('beautylog.log(), with normal logText, without logType');\n            beautylog.log('beautylog.log(), with normal logText, with logType \"dir\"','dir');\n            beautylog.log('beautylog.log(), with normal logText, with logType \"error\"','error');\n            beautylog.log('beautylog.log(), with normal logText, with logType \"info\"','info');\n            beautylog.log('beautylog.log(), with normal logText, with logType \"ok\"','ok');\n            beautylog.log('beautylog.log(), with normal logText, with logType \"success\"','success');\n            beautylog.log('beautylog.log(), with normal logText, with logType \"warn\"','warn');\n        });\n    });\n    describe(\".dir(message)\",function(){\n        it(\"should print a blue Dir message\",function(){\n            beautylog.dir('beautylog.dir(), with normal logText, without logType');\n        })\n    })\n    describe(\".error(message)\",function(){\n        it(\"should print a red error message\",function(){\n            beautylog.error('beautylog.error(), with normal logText, without logType');\n        });\n    });\n    describe(\".figlet\",function(){\n        it(\"should print nice fonts to console in yellow\",function(done){\n            beautylog.figlet(\"Async!\",{font:\"Star Wars\",color:\"yellow\"}).then(done);\n        })\n    });\n    describe(\".figletSync\",function(){\n        it(\"should print nice fonts to console in yellow\",function(){\n            beautylog.figletSync(\"Sync!\",{font:\"Star Wars\",color:\"blue\"});\n        })\n    });\n    describe(\".info(message)\",function(){\n        it(\"should display a purple info message\",function(){\n            beautylog.info('beautylog.dir(), with normal logText, without logType');\n        });\n    });\n    describe(\".logReduced(message)\",function(){\n        it(\"should only log two messages\",function(){\n            beautylog.logReduced(\"Message 1\");\n            beautylog.logReduced(\"Message 1\");\n            beautylog.logReduced(\"Message 1\");\n            beautylog.logReduced(\"Message 1\");\n            beautylog.logReduced(\"Message 2\");\n            beautylog.logReduced(\"Message 2\");\n        })\n    })\n    describe(\".ok(message)\",function(){\n        it(\"should display a green ok message\",function(){\n            beautylog.ok('beautylog.ok(), with normal logText, without logType');\n        });\n    });\n    describe(\".newLine(number)\",function(){\n        it(\"create specified amount of new lines\",function(){\n            beautylog.newLine(1);\n        });\n    });\n    describe(\".ora(text,color)\",function(){\n        it(\"should display, update, and end a message\",function(done){\n            this.timeout(10000);\n            let testOra = new beautylog.Ora(\"This is a test text\",\"green\",true);\n            setTimeout(function(){\n                testOra.text(\"updated text!\");\n                testOra.log(\"an intermediate log message\",\"info\");\n                beautylog.info(\"another log message that uses the normal log function\");\n                setTimeout(function(){\n                    testOra.endOk(\"Allright, ora works!\");\n                    done();\n                },2000);\n            },2000)\n        });\n        it(\"should display an error message when ended with error\",function(done){\n            this.timeout(10000);\n            let testOra = new beautylog.Ora(\"This is another test text\",\"green\");\n            setTimeout(function(){\n                testOra.endError(\"Allright, ora displays an error!\");\n                done();\n            },2000)\n        });\n    });\n    describe(\".success(message)\",function(){\n        it(\"should display an orange warn message\",function(){\n            beautylog.success('beautylog.success(), with normal logText, without logType');\n        })\n    });\n    describe(\".warn\",function(){\n        it(\"should display a orange warn message\",function(){\n            beautylog.warn('beautylog.warn(), with normal logText, without logType');\n        });\n    });\n    describe(\".Table\",function(){\n        it(\"should print a nice table\",function(){\n            (function(){\n                var testTable1 = new beautylog.Table(\"checks\");\n                testTable1.push(['check1','success']);\n                testTable1.push(['check2','error']);\n                testTable1.push(['check3','error']);\n                testTable1.print();\n\n                var testTable2 = new beautylog.Table(\"custom\",[\"Column1\".red,\"Column2\".blue,\"Column3\".cyan]);\n                testTable2.push([\"Hey\",\"this\",\"works\"]);\n                testTable2.print();\n            })();\n        });\n    });\n});\n\n\n"]} diff --git a/test/test.ts b/test/test.ts index d7bfb85..643ac13 100644 --- a/test/test.ts +++ b/test/test.ts @@ -41,6 +41,16 @@ describe("beautylog",function(){ beautylog.info('beautylog.dir(), with normal logText, without logType'); }); }); + describe(".logReduced(message)",function(){ + it("should only log two messages",function(){ + beautylog.logReduced("Message 1"); + beautylog.logReduced("Message 1"); + beautylog.logReduced("Message 1"); + beautylog.logReduced("Message 1"); + beautylog.logReduced("Message 2"); + beautylog.logReduced("Message 2"); + }) + }) describe(".ok(message)",function(){ it("should display a green ok message",function(){ beautylog.ok('beautylog.ok(), with normal logText, without logType'); diff --git a/ts/beautylog.log.ts b/ts/beautylog.log.ts index 1349ec9..c7c5e8d 100644 --- a/ts/beautylog.log.ts +++ b/ts/beautylog.log.ts @@ -57,8 +57,28 @@ export let dir = (logText) => { return log(logText, 'dir'); }; +/** + * creates a new empty line + * @param linesArg + * @returns void + */ export let newLine = (linesArg:number = 1) => { for(let i = 0; i < linesArg;i++){ console.log("\n"); } -} \ No newline at end of file +} + +/** + * logs a reduced log that only logs changes of consequential log messages + */ +export let logReduced = (logTextArg:string,repeatEveryTimesArg:number = 0) => { + if(logTextArg == previousMessage && (repeatEveryTimesArg == 0 || sameMessageCounter != repeatEveryTimesArg)){ + sameMessageCounter++; + } else { + sameMessageCounter = 0; + previousMessage = logTextArg; + log(logTextArg); + } +}; +let previousMessage:string = ""; +let sameMessageCounter:number = 0; \ No newline at end of file diff --git a/ts/index.ts b/ts/index.ts index 145be25..4050147 100644 --- a/ts/index.ts +++ b/ts/index.ts @@ -8,5 +8,5 @@ export {Table} from "./beautylog.classes.table"; export {Ora} from "./beautylog.classes.ora"; // export methods -export {dir,error,info,log,ok,success,warn,newLine} from "./beautylog.log"; +export {dir,error,info,log,logReduced,ok,success,warn,newLine} from "./beautylog.log"; export {figlet,figletSync} from "./beautylog.figlet" \ No newline at end of file