change config rust-analyzer.statusBar.documentSelector to showStatusBar

This commit is contained in:
Mark Murphy 2024-12-19 16:41:35 -05:00
parent fe027d79d2
commit ed0df3094b
3 changed files with 64 additions and 37 deletions

View file

@ -426,40 +426,55 @@
"default": "openLogs", "default": "openLogs",
"markdownDescription": "Action to run when clicking the extension status bar item." "markdownDescription": "Action to run when clicking the extension status bar item."
}, },
"rust-analyzer.statusBar.documentSelector": { "rust-analyzer.statusBar.showStatusBar": {
"type": [ "markdownDescription": "When to show the extension status bar.\n\n`\"always\"` Always show the status bar.\n\n`\"never\"` Never show the status bar.\n\n`{ documentSelector: <DocumentSelector>[] }` Show the status bar if the open file matches any of the given document selectors.\n\nSee [VS Code -- DocumentSelector](https://code.visualstudio.com/api/references/document-selector) for more information.",
"array", "anyOf": [
"null" {
], "type": "string",
"items": { "enum": [
"type": "object", "always",
"properties": { "never"
"language": { ]
"type": [ },
"string", {
"null" "type": "object",
] "properties": {
}, "documentSelector": {
"pattern": { "type": "array",
"type": [ "items": {
"string", "type": "object",
"null" "properties": {
] "language": {
"type": "string"
},
"notebookType": {
"type": "string"
},
"scheme": {
"type": "string"
},
"pattern": {
"type": "string"
}
}
}
}
} }
} }
},
"default": [
{
"language": "rust"
},
{
"pattern": "**/Cargo.toml"
},
{
"pattern": "**/Cargo.lock"
}
], ],
"markdownDescription": "Determines when to show the extension status bar item based on the currently open file. Use `{ \"pattern\": \"**\" }` to always show. Use `null` to never show." "default": {
"documentSelector": [
{
"language": "rust"
},
{
"pattern": "**/Cargo.toml"
},
{
"pattern": "**/Cargo.lock"
}
]
}
} }
} }
}, },

View file

@ -13,6 +13,13 @@ export type RunnableEnvCfgItem = {
}; };
export type RunnableEnvCfg = Record<string, string> | RunnableEnvCfgItem[]; export type RunnableEnvCfg = Record<string, string> | RunnableEnvCfgItem[];
type ShowStatusBar =
| "always"
| "never"
| {
documentSelector: vscode.DocumentSelector;
};
export class Config { export class Config {
readonly extensionId = "rust-lang.rust-analyzer"; readonly extensionId = "rust-lang.rust-analyzer";
configureLang: vscode.Disposable | undefined; configureLang: vscode.Disposable | undefined;
@ -348,8 +355,8 @@ export class Config {
return this.get<string>("statusBar.clickAction"); return this.get<string>("statusBar.clickAction");
} }
get statusBarDocumentSelector() { get statusBarShowStatusBar() {
return this.get<vscode.DocumentSelector>("statusBar.documentSelector"); return this.get<ShowStatusBar>("statusBar.showStatusBar");
} }
get initializeStopped() { get initializeStopped() {

View file

@ -478,14 +478,19 @@ export class Ctx implements RustAnalyzerExtensionApi {
} }
private updateStatusBarVisibility(editor: vscode.TextEditor | undefined) { private updateStatusBarVisibility(editor: vscode.TextEditor | undefined) {
const documentSelector = this.config.statusBarDocumentSelector; const showStatusBar = this.config.statusBarShowStatusBar;
if (documentSelector != null) { if (showStatusBar == null || showStatusBar === "never") {
this.statusBar.hide();
} else if (showStatusBar === "always") {
this.statusBar.show();
} else {
const documentSelector = showStatusBar.documentSelector;
if (editor != null && vscode.languages.match(documentSelector, editor.document) > 0) { if (editor != null && vscode.languages.match(documentSelector, editor.document) > 0) {
this.statusBar.show(); this.statusBar.show();
return; } else {
this.statusBar.hide();
} }
} }
this.statusBar.hide();
} }
pushExtCleanup(d: Disposable) { pushExtCleanup(d: Disposable) {