mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-14 22:24:14 +00:00
Fix shadowing of record enum variant in patterns
This commit is contained in:
parent
e6276c8b64
commit
4ec7e61229
2 changed files with 30 additions and 7 deletions
|
@ -1510,20 +1510,20 @@ impl ExprCollector<'_> {
|
||||||
BuiltinShadowMode::Other,
|
BuiltinShadowMode::Other,
|
||||||
None,
|
None,
|
||||||
);
|
);
|
||||||
|
// Funnily enough, record structs/variants *can* be shadowed
|
||||||
|
// by pattern bindings (but unit or tuple structs/variants
|
||||||
|
// can't).
|
||||||
match resolved.take_values() {
|
match resolved.take_values() {
|
||||||
Some(ModuleDefId::ConstId(_)) => (None, Pat::Path(name.into())),
|
Some(ModuleDefId::ConstId(_)) => (None, Pat::Path(name.into())),
|
||||||
Some(ModuleDefId::EnumVariantId(_)) => {
|
Some(ModuleDefId::EnumVariantId(variant))
|
||||||
// this is only really valid for unit variants, but
|
if self.db.variant_data(variant.into()).kind()
|
||||||
// shadowing other enum variants with a pattern is
|
!= StructKind::Record =>
|
||||||
// an error anyway
|
{
|
||||||
(None, Pat::Path(name.into()))
|
(None, Pat::Path(name.into()))
|
||||||
}
|
}
|
||||||
Some(ModuleDefId::AdtId(AdtId::StructId(s)))
|
Some(ModuleDefId::AdtId(AdtId::StructId(s)))
|
||||||
if self.db.struct_data(s).variant_data.kind() != StructKind::Record =>
|
if self.db.struct_data(s).variant_data.kind() != StructKind::Record =>
|
||||||
{
|
{
|
||||||
// Funnily enough, record structs *can* be shadowed
|
|
||||||
// by pattern bindings (but unit or tuple structs
|
|
||||||
// can't).
|
|
||||||
(None, Pat::Path(name.into()))
|
(None, Pat::Path(name.into()))
|
||||||
}
|
}
|
||||||
// shadowing statics is an error as well, so we just ignore that case here
|
// shadowing statics is an error as well, so we just ignore that case here
|
||||||
|
|
|
@ -404,3 +404,26 @@ fn foo() {
|
||||||
}"#]]
|
}"#]]
|
||||||
.assert_eq(&body.pretty_print(&db, def, Edition::CURRENT))
|
.assert_eq(&body.pretty_print(&db, def, Edition::CURRENT))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn shadowing_record_variant() {
|
||||||
|
let (_, body, _) = lower(
|
||||||
|
r#"
|
||||||
|
enum A {
|
||||||
|
B { field: i32 },
|
||||||
|
}
|
||||||
|
fn f() {
|
||||||
|
use A::*;
|
||||||
|
match () {
|
||||||
|
B => {}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
"#,
|
||||||
|
);
|
||||||
|
assert_eq!(body.bindings.len(), 1, "should have a binding for `B`");
|
||||||
|
assert_eq!(
|
||||||
|
body.bindings[BindingId::from_raw(RawIdx::from_u32(0))].name.as_str(),
|
||||||
|
"B",
|
||||||
|
"should have a binding for `B`",
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in a new issue