forked from gulpjs/gulp
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.js
57 lines (46 loc) · 1.51 KB
/
index.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
/*jshint node:true */
"use strict";
var util = require('util');
var Orchestrator = require('orchestrator');
var gutil = require('gulp-util');
var prettyTime = require('pretty-hrtime');
// format orchestrator errors
var formatError = function(e) {
if (!e.err) return e.message;
if (e.err.message) return e.err.message;
return JSON.stringify(e.err);
};
function Gulp(){
Orchestrator.call(this);
this.env = {};
// Logging
this.on('task_start', function(e){
gutil.log('Running', "'"+gutil.colors.cyan(e.task)+"'...");
});
this.on('task_stop', function(e){
var time = prettyTime(e.hrDuration);
gutil.log('Finished', "'"+gutil.colors.cyan(e.task)+"'", "in", gutil.colors.magenta(time));
});
this.on('task_err', function(e){
var msg = formatError(e);
var time = prettyTime(e.hrDuration);
gutil.log('Errored', "'"+gutil.colors.cyan(e.task)+"'", "in", gutil.colors.magenta(time), gutil.colors.red(msg));
});
}
util.inherits(Gulp, Orchestrator);
Gulp.prototype.taskQueue = Gulp.prototype.seq;
Gulp.prototype.task = Gulp.prototype.add;
Gulp.prototype.run = function(){
var tasks = Array.prototype.slice.call(arguments);
// impose our opinion of "default" tasks onto orchestrator
if (!tasks.length) {
tasks = ['default'];
}
this.start.apply(this, tasks);
};
Gulp.prototype.src = require('./lib/createInputStream');
Gulp.prototype.dest = require('./lib/createOutputStream');
Gulp.prototype.watch = require('./lib/watch');
var gulp = new Gulp();
gulp.Gulp = Gulp;
module.exports = gulp;