|
3 | 3 | * Licensed under the MIT License. See License.txt in the project root for license information. |
4 | 4 | *--------------------------------------------------------------------------------------------*/ |
5 | 5 |
|
6 | | -import { CompletionItemProvider, TextDocument, Position, CompletionContext, CompletionList, CompletionItem, MarkdownString, TextEdit, Range, SnippetString } from "vscode"; |
| 6 | +import { CompletionItemProvider, TextDocument, Position, CompletionContext, CompletionList, CompletionItem, MarkdownString, TextEdit, Range, SnippetString, window, Selection, WorkspaceEdit, workspace } from "vscode"; |
7 | 7 | import AbstractProvider from "./abstractProvider"; |
8 | 8 | import * as protocol from "../omnisharp/protocol"; |
9 | 9 | import * as serverUtils from '../omnisharp/utils'; |
10 | 10 | import { CancellationToken, CompletionTriggerKind as LspCompletionTriggerKind, InsertTextFormat } from "vscode-languageserver-protocol"; |
11 | 11 | import { createRequest } from "../omnisharp/typeConversion"; |
| 12 | +import { LanguageMiddlewareFeature } from "../omnisharp/LanguageMiddlewareFeature"; |
| 13 | +import { OmniSharpServer } from "../omnisharp/server"; |
| 14 | + |
| 15 | +export const CompletionAfterInsertCommand = "csharp.completion.afterInsert"; |
12 | 16 |
|
13 | 17 | export default class OmnisharpCompletionProvider extends AbstractProvider implements CompletionItemProvider { |
14 | 18 |
|
15 | 19 | #lastCompletions?: Map<CompletionItem, protocol.OmnisharpCompletionItem>; |
16 | 20 |
|
| 21 | + constructor(server: OmniSharpServer, languageMiddlewareFeature: LanguageMiddlewareFeature) { |
| 22 | + super(server, languageMiddlewareFeature); |
| 23 | + } |
| 24 | + |
17 | 25 | public async provideCompletionItems(document: TextDocument, position: Position, token: CancellationToken, context: CompletionContext): Promise<CompletionList> { |
18 | 26 | let request = createRequest<protocol.CompletionRequest>(document, position); |
19 | 27 | request.CompletionTrigger = (context.triggerKind + 1) as LspCompletionTriggerKind; |
20 | 28 | request.TriggerCharacter = context.triggerCharacter; |
21 | 29 |
|
22 | 30 | try { |
23 | 31 | const response = await serverUtils.getCompletion(this._server, request, token); |
24 | | - const mappedItems = response.Items.map(this._convertToVscodeCompletionItem); |
| 32 | + const mappedItems = response.Items.map(arg => this._convertToVscodeCompletionItem(arg)); |
25 | 33 |
|
26 | 34 | let lastCompletions = new Map(); |
27 | 35 |
|
@@ -59,6 +67,40 @@ export default class OmnisharpCompletionProvider extends AbstractProvider implem |
59 | 67 | } |
60 | 68 | } |
61 | 69 |
|
| 70 | + public async afterInsert(item: protocol.OmnisharpCompletionItem) { |
| 71 | + try { |
| 72 | + const uri = window.activeTextEditor.document.uri; |
| 73 | + const response = await serverUtils.getCompletionAfterInsert(this._server, { Item: item }); |
| 74 | + |
| 75 | + if (!response.Changes || !response.Column || !response.Line) { |
| 76 | + return; |
| 77 | + } |
| 78 | + |
| 79 | + let edit = new WorkspaceEdit(); |
| 80 | + edit.set(uri, response.Changes.map(change => ({ |
| 81 | + newText: change.NewText, |
| 82 | + range: new Range(new Position(change.StartLine, change.StartColumn), |
| 83 | + new Position(change.EndLine, change.EndColumn)) |
| 84 | + }))); |
| 85 | + |
| 86 | + edit = await this._languageMiddlewareFeature.remap("remapWorkspaceEdit", edit, CancellationToken.None); |
| 87 | + |
| 88 | + const applied = await workspace.applyEdit(edit); |
| 89 | + if (!applied) { |
| 90 | + return; |
| 91 | + } |
| 92 | + |
| 93 | + const responseLine = response.Line; |
| 94 | + const responseColumn = response.Column; |
| 95 | + |
| 96 | + const finalPosition = new Position(responseLine, responseColumn); |
| 97 | + window.activeTextEditor.selections = [new Selection(finalPosition, finalPosition)]; |
| 98 | + } |
| 99 | + catch (error) { |
| 100 | + return; |
| 101 | + } |
| 102 | + } |
| 103 | + |
62 | 104 | private _convertToVscodeCompletionItem(omnisharpCompletion: protocol.OmnisharpCompletionItem): CompletionItem { |
63 | 105 | const docs: MarkdownString | undefined = omnisharpCompletion.Documentation ? new MarkdownString(omnisharpCompletion.Documentation, false) : undefined; |
64 | 106 |
|
@@ -94,7 +136,8 @@ export default class OmnisharpCompletionProvider extends AbstractProvider implem |
94 | 136 | tags: omnisharpCompletion.Tags, |
95 | 137 | sortText: omnisharpCompletion.SortText, |
96 | 138 | additionalTextEdits: additionalTextEdits, |
97 | | - keepWhitespace: true |
| 139 | + keepWhitespace: true, |
| 140 | + command: omnisharpCompletion.HasAfterInsertStep ? { command: CompletionAfterInsertCommand, title: "", arguments: [omnisharpCompletion] } : undefined |
98 | 141 | }; |
99 | 142 | } |
100 | 143 | } |
0 commit comments