From 8944ae24624551ab18319b28a9d959e5a5aead84 Mon Sep 17 00:00:00 2001 From: Phil Kunz Date: Sun, 15 May 2016 15:28:38 +0200 Subject: [PATCH] added Taskparallel class that executest tasks in parallel --- dist/index.d.ts | 5 +++- dist/index.js | 14 ++++++---- dist/taskbuffer.classes.d.ts | 2 -- dist/taskbuffer.classes.helpers.d.ts | 2 +- dist/taskbuffer.classes.helpers.js | 6 ++--- dist/taskbuffer.classes.js | 8 ------ dist/taskbuffer.classes.taskchain.d.ts | 2 +- dist/taskbuffer.classes.taskchain.js | 13 +++------ dist/taskbuffer.classes.taskparallel.d.ts | 7 +++++ dist/taskbuffer.classes.taskparallel.js | 32 +++++++++++++++++++++++ dist/taskbuffer.classes.taskspace.d.ts | 2 ++ dist/taskbuffer.classes.taskspace.js | 10 +++++-- ts/index.ts | 5 +++- ts/taskbuffer.classes.helpers.ts | 2 +- ts/taskbuffer.classes.taskchain.ts | 14 ++-------- ts/taskbuffer.classes.taskparallel.ts | 29 ++++++++++++++++++++ ts/taskbuffer.classes.taskspace.ts | 7 +++++ ts/taskbuffer.classes.ts | 2 -- 18 files changed, 113 insertions(+), 49 deletions(-) delete mode 100644 dist/taskbuffer.classes.d.ts delete mode 100644 dist/taskbuffer.classes.js create mode 100644 dist/taskbuffer.classes.taskparallel.d.ts create mode 100644 dist/taskbuffer.classes.taskparallel.js create mode 100644 ts/taskbuffer.classes.taskparallel.ts delete mode 100644 ts/taskbuffer.classes.ts diff --git a/dist/index.d.ts b/dist/index.d.ts index 5e16801..5787bcb 100644 --- a/dist/index.d.ts +++ b/dist/index.d.ts @@ -1,2 +1,5 @@ -export * from "./taskbuffer.classes"; +export { Task } from "./taskbuffer.classes.task"; +export { Taskchain } from "./taskbuffer.classes.taskchain"; +export { Taskparallel } from "./taskbuffer.classes.taskparallel"; +export { Taskspace } from "./taskbuffer.classes.taskspace"; import "./taskbuffer.classes.helpers"; diff --git a/dist/index.js b/dist/index.js index dca70c6..cf34007 100644 --- a/dist/index.js +++ b/dist/index.js @@ -1,10 +1,14 @@ "use strict"; -function __export(m) { - for (var p in m) if (!exports.hasOwnProperty(p)) exports[p] = m[p]; -} /// -__export(require("./taskbuffer.classes")); +var taskbuffer_classes_task_1 = require("./taskbuffer.classes.task"); +exports.Task = taskbuffer_classes_task_1.Task; +var taskbuffer_classes_taskchain_1 = require("./taskbuffer.classes.taskchain"); +exports.Taskchain = taskbuffer_classes_taskchain_1.Taskchain; +var taskbuffer_classes_taskparallel_1 = require("./taskbuffer.classes.taskparallel"); +exports.Taskparallel = taskbuffer_classes_taskparallel_1.Taskparallel; +var taskbuffer_classes_taskspace_1 = require("./taskbuffer.classes.taskspace"); +exports.Taskspace = taskbuffer_classes_taskspace_1.Taskspace; // import for naming only require("./taskbuffer.classes.helpers"); -//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7QUFBQSw0Q0FBNEM7QUFDNUMsaUJBQWMsc0JBQXNCLENBQUMsRUFBQTtBQUVyQyx5QkFBeUI7QUFDekIsUUFBTyw4QkFBOEIsQ0FBQyxDQUFEIiwiZmlsZSI6ImluZGV4LmpzIiwic291cmNlc0NvbnRlbnQiOlsiLy8vIDxyZWZlcmVuY2UgcGF0aD1cIi4vdHlwaW5ncy9tYWluLmQudHNcIiAvPlxyXG5leHBvcnQgKiBmcm9tIFwiLi90YXNrYnVmZmVyLmNsYXNzZXNcIjtcclxuXHJcbi8vIGltcG9ydCBmb3IgbmFtaW5nIG9ubHlcclxuaW1wb3J0IFwiLi90YXNrYnVmZmVyLmNsYXNzZXMuaGVscGVyc1wiIl19 +//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSw0Q0FBNEM7QUFDNUMsd0NBQW1CLDJCQUEyQixDQUFDO0FBQXZDLDhDQUF1QztBQUMvQyw2Q0FBd0IsZ0NBQWdDLENBQUM7QUFBakQsNkRBQWlEO0FBQ3pELGdEQUEyQixtQ0FBbUMsQ0FBQztBQUF2RCxzRUFBdUQ7QUFDL0QsNkNBQXdCLGdDQUFnQyxDQUFDO0FBQWpELDZEQUFpRDtBQUV6RCx5QkFBeUI7QUFDekIsUUFBTyw4QkFBOEIsQ0FBQyxDQUFEIiwiZmlsZSI6ImluZGV4LmpzIiwic291cmNlc0NvbnRlbnQiOlsiLy8vIDxyZWZlcmVuY2UgcGF0aD1cIi4vdHlwaW5ncy9tYWluLmQudHNcIiAvPlxyXG5leHBvcnQge1Rhc2t9IGZyb20gXCIuL3Rhc2tidWZmZXIuY2xhc3Nlcy50YXNrXCI7XHJcbmV4cG9ydCB7VGFza2NoYWlufSBmcm9tIFwiLi90YXNrYnVmZmVyLmNsYXNzZXMudGFza2NoYWluXCI7XHJcbmV4cG9ydCB7VGFza3BhcmFsbGVsfSBmcm9tIFwiLi90YXNrYnVmZmVyLmNsYXNzZXMudGFza3BhcmFsbGVsXCI7XHJcbmV4cG9ydCB7VGFza3NwYWNlfSBmcm9tIFwiLi90YXNrYnVmZmVyLmNsYXNzZXMudGFza3NwYWNlXCI7XHJcblxyXG4vLyBpbXBvcnQgZm9yIG5hbWluZyBvbmx5XHJcbmltcG9ydCBcIi4vdGFza2J1ZmZlci5jbGFzc2VzLmhlbHBlcnNcIiJdfQ== diff --git a/dist/taskbuffer.classes.d.ts b/dist/taskbuffer.classes.d.ts deleted file mode 100644 index d396f7c..0000000 --- a/dist/taskbuffer.classes.d.ts +++ /dev/null @@ -1,2 +0,0 @@ -export * from "./taskbuffer.classes.task"; -export * from "./taskbuffer.classes.taskchain"; diff --git a/dist/taskbuffer.classes.helpers.d.ts b/dist/taskbuffer.classes.helpers.d.ts index 13993f4..089ca3f 100644 --- a/dist/taskbuffer.classes.helpers.d.ts +++ b/dist/taskbuffer.classes.helpers.d.ts @@ -1,4 +1,4 @@ -import { Task } from "./taskbuffer.classes"; +import { Task } from "./taskbuffer.classes.task"; export declare let emptyTaskFunction: () => any; export declare let isTask: (taskArg: any) => boolean; export declare let isTaskTouched: (taskArg: Task, touchedTasksArray: Task[]) => boolean; diff --git a/dist/taskbuffer.classes.helpers.js b/dist/taskbuffer.classes.helpers.js index 4404c43..708aa94 100644 --- a/dist/taskbuffer.classes.helpers.js +++ b/dist/taskbuffer.classes.helpers.js @@ -1,14 +1,14 @@ "use strict"; /// var plugins = require("./taskbuffer.plugins"); -var taskbuffer_classes_1 = require("./taskbuffer.classes"); +var taskbuffer_classes_task_1 = require("./taskbuffer.classes.task"); exports.emptyTaskFunction = function () { var done = plugins.Q.defer(); done.resolve(); return done.promise; }; exports.isTask = function (taskArg) { - if (taskArg instanceof taskbuffer_classes_1.Task + if (taskArg instanceof taskbuffer_classes_task_1.Task && typeof taskArg.task === "function") { return true; } @@ -93,4 +93,4 @@ exports.updateTaskStatus = function (taskArg, statusArg) { } }; -//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["taskbuffer.classes.helpers.ts"],"names":[],"mappings":"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","file":"taskbuffer.classes.helpers.js","sourcesContent":["/// <reference path=\"./typings/main.d.ts\" />\r\nimport plugins = require(\"./taskbuffer.plugins\");\r\nimport {Task} from \"./taskbuffer.classes\"\r\n\r\nexport let emptyTaskFunction = function(){\r\n    let done = plugins.Q.defer();\r\n    done.resolve();\r\n    return done.promise;\r\n};\r\n\r\nexport let isTask = function(taskArg):boolean{\r\n    if(\r\n        taskArg instanceof Task\r\n        && typeof taskArg.task === \"function\"\r\n    ){\r\n        return true;\r\n    } else {\r\n        return false;\r\n    }\r\n};\r\n\r\n\r\nexport let isTaskTouched = (taskArg:Task, touchedTasksArray:Task[]):boolean => {\r\n    let result = false;\r\n    for (let keyArg in touchedTasksArray){\r\n        if(taskArg === touchedTasksArray[keyArg]){\r\n            result = true;\r\n        }\r\n    }\r\n    return result;\r\n}\r\n\r\nexport let runTask = function(taskArg:Task,optionsArg:{touchedTasksArray:Task[]} = {touchedTasksArray:[]}){\r\n    let done = plugins.Q.defer();\r\n    updateTaskStatus(taskArg,\"running\");\r\n    done.promise.then(function(){updateTaskStatus(taskArg,\"idle\")})\r\n    let localDeferred = plugins.Q.defer();\r\n    let touchedTasksArray:Task[];\r\n    if(optionsArg.touchedTasksArray){\r\n        touchedTasksArray = optionsArg.touchedTasksArray;\r\n    } else {\r\n        touchedTasksArray = [];\r\n    }\r\n    touchedTasksArray.push(taskArg);\r\n    localDeferred.promise\r\n        .then(() =>{\r\n            if(taskArg.preTask && !isTaskTouched(taskArg.preTask,touchedTasksArray)){\r\n                return runTask(taskArg.preTask,{touchedTasksArray:touchedTasksArray})\r\n            } else {\r\n                let done2 = plugins.Q.defer();\r\n                done2.resolve();\r\n                return done2.promise;\r\n            }\r\n        })\r\n        .then(() => {\r\n            return taskArg.task();\r\n        })\r\n        .then(() => {\r\n            if(taskArg.afterTask && !isTaskTouched(taskArg.afterTask,touchedTasksArray)){\r\n                return runTask(taskArg.afterTask,{touchedTasksArray:touchedTasksArray})\r\n            } else {\r\n                let done2 = plugins.Q.defer();\r\n                done2.resolve();\r\n                return done2.promise;\r\n            }\r\n        })\r\n        .then(() => {\r\n            done.resolve();\r\n        });\r\n    localDeferred.resolve();\r\n    return done.promise;\r\n};\r\n\r\nexport let runBufferedTask = (taskArg:Task) => {\r\n    let recursiveBufferRunner = () => {\r\n        if(taskArg.bufferCounter > 0){\r\n            taskArg.bufferCounter--;\r\n            runTask(taskArg)\r\n                .then(recursiveBufferRunner);\r\n        }\r\n    }\r\n}\r\n\r\nexport let updateTaskStatus = (taskArg,statusArg:string) => {\r\n    switch (statusArg) {\r\n        case \"running\":\r\n            taskArg.running = true;\r\n            taskArg.idle = false;\r\n            break;\r\n        case \"idle\":\r\n            taskArg.running = false;\r\n            taskArg.idle = true;\r\n            break;\r\n        default:\r\n            throw new Error(\"status not recognised\");\r\n    }\r\n}"]} +//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["taskbuffer.classes.helpers.ts"],"names":[],"mappings":"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","file":"taskbuffer.classes.helpers.js","sourcesContent":["/// <reference path=\"./typings/main.d.ts\" />\r\nimport plugins = require(\"./taskbuffer.plugins\");\r\nimport {Task} from \"./taskbuffer.classes.task\";\r\n\r\nexport let emptyTaskFunction = function(){\r\n    let done = plugins.Q.defer();\r\n    done.resolve();\r\n    return done.promise;\r\n};\r\n\r\nexport let isTask = function(taskArg):boolean{\r\n    if(\r\n        taskArg instanceof Task\r\n        && typeof taskArg.task === \"function\"\r\n    ){\r\n        return true;\r\n    } else {\r\n        return false;\r\n    }\r\n};\r\n\r\n\r\nexport let isTaskTouched = (taskArg:Task, touchedTasksArray:Task[]):boolean => {\r\n    let result = false;\r\n    for (let keyArg in touchedTasksArray){\r\n        if(taskArg === touchedTasksArray[keyArg]){\r\n            result = true;\r\n        }\r\n    }\r\n    return result;\r\n}\r\n\r\nexport let runTask = function(taskArg:Task,optionsArg:{touchedTasksArray:Task[]} = {touchedTasksArray:[]}){\r\n    let done = plugins.Q.defer();\r\n    updateTaskStatus(taskArg,\"running\");\r\n    done.promise.then(function(){updateTaskStatus(taskArg,\"idle\")})\r\n    let localDeferred = plugins.Q.defer();\r\n    let touchedTasksArray:Task[];\r\n    if(optionsArg.touchedTasksArray){\r\n        touchedTasksArray = optionsArg.touchedTasksArray;\r\n    } else {\r\n        touchedTasksArray = [];\r\n    }\r\n    touchedTasksArray.push(taskArg);\r\n    localDeferred.promise\r\n        .then(() =>{\r\n            if(taskArg.preTask && !isTaskTouched(taskArg.preTask,touchedTasksArray)){\r\n                return runTask(taskArg.preTask,{touchedTasksArray:touchedTasksArray})\r\n            } else {\r\n                let done2 = plugins.Q.defer();\r\n                done2.resolve();\r\n                return done2.promise;\r\n            }\r\n        })\r\n        .then(() => {\r\n            return taskArg.task();\r\n        })\r\n        .then(() => {\r\n            if(taskArg.afterTask && !isTaskTouched(taskArg.afterTask,touchedTasksArray)){\r\n                return runTask(taskArg.afterTask,{touchedTasksArray:touchedTasksArray})\r\n            } else {\r\n                let done2 = plugins.Q.defer();\r\n                done2.resolve();\r\n                return done2.promise;\r\n            }\r\n        })\r\n        .then(() => {\r\n            done.resolve();\r\n        });\r\n    localDeferred.resolve();\r\n    return done.promise;\r\n};\r\n\r\nexport let runBufferedTask = (taskArg:Task) => {\r\n    let recursiveBufferRunner = () => {\r\n        if(taskArg.bufferCounter > 0){\r\n            taskArg.bufferCounter--;\r\n            runTask(taskArg)\r\n                .then(recursiveBufferRunner);\r\n        }\r\n    }\r\n}\r\n\r\nexport let updateTaskStatus = (taskArg,statusArg:string) => {\r\n    switch (statusArg) {\r\n        case \"running\":\r\n            taskArg.running = true;\r\n            taskArg.idle = false;\r\n            break;\r\n        case \"idle\":\r\n            taskArg.running = false;\r\n            taskArg.idle = true;\r\n            break;\r\n        default:\r\n            throw new Error(\"status not recognised\");\r\n    }\r\n}"]} diff --git a/dist/taskbuffer.classes.js b/dist/taskbuffer.classes.js deleted file mode 100644 index 127b5ee..0000000 --- a/dist/taskbuffer.classes.js +++ /dev/null @@ -1,8 +0,0 @@ -"use strict"; -function __export(m) { - for (var p in m) if (!exports.hasOwnProperty(p)) exports[p] = m[p]; -} -__export(require("./taskbuffer.classes.task")); -__export(require("./taskbuffer.classes.taskchain")); - -//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRhc2tidWZmZXIuY2xhc3Nlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7O0FBQUEsaUJBQWMsMkJBQ2QsQ0FBQyxFQUR3QztBQUN6QyxpQkFBYyxnQ0FDZCxDQUFDLEVBRDZDIiwiZmlsZSI6InRhc2tidWZmZXIuY2xhc3Nlcy5qcyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gXCIuL3Rhc2tidWZmZXIuY2xhc3Nlcy50YXNrXCJcclxuZXhwb3J0ICogZnJvbSBcIi4vdGFza2J1ZmZlci5jbGFzc2VzLnRhc2tjaGFpblwiXHJcbiJdfQ== diff --git a/dist/taskbuffer.classes.taskchain.d.ts b/dist/taskbuffer.classes.taskchain.d.ts index 01b2dd6..ffe0e09 100644 --- a/dist/taskbuffer.classes.taskchain.d.ts +++ b/dist/taskbuffer.classes.taskchain.d.ts @@ -1,4 +1,4 @@ -import { Task } from "./taskbuffer.classes"; +import { Task } from "./taskbuffer.classes.task"; export declare class Taskchain extends Task { taskArray: Task[]; private _oraObject; diff --git a/dist/taskbuffer.classes.taskchain.js b/dist/taskbuffer.classes.taskchain.js index a9ddf3b..f20a6b1 100644 --- a/dist/taskbuffer.classes.taskchain.js +++ b/dist/taskbuffer.classes.taskchain.js @@ -6,7 +6,7 @@ var __extends = (this && this.__extends) || function (d, b) { }; /// var plugins = require("./taskbuffer.plugins"); -var taskbuffer_classes_1 = require("./taskbuffer.classes"); +var taskbuffer_classes_task_1 = require("./taskbuffer.classes.task"); var helpers = require("./taskbuffer.classes.helpers"); var Taskchain = (function (_super) { __extends(Taskchain, _super); @@ -56,15 +56,8 @@ var Taskchain = (function (_super) { return helpers.runTask(this); }; return Taskchain; -}(taskbuffer_classes_1.Task)); +}(taskbuffer_classes_task_1.Task)); exports.Taskchain = Taskchain; ; -var myTask = new Taskchain({ - taskArray: [ - new taskbuffer_classes_1.Task({ - taskFunction: function () { } - }) - ] -}); -//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRhc2tidWZmZXIuY2xhc3Nlcy50YXNrY2hhaW4udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUEsNENBQTRDO0FBQzVDLElBQVksT0FBTyxXQUFNLHNCQUFzQixDQUFDLENBQUE7QUFDaEQsbUNBQW1CLHNCQUFzQixDQUFDLENBQUE7QUFDMUMsSUFBTyxPQUFPLFdBQVcsOEJBQThCLENBQUMsQ0FBQztBQUV6RDtJQUErQiw2QkFBSTtJQUcvQixtQkFBWSxVQUlYO1FBUEwsaUJBb0RDO1FBNUNPLElBQUksT0FBTyxHQUFHLE9BQU8sQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUMvQjtZQUNJLElBQUksRUFBQyxjQUFjO1lBQ25CLEdBQUcsRUFBQyxLQUFLO1NBQ1osRUFDRCxVQUFVLEVBQ1Y7WUFDSSxZQUFZLEVBQUU7Z0JBQ1YsT0FBTyxDQUFDLEdBQUcsQ0FBQyw0QkFBNEIsQ0FBQyxDQUFDO2dCQUMxQyxJQUFJLElBQUksR0FBRyxPQUFPLENBQUMsQ0FBQyxDQUFDLEtBQUssRUFBRSxDQUFDLENBQUMsd0NBQXdDO2dCQUN0RSxJQUFJLFdBQVcsR0FBRyxDQUFDLENBQUM7Z0JBQ3BCLElBQUksWUFBWSxHQUFHO29CQUNmLEVBQUUsQ0FBQSxDQUFDLE9BQU8sS0FBSSxDQUFDLFNBQVMsQ0FBQyxXQUFXLENBQUMsSUFBSSxXQUFXLENBQUMsQ0FBQSxDQUFDO3dCQUNsRCxLQUFJLENBQUMsU0FBUyxDQUFDLFdBQVcsQ0FBQyxDQUFDLE9BQU8sRUFBRTs2QkFDaEMsSUFBSSxDQUFDOzRCQUNGLFdBQVcsRUFBRSxDQUFDOzRCQUNkLFlBQVksRUFBRSxDQUFDO3dCQUNuQixDQUFDLENBQUMsQ0FBQztvQkFDWCxDQUFDO29CQUFDLElBQUksQ0FBQyxDQUFDO3dCQUNKLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQztvQkFDbkIsQ0FBQztnQkFDTCxDQUFDLENBQUM7Z0JBQ0YsWUFBWSxFQUFFLENBQUM7Z0JBQ2YsTUFBTSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUM7WUFDeEIsQ0FBQztTQUNKLENBQ0osQ0FBQztRQUNGLGtCQUFNLE9BQU8sQ0FBQyxDQUFDO1FBQ2YsSUFBSSxDQUFDLFNBQVMsR0FBRyxVQUFVLENBQUMsU0FBUyxDQUFDO1FBQ3RDLElBQUksQ0FBQyxVQUFVLEdBQUcsSUFBSSxPQUFPLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxnQkFBZ0IsRUFBQyxNQUFNLENBQUMsQ0FBQztJQUN6RSxDQUFDO0lBQ0QsMkJBQU8sR0FBUCxVQUFRLE9BQVk7UUFDaEIsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDakMsQ0FBQzs7SUFDRCw4QkFBVSxHQUFWLFVBQVcsT0FBWTtRQUNuQixNQUFNO0lBQ1YsQ0FBQzs7SUFDRCw2QkFBUyxHQUFUO0lBRUEsQ0FBQzs7SUFDRCwyQkFBTyxHQUFQO1FBQ0ksSUFBSSxDQUFDLFVBQVUsQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLElBQUksR0FBRyxhQUFhLENBQUMsQ0FBQztRQUNqRCxNQUFNLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUNqQyxDQUFDO0lBQ0wsZ0JBQUM7QUFBRCxDQXBEQSxBQW9EQyxDQXBEOEIseUJBQUksR0FvRGxDO0FBcERZLGlCQUFTLFlBb0RyQixDQUFBO0FBQUEsQ0FBQztBQUVGLElBQUksTUFBTSxHQUFHLElBQUksU0FBUyxDQUN0QjtJQUNJLFNBQVMsRUFBRTtRQUNQLElBQUkseUJBQUksQ0FBQztZQUNMLFlBQVksRUFBQyxjQUFXLENBQUM7U0FDNUIsQ0FBQztLQUNMO0NBQ0osQ0FDSixDQUFDIiwiZmlsZSI6InRhc2tidWZmZXIuY2xhc3Nlcy50YXNrY2hhaW4uanMiLCJzb3VyY2VzQ29udGVudCI6WyIvLy8gPHJlZmVyZW5jZSBwYXRoPVwiLi90eXBpbmdzL21haW4uZC50c1wiIC8+XHJcbmltcG9ydCAqIGFzIHBsdWdpbnMgZnJvbSBcIi4vdGFza2J1ZmZlci5wbHVnaW5zXCI7XHJcbmltcG9ydCB7VGFza30gZnJvbSBcIi4vdGFza2J1ZmZlci5jbGFzc2VzXCI7XHJcbmltcG9ydCBoZWxwZXJzID0gcmVxdWlyZShcIi4vdGFza2J1ZmZlci5jbGFzc2VzLmhlbHBlcnNcIik7XHJcblxyXG5leHBvcnQgY2xhc3MgVGFza2NoYWluIGV4dGVuZHMgVGFzayB7XHJcbiAgICB0YXNrQXJyYXk6VGFza1tdO1xyXG4gICAgcHJpdmF0ZSBfb3JhT2JqZWN0O1xyXG4gICAgY29uc3RydWN0b3Iob3B0aW9uc0FyZzp7XHJcbiAgICAgICAgbmFtZT86c3RyaW5nLFxyXG4gICAgICAgIGxvZz86Ym9vbGVhbixcclxuICAgICAgICB0YXNrQXJyYXk6VGFza1tdXHJcbiAgICB9KXtcclxuICAgICAgICBsZXQgb3B0aW9ucyA9IHBsdWdpbnMubG9kYXNoLmFzc2lnbihcclxuICAgICAgICAgICAge1xyXG4gICAgICAgICAgICAgICAgbmFtZTpcInVubmFtZWQgVGFza1wiLFxyXG4gICAgICAgICAgICAgICAgbG9nOmZhbHNlXHJcbiAgICAgICAgICAgIH0sXHJcbiAgICAgICAgICAgIG9wdGlvbnNBcmcsXHJcbiAgICAgICAgICAgIHtcclxuICAgICAgICAgICAgICAgIHRhc2tGdW5jdGlvbjogKCkgPT4geyAvLyB0aGlzIGlzIHRoZSBmdW5jdGlvbiB0aGF0IGdldHMgZXhlY3V0ZWQgd2hlbiBUYXNrQ2hhaW4gaXMgdHJpZ2dlcmVkXHJcbiAgICAgICAgICAgICAgICAgICAgY29uc29sZS5sb2coXCJydW5uaW5nIHRhc2tjaGFpbiBmdW5jdGlvblwiKTtcclxuICAgICAgICAgICAgICAgICAgICBsZXQgZG9uZSA9IHBsdWdpbnMuUS5kZWZlcigpOyAvLyB0aGlzIGlzIHRoZSBzdGFydGluZyBEZWZlcnJlZCBvYmplY3QgXHJcbiAgICAgICAgICAgICAgICAgICAgbGV0IHRhc2tDb3VudGVyID0gMDtcclxuICAgICAgICAgICAgICAgICAgICBsZXQgaXRlcmF0ZVRhc2tzID0gKCkgPT4ge1xyXG4gICAgICAgICAgICAgICAgICAgICAgICBpZih0eXBlb2YgdGhpcy50YXNrQXJyYXlbdGFza0NvdW50ZXJdICE9IFwidW5kZWZpbmVkXCIpe1xyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgdGhpcy50YXNrQXJyYXlbdGFza0NvdW50ZXJdLnRyaWdnZXIoKVxyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIC50aGVuKCgpPT57XHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHRhc2tDb3VudGVyKys7XHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGl0ZXJhdGVUYXNrcygpO1xyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIH0pOyAgICAgXHJcbiAgICAgICAgICAgICAgICAgICAgICAgIH0gZWxzZSB7XHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBkb25lLnJlc29sdmUoKTtcclxuICAgICAgICAgICAgICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICAgICAgICAgIH07XHJcbiAgICAgICAgICAgICAgICAgICAgaXRlcmF0ZVRhc2tzKCk7XHJcbiAgICAgICAgICAgICAgICAgICAgcmV0dXJuIGRvbmUucHJvbWlzZTtcclxuICAgICAgICAgICAgICAgIH1cclxuICAgICAgICAgICAgfVxyXG4gICAgICAgICk7XHJcbiAgICAgICAgc3VwZXIob3B0aW9ucyk7XHJcbiAgICAgICAgdGhpcy50YXNrQXJyYXkgPSBvcHRpb25zQXJnLnRhc2tBcnJheTtcclxuICAgICAgICB0aGlzLl9vcmFPYmplY3QgPSBuZXcgcGx1Z2lucy5iZWF1dHlsb2cuT3JhKFwiVGFza2NoYWluIGlkbGVcIixcImJsdWVcIik7XHJcbiAgICB9XHJcbiAgICBhZGRUYXNrKHRhc2tBcmc6VGFzayl7XHJcbiAgICAgICAgdGhpcy50YXNrQXJyYXkucHVzaCh0YXNrQXJnKTtcclxuICAgIH07XHJcbiAgICByZW1vdmVUYXNrKHRhc2tBcmc6VGFzayl7XHJcbiAgICAgICAgLy9UT0RPXHJcbiAgICB9O1xyXG4gICAgc2hpZnRUYXNrKCl7XHJcbiAgICAgICAgXHJcbiAgICB9O1xyXG4gICAgdHJpZ2dlcigpe1xyXG4gICAgICAgIHRoaXMuX29yYU9iamVjdC5zdGFydCh0aGlzLm5hbWUgKyBcIiBydW5uaW5nLi4uXCIpO1xyXG4gICAgICAgIHJldHVybiBoZWxwZXJzLnJ1blRhc2sodGhpcyk7XHJcbiAgICB9XHJcbn07XHJcblxyXG5sZXQgbXlUYXNrID0gbmV3IFRhc2tjaGFpbihcclxuICAgIHtcclxuICAgICAgICB0YXNrQXJyYXk6IFtcclxuICAgICAgICAgICAgbmV3IFRhc2soe1xyXG4gICAgICAgICAgICAgICAgdGFza0Z1bmN0aW9uOmZ1bmN0aW9uKCl7fVxyXG4gICAgICAgICAgICB9KVxyXG4gICAgICAgIF1cclxuICAgIH1cclxuKTsiXX0= +//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRhc2tidWZmZXIuY2xhc3Nlcy50YXNrY2hhaW4udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUEsNENBQTRDO0FBQzVDLElBQVksT0FBTyxXQUFNLHNCQUFzQixDQUFDLENBQUE7QUFDaEQsd0NBQW1CLDJCQUEyQixDQUFDLENBQUE7QUFDL0MsSUFBTyxPQUFPLFdBQVcsOEJBQThCLENBQUMsQ0FBQztBQUV6RDtJQUErQiw2QkFBSTtJQUcvQixtQkFBWSxVQUlYO1FBUEwsaUJBb0RDO1FBNUNPLElBQUksT0FBTyxHQUFHLE9BQU8sQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUMvQjtZQUNJLElBQUksRUFBQyxjQUFjO1lBQ25CLEdBQUcsRUFBQyxLQUFLO1NBQ1osRUFDRCxVQUFVLEVBQ1Y7WUFDSSxZQUFZLEVBQUU7Z0JBQ1YsT0FBTyxDQUFDLEdBQUcsQ0FBQyw0QkFBNEIsQ0FBQyxDQUFDO2dCQUMxQyxJQUFJLElBQUksR0FBRyxPQUFPLENBQUMsQ0FBQyxDQUFDLEtBQUssRUFBRSxDQUFDLENBQUMsd0NBQXdDO2dCQUN0RSxJQUFJLFdBQVcsR0FBRyxDQUFDLENBQUM7Z0JBQ3BCLElBQUksWUFBWSxHQUFHO29CQUNmLEVBQUUsQ0FBQSxDQUFDLE9BQU8sS0FBSSxDQUFDLFNBQVMsQ0FBQyxXQUFXLENBQUMsSUFBSSxXQUFXLENBQUMsQ0FBQSxDQUFDO3dCQUNsRCxLQUFJLENBQUMsU0FBUyxDQUFDLFdBQVcsQ0FBQyxDQUFDLE9BQU8sRUFBRTs2QkFDaEMsSUFBSSxDQUFDOzRCQUNGLFdBQVcsRUFBRSxDQUFDOzRCQUNkLFlBQVksRUFBRSxDQUFDO3dCQUNuQixDQUFDLENBQUMsQ0FBQztvQkFDWCxDQUFDO29CQUFDLElBQUksQ0FBQyxDQUFDO3dCQUNKLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQztvQkFDbkIsQ0FBQztnQkFDTCxDQUFDLENBQUM7Z0JBQ0YsWUFBWSxFQUFFLENBQUM7Z0JBQ2YsTUFBTSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUM7WUFDeEIsQ0FBQztTQUNKLENBQ0osQ0FBQztRQUNGLGtCQUFNLE9BQU8sQ0FBQyxDQUFDO1FBQ2YsSUFBSSxDQUFDLFNBQVMsR0FBRyxVQUFVLENBQUMsU0FBUyxDQUFDO1FBQ3RDLElBQUksQ0FBQyxVQUFVLEdBQUcsSUFBSSxPQUFPLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxnQkFBZ0IsRUFBQyxNQUFNLENBQUMsQ0FBQztJQUN6RSxDQUFDO0lBQ0QsMkJBQU8sR0FBUCxVQUFRLE9BQVk7UUFDaEIsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDakMsQ0FBQzs7SUFDRCw4QkFBVSxHQUFWLFVBQVcsT0FBWTtRQUNuQixNQUFNO0lBQ1YsQ0FBQzs7SUFDRCw2QkFBUyxHQUFUO0lBRUEsQ0FBQzs7SUFDRCwyQkFBTyxHQUFQO1FBQ0ksSUFBSSxDQUFDLFVBQVUsQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLElBQUksR0FBRyxhQUFhLENBQUMsQ0FBQztRQUNqRCxNQUFNLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUNqQyxDQUFDO0lBQ0wsZ0JBQUM7QUFBRCxDQXBEQSxBQW9EQyxDQXBEOEIsOEJBQUksR0FvRGxDO0FBcERZLGlCQUFTLFlBb0RyQixDQUFBO0FBQUEsQ0FBQyIsImZpbGUiOiJ0YXNrYnVmZmVyLmNsYXNzZXMudGFza2NoYWluLmpzIiwic291cmNlc0NvbnRlbnQiOlsiLy8vIDxyZWZlcmVuY2UgcGF0aD1cIi4vdHlwaW5ncy9tYWluLmQudHNcIiAvPlxyXG5pbXBvcnQgKiBhcyBwbHVnaW5zIGZyb20gXCIuL3Rhc2tidWZmZXIucGx1Z2luc1wiO1xyXG5pbXBvcnQge1Rhc2t9IGZyb20gXCIuL3Rhc2tidWZmZXIuY2xhc3Nlcy50YXNrXCI7XHJcbmltcG9ydCBoZWxwZXJzID0gcmVxdWlyZShcIi4vdGFza2J1ZmZlci5jbGFzc2VzLmhlbHBlcnNcIik7XHJcblxyXG5leHBvcnQgY2xhc3MgVGFza2NoYWluIGV4dGVuZHMgVGFzayB7XHJcbiAgICB0YXNrQXJyYXk6VGFza1tdO1xyXG4gICAgcHJpdmF0ZSBfb3JhT2JqZWN0O1xyXG4gICAgY29uc3RydWN0b3Iob3B0aW9uc0FyZzp7XHJcbiAgICAgICAgbmFtZT86c3RyaW5nLFxyXG4gICAgICAgIGxvZz86Ym9vbGVhbixcclxuICAgICAgICB0YXNrQXJyYXk6VGFza1tdXHJcbiAgICB9KXtcclxuICAgICAgICBsZXQgb3B0aW9ucyA9IHBsdWdpbnMubG9kYXNoLmFzc2lnbihcclxuICAgICAgICAgICAge1xyXG4gICAgICAgICAgICAgICAgbmFtZTpcInVubmFtZWQgVGFza1wiLFxyXG4gICAgICAgICAgICAgICAgbG9nOmZhbHNlXHJcbiAgICAgICAgICAgIH0sXHJcbiAgICAgICAgICAgIG9wdGlvbnNBcmcsXHJcbiAgICAgICAgICAgIHtcclxuICAgICAgICAgICAgICAgIHRhc2tGdW5jdGlvbjogKCkgPT4geyAvLyB0aGlzIGlzIHRoZSBmdW5jdGlvbiB0aGF0IGdldHMgZXhlY3V0ZWQgd2hlbiBUYXNrQ2hhaW4gaXMgdHJpZ2dlcmVkXHJcbiAgICAgICAgICAgICAgICAgICAgY29uc29sZS5sb2coXCJydW5uaW5nIHRhc2tjaGFpbiBmdW5jdGlvblwiKTtcclxuICAgICAgICAgICAgICAgICAgICBsZXQgZG9uZSA9IHBsdWdpbnMuUS5kZWZlcigpOyAvLyB0aGlzIGlzIHRoZSBzdGFydGluZyBEZWZlcnJlZCBvYmplY3QgXHJcbiAgICAgICAgICAgICAgICAgICAgbGV0IHRhc2tDb3VudGVyID0gMDtcclxuICAgICAgICAgICAgICAgICAgICBsZXQgaXRlcmF0ZVRhc2tzID0gKCkgPT4ge1xyXG4gICAgICAgICAgICAgICAgICAgICAgICBpZih0eXBlb2YgdGhpcy50YXNrQXJyYXlbdGFza0NvdW50ZXJdICE9IFwidW5kZWZpbmVkXCIpe1xyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgdGhpcy50YXNrQXJyYXlbdGFza0NvdW50ZXJdLnRyaWdnZXIoKVxyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIC50aGVuKCgpPT57XHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHRhc2tDb3VudGVyKys7XHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGl0ZXJhdGVUYXNrcygpO1xyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIH0pOyAgICAgXHJcbiAgICAgICAgICAgICAgICAgICAgICAgIH0gZWxzZSB7XHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBkb25lLnJlc29sdmUoKTtcclxuICAgICAgICAgICAgICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICAgICAgICAgIH07XHJcbiAgICAgICAgICAgICAgICAgICAgaXRlcmF0ZVRhc2tzKCk7XHJcbiAgICAgICAgICAgICAgICAgICAgcmV0dXJuIGRvbmUucHJvbWlzZTtcclxuICAgICAgICAgICAgICAgIH1cclxuICAgICAgICAgICAgfVxyXG4gICAgICAgICk7XHJcbiAgICAgICAgc3VwZXIob3B0aW9ucyk7XHJcbiAgICAgICAgdGhpcy50YXNrQXJyYXkgPSBvcHRpb25zQXJnLnRhc2tBcnJheTtcclxuICAgICAgICB0aGlzLl9vcmFPYmplY3QgPSBuZXcgcGx1Z2lucy5iZWF1dHlsb2cuT3JhKFwiVGFza2NoYWluIGlkbGVcIixcImJsdWVcIik7XHJcbiAgICB9XHJcbiAgICBhZGRUYXNrKHRhc2tBcmc6VGFzayl7XHJcbiAgICAgICAgdGhpcy50YXNrQXJyYXkucHVzaCh0YXNrQXJnKTtcclxuICAgIH07XHJcbiAgICByZW1vdmVUYXNrKHRhc2tBcmc6VGFzayl7XHJcbiAgICAgICAgLy9UT0RPXHJcbiAgICB9O1xyXG4gICAgc2hpZnRUYXNrKCl7XHJcbiAgICAgICAgXHJcbiAgICB9O1xyXG4gICAgdHJpZ2dlcigpe1xyXG4gICAgICAgIHRoaXMuX29yYU9iamVjdC5zdGFydCh0aGlzLm5hbWUgKyBcIiBydW5uaW5nLi4uXCIpO1xyXG4gICAgICAgIHJldHVybiBoZWxwZXJzLnJ1blRhc2sodGhpcyk7XHJcbiAgICB9XHJcbn07Il19 diff --git a/dist/taskbuffer.classes.taskparallel.d.ts b/dist/taskbuffer.classes.taskparallel.d.ts new file mode 100644 index 0000000..99783da --- /dev/null +++ b/dist/taskbuffer.classes.taskparallel.d.ts @@ -0,0 +1,7 @@ +import { Task } from "./taskbuffer.classes.task"; +export declare class Taskparallel extends Task { + taskArray: Task[]; + constructor(optionsArg: { + taskArray: Task[]; + }); +} diff --git a/dist/taskbuffer.classes.taskparallel.js b/dist/taskbuffer.classes.taskparallel.js new file mode 100644 index 0000000..625c6ff --- /dev/null +++ b/dist/taskbuffer.classes.taskparallel.js @@ -0,0 +1,32 @@ +"use strict"; +var __extends = (this && this.__extends) || function (d, b) { + for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); +}; +/// +var plugins = require("./taskbuffer.plugins"); +var taskbuffer_classes_task_1 = require("./taskbuffer.classes.task"); +var Taskparallel = (function (_super) { + __extends(Taskparallel, _super); + function Taskparallel(optionsArg) { + var _this = this; + var options = plugins.lodash.assign(optionsArg, { + taskFunction: function () { + var done = plugins.Q.defer(); + var promiseArray; // stores promises of all tasks, since they run in parallel + _this.taskArray.forEach(function (taskArg) { + promiseArray.push(taskArg.trigger()); + }); + plugins.Q.all(promiseArray) + .then(done.resolve); + return done.promise; + } + }); + _super.call(this, options); + } + return Taskparallel; +}(taskbuffer_classes_task_1.Task)); +exports.Taskparallel = Taskparallel; + +//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRhc2tidWZmZXIuY2xhc3Nlcy50YXNrcGFyYWxsZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUEsNENBQTRDO0FBQzVDLElBQVksT0FBTyxXQUFNLHNCQUN6QixDQUFDLENBRDhDO0FBRS9DLHdDQUFtQiwyQkFFbkIsQ0FBQyxDQUY2QztBQUU5QztJQUFrQyxnQ0FBSTtJQUVsQyxzQkFBWSxVQUVYO1FBSkwsaUJBc0JDO1FBakJPLElBQUksT0FBTyxHQUFHLE9BQU8sQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUMvQixVQUFVLEVBQ1Y7WUFDSSxZQUFZLEVBQUM7Z0JBQ1QsSUFBSSxJQUFJLEdBQUcsT0FBTyxDQUFDLENBQUMsQ0FBQyxLQUFLLEVBQUUsQ0FBQztnQkFDN0IsSUFBSSxZQUFZLENBQUMsQ0FBQywyREFBMkQ7Z0JBQzdFLEtBQUksQ0FBQyxTQUFTLENBQUMsT0FBTyxDQUFDLFVBQVMsT0FBWTtvQkFDeEMsWUFBWSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsT0FBTyxFQUFFLENBQUMsQ0FBQztnQkFDekMsQ0FBQyxDQUFDLENBQUE7Z0JBQ0YsT0FBTyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsWUFBWSxDQUFDO3FCQUN0QixJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDO2dCQUN4QixNQUFNLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQztZQUN4QixDQUFDO1NBQ0osQ0FDSixDQUFBO1FBQ0Qsa0JBQU0sT0FBTyxDQUFDLENBQUM7SUFDbkIsQ0FBQztJQUNMLG1CQUFDO0FBQUQsQ0F0QkEsQUFzQkMsQ0F0QmlDLDhCQUFJLEdBc0JyQztBQXRCWSxvQkFBWSxlQXNCeEIsQ0FBQSIsImZpbGUiOiJ0YXNrYnVmZmVyLmNsYXNzZXMudGFza3BhcmFsbGVsLmpzIiwic291cmNlc0NvbnRlbnQiOlsiLy8vIDxyZWZlcmVuY2UgcGF0aD1cIi4vdHlwaW5ncy9tYWluLmQudHNcIiAvPlxyXG5pbXBvcnQgKiBhcyBwbHVnaW5zIGZyb20gXCIuL3Rhc2tidWZmZXIucGx1Z2luc1wiXHJcbmltcG9ydCAqIGFzIGhlbHBlcnMgZnJvbSBcIi4vdGFza2J1ZmZlci5jbGFzc2VzLmhlbHBlcnNcIlxyXG5pbXBvcnQge1Rhc2t9IGZyb20gXCIuL3Rhc2tidWZmZXIuY2xhc3Nlcy50YXNrXCJcclxuXHJcbmV4cG9ydCBjbGFzcyBUYXNrcGFyYWxsZWwgZXh0ZW5kcyBUYXNrIHtcclxuICAgIHRhc2tBcnJheTpUYXNrW107XHJcbiAgICBjb25zdHJ1Y3RvcihvcHRpb25zQXJnOntcclxuICAgICAgICB0YXNrQXJyYXk6VGFza1tdXHJcbiAgICB9KXtcclxuICAgICAgICBsZXQgb3B0aW9ucyA9IHBsdWdpbnMubG9kYXNoLmFzc2lnbihcclxuICAgICAgICAgICAgb3B0aW9uc0FyZyxcclxuICAgICAgICAgICAge1xyXG4gICAgICAgICAgICAgICAgdGFza0Z1bmN0aW9uOigpID0+IHtcclxuICAgICAgICAgICAgICAgICAgICBsZXQgZG9uZSA9IHBsdWdpbnMuUS5kZWZlcigpO1xyXG4gICAgICAgICAgICAgICAgICAgIGxldCBwcm9taXNlQXJyYXk7IC8vIHN0b3JlcyBwcm9taXNlcyBvZiBhbGwgdGFza3MsIHNpbmNlIHRoZXkgcnVuIGluIHBhcmFsbGVsXHJcbiAgICAgICAgICAgICAgICAgICAgdGhpcy50YXNrQXJyYXkuZm9yRWFjaChmdW5jdGlvbih0YXNrQXJnOlRhc2spe1xyXG4gICAgICAgICAgICAgICAgICAgICAgICBwcm9taXNlQXJyYXkucHVzaCh0YXNrQXJnLnRyaWdnZXIoKSk7XHJcbiAgICAgICAgICAgICAgICAgICAgfSlcclxuICAgICAgICAgICAgICAgICAgICBwbHVnaW5zLlEuYWxsKHByb21pc2VBcnJheSlcclxuICAgICAgICAgICAgICAgICAgICAgICAgLnRoZW4oZG9uZS5yZXNvbHZlKTtcclxuICAgICAgICAgICAgICAgICAgICByZXR1cm4gZG9uZS5wcm9taXNlO1xyXG4gICAgICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgKVxyXG4gICAgICAgIHN1cGVyKG9wdGlvbnMpO1xyXG4gICAgfVxyXG59XHJcblxyXG4iXX0= diff --git a/dist/taskbuffer.classes.taskspace.d.ts b/dist/taskbuffer.classes.taskspace.d.ts index e69de29..d155af1 100644 --- a/dist/taskbuffer.classes.taskspace.d.ts +++ b/dist/taskbuffer.classes.taskspace.d.ts @@ -0,0 +1,2 @@ +export declare class Taskspace { +} diff --git a/dist/taskbuffer.classes.taskspace.js b/dist/taskbuffer.classes.taskspace.js index 35c8d40..6d85bcc 100644 --- a/dist/taskbuffer.classes.taskspace.js +++ b/dist/taskbuffer.classes.taskspace.js @@ -1,3 +1,9 @@ +"use strict"; +var Taskspace = (function () { + function Taskspace() { + } + return Taskspace; +}()); +exports.Taskspace = Taskspace; - -//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsImZpbGUiOiJ0YXNrYnVmZmVyLmNsYXNzZXMudGFza3NwYWNlLmpzIiwic291cmNlc0NvbnRlbnQiOltdfQ== +//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRhc2tidWZmZXIuY2xhc3Nlcy50YXNrc3BhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUlBO0lBQUE7SUFFQSxDQUFDO0lBQUQsZ0JBQUM7QUFBRCxDQUZBLEFBRUMsSUFBQTtBQUZZLGlCQUFTLFlBRXJCLENBQUEiLCJmaWxlIjoidGFza2J1ZmZlci5jbGFzc2VzLnRhc2tzcGFjZS5qcyIsInNvdXJjZXNDb250ZW50IjpbIi8vLyA8cmVmZXJlbmNlIHBhdGg9XCIuL3R5cGluZ3MvbWFpbi5kLnRzXCIgLz5cclxuaW1wb3J0ICogYXMgcGx1Z2lucyBmcm9tIFwiLi90YXNrYnVmZmVyLnBsdWdpbnNcIlxyXG5pbXBvcnQgKiBhcyBoZWxwZXJzIGZyb20gXCIuL3Rhc2tidWZmZXIuY2xhc3Nlcy5oZWxwZXJzXCJcclxuXHJcbmV4cG9ydCBjbGFzcyBUYXNrc3BhY2Uge1xyXG4gICAgXHJcbn0iXX0= diff --git a/ts/index.ts b/ts/index.ts index a2ce4a4..610a2fe 100644 --- a/ts/index.ts +++ b/ts/index.ts @@ -1,5 +1,8 @@ /// -export * from "./taskbuffer.classes"; +export {Task} from "./taskbuffer.classes.task"; +export {Taskchain} from "./taskbuffer.classes.taskchain"; +export {Taskparallel} from "./taskbuffer.classes.taskparallel"; +export {Taskspace} from "./taskbuffer.classes.taskspace"; // import for naming only import "./taskbuffer.classes.helpers" \ No newline at end of file diff --git a/ts/taskbuffer.classes.helpers.ts b/ts/taskbuffer.classes.helpers.ts index 12faaad..bf4a9ae 100644 --- a/ts/taskbuffer.classes.helpers.ts +++ b/ts/taskbuffer.classes.helpers.ts @@ -1,6 +1,6 @@ /// import plugins = require("./taskbuffer.plugins"); -import {Task} from "./taskbuffer.classes" +import {Task} from "./taskbuffer.classes.task"; export let emptyTaskFunction = function(){ let done = plugins.Q.defer(); diff --git a/ts/taskbuffer.classes.taskchain.ts b/ts/taskbuffer.classes.taskchain.ts index 787dcc1..b291aad 100644 --- a/ts/taskbuffer.classes.taskchain.ts +++ b/ts/taskbuffer.classes.taskchain.ts @@ -1,6 +1,6 @@ /// import * as plugins from "./taskbuffer.plugins"; -import {Task} from "./taskbuffer.classes"; +import {Task} from "./taskbuffer.classes.task"; import helpers = require("./taskbuffer.classes.helpers"); export class Taskchain extends Task { @@ -55,14 +55,4 @@ export class Taskchain extends Task { this._oraObject.start(this.name + " running..."); return helpers.runTask(this); } -}; - -let myTask = new Taskchain( - { - taskArray: [ - new Task({ - taskFunction:function(){} - }) - ] - } -); \ No newline at end of file +}; \ No newline at end of file diff --git a/ts/taskbuffer.classes.taskparallel.ts b/ts/taskbuffer.classes.taskparallel.ts new file mode 100644 index 0000000..75c1b8c --- /dev/null +++ b/ts/taskbuffer.classes.taskparallel.ts @@ -0,0 +1,29 @@ +/// +import * as plugins from "./taskbuffer.plugins" +import * as helpers from "./taskbuffer.classes.helpers" +import {Task} from "./taskbuffer.classes.task" + +export class Taskparallel extends Task { + taskArray:Task[]; + constructor(optionsArg:{ + taskArray:Task[] + }){ + let options = plugins.lodash.assign( + optionsArg, + { + taskFunction:() => { + let done = plugins.Q.defer(); + let promiseArray; // stores promises of all tasks, since they run in parallel + this.taskArray.forEach(function(taskArg:Task){ + promiseArray.push(taskArg.trigger()); + }) + plugins.Q.all(promiseArray) + .then(done.resolve); + return done.promise; + } + } + ) + super(options); + } +} + diff --git a/ts/taskbuffer.classes.taskspace.ts b/ts/taskbuffer.classes.taskspace.ts index e69de29..51d1726 100644 --- a/ts/taskbuffer.classes.taskspace.ts +++ b/ts/taskbuffer.classes.taskspace.ts @@ -0,0 +1,7 @@ +/// +import * as plugins from "./taskbuffer.plugins" +import * as helpers from "./taskbuffer.classes.helpers" + +export class Taskspace { + +} \ No newline at end of file diff --git a/ts/taskbuffer.classes.ts b/ts/taskbuffer.classes.ts deleted file mode 100644 index 21a01b3..0000000 --- a/ts/taskbuffer.classes.ts +++ /dev/null @@ -1,2 +0,0 @@ -export * from "./taskbuffer.classes.task" -export * from "./taskbuffer.classes.taskchain"