Skip to content

Commit

Permalink
fix(linter): remove unsafe fixer of no-useless-spread
Browse files Browse the repository at this point in the history
  • Loading branch information
shulaoda committed Oct 19, 2024
1 parent 002289b commit 4dfefe1
Show file tree
Hide file tree
Showing 2 changed files with 16 additions and 12 deletions.
21 changes: 16 additions & 5 deletions crates/oxc_linter/src/rules/unicorn/no_useless_spread/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -380,13 +380,26 @@ fn check_useless_clone<'a>(
is_array: bool,
spread_elem: &SpreadElement<'a>,
ctx: &LintContext<'a>,
) -> bool {
) {
let span = Span::new(spread_elem.span.start, spread_elem.span.start + 3);
let target = spread_elem.argument.get_inner_expression();

// already diagnosed by first check
if matches!(target, Expression::ArrayExpression(_) | Expression::ObjectExpression(_)) {
return false;
return;
}

// unsafe fixer of `[...new Array(1)]`
if let Expression::NewExpression(new_expr) = target {
let is_array_constructor = new_expr
.callee
.without_parentheses()
.get_identifier_reference()
.is_some_and(|id| id.name == "Array");

if is_array_constructor && new_expr.arguments.len() == 1 {
return;
}
}

let hint = target.const_eval();
Expand All @@ -397,9 +410,7 @@ fn check_useless_clone<'a>(
ctx.diagnostic_with_fix(clone(span, is_array, name), |fixer| {
fix_by_removing_array_spread(fixer, &array_or_obj_span, spread_elem)
});
return true;
}
false
}

fn diagnostic_name<'a>(ctx: &LintContext<'a>, expr: &Expression<'a>) -> Option<&'a str> {
Expand Down Expand Up @@ -577,6 +588,7 @@ fn test() {
"[...arr.reduce((set, b) => set.add(b), new Set(iter))]",
// NOTE: we may want to consider this a violation in the future
"[...(foo ? new Set() : [])]",
"[...new Array(3)]",
];

let fail = vec![
Expand Down Expand Up @@ -666,7 +678,6 @@ fn test() {
r"[...foo.toSpliced(0, 1)]",
r"[...foo.with(0, bar)]",
r#"[...foo.split("|")]"#,
r"[...new Array(3)]",
r"[...Object.keys(foo)]",
r"[...Object.values(foo)]",
r"[...Array.from(foo)]",
Expand Down
7 changes: 0 additions & 7 deletions crates/oxc_linter/src/snapshots/no_useless_spread.snap
Original file line number Diff line number Diff line change
Expand Up @@ -637,13 +637,6 @@ source: crates/oxc_linter/src/tester.rs
╰────
help: `foo.split` returns a new array. Spreading it into an array expression to create a new array is redundant.

eslint-plugin-unicorn(no-useless-spread): Using a spread operator here creates a new array unnecessarily.
╭─[no_useless_spread.tsx:1:2]
1 │ [...new Array(3)]
· ───
╰────
help: `new Array(3)` returns a new array. Spreading it into an array expression to create a new array is redundant.

eslint-plugin-unicorn(no-useless-spread): Using a spread operator here creates a new array unnecessarily.
╭─[no_useless_spread.tsx:1:2]
1 │ [...Object.keys(foo)]
Expand Down

0 comments on commit 4dfefe1

Please sign in to comment.