Skip to content

Commit

Permalink
fix #191745
Browse files Browse the repository at this point in the history
  • Loading branch information
meganrogge committed Apr 2, 2024
1 parent 8ef2d1d commit e4947ea
Showing 1 changed file with 53 additions and 30 deletions.
83 changes: 53 additions & 30 deletions src/vs/workbench/contrib/tasks/browser/abstractTaskService.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3001,33 +3001,8 @@ export abstract class AbstractTaskService extends Disposable implements ITaskSer
});
});
};
let globTasksDetected = false;
// First check for globs before checking for the default tasks of the task group
const absoluteURI = EditorResourceAccessor.getOriginalUri(this._editorService.activeEditor);
if (absoluteURI) {
const workspaceFolder = this._contextService.getWorkspaceFolder(absoluteURI);
if (workspaceFolder) {
const configuredTasks = this._getConfiguration(workspaceFolder)?.config?.tasks;
if (configuredTasks) {
globTasksDetected = configuredTasks.filter(task => task.group && typeof task.group !== 'string' && typeof task.group.isDefault === 'string').length > 0;
// This will activate extensions, so only do so if necessary #185960
if (globTasksDetected) {
// Fallback to absolute path of the file if it is not in a workspace or relative path cannot be found
const relativePath = workspaceFolder?.uri ? (resources.relativePath(workspaceFolder.uri, absoluteURI) ?? absoluteURI.path) : absoluteURI.path;

groupTasks = await this._findWorkspaceTasks((task) => {
const currentTaskGroup = task.configurationProperties.group;
if (currentTaskGroup && typeof currentTaskGroup !== 'string' && typeof currentTaskGroup.isDefault === 'string') {
return (currentTaskGroup._id === taskGroup._id && glob.match(currentTaskGroup.isDefault, relativePath));
}

return false;
});
}
}
}
}

const { globGroupTasks, globTasksDetected } = await this._getGlobTasks(taskGroup._id);
groupTasks = [...globGroupTasks];
if (!globTasksDetected && groupTasks.length === 0) {
groupTasks = await this._findWorkspaceTasksInGroup(taskGroup, true);
}
Expand Down Expand Up @@ -3089,6 +3064,39 @@ export abstract class AbstractTaskService extends Disposable implements ITaskSer
this._progressService.withProgress(options, () => promise);
}

private async _getGlobTasks(taskGroupId: string): Promise<{ globGroupTasks: (Task | ConfiguringTask)[]; globTasksDetected: boolean }> {
let globTasksDetected = false;
// First check for globs before checking for the default tasks of the task group
const absoluteURI = EditorResourceAccessor.getOriginalUri(this._editorService.activeEditor);
if (absoluteURI) {
const workspaceFolder = this._contextService.getWorkspaceFolder(absoluteURI);
if (workspaceFolder) {
const configuredTasks = this._getConfiguration(workspaceFolder)?.config?.tasks;
if (configuredTasks) {
globTasksDetected = configuredTasks.filter(task => task.group && typeof task.group !== 'string' && typeof task.group.isDefault === 'string').length > 0;
// This will activate extensions, so only do so if necessary #185960
if (globTasksDetected) {
// Fallback to absolute path of the file if it is not in a workspace or relative path cannot be found
const relativePath = workspaceFolder?.uri ? (resources.relativePath(workspaceFolder.uri, absoluteURI) ?? absoluteURI.path) : absoluteURI.path;

const globGroupTasks = await this._findWorkspaceTasks((task) => {
const currentTaskGroup = task.configurationProperties.group;
if (currentTaskGroup && typeof currentTaskGroup !== 'string' && typeof currentTaskGroup.isDefault === 'string') {
return (currentTaskGroup._id === taskGroupId && glob.match(currentTaskGroup.isDefault, relativePath));
}

globTasksDetected = false;
return false;
});
return { globGroupTasks, globTasksDetected };
}
}
}
}
return { globGroupTasks: [], globTasksDetected };

}

private _runBuildCommand(): void {
if (!this._tasksReconnected) {
return;
Expand Down Expand Up @@ -3432,10 +3440,25 @@ export abstract class AbstractTaskService extends Disposable implements ITaskSer
const entries: QuickPickInput<TaskQuickPickEntryType>[] = [];
let selectedTask: Task | undefined;
let selectedEntry: TaskQuickPickEntryType | undefined;
this._showIgnoredFoldersMessage().then(() => {
this._showIgnoredFoldersMessage().then(async () => {
const { globGroupTasks } = await this._getGlobTasks(TaskGroup.Build._id);
let defaultTasks = globGroupTasks;
if (!defaultTasks?.length) {
defaultTasks = this._getDefaultTasks(tasks, false);
}
let defaultBuildTask;
if (defaultTasks.length === 1) {
const group: string | TaskGroup | undefined = defaultTasks[0].configurationProperties.group;
if (group) {
if (typeof group === 'string' && group === TaskGroup.Build._id) {
defaultBuildTask = defaultTasks[0];
} else if ((group as any)._id === TaskGroup.Build._id) {
defaultBuildTask = defaultTasks[0];
}
}
}
for (const task of tasks) {
const taskGroup: TaskGroup | undefined = TaskGroup.from(task.configurationProperties.group);
if (taskGroup && taskGroup.isDefault && taskGroup._id === TaskGroup.Build._id) {
if (task === defaultBuildTask) {
const label = nls.localize('TaskService.defaultBuildTaskExists', '{0} is already marked as the default build task', TaskQuickPick.getTaskLabelWithIcon(task, task.getQualifiedLabel()));
selectedTask = task;
selectedEntry = { label, task, description: this.getTaskDescription(task), detail: this._showDetail() ? task.configurationProperties.detail : undefined };
Expand Down

0 comments on commit e4947ea

Please sign in to comment.