diff options
Diffstat (limited to 'editors')
-rw-r--r-- | editors/code/package.json | 5 | ||||
-rw-r--r-- | editors/code/src/commands/index.ts | 1 | ||||
-rw-r--r-- | editors/code/src/commands/server_version.ts | 21 | ||||
-rw-r--r-- | editors/code/src/main.ts | 1 |
4 files changed, 28 insertions, 0 deletions
diff --git a/editors/code/package.json b/editors/code/package.json index c498c14b4..72befe2b6 100644 --- a/editors/code/package.json +++ b/editors/code/package.json | |||
@@ -131,6 +131,11 @@ | |||
131 | "command": "rust-analyzer.ssr", | 131 | "command": "rust-analyzer.ssr", |
132 | "title": "Structural Search Replace", | 132 | "title": "Structural Search Replace", |
133 | "category": "Rust Analyzer" | 133 | "category": "Rust Analyzer" |
134 | }, | ||
135 | { | ||
136 | "command": "rust-analyzer.serverVersion", | ||
137 | "title": "Show RA Version", | ||
138 | "category": "Rust Analyzer" | ||
134 | } | 139 | } |
135 | ], | 140 | ], |
136 | "keybindings": [ | 141 | "keybindings": [ |
diff --git a/editors/code/src/commands/index.ts b/editors/code/src/commands/index.ts index bebd99ca9..839245f48 100644 --- a/editors/code/src/commands/index.ts +++ b/editors/code/src/commands/index.ts | |||
@@ -13,6 +13,7 @@ export * from './syntax_tree'; | |||
13 | export * from './expand_macro'; | 13 | export * from './expand_macro'; |
14 | export * from './runnables'; | 14 | export * from './runnables'; |
15 | export * from './ssr'; | 15 | export * from './ssr'; |
16 | export * from './server_version'; | ||
16 | 17 | ||
17 | export function collectGarbage(ctx: Ctx): Cmd { | 18 | export function collectGarbage(ctx: Ctx): Cmd { |
18 | return async () => { | 19 | return async () => { |
diff --git a/editors/code/src/commands/server_version.ts b/editors/code/src/commands/server_version.ts new file mode 100644 index 000000000..421301b42 --- /dev/null +++ b/editors/code/src/commands/server_version.ts | |||
@@ -0,0 +1,21 @@ | |||
1 | import * as vscode from 'vscode'; | ||
2 | import { ensureServerBinary } from '../installation/server'; | ||
3 | import { Ctx, Cmd } from '../ctx'; | ||
4 | import { spawnSync } from 'child_process'; | ||
5 | |||
6 | export function serverVersion(ctx: Ctx): Cmd { | ||
7 | return async () => { | ||
8 | const binaryPath = await ensureServerBinary(ctx.config.serverSource); | ||
9 | |||
10 | if (binaryPath == null) { | ||
11 | throw new Error( | ||
12 | "Rust Analyzer Language Server is not available. " + | ||
13 | "Please, ensure its [proper installation](https://rust-analyzer.github.io/manual.html#installation)." | ||
14 | ); | ||
15 | } | ||
16 | |||
17 | const version = spawnSync(binaryPath, ["--version"], { encoding: "utf8" }).stdout; | ||
18 | vscode.window.showInformationMessage('rust-analyzer version : ' + version); | ||
19 | }; | ||
20 | } | ||
21 | |||
diff --git a/editors/code/src/main.ts b/editors/code/src/main.ts index a22e0bc66..de19a44e5 100644 --- a/editors/code/src/main.ts +++ b/editors/code/src/main.ts | |||
@@ -55,6 +55,7 @@ export async function activate(context: vscode.ExtensionContext) { | |||
55 | ctx.registerCommand('run', commands.run); | 55 | ctx.registerCommand('run', commands.run); |
56 | ctx.registerCommand('onEnter', commands.onEnter); | 56 | ctx.registerCommand('onEnter', commands.onEnter); |
57 | ctx.registerCommand('ssr', commands.ssr); | 57 | ctx.registerCommand('ssr', commands.ssr); |
58 | ctx.registerCommand('serverVersion', commands.serverVersion); | ||
58 | 59 | ||
59 | // Internal commands which are invoked by the server. | 60 | // Internal commands which are invoked by the server. |
60 | ctx.registerCommand('runSingle', commands.runSingle); | 61 | ctx.registerCommand('runSingle', commands.runSingle); |