@theia/task 1.45.1 → 1.46.0-next.72
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +193 -193
- package/lib/browser/index.d.ts +6 -6
- package/lib/browser/index.js +33 -33
- package/lib/browser/process/process-task-contribution.d.ts +6 -6
- package/lib/browser/process/process-task-contribution.js +43 -43
- package/lib/browser/process/process-task-frontend-module.d.ts +2 -2
- package/lib/browser/process/process-task-frontend-module.js +27 -27
- package/lib/browser/process/process-task-resolver.d.ts +17 -17
- package/lib/browser/process/process-task-resolver.js +101 -101
- package/lib/browser/provided-task-configurations.d.ts +43 -43
- package/lib/browser/provided-task-configurations.js +213 -213
- package/lib/browser/provided-task-configurations.spec.d.ts +1 -1
- package/lib/browser/provided-task-configurations.spec.js +43 -43
- package/lib/browser/quick-open-task.d.ts +144 -144
- package/lib/browser/quick-open-task.d.ts.map +1 -1
- package/lib/browser/quick-open-task.js +752 -748
- package/lib/browser/quick-open-task.js.map +1 -1
- package/lib/browser/task-configuration-manager.d.ts +64 -64
- package/lib/browser/task-configuration-manager.js +261 -261
- package/lib/browser/task-configuration-model.d.ts +32 -32
- package/lib/browser/task-configuration-model.js +79 -79
- package/lib/browser/task-configurations.d.ts +127 -127
- package/lib/browser/task-configurations.js +486 -486
- package/lib/browser/task-contribution.d.ts +182 -182
- package/lib/browser/task-contribution.js +206 -206
- package/lib/browser/task-definition-registry.d.ts +38 -38
- package/lib/browser/task-definition-registry.js +134 -134
- package/lib/browser/task-definition-registry.spec.d.ts +1 -1
- package/lib/browser/task-definition-registry.spec.js +170 -170
- package/lib/browser/task-frontend-contribution.d.ts +56 -56
- package/lib/browser/task-frontend-contribution.js +358 -358
- package/lib/browser/task-frontend-module.d.ts +5 -5
- package/lib/browser/task-frontend-module.js +79 -79
- package/lib/browser/task-name-resolver.d.ts +13 -13
- package/lib/browser/task-name-resolver.js +67 -67
- package/lib/browser/task-node.d.ts +9 -9
- package/lib/browser/task-node.js +17 -17
- package/lib/browser/task-preferences.d.ts +4 -4
- package/lib/browser/task-preferences.js +40 -40
- package/lib/browser/task-problem-matcher-registry.d.ts +40 -40
- package/lib/browser/task-problem-matcher-registry.js +309 -309
- package/lib/browser/task-problem-pattern-registry.d.ts +23 -23
- package/lib/browser/task-problem-pattern-registry.js +210 -210
- package/lib/browser/task-schema-updater.d.ts +58 -58
- package/lib/browser/task-schema-updater.js +688 -688
- package/lib/browser/task-service.d.ts +279 -279
- package/lib/browser/task-service.js +1119 -1119
- package/lib/browser/task-source-resolver.d.ts +9 -9
- package/lib/browser/task-source-resolver.js +51 -51
- package/lib/browser/task-templates.d.ts +13 -13
- package/lib/browser/task-templates.js +161 -161
- package/lib/browser/task-terminal-widget-manager.d.ts +44 -44
- package/lib/browser/task-terminal-widget-manager.js +228 -228
- package/lib/browser/tasks-monaco-contribution.d.ts +1 -1
- package/lib/browser/tasks-monaco-contribution.js +27 -27
- package/lib/common/index.d.ts +4 -4
- package/lib/common/index.js +31 -31
- package/lib/common/problem-matcher-protocol.d.ts +124 -124
- package/lib/common/problem-matcher-protocol.js +132 -132
- package/lib/common/process/task-protocol.d.ts +68 -68
- package/lib/common/process/task-protocol.js +33 -33
- package/lib/common/task-common-module.d.ts +7 -7
- package/lib/common/task-common-module.js +33 -33
- package/lib/common/task-protocol.d.ts +192 -192
- package/lib/common/task-protocol.js +137 -137
- package/lib/common/task-util.d.ts +22 -22
- package/lib/common/task-util.js +46 -46
- package/lib/common/task-watcher.d.ts +17 -17
- package/lib/common/task-watcher.js +86 -86
- package/lib/node/custom/custom-task-runner-backend-module.d.ts +2 -2
- package/lib/node/custom/custom-task-runner-backend-module.js +36 -36
- package/lib/node/custom/custom-task-runner-contribution.d.ts +6 -6
- package/lib/node/custom/custom-task-runner-contribution.js +42 -42
- package/lib/node/custom/custom-task-runner.d.ts +15 -15
- package/lib/node/custom/custom-task-runner.js +69 -69
- package/lib/node/custom/custom-task.d.ts +20 -20
- package/lib/node/custom/custom-task.js +78 -78
- package/lib/node/index.d.ts +3 -3
- package/lib/node/index.js +30 -30
- package/lib/node/process/process-task-runner-backend-module.d.ts +2 -2
- package/lib/node/process/process-task-runner-backend-module.js +36 -36
- package/lib/node/process/process-task-runner-contribution.d.ts +6 -6
- package/lib/node/process/process-task-runner-contribution.js +43 -43
- package/lib/node/process/process-task-runner.d.ts +60 -60
- package/lib/node/process/process-task-runner.js +355 -355
- package/lib/node/process/process-task.d.ts +26 -26
- package/lib/node/process/process-task.js +135 -135
- package/lib/node/process/process-task.spec.d.ts +1 -1
- package/lib/node/process/process-task.spec.js +29 -29
- package/lib/node/task-abstract-line-matcher.d.ts +49 -49
- package/lib/node/task-abstract-line-matcher.js +273 -273
- package/lib/node/task-backend-application-contribution.d.ts +8 -8
- package/lib/node/task-backend-application-contribution.js +48 -48
- package/lib/node/task-backend-module.d.ts +3 -3
- package/lib/node/task-backend-module.js +50 -50
- package/lib/node/task-line-matchers.d.ts +27 -27
- package/lib/node/task-line-matchers.js +121 -121
- package/lib/node/task-manager.d.ts +55 -55
- package/lib/node/task-manager.js +135 -135
- package/lib/node/task-problem-collector.d.ts +10 -10
- package/lib/node/task-problem-collector.js +57 -57
- package/lib/node/task-problem-collector.spec.d.ts +1 -1
- package/lib/node/task-problem-collector.spec.js +310 -310
- package/lib/node/task-runner-protocol.d.ts +16 -16
- package/lib/node/task-runner-protocol.js +19 -19
- package/lib/node/task-runner.d.ts +50 -50
- package/lib/node/task-runner.js +97 -97
- package/lib/node/task-server.d.ts +39 -39
- package/lib/node/task-server.js +237 -237
- package/lib/node/task-server.slow-spec.d.ts +1 -1
- package/lib/node/task-server.slow-spec.js +395 -395
- package/lib/node/task.d.ts +50 -50
- package/lib/node/task.js +77 -77
- package/lib/node/test/task-test-container.d.ts +2 -2
- package/lib/node/test/task-test-container.js +58 -58
- package/package.json +14 -14
- package/src/browser/index.ts +22 -22
- package/src/browser/process/process-task-contribution.ts +31 -31
- package/src/browser/process/process-task-frontend-module.ts +27 -27
- package/src/browser/process/process-task-resolver.ts +89 -89
- package/src/browser/provided-task-configurations.spec.ts +46 -46
- package/src/browser/provided-task-configurations.ts +213 -213
- package/src/browser/quick-open-task.ts +831 -827
- package/src/browser/style/index.css +19 -19
- package/src/browser/task-configuration-manager.ts +256 -256
- package/src/browser/task-configuration-model.ts +101 -101
- package/src/browser/task-configurations.ts +508 -508
- package/src/browser/task-contribution.ts +266 -266
- package/src/browser/task-definition-registry.spec.ts +203 -203
- package/src/browser/task-definition-registry.ts +131 -131
- package/src/browser/task-frontend-contribution.ts +402 -402
- package/src/browser/task-frontend-module.ts +86 -86
- package/src/browser/task-name-resolver.ts +55 -55
- package/src/browser/task-node.ts +37 -37
- package/src/browser/task-preferences.ts +40 -40
- package/src/browser/task-problem-matcher-registry.ts +308 -308
- package/src/browser/task-problem-pattern-registry.ts +196 -196
- package/src/browser/task-schema-updater.ts +701 -701
- package/src/browser/task-service.ts +1164 -1164
- package/src/browser/task-source-resolver.ts +36 -36
- package/src/browser/task-templates.ts +168 -168
- package/src/browser/task-terminal-widget-manager.ts +224 -224
- package/src/browser/tasks-monaco-contribution.ts +27 -27
- package/src/common/index.ts +20 -20
- package/src/common/problem-matcher-protocol.ts +234 -234
- package/src/common/process/task-protocol.ts +97 -97
- package/src/common/task-common-module.ts +34 -34
- package/src/common/task-protocol.ts +317 -317
- package/src/common/task-util.ts +43 -43
- package/src/common/task-watcher.ts +78 -78
- package/src/node/custom/custom-task-runner-backend-module.ts +37 -37
- package/src/node/custom/custom-task-runner-contribution.ts +30 -30
- package/src/node/custom/custom-task-runner.ts +60 -60
- package/src/node/custom/custom-task.ts +73 -73
- package/src/node/index.ts +19 -19
- package/src/node/process/process-task-runner-backend-module.ts +37 -37
- package/src/node/process/process-task-runner-contribution.ts +31 -31
- package/src/node/process/process-task-runner.ts +371 -371
- package/src/node/process/process-task.spec.ts +30 -30
- package/src/node/process/process-task.ts +144 -144
- package/src/node/task-abstract-line-matcher.ts +312 -312
- package/src/node/task-backend-application-contribution.ts +36 -36
- package/src/node/task-backend-module.ts +57 -57
- package/src/node/task-line-matchers.ts +127 -127
- package/src/node/task-manager.ts +129 -129
- package/src/node/task-problem-collector.spec.ts +338 -338
- package/src/node/task-problem-collector.ts +62 -62
- package/src/node/task-runner-protocol.ts +33 -33
- package/src/node/task-runner.ts +96 -96
- package/src/node/task-server.slow-spec.ts +444 -444
- package/src/node/task-server.ts +263 -263
- package/src/node/task.ts +103 -103
- package/src/node/test/task-test-container.ts +63 -63
|
@@ -1,80 +1,80 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
// *****************************************************************************
|
|
3
|
-
// Copyright (C) 2019 Ericsson and others.
|
|
4
|
-
//
|
|
5
|
-
// This program and the accompanying materials are made available under the
|
|
6
|
-
// terms of the Eclipse Public License v. 2.0 which is available at
|
|
7
|
-
// http://www.eclipse.org/legal/epl-2.0.
|
|
8
|
-
//
|
|
9
|
-
// This Source Code may also be made available under the following Secondary
|
|
10
|
-
// Licenses when the conditions for such availability set forth in the Eclipse
|
|
11
|
-
// Public License v. 2.0 are satisfied: GNU General Public License, version 2
|
|
12
|
-
// with the GNU Classpath Exception which is available at
|
|
13
|
-
// https://www.gnu.org/software/classpath/license.html.
|
|
14
|
-
//
|
|
15
|
-
// SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-only WITH Classpath-exception-2.0
|
|
16
|
-
// *****************************************************************************
|
|
17
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
18
|
-
exports.TaskConfigurationModel = void 0;
|
|
19
|
-
const event_1 = require("@theia/core/lib/common/event");
|
|
20
|
-
const disposable_1 = require("@theia/core/lib/common/disposable");
|
|
21
|
-
const browser_1 = require("@theia/core/lib/browser");
|
|
22
|
-
const common_1 = require("@theia/core/lib/common");
|
|
23
|
-
/**
|
|
24
|
-
* Holds the task configurations associated with a particular file. Uses an editor model to facilitate
|
|
25
|
-
* non-destructive editing and coordination with editing the file by hand.
|
|
26
|
-
*/
|
|
27
|
-
class TaskConfigurationModel {
|
|
28
|
-
constructor(scope, preferences) {
|
|
29
|
-
this.scope = scope;
|
|
30
|
-
this.preferences = preferences;
|
|
31
|
-
this.onDidChangeEmitter = new event_1.Emitter();
|
|
32
|
-
this.onDidChange = this.onDidChangeEmitter.event;
|
|
33
|
-
this.toDispose = new disposable_1.DisposableCollection(this.onDidChangeEmitter);
|
|
34
|
-
this.reconcile();
|
|
35
|
-
this.toDispose.push(this.preferences.onDidPreferencesChanged((e) => {
|
|
36
|
-
const change = e['tasks'];
|
|
37
|
-
if (change && browser_1.PreferenceProviderDataChange.affects(change, this.getWorkspaceFolder())) {
|
|
38
|
-
this.reconcile();
|
|
39
|
-
}
|
|
40
|
-
}));
|
|
41
|
-
}
|
|
42
|
-
get uri() {
|
|
43
|
-
return this.json.uri;
|
|
44
|
-
}
|
|
45
|
-
getWorkspaceFolder() {
|
|
46
|
-
return typeof this.scope === 'string' ? this.scope : undefined;
|
|
47
|
-
}
|
|
48
|
-
dispose() {
|
|
49
|
-
this.toDispose.dispose();
|
|
50
|
-
}
|
|
51
|
-
get onDispose() {
|
|
52
|
-
return this.toDispose.onDispose;
|
|
53
|
-
}
|
|
54
|
-
get configurations() {
|
|
55
|
-
return this.json.configurations;
|
|
56
|
-
}
|
|
57
|
-
reconcile() {
|
|
58
|
-
this.json = this.parseConfigurations();
|
|
59
|
-
this.onDidChangeEmitter.fire(undefined);
|
|
60
|
-
}
|
|
61
|
-
setConfigurations(value) {
|
|
62
|
-
return this.preferences.setPreference('tasks.tasks', value, this.getWorkspaceFolder());
|
|
63
|
-
}
|
|
64
|
-
parseConfigurations() {
|
|
65
|
-
const configurations = [];
|
|
66
|
-
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
67
|
-
const { configUri, value } = this.preferences.resolve('tasks', this.getWorkspaceFolder());
|
|
68
|
-
if ((0, common_1.isObject)(value) && Array.isArray(value.tasks)) {
|
|
69
|
-
for (const taskConfig of value.tasks) {
|
|
70
|
-
configurations.push(taskConfig);
|
|
71
|
-
}
|
|
72
|
-
}
|
|
73
|
-
return {
|
|
74
|
-
uri: configUri,
|
|
75
|
-
configurations
|
|
76
|
-
};
|
|
77
|
-
}
|
|
78
|
-
}
|
|
79
|
-
exports.TaskConfigurationModel = TaskConfigurationModel;
|
|
1
|
+
"use strict";
|
|
2
|
+
// *****************************************************************************
|
|
3
|
+
// Copyright (C) 2019 Ericsson and others.
|
|
4
|
+
//
|
|
5
|
+
// This program and the accompanying materials are made available under the
|
|
6
|
+
// terms of the Eclipse Public License v. 2.0 which is available at
|
|
7
|
+
// http://www.eclipse.org/legal/epl-2.0.
|
|
8
|
+
//
|
|
9
|
+
// This Source Code may also be made available under the following Secondary
|
|
10
|
+
// Licenses when the conditions for such availability set forth in the Eclipse
|
|
11
|
+
// Public License v. 2.0 are satisfied: GNU General Public License, version 2
|
|
12
|
+
// with the GNU Classpath Exception which is available at
|
|
13
|
+
// https://www.gnu.org/software/classpath/license.html.
|
|
14
|
+
//
|
|
15
|
+
// SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-only WITH Classpath-exception-2.0
|
|
16
|
+
// *****************************************************************************
|
|
17
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
18
|
+
exports.TaskConfigurationModel = void 0;
|
|
19
|
+
const event_1 = require("@theia/core/lib/common/event");
|
|
20
|
+
const disposable_1 = require("@theia/core/lib/common/disposable");
|
|
21
|
+
const browser_1 = require("@theia/core/lib/browser");
|
|
22
|
+
const common_1 = require("@theia/core/lib/common");
|
|
23
|
+
/**
|
|
24
|
+
* Holds the task configurations associated with a particular file. Uses an editor model to facilitate
|
|
25
|
+
* non-destructive editing and coordination with editing the file by hand.
|
|
26
|
+
*/
|
|
27
|
+
class TaskConfigurationModel {
|
|
28
|
+
constructor(scope, preferences) {
|
|
29
|
+
this.scope = scope;
|
|
30
|
+
this.preferences = preferences;
|
|
31
|
+
this.onDidChangeEmitter = new event_1.Emitter();
|
|
32
|
+
this.onDidChange = this.onDidChangeEmitter.event;
|
|
33
|
+
this.toDispose = new disposable_1.DisposableCollection(this.onDidChangeEmitter);
|
|
34
|
+
this.reconcile();
|
|
35
|
+
this.toDispose.push(this.preferences.onDidPreferencesChanged((e) => {
|
|
36
|
+
const change = e['tasks'];
|
|
37
|
+
if (change && browser_1.PreferenceProviderDataChange.affects(change, this.getWorkspaceFolder())) {
|
|
38
|
+
this.reconcile();
|
|
39
|
+
}
|
|
40
|
+
}));
|
|
41
|
+
}
|
|
42
|
+
get uri() {
|
|
43
|
+
return this.json.uri;
|
|
44
|
+
}
|
|
45
|
+
getWorkspaceFolder() {
|
|
46
|
+
return typeof this.scope === 'string' ? this.scope : undefined;
|
|
47
|
+
}
|
|
48
|
+
dispose() {
|
|
49
|
+
this.toDispose.dispose();
|
|
50
|
+
}
|
|
51
|
+
get onDispose() {
|
|
52
|
+
return this.toDispose.onDispose;
|
|
53
|
+
}
|
|
54
|
+
get configurations() {
|
|
55
|
+
return this.json.configurations;
|
|
56
|
+
}
|
|
57
|
+
reconcile() {
|
|
58
|
+
this.json = this.parseConfigurations();
|
|
59
|
+
this.onDidChangeEmitter.fire(undefined);
|
|
60
|
+
}
|
|
61
|
+
setConfigurations(value) {
|
|
62
|
+
return this.preferences.setPreference('tasks.tasks', value, this.getWorkspaceFolder());
|
|
63
|
+
}
|
|
64
|
+
parseConfigurations() {
|
|
65
|
+
const configurations = [];
|
|
66
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
67
|
+
const { configUri, value } = this.preferences.resolve('tasks', this.getWorkspaceFolder());
|
|
68
|
+
if ((0, common_1.isObject)(value) && Array.isArray(value.tasks)) {
|
|
69
|
+
for (const taskConfig of value.tasks) {
|
|
70
|
+
configurations.push(taskConfig);
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
return {
|
|
74
|
+
uri: configUri,
|
|
75
|
+
configurations
|
|
76
|
+
};
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
exports.TaskConfigurationModel = TaskConfigurationModel;
|
|
80
80
|
//# sourceMappingURL=task-configuration-model.js.map
|
|
@@ -1,128 +1,128 @@
|
|
|
1
|
-
import { TaskConfiguration, TaskCustomization, TaskConfigurationScope } from '../common';
|
|
2
|
-
import { TaskDefinitionRegistry } from './task-definition-registry';
|
|
3
|
-
import { ProvidedTaskConfigurations } from './provided-task-configurations';
|
|
4
|
-
import { TaskConfigurationManager, TasksChange } from './task-configuration-manager';
|
|
5
|
-
import { TaskSchemaUpdater } from './task-schema-updater';
|
|
6
|
-
import { TaskSourceResolver } from './task-source-resolver';
|
|
7
|
-
import { Disposable, DisposableCollection } from '@theia/core/lib/common';
|
|
8
|
-
import { WorkspaceService } from '@theia/workspace/lib/browser';
|
|
9
|
-
export interface TaskConfigurationClient {
|
|
10
|
-
/**
|
|
11
|
-
* The task configuration file has changed, so a client might want to refresh its configurations
|
|
12
|
-
* @returns an array of strings, each one being a task label
|
|
13
|
-
*/
|
|
14
|
-
taskConfigurationChanged: (event: string[]) => void;
|
|
15
|
-
}
|
|
16
|
-
/**
|
|
17
|
-
* Watches a tasks.json configuration file and provides a parsed version of the contained task configurations
|
|
18
|
-
*/
|
|
19
|
-
export declare class TaskConfigurations implements Disposable {
|
|
20
|
-
protected readonly toDispose: DisposableCollection;
|
|
21
|
-
/**
|
|
22
|
-
* Map of source (path of root folder that the task configs come from) and task config map.
|
|
23
|
-
* For the inner map (i.e., task config map), the key is task label and value TaskConfiguration
|
|
24
|
-
*/
|
|
25
|
-
protected tasksMap: Map<string, Map<string, TaskConfiguration>>;
|
|
26
|
-
/**
|
|
27
|
-
* Map of source (path of root folder that the task configs come from) and task customizations map.
|
|
28
|
-
*/
|
|
29
|
-
protected taskCustomizationMap: Map<string, TaskCustomization[]>;
|
|
30
|
-
protected client: TaskConfigurationClient | undefined;
|
|
31
|
-
/**
|
|
32
|
-
* Map of source (path of root folder that the task configs come from) and raw task configurations / customizations.
|
|
33
|
-
* This map is used to store the data from `tasks.json` files in workspace.
|
|
34
|
-
*/
|
|
35
|
-
private rawTaskConfigurations;
|
|
36
|
-
protected readonly workspaceService: WorkspaceService;
|
|
37
|
-
protected readonly taskDefinitionRegistry: TaskDefinitionRegistry;
|
|
38
|
-
protected readonly providedTaskConfigurations: ProvidedTaskConfigurations;
|
|
39
|
-
protected readonly taskConfigurationManager: TaskConfigurationManager;
|
|
40
|
-
protected readonly taskSchemaUpdater: TaskSchemaUpdater;
|
|
41
|
-
protected readonly taskSourceResolver: TaskSourceResolver;
|
|
42
|
-
constructor();
|
|
43
|
-
protected init(): void;
|
|
44
|
-
setClient(client: TaskConfigurationClient): void;
|
|
45
|
-
dispose(): void;
|
|
46
|
-
/** returns the list of known task labels */
|
|
47
|
-
getTaskLabels(): string[];
|
|
48
|
-
/**
|
|
49
|
-
* returns a collection of known tasks, which includes:
|
|
50
|
-
* - all the configured tasks in `tasks.json`, and
|
|
51
|
-
* - the customized detected tasks.
|
|
52
|
-
*
|
|
53
|
-
* The invalid task configs are not returned.
|
|
54
|
-
*/
|
|
55
|
-
getTasks(token: number): Promise<TaskConfiguration[]>;
|
|
56
|
-
getRawTaskConfigurations(scope?: TaskConfigurationScope): (TaskCustomization | TaskConfiguration)[];
|
|
57
|
-
/**
|
|
58
|
-
* returns a collection of invalid task configs as per the task schema defined in Theia.
|
|
59
|
-
*/
|
|
60
|
-
getInvalidTaskConfigurations(): (TaskCustomization | TaskConfiguration)[];
|
|
61
|
-
/** returns the task configuration for a given label or undefined if none */
|
|
62
|
-
getTask(scope: TaskConfigurationScope, taskLabel: string): TaskConfiguration | undefined;
|
|
63
|
-
/** returns the customized task for a given label or undefined if none */
|
|
64
|
-
getCustomizedTask(token: number, scope: TaskConfigurationScope, taskLabel: string): Promise<TaskConfiguration | undefined>;
|
|
65
|
-
/** removes tasks configured in the given task config file */
|
|
66
|
-
private removeTasks;
|
|
67
|
-
/**
|
|
68
|
-
* Removes task customization objects found in the given task config file from the memory.
|
|
69
|
-
* Please note: this function does not modify the task config file.
|
|
70
|
-
*/
|
|
71
|
-
private removeTaskCustomizations;
|
|
72
|
-
/**
|
|
73
|
-
* Returns the task customizations by type from a given root folder in the workspace.
|
|
74
|
-
* @param type the type of task customizations
|
|
75
|
-
* @param rootFolder the root folder to find task customizations from. If `undefined`, this function returns an empty array.
|
|
76
|
-
*/
|
|
77
|
-
private getTaskCustomizations;
|
|
78
|
-
/**
|
|
79
|
-
* Returns the customization object in `tasks.json` for the given task. Please note, this function
|
|
80
|
-
* returns `undefined` if the given task is not a detected task, because configured tasks don't need
|
|
81
|
-
* customization objects - users can modify its config directly in `tasks.json`.
|
|
82
|
-
* @param taskConfig The task config, which could either be a configured task or a detected task.
|
|
83
|
-
*/
|
|
84
|
-
getCustomizationForTask(taskConfig: TaskConfiguration): TaskCustomization | undefined;
|
|
85
|
-
/**
|
|
86
|
-
* Called when a change, to a config file we watch, is detected.
|
|
87
|
-
*/
|
|
88
|
-
protected onDidTaskFileChange(fileChanges: TasksChange[]): Promise<void>;
|
|
89
|
-
/**
|
|
90
|
-
* Read the task configs from the task configuration manager, and updates the list of available tasks.
|
|
91
|
-
*/
|
|
92
|
-
protected refreshTasks(scope: TaskConfigurationScope): Promise<void>;
|
|
93
|
-
/** parses a config file and extracts the tasks launch configurations */
|
|
94
|
-
protected readTasks(scope: TaskConfigurationScope): Promise<(TaskCustomization | TaskConfiguration)[] | undefined>;
|
|
95
|
-
openUserTasks(): Promise<void>;
|
|
96
|
-
/** Adds given task to a config file and opens the file to provide ability to edit task configuration. */
|
|
97
|
-
configure(token: number, task: TaskConfiguration): Promise<void>;
|
|
98
|
-
private getTaskCustomizationTemplate;
|
|
99
|
-
/** Writes the task to a config file. Creates a config file if this one does not exist */
|
|
100
|
-
saveTask(scope: TaskConfigurationScope, task: TaskConfiguration): Promise<boolean>;
|
|
101
|
-
/**
|
|
102
|
-
* This function is called after a change in TaskDefinitionRegistry happens.
|
|
103
|
-
* It checks all tasks that have been loaded, and re-organized them in `tasksMap` and `taskCustomizationMap`.
|
|
104
|
-
*/
|
|
105
|
-
protected reorganizeTasks(): void;
|
|
106
|
-
private getTransformedRawTask;
|
|
107
|
-
/**
|
|
108
|
-
* Returns `true` if the given task configuration is valid as per the task schema defined in Theia
|
|
109
|
-
* or contributed by Theia extensions and plugins, `false` otherwise.
|
|
110
|
-
*/
|
|
111
|
-
private isTaskConfigValid;
|
|
112
|
-
/**
|
|
113
|
-
* Updates the task config in the `tasks.json`.
|
|
114
|
-
* The task config, together with updates, will be written into the `tasks.json` if it is not found in the file.
|
|
115
|
-
*
|
|
116
|
-
* @param task task that the updates will be applied to
|
|
117
|
-
* @param update the updates to be applied
|
|
118
|
-
*/
|
|
119
|
-
updateTaskConfig(token: number, task: TaskConfiguration, update: {
|
|
120
|
-
[name: string]: any;
|
|
121
|
-
}): Promise<void>;
|
|
122
|
-
private getKeyFromScope;
|
|
123
|
-
private getScopeFromKey;
|
|
124
|
-
/** checks if the config is a detected / contributed task */
|
|
125
|
-
private isDetectedTask;
|
|
126
|
-
private getTaskDefinition;
|
|
127
|
-
}
|
|
1
|
+
import { TaskConfiguration, TaskCustomization, TaskConfigurationScope } from '../common';
|
|
2
|
+
import { TaskDefinitionRegistry } from './task-definition-registry';
|
|
3
|
+
import { ProvidedTaskConfigurations } from './provided-task-configurations';
|
|
4
|
+
import { TaskConfigurationManager, TasksChange } from './task-configuration-manager';
|
|
5
|
+
import { TaskSchemaUpdater } from './task-schema-updater';
|
|
6
|
+
import { TaskSourceResolver } from './task-source-resolver';
|
|
7
|
+
import { Disposable, DisposableCollection } from '@theia/core/lib/common';
|
|
8
|
+
import { WorkspaceService } from '@theia/workspace/lib/browser';
|
|
9
|
+
export interface TaskConfigurationClient {
|
|
10
|
+
/**
|
|
11
|
+
* The task configuration file has changed, so a client might want to refresh its configurations
|
|
12
|
+
* @returns an array of strings, each one being a task label
|
|
13
|
+
*/
|
|
14
|
+
taskConfigurationChanged: (event: string[]) => void;
|
|
15
|
+
}
|
|
16
|
+
/**
|
|
17
|
+
* Watches a tasks.json configuration file and provides a parsed version of the contained task configurations
|
|
18
|
+
*/
|
|
19
|
+
export declare class TaskConfigurations implements Disposable {
|
|
20
|
+
protected readonly toDispose: DisposableCollection;
|
|
21
|
+
/**
|
|
22
|
+
* Map of source (path of root folder that the task configs come from) and task config map.
|
|
23
|
+
* For the inner map (i.e., task config map), the key is task label and value TaskConfiguration
|
|
24
|
+
*/
|
|
25
|
+
protected tasksMap: Map<string, Map<string, TaskConfiguration>>;
|
|
26
|
+
/**
|
|
27
|
+
* Map of source (path of root folder that the task configs come from) and task customizations map.
|
|
28
|
+
*/
|
|
29
|
+
protected taskCustomizationMap: Map<string, TaskCustomization[]>;
|
|
30
|
+
protected client: TaskConfigurationClient | undefined;
|
|
31
|
+
/**
|
|
32
|
+
* Map of source (path of root folder that the task configs come from) and raw task configurations / customizations.
|
|
33
|
+
* This map is used to store the data from `tasks.json` files in workspace.
|
|
34
|
+
*/
|
|
35
|
+
private rawTaskConfigurations;
|
|
36
|
+
protected readonly workspaceService: WorkspaceService;
|
|
37
|
+
protected readonly taskDefinitionRegistry: TaskDefinitionRegistry;
|
|
38
|
+
protected readonly providedTaskConfigurations: ProvidedTaskConfigurations;
|
|
39
|
+
protected readonly taskConfigurationManager: TaskConfigurationManager;
|
|
40
|
+
protected readonly taskSchemaUpdater: TaskSchemaUpdater;
|
|
41
|
+
protected readonly taskSourceResolver: TaskSourceResolver;
|
|
42
|
+
constructor();
|
|
43
|
+
protected init(): void;
|
|
44
|
+
setClient(client: TaskConfigurationClient): void;
|
|
45
|
+
dispose(): void;
|
|
46
|
+
/** returns the list of known task labels */
|
|
47
|
+
getTaskLabels(): string[];
|
|
48
|
+
/**
|
|
49
|
+
* returns a collection of known tasks, which includes:
|
|
50
|
+
* - all the configured tasks in `tasks.json`, and
|
|
51
|
+
* - the customized detected tasks.
|
|
52
|
+
*
|
|
53
|
+
* The invalid task configs are not returned.
|
|
54
|
+
*/
|
|
55
|
+
getTasks(token: number): Promise<TaskConfiguration[]>;
|
|
56
|
+
getRawTaskConfigurations(scope?: TaskConfigurationScope): (TaskCustomization | TaskConfiguration)[];
|
|
57
|
+
/**
|
|
58
|
+
* returns a collection of invalid task configs as per the task schema defined in Theia.
|
|
59
|
+
*/
|
|
60
|
+
getInvalidTaskConfigurations(): (TaskCustomization | TaskConfiguration)[];
|
|
61
|
+
/** returns the task configuration for a given label or undefined if none */
|
|
62
|
+
getTask(scope: TaskConfigurationScope, taskLabel: string): TaskConfiguration | undefined;
|
|
63
|
+
/** returns the customized task for a given label or undefined if none */
|
|
64
|
+
getCustomizedTask(token: number, scope: TaskConfigurationScope, taskLabel: string): Promise<TaskConfiguration | undefined>;
|
|
65
|
+
/** removes tasks configured in the given task config file */
|
|
66
|
+
private removeTasks;
|
|
67
|
+
/**
|
|
68
|
+
* Removes task customization objects found in the given task config file from the memory.
|
|
69
|
+
* Please note: this function does not modify the task config file.
|
|
70
|
+
*/
|
|
71
|
+
private removeTaskCustomizations;
|
|
72
|
+
/**
|
|
73
|
+
* Returns the task customizations by type from a given root folder in the workspace.
|
|
74
|
+
* @param type the type of task customizations
|
|
75
|
+
* @param rootFolder the root folder to find task customizations from. If `undefined`, this function returns an empty array.
|
|
76
|
+
*/
|
|
77
|
+
private getTaskCustomizations;
|
|
78
|
+
/**
|
|
79
|
+
* Returns the customization object in `tasks.json` for the given task. Please note, this function
|
|
80
|
+
* returns `undefined` if the given task is not a detected task, because configured tasks don't need
|
|
81
|
+
* customization objects - users can modify its config directly in `tasks.json`.
|
|
82
|
+
* @param taskConfig The task config, which could either be a configured task or a detected task.
|
|
83
|
+
*/
|
|
84
|
+
getCustomizationForTask(taskConfig: TaskConfiguration): TaskCustomization | undefined;
|
|
85
|
+
/**
|
|
86
|
+
* Called when a change, to a config file we watch, is detected.
|
|
87
|
+
*/
|
|
88
|
+
protected onDidTaskFileChange(fileChanges: TasksChange[]): Promise<void>;
|
|
89
|
+
/**
|
|
90
|
+
* Read the task configs from the task configuration manager, and updates the list of available tasks.
|
|
91
|
+
*/
|
|
92
|
+
protected refreshTasks(scope: TaskConfigurationScope): Promise<void>;
|
|
93
|
+
/** parses a config file and extracts the tasks launch configurations */
|
|
94
|
+
protected readTasks(scope: TaskConfigurationScope): Promise<(TaskCustomization | TaskConfiguration)[] | undefined>;
|
|
95
|
+
openUserTasks(): Promise<void>;
|
|
96
|
+
/** Adds given task to a config file and opens the file to provide ability to edit task configuration. */
|
|
97
|
+
configure(token: number, task: TaskConfiguration): Promise<void>;
|
|
98
|
+
private getTaskCustomizationTemplate;
|
|
99
|
+
/** Writes the task to a config file. Creates a config file if this one does not exist */
|
|
100
|
+
saveTask(scope: TaskConfigurationScope, task: TaskConfiguration): Promise<boolean>;
|
|
101
|
+
/**
|
|
102
|
+
* This function is called after a change in TaskDefinitionRegistry happens.
|
|
103
|
+
* It checks all tasks that have been loaded, and re-organized them in `tasksMap` and `taskCustomizationMap`.
|
|
104
|
+
*/
|
|
105
|
+
protected reorganizeTasks(): void;
|
|
106
|
+
private getTransformedRawTask;
|
|
107
|
+
/**
|
|
108
|
+
* Returns `true` if the given task configuration is valid as per the task schema defined in Theia
|
|
109
|
+
* or contributed by Theia extensions and plugins, `false` otherwise.
|
|
110
|
+
*/
|
|
111
|
+
private isTaskConfigValid;
|
|
112
|
+
/**
|
|
113
|
+
* Updates the task config in the `tasks.json`.
|
|
114
|
+
* The task config, together with updates, will be written into the `tasks.json` if it is not found in the file.
|
|
115
|
+
*
|
|
116
|
+
* @param task task that the updates will be applied to
|
|
117
|
+
* @param update the updates to be applied
|
|
118
|
+
*/
|
|
119
|
+
updateTaskConfig(token: number, task: TaskConfiguration, update: {
|
|
120
|
+
[name: string]: any;
|
|
121
|
+
}): Promise<void>;
|
|
122
|
+
private getKeyFromScope;
|
|
123
|
+
private getScopeFromKey;
|
|
124
|
+
/** checks if the config is a detected / contributed task */
|
|
125
|
+
private isDetectedTask;
|
|
126
|
+
private getTaskDefinition;
|
|
127
|
+
}
|
|
128
128
|
//# sourceMappingURL=task-configurations.d.ts.map
|