Unnamed repository; edit this file 'description' to name the repository.
Merge pull request #18756 from roife/fix-18751
fix missing name enum when hovering on fields in variants
Lukas Wirth 2024-12-25
parent dc90d2d · parent 5a3d1a6 · commit bfc223e
-rw-r--r--crates/ide/src/hover/render.rs15
-rw-r--r--crates/ide/src/hover/tests.rs2
2 files changed, 14 insertions, 3 deletions
diff --git a/crates/ide/src/hover/render.rs b/crates/ide/src/hover/render.rs
index 8c5c27c47c..119a864eb9 100644
--- a/crates/ide/src/hover/render.rs
+++ b/crates/ide/src/hover/render.rs
@@ -5,7 +5,7 @@ use either::Either;
use hir::{
db::ExpandDatabase, Adt, AsAssocItem, AsExternAssocItem, AssocItemContainer, CaptureKind,
DynCompatibilityViolation, HasCrate, HasSource, HirDisplay, Layout, LayoutError,
- MethodViolationCode, Name, Semantics, Symbol, Trait, Type, TypeInfo,
+ MethodViolationCode, Name, Semantics, Symbol, Trait, Type, TypeInfo, VariantDef,
};
use ide_db::{
base_db::SourceDatabase,
@@ -378,7 +378,18 @@ pub(super) fn process_markup(
fn definition_owner_name(db: &RootDatabase, def: &Definition, edition: Edition) -> Option<String> {
match def {
- Definition::Field(f) => Some(f.parent_def(db).name(db)),
+ Definition::Field(f) => {
+ let parent = f.parent_def(db);
+ let parent_name = parent.name(db);
+ let parent_name = parent_name.display(db, edition).to_string();
+ return match parent {
+ VariantDef::Variant(variant) => {
+ let enum_name = variant.parent_enum(db).name(db);
+ Some(format!("{}::{parent_name}", enum_name.display(db, edition)))
+ }
+ _ => Some(parent_name),
+ };
+ }
Definition::Local(l) => l.parent(db).name(db),
Definition::Variant(e) => Some(e.parent_enum(db).name(db)),
diff --git a/crates/ide/src/hover/tests.rs b/crates/ide/src/hover/tests.rs
index cc926a5b56..ed8cd64cdb 100644
--- a/crates/ide/src/hover/tests.rs
+++ b/crates/ide/src/hover/tests.rs
@@ -7294,7 +7294,7 @@ enum Enum {
*field*
```rust
- ra_test_fixture::RecordV
+ ra_test_fixture::Enum::RecordV
```
```rust