mirror of
https://github.com/helix-editor/helix.git
synced 2025-01-19 13:37:06 +04:00
Use the correct language ID for JavaScript & TypeScript (#1466)
* Use correct language ID for JavaScript/TypeScript * Add missing slash * Only calculate fallback when needed
This commit is contained in:
parent
97e6f2a38f
commit
3a34036310
@ -95,6 +95,7 @@ pub struct LanguageServerConfiguration {
|
||||
#[serde(default)]
|
||||
#[serde(skip_serializing_if = "Vec::is_empty")]
|
||||
pub args: Vec<String>,
|
||||
pub language_id: Option<String>,
|
||||
}
|
||||
|
||||
#[derive(Debug, Serialize, Deserialize)]
|
||||
|
@ -358,12 +358,8 @@ pub async fn handle_language_server_message(
|
||||
|
||||
// trigger textDocument/didOpen for docs that are already open
|
||||
for doc in docs {
|
||||
// TODO: extract and share with editor.open
|
||||
let language_id = doc
|
||||
.language()
|
||||
.and_then(|s| s.split('.').last()) // source.rust
|
||||
.map(ToOwned::to_owned)
|
||||
.unwrap_or_default();
|
||||
let language_id =
|
||||
doc.language_id().map(ToOwned::to_owned).unwrap_or_default();
|
||||
|
||||
tokio::spawn(language_server.text_document_did_open(
|
||||
doc.url().unwrap(),
|
||||
|
@ -844,6 +844,24 @@ pub fn language(&self) -> Option<&str> {
|
||||
.map(|language| language.scope.as_str())
|
||||
}
|
||||
|
||||
/// Language ID for the document. Either the `language-id` from the
|
||||
/// `language-server` configuration, or the document language if no
|
||||
/// `language-id` has been specified.
|
||||
pub fn language_id(&self) -> Option<&str> {
|
||||
self.language
|
||||
.as_ref()
|
||||
.and_then(|config| config.language_server.as_ref())
|
||||
.and_then(|lsp_config| lsp_config.language_id.as_ref())
|
||||
.map_or_else(
|
||||
|| {
|
||||
self.language()
|
||||
.and_then(|s| s.rsplit_once('.'))
|
||||
.map(|(_, language_id)| language_id)
|
||||
},
|
||||
|language_id| Some(language_id.as_str()),
|
||||
)
|
||||
}
|
||||
|
||||
/// Corresponding [`LanguageConfiguration`].
|
||||
pub fn language_config(&self) -> Option<&LanguageConfiguration> {
|
||||
self.language.as_deref()
|
||||
|
@ -307,11 +307,8 @@ fn launch_language_server(ls: &mut helix_lsp::Registry, doc: &mut Document) -> O
|
||||
if let Some(language_server) = doc.language_server() {
|
||||
tokio::spawn(language_server.text_document_did_close(doc.identifier()));
|
||||
}
|
||||
let language_id = doc
|
||||
.language()
|
||||
.and_then(|s| s.split('.').last()) // source.rust
|
||||
.map(ToOwned::to_owned)
|
||||
.unwrap_or_default();
|
||||
|
||||
let language_id = doc.language_id().map(ToOwned::to_owned).unwrap_or_default();
|
||||
|
||||
// TODO: this now races with on_init code if the init happens too quickly
|
||||
tokio::spawn(language_server.text_document_did_open(
|
||||
|
@ -128,7 +128,7 @@ roots = []
|
||||
comment-token = "//"
|
||||
# TODO: highlights-jsx, highlights-params
|
||||
|
||||
language-server = { command = "typescript-language-server", args = ["--stdio"] }
|
||||
language-server = { command = "typescript-language-server", args = ["--stdio"], language-id = "javascript" }
|
||||
indent = { tab-width = 2, unit = " " }
|
||||
|
||||
[[language]]
|
||||
@ -140,7 +140,7 @@ shebangs = []
|
||||
roots = []
|
||||
# TODO: highlights-jsx, highlights-params
|
||||
|
||||
language-server = { command = "typescript-language-server", args = ["--stdio"] }
|
||||
language-server = { command = "typescript-language-server", args = ["--stdio"], language-id = "typescript"}
|
||||
indent = { tab-width = 2, unit = " " }
|
||||
|
||||
[[language]]
|
||||
@ -151,7 +151,7 @@ file-types = ["tsx"]
|
||||
roots = []
|
||||
# TODO: highlights-jsx, highlights-params
|
||||
|
||||
language-server = { command = "typescript-language-server", args = ["--stdio"] }
|
||||
language-server = { command = "typescript-language-server", args = ["--stdio"], language-id = "typescriptreact" }
|
||||
indent = { tab-width = 2, unit = " " }
|
||||
|
||||
[[language]]
|
||||
|
Loading…
Reference in New Issue
Block a user