File size: 1,206 Bytes
bc20498
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
"use strict";

const chalk = require('chalk');
let logs = [];
const logLevel = () => {
  return process.env.npm_config_loglevel || 'notice';
};
const error = (...messages) => {
  logs.push(messages.join(' '));
  console.log(chalk.red(...messages)); // eslint-disable-line no-console
};

const warn = (...messages) => {
  if (logLevel() === 'silent') return;
  logs.push(messages.join(' '));
  console.log(chalk.yellow(...messages)); // eslint-disable-line no-console
};

const log = (...messages) => {
  if (logLevel() === 'silent' || logLevel() === 'warn') return;
  logs.push(messages.join(' '));
  console.log(...messages); // eslint-disable-line no-console
};

const always = (...messages) => {
  logs.push(messages.join(' '));
  console.log(...messages); // eslint-disable-line no-console
};

// splits long text into lines and calls log()
// on each one to allow easy unit testing for specific message
const logLines = text => {
  const lines = text.split('\n');
  for (const line of lines) {
    log(line);
  }
};
const print = () => {
  return logs.join('\n');
};
const reset = () => {
  logs = [];
};
module.exports = {
  log,
  warn,
  error,
  always,
  logLines,
  print,
  reset,
  logLevel
};