Skip to content

Commit

Permalink
Remove old rls.findImpls command
Browse files Browse the repository at this point in the history
This was used before LSP has considered (and now stabilised)
a 'go to implementation' request. Handling this via LSP,
even at the cost of command disappearing from the context menu [1],
is preferred than using a global command. We'd have to maintain an
extra mapping and guess which RLS server is responsible for the file
for which a request has been made. This is hacky and not guaranteed
to be correct; meanwhile we get errors in multi-root workspaces
whenever we open more than one folder due to each instance trying to
register a global command under the same identifier.

The clean solution is to remove this extra command and use the standard
Go to Implementation (under Go > Go to Implementation [Ctrl + F12])
while we wait for the user configurable menus [2] to land.

[1]: microsoft/vscode#54317
[2]: microsoft/vscode#9285
  • Loading branch information
Xanewok committed Apr 6, 2019
1 parent 2407b28 commit 7919de1
Show file tree
Hide file tree
Showing 3 changed files with 0 additions and 63 deletions.
10 changes: 0 additions & 10 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -65,16 +65,6 @@ Some highlights:

## Features

### Commands

Commands can be found in the command palette <kbd>Ctrl</kbd>+<kbd>Shift</kbd>+<kbd>P</kbd>. We provide the
following commands:

* `Find Implementations` - Find locations of `impl` blocks for traits, structs, and enums.
Usefull to find all structs implementing a specific trait or all traits implemented for a struct.
Select a type when running the command.


### Snippets

Snippets are code templates which expand into common boilerplate. Intellisense
Expand Down
15 changes: 0 additions & 15 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -80,12 +80,6 @@
}
],
"commands": [
{
"command": "rls.findImpls",
"title": "Find Implementations",
"description": "Show impl blocks for trait, struct, or enum",
"category": "Rust"
},
{
"command": "rls.update",
"title": "Update the RLS",
Expand All @@ -99,15 +93,6 @@
"category": "Rust"
}
],
"menus": {
"editor/context": [
{
"command": "rls.findImpls",
"when": "editorLangId == rust && editorHasReferenceProvider",
"group": "navigation@4"
}
]
},
"taskDefinitions": [
{
"type": "cargo",
Expand Down
38 changes: 0 additions & 38 deletions src/extension.ts
Original file line number Diff line number Diff line change
Expand Up @@ -298,44 +298,6 @@ class ClientWorkspace {
return;
}

const findImplsDisposable = commands.registerTextEditorCommand(
'rls.findImpls',
async (textEditor: TextEditor, _edit: TextEditorEdit) => {
if (!this.lc) {
return;
}
await this.lc.onReady();
// Prior to https://github.com/rust-lang-nursery/rls/pull/936 we used a custom
// LSP message - if the implementation provider is specified this means we can use the 3.6 one.
const useLSPRequest =
this.lc.initializeResult &&
this.lc.initializeResult.capabilities.implementationProvider === true;
const request = useLSPRequest
? ImplementationRequest.type.method
: 'rustDocument/implementations';

const params = this.lc.code2ProtocolConverter.asTextDocumentPositionParams(
textEditor.document,
textEditor.selection.active,
);
let locations: Location[];
try {
locations = await this.lc.sendRequest<Location[]>(request, params);
} catch (reason) {
window.showWarningMessage(`find implementations failed: ${reason}`);
return;
}

return commands.executeCommand(
'editor.action.showReferences',
textEditor.document.uri,
textEditor.selection.active,
locations.map(this.lc.protocol2CodeConverter.asLocation),
);
},
);
this.disposables.push(findImplsDisposable);

const rustupUpdateDisposable = commands.registerCommand(
'rls.update',
() => {
Expand Down

0 comments on commit 7919de1

Please sign in to comment.