deploy: current vibn theia state
Made-with: Cursor
This commit is contained in:
129
packages/task/src/node/task-manager.ts
Normal file
129
packages/task/src/node/task-manager.ts
Normal file
@@ -0,0 +1,129 @@
|
||||
// *****************************************************************************
|
||||
// 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
|
||||
// *****************************************************************************
|
||||
import { inject, injectable, named } from '@theia/core/shared/inversify';
|
||||
import { Emitter, Event, ILogger } from '@theia/core/lib/common';
|
||||
import { BackendApplicationContribution } from '@theia/core/lib/node';
|
||||
import { Task } from './task';
|
||||
import { ManagedTaskManager } from '../common';
|
||||
|
||||
// inspired by process-manager.ts
|
||||
|
||||
/**
|
||||
* The {@link TaskManager} is the common component responsible for managing running tasks.
|
||||
*/
|
||||
@injectable()
|
||||
export class TaskManager implements BackendApplicationContribution, ManagedTaskManager<Task> {
|
||||
|
||||
/** contains all running tasks */
|
||||
protected readonly tasks: Map<number, Task> = new Map();
|
||||
/** contains running tasks per context */
|
||||
protected readonly tasksPerCtx: Map<string, Task[]> = new Map();
|
||||
/** each task has this unique task id, for this back-end */
|
||||
protected id: number = -1;
|
||||
/**
|
||||
* Emit when a registered task is deleted.
|
||||
*/
|
||||
protected readonly deleteEmitter = new Emitter<number>();
|
||||
|
||||
constructor(
|
||||
@inject(ILogger) @named('task') protected readonly logger: ILogger
|
||||
) { }
|
||||
|
||||
/**
|
||||
* 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: Task, ctx?: string): number {
|
||||
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: number): Task | undefined {
|
||||
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?: string): Task[] | undefined {
|
||||
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: Task): void {
|
||||
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(): Event<number> {
|
||||
return this.deleteEmitter.event;
|
||||
}
|
||||
|
||||
/**
|
||||
* Is triggered on application stop to cleanup all ongoing tasks.
|
||||
*/
|
||||
onStop(): void {
|
||||
this.tasks.forEach((task: Task, id: number) => {
|
||||
this.logger.debug(`Task Backend application: onStop(): cleaning task id: ${id}`);
|
||||
this.delete(task);
|
||||
});
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user