forked from remy/inliner
-
Notifications
You must be signed in to change notification settings - Fork 0
/
progress.js
61 lines (53 loc) · 1.5 KB
/
progress.js
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
54
55
56
57
58
59
60
61
var styles = require('ansi-styles');
var ansi = require('ansi-escapes');
console.warn(ansi.cursorHide + '\n\n' + ansi.cursorUp() +
ansi.cursorSavePosition);
module.exports = function (progress, jobs, keep) {
if (keep) {
process.stderr.write(
ansi.cursorRestorePosition +
ansi.cursorLeft +
ansi.eraseLines(2) +
styles.red.open + '‣ ' + styles.red.close +
styles.gray.open + progress + styles.gray.close +
'\n\n' +
ansi.cursorSavePosition +
'\n\n'
);
}
var remaining = jobs.breakdown.join(', ');
if (remaining) {
remaining = ' remaining: ' + remaining;
}
var t = jobs.todo / jobs.total * 100;
if (t < 1) {
t = 0;
} else {
t = t | 0;
}
var str = styles.green.open +
(100 - t) + '%' +
styles.green.close +
remaining +
styles.gray.open +
'\nLast job: ' + progress +
styles.gray.close;
process.stderr.write(
ansi.cursorRestorePosition +
ansi.cursorLeft +
ansi.eraseLines(2) +
str.trim() + '\n');
};
module.exports.end = function (time) {
var diff = process.hrtime(time);
process.stderr.write(styles.green.open + 'Time: ' + diff[0] + 's ' +
(diff[1] / 1e6).toFixed(3) + 'ms\n' + styles.green.close);
process.stderr.write(ansi.cursorShow);
};
// tidy up cursor
'exit SIGINT SIGTERM'.split(' ').map(function (event) {
process.once(event, function () {
process.stderr.write(ansi.cursorShow); // put the cursor back
try { process.kill(process.pid, event); } catch (e) {}
});
});