-
Notifications
You must be signed in to change notification settings - Fork 2
/
log.js
47 lines (41 loc) · 1.02 KB
/
log.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
'use strict';
var util = require('./.');
exports = module.exports = logger;
// logging
//
function logger(/* arguments */){
var date = util.date(new Date(), 'HH:MM:ss');
process.stdout.write('[' + util.color.grey(date) + '] ');
console.log.apply(console, arguments);
}
// --task-simple helper
util.logTasksSimple = function(runtime) {
console.log(
Object.keys(runtime.store.children)
.join('\n')
.trim()
);
};
// --task helper
util.taskTree = function(tasks) {
return Object.keys(tasks)
.reduce(function (prev, task) {
prev.nodes.push({
label: task,
nodes: tasks[task].dep
});
return prev;
}, {
nodes: [ ]
});
};
// --task helper
util.logTasks = function(runtime) {
var tree = this.taskTree(runtime.store.children);
var configFile = this.tildify(process.argv[1]);
tree.label = 'Tasks for ' + this.color.magenta(configFile);
require('archy')(tree).split('\n').forEach(function (v) {
if(!v.trim().length) { return ; }
util.log(v);
});
};