mirror of
https://github.com/rust-lang/rust-analyzer.git
synced 2025-08-31 07:37:30 +00:00
Introduce cargo-watch.check-command
This commit is contained in:
parent
7d79be3280
commit
4722e6d491
4 changed files with 27 additions and 7 deletions
|
@ -43,7 +43,7 @@ export class CargoWatchProvider implements vscode.Disposable {
|
|||
this.diagnosticCollection = vscode.languages.createDiagnosticCollection(
|
||||
'rustc'
|
||||
);
|
||||
this.statusDisplay = new StatusDisplay();
|
||||
this.statusDisplay = new StatusDisplay(Server.config.cargoWatchOptions.checkCommand);
|
||||
this.outputChannel = vscode.window.createOutputChannel(
|
||||
'Cargo Watch Trace'
|
||||
);
|
||||
|
@ -57,7 +57,9 @@ export class CargoWatchProvider implements vscode.Disposable {
|
|||
return;
|
||||
}
|
||||
|
||||
let args = 'check --all-targets --message-format json';
|
||||
let command = Server.config.cargoWatchOptions.checkCommand;
|
||||
|
||||
let args = command + ' --all-targets --message-format json';
|
||||
if (Server.config.cargoWatchOptions.checkArguments.length > 0) {
|
||||
// Excape the double quote string:
|
||||
args += ' ' + Server.config.cargoWatchOptions.checkArguments;
|
||||
|
|
|
@ -7,13 +7,15 @@ export class StatusDisplay implements vscode.Disposable {
|
|||
|
||||
private i = 0;
|
||||
private statusBarItem: vscode.StatusBarItem;
|
||||
private command: string;
|
||||
private timer?: NodeJS.Timeout;
|
||||
|
||||
constructor() {
|
||||
constructor(command: string) {
|
||||
this.statusBarItem = vscode.window.createStatusBarItem(
|
||||
vscode.StatusBarAlignment.Left,
|
||||
10
|
||||
);
|
||||
this.command = command;
|
||||
this.statusBarItem.hide();
|
||||
}
|
||||
|
||||
|
@ -24,11 +26,11 @@ export class StatusDisplay implements vscode.Disposable {
|
|||
this.timer ||
|
||||
setInterval(() => {
|
||||
if (this.packageName) {
|
||||
this.statusBarItem!.text = `cargo check [${
|
||||
this.statusBarItem!.text = `cargo ${this.command} [${
|
||||
this.packageName
|
||||
}] ${this.frame()}`;
|
||||
} else {
|
||||
this.statusBarItem!.text = `cargo check ${this.frame()}`;
|
||||
this.statusBarItem!.text = `cargo ${this.command} ${this.frame()}`;
|
||||
}
|
||||
}, 300);
|
||||
|
||||
|
|
|
@ -1,6 +1,7 @@
|
|||
import * as vscode from 'vscode';
|
||||
|
||||
import { Server } from './server';
|
||||
import { strict } from 'assert';
|
||||
|
||||
const RA_LSP_DEBUG = process.env.__RA_LSP_SERVER_DEBUG;
|
||||
|
||||
|
@ -10,6 +11,7 @@ export type CargoWatchTraceOptions = 'off' | 'error' | 'verbose';
|
|||
export interface CargoWatchOptions {
|
||||
enableOnStartup: CargoWatchStartupOptions;
|
||||
checkArguments: string;
|
||||
checkCommand: string;
|
||||
trace: CargoWatchTraceOptions;
|
||||
}
|
||||
|
||||
|
@ -23,7 +25,8 @@ export class Config {
|
|||
public cargoWatchOptions: CargoWatchOptions = {
|
||||
enableOnStartup: 'ask',
|
||||
trace: 'off',
|
||||
checkArguments: ''
|
||||
checkArguments: '',
|
||||
checkCommand: ''
|
||||
};
|
||||
|
||||
private prevEnhancedTyping: null | boolean = null;
|
||||
|
@ -110,6 +113,14 @@ export class Config {
|
|||
''
|
||||
);
|
||||
}
|
||||
|
||||
if (config.has('cargo-watch.check-command')) {
|
||||
this.cargoWatchOptions.checkCommand = config.get<string>(
|
||||
'cargo-watch.check-command',
|
||||
''
|
||||
);
|
||||
}
|
||||
|
||||
if (config.has('lruCapacity')) {
|
||||
this.lruCapacity = config.get('lruCapacity') as number;
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue