forked from robrich/sequencify
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.js
44 lines (38 loc) · 1.11 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
/*jshint node:true */
"use strict";
var sequence = function (tasks, names, results, missing, recursive, nest) {
names.forEach(function (name) {
if (results.indexOf(name) !== -1) {
return; // de-dup results
}
var node = tasks[name];
if (!node) {
missing.push(name);
} else if (nest.indexOf(name) > -1) {
nest.push(name);
recursive.push(nest.slice(0));
nest.pop(name);
} else if (node.dep.length) {
nest.push(name);
sequence(tasks, node.dep, results, missing, recursive, nest); // recurse
nest.pop(name);
}
results.push(name);
});
};
// tasks: object with keys as task names
// names: array of task names
module.exports = function (tasks, names) {
var results = []; // the final sequence
var missing = []; // missing tasks
var recursive = []; // recursive task dependencies
sequence(tasks, names, results, missing, recursive, []);
if (missing.length || recursive.length) {
results = []; // results are incomplete at best, completely wrong at worst, remove them to avoid confusion
}
return {
sequence: results,
missingTasks: missing,
recursiveDependencies: recursive
};
};