@theia/task 1.53.0-next.4 → 1.53.0-next.55

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 (60) hide show
  1. package/README.md +193 -193
  2. package/lib/browser/task-schema-updater.js +1 -1
  3. package/package.json +13 -13
  4. package/src/browser/index.ts +22 -22
  5. package/src/browser/process/process-task-contribution.ts +31 -31
  6. package/src/browser/process/process-task-frontend-module.ts +27 -27
  7. package/src/browser/process/process-task-resolver.ts +89 -89
  8. package/src/browser/provided-task-configurations.spec.ts +46 -46
  9. package/src/browser/provided-task-configurations.ts +213 -213
  10. package/src/browser/quick-open-task.ts +831 -831
  11. package/src/browser/style/index.css +19 -19
  12. package/src/browser/task-configuration-manager.ts +256 -256
  13. package/src/browser/task-configuration-model.ts +101 -101
  14. package/src/browser/task-configurations.ts +508 -508
  15. package/src/browser/task-contribution.ts +266 -266
  16. package/src/browser/task-definition-registry.spec.ts +203 -203
  17. package/src/browser/task-definition-registry.ts +131 -131
  18. package/src/browser/task-frontend-contribution.ts +402 -402
  19. package/src/browser/task-frontend-module.ts +86 -86
  20. package/src/browser/task-name-resolver.ts +55 -55
  21. package/src/browser/task-node.ts +37 -37
  22. package/src/browser/task-preferences.ts +40 -40
  23. package/src/browser/task-problem-matcher-registry.ts +308 -308
  24. package/src/browser/task-problem-pattern-registry.ts +196 -196
  25. package/src/browser/task-schema-updater.ts +701 -701
  26. package/src/browser/task-service.ts +1164 -1164
  27. package/src/browser/task-source-resolver.ts +36 -36
  28. package/src/browser/task-templates.ts +168 -168
  29. package/src/browser/task-terminal-widget-manager.ts +224 -224
  30. package/src/browser/tasks-monaco-contribution.ts +27 -27
  31. package/src/common/index.ts +20 -20
  32. package/src/common/problem-matcher-protocol.ts +234 -234
  33. package/src/common/process/task-protocol.ts +97 -97
  34. package/src/common/task-common-module.ts +34 -34
  35. package/src/common/task-protocol.ts +317 -317
  36. package/src/common/task-util.ts +43 -43
  37. package/src/common/task-watcher.ts +78 -78
  38. package/src/node/custom/custom-task-runner-backend-module.ts +37 -37
  39. package/src/node/custom/custom-task-runner-contribution.ts +30 -30
  40. package/src/node/custom/custom-task-runner.ts +60 -60
  41. package/src/node/custom/custom-task.ts +73 -73
  42. package/src/node/index.ts +19 -19
  43. package/src/node/process/process-task-runner-backend-module.ts +37 -37
  44. package/src/node/process/process-task-runner-contribution.ts +31 -31
  45. package/src/node/process/process-task-runner.ts +371 -371
  46. package/src/node/process/process-task.spec.ts +30 -30
  47. package/src/node/process/process-task.ts +144 -144
  48. package/src/node/task-abstract-line-matcher.ts +312 -312
  49. package/src/node/task-backend-application-contribution.ts +36 -36
  50. package/src/node/task-backend-module.ts +57 -57
  51. package/src/node/task-line-matchers.ts +127 -127
  52. package/src/node/task-manager.ts +129 -129
  53. package/src/node/task-problem-collector.spec.ts +338 -338
  54. package/src/node/task-problem-collector.ts +62 -62
  55. package/src/node/task-runner-protocol.ts +33 -33
  56. package/src/node/task-runner.ts +96 -96
  57. package/src/node/task-server.slow-spec.ts +444 -444
  58. package/src/node/task-server.ts +263 -263
  59. package/src/node/task.ts +103 -103
  60. package/src/node/test/task-test-container.ts +63 -63
