@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,262 +1,262 @@
|
|
|
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
|
-
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
18
|
-
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
19
|
-
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
20
|
-
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
21
|
-
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
22
|
-
};
|
|
23
|
-
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
24
|
-
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
25
|
-
};
|
|
26
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
27
|
-
exports.TaskConfigurationManager = void 0;
|
|
28
|
-
const jsoncparser = require("jsonc-parser");
|
|
29
|
-
const debounce = require("p-debounce");
|
|
30
|
-
const inversify_1 = require("@theia/core/shared/inversify");
|
|
31
|
-
const event_1 = require("@theia/core/lib/common/event");
|
|
32
|
-
const browser_1 = require("@theia/editor/lib/browser");
|
|
33
|
-
const browser_2 = require("@theia/core/lib/browser");
|
|
34
|
-
const quick_pick_service_1 = require("@theia/core/lib/common/quick-pick-service");
|
|
35
|
-
const workspace_service_1 = require("@theia/workspace/lib/browser/workspace-service");
|
|
36
|
-
const task_configuration_model_1 = require("./task-configuration-model");
|
|
37
|
-
const task_templates_1 = require("./task-templates");
|
|
38
|
-
const task_protocol_1 = require("../common/task-protocol");
|
|
39
|
-
const workspace_variable_contribution_1 = require("@theia/workspace/lib/browser/workspace-variable-contribution");
|
|
40
|
-
const preference_configurations_1 = require("@theia/core/lib/browser/preferences/preference-configurations");
|
|
41
|
-
const file_service_1 = require("@theia/filesystem/lib/browser/file-service");
|
|
42
|
-
const common_1 = require("@theia/core/lib/common");
|
|
43
|
-
const task_schema_updater_1 = require("./task-schema-updater");
|
|
44
|
-
/**
|
|
45
|
-
* This class connects the the "tasks" preferences sections to task system: it collects tasks preference values and
|
|
46
|
-
* provides them to the task system as raw, parsed JSON.
|
|
47
|
-
*/
|
|
48
|
-
let TaskConfigurationManager = class TaskConfigurationManager {
|
|
49
|
-
constructor() {
|
|
50
|
-
this.onDidChangeTaskConfigEmitter = new event_1.Emitter();
|
|
51
|
-
this.onDidChangeTaskConfig = this.onDidChangeTaskConfigEmitter.event;
|
|
52
|
-
this.models = new Map();
|
|
53
|
-
this.updateModels = debounce(async () => {
|
|
54
|
-
const roots = await this.workspaceService.roots;
|
|
55
|
-
const toDelete = new Set([...this.models.keys()]
|
|
56
|
-
.filter(key => key !== task_protocol_1.TaskScope.Global && key !== task_protocol_1.TaskScope.Workspace));
|
|
57
|
-
this.updateWorkspaceModel();
|
|
58
|
-
for (const rootStat of roots) {
|
|
59
|
-
const key = rootStat.resource.toString();
|
|
60
|
-
toDelete.delete(key);
|
|
61
|
-
if (!this.models.has(key)) {
|
|
62
|
-
const model = new task_configuration_model_1.TaskConfigurationModel(key, this.folderPreferences);
|
|
63
|
-
model.onDidChange(() => this.onDidChangeTaskConfigEmitter.fire({ scope: key, type: 0 /* UPDATED */ }));
|
|
64
|
-
model.onDispose(() => this.models.delete(key));
|
|
65
|
-
this.models.set(key, model);
|
|
66
|
-
this.onDidChangeTaskConfigEmitter.fire({ scope: key, type: 0 /* UPDATED */ });
|
|
67
|
-
}
|
|
68
|
-
}
|
|
69
|
-
for (const uri of toDelete) {
|
|
70
|
-
const model = this.models.get(uri);
|
|
71
|
-
if (model) {
|
|
72
|
-
model.dispose();
|
|
73
|
-
}
|
|
74
|
-
this.onDidChangeTaskConfigEmitter.fire({ scope: uri, type: 2 /* DELETED */ });
|
|
75
|
-
}
|
|
76
|
-
}, 500);
|
|
77
|
-
this.toDisposeOnDelegateChange = new common_1.DisposableCollection();
|
|
78
|
-
}
|
|
79
|
-
init() {
|
|
80
|
-
this.createModels();
|
|
81
|
-
this.folderPreferences.onDidPreferencesChanged(e => {
|
|
82
|
-
if (e['tasks']) {
|
|
83
|
-
this.updateModels();
|
|
84
|
-
}
|
|
85
|
-
});
|
|
86
|
-
this.workspaceService.onWorkspaceChanged(() => {
|
|
87
|
-
this.updateModels();
|
|
88
|
-
});
|
|
89
|
-
this.workspaceService.onWorkspaceLocationChanged(() => {
|
|
90
|
-
this.updateModels();
|
|
91
|
-
});
|
|
92
|
-
}
|
|
93
|
-
createModels() {
|
|
94
|
-
const userModel = new task_configuration_model_1.TaskConfigurationModel(task_protocol_1.TaskScope.Global, this.userPreferences);
|
|
95
|
-
userModel.onDidChange(() => this.onDidChangeTaskConfigEmitter.fire({ scope: task_protocol_1.TaskScope.Global, type: 0 /* UPDATED */ }));
|
|
96
|
-
this.models.set(task_protocol_1.TaskScope.Global, userModel);
|
|
97
|
-
this.updateModels();
|
|
98
|
-
}
|
|
99
|
-
getTasks(scope) {
|
|
100
|
-
var _a, _b;
|
|
101
|
-
return (_b = (_a = this.getModel(scope)) === null || _a === void 0 ? void 0 : _a.configurations) !== null && _b !== void 0 ? _b : [];
|
|
102
|
-
}
|
|
103
|
-
getTask(name, scope) {
|
|
104
|
-
return this.getTasks(scope).find((configuration) => configuration.name === name);
|
|
105
|
-
}
|
|
106
|
-
async openConfiguration(scope) {
|
|
107
|
-
const taskPrefModel = this.getModel(scope);
|
|
108
|
-
const maybeURI = typeof scope === 'string' ? scope : undefined;
|
|
109
|
-
const configURI = this.preferenceService.getConfigUri(this.getMatchingPreferenceScope(scope), maybeURI, 'tasks');
|
|
110
|
-
if (taskPrefModel && configURI) {
|
|
111
|
-
await this.doOpen(taskPrefModel, configURI);
|
|
112
|
-
}
|
|
113
|
-
}
|
|
114
|
-
async addTaskConfiguration(scope, taskConfig) {
|
|
115
|
-
const taskPrefModel = this.getModel(scope);
|
|
116
|
-
if (taskPrefModel) {
|
|
117
|
-
const configurations = taskPrefModel.configurations;
|
|
118
|
-
return this.setTaskConfigurations(scope, [...configurations, taskConfig]);
|
|
119
|
-
}
|
|
120
|
-
return false;
|
|
121
|
-
}
|
|
122
|
-
async setTaskConfigurations(scope, taskConfigs) {
|
|
123
|
-
const taskPrefModel = this.getModel(scope);
|
|
124
|
-
if (taskPrefModel) {
|
|
125
|
-
return taskPrefModel.setConfigurations(taskConfigs);
|
|
126
|
-
}
|
|
127
|
-
return false;
|
|
128
|
-
}
|
|
129
|
-
getModel(scope) {
|
|
130
|
-
return this.models.get(scope);
|
|
131
|
-
}
|
|
132
|
-
async doOpen(model, configURI) {
|
|
133
|
-
if (!model.uri) {
|
|
134
|
-
// The file has not yet been created.
|
|
135
|
-
await this.doCreate(model, configURI);
|
|
136
|
-
}
|
|
137
|
-
return this.editorManager.open(configURI, {
|
|
138
|
-
mode: 'activate'
|
|
139
|
-
});
|
|
140
|
-
}
|
|
141
|
-
async doCreate(model, configURI) {
|
|
142
|
-
var _a;
|
|
143
|
-
const content = await this.getInitialConfigurationContent();
|
|
144
|
-
if (content) {
|
|
145
|
-
// All scopes but workspace.
|
|
146
|
-
if (this.preferenceConfigurations.getName(configURI) === 'tasks') {
|
|
147
|
-
await this.fileService.write(configURI, content);
|
|
148
|
-
}
|
|
149
|
-
else {
|
|
150
|
-
let taskContent;
|
|
151
|
-
try {
|
|
152
|
-
taskContent = jsoncparser.parse(content);
|
|
153
|
-
}
|
|
154
|
-
catch {
|
|
155
|
-
taskContent = (_a = this.taskSchemaProvider.getTaskSchema().default) !== null && _a !== void 0 ? _a : {};
|
|
156
|
-
}
|
|
157
|
-
await model.preferences.setPreference('tasks', taskContent);
|
|
158
|
-
}
|
|
159
|
-
}
|
|
160
|
-
}
|
|
161
|
-
getMatchingPreferenceScope(scope) {
|
|
162
|
-
switch (scope) {
|
|
163
|
-
case task_protocol_1.TaskScope.Global:
|
|
164
|
-
return browser_2.PreferenceScope.User;
|
|
165
|
-
case task_protocol_1.TaskScope.Workspace:
|
|
166
|
-
return browser_2.PreferenceScope.Workspace;
|
|
167
|
-
default:
|
|
168
|
-
return browser_2.PreferenceScope.Folder;
|
|
169
|
-
}
|
|
170
|
-
}
|
|
171
|
-
async getInitialConfigurationContent() {
|
|
172
|
-
var _a;
|
|
173
|
-
const selected = await this.quickPickService.show(this.taskTemplateSelector.selectTemplates(), {
|
|
174
|
-
placeholder: 'Select a Task Template'
|
|
175
|
-
});
|
|
176
|
-
if (selected) {
|
|
177
|
-
return (_a = selected.value) === null || _a === void 0 ? void 0 : _a.content;
|
|
178
|
-
}
|
|
179
|
-
}
|
|
180
|
-
updateWorkspaceModel() {
|
|
181
|
-
var _a;
|
|
182
|
-
const isFolderWorkspace = this.workspaceService.opened && !this.workspaceService.saved;
|
|
183
|
-
const newDelegate = isFolderWorkspace ? this.folderPreferences : this.workspacePreferences;
|
|
184
|
-
const effectiveScope = isFolderWorkspace ? (_a = this.workspaceService.tryGetRoots()[0]) === null || _a === void 0 ? void 0 : _a.resource.toString() : task_protocol_1.TaskScope.Workspace;
|
|
185
|
-
if (newDelegate !== this.workspaceDelegate) {
|
|
186
|
-
this.workspaceDelegate = newDelegate;
|
|
187
|
-
this.toDisposeOnDelegateChange.dispose();
|
|
188
|
-
const workspaceModel = new task_configuration_model_1.TaskConfigurationModel(effectiveScope, newDelegate);
|
|
189
|
-
this.toDisposeOnDelegateChange.push(workspaceModel);
|
|
190
|
-
// If the delegate is the folder preference provider, its events will be relayed via the folder scope models.
|
|
191
|
-
if (newDelegate === this.workspacePreferences) {
|
|
192
|
-
this.toDisposeOnDelegateChange.push(workspaceModel.onDidChange(() => {
|
|
193
|
-
this.onDidChangeTaskConfigEmitter.fire({ scope: task_protocol_1.TaskScope.Workspace, type: 0 /* UPDATED */ });
|
|
194
|
-
}));
|
|
195
|
-
}
|
|
196
|
-
this.models.set(task_protocol_1.TaskScope.Workspace, workspaceModel);
|
|
197
|
-
this.onDidChangeTaskConfigEmitter.fire({ scope: effectiveScope, type: 0 /* UPDATED */ });
|
|
198
|
-
}
|
|
199
|
-
}
|
|
200
|
-
};
|
|
201
|
-
__decorate([
|
|
202
|
-
(0, inversify_1.inject)(workspace_service_1.WorkspaceService),
|
|
203
|
-
__metadata("design:type", workspace_service_1.WorkspaceService)
|
|
204
|
-
], TaskConfigurationManager.prototype, "workspaceService", void 0);
|
|
205
|
-
__decorate([
|
|
206
|
-
(0, inversify_1.inject)(browser_1.EditorManager),
|
|
207
|
-
__metadata("design:type", browser_1.EditorManager)
|
|
208
|
-
], TaskConfigurationManager.prototype, "editorManager", void 0);
|
|
209
|
-
__decorate([
|
|
210
|
-
(0, inversify_1.inject)(quick_pick_service_1.QuickPickService),
|
|
211
|
-
__metadata("design:type", Object)
|
|
212
|
-
], TaskConfigurationManager.prototype, "quickPickService", void 0);
|
|
213
|
-
__decorate([
|
|
214
|
-
(0, inversify_1.inject)(file_service_1.FileService),
|
|
215
|
-
__metadata("design:type", file_service_1.FileService)
|
|
216
|
-
], TaskConfigurationManager.prototype, "fileService", void 0);
|
|
217
|
-
__decorate([
|
|
218
|
-
(0, inversify_1.inject)(browser_2.PreferenceService),
|
|
219
|
-
__metadata("design:type", Object)
|
|
220
|
-
], TaskConfigurationManager.prototype, "preferenceService", void 0);
|
|
221
|
-
__decorate([
|
|
222
|
-
(0, inversify_1.inject)(task_schema_updater_1.TaskSchemaUpdater),
|
|
223
|
-
__metadata("design:type", task_schema_updater_1.TaskSchemaUpdater)
|
|
224
|
-
], TaskConfigurationManager.prototype, "taskSchemaProvider", void 0);
|
|
225
|
-
__decorate([
|
|
226
|
-
(0, inversify_1.inject)(browser_2.PreferenceProvider),
|
|
227
|
-
(0, inversify_1.named)(browser_2.PreferenceScope.Folder),
|
|
228
|
-
__metadata("design:type", browser_2.PreferenceProvider)
|
|
229
|
-
], TaskConfigurationManager.prototype, "folderPreferences", void 0);
|
|
230
|
-
__decorate([
|
|
231
|
-
(0, inversify_1.inject)(browser_2.PreferenceProvider),
|
|
232
|
-
(0, inversify_1.named)(browser_2.PreferenceScope.User),
|
|
233
|
-
__metadata("design:type", browser_2.PreferenceProvider)
|
|
234
|
-
], TaskConfigurationManager.prototype, "userPreferences", void 0);
|
|
235
|
-
__decorate([
|
|
236
|
-
(0, inversify_1.inject)(browser_2.PreferenceProvider),
|
|
237
|
-
(0, inversify_1.named)(browser_2.PreferenceScope.Workspace),
|
|
238
|
-
__metadata("design:type", browser_2.PreferenceProvider)
|
|
239
|
-
], TaskConfigurationManager.prototype, "workspacePreferences", void 0);
|
|
240
|
-
__decorate([
|
|
241
|
-
(0, inversify_1.inject)(preference_configurations_1.PreferenceConfigurations),
|
|
242
|
-
__metadata("design:type", preference_configurations_1.PreferenceConfigurations)
|
|
243
|
-
], TaskConfigurationManager.prototype, "preferenceConfigurations", void 0);
|
|
244
|
-
__decorate([
|
|
245
|
-
(0, inversify_1.inject)(workspace_variable_contribution_1.WorkspaceVariableContribution),
|
|
246
|
-
__metadata("design:type", workspace_variable_contribution_1.WorkspaceVariableContribution)
|
|
247
|
-
], TaskConfigurationManager.prototype, "workspaceVariables", void 0);
|
|
248
|
-
__decorate([
|
|
249
|
-
(0, inversify_1.inject)(task_templates_1.TaskTemplateSelector),
|
|
250
|
-
__metadata("design:type", task_templates_1.TaskTemplateSelector)
|
|
251
|
-
], TaskConfigurationManager.prototype, "taskTemplateSelector", void 0);
|
|
252
|
-
__decorate([
|
|
253
|
-
(0, inversify_1.postConstruct)(),
|
|
254
|
-
__metadata("design:type", Function),
|
|
255
|
-
__metadata("design:paramtypes", []),
|
|
256
|
-
__metadata("design:returntype", void 0)
|
|
257
|
-
], TaskConfigurationManager.prototype, "init", null);
|
|
258
|
-
TaskConfigurationManager = __decorate([
|
|
259
|
-
(0, inversify_1.injectable)()
|
|
260
|
-
], TaskConfigurationManager);
|
|
261
|
-
exports.TaskConfigurationManager = TaskConfigurationManager;
|
|
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
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
18
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
19
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
20
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
21
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
22
|
+
};
|
|
23
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
24
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
25
|
+
};
|
|
26
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
27
|
+
exports.TaskConfigurationManager = void 0;
|
|
28
|
+
const jsoncparser = require("jsonc-parser");
|
|
29
|
+
const debounce = require("p-debounce");
|
|
30
|
+
const inversify_1 = require("@theia/core/shared/inversify");
|
|
31
|
+
const event_1 = require("@theia/core/lib/common/event");
|
|
32
|
+
const browser_1 = require("@theia/editor/lib/browser");
|
|
33
|
+
const browser_2 = require("@theia/core/lib/browser");
|
|
34
|
+
const quick_pick_service_1 = require("@theia/core/lib/common/quick-pick-service");
|
|
35
|
+
const workspace_service_1 = require("@theia/workspace/lib/browser/workspace-service");
|
|
36
|
+
const task_configuration_model_1 = require("./task-configuration-model");
|
|
37
|
+
const task_templates_1 = require("./task-templates");
|
|
38
|
+
const task_protocol_1 = require("../common/task-protocol");
|
|
39
|
+
const workspace_variable_contribution_1 = require("@theia/workspace/lib/browser/workspace-variable-contribution");
|
|
40
|
+
const preference_configurations_1 = require("@theia/core/lib/browser/preferences/preference-configurations");
|
|
41
|
+
const file_service_1 = require("@theia/filesystem/lib/browser/file-service");
|
|
42
|
+
const common_1 = require("@theia/core/lib/common");
|
|
43
|
+
const task_schema_updater_1 = require("./task-schema-updater");
|
|
44
|
+
/**
|
|
45
|
+
* This class connects the the "tasks" preferences sections to task system: it collects tasks preference values and
|
|
46
|
+
* provides them to the task system as raw, parsed JSON.
|
|
47
|
+
*/
|
|
48
|
+
let TaskConfigurationManager = class TaskConfigurationManager {
|
|
49
|
+
constructor() {
|
|
50
|
+
this.onDidChangeTaskConfigEmitter = new event_1.Emitter();
|
|
51
|
+
this.onDidChangeTaskConfig = this.onDidChangeTaskConfigEmitter.event;
|
|
52
|
+
this.models = new Map();
|
|
53
|
+
this.updateModels = debounce(async () => {
|
|
54
|
+
const roots = await this.workspaceService.roots;
|
|
55
|
+
const toDelete = new Set([...this.models.keys()]
|
|
56
|
+
.filter(key => key !== task_protocol_1.TaskScope.Global && key !== task_protocol_1.TaskScope.Workspace));
|
|
57
|
+
this.updateWorkspaceModel();
|
|
58
|
+
for (const rootStat of roots) {
|
|
59
|
+
const key = rootStat.resource.toString();
|
|
60
|
+
toDelete.delete(key);
|
|
61
|
+
if (!this.models.has(key)) {
|
|
62
|
+
const model = new task_configuration_model_1.TaskConfigurationModel(key, this.folderPreferences);
|
|
63
|
+
model.onDidChange(() => this.onDidChangeTaskConfigEmitter.fire({ scope: key, type: 0 /* UPDATED */ }));
|
|
64
|
+
model.onDispose(() => this.models.delete(key));
|
|
65
|
+
this.models.set(key, model);
|
|
66
|
+
this.onDidChangeTaskConfigEmitter.fire({ scope: key, type: 0 /* UPDATED */ });
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
for (const uri of toDelete) {
|
|
70
|
+
const model = this.models.get(uri);
|
|
71
|
+
if (model) {
|
|
72
|
+
model.dispose();
|
|
73
|
+
}
|
|
74
|
+
this.onDidChangeTaskConfigEmitter.fire({ scope: uri, type: 2 /* DELETED */ });
|
|
75
|
+
}
|
|
76
|
+
}, 500);
|
|
77
|
+
this.toDisposeOnDelegateChange = new common_1.DisposableCollection();
|
|
78
|
+
}
|
|
79
|
+
init() {
|
|
80
|
+
this.createModels();
|
|
81
|
+
this.folderPreferences.onDidPreferencesChanged(e => {
|
|
82
|
+
if (e['tasks']) {
|
|
83
|
+
this.updateModels();
|
|
84
|
+
}
|
|
85
|
+
});
|
|
86
|
+
this.workspaceService.onWorkspaceChanged(() => {
|
|
87
|
+
this.updateModels();
|
|
88
|
+
});
|
|
89
|
+
this.workspaceService.onWorkspaceLocationChanged(() => {
|
|
90
|
+
this.updateModels();
|
|
91
|
+
});
|
|
92
|
+
}
|
|
93
|
+
createModels() {
|
|
94
|
+
const userModel = new task_configuration_model_1.TaskConfigurationModel(task_protocol_1.TaskScope.Global, this.userPreferences);
|
|
95
|
+
userModel.onDidChange(() => this.onDidChangeTaskConfigEmitter.fire({ scope: task_protocol_1.TaskScope.Global, type: 0 /* UPDATED */ }));
|
|
96
|
+
this.models.set(task_protocol_1.TaskScope.Global, userModel);
|
|
97
|
+
this.updateModels();
|
|
98
|
+
}
|
|
99
|
+
getTasks(scope) {
|
|
100
|
+
var _a, _b;
|
|
101
|
+
return (_b = (_a = this.getModel(scope)) === null || _a === void 0 ? void 0 : _a.configurations) !== null && _b !== void 0 ? _b : [];
|
|
102
|
+
}
|
|
103
|
+
getTask(name, scope) {
|
|
104
|
+
return this.getTasks(scope).find((configuration) => configuration.name === name);
|
|
105
|
+
}
|
|
106
|
+
async openConfiguration(scope) {
|
|
107
|
+
const taskPrefModel = this.getModel(scope);
|
|
108
|
+
const maybeURI = typeof scope === 'string' ? scope : undefined;
|
|
109
|
+
const configURI = this.preferenceService.getConfigUri(this.getMatchingPreferenceScope(scope), maybeURI, 'tasks');
|
|
110
|
+
if (taskPrefModel && configURI) {
|
|
111
|
+
await this.doOpen(taskPrefModel, configURI);
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
async addTaskConfiguration(scope, taskConfig) {
|
|
115
|
+
const taskPrefModel = this.getModel(scope);
|
|
116
|
+
if (taskPrefModel) {
|
|
117
|
+
const configurations = taskPrefModel.configurations;
|
|
118
|
+
return this.setTaskConfigurations(scope, [...configurations, taskConfig]);
|
|
119
|
+
}
|
|
120
|
+
return false;
|
|
121
|
+
}
|
|
122
|
+
async setTaskConfigurations(scope, taskConfigs) {
|
|
123
|
+
const taskPrefModel = this.getModel(scope);
|
|
124
|
+
if (taskPrefModel) {
|
|
125
|
+
return taskPrefModel.setConfigurations(taskConfigs);
|
|
126
|
+
}
|
|
127
|
+
return false;
|
|
128
|
+
}
|
|
129
|
+
getModel(scope) {
|
|
130
|
+
return this.models.get(scope);
|
|
131
|
+
}
|
|
132
|
+
async doOpen(model, configURI) {
|
|
133
|
+
if (!model.uri) {
|
|
134
|
+
// The file has not yet been created.
|
|
135
|
+
await this.doCreate(model, configURI);
|
|
136
|
+
}
|
|
137
|
+
return this.editorManager.open(configURI, {
|
|
138
|
+
mode: 'activate'
|
|
139
|
+
});
|
|
140
|
+
}
|
|
141
|
+
async doCreate(model, configURI) {
|
|
142
|
+
var _a;
|
|
143
|
+
const content = await this.getInitialConfigurationContent();
|
|
144
|
+
if (content) {
|
|
145
|
+
// All scopes but workspace.
|
|
146
|
+
if (this.preferenceConfigurations.getName(configURI) === 'tasks') {
|
|
147
|
+
await this.fileService.write(configURI, content);
|
|
148
|
+
}
|
|
149
|
+
else {
|
|
150
|
+
let taskContent;
|
|
151
|
+
try {
|
|
152
|
+
taskContent = jsoncparser.parse(content);
|
|
153
|
+
}
|
|
154
|
+
catch {
|
|
155
|
+
taskContent = (_a = this.taskSchemaProvider.getTaskSchema().default) !== null && _a !== void 0 ? _a : {};
|
|
156
|
+
}
|
|
157
|
+
await model.preferences.setPreference('tasks', taskContent);
|
|
158
|
+
}
|
|
159
|
+
}
|
|
160
|
+
}
|
|
161
|
+
getMatchingPreferenceScope(scope) {
|
|
162
|
+
switch (scope) {
|
|
163
|
+
case task_protocol_1.TaskScope.Global:
|
|
164
|
+
return browser_2.PreferenceScope.User;
|
|
165
|
+
case task_protocol_1.TaskScope.Workspace:
|
|
166
|
+
return browser_2.PreferenceScope.Workspace;
|
|
167
|
+
default:
|
|
168
|
+
return browser_2.PreferenceScope.Folder;
|
|
169
|
+
}
|
|
170
|
+
}
|
|
171
|
+
async getInitialConfigurationContent() {
|
|
172
|
+
var _a;
|
|
173
|
+
const selected = await this.quickPickService.show(this.taskTemplateSelector.selectTemplates(), {
|
|
174
|
+
placeholder: 'Select a Task Template'
|
|
175
|
+
});
|
|
176
|
+
if (selected) {
|
|
177
|
+
return (_a = selected.value) === null || _a === void 0 ? void 0 : _a.content;
|
|
178
|
+
}
|
|
179
|
+
}
|
|
180
|
+
updateWorkspaceModel() {
|
|
181
|
+
var _a;
|
|
182
|
+
const isFolderWorkspace = this.workspaceService.opened && !this.workspaceService.saved;
|
|
183
|
+
const newDelegate = isFolderWorkspace ? this.folderPreferences : this.workspacePreferences;
|
|
184
|
+
const effectiveScope = isFolderWorkspace ? (_a = this.workspaceService.tryGetRoots()[0]) === null || _a === void 0 ? void 0 : _a.resource.toString() : task_protocol_1.TaskScope.Workspace;
|
|
185
|
+
if (newDelegate !== this.workspaceDelegate) {
|
|
186
|
+
this.workspaceDelegate = newDelegate;
|
|
187
|
+
this.toDisposeOnDelegateChange.dispose();
|
|
188
|
+
const workspaceModel = new task_configuration_model_1.TaskConfigurationModel(effectiveScope, newDelegate);
|
|
189
|
+
this.toDisposeOnDelegateChange.push(workspaceModel);
|
|
190
|
+
// If the delegate is the folder preference provider, its events will be relayed via the folder scope models.
|
|
191
|
+
if (newDelegate === this.workspacePreferences) {
|
|
192
|
+
this.toDisposeOnDelegateChange.push(workspaceModel.onDidChange(() => {
|
|
193
|
+
this.onDidChangeTaskConfigEmitter.fire({ scope: task_protocol_1.TaskScope.Workspace, type: 0 /* UPDATED */ });
|
|
194
|
+
}));
|
|
195
|
+
}
|
|
196
|
+
this.models.set(task_protocol_1.TaskScope.Workspace, workspaceModel);
|
|
197
|
+
this.onDidChangeTaskConfigEmitter.fire({ scope: effectiveScope, type: 0 /* UPDATED */ });
|
|
198
|
+
}
|
|
199
|
+
}
|
|
200
|
+
};
|
|
201
|
+
__decorate([
|
|
202
|
+
(0, inversify_1.inject)(workspace_service_1.WorkspaceService),
|
|
203
|
+
__metadata("design:type", workspace_service_1.WorkspaceService)
|
|
204
|
+
], TaskConfigurationManager.prototype, "workspaceService", void 0);
|
|
205
|
+
__decorate([
|
|
206
|
+
(0, inversify_1.inject)(browser_1.EditorManager),
|
|
207
|
+
__metadata("design:type", browser_1.EditorManager)
|
|
208
|
+
], TaskConfigurationManager.prototype, "editorManager", void 0);
|
|
209
|
+
__decorate([
|
|
210
|
+
(0, inversify_1.inject)(quick_pick_service_1.QuickPickService),
|
|
211
|
+
__metadata("design:type", Object)
|
|
212
|
+
], TaskConfigurationManager.prototype, "quickPickService", void 0);
|
|
213
|
+
__decorate([
|
|
214
|
+
(0, inversify_1.inject)(file_service_1.FileService),
|
|
215
|
+
__metadata("design:type", file_service_1.FileService)
|
|
216
|
+
], TaskConfigurationManager.prototype, "fileService", void 0);
|
|
217
|
+
__decorate([
|
|
218
|
+
(0, inversify_1.inject)(browser_2.PreferenceService),
|
|
219
|
+
__metadata("design:type", Object)
|
|
220
|
+
], TaskConfigurationManager.prototype, "preferenceService", void 0);
|
|
221
|
+
__decorate([
|
|
222
|
+
(0, inversify_1.inject)(task_schema_updater_1.TaskSchemaUpdater),
|
|
223
|
+
__metadata("design:type", task_schema_updater_1.TaskSchemaUpdater)
|
|
224
|
+
], TaskConfigurationManager.prototype, "taskSchemaProvider", void 0);
|
|
225
|
+
__decorate([
|
|
226
|
+
(0, inversify_1.inject)(browser_2.PreferenceProvider),
|
|
227
|
+
(0, inversify_1.named)(browser_2.PreferenceScope.Folder),
|
|
228
|
+
__metadata("design:type", browser_2.PreferenceProvider)
|
|
229
|
+
], TaskConfigurationManager.prototype, "folderPreferences", void 0);
|
|
230
|
+
__decorate([
|
|
231
|
+
(0, inversify_1.inject)(browser_2.PreferenceProvider),
|
|
232
|
+
(0, inversify_1.named)(browser_2.PreferenceScope.User),
|
|
233
|
+
__metadata("design:type", browser_2.PreferenceProvider)
|
|
234
|
+
], TaskConfigurationManager.prototype, "userPreferences", void 0);
|
|
235
|
+
__decorate([
|
|
236
|
+
(0, inversify_1.inject)(browser_2.PreferenceProvider),
|
|
237
|
+
(0, inversify_1.named)(browser_2.PreferenceScope.Workspace),
|
|
238
|
+
__metadata("design:type", browser_2.PreferenceProvider)
|
|
239
|
+
], TaskConfigurationManager.prototype, "workspacePreferences", void 0);
|
|
240
|
+
__decorate([
|
|
241
|
+
(0, inversify_1.inject)(preference_configurations_1.PreferenceConfigurations),
|
|
242
|
+
__metadata("design:type", preference_configurations_1.PreferenceConfigurations)
|
|
243
|
+
], TaskConfigurationManager.prototype, "preferenceConfigurations", void 0);
|
|
244
|
+
__decorate([
|
|
245
|
+
(0, inversify_1.inject)(workspace_variable_contribution_1.WorkspaceVariableContribution),
|
|
246
|
+
__metadata("design:type", workspace_variable_contribution_1.WorkspaceVariableContribution)
|
|
247
|
+
], TaskConfigurationManager.prototype, "workspaceVariables", void 0);
|
|
248
|
+
__decorate([
|
|
249
|
+
(0, inversify_1.inject)(task_templates_1.TaskTemplateSelector),
|
|
250
|
+
__metadata("design:type", task_templates_1.TaskTemplateSelector)
|
|
251
|
+
], TaskConfigurationManager.prototype, "taskTemplateSelector", void 0);
|
|
252
|
+
__decorate([
|
|
253
|
+
(0, inversify_1.postConstruct)(),
|
|
254
|
+
__metadata("design:type", Function),
|
|
255
|
+
__metadata("design:paramtypes", []),
|
|
256
|
+
__metadata("design:returntype", void 0)
|
|
257
|
+
], TaskConfigurationManager.prototype, "init", null);
|
|
258
|
+
TaskConfigurationManager = __decorate([
|
|
259
|
+
(0, inversify_1.injectable)()
|
|
260
|
+
], TaskConfigurationManager);
|
|
261
|
+
exports.TaskConfigurationManager = TaskConfigurationManager;
|
|
262
262
|
//# sourceMappingURL=task-configuration-manager.js.map
|
|
@@ -1,33 +1,33 @@
|
|
|
1
|
-
import URI from '@theia/core/lib/common/uri';
|
|
2
|
-
import { Emitter, Event } from '@theia/core/lib/common/event';
|
|
3
|
-
import { Disposable, DisposableCollection } from '@theia/core/lib/common/disposable';
|
|
4
|
-
import { TaskCustomization, TaskConfiguration, TaskConfigurationScope } from '../common/task-protocol';
|
|
5
|
-
import { PreferenceProvider } from '@theia/core/lib/browser';
|
|
6
|
-
/**
|
|
7
|
-
* Holds the task configurations associated with a particular file. Uses an editor model to facilitate
|
|
8
|
-
* non-destructive editing and coordination with editing the file by hand.
|
|
9
|
-
*/
|
|
10
|
-
export declare class TaskConfigurationModel implements Disposable {
|
|
11
|
-
protected readonly scope: TaskConfigurationScope;
|
|
12
|
-
readonly preferences: PreferenceProvider;
|
|
13
|
-
protected json: TaskConfigurationModel.JsonContent;
|
|
14
|
-
protected readonly onDidChangeEmitter: Emitter<void>;
|
|
15
|
-
readonly onDidChange: Event<void>;
|
|
16
|
-
protected readonly toDispose: DisposableCollection;
|
|
17
|
-
constructor(scope: TaskConfigurationScope, preferences: PreferenceProvider);
|
|
18
|
-
get uri(): URI | undefined;
|
|
19
|
-
getWorkspaceFolder(): string | undefined;
|
|
20
|
-
dispose(): void;
|
|
21
|
-
get onDispose(): Event<void>;
|
|
22
|
-
get configurations(): (TaskCustomization | TaskConfiguration)[];
|
|
23
|
-
protected reconcile(): void;
|
|
24
|
-
setConfigurations(value: object): Promise<boolean>;
|
|
25
|
-
protected parseConfigurations(): TaskConfigurationModel.JsonContent;
|
|
26
|
-
}
|
|
27
|
-
export declare namespace TaskConfigurationModel {
|
|
28
|
-
interface JsonContent {
|
|
29
|
-
uri?: URI;
|
|
30
|
-
configurations: (TaskCustomization | TaskConfiguration)[];
|
|
31
|
-
}
|
|
32
|
-
}
|
|
1
|
+
import URI from '@theia/core/lib/common/uri';
|
|
2
|
+
import { Emitter, Event } from '@theia/core/lib/common/event';
|
|
3
|
+
import { Disposable, DisposableCollection } from '@theia/core/lib/common/disposable';
|
|
4
|
+
import { TaskCustomization, TaskConfiguration, TaskConfigurationScope } from '../common/task-protocol';
|
|
5
|
+
import { PreferenceProvider } from '@theia/core/lib/browser';
|
|
6
|
+
/**
|
|
7
|
+
* Holds the task configurations associated with a particular file. Uses an editor model to facilitate
|
|
8
|
+
* non-destructive editing and coordination with editing the file by hand.
|
|
9
|
+
*/
|
|
10
|
+
export declare class TaskConfigurationModel implements Disposable {
|
|
11
|
+
protected readonly scope: TaskConfigurationScope;
|
|
12
|
+
readonly preferences: PreferenceProvider;
|
|
13
|
+
protected json: TaskConfigurationModel.JsonContent;
|
|
14
|
+
protected readonly onDidChangeEmitter: Emitter<void>;
|
|
15
|
+
readonly onDidChange: Event<void>;
|
|
16
|
+
protected readonly toDispose: DisposableCollection;
|
|
17
|
+
constructor(scope: TaskConfigurationScope, preferences: PreferenceProvider);
|
|
18
|
+
get uri(): URI | undefined;
|
|
19
|
+
getWorkspaceFolder(): string | undefined;
|
|
20
|
+
dispose(): void;
|
|
21
|
+
get onDispose(): Event<void>;
|
|
22
|
+
get configurations(): (TaskCustomization | TaskConfiguration)[];
|
|
23
|
+
protected reconcile(): void;
|
|
24
|
+
setConfigurations(value: object): Promise<boolean>;
|
|
25
|
+
protected parseConfigurations(): TaskConfigurationModel.JsonContent;
|
|
26
|
+
}
|
|
27
|
+
export declare namespace TaskConfigurationModel {
|
|
28
|
+
interface JsonContent {
|
|
29
|
+
uri?: URI;
|
|
30
|
+
configurations: (TaskCustomization | TaskConfiguration)[];
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
33
|
//# sourceMappingURL=task-configuration-model.d.ts.map
|