From 48ff90ee423b03b239fcad8f6a132a72eb00a2c0 Mon Sep 17 00:00:00 2001 From: Valerii Smirnov <57757211+XantreGodlike@users.noreply.github.com> Date: Thu, 18 Jan 2024 02:32:40 +0100 Subject: [PATCH] fix(linter): eslint-plugin-import no-named-as-default-member rule (#2071) Fixed false positives and early return @mysteryven #1988 https://github.com/oxc-project/oxc/pull/1988/files/64de6e9265d97d623d1f3a531b8c12a1a39dce02#r1453429430 --- .../import/no_named_as_default_member.rs | 53 +++++++++++-------- 1 file changed, 32 insertions(+), 21 deletions(-) diff --git a/crates/oxc_linter/src/rules/import/no_named_as_default_member.rs b/crates/oxc_linter/src/rules/import/no_named_as_default_member.rs index 6a7d9eed94388..da4ee51f27eac 100644 --- a/crates/oxc_linter/src/rules/import/no_named_as_default_member.rs +++ b/crates/oxc_linter/src/rules/import/no_named_as_default_member.rs @@ -3,7 +3,7 @@ use std::collections::HashMap; use dashmap::mapref::one::Ref; use oxc_ast::{ - ast::{BindingPatternKind, Expression, MemberExpression}, + ast::{BindingPatternKind, Expression, IdentifierReference, MemberExpression}, AstKind, }; use oxc_diagnostics::{ @@ -11,6 +11,7 @@ use oxc_diagnostics::{ thiserror::Error, }; use oxc_macros::declare_oxc_lint; +use oxc_semantic::SymbolId; use oxc_span::{Atom, Span}; use oxc_syntax::module_record::ImportImportName; @@ -44,12 +45,21 @@ declare_oxc_lint!( NoNamedAsDefaultMember, nursery ); +fn get_symbol_id_from_ident( + ctx: &LintContext<'_>, + ident: &IdentifierReference, +) -> Option { + let reference_id = ident.reference_id.get().unwrap(); + let reference = &ctx.symbols().references[reference_id]; + reference.symbol_id() +} impl Rule for NoNamedAsDefaultMember { fn run_once(&self, ctx: &LintContext<'_>) { let module_record = ctx.semantic().module_record(); - let mut has_members_map: HashMap<&Atom, (Ref<'_, Atom, _, _>, Atom)> = HashMap::default(); + let mut has_members_map: HashMap, Atom)> = + HashMap::default(); for import_entry in &module_record.import_entries { let ImportImportName::Default(_) = import_entry.import_name else { continue; @@ -62,7 +72,7 @@ impl Rule for NoNamedAsDefaultMember { if !remote_module_record_ref.exported_bindings.is_empty() { has_members_map.insert( - import_entry.local_name.name(), + ctx.symbols().get_symbol_id_from_span(&import_entry.local_name.span()).unwrap(), (remote_module_record_ref, import_entry.module_request.name().to_owned()), ); } @@ -71,15 +81,18 @@ impl Rule for NoNamedAsDefaultMember { if has_members_map.is_empty() { return; }; - let get_external_module_name_if_has_entry = |module_name: &Atom, entry_name: &Atom| { - has_members_map.get(&module_name).and_then(|it| { - if it.0.exported_bindings.contains_key(entry_name) { - Some(it.1.to_string()) - } else { - None - } - }) - }; + let get_external_module_name_if_has_entry = + |ident: &IdentifierReference, entry_name: &Atom| { + get_symbol_id_from_ident(ctx, ident) + .and_then(|symbol_id| has_members_map.get(&symbol_id)) + .and_then(|it| { + if it.0.exported_bindings.contains_key(entry_name) { + Some(it.1.to_string()) + } else { + None + } + }) + }; let process_member_expr = |member_expr: &MemberExpression| { let Expression::Identifier(ident) = member_expr.object() else { @@ -89,7 +102,7 @@ impl Rule for NoNamedAsDefaultMember { return; }; if let Some(module_name) = - get_external_module_name_if_has_entry(&ident.name, &Atom::new_inline(prop_str)) + get_external_module_name_if_has_entry(ident, &Atom::new_inline(prop_str)) { ctx.diagnostic(NoNamedAsDefaultMemberDignostic( match member_expr { @@ -108,21 +121,19 @@ impl Rule for NoNamedAsDefaultMember { match item.kind() { AstKind::MemberExpression(member_expr) => process_member_expr(member_expr), AstKind::VariableDeclarator(decl) => { - if let Some(Expression::MemberExpression(member_expr)) = &decl.init { - process_member_expr(member_expr); - return; - } let Some(Expression::Identifier(ident)) = &decl.init else { - return; + continue; }; let BindingPatternKind::ObjectPattern(object_pattern) = &decl.id.kind else { - return; + continue; }; for prop in &*object_pattern.properties { - let Some(name) = prop.key.static_name() else { return }; + let Some(name) = prop.key.static_name() else { + continue; + }; if let Some(module_name) = - get_external_module_name_if_has_entry(&ident.name, &name) + get_external_module_name_if_has_entry(ident, &name) { ctx.diagnostic(NoNamedAsDefaultMemberDignostic( decl.span,