Fixes to progress display

This commit is contained in:
Aleksey Kladov 2019-12-31 21:13:30 +01:00
parent e4d217074d
commit ef24721640
2 changed files with 12 additions and 17 deletions

View file

@ -11,17 +11,6 @@ let ctx!: Ctx;
export async function activate(context: vscode.ExtensionContext) { export async function activate(context: vscode.ExtensionContext) {
ctx = new Ctx(context); ctx = new Ctx(context);
// Note: we try to start the server before we register various commands, so
// that it registers its `onDidChangeDocument` handler before us.
//
// This a horribly, horribly wrong way to deal with this problem.
try {
await ctx.restartServer();
} catch (e) {
vscode.window.showErrorMessage(e.message);
}
// Commands which invokes manually via command pallet, shortcut, etc. // Commands which invokes manually via command pallet, shortcut, etc.
ctx.registerCommand('analyzerStatus', commands.analyzerStatus); ctx.registerCommand('analyzerStatus', commands.analyzerStatus);
ctx.registerCommand('collectGarbage', commands.collectGarbage); ctx.registerCommand('collectGarbage', commands.collectGarbage);
@ -42,7 +31,17 @@ export async function activate(context: vscode.ExtensionContext) {
ctx.overrideCommand('type', commands.onEnter); ctx.overrideCommand('type', commands.onEnter);
} }
activateStatusDisplay(ctx); activateStatusDisplay(ctx);
activateHighlighting(ctx); activateHighlighting(ctx);
// Note: we try to start the server before we activate type hints so that it
// registers its `onDidChangeDocument` handler before us.
//
// This a horribly, horribly wrong way to deal with this problem.
try {
await ctx.restartServer();
} catch (e) {
vscode.window.showErrorMessage(e.message);
}
activateInlayHints(ctx); activateInlayHints(ctx);
} }

View file

@ -36,13 +36,9 @@ class StatusDisplay implements vscode.Disposable {
this.timer || this.timer ||
setInterval(() => { setInterval(() => {
if (this.packageName) { if (this.packageName) {
this.statusBarItem!.text = `cargo ${this.command} [${ this.statusBarItem!.text = `${this.frame()} cargo ${this.command} [${this.packageName}]`;
this.packageName
}] ${this.frame()}`;
} else { } else {
this.statusBarItem!.text = `cargo ${ this.statusBarItem!.text = `${this.frame()} cargo ${this.command}`;
this.command
} ${this.frame()}`;
} }
}, 300); }, 300);