mirror of
https://github.com/denoland/deno.git
synced 2025-01-12 00:54:02 -05:00
chore: upgrade lspower to 1.4.0 (#12894)
This commit is contained in:
parent
c6f3493f18
commit
e68a241946
10 changed files with 109 additions and 106 deletions
20
Cargo.lock
generated
20
Cargo.lock
generated
|
@ -198,9 +198,9 @@ dependencies = [
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "auto_impl"
|
name = "auto_impl"
|
||||||
version = "0.4.1"
|
version = "0.5.0"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "42cbf586c80ada5e5ccdecae80d3ef0854f224e2dd74435f8d87e6831b8d0a38"
|
checksum = "7862e21c893d65a1650125d157eaeec691439379a1cee17ee49031b79236ada4"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"proc-macro-error",
|
"proc-macro-error",
|
||||||
"proc-macro2 1.0.29",
|
"proc-macro2 1.0.29",
|
||||||
|
@ -2109,9 +2109,9 @@ dependencies = [
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "lsp-types"
|
name = "lsp-types"
|
||||||
version = "0.89.2"
|
version = "0.91.1"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "852e0dedfd52cc32325598b2631e0eba31b7b708959676a9f837042f276b09a2"
|
checksum = "2368312c59425dd133cb9a327afee65be0a633a8ce471d248e2202a48f8f68ae"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"bitflags",
|
"bitflags",
|
||||||
"serde",
|
"serde",
|
||||||
|
@ -2122,9 +2122,9 @@ dependencies = [
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "lspower"
|
name = "lspower"
|
||||||
version = "1.1.0"
|
version = "1.4.0"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "3167a7555dbacd9ddf3c42eefcc2d4d5e46bb79cd1702bb25d4152bdf537d4b4"
|
checksum = "c713fbfa0f03f0b8286a1e250281350aa07dee40e6ef5c0a4d5a2801146d7a54"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"anyhow",
|
"anyhow",
|
||||||
"async-trait",
|
"async-trait",
|
||||||
|
@ -4113,9 +4113,9 @@ checksum = "cda74da7e1a664f795bb1f8a87ec406fb89a02522cf6e50620d016add6dbbf5c"
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "tokio"
|
name = "tokio"
|
||||||
version = "1.12.0"
|
version = "1.14.0"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "c2c2416fdedca8443ae44b4527de1ea633af61d8f7169ffa6e72c5b53d24efcc"
|
checksum = "70e992e41e0d2fb9f755b37446f20900f64446ef54874f40a60c78f021ac6144"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"autocfg 1.0.1",
|
"autocfg 1.0.1",
|
||||||
"bytes",
|
"bytes",
|
||||||
|
@ -4133,9 +4133,9 @@ dependencies = [
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "tokio-macros"
|
name = "tokio-macros"
|
||||||
version = "1.4.1"
|
version = "1.6.0"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "154794c8f499c2619acd19e839294703e9e32e7630ef5f46ea80d4ef0fbee5eb"
|
checksum = "c9efc1aba077437943f7515666aa2b882dfabfbfdf89c819ea75a8d6e9eaba5e"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"proc-macro2 1.0.29",
|
"proc-macro2 1.0.29",
|
||||||
"quote 1.0.10",
|
"quote 1.0.10",
|
||||||
|
|
|
@ -64,7 +64,7 @@ jsonc-parser = { version = "0.17.0", features = ["serde"] }
|
||||||
lazy_static = "1.4.0"
|
lazy_static = "1.4.0"
|
||||||
libc = "0.2.106"
|
libc = "0.2.106"
|
||||||
log = { version = "0.4.14", features = ["serde"] }
|
log = { version = "0.4.14", features = ["serde"] }
|
||||||
lspower = "1.1.0"
|
lspower = "1.4.0"
|
||||||
notify = "5.0.0-pre.12"
|
notify = "5.0.0-pre.12"
|
||||||
num_cpus = "1.13.0"
|
num_cpus = "1.13.0"
|
||||||
once_cell = "1.8.0"
|
once_cell = "1.8.0"
|
||||||
|
|
|
@ -95,7 +95,7 @@ impl Reference {
|
||||||
hint,
|
hint,
|
||||||
} => lsp::Diagnostic {
|
} => lsp::Diagnostic {
|
||||||
range: self.range,
|
range: self.range,
|
||||||
severity: Some(lsp::DiagnosticSeverity::Warning),
|
severity: Some(lsp::DiagnosticSeverity::WARNING),
|
||||||
code: Some(lsp::NumberOrString::String(code.to_string())),
|
code: Some(lsp::NumberOrString::String(code.to_string())),
|
||||||
code_description: None,
|
code_description: None,
|
||||||
source: Some("deno-lint".to_string()),
|
source: Some("deno-lint".to_string()),
|
||||||
|
@ -785,7 +785,7 @@ mod tests {
|
||||||
},
|
},
|
||||||
lsp::Diagnostic {
|
lsp::Diagnostic {
|
||||||
range,
|
range,
|
||||||
severity: Some(lsp::DiagnosticSeverity::Warning),
|
severity: Some(lsp::DiagnosticSeverity::WARNING),
|
||||||
code: Some(lsp::NumberOrString::String("code1".to_string())),
|
code: Some(lsp::NumberOrString::String("code1".to_string())),
|
||||||
source: Some("deno-lint".to_string()),
|
source: Some("deno-lint".to_string()),
|
||||||
message: "message1".to_string(),
|
message: "message1".to_string(),
|
||||||
|
@ -803,7 +803,7 @@ mod tests {
|
||||||
},
|
},
|
||||||
lsp::Diagnostic {
|
lsp::Diagnostic {
|
||||||
range,
|
range,
|
||||||
severity: Some(lsp::DiagnosticSeverity::Warning),
|
severity: Some(lsp::DiagnosticSeverity::WARNING),
|
||||||
code: Some(lsp::NumberOrString::String("code2".to_string())),
|
code: Some(lsp::NumberOrString::String("code2".to_string())),
|
||||||
source: Some("deno-lint".to_string()),
|
source: Some("deno-lint".to_string()),
|
||||||
message: "message2\nhint2".to_string(),
|
message: "message2\nhint2".to_string(),
|
||||||
|
|
|
@ -68,7 +68,7 @@ pub fn server_capabilities(
|
||||||
text_document_sync: Some(TextDocumentSyncCapability::Options(
|
text_document_sync: Some(TextDocumentSyncCapability::Options(
|
||||||
TextDocumentSyncOptions {
|
TextDocumentSyncOptions {
|
||||||
open_close: Some(true),
|
open_close: Some(true),
|
||||||
change: Some(TextDocumentSyncKind::Incremental),
|
change: Some(TextDocumentSyncKind::INCREMENTAL),
|
||||||
will_save: None,
|
will_save: None,
|
||||||
will_save_wait_until: None,
|
will_save_wait_until: None,
|
||||||
save: Some(SaveOptions::default().into()),
|
save: Some(SaveOptions::default().into()),
|
||||||
|
|
|
@ -150,7 +150,7 @@ pub(crate) async fn get_import_completions(
|
||||||
.iter()
|
.iter()
|
||||||
.map(|s| lsp::CompletionItem {
|
.map(|s| lsp::CompletionItem {
|
||||||
label: s.to_string(),
|
label: s.to_string(),
|
||||||
kind: Some(lsp::CompletionItemKind::Folder),
|
kind: Some(lsp::CompletionItemKind::FOLDER),
|
||||||
detail: Some("(local)".to_string()),
|
detail: Some("(local)".to_string()),
|
||||||
sort_text: Some("1".to_string()),
|
sort_text: Some("1".to_string()),
|
||||||
insert_text: Some(s.to_string()),
|
insert_text: Some(s.to_string()),
|
||||||
|
@ -223,7 +223,7 @@ fn get_local_completions(
|
||||||
match de.file_type() {
|
match de.file_type() {
|
||||||
Ok(file_type) if file_type.is_dir() => Some(lsp::CompletionItem {
|
Ok(file_type) if file_type.is_dir() => Some(lsp::CompletionItem {
|
||||||
label,
|
label,
|
||||||
kind: Some(lsp::CompletionItemKind::Folder),
|
kind: Some(lsp::CompletionItemKind::FOLDER),
|
||||||
filter_text,
|
filter_text,
|
||||||
sort_text: Some("1".to_string()),
|
sort_text: Some("1".to_string()),
|
||||||
text_edit,
|
text_edit,
|
||||||
|
@ -233,7 +233,7 @@ fn get_local_completions(
|
||||||
if is_supported_ext(&de.path()) {
|
if is_supported_ext(&de.path()) {
|
||||||
Some(lsp::CompletionItem {
|
Some(lsp::CompletionItem {
|
||||||
label,
|
label,
|
||||||
kind: Some(lsp::CompletionItemKind::File),
|
kind: Some(lsp::CompletionItemKind::FILE),
|
||||||
detail: Some("(local)".to_string()),
|
detail: Some("(local)".to_string()),
|
||||||
filter_text,
|
filter_text,
|
||||||
sort_text: Some("1".to_string()),
|
sort_text: Some("1".to_string()),
|
||||||
|
@ -305,7 +305,7 @@ fn get_workspace_completions(
|
||||||
}));
|
}));
|
||||||
Some(lsp::CompletionItem {
|
Some(lsp::CompletionItem {
|
||||||
label,
|
label,
|
||||||
kind: Some(lsp::CompletionItemKind::File),
|
kind: Some(lsp::CompletionItemKind::FILE),
|
||||||
detail,
|
detail,
|
||||||
sort_text: Some("1".to_string()),
|
sort_text: Some("1".to_string()),
|
||||||
text_edit,
|
text_edit,
|
||||||
|
@ -652,7 +652,7 @@ mod tests {
|
||||||
actual,
|
actual,
|
||||||
vec![lsp::CompletionItem {
|
vec![lsp::CompletionItem {
|
||||||
label: "https://deno.land/x/a/b/c.ts".to_string(),
|
label: "https://deno.land/x/a/b/c.ts".to_string(),
|
||||||
kind: Some(lsp::CompletionItemKind::File),
|
kind: Some(lsp::CompletionItemKind::FILE),
|
||||||
detail: Some("(remote)".to_string()),
|
detail: Some("(remote)".to_string()),
|
||||||
sort_text: Some("1".to_string()),
|
sort_text: Some("1".to_string()),
|
||||||
text_edit: Some(lsp::CompletionTextEdit::Edit(lsp::TextEdit {
|
text_edit: Some(lsp::CompletionTextEdit::Edit(lsp::TextEdit {
|
||||||
|
|
|
@ -197,15 +197,15 @@ impl DiagnosticsServer {
|
||||||
impl<'a> From<&'a diagnostics::DiagnosticCategory> for lsp::DiagnosticSeverity {
|
impl<'a> From<&'a diagnostics::DiagnosticCategory> for lsp::DiagnosticSeverity {
|
||||||
fn from(category: &'a diagnostics::DiagnosticCategory) -> Self {
|
fn from(category: &'a diagnostics::DiagnosticCategory) -> Self {
|
||||||
match category {
|
match category {
|
||||||
diagnostics::DiagnosticCategory::Error => lsp::DiagnosticSeverity::Error,
|
diagnostics::DiagnosticCategory::Error => lsp::DiagnosticSeverity::ERROR,
|
||||||
diagnostics::DiagnosticCategory::Warning => {
|
diagnostics::DiagnosticCategory::Warning => {
|
||||||
lsp::DiagnosticSeverity::Warning
|
lsp::DiagnosticSeverity::WARNING
|
||||||
}
|
}
|
||||||
diagnostics::DiagnosticCategory::Suggestion => {
|
diagnostics::DiagnosticCategory::Suggestion => {
|
||||||
lsp::DiagnosticSeverity::Hint
|
lsp::DiagnosticSeverity::HINT
|
||||||
}
|
}
|
||||||
diagnostics::DiagnosticCategory::Message => {
|
diagnostics::DiagnosticCategory::Message => {
|
||||||
lsp::DiagnosticSeverity::Information
|
lsp::DiagnosticSeverity::INFORMATION
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -286,9 +286,9 @@ fn ts_json_to_diagnostics(
|
||||||
tags: match d.code {
|
tags: match d.code {
|
||||||
// These are codes that indicate the variable is unused.
|
// These are codes that indicate the variable is unused.
|
||||||
2695 | 6133 | 6138 | 6192 | 6196 | 6198 | 6199 | 6205 | 7027
|
2695 | 6133 | 6138 | 6192 | 6196 | 6198 | 6199 | 6205 | 7027
|
||||||
| 7028 => Some(vec![lsp::DiagnosticTag::Unnecessary]),
|
| 7028 => Some(vec![lsp::DiagnosticTag::UNNECESSARY]),
|
||||||
// These are codes that indicated the variable is deprecated.
|
// These are codes that indicated the variable is deprecated.
|
||||||
2789 | 6385 | 6387 => Some(vec![lsp::DiagnosticTag::Deprecated]),
|
2789 | 6385 | 6387 => Some(vec![lsp::DiagnosticTag::DEPRECATED]),
|
||||||
_ => None,
|
_ => None,
|
||||||
},
|
},
|
||||||
data: None,
|
data: None,
|
||||||
|
@ -445,7 +445,7 @@ fn diagnose_dependency(
|
||||||
if let Some(message) = doc.maybe_warning() {
|
if let Some(message) = doc.maybe_warning() {
|
||||||
diagnostics.push(lsp::Diagnostic {
|
diagnostics.push(lsp::Diagnostic {
|
||||||
range: documents::to_lsp_range(range),
|
range: documents::to_lsp_range(range),
|
||||||
severity: Some(lsp::DiagnosticSeverity::Warning),
|
severity: Some(lsp::DiagnosticSeverity::WARNING),
|
||||||
code: Some(lsp::NumberOrString::String("deno-warn".to_string())),
|
code: Some(lsp::NumberOrString::String("deno-warn".to_string())),
|
||||||
source: Some("deno".to_string()),
|
source: Some("deno".to_string()),
|
||||||
message,
|
message,
|
||||||
|
@ -461,7 +461,7 @@ fn diagnose_dependency(
|
||||||
};
|
};
|
||||||
diagnostics.push(lsp::Diagnostic {
|
diagnostics.push(lsp::Diagnostic {
|
||||||
range: documents::to_lsp_range(range),
|
range: documents::to_lsp_range(range),
|
||||||
severity: Some(lsp::DiagnosticSeverity::Error),
|
severity: Some(lsp::DiagnosticSeverity::ERROR),
|
||||||
code,
|
code,
|
||||||
source: Some("deno".to_string()),
|
source: Some("deno".to_string()),
|
||||||
message,
|
message,
|
||||||
|
@ -472,7 +472,7 @@ fn diagnose_dependency(
|
||||||
}
|
}
|
||||||
Some(Err(err)) => diagnostics.push(lsp::Diagnostic {
|
Some(Err(err)) => diagnostics.push(lsp::Diagnostic {
|
||||||
range: documents::to_lsp_range(err.range()),
|
range: documents::to_lsp_range(err.range()),
|
||||||
severity: Some(lsp::DiagnosticSeverity::Error),
|
severity: Some(lsp::DiagnosticSeverity::ERROR),
|
||||||
code: Some(resolution_error_as_code(err)),
|
code: Some(resolution_error_as_code(err)),
|
||||||
source: Some("deno".to_string()),
|
source: Some("deno".to_string()),
|
||||||
message: err.to_string(),
|
message: err.to_string(),
|
||||||
|
|
|
@ -579,7 +579,7 @@ impl Inner {
|
||||||
tsconfig.merge(&unstable_libs);
|
tsconfig.merge(&unstable_libs);
|
||||||
}
|
}
|
||||||
if let Err(err) = self.merge_user_tsconfig(&mut tsconfig) {
|
if let Err(err) = self.merge_user_tsconfig(&mut tsconfig) {
|
||||||
self.client.show_message(MessageType::Warning, err).await;
|
self.client.show_message(MessageType::WARNING, err).await;
|
||||||
}
|
}
|
||||||
let _ok: bool = self
|
let _ok: bool = self
|
||||||
.ts_server
|
.ts_server
|
||||||
|
@ -669,13 +669,13 @@ impl Inner {
|
||||||
self.update_debug_flag();
|
self.update_debug_flag();
|
||||||
// Check to see if we need to change the cache path
|
// Check to see if we need to change the cache path
|
||||||
if let Err(err) = self.update_cache() {
|
if let Err(err) = self.update_cache() {
|
||||||
self.client.show_message(MessageType::Warning, err).await;
|
self.client.show_message(MessageType::WARNING, err).await;
|
||||||
}
|
}
|
||||||
if let Err(err) = self.update_config_file() {
|
if let Err(err) = self.update_config_file() {
|
||||||
self.client.show_message(MessageType::Warning, err).await;
|
self.client.show_message(MessageType::WARNING, err).await;
|
||||||
}
|
}
|
||||||
if let Err(err) = self.update_tsconfig().await {
|
if let Err(err) = self.update_tsconfig().await {
|
||||||
self.client.show_message(MessageType::Warning, err).await;
|
self.client.show_message(MessageType::WARNING, err).await;
|
||||||
}
|
}
|
||||||
|
|
||||||
if capabilities.code_action_provider.is_some() {
|
if capabilities.code_action_provider.is_some() {
|
||||||
|
@ -692,11 +692,11 @@ impl Inner {
|
||||||
|
|
||||||
// Check to see if we need to setup the import map
|
// Check to see if we need to setup the import map
|
||||||
if let Err(err) = self.update_import_map().await {
|
if let Err(err) = self.update_import_map().await {
|
||||||
self.client.show_message(MessageType::Warning, err).await;
|
self.client.show_message(MessageType::WARNING, err).await;
|
||||||
}
|
}
|
||||||
// Check to see if we need to setup any module registries
|
// Check to see if we need to setup any module registries
|
||||||
if let Err(err) = self.update_registries().await {
|
if let Err(err) = self.update_registries().await {
|
||||||
self.client.show_message(MessageType::Warning, err).await;
|
self.client.show_message(MessageType::WARNING, err).await;
|
||||||
}
|
}
|
||||||
self.documents.update_config(
|
self.documents.update_config(
|
||||||
self.maybe_import_map.clone(),
|
self.maybe_import_map.clone(),
|
||||||
|
@ -893,19 +893,19 @@ impl Inner {
|
||||||
|
|
||||||
self.update_debug_flag();
|
self.update_debug_flag();
|
||||||
if let Err(err) = self.update_cache() {
|
if let Err(err) = self.update_cache() {
|
||||||
self.client.show_message(MessageType::Warning, err).await;
|
self.client.show_message(MessageType::WARNING, err).await;
|
||||||
}
|
}
|
||||||
if let Err(err) = self.update_import_map().await {
|
if let Err(err) = self.update_import_map().await {
|
||||||
self.client.show_message(MessageType::Warning, err).await;
|
self.client.show_message(MessageType::WARNING, err).await;
|
||||||
}
|
}
|
||||||
if let Err(err) = self.update_registries().await {
|
if let Err(err) = self.update_registries().await {
|
||||||
self.client.show_message(MessageType::Warning, err).await;
|
self.client.show_message(MessageType::WARNING, err).await;
|
||||||
}
|
}
|
||||||
if let Err(err) = self.update_config_file() {
|
if let Err(err) = self.update_config_file() {
|
||||||
self.client.show_message(MessageType::Warning, err).await;
|
self.client.show_message(MessageType::WARNING, err).await;
|
||||||
}
|
}
|
||||||
if let Err(err) = self.update_tsconfig().await {
|
if let Err(err) = self.update_tsconfig().await {
|
||||||
self.client.show_message(MessageType::Warning, err).await;
|
self.client.show_message(MessageType::WARNING, err).await;
|
||||||
}
|
}
|
||||||
if let Err(err) = self.diagnostics_server.update() {
|
if let Err(err) = self.diagnostics_server.update() {
|
||||||
error!("{}", err);
|
error!("{}", err);
|
||||||
|
@ -936,7 +936,7 @@ impl Inner {
|
||||||
if let Some(import_map_uri) = &self.maybe_import_map_uri {
|
if let Some(import_map_uri) = &self.maybe_import_map_uri {
|
||||||
if changes.iter().any(|uri| import_map_uri == uri) {
|
if changes.iter().any(|uri| import_map_uri == uri) {
|
||||||
if let Err(err) = self.update_import_map().await {
|
if let Err(err) = self.update_import_map().await {
|
||||||
self.client.show_message(MessageType::Warning, err).await;
|
self.client.show_message(MessageType::WARNING, err).await;
|
||||||
}
|
}
|
||||||
touched = true;
|
touched = true;
|
||||||
}
|
}
|
||||||
|
@ -945,10 +945,10 @@ impl Inner {
|
||||||
if let Some(config_uri) = &self.maybe_config_uri {
|
if let Some(config_uri) = &self.maybe_config_uri {
|
||||||
if changes.iter().any(|uri| config_uri == uri) {
|
if changes.iter().any(|uri| config_uri == uri) {
|
||||||
if let Err(err) = self.update_config_file() {
|
if let Err(err) = self.update_config_file() {
|
||||||
self.client.show_message(MessageType::Warning, err).await;
|
self.client.show_message(MessageType::WARNING, err).await;
|
||||||
}
|
}
|
||||||
if let Err(err) = self.update_tsconfig().await {
|
if let Err(err) = self.update_tsconfig().await {
|
||||||
self.client.show_message(MessageType::Warning, err).await;
|
self.client.show_message(MessageType::WARNING, err).await;
|
||||||
}
|
}
|
||||||
touched = true;
|
touched = true;
|
||||||
}
|
}
|
||||||
|
@ -1066,7 +1066,7 @@ impl Inner {
|
||||||
Ok(Some(text_edits))
|
Ok(Some(text_edits))
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
self.client.show_message(MessageType::Warning, format!("Unable to format \"{}\". Likely due to unrecoverable syntax errors in the file.", specifier)).await;
|
self.client.show_message(MessageType::WARNING, format!("Unable to format \"{}\". Likely due to unrecoverable syntax errors in the file.", specifier)).await;
|
||||||
Ok(None)
|
Ok(None)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -2613,7 +2613,7 @@ impl Inner {
|
||||||
}
|
}
|
||||||
let cache_server = self.maybe_cache_server.as_ref().unwrap();
|
let cache_server = self.maybe_cache_server.as_ref().unwrap();
|
||||||
if let Err(err) = cache_server.cache(roots).await {
|
if let Err(err) = cache_server.cache(roots).await {
|
||||||
self.client.show_message(MessageType::Warning, err).await;
|
self.client.show_message(MessageType::WARNING, err).await;
|
||||||
}
|
}
|
||||||
|
|
||||||
// now that we have dependencies loaded, we need to re-analyze them and
|
// now that we have dependencies loaded, we need to re-analyze them and
|
||||||
|
|
|
@ -348,7 +348,7 @@ impl ModuleRegistry {
|
||||||
s,
|
s,
|
||||||
lsp::CompletionItem {
|
lsp::CompletionItem {
|
||||||
label,
|
label,
|
||||||
kind: Some(lsp::CompletionItemKind::Folder),
|
kind: Some(lsp::CompletionItemKind::FOLDER),
|
||||||
filter_text,
|
filter_text,
|
||||||
sort_text: Some("1".to_string()),
|
sort_text: Some("1".to_string()),
|
||||||
text_edit,
|
text_edit,
|
||||||
|
@ -508,9 +508,9 @@ impl ModuleRegistry {
|
||||||
item.clone()
|
item.clone()
|
||||||
};
|
};
|
||||||
let kind = if key.name == last_key_name {
|
let kind = if key.name == last_key_name {
|
||||||
Some(lsp::CompletionItemKind::File)
|
Some(lsp::CompletionItemKind::FILE)
|
||||||
} else {
|
} else {
|
||||||
Some(lsp::CompletionItemKind::Folder)
|
Some(lsp::CompletionItemKind::FOLDER)
|
||||||
};
|
};
|
||||||
let mut params = match_result.params.clone();
|
let mut params = match_result.params.clone();
|
||||||
params.insert(
|
params.insert(
|
||||||
|
@ -572,7 +572,7 @@ impl ModuleRegistry {
|
||||||
Token::String(s) => {
|
Token::String(s) => {
|
||||||
if s.starts_with(path) {
|
if s.starts_with(path) {
|
||||||
let label = s.to_string();
|
let label = s.to_string();
|
||||||
let kind = Some(lsp::CompletionItemKind::Folder);
|
let kind = Some(lsp::CompletionItemKind::FOLDER);
|
||||||
let mut url = specifier.clone();
|
let mut url = specifier.clone();
|
||||||
url.set_path(s);
|
url.set_path(s);
|
||||||
let full_text = url.as_str();
|
let full_text = url.as_str();
|
||||||
|
@ -606,7 +606,7 @@ impl ModuleRegistry {
|
||||||
let base = Url::parse(&origin).ok()?;
|
let base = Url::parse(&origin).ok()?;
|
||||||
for (idx, item) in items.into_iter().enumerate() {
|
for (idx, item) in items.into_iter().enumerate() {
|
||||||
let path = format!("{}{}", prefix, item);
|
let path = format!("{}{}", prefix, item);
|
||||||
let kind = Some(lsp::CompletionItemKind::Folder);
|
let kind = Some(lsp::CompletionItemKind::FOLDER);
|
||||||
let item_specifier = base.join(&path).ok()?;
|
let item_specifier = base.join(&path).ok()?;
|
||||||
let full_text = item_specifier.as_str();
|
let full_text = item_specifier.as_str();
|
||||||
let text_edit = Some(
|
let text_edit = Some(
|
||||||
|
@ -687,7 +687,7 @@ impl ModuleRegistry {
|
||||||
}));
|
}));
|
||||||
Some(lsp::CompletionItem {
|
Some(lsp::CompletionItem {
|
||||||
label: origin,
|
label: origin,
|
||||||
kind: Some(lsp::CompletionItemKind::Folder),
|
kind: Some(lsp::CompletionItemKind::FOLDER),
|
||||||
detail: Some("(registry)".to_string()),
|
detail: Some("(registry)".to_string()),
|
||||||
sort_text: Some("2".to_string()),
|
sort_text: Some("2".to_string()),
|
||||||
text_edit,
|
text_edit,
|
||||||
|
@ -1036,10 +1036,10 @@ mod tests {
|
||||||
let completions = completions.unwrap();
|
let completions = completions.unwrap();
|
||||||
assert_eq!(completions.len(), 2);
|
assert_eq!(completions.len(), 2);
|
||||||
assert_eq!(completions[0].detail, Some("(path)".to_string()));
|
assert_eq!(completions[0].detail, Some("(path)".to_string()));
|
||||||
assert_eq!(completions[0].kind, Some(lsp::CompletionItemKind::File));
|
assert_eq!(completions[0].kind, Some(lsp::CompletionItemKind::FILE));
|
||||||
assert!(completions[0].command.is_some());
|
assert!(completions[0].command.is_some());
|
||||||
assert_eq!(completions[1].detail, Some("(path)".to_string()));
|
assert_eq!(completions[1].detail, Some("(path)".to_string()));
|
||||||
assert_eq!(completions[0].kind, Some(lsp::CompletionItemKind::File));
|
assert_eq!(completions[0].kind, Some(lsp::CompletionItemKind::FILE));
|
||||||
assert!(completions[1].command.is_some());
|
assert!(completions[1].command.is_some());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
105
cli/lsp/tsc.rs
105
cli/lsp/tsc.rs
|
@ -457,7 +457,7 @@ impl From<ScriptElementKind> for lsp::CompletionItemKind {
|
||||||
fn from(kind: ScriptElementKind) -> Self {
|
fn from(kind: ScriptElementKind) -> Self {
|
||||||
match kind {
|
match kind {
|
||||||
ScriptElementKind::PrimitiveType | ScriptElementKind::Keyword => {
|
ScriptElementKind::PrimitiveType | ScriptElementKind::Keyword => {
|
||||||
lsp::CompletionItemKind::Keyword
|
lsp::CompletionItemKind::KEYWORD
|
||||||
}
|
}
|
||||||
ScriptElementKind::ConstElement
|
ScriptElementKind::ConstElement
|
||||||
| ScriptElementKind::LetElement
|
| ScriptElementKind::LetElement
|
||||||
|
@ -465,40 +465,40 @@ impl From<ScriptElementKind> for lsp::CompletionItemKind {
|
||||||
| ScriptElementKind::LocalVariableElement
|
| ScriptElementKind::LocalVariableElement
|
||||||
| ScriptElementKind::Alias
|
| ScriptElementKind::Alias
|
||||||
| ScriptElementKind::ParameterElement => {
|
| ScriptElementKind::ParameterElement => {
|
||||||
lsp::CompletionItemKind::Variable
|
lsp::CompletionItemKind::VARIABLE
|
||||||
}
|
}
|
||||||
ScriptElementKind::MemberVariableElement
|
ScriptElementKind::MemberVariableElement
|
||||||
| ScriptElementKind::MemberGetAccessorElement
|
| ScriptElementKind::MemberGetAccessorElement
|
||||||
| ScriptElementKind::MemberSetAccessorElement => {
|
| ScriptElementKind::MemberSetAccessorElement => {
|
||||||
lsp::CompletionItemKind::Field
|
lsp::CompletionItemKind::FIELD
|
||||||
}
|
}
|
||||||
ScriptElementKind::FunctionElement
|
ScriptElementKind::FunctionElement
|
||||||
| ScriptElementKind::LocalFunctionElement => {
|
| ScriptElementKind::LocalFunctionElement => {
|
||||||
lsp::CompletionItemKind::Function
|
lsp::CompletionItemKind::FUNCTION
|
||||||
}
|
}
|
||||||
ScriptElementKind::MemberFunctionElement
|
ScriptElementKind::MemberFunctionElement
|
||||||
| ScriptElementKind::ConstructSignatureElement
|
| ScriptElementKind::ConstructSignatureElement
|
||||||
| ScriptElementKind::CallSignatureElement
|
| ScriptElementKind::CallSignatureElement
|
||||||
| ScriptElementKind::IndexSignatureElement => {
|
| ScriptElementKind::IndexSignatureElement => {
|
||||||
lsp::CompletionItemKind::Method
|
lsp::CompletionItemKind::METHOD
|
||||||
}
|
}
|
||||||
ScriptElementKind::EnumElement => lsp::CompletionItemKind::Enum,
|
ScriptElementKind::EnumElement => lsp::CompletionItemKind::ENUM,
|
||||||
ScriptElementKind::EnumMemberElement => {
|
ScriptElementKind::EnumMemberElement => {
|
||||||
lsp::CompletionItemKind::EnumMember
|
lsp::CompletionItemKind::ENUM_MEMBER
|
||||||
}
|
}
|
||||||
ScriptElementKind::ModuleElement
|
ScriptElementKind::ModuleElement
|
||||||
| ScriptElementKind::ExternalModuleName => {
|
| ScriptElementKind::ExternalModuleName => {
|
||||||
lsp::CompletionItemKind::Module
|
lsp::CompletionItemKind::MODULE
|
||||||
}
|
}
|
||||||
ScriptElementKind::ClassElement | ScriptElementKind::TypeElement => {
|
ScriptElementKind::ClassElement | ScriptElementKind::TypeElement => {
|
||||||
lsp::CompletionItemKind::Class
|
lsp::CompletionItemKind::CLASS
|
||||||
}
|
}
|
||||||
ScriptElementKind::InterfaceElement => lsp::CompletionItemKind::Interface,
|
ScriptElementKind::InterfaceElement => lsp::CompletionItemKind::INTERFACE,
|
||||||
ScriptElementKind::Warning => lsp::CompletionItemKind::Text,
|
ScriptElementKind::Warning => lsp::CompletionItemKind::TEXT,
|
||||||
ScriptElementKind::ScriptElement => lsp::CompletionItemKind::File,
|
ScriptElementKind::ScriptElement => lsp::CompletionItemKind::FILE,
|
||||||
ScriptElementKind::Directory => lsp::CompletionItemKind::Folder,
|
ScriptElementKind::Directory => lsp::CompletionItemKind::FOLDER,
|
||||||
ScriptElementKind::String => lsp::CompletionItemKind::Constant,
|
ScriptElementKind::String => lsp::CompletionItemKind::CONSTANT,
|
||||||
_ => lsp::CompletionItemKind::Property,
|
_ => lsp::CompletionItemKind::PROPERTY,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -507,35 +507,35 @@ impl From<ScriptElementKind> for lsp::CompletionItemKind {
|
||||||
impl From<ScriptElementKind> for lsp::SymbolKind {
|
impl From<ScriptElementKind> for lsp::SymbolKind {
|
||||||
fn from(kind: ScriptElementKind) -> Self {
|
fn from(kind: ScriptElementKind) -> Self {
|
||||||
match kind {
|
match kind {
|
||||||
ScriptElementKind::ModuleElement => Self::Module,
|
ScriptElementKind::ModuleElement => Self::MODULE,
|
||||||
// this is only present in `getSymbolKind` in `workspaceSymbols` in
|
// this is only present in `getSymbolKind` in `workspaceSymbols` in
|
||||||
// vscode, but seems strange it isn't consistent.
|
// vscode, but seems strange it isn't consistent.
|
||||||
ScriptElementKind::TypeElement => Self::Class,
|
ScriptElementKind::TypeElement => Self::CLASS,
|
||||||
ScriptElementKind::ClassElement => Self::Class,
|
ScriptElementKind::ClassElement => Self::CLASS,
|
||||||
ScriptElementKind::EnumElement => Self::Enum,
|
ScriptElementKind::EnumElement => Self::ENUM,
|
||||||
ScriptElementKind::EnumMemberElement => Self::EnumMember,
|
ScriptElementKind::EnumMemberElement => Self::ENUM_MEMBER,
|
||||||
ScriptElementKind::InterfaceElement => Self::Interface,
|
ScriptElementKind::InterfaceElement => Self::INTERFACE,
|
||||||
ScriptElementKind::IndexSignatureElement => Self::Method,
|
ScriptElementKind::IndexSignatureElement => Self::METHOD,
|
||||||
ScriptElementKind::CallSignatureElement => Self::Method,
|
ScriptElementKind::CallSignatureElement => Self::METHOD,
|
||||||
ScriptElementKind::MemberFunctionElement => Self::Method,
|
ScriptElementKind::MemberFunctionElement => Self::METHOD,
|
||||||
// workspaceSymbols in vscode treats them as fields, which does seem more
|
// workspaceSymbols in vscode treats them as fields, which does seem more
|
||||||
// semantically correct while `fromProtocolScriptElementKind` treats them
|
// semantically correct while `fromProtocolScriptElementKind` treats them
|
||||||
// as properties.
|
// as properties.
|
||||||
ScriptElementKind::MemberVariableElement => Self::Field,
|
ScriptElementKind::MemberVariableElement => Self::FIELD,
|
||||||
ScriptElementKind::MemberGetAccessorElement => Self::Field,
|
ScriptElementKind::MemberGetAccessorElement => Self::FIELD,
|
||||||
ScriptElementKind::MemberSetAccessorElement => Self::Field,
|
ScriptElementKind::MemberSetAccessorElement => Self::FIELD,
|
||||||
ScriptElementKind::VariableElement => Self::Variable,
|
ScriptElementKind::VariableElement => Self::VARIABLE,
|
||||||
ScriptElementKind::LetElement => Self::Variable,
|
ScriptElementKind::LetElement => Self::VARIABLE,
|
||||||
ScriptElementKind::ConstElement => Self::Variable,
|
ScriptElementKind::ConstElement => Self::VARIABLE,
|
||||||
ScriptElementKind::LocalVariableElement => Self::Variable,
|
ScriptElementKind::LocalVariableElement => Self::VARIABLE,
|
||||||
ScriptElementKind::Alias => Self::Variable,
|
ScriptElementKind::Alias => Self::VARIABLE,
|
||||||
ScriptElementKind::FunctionElement => Self::Function,
|
ScriptElementKind::FunctionElement => Self::FUNCTION,
|
||||||
ScriptElementKind::LocalFunctionElement => Self::Function,
|
ScriptElementKind::LocalFunctionElement => Self::FUNCTION,
|
||||||
ScriptElementKind::ConstructSignatureElement => Self::Constructor,
|
ScriptElementKind::ConstructSignatureElement => Self::CONSTRUCTOR,
|
||||||
ScriptElementKind::ConstructorImplementationElement => Self::Constructor,
|
ScriptElementKind::ConstructorImplementationElement => Self::CONSTRUCTOR,
|
||||||
ScriptElementKind::TypeParameterElement => Self::TypeParameter,
|
ScriptElementKind::TypeParameterElement => Self::TYPE_PARAMETER,
|
||||||
ScriptElementKind::String => Self::String,
|
ScriptElementKind::String => Self::STRING,
|
||||||
_ => Self::Variable,
|
_ => Self::VARIABLE,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -726,7 +726,7 @@ impl NavigateToItem {
|
||||||
let mut tags: Option<Vec<lsp::SymbolTag>> = None;
|
let mut tags: Option<Vec<lsp::SymbolTag>> = None;
|
||||||
let kind_modifiers = parse_kind_modifier(&self.kind_modifiers);
|
let kind_modifiers = parse_kind_modifier(&self.kind_modifiers);
|
||||||
if kind_modifiers.contains("deprecated") {
|
if kind_modifiers.contains("deprecated") {
|
||||||
tags = Some(vec![lsp::SymbolTag::Deprecated]);
|
tags = Some(vec![lsp::SymbolTag::DEPRECATED]);
|
||||||
}
|
}
|
||||||
|
|
||||||
// The field `deprecated` is deprecated but SymbolInformation does not have
|
// The field `deprecated` is deprecated but SymbolInformation does not have
|
||||||
|
@ -837,7 +837,7 @@ impl NavigationTree {
|
||||||
let mut tags: Option<Vec<lsp::SymbolTag>> = None;
|
let mut tags: Option<Vec<lsp::SymbolTag>> = None;
|
||||||
let kind_modifiers = parse_kind_modifier(&self.kind_modifiers);
|
let kind_modifiers = parse_kind_modifier(&self.kind_modifiers);
|
||||||
if kind_modifiers.contains("deprecated") {
|
if kind_modifiers.contains("deprecated") {
|
||||||
tags = Some(vec![lsp::SymbolTag::Deprecated]);
|
tags = Some(vec![lsp::SymbolTag::DEPRECATED]);
|
||||||
}
|
}
|
||||||
|
|
||||||
let children = if !symbol_children.is_empty() {
|
let children = if !symbol_children.is_empty() {
|
||||||
|
@ -1087,9 +1087,9 @@ impl DocumentHighlights {
|
||||||
range: hs.text_span.to_range(line_index.clone()),
|
range: hs.text_span.to_range(line_index.clone()),
|
||||||
kind: match hs.kind {
|
kind: match hs.kind {
|
||||||
HighlightSpanKind::WrittenReference => {
|
HighlightSpanKind::WrittenReference => {
|
||||||
Some(lsp::DocumentHighlightKind::Write)
|
Some(lsp::DocumentHighlightKind::WRITE)
|
||||||
}
|
}
|
||||||
_ => Some(lsp::DocumentHighlightKind::Read),
|
_ => Some(lsp::DocumentHighlightKind::READ),
|
||||||
},
|
},
|
||||||
})
|
})
|
||||||
.collect()
|
.collect()
|
||||||
|
@ -1550,7 +1550,7 @@ impl CallHierarchyItem {
|
||||||
if let Some(modifiers) = self.kind_modifiers.as_ref() {
|
if let Some(modifiers) = self.kind_modifiers.as_ref() {
|
||||||
let kind_modifiers = parse_kind_modifier(modifiers);
|
let kind_modifiers = parse_kind_modifier(modifiers);
|
||||||
if kind_modifiers.contains("deprecated") {
|
if kind_modifiers.contains("deprecated") {
|
||||||
tags = Some(vec![lsp::SymbolTag::Deprecated]);
|
tags = Some(vec![lsp::SymbolTag::DEPRECATED]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1884,8 +1884,8 @@ impl CompletionEntry {
|
||||||
|
|
||||||
let preselect = self.is_recommended;
|
let preselect = self.is_recommended;
|
||||||
let use_code_snippet = settings.complete_function_calls
|
let use_code_snippet = settings.complete_function_calls
|
||||||
&& (kind == Some(lsp::CompletionItemKind::Function)
|
&& (kind == Some(lsp::CompletionItemKind::FUNCTION)
|
||||||
|| kind == Some(lsp::CompletionItemKind::Method));
|
|| kind == Some(lsp::CompletionItemKind::METHOD));
|
||||||
// TODO(@kitsonk) missing from types: https://github.com/gluon-lang/lsp-types/issues/204
|
// TODO(@kitsonk) missing from types: https://github.com/gluon-lang/lsp-types/issues/204
|
||||||
let _commit_characters = self.get_commit_characters(info, settings);
|
let _commit_characters = self.get_commit_characters(info, settings);
|
||||||
let mut insert_text = self.insert_text.clone();
|
let mut insert_text = self.insert_text.clone();
|
||||||
|
@ -1906,10 +1906,10 @@ impl CompletionEntry {
|
||||||
label += "?";
|
label += "?";
|
||||||
}
|
}
|
||||||
if kind_modifiers.contains("deprecated") {
|
if kind_modifiers.contains("deprecated") {
|
||||||
tags = Some(vec![lsp::CompletionItemTag::Deprecated]);
|
tags = Some(vec![lsp::CompletionItemTag::DEPRECATED]);
|
||||||
}
|
}
|
||||||
if kind_modifiers.contains("color") {
|
if kind_modifiers.contains("color") {
|
||||||
kind = Some(lsp::CompletionItemKind::Color);
|
kind = Some(lsp::CompletionItemKind::COLOR);
|
||||||
}
|
}
|
||||||
if self.kind == ScriptElementKind::ScriptElement {
|
if self.kind == ScriptElementKind::ScriptElement {
|
||||||
for ext_modifier in FILE_EXTENSION_KIND_MODIFIERS {
|
for ext_modifier in FILE_EXTENSION_KIND_MODIFIERS {
|
||||||
|
@ -2669,14 +2669,17 @@ pub enum SignatureHelpTriggerKind {
|
||||||
Invoked,
|
Invoked,
|
||||||
#[serde(rename = "retrigger")]
|
#[serde(rename = "retrigger")]
|
||||||
Retrigger,
|
Retrigger,
|
||||||
|
#[serde(rename = "unknown")]
|
||||||
|
Unknown,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl From<lsp::SignatureHelpTriggerKind> for SignatureHelpTriggerKind {
|
impl From<lsp::SignatureHelpTriggerKind> for SignatureHelpTriggerKind {
|
||||||
fn from(kind: lsp::SignatureHelpTriggerKind) -> Self {
|
fn from(kind: lsp::SignatureHelpTriggerKind) -> Self {
|
||||||
match kind {
|
match kind {
|
||||||
lsp::SignatureHelpTriggerKind::Invoked => Self::Invoked,
|
lsp::SignatureHelpTriggerKind::INVOKED => Self::Invoked,
|
||||||
lsp::SignatureHelpTriggerKind::TriggerCharacter => Self::CharacterTyped,
|
lsp::SignatureHelpTriggerKind::TRIGGER_CHARACTER => Self::CharacterTyped,
|
||||||
lsp::SignatureHelpTriggerKind::ContentChange => Self::Retrigger,
|
lsp::SignatureHelpTriggerKind::CONTENT_CHANGE => Self::Retrigger,
|
||||||
|
_ => Self::Unknown,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -179,7 +179,7 @@ fn lsp_tsconfig_bad_config_path() {
|
||||||
let (method, maybe_params) = client.read_notification().unwrap();
|
let (method, maybe_params) = client.read_notification().unwrap();
|
||||||
assert_eq!(method, "window/showMessage");
|
assert_eq!(method, "window/showMessage");
|
||||||
assert_eq!(maybe_params, Some(lsp::ShowMessageParams {
|
assert_eq!(maybe_params, Some(lsp::ShowMessageParams {
|
||||||
typ: lsp::MessageType::Warning,
|
typ: lsp::MessageType::WARNING,
|
||||||
message: "The path to the configuration file (\"bad_tsconfig.json\") is not resolvable.".to_string()
|
message: "The path to the configuration file (\"bad_tsconfig.json\") is not resolvable.".to_string()
|
||||||
}));
|
}));
|
||||||
let diagnostics = did_open(
|
let diagnostics = did_open(
|
||||||
|
@ -3118,7 +3118,7 @@ fn lsp_diagnostics_warn() {
|
||||||
character: 60
|
character: 60
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
severity: Some(lsp::DiagnosticSeverity::Warning),
|
severity: Some(lsp::DiagnosticSeverity::WARNING),
|
||||||
code: Some(lsp::NumberOrString::String("deno-warn".to_string())),
|
code: Some(lsp::NumberOrString::String("deno-warn".to_string())),
|
||||||
source: Some("deno".to_string()),
|
source: Some("deno".to_string()),
|
||||||
message: "foobar".to_string(),
|
message: "foobar".to_string(),
|
||||||
|
|
Loading…
Reference in a new issue