Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

move builtin terminal quick fixes to contribution model #164099

Merged
merged 30 commits into from
Oct 24, 2022
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
30 commits
Select commit Hold shift + click to select a range
2fdae24
add stuff
meganrogge Oct 20, 2022
1899843
tweak
meganrogge Oct 20, 2022
ce05e51
Revert "add stuff"
meganrogge Oct 20, 2022
55bac09
Revert "tweak"
meganrogge Oct 20, 2022
0f5d4df
delete proposed api
meganrogge Oct 20, 2022
b8c2800
add contribution point
meganrogge Oct 20, 2022
6849d34
don't register another terminal contrib point
meganrogge Oct 20, 2022
6f03181
combine contrib points
meganrogge Oct 20, 2022
7f24e91
adopt contributed quick fixes
meganrogge Oct 20, 2022
0d97708
contribute git push quick fix as test
meganrogge Oct 20, 2022
5491e28
delete logs, replace all
meganrogge Oct 20, 2022
074e3c1
Revert "contribute git push quick fix as test"
meganrogge Oct 20, 2022
331c596
return [] if resolved variable is not in expected command/link
meganrogge Oct 20, 2022
0cdc829
add group: prefix to variables
meganrogge Oct 20, 2022
ca231dd
Merge branch 'main' into merogge/provider-quick-fix
meganrogge Oct 20, 2022
701c201
allow multiple groups to be resolved
meganrogge Oct 20, 2022
d34164e
improve docs
meganrogge Oct 20, 2022
45f9614
improve description
meganrogge Oct 20, 2022
19daf71
fix test
meganrogge Oct 20, 2022
33c66e4
Merge branch 'main' into merogge/provider-quick-fix
meganrogge Oct 24, 2022
34a85a4
fix test
meganrogge Oct 24, 2022
0cc0ae8
fix #163965
meganrogge Oct 24, 2022
f58c431
move 3 fixes over to extension contrib model
meganrogge Oct 24, 2022
09264dc
add proposed api placeholder file
meganrogge Oct 24, 2022
2a65a5c
fix test
meganrogge Oct 24, 2022
cbd24be
rename
meganrogge Oct 24, 2022
b091327
reinsert notebook proposal
meganrogge Oct 24, 2022
f6b1ddb
revert change bc args were lost w git similar
meganrogge Oct 24, 2022
db9ff8b
Merge branch 'main' into merogge/provider-quick-fix
meganrogge Oct 24, 2022
476360f
revert accidental deletion
meganrogge Oct 24, 2022
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
15 changes: 14 additions & 1 deletion src/vs/platform/terminal/common/terminal.ts
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ import { Event } from 'vs/base/common/event';
import { IProcessEnvironment, OperatingSystem } from 'vs/base/common/platform';
import { URI, UriComponents } from 'vs/base/common/uri';
import { createDecorator } from 'vs/platform/instantiation/common/instantiation';
import { IPtyHostProcessReplayEvent, ISerializedCommandDetectionCapability, ITerminalCapabilityStore } from 'vs/platform/terminal/common/capabilities/capabilities';
import { IPtyHostProcessReplayEvent, ISerializedCommandDetectionCapability, ITerminalCapabilityStore, ITerminalOutputMatcher } from 'vs/platform/terminal/common/capabilities/capabilities';
import { IGetTerminalLayoutInfoArgs, IProcessDetails, ISetTerminalLayoutInfoArgs } from 'vs/platform/terminal/common/terminalProcess';
import { ThemeIcon } from 'vs/platform/theme/common/themeService';
import { ISerializableEnvironmentVariableCollections } from 'vs/platform/terminal/common/environmentVariable';
Expand Down Expand Up @@ -799,6 +799,15 @@ export interface ITerminalContributions {
profiles?: ITerminalProfileContribution[];
}

export interface ITerminalQuickFixContribution {
id: string;
commandLineMatcher: string | RegExp;
outputMatcher: ITerminalOutputMatcher;
exitStatus?: boolean;
meganrogge marked this conversation as resolved.
Show resolved Hide resolved
commandToRun?: string;
meganrogge marked this conversation as resolved.
Show resolved Hide resolved
linkToOpen?: string;
meganrogge marked this conversation as resolved.
Show resolved Hide resolved
}

export interface ITerminalProfileContribution {
title: string;
id: string;
Expand All @@ -810,6 +819,10 @@ export interface IExtensionTerminalProfile extends ITerminalProfileContribution
extensionIdentifier: string;
}

export interface IExtensionTerminalQuickFix extends ITerminalQuickFixContribution {
extensionIdentifier: string;
}

