提交 c179d2f7 编写于 作者: A Alex Ross

Task tweaks for tasks in workspace file

Part of #1435
上级 3fc8e407
......@@ -1054,8 +1054,8 @@ export abstract class AbstractTaskService extends Disposable implements ITaskSer
}
});
let resolver: ITaskResolver = {
resolve: (workspaceFolder: IWorkspaceFolder, alias: string) => {
let data = resolverData.get(workspaceFolder.uri.toString());
resolve: (uri: URI, alias: string) => {
let data = resolverData.get(uri.toString());
if (!data) {
return undefined;
}
......@@ -1086,7 +1086,7 @@ export abstract class AbstractTaskService extends Disposable implements ITaskSer
{ reevaluateOnRerun: true },
{
identifier: id,
dependsOn: extensionTasks.map((extensionTask) => { return { workspaceFolder: extensionTask.getWorkspaceFolder()!, task: extensionTask._id }; }),
dependsOn: extensionTasks.map((extensionTask) => { return { uri: extensionTask.getWorkspaceFolder()!.uri, task: extensionTask._id }; }),
name: id,
}
);
......@@ -1119,9 +1119,10 @@ export abstract class AbstractTaskService extends Disposable implements ITaskSer
}
}
});
return {
resolve: (workspaceFolder: IWorkspaceFolder, identifier: string | TaskIdentifier | undefined) => {
let data = resolverData.get(workspaceFolder.uri.toString());
resolve: (uri: URI, identifier: string | TaskIdentifier | undefined) => {
let data = uri ? resolverData.get(uri.toString()) : undefined;
if (!data || !identifier) {
return undefined;
}
......@@ -1949,7 +1950,7 @@ export abstract class AbstractTaskService extends Disposable implements ITaskSer
let resolver = this.createResolver(grouped);
let folders = this.contextService.getWorkspace().folders;
for (let folder of folders) {
let task = resolver.resolve(folder, identifier);
let task = resolver.resolve(folder.uri, identifier);
if (task) {
this.run(task).then(undefined, reason => {
// eat the error, it has already been surfaced to the user and we don't care about it here
......
......@@ -347,7 +347,7 @@ export class TerminalTaskSystem implements ITaskSystem {
let promises: Promise<ITaskSummary>[] = [];
if (task.configurationProperties.dependsOn) {
for (const dependency of task.configurationProperties.dependsOn) {
let dependencyTask = resolver.resolve(dependency.workspaceFolder, dependency.task!);
let dependencyTask = resolver.resolve(dependency.uri, dependency.task!);
if (dependencyTask) {
let key = dependencyTask.getMapKey();
let promise = this.activeTasks[key] ? this.activeTasks[key].promise : undefined;
......@@ -363,7 +363,7 @@ export class TerminalTaskSystem implements ITaskSystem {
this.log(nls.localize('dependencyFailed',
'Couldn\'t resolve dependent task \'{0}\' in workspace folder \'{1}\'',
Types.isString(dependency.task) ? dependency.task : JSON.stringify(dependency.task, undefined, 0),
dependency.workspaceFolder.name
dependency.uri.toString()
));
this.showOutput();
}
......
......@@ -1226,9 +1226,12 @@ namespace GroupKind {
namespace TaskDependency {
export function from(this: void, external: string | TaskIdentifier, context: ParseContext): Tasks.TaskDependency | undefined {
if (Types.isString(external)) {
return { workspaceFolder: context.workspaceFolder, task: external };
return { uri: context.workspace && context.workspace.configuration ? context.workspace.configuration : context.workspaceFolder.uri, task: external };
} else if (TaskIdentifier.is(external)) {
return { workspaceFolder: context.workspaceFolder, task: Tasks.TaskDefinition.createTaskIdentifier(external as Tasks.TaskIdentifier, context.problemReporter) };
return {
uri: context.workspace && context.workspace.configuration ? context.workspace.configuration : context.workspaceFolder.uri,
task: Tasks.TaskDefinition.createTaskIdentifier(external as Tasks.TaskIdentifier, context.problemReporter)
};
} else {
return undefined;
}
......
......@@ -93,7 +93,7 @@ export interface ITaskExecuteResult {
}
export interface ITaskResolver {
resolve(workspaceFolder: IWorkspaceFolder, identifier: string | KeyedTaskIdentifier | undefined): Task | undefined;
resolve(uri: URI, identifier: string | KeyedTaskIdentifier | undefined): Task | undefined;
}
export interface TaskTerminateResponse extends TerminateResponse {
......
......@@ -8,7 +8,7 @@ import * as Types from 'vs/base/common/types';
import * as resources from 'vs/base/common/resources';
import { IJSONSchemaMap } from 'vs/base/common/jsonSchema';
import * as Objects from 'vs/base/common/objects';
import { UriComponents } from 'vs/base/common/uri';
import { UriComponents, URI } from 'vs/base/common/uri';
import { ProblemMatcher } from 'vs/workbench/contrib/tasks/common/problemMatcher';
import { IWorkspaceFolder, IWorkspace } from 'vs/platform/workspace/common/workspace';
......@@ -438,7 +438,7 @@ export interface KeyedTaskIdentifier extends TaskIdentifier {
}
export interface TaskDependency {
workspaceFolder: IWorkspaceFolder;
uri: URI;
task: string | KeyedTaskIdentifier | undefined;
}
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册