forked from laravel/elixir
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.js
109 lines (90 loc) · 3.27 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
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
var fs = require('fs');
var gulp = require('gulp');
var _ = require('underscore');
var gutils = require('gulp-util');
/**
* Elixir is a wrapper around Gulp.
*
* @param {Function} recipe
*/
var Elixir = function(recipe) {
// We'll start by loading all of the available tasks.
require('require-dir')('./tasks');
// The user may then choose which tasks they want.
recipe(Elixir.mixins);
// Now that the user has requested their desired tasks
// from the Gulpfile, we'll initialize everything!
createGulpTasks.call(Elixir);
};
Elixir.mixins = {};
Elixir.Log = require('./Logger');
Elixir.Notification = require('./Notification');
Elixir.GulpPaths = require('./GulpPaths');
Elixir.config = config = require('./Config');
Elixir.Task = require('./Task')(Elixir);
Elixir.tasks = config.tasks;
Elixir.Plugins = require('gulp-load-plugins')();
/**
* Register a new task with Elixir.
*
* @param {string} name
* @param {Function} callback
*/
Elixir.extend = function(name, callback) {
Elixir.mixins[name] = function() {
callback.apply(this, arguments);
return this.mixins;
}.bind(this);
};
/**
* Allow for config overrides, via an elixir.json file.
*
* @param {string} file
*/
Elixir.setDefaultsFrom = function(file) {
var overrides;
if (fs.existsSync(file)) {
overrides = JSON.parse(fs.readFileSync(file, 'utf8'));
_.mixin({
deepExtend: require('underscore-deep-extend')(_)
});
_.deepExtend(Elixir.config, overrides);
}
}('elixir.json');
/**
* Create the actual Gulp tasks dynamically,
* based upon the chosen Elixir mixins.
*/
var createGulpTasks = function() {
var tasks = this.tasks;
tasks.forEach(function(task) {
if (_.contains(gulp.tasks, task.name)) return;
gulp.task(task.name, function() {
// If the user is running gulp watch or gulp *task from the
// command line, then we'll trigger the current Gulp task
// logic as many times as was requested in the Gulpfile.
// Example: mix.sass('app.scss').sass('admin.scss').
if (_.intersection(gutils.env._, [task.name, 'watch', 'tdd']).length) {
return _.where(tasks, { name: task.name })
.forEach(function(task) {
task.run();
});
}
// On the other hand, if the user just triggered `gulp`,
// then we can simply run the task, badabingbadaboom.
var gulp = Elixir.Task.find(task.name).run();
// This is a little tricky. With Elixir, a single Gulp task
// can be triggered multiple times, with unique sets of
// data - which you provide, when you do mix.task().
// The kicker is that, when the Gulp task is triggered,
// we must know which set of data you want to use. So
// we increment an index each time the task is run.
// The Task.find method will then, when called, properly
// return the correct data that corresponds to the
// active index for the current task. Got it?
Elixir.config.activeTasks[task.name]++;
return gulp;
});
});
};
module.exports = Elixir;