-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.js
71 lines (63 loc) · 1.82 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
58
59
60
61
62
63
64
65
66
67
68
69
70
71
'use strict';
var gutil = require('gulp-util')
var chalk = require('chalk')
var resolve = require('resolve')
var prettyTime = require('pretty-hrtime')
var failed = false
// Format orchestrator errors
function formatError(e) {
if (!e.err) {
return e.message
}
// PluginError
if (typeof e.err.showStack === 'boolean') {
return e.err.toString()
}
// Normal error
if (e.err.stack) {
return e.err.stack
}
// Unknown (string, number, etc.)
return new Error(String(e.err)).stack
}
module.exports = function () {
var gulp = require(resolve.sync('gulp', {
basedir: process.cwd()
}))
require(resolve.sync('./gulpfile.js', {
basedir: process.cwd()
}))
// Total hack due to poor error management in orchestrator
gulp.on('err', function() {
failed = true
})
gulp.on('task_start', function(e) {
// so when 5 tasks start at once it only logs one time with all 5
gutil.log('Starting', '\'' + chalk.cyan(e.task) + '\'...')
})
gulp.on('task_stop', function(e) {
var time = prettyTime(e.hrDuration)
gutil.log(
'Finished', '\'' + chalk.cyan(e.task) + '\'',
'after', chalk.magenta(time)
)
})
gulp.on('task_err', function(e) {
var msg = formatError(e)
var time = prettyTime(e.hrDuration)
gutil.log(
'\'' + chalk.cyan(e.task) + '\'',
chalk.red('errored after'),
chalk.magenta(time)
)
gutil.log(msg)
})
gulp.on('task_not_found', function(err) {
gutil.log(
chalk.red('Task \'' + err.task + '\' is not in your gulpfile')
)
gutil.log('Please check the documentation for proper gulpfile formatting')
process.exit(1)
})
return gulp
}