From d837a46ebd1c3a01c3493660f01cbccee68e1aa4 Mon Sep 17 00:00:00 2001 From: "Alex Lam S.L" Date: Wed, 17 Mar 2021 21:14:14 +0000 Subject: fix corner case in `reduce_vars` (#4796) --- lib/compress.js | 1 + test/compress/spreads.js | 25 +++++++++++++++++++++++++ 2 files changed, 26 insertions(+) diff --git a/lib/compress.js b/lib/compress.js index f8b9c8c3..0d4f7abc 100644 --- a/lib/compress.js +++ b/lib/compress.js @@ -624,6 +624,7 @@ merge(Compressor.prototype, { if (parent instanceof AST_Binary) return lazy_op[parent.operator]; if (parent instanceof AST_Conditional) return parent.condition !== node; if (parent instanceof AST_Sequence) return parent.tail_node() === node; + if (parent instanceof AST_Spread) return true; } function mark_escaped(tw, d, scope, node, value, level, depth) { diff --git a/test/compress/spreads.js b/test/compress/spreads.js index f8c0d592..02bb3f0e 100644 --- a/test/compress/spreads.js +++ b/test/compress/spreads.js @@ -294,6 +294,31 @@ reduce_vars_2: { node_version: ">=6" } +reduce_vars_3: { + options = { + reduce_funcs: true, + reduce_vars: true, + toplevel: true, + unused: true, + } + input: { + function f() {} + function g() { + return (a => a)(...[ f ]); + } + console.log(g() === g() ? "PASS" : "FAIL"); + } + expect: { + function f() {} + function g() { + return (a => a)(...[ f ]); + } + console.log(g() === g() ? "PASS" : "FAIL"); + } + expect_stdout: "PASS" + node_version: ">=6" +} + convert_setter: { options = { objects: true, -- cgit v1.2.3