Display vscode message after changing cargo-watch options

This commit is contained in:
memoryruins 2020-01-14 20:52:48 -05:00
parent 754d9d1a0c
commit edb820c329

View file

@ -42,6 +42,7 @@ export class Config {
private prevEnhancedTyping: null | boolean = null; private prevEnhancedTyping: null | boolean = null;
private prevCargoFeatures: null | CargoFeatures = null; private prevCargoFeatures: null | CargoFeatures = null;
private prevCargoWatchOptions: null | CargoWatchOptions = null;
constructor(ctx: vscode.ExtensionContext) { constructor(ctx: vscode.ExtensionContext) {
vscode.workspace.onDidChangeConfiguration(_ => this.refresh(), ctx.subscriptions); vscode.workspace.onDidChangeConfiguration(_ => this.refresh(), ctx.subscriptions);
@ -174,6 +175,24 @@ export class Config {
} }
this.prevCargoFeatures = { ...this.cargoFeatures }; this.prevCargoFeatures = { ...this.cargoFeatures };
if (
this.prevCargoWatchOptions !== null &&
(this.cargoWatchOptions.enable !==
this.prevCargoWatchOptions.enable ||
this.cargoWatchOptions.command !==
this.prevCargoWatchOptions.command ||
this.cargoWatchOptions.allTargets !==
this.prevCargoWatchOptions.allTargets ||
this.cargoWatchOptions.arguments.length !==
this.prevCargoWatchOptions.arguments.length ||
this.cargoWatchOptions.arguments.some(
(v, i) => v !== this.prevCargoWatchOptions!.arguments[i],
))
) {
requireReloadMessage = 'Changing cargo-watch options requires a reload';
}
this.prevCargoWatchOptions = { ...this.cargoWatchOptions };
if (requireReloadMessage !== null) { if (requireReloadMessage !== null) {
const reloadAction = 'Reload now'; const reloadAction = 'Reload now';
vscode.window vscode.window