Add progress reporting

This commit is contained in:
vsrs 2021-02-27 21:07:23 +03:00
parent 669e117644
commit 45d4e6b639
2 changed files with 25 additions and 17 deletions

View file

@ -1164,6 +1164,13 @@
"command": "rust-analyzer.openCargoToml", "command": "rust-analyzer.openCargoToml",
"when": "inRustProject" "when": "inRustProject"
} }
],
"editor/context": [
{
"command": "rust-analyzer.peekTests",
"when": "inRustProject",
"group": "navigation@1000"
}
] ]
} }
} }

View file

@ -566,6 +566,11 @@ export function peekTests(ctx: Ctx): Cmd {
const editor = ctx.activeRustEditor; const editor = ctx.activeRustEditor;
if (!editor || !client) return; if (!editor || !client) return;
await vscode.window.withProgress({
location: vscode.ProgressLocation.Notification,
title: "Looking for tests...",
cancellable: false,
}, async (_progress, _token) => {
const uri = editor.document.uri.toString(); const uri = editor.document.uri.toString();
const position = client.code2ProtocolConverter.asPosition( const position = client.code2ProtocolConverter.asPosition(
editor.selection.active, editor.selection.active,
@ -575,15 +580,11 @@ export function peekTests(ctx: Ctx): Cmd {
textDocument: { uri: uri }, textDocument: { uri: uri },
position: position, position: position,
}); });
const locations: lc.Location[] = tests.map(it =>
const locations: lc.Location[] = tests.map( it => { lc.Location.create(it.runnable.location!.targetUri, it.runnable.location!.targetSelectionRange));
return {
uri: it.runnable.location!.targetUri,
range: it.runnable.location!.targetSelectionRange
};
});
await showReferencesImpl(client, uri, position, locations); await showReferencesImpl(client, uri, position, locations);
});
}; };
} }