Skip to content

Commit ae2aaa4

Browse files
committed
Update: Add ^4.0.0 support which is a mirror of alpha.2 logic
1 parent 571a7c9 commit ae2aaa4

File tree

7 files changed

+85
-6
lines changed

7 files changed

+85
-6
lines changed

lib/versioned/^4.0.0-alpha.1/index.js

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -10,9 +10,9 @@ var tildify = require('tildify');
1010
var exit = require('../../shared/exit');
1111

1212
var logTasks = require('../../shared/log/tasks');
13-
var logEvents = require('../^4.0.0-alpha.2/log/events');
14-
var logSyncTask = require('../^4.0.0-alpha.2/log/syncTask');
15-
var logTasksSimple = require('../^4.0.0-alpha.2/log/tasksSimple');
13+
var logEvents = require('../^4.0.0/log/events');
14+
var logSyncTask = require('../^4.0.0/log/syncTask');
15+
var logTasksSimple = require('../^4.0.0/log/tasksSimple');
1616

1717
function execute(opts, env) {
1818

lib/versioned/^4.0.0-alpha.2/index.js

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -10,9 +10,9 @@ var tildify = require('tildify');
1010
var exit = require('../../shared/exit');
1111

1212
var logTasks = require('../../shared/log/tasks');
13-
var logEvents = require('./log/events');
14-
var logSyncTask = require('./log/syncTask');
15-
var logTasksSimple = require('./log/tasksSimple');
13+
var logEvents = require('../^4.0.0/log/events');
14+
var logSyncTask = require('../^4.0.0/log/syncTask');
15+
var logTasksSimple = require('../^4.0.0/log/tasksSimple');
1616

1717
function execute(opts, env) {
1818

lib/versioned/^4.0.0/index.js

Lines changed: 79 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,79 @@
1+
'use strict';
2+
3+
var fs = require('fs');
4+
5+
var log = require('gulplog');
6+
var chalk = require('chalk');
7+
var stdout = require('mute-stdout');
8+
var tildify = require('tildify');
9+
10+
var exit = require('../../shared/exit');
11+
12+
var logTasks = require('../../shared/log/tasks');
13+
var logEvents = require('./log/events');
14+
var logSyncTask = require('./log/syncTask');
15+
var logTasksSimple = require('./log/tasksSimple');
16+
17+
function execute(opts, env) {
18+
19+
var tasks = opts._;
20+
var toRun = tasks.length ? tasks : ['default'];
21+
22+
if (opts.tasksSimple || opts.tasks || opts.tasksJson) {
23+
// Mute stdout if we are listing tasks
24+
stdout.mute();
25+
}
26+
27+
var gulpInst = require(env.modulePath);
28+
logEvents(gulpInst);
29+
logSyncTask(gulpInst);
30+
31+
// This is what actually loads up the gulpfile
32+
require(env.configPath);
33+
34+
// Always unmute stdout after gulpfile is required
35+
stdout.unmute();
36+
37+
process.nextTick(function() {
38+
var tree;
39+
40+
if (opts.tasksSimple) {
41+
tree = gulpInst.tree();
42+
return logTasksSimple(tree.nodes);
43+
}
44+
if (opts.tasks) {
45+
tree = gulpInst.tree({ deep: true });
46+
tree.label = 'Tasks for ' + chalk.magenta(tildify(env.configPath));
47+
48+
return logTasks(tree, function(task) {
49+
return gulpInst.task(task).description;
50+
});
51+
}
52+
if (opts.tasksJson) {
53+
tree = gulpInst.tree({ deep: true });
54+
tree.label = 'Tasks for ' + tildify(env.configPath);
55+
56+
var output = JSON.stringify(tree);
57+
58+
if (typeof opts.tasksJson === 'boolean' && opts.tasksJson) {
59+
return console.log(output);
60+
} else {
61+
return fs.writeFileSync(opts.tasksJson, output, 'utf-8');
62+
}
63+
}
64+
try {
65+
log.info('Using gulpfile', chalk.magenta(tildify(env.configPath)));
66+
gulpInst.parallel(toRun)(function(err) {
67+
if (err) {
68+
exit(1);
69+
}
70+
});
71+
} catch (err) {
72+
log.error(chalk.red(err.message));
73+
log.error('To list available tasks, try running: gulp --tasks');
74+
exit(1);
75+
}
76+
});
77+
}
78+
79+
module.exports = execute;

0 commit comments

Comments
 (0)