From 944f30bd694be71d76e1a175033e19409fe9f8b4 Mon Sep 17 00:00:00 2001 From: Aleksey Kladov Date: Tue, 8 Dec 2020 16:28:21 +0300 Subject: [PATCH] Open Cargo.toml opens more specific manifest --- crates/rust-analyzer/src/cargo_target_spec.rs | 12 +++++++++--- crates/rust-analyzer/src/handlers.rs | 10 +++------- 2 files changed, 12 insertions(+), 10 deletions(-) diff --git a/crates/rust-analyzer/src/cargo_target_spec.rs b/crates/rust-analyzer/src/cargo_target_spec.rs index 1ab72bd915..8a8b4a32cb 100644 --- a/crates/rust-analyzer/src/cargo_target_spec.rs +++ b/crates/rust-analyzer/src/cargo_target_spec.rs @@ -14,6 +14,7 @@ use crate::{global_state::GlobalStateSnapshot, Result}; #[derive(Clone)] pub(crate) struct CargoTargetSpec { pub(crate) workspace_root: AbsPathBuf, + pub(crate) cargo_toml: AbsPathBuf, pub(crate) package: String, pub(crate) target: String, pub(crate) target_kind: TargetKind, @@ -115,12 +116,17 @@ impl CargoTargetSpec { Some(it) => it, None => return Ok(None), }; + + let target_data = &cargo_ws[target]; + let package_data = &cargo_ws[target_data.package]; let res = CargoTargetSpec { workspace_root: cargo_ws.workspace_root().to_path_buf(), - package: cargo_ws.package_flag(&cargo_ws[cargo_ws[target].package]), - target: cargo_ws[target].name.clone(), - target_kind: cargo_ws[target].kind, + cargo_toml: package_data.manifest.clone(), + package: cargo_ws.package_flag(&package_data), + target: target_data.name.clone(), + target_kind: target_data.kind, }; + Ok(Some(res)) } diff --git a/crates/rust-analyzer/src/handlers.rs b/crates/rust-analyzer/src/handlers.rs index 7bfbc61037..6250171bab 100644 --- a/crates/rust-analyzer/src/handlers.rs +++ b/crates/rust-analyzer/src/handlers.rs @@ -1342,13 +1342,9 @@ pub(crate) fn handle_open_cargo_toml( None => return Ok(None), }; - let cargo_toml_path = cargo_spec.workspace_root.join("Cargo.toml"); - if !cargo_toml_path.exists() { - return Ok(None); - } - let cargo_toml_url = to_proto::url_from_abs_path(&cargo_toml_path); - let cargo_toml_location = Location::new(cargo_toml_url, Range::default()); - let res = lsp_types::GotoDefinitionResponse::from(cargo_toml_location); + let cargo_toml_url = to_proto::url_from_abs_path(&cargo_spec.cargo_toml); + let res: lsp_types::GotoDefinitionResponse = + Location::new(cargo_toml_url, Range::default()).into(); Ok(Some(res)) }