UNPKG

@theia/task

Version:

Theia - Task extension. This extension adds support for executing raw or terminal processes in the backend.

125 lines 4.42 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.TaskManager = void 0; const tslib_1 = require("tslib"); // ***************************************************************************** // Copyright (C) 2017 Ericsson and others. // // This program and the accompanying materials are made available under the // terms of the Eclipse Public License v. 2.0 which is available at // http://www.eclipse.org/legal/epl-2.0. // // This Source Code may also be made available under the following Secondary // Licenses when the conditions for such availability set forth in the Eclipse // Public License v. 2.0 are satisfied: GNU General Public License, version 2 // with the GNU Classpath Exception which is available at // https://www.gnu.org/software/classpath/license.html. // // SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-only WITH Classpath-exception-2.0 // ***************************************************************************** const inversify_1 = require("@theia/core/shared/inversify"); const common_1 = require("@theia/core/lib/common"); // inspired by process-manager.ts /** * The {@link TaskManager} is the common component responsible for managing running tasks. */ let TaskManager = class TaskManager { constructor(logger) { this.logger = logger; /** contains all running tasks */ this.tasks = new Map(); /** contains running tasks per context */ this.tasksPerCtx = new Map(); /** each task has this unique task id, for this back-end */ this.id = -1; /** * Emit when a registered task is deleted. */ this.deleteEmitter = new common_1.Emitter(); } /** * Registers a new task (in the given context if present). Each registered * task is considered to be currently running. * @param task the new task. * @param ctx the provided context. * * @returns the registration id for the given task. */ register(task, ctx) { const id = ++this.id; this.tasks.set(id, task); if (ctx) { let tks = this.tasksPerCtx.get(ctx); if (tks === undefined) { tks = []; } tks.push(task); this.tasksPerCtx.set(ctx, tks); } return id; } /** * Try to retrieve the registered task for the given id. * @param id the task registration id. * * @returns the task or `undefined` if no task was registered for the given id. */ get(id) { return this.tasks.get(id); } /** * Returns all running tasks. If a context is provided, filter-down to * only tasks started from that context. * @param ctx the task execution context. * * @returns all running tasks for the given context or `undefined` if no tasks are registered for the given context. */ getTasks(ctx) { if (!ctx) { return [...this.tasks.values()]; } else { if (this.tasksPerCtx.has(ctx)) { return this.tasksPerCtx.get(ctx); } } } /** * Delete the given task from the task manager. * @param task the task to delete. */ delete(task) { this.tasks.delete(task.id); const ctx = task.context; if (ctx && this.tasksPerCtx.has(ctx)) { const tasksForWS = this.tasksPerCtx.get(ctx); if (tasksForWS !== undefined) { const idx = tasksForWS.indexOf(task); if (idx !== -1) { tasksForWS.splice(idx, 1); } } } this.deleteEmitter.fire(task.id); } get onDelete() { return this.deleteEmitter.event; } /** * Is triggered on application stop to cleanup all ongoing tasks. */ onStop() { this.tasks.forEach((task, id) => { this.logger.debug(`Task Backend application: onStop(): cleaning task id: ${id}`); this.delete(task); }); } }; exports.TaskManager = TaskManager; exports.TaskManager = TaskManager = tslib_1.__decorate([ (0, inversify_1.injectable)(), tslib_1.__param(0, (0, inversify_1.inject)(common_1.ILogger)), tslib_1.__param(0, (0, inversify_1.named)('task')), tslib_1.__metadata("design:paramtypes", [Object]) ], TaskManager); //# sourceMappingURL=task-manager.js.map