export type ITerminalProfileObject = ITerminalExecutable | ITerminalProfileSource | IExtensionTerminalProfile | null;
export type ITerminalProfileType = ITerminalProfile | IExtensionTerminalProfile;

Expand Down
48 changes: 48 additions & 0 deletions src/vs/workbench/contrib/terminal/common/terminal.ts
Original file line number Diff line number Diff line change
Expand Up @@ -717,6 +717,54 @@ export const terminalContributionsDescriptor: IExtensionPointDescriptor = {
description: nls.localize('vscode.extension.contributes.terminal', 'Contributes terminal functionality.'),
type: 'object',
properties: {
quickFixes: {
type: 'array',
description: nls.localize('vscode.extension.contributes.terminal.quickFixes', "Defines quick fixes for terminals with shell integration enabled."),
items: {
type: 'object',
required: ['id', 'commandLineMatcher', 'outputMatcher'],
defaultSnippets: [{
body: {
id: '$1',
commandLineMatcher: '$2',
outputMatcher: '$3'
}
}],
properties: {
id: {
description: nls.localize('vscode.extension.contributes.terminal.quickFixes.id', "The ID of the quick fix."),
type: 'string',
},
commandLineMatcher: {
description: nls.localize('vscode.extension.contributes.terminal.quickFixes.commandLineMatcher', "The command line to match."),
type: 'string',
},
outputMatcher: {
description: nls.localize('vscode.extension.contributes.terminal.quickFixes.outputMatcher', "The output to match."),
type: 'object',
required: ['lineMatcher', 'anchor', 'offset', 'length'],
properties: {
lineMatcher: {
description: 'The command line to match',
type: 'string'
},
anchor: {
description: 'Which side of the output to anchor the offset and length against',
enum: ['top', 'bottom']
},
offset: {
description: 'How far from either the top or the bottom of the butter to start matching against.',
type: 'number'
},
length: {
description: 'The number of rows to match against, this should be as small as possible for performance reasons',
type: 'number'
}
}
},
},
}
},
profiles: {
type: 'array',
description: nls.localize('vscode.extension.contributes.terminal.profiles', "Defines additional terminal profiles that the user can create."),
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -5,5 +5,7 @@

import { InstantiationType, registerSingleton } from 'vs/platform/instantiation/common/extensions';
import { ITerminalContributionService, TerminalContributionService } from 'vs/workbench/contrib/terminal/common/terminalExtensionPoints';
import { ITerminalQuickFixContributionsService, TerminalQuickFixContributionService } from 'vs/workbench/contrib/terminal/common/terminalQuickFixExtensionPoint';

registerSingleton(ITerminalContributionService, TerminalContributionService, InstantiationType.Delayed);
registerSingleton(ITerminalQuickFixContributionsService, TerminalQuickFixContributionService, InstantiationType.Delayed);
Original file line number Diff line number Diff line change
@@ -0,0 +1,43 @@
/*---------------------------------------------------------------------------------------------
* Copyright (c) Microsoft Corporation. All rights reserved.
* Licensed under the MIT License. See License.txt in the project root for license information.
*--------------------------------------------------------------------------------------------*/

import * as extensionsRegistry from 'vs/workbench/services/extensions/common/extensionsRegistry';
import { terminalContributionsDescriptor } from 'vs/workbench/contrib/terminal/common/terminal';
import { createDecorator } from 'vs/platform/instantiation/common/instantiation';
import { IExtensionTerminalQuickFix, ITerminalQuickFixContribution } from 'vs/platform/terminal/common/terminal';

export const terminalQuickFixExtPoint = extensionsRegistry.ExtensionsRegistry.registerExtensionPoint<ITerminalQuickFixContribution>(terminalContributionsDescriptor);

export interface ITerminalQuickFixContributionsService {
readonly _serviceBrand: undefined;

readonly quickFixes: Array<IExtensionTerminalQuickFix>;
}

export const ITerminalQuickFixContributionsService = createDecorator<ITerminalQuickFixContributionsService>('terminalQuickFixContributionsService');

export class TerminalQuickFixContributionService implements ITerminalQuickFixContributionsService {
declare _serviceBrand: undefined;

private _quickFixes: Array<IExtensionTerminalQuickFix> = [];
get quickFixes() { return this._quickFixes; }

constructor() {
terminalQuickFixExtPoint.setHandler(contributions => {
for (const c of contributions) {
const fix = c.value;
this._quickFixes.push({
id: fix.id,
commandLineMatcher: fix.commandLineMatcher,
outputMatcher: fix.outputMatcher,
commandToRun: fix.commandToRun,
linkToOpen: fix.linkToOpen,
extensionIdentifier: c.description.identifier.value
});
}
return this._quickFixes;
});
}
}