aboutsummaryrefslogtreecommitdiff
path: root/node_modules/sequencify/index.js
diff options
context:
space:
mode:
authorFlorian Dold <florian.dold@gmail.com>2016-10-10 03:43:44 +0200
committerFlorian Dold <florian.dold@gmail.com>2016-10-10 03:43:44 +0200
commitabd94a7f5a50f43c797a11b53549ae48fff667c3 (patch)
treeab8ed457f65cdd72e13e0571d2975729428f1551 /node_modules/sequencify/index.js
parenta0247c6a3fd6a09a41a7e35a3441324c4dcb58be (diff)
downloadwallet-core-abd94a7f5a50f43c797a11b53549ae48fff667c3.tar.xz
add node_modules to address #4364
Diffstat (limited to 'node_modules/sequencify/index.js')
-rw-r--r--node_modules/sequencify/index.js46
1 files changed, 46 insertions, 0 deletions
diff --git a/node_modules/sequencify/index.js b/node_modules/sequencify/index.js
new file mode 100644
index 000000000..b05f8bf32
--- /dev/null
+++ b/node_modules/sequencify/index.js
@@ -0,0 +1,46 @@
+/*jshint node:true */
+
+"use strict";
+
+var sequence = function (tasks, names, results, nest) {
+ var i, name, node, e, j;
+ nest = nest || [];
+ for (i = 0; i < names.length; i++) {
+ name = names[i];
+ // de-dup results
+ if (results.indexOf(name) === -1) {
+ node = tasks[name];
+ if (!node) {
+ e = new Error('task "'+name+'" is not defined');
+ e.missingTask = name;
+ e.taskList = [];
+ for (j in tasks) {
+ if (tasks.hasOwnProperty(j)) {
+ e.taskList.push(tasks[j].name);
+ }
+ }
+ throw e;
+ }
+ if (nest.indexOf(name) > -1) {
+ nest.push(name);
+ e = new Error('Recursive dependencies detected: '+nest.join(' -> '));
+ e.recursiveTasks = nest;
+ e.taskList = [];
+ for (j in tasks) {
+ if (tasks.hasOwnProperty(j)) {
+ e.taskList.push(tasks[j].name);
+ }
+ }
+ throw e;
+ }
+ if (node.dep.length) {
+ nest.push(name);
+ sequence(tasks, node.dep, results, nest); // recurse
+ nest.pop(name);
+ }
+ results.push(name);
+ }
+ }
+};
+
+module.exports = sequence;