@@ -1,308 +1,308 @@
1
- // *****************************************************************************
2
- // Copyright (C) 2019 Ericsson and others.
3
- //
4
- // This program and the accompanying materials are made available under the
5
- // terms of the Eclipse Public License v. 2.0 which is available at
6
- // http://www.eclipse.org/legal/epl-2.0.
7
- //
8
- // This Source Code may also be made available under the following Secondary
9
- // Licenses when the conditions for such availability set forth in the Eclipse
10
- // Public License v. 2.0 are satisfied: GNU General Public License, version 2
11
- // with the GNU Classpath Exception which is available at
12
- // https://www.gnu.org/software/classpath/license.html.
13
- //
14
- // SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-only WITH Classpath-exception-2.0
15
- // *****************************************************************************
16
-
17
- /*---------------------------------------------------------------------------------------------
18
- * Copyright (c) Microsoft Corporation. All rights reserved.
19
- * Licensed under the MIT License. See License.txt in the project root for license information.
20
- *--------------------------------------------------------------------------------------------*/
21
-
22
- import { inject, injectable, postConstruct } from '@theia/core/shared/inversify';
23
- import { Event, Emitter } from '@theia/core/lib/common';
24
- import { Disposable, DisposableCollection } from '@theia/core/lib/common/disposable';
25
- import {
26
- ApplyToKind, FileLocationKind, NamedProblemMatcher,
27
- ProblemPattern, ProblemMatcher, ProblemMatcherContribution, WatchingMatcher,
28
- fromVariableName
29
- } from '../common';
30
- import { ProblemPatternRegistry } from './task-problem-pattern-registry';
31
- import { Severity } from '@theia/core/lib/common/severity';
32
- import { Deferred } from '@theia/core/lib/common/promise-util';
33
-
34
- @injectable()
35
- export class ProblemMatcherRegistry {
36
-
37
- private readonly matchers = new Map<string, NamedProblemMatcher>();
38
- private readyPromise = new Deferred<void>();
39
-
40
- @inject(ProblemPatternRegistry)
41
- protected readonly problemPatternRegistry: ProblemPatternRegistry;
42
-
43
- protected readonly onDidChangeProblemMatcherEmitter = new Emitter<void>();
44
- get onDidChangeProblemMatcher(): Event<void> {
45
- return this.onDidChangeProblemMatcherEmitter.event;
46
- }
47
-
48
- @postConstruct()
49
- protected init(): void {
50
- this.problemPatternRegistry.onReady().then(() => {
51
- this.fillDefaults();
52
- this.readyPromise.resolve();
53
- this.onDidChangeProblemMatcherEmitter.fire(undefined);
54
- });
55
- }
56
-
57
- onReady(): Promise<void> {
58
- return this.readyPromise.promise;
59
- }
60
-
61
- /**
62
- * Add a problem matcher to the registry.
63
- *
64
- * @param definition the problem matcher to be added.
65
- */
66
- register(matcher: ProblemMatcherContribution): Disposable {
67
- if (!matcher.name) {
68
- console.error('Only named Problem Matchers can be registered.');
69
- return Disposable.NULL;
70
- }
71
- const toDispose = new DisposableCollection(Disposable.create(() => {
72
- /* mark as not disposed */
73
- this.onDidChangeProblemMatcherEmitter.fire(undefined);
74
- }));
75
- this.doRegister(matcher, toDispose).then(() => this.onDidChangeProblemMatcherEmitter.fire(undefined));
76
- return toDispose;
77
- }
78
-
79
- protected async doRegister(matcher: ProblemMatcherContribution, toDispose: DisposableCollection): Promise<void> {
80
- const problemMatcher = await this.getProblemMatcherFromContribution(matcher);
81
- if (toDispose.disposed) {
82
- return;
83
- }
84
- toDispose.push(this.add(problemMatcher as NamedProblemMatcher));
85
- }
86
-
87
- /**
88
- * Finds the problem matcher from the registry by its name.
89
- *
90
- * @param name the name of the problem matcher
91
- * @return the problem matcher. If the task definition is not found, `undefined` is returned.
92
- */
93
- get(name: string): NamedProblemMatcher | undefined {
94
- return this.matchers.get(fromVariableName(name));
95
- }
96
-
97
- /**
98
- * Returns all registered problem matchers in the registry.
99
- */
100
- getAll(): NamedProblemMatcher[] {
101
- const all: NamedProblemMatcher[] = [];
102
- for (const matcherName of this.matchers.keys()) {
103
- all.push(this.get(matcherName)!);
104
- }
105
- all.sort((one, other) => one.name.localeCompare(other.name));
106
- return all;
107
- }
108
-
109
- /**
110
- * Transforms the `ProblemMatcherContribution` to a `ProblemMatcher`
111
- *
112
- * @return the problem matcher
113
- */
114
- async getProblemMatcherFromContribution(matcher: ProblemMatcherContribution): Promise<ProblemMatcher> {
115
- let baseMatcher: NamedProblemMatcher | undefined;
116
- if (matcher.base) {
117
- baseMatcher = this.get(matcher.base);
118
- }
119
-
120
- let fileLocation: FileLocationKind | undefined;
121
- let filePrefix: string | undefined;
122
- if (matcher.fileLocation === undefined) {
123
- fileLocation = baseMatcher ? baseMatcher.fileLocation : FileLocationKind.Relative;
124
- filePrefix = baseMatcher ? baseMatcher.filePrefix : '${workspaceFolder}';
125
- } else {
126
- const locationAndPrefix = this.getFileLocationKindAndPrefix(matcher);
127
- fileLocation = locationAndPrefix.fileLocation;
128
- filePrefix = locationAndPrefix.filePrefix;
129
- }
130
-
131
- const patterns: ProblemPattern[] = [];
132
- if (matcher.pattern) {
133
- if (typeof matcher.pattern === 'string') {
134
- await this.problemPatternRegistry.onReady();
135
- const registeredPattern = this.problemPatternRegistry.get(fromVariableName(matcher.pattern));
136
- if (Array.isArray(registeredPattern)) {
137
- patterns.push(...registeredPattern);
138
- } else if (!!registeredPattern) {
139
- patterns.push(registeredPattern);
140
- }
141
- } else if (Array.isArray(matcher.pattern)) {
142
- patterns.push(...matcher.pattern.map(p => ProblemPattern.fromProblemPatternContribution(p)));
143
- } else {
144
- patterns.push(ProblemPattern.fromProblemPatternContribution(matcher.pattern));
145
- }
146
- } else if (baseMatcher) {
147
- if (Array.isArray(baseMatcher.pattern)) {
148
- patterns.push(...baseMatcher.pattern);
149
- } else {
150
- patterns.push(baseMatcher.pattern);
151
- }
152
- }
153
-
154
- let deprecated: boolean | undefined = matcher.deprecated;
155
- if (deprecated === undefined && baseMatcher) {
156
- deprecated = baseMatcher.deprecated;
157
- }
158
-
159
- let applyTo: ApplyToKind | undefined;
160
- if (matcher.applyTo === undefined) {
161
- applyTo = baseMatcher ? baseMatcher.applyTo : ApplyToKind.allDocuments;
162
- } else {
163
- applyTo = ApplyToKind.fromString(matcher.applyTo) || ApplyToKind.allDocuments;
164
- }
165
-
166
- let severity: Severity = Severity.fromValue(matcher.severity);
167
- if (matcher.severity === undefined && baseMatcher && baseMatcher.severity !== undefined) {
168
- severity = baseMatcher.severity;
169
- }
170
- let watching: WatchingMatcher | undefined = WatchingMatcher.fromWatchingMatcherContribution(matcher.background || matcher.watching);
171
- if (watching === undefined && baseMatcher) {
172
- watching = baseMatcher.watching;
173
- }
174
- const problemMatcher = {
175
- name: matcher.name || (baseMatcher ? baseMatcher.name : undefined),
176
- label: matcher.label || baseMatcher?.label || '',
177
- deprecated,
178
- owner: matcher.owner || (baseMatcher ? baseMatcher.owner : ''),
179
- source: matcher.source || (baseMatcher ? baseMatcher.source : undefined),
180
- applyTo,
181
- fileLocation,
182
- filePrefix,
183
- pattern: patterns,
184
- severity,
185
- watching
186
- };
187
- return problemMatcher;
188
- }
189
-
190
- private add(matcher: NamedProblemMatcher): Disposable {
191
- this.matchers.set(matcher.name, matcher);
192
- return Disposable.create(() => this.matchers.delete(matcher.name));
193
- }
194
-
195
- private getFileLocationKindAndPrefix(matcher: ProblemMatcherContribution): { fileLocation: FileLocationKind, filePrefix: string } {
196
- let fileLocation = FileLocationKind.Relative;
197
- let filePrefix = '${workspaceFolder}';
198
- if (matcher.fileLocation !== undefined) {
199
- if (Array.isArray(matcher.fileLocation)) {
200
- if (matcher.fileLocation.length > 0) {
201
- const locationKind = FileLocationKind.fromString(matcher.fileLocation[0]);
202
- if (matcher.fileLocation.length === 1 && locationKind === FileLocationKind.Absolute) {
203
- fileLocation = locationKind;
204
- } else if (matcher.fileLocation.length === 2 && locationKind === FileLocationKind.Relative && matcher.fileLocation[1]) {
205
- fileLocation = locationKind;
206
- filePrefix = matcher.fileLocation[1];
207
- }
208
- }
209
- } else {
210
- const locationKind = FileLocationKind.fromString(matcher.fileLocation);
211
- if (locationKind) {
212
- fileLocation = locationKind;
213
- if (locationKind === FileLocationKind.Relative) {
214
- filePrefix = '${workspaceFolder}';
215
- }
216
- }
217
- }
218
- }
219
- return { fileLocation, filePrefix };
220
- }
221
-
222
- // copied from https://github.com/Microsoft/vscode/blob/1.33.1/src/vs/workbench/contrib/tasks/common/problemMatcher.ts
223
- private fillDefaults(): void {
224
- this.add({
225
- name: 'msCompile',
226
- label: 'Microsoft compiler problems',
227
- owner: 'msCompile',
228
- applyTo: ApplyToKind.allDocuments,
229
- fileLocation: FileLocationKind.Absolute,
230
- pattern: (this.problemPatternRegistry.get('msCompile'))!
231
- });
232
-
233
- this.add({
234
- name: 'lessCompile',
235
- label: 'Less problems',
236
- deprecated: true,
237
- owner: 'lessCompile',
238
- source: 'less',
239
- applyTo: ApplyToKind.allDocuments,
240
- fileLocation: FileLocationKind.Absolute,
241
- pattern: (this.problemPatternRegistry.get('lessCompile'))!,
242
- severity: Severity.Error
243
- });
244
-
245
- this.add({
246
- name: 'gulp-tsc',
247
- label: 'Gulp TSC Problems',
248
- owner: 'typescript',
249
- source: 'ts',
250
- applyTo: ApplyToKind.closedDocuments,
251
- fileLocation: FileLocationKind.Relative,
252
- filePrefix: '${workspaceFolder}',
253
- pattern: (this.problemPatternRegistry.get('gulp-tsc'))!
254
- });
255
-
256
- this.add({
257
- name: 'jshint',
258
- label: 'JSHint problems',
259
- owner: 'jshint',
260
- source: 'jshint',
261
- applyTo: ApplyToKind.allDocuments,
262
- fileLocation: FileLocationKind.Absolute,
263
- pattern: (this.problemPatternRegistry.get('jshint'))!
264
- });
265
-
266
- this.add({
267
- name: 'jshint-stylish',
268
- label: 'JSHint stylish problems',
269
- owner: 'jshint',
270
- source: 'jshint',
271
- applyTo: ApplyToKind.allDocuments,
272
- fileLocation: FileLocationKind.Absolute,
273
- pattern: (this.problemPatternRegistry.get('jshint-stylish'))!
274
- });
275
-
276
- this.add({
277
- name: 'eslint-compact',
278
- label: 'ESLint compact problems',
279
- owner: 'eslint',
280
- source: 'eslint',
281
- applyTo: ApplyToKind.allDocuments,
282
- fileLocation: FileLocationKind.Absolute,
283
- filePrefix: '${workspaceFolder}',
284
- pattern: (this.problemPatternRegistry.get('eslint-compact'))!
285
- });
286
-
287
- this.add({
288
- name: 'eslint-stylish',
289
- label: 'ESLint stylish problems',
290
- owner: 'eslint',
291
- source: 'eslint',
292
- applyTo: ApplyToKind.allDocuments,
293
- fileLocation: FileLocationKind.Absolute,
294
- pattern: (this.problemPatternRegistry.get('eslint-stylish'))!
295
- });
296
-
297
- this.add({
298
- name: 'go',
299
- label: 'Go problems',
300
- owner: 'go',
301
- source: 'go',
302
- applyTo: ApplyToKind.allDocuments,
303
- fileLocation: FileLocationKind.Relative,
304
- filePrefix: '${workspaceFolder}',
305
- pattern: (this.problemPatternRegistry.get('go'))!
306
- });
307
- }
308
- }
1
+ // *****************************************************************************
2
+ // Copyright (C) 2019 Ericsson and others.
3
+ //
4
+ // This program and the accompanying materials are made available under the
5
+ // terms of the Eclipse Public License v. 2.0 which is available at
6
+ // http://www.eclipse.org/legal/epl-2.0.
7
+ //
8
+ // This Source Code may also be made available under the following Secondary
9
+ // Licenses when the conditions for such availability set forth in the Eclipse
10
+ // Public License v. 2.0 are satisfied: GNU General Public License, version 2
11
+ // with the GNU Classpath Exception which is available at
12
+ // https://www.gnu.org/software/classpath/license.html.
13
+ //
14
+ // SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-only WITH Classpath-exception-2.0
15
+ // *****************************************************************************
16
+
17
+ /*---------------------------------------------------------------------------------------------
18
+ * Copyright (c) Microsoft Corporation. All rights reserved.
19
+ * Licensed under the MIT License. See License.txt in the project root for license information.
20
+ *--------------------------------------------------------------------------------------------*/
21
+
22
+ import { inject, injectable, postConstruct } from '@theia/core/shared/inversify';
23
+ import { Event, Emitter } from '@theia/core/lib/common';
24
+ import { Disposable, DisposableCollection } from '@theia/core/lib/common/disposable';
25
+ import {
26
+ ApplyToKind, FileLocationKind, NamedProblemMatcher,
27
+ ProblemPattern, ProblemMatcher, ProblemMatcherContribution, WatchingMatcher,
28
+ fromVariableName
29
+ } from '../common';
30
+ import { ProblemPatternRegistry } from './task-problem-pattern-registry';
31
+ import { Severity } from '@theia/core/lib/common/severity';
32
+ import { Deferred } from '@theia/core/lib/common/promise-util';
33
+
34
+ @injectable()
35
+ export class ProblemMatcherRegistry {
36
+
37
+ private readonly matchers = new Map<string, NamedProblemMatcher>();
38
+ private readyPromise = new Deferred<void>();
39
+
40
+ @inject(ProblemPatternRegistry)
41
+ protected readonly problemPatternRegistry: ProblemPatternRegistry;
42
+
43
+ protected readonly onDidChangeProblemMatcherEmitter = new Emitter<void>();
44
+ get onDidChangeProblemMatcher(): Event<void> {
45
+ return this.onDidChangeProblemMatcherEmitter.event;
46
+ }
47
+
48
+ @postConstruct()
49
+ protected init(): void {
50
+ this.problemPatternRegistry.onReady().then(() => {
51
+ this.fillDefaults();
52
+ this.readyPromise.resolve();
53
+ this.onDidChangeProblemMatcherEmitter.fire(undefined);
54
+ });
55
+ }
56
+
57
+ onReady(): Promise<void> {
58
+ return this.readyPromise.promise;
59
+ }
60
+
61
+ /**
62
+ * Add a problem matcher to the registry.
63
+ *
64
+ * @param definition the problem matcher to be added.
65
+ */
66
+ register(matcher: ProblemMatcherContribution): Disposable {
67
+ if (!matcher.name) {
68
+ console.error('Only named Problem Matchers can be registered.');
69
+ return Disposable.NULL;
70
+ }
71
+ const toDispose = new DisposableCollection(Disposable.create(() => {
72
+ /* mark as not disposed */
73
+ this.onDidChangeProblemMatcherEmitter.fire(undefined);
74
+ }));
75
+ this.doRegister(matcher, toDispose).then(() => this.onDidChangeProblemMatcherEmitter.fire(undefined));
76
+ return toDispose;
77
+ }
78
+
79
+ protected async doRegister(matcher: ProblemMatcherContribution, toDispose: DisposableCollection): Promise<void> {
80
+ const problemMatcher = await this.getProblemMatcherFromContribution(matcher);
81
+ if (toDispose.disposed) {
82
+ return;
83
+ }
84
+ toDispose.push(this.add(problemMatcher as NamedProblemMatcher));
85
+ }
86
+
87
+ /**
88
+ * Finds the problem matcher from the registry by its name.
89
+ *
90
+ * @param name the name of the problem matcher
91
+ * @return the problem matcher. If the task definition is not found, `undefined` is returned.
92
+ */
93
+ get(name: string): NamedProblemMatcher | undefined {
94
+ return this.matchers.get(fromVariableName(name));
95
+ }
96
+
97
+ /**
98
+ * Returns all registered problem matchers in the registry.
99
+ */
100
+ getAll(): NamedProblemMatcher[] {
101
+ const all: NamedProblemMatcher[] = [];
102
+ for (const matcherName of this.matchers.keys()) {
103
+ all.push(this.get(matcherName)!);
104
+ }
105
+ all.sort((one, other) => one.name.localeCompare(other.name));
106
+ return all;
107
+ }
108
+
109
+ /**
110
+ * Transforms the `ProblemMatcherContribution` to a `ProblemMatcher`
111
+ *
112
+ * @return the problem matcher
113
+ */
114
+ async getProblemMatcherFromContribution(matcher: ProblemMatcherContribution): Promise<ProblemMatcher> {
115
+ let baseMatcher: NamedProblemMatcher | undefined;
116
+ if (matcher.base) {
117
+ baseMatcher = this.get(matcher.base);
118
+ }
119
+
120
+ let fileLocation: FileLocationKind | undefined;
121
+ let filePrefix: string | undefined;
122
+ if (matcher.fileLocation === undefined) {
123
+ fileLocation = baseMatcher ? baseMatcher.fileLocation : FileLocationKind.Relative;
124
+ filePrefix = baseMatcher ? baseMatcher.filePrefix : '${workspaceFolder}';
125
+ } else {
126
+ const locationAndPrefix = this.getFileLocationKindAndPrefix(matcher);
127
+ fileLocation = locationAndPrefix.fileLocation;
128
+ filePrefix = locationAndPrefix.filePrefix;
129
+ }
130
+
131
+ const patterns: ProblemPattern[] = [];
132
+ if (matcher.pattern) {
133
+ if (typeof matcher.pattern === 'string') {
134
+ await this.problemPatternRegistry.onReady();
135
+ const registeredPattern = this.problemPatternRegistry.get(fromVariableName(matcher.pattern));
136
+ if (Array.isArray(registeredPattern)) {
137
+ patterns.push(...registeredPattern);
138
+ } else if (!!registeredPattern) {
139
+ patterns.push(registeredPattern);
140
+ }
141
+ } else if (Array.isArray(matcher.pattern)) {
142
+ patterns.push(...matcher.pattern.map(p => ProblemPattern.fromProblemPatternContribution(p)));
143
+ } else {
144
+ patterns.push(ProblemPattern.fromProblemPatternContribution(matcher.pattern));
145
+ }
146
+ } else if (baseMatcher) {
147
+ if (Array.isArray(baseMatcher.pattern)) {
148
+ patterns.push(...baseMatcher.pattern);
149
+ } else {
150
+ patterns.push(baseMatcher.pattern);
151
+ }
152
+ }
153
+
154
+ let deprecated: boolean | undefined = matcher.deprecated;
155
+ if (deprecated === undefined && baseMatcher) {
156
+ deprecated = baseMatcher.deprecated;
157
+ }
158
+
159
+ let applyTo: ApplyToKind | undefined;
160
+ if (matcher.applyTo === undefined) {
161
+ applyTo = baseMatcher ? baseMatcher.applyTo : ApplyToKind.allDocuments;
162
+ } else {
163
+ applyTo = ApplyToKind.fromString(matcher.applyTo) || ApplyToKind.allDocuments;
164
+ }
165
+
166
+ let severity: Severity = Severity.fromValue(matcher.severity);
167
+ if (matcher.severity === undefined && baseMatcher && baseMatcher.severity !== undefined) {
168
+ severity = baseMatcher.severity;
169
+ }
170
+ let watching: WatchingMatcher | undefined = WatchingMatcher.fromWatchingMatcherContribution(matcher.background || matcher.watching);
171
+ if (watching === undefined && baseMatcher) {
172
+ watching = baseMatcher.watching;
173
+ }
174
+ const problemMatcher = {
175
+ name: matcher.name || (baseMatcher ? baseMatcher.name : undefined),
176
+ label: matcher.label || baseMatcher?.label || '',
177
+ deprecated,
178
+ owner: matcher.owner || (baseMatcher ? baseMatcher.owner : ''),
179
+ source: matcher.source || (baseMatcher ? baseMatcher.source : undefined),
180
+ applyTo,
181
+ fileLocation,
182
+ filePrefix,
183
+ pattern: patterns,
184
+ severity,
185
+ watching
186
+ };
187
+ return problemMatcher;
188
+ }
189
+
190
+ private add(matcher: NamedProblemMatcher): Disposable {
191
+ this.matchers.set(matcher.name, matcher);
192
+ return Disposable.create(() => this.matchers.delete(matcher.name));
193
+ }
194
+
195
+ private getFileLocationKindAndPrefix(matcher: ProblemMatcherContribution): { fileLocation: FileLocationKind, filePrefix: string } {
196
+ let fileLocation = FileLocationKind.Relative;
197
+ let filePrefix = '${workspaceFolder}';
198
+ if (matcher.fileLocation !== undefined) {
199
+ if (Array.isArray(matcher.fileLocation)) {
200
+ if (matcher.fileLocation.length > 0) {
201
+ const locationKind = FileLocationKind.fromString(matcher.fileLocation[0]);
202
+ if (matcher.fileLocation.length === 1 && locationKind === FileLocationKind.Absolute) {
203
+ fileLocation = locationKind;
204
+ } else if (matcher.fileLocation.length === 2 && locationKind === FileLocationKind.Relative && matcher.fileLocation[1]) {
205
+ fileLocation = locationKind;
206
+ filePrefix = matcher.fileLocation[1];
207
+ }
208
+ }
209
+ } else {
210
+ const locationKind = FileLocationKind.fromString(matcher.fileLocation);
211
+ if (locationKind) {
212
+ fileLocation = locationKind;
213
+ if (locationKind === FileLocationKind.Relative) {
214
+ filePrefix = '${workspaceFolder}';
215
+ }
216
+ }
217
+ }
218
+ }
219
+ return { fileLocation, filePrefix };
220
+ }
221
+
222
+ // copied from https://github.com/Microsoft/vscode/blob/1.33.1/src/vs/workbench/contrib/tasks/common/problemMatcher.ts
223
+ private fillDefaults(): void {
224
+ this.add({
225
+ name: 'msCompile',
226
+ label: 'Microsoft compiler problems',
227
+ owner: 'msCompile',
228
+ applyTo: ApplyToKind.allDocuments,
229
+ fileLocation: FileLocationKind.Absolute,
230
+ pattern: (this.problemPatternRegistry.get('msCompile'))!
231
+ });
232
+
233
+ this.add({
234
+ name: 'lessCompile',
235
+ label: 'Less problems',
236
+ deprecated: true,
237
+ owner: 'lessCompile',
238
+ source: 'less',
239
+ applyTo: ApplyToKind.allDocuments,
240
+ fileLocation: FileLocationKind.Absolute,
241
+ pattern: (this.problemPatternRegistry.get('lessCompile'))!,
242
+ severity: Severity.Error
243
+ });
244
+
245
+ this.add({
246
+ name: 'gulp-tsc',
247
+ label: 'Gulp TSC Problems',
248
+ owner: 'typescript',
249
+ source: 'ts',
250
+ applyTo: ApplyToKind.closedDocuments,
251
+ fileLocation: FileLocationKind.Relative,
252
+ filePrefix: '${workspaceFolder}',
253
+ pattern: (this.problemPatternRegistry.get('gulp-tsc'))!
254
+ });
255
+
256
+ this.add({
257
+ name: 'jshint',
258
+ label: 'JSHint problems',
259
+ owner: 'jshint',
260
+ source: 'jshint',
261
+ applyTo: ApplyToKind.allDocuments,
262
+ fileLocation: FileLocationKind.Absolute,
263
+ pattern: (this.problemPatternRegistry.get('jshint'))!
264
+ });
265
+
266
+ this.add({
267
+ name: 'jshint-stylish',
268
+ label: 'JSHint stylish problems',
269
+ owner: 'jshint',
270
+ source: 'jshint',
271
+ applyTo: ApplyToKind.allDocuments,
272
+ fileLocation: FileLocationKind.Absolute,
273
+ pattern: (this.problemPatternRegistry.get('jshint-stylish'))!
274
+ });
275
+
276
+ this.add({
277
+ name: 'eslint-compact',
278
+ label: 'ESLint compact problems',
279
+ owner: 'eslint',
280
+ source: 'eslint',
281
+ applyTo: ApplyToKind.allDocuments,
282
+ fileLocation: FileLocationKind.Absolute,
283
+ filePrefix: '${workspaceFolder}',
284
+ pattern: (this.problemPatternRegistry.get('eslint-compact'))!
285
+ });
286
+
287
+ this.add({
288
+ name: 'eslint-stylish',
289
+ label: 'ESLint stylish problems',
290
+ owner: 'eslint',
291
+ source: 'eslint',
292
+ applyTo: ApplyToKind.allDocuments,
293
+ fileLocation: FileLocationKind.Absolute,
294
+ pattern: (this.problemPatternRegistry.get('eslint-stylish'))!
295
+ });
296
+
297
+ this.add({
298
+ name: 'go',
299
+ label: 'Go problems',
300
+ owner: 'go',
301
+ source: 'go',
302
+ applyTo: ApplyToKind.allDocuments,
303
+ fileLocation: FileLocationKind.Relative,
304
+ filePrefix: '${workspaceFolder}',
305
+ pattern: (this.problemPatternRegistry.get('go'))!
306
+ });
307
+ }
308
+ }