@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.
Files changed (173) hide show
  1. package/README.md +193 -193
  2. package/lib/browser/index.d.ts +6 -6
  3. package/lib/browser/index.js +33 -33
  4. package/lib/browser/process/process-task-contribution.d.ts +6 -6
  5. package/lib/browser/process/process-task-contribution.js +43 -43
  6. package/lib/browser/process/process-task-frontend-module.d.ts +2 -2
  7. package/lib/browser/process/process-task-frontend-module.js +27 -27
  8. package/lib/browser/process/process-task-resolver.d.ts +17 -17
  9. package/lib/browser/process/process-task-resolver.js +101 -101
  10. package/lib/browser/provided-task-configurations.d.ts +43 -43
  11. package/lib/browser/provided-task-configurations.js +213 -213
  12. package/lib/browser/provided-task-configurations.spec.d.ts +1 -1
  13. package/lib/browser/provided-task-configurations.spec.js +43 -43
  14. package/lib/browser/quick-open-task.d.ts +144 -144
  15. package/lib/browser/quick-open-task.d.ts.map +1 -1
  16. package/lib/browser/quick-open-task.js +752 -748
  17. package/lib/browser/quick-open-task.js.map +1 -1
  18. package/lib/browser/task-configuration-manager.d.ts +64 -64
  19. package/lib/browser/task-configuration-manager.js +261 -261
  20. package/lib/browser/task-configuration-model.d.ts +32 -32
  21. package/lib/browser/task-configuration-model.js +79 -79
  22. package/lib/browser/task-configurations.d.ts +127 -127
  23. package/lib/browser/task-configurations.js +486 -486
  24. package/lib/browser/task-contribution.d.ts +182 -182
  25. package/lib/browser/task-contribution.js +206 -206
  26. package/lib/browser/task-definition-registry.d.ts +38 -38
  27. package/lib/browser/task-definition-registry.js +134 -134
  28. package/lib/browser/task-definition-registry.spec.d.ts +1 -1
  29. package/lib/browser/task-definition-registry.spec.js +170 -170
  30. package/lib/browser/task-frontend-contribution.d.ts +56 -56
  31. package/lib/browser/task-frontend-contribution.js +358 -358
  32. package/lib/browser/task-frontend-module.d.ts +5 -5
  33. package/lib/browser/task-frontend-module.js +79 -79
  34. package/lib/browser/task-name-resolver.d.ts +13 -13
  35. package/lib/browser/task-name-resolver.js +67 -67
  36. package/lib/browser/task-node.d.ts +9 -9
  37. package/lib/browser/task-node.js +17 -17
  38. package/lib/browser/task-preferences.d.ts +4 -4
  39. package/lib/browser/task-preferences.js +40 -40
  40. package/lib/browser/task-problem-matcher-registry.d.ts +40 -40
  41. package/lib/browser/task-problem-matcher-registry.js +309 -309
  42. package/lib/browser/task-problem-pattern-registry.d.ts +23 -23
  43. package/lib/browser/task-problem-pattern-registry.js +210 -210
  44. package/lib/browser/task-schema-updater.d.ts +58 -58
  45. package/lib/browser/task-schema-updater.js +688 -688
  46. package/lib/browser/task-service.d.ts +279 -279
  47. package/lib/browser/task-service.js +1119 -1119
  48. package/lib/browser/task-source-resolver.d.ts +9 -9
  49. package/lib/browser/task-source-resolver.js +51 -51
  50. package/lib/browser/task-templates.d.ts +13 -13
  51. package/lib/browser/task-templates.js +161 -161
  52. package/lib/browser/task-terminal-widget-manager.d.ts +44 -44
  53. package/lib/browser/task-terminal-widget-manager.js +228 -228
  54. package/lib/browser/tasks-monaco-contribution.d.ts +1 -1
  55. package/lib/browser/tasks-monaco-contribution.js +27 -27
  56. package/lib/common/index.d.ts +4 -4
  57. package/lib/common/index.js +31 -31
  58. package/lib/common/problem-matcher-protocol.d.ts +124 -124
  59. package/lib/common/problem-matcher-protocol.js +132 -132
  60. package/lib/common/process/task-protocol.d.ts +68 -68
  61. package/lib/common/process/task-protocol.js +33 -33
  62. package/lib/common/task-common-module.d.ts +7 -7
  63. package/lib/common/task-common-module.js +33 -33
  64. package/lib/common/task-protocol.d.ts +192 -192
  65. package/lib/common/task-protocol.js +137 -137
  66. package/lib/common/task-util.d.ts +22 -22
  67. package/lib/common/task-util.js +46 -46
  68. package/lib/common/task-watcher.d.ts +17 -17
  69. package/lib/common/task-watcher.js +86 -86
  70. package/lib/node/custom/custom-task-runner-backend-module.d.ts +2 -2
  71. package/lib/node/custom/custom-task-runner-backend-module.js +36 -36
  72. package/lib/node/custom/custom-task-runner-contribution.d.ts +6 -6
  73. package/lib/node/custom/custom-task-runner-contribution.js +42 -42
  74. package/lib/node/custom/custom-task-runner.d.ts +15 -15
  75. package/lib/node/custom/custom-task-runner.js +69 -69
  76. package/lib/node/custom/custom-task.d.ts +20 -20
  77. package/lib/node/custom/custom-task.js +78 -78
  78. package/lib/node/index.d.ts +3 -3
  79. package/lib/node/index.js +30 -30
  80. package/lib/node/process/process-task-runner-backend-module.d.ts +2 -2
  81. package/lib/node/process/process-task-runner-backend-module.js +36 -36
  82. package/lib/node/process/process-task-runner-contribution.d.ts +6 -6
  83. package/lib/node/process/process-task-runner-contribution.js +43 -43
  84. package/lib/node/process/process-task-runner.d.ts +60 -60
  85. package/lib/node/process/process-task-runner.js +355 -355
  86. package/lib/node/process/process-task.d.ts +26 -26
  87. package/lib/node/process/process-task.js +135 -135
  88. package/lib/node/process/process-task.spec.d.ts +1 -1
  89. package/lib/node/process/process-task.spec.js +29 -29
  90. package/lib/node/task-abstract-line-matcher.d.ts +49 -49
  91. package/lib/node/task-abstract-line-matcher.js +273 -273
  92. package/lib/node/task-backend-application-contribution.d.ts +8 -8
  93. package/lib/node/task-backend-application-contribution.js +48 -48
  94. package/lib/node/task-backend-module.d.ts +3 -3
  95. package/lib/node/task-backend-module.js +50 -50
  96. package/lib/node/task-line-matchers.d.ts +27 -27
  97. package/lib/node/task-line-matchers.js +121 -121
  98. package/lib/node/task-manager.d.ts +55 -55
  99. package/lib/node/task-manager.js +135 -135
  100. package/lib/node/task-problem-collector.d.ts +10 -10
  101. package/lib/node/task-problem-collector.js +57 -57
  102. package/lib/node/task-problem-collector.spec.d.ts +1 -1
  103. package/lib/node/task-problem-collector.spec.js +310 -310
  104. package/lib/node/task-runner-protocol.d.ts +16 -16
  105. package/lib/node/task-runner-protocol.js +19 -19
  106. package/lib/node/task-runner.d.ts +50 -50
  107. package/lib/node/task-runner.js +97 -97
  108. package/lib/node/task-server.d.ts +39 -39
  109. package/lib/node/task-server.js +237 -237
  110. package/lib/node/task-server.slow-spec.d.ts +1 -1
  111. package/lib/node/task-server.slow-spec.js +395 -395
  112. package/lib/node/task.d.ts +50 -50
  113. package/lib/node/task.js +77 -77
  114. package/lib/node/test/task-test-container.d.ts +2 -2
  115. package/lib/node/test/task-test-container.js +58 -58
  116. package/package.json +14 -14
  117. package/src/browser/index.ts +22 -22
  118. package/src/browser/process/process-task-contribution.ts +31 -31
  119. package/src/browser/process/process-task-frontend-module.ts +27 -27
  120. package/src/browser/process/process-task-resolver.ts +89 -89
  121. package/src/browser/provided-task-configurations.spec.ts +46 -46
  122. package/src/browser/provided-task-configurations.ts +213 -213
  123. package/src/browser/quick-open-task.ts +831 -827
  124. package/src/browser/style/index.css +19 -19
  125. package/src/browser/task-configuration-manager.ts +256 -256
  126. package/src/browser/task-configuration-model.ts +101 -101
  127. package/src/browser/task-configurations.ts +508 -508
  128. package/src/browser/task-contribution.ts +266 -266
  129. package/src/browser/task-definition-registry.spec.ts +203 -203
  130. package/src/browser/task-definition-registry.ts +131 -131
  131. package/src/browser/task-frontend-contribution.ts +402 -402
  132. package/src/browser/task-frontend-module.ts +86 -86
  133. package/src/browser/task-name-resolver.ts +55 -55
  134. package/src/browser/task-node.ts +37 -37
  135. package/src/browser/task-preferences.ts +40 -40
  136. package/src/browser/task-problem-matcher-registry.ts +308 -308
  137. package/src/browser/task-problem-pattern-registry.ts +196 -196
  138. package/src/browser/task-schema-updater.ts +701 -701
  139. package/src/browser/task-service.ts +1164 -1164
  140. package/src/browser/task-source-resolver.ts +36 -36
  141. package/src/browser/task-templates.ts +168 -168
  142. package/src/browser/task-terminal-widget-manager.ts +224 -224
  143. package/src/browser/tasks-monaco-contribution.ts +27 -27
  144. package/src/common/index.ts +20 -20
  145. package/src/common/problem-matcher-protocol.ts +234 -234
  146. package/src/common/process/task-protocol.ts +97 -97
  147. package/src/common/task-common-module.ts +34 -34
  148. package/src/common/task-protocol.ts +317 -317
  149. package/src/common/task-util.ts +43 -43
  150. package/src/common/task-watcher.ts +78 -78
  151. package/src/node/custom/custom-task-runner-backend-module.ts +37 -37
  152. package/src/node/custom/custom-task-runner-contribution.ts +30 -30
  153. package/src/node/custom/custom-task-runner.ts +60 -60
  154. package/src/node/custom/custom-task.ts +73 -73
  155. package/src/node/index.ts +19 -19
  156. package/src/node/process/process-task-runner-backend-module.ts +37 -37
  157. package/src/node/process/process-task-runner-contribution.ts +31 -31
  158. package/src/node/process/process-task-runner.ts +371 -371
  159. package/src/node/process/process-task.spec.ts +30 -30
  160. package/src/node/process/process-task.ts +144 -144
  161. package/src/node/task-abstract-line-matcher.ts +312 -312
  162. package/src/node/task-backend-application-contribution.ts +36 -36
  163. package/src/node/task-backend-module.ts +57 -57
  164. package/src/node/task-line-matchers.ts +127 -127
  165. package/src/node/task-manager.ts +129 -129
  166. package/src/node/task-problem-collector.spec.ts +338 -338
  167. package/src/node/task-problem-collector.ts +62 -62
  168. package/src/node/task-runner-protocol.ts +33 -33
  169. package/src/node/task-runner.ts +96 -96
  170. package/src/node/task-server.slow-spec.ts +444 -444
  171. package/src/node/task-server.ts +263 -263
  172. package/src/node/task.ts +103 -103
  173. 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