From 63f1355daa098899473ababa2c8d6d82eee17610 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Donny/=EA=B0=95=EB=8F=99=EC=9C=A4?= Date: Mon, 24 Jul 2023 11:37:52 +0900 Subject: [PATCH 1/5] Add a test --- .../tests/fixture/issues/7697/1/config.json | 47 +++++++++++++++++++ .../tests/fixture/issues/7697/1/input.js | 6 +++ 2 files changed, 53 insertions(+) create mode 100644 crates/swc_ecma_minifier/tests/fixture/issues/7697/1/config.json create mode 100644 crates/swc_ecma_minifier/tests/fixture/issues/7697/1/input.js diff --git a/crates/swc_ecma_minifier/tests/fixture/issues/7697/1/config.json b/crates/swc_ecma_minifier/tests/fixture/issues/7697/1/config.json new file mode 100644 index 000000000000..2c1ceea5a033 --- /dev/null +++ b/crates/swc_ecma_minifier/tests/fixture/issues/7697/1/config.json @@ -0,0 +1,47 @@ +{ + "arguments": false, + "arrows": true, + "booleans": true, + "booleans_as_integers": false, + "collapse_vars": true, + "comparisons": true, + "computed_props": true, + "conditionals": true, + "dead_code": true, + "directives": true, + "drop_console": false, + "drop_debugger": true, + "evaluate": true, + "expression": true, + "hoist_funs": false, + "hoist_props": true, + "hoist_vars": false, + "if_return": true, + "join_vars": true, + "keep_classnames": false, + "keep_fargs": true, + "keep_fnames": false, + "keep_infinity": false, + "loops": true, + "negate_iife": true, + "properties": true, + "reduce_funcs": false, + "reduce_vars": false, + "side_effects": true, + "switches": true, + "typeofs": true, + "unsafe": false, + "unsafe_arrows": false, + "unsafe_comps": false, + "unsafe_Function": false, + "unsafe_math": false, + "unsafe_symbols": false, + "unsafe_methods": false, + "unsafe_proto": false, + "unsafe_regexp": false, + "unsafe_undefined": false, + "unused": true, + "const_to_let": true, + "pristine_globals": true, + "passes": 2 +} diff --git a/crates/swc_ecma_minifier/tests/fixture/issues/7697/1/input.js b/crates/swc_ecma_minifier/tests/fixture/issues/7697/1/input.js new file mode 100644 index 000000000000..9205884ee3e4 --- /dev/null +++ b/crates/swc_ecma_minifier/tests/fixture/issues/7697/1/input.js @@ -0,0 +1,6 @@ +let id = 0; + +export function getId() { + id = id % 9999; + return `${id++}` +} \ No newline at end of file From 6575bda5f07512ec8bf9a7e41219005009e2ede3 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Donny/=EA=B0=95=EB=8F=99=EC=9C=A4?= Date: Mon, 24 Jul 2023 12:06:37 +0900 Subject: [PATCH 2/5] abort in visitor --- .../src/compress/optimize/sequences.rs | 15 +++++++++++++++ 1 file changed, 15 insertions(+) diff --git a/crates/swc_ecma_minifier/src/compress/optimize/sequences.rs b/crates/swc_ecma_minifier/src/compress/optimize/sequences.rs index e78964c3a717..b8434f67e710 100644 --- a/crates/swc_ecma_minifier/src/compress/optimize/sequences.rs +++ b/crates/swc_ecma_minifier/src/compress/optimize/sequences.rs @@ -2493,8 +2493,11 @@ struct UsageCounter<'a> { expr_usage: usize, pat_usage: usize, + abort: bool, + target: &'a Ident, in_lhs: bool, + in_abort: bool, } impl Visit for UsageCounter<'_> { @@ -2502,6 +2505,11 @@ impl Visit for UsageCounter<'_> { fn visit_ident(&mut self, i: &Ident) { if self.target.sym == i.sym && self.target.span.ctxt == i.span.ctxt { + if self.in_abort { + self.abort = true; + return; + } + if self.in_lhs { self.pat_usage += 1; } else { @@ -2521,6 +2529,13 @@ impl Visit for UsageCounter<'_> { } } + fn visit_update_expr(&mut self, e: &UpdateExpr) { + let old_in_abort = self.in_abort; + self.in_abort = true; + e.visit_children_with(self); + self.in_abort = old_in_abort; + } + fn visit_pat(&mut self, p: &Pat) { let old = self.in_lhs; self.in_lhs = true; From 7bf838bcd5f4feb21f8acb7d1ee9221b8925921a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Donny/=EA=B0=95=EB=8F=99=EC=9C=A4?= Date: Mon, 24 Jul 2023 12:07:10 +0900 Subject: [PATCH 3/5] fix --- .../src/compress/optimize/sequences.rs | 12 +++++++++--- 1 file changed, 9 insertions(+), 3 deletions(-) diff --git a/crates/swc_ecma_minifier/src/compress/optimize/sequences.rs b/crates/swc_ecma_minifier/src/compress/optimize/sequences.rs index b8434f67e710..9112ef4f2dc6 100644 --- a/crates/swc_ecma_minifier/src/compress/optimize/sequences.rs +++ b/crates/swc_ecma_minifier/src/compress/optimize/sequences.rs @@ -2031,9 +2031,11 @@ impl Optimizer<'_> { pat_usage: Default::default(), target: a_id, in_lhs: false, + abort: false, + in_abort: false, }; b.visit_with(&mut v); - if v.expr_usage != 1 || v.pat_usage != 0 { + if v.expr_usage != 1 || v.pat_usage != 0 || v.abort { log_abort!( "sequences: Aborting merging of an update expression because of \ usage counts ({}, ref = {}, pat = {})", @@ -2103,9 +2105,11 @@ impl Optimizer<'_> { pat_usage: Default::default(), target: a_id, in_lhs: false, + abort: false, + in_abort: false, }; b.visit_with(&mut v); - if v.expr_usage != 1 || v.pat_usage != 0 { + if v.expr_usage != 1 || v.pat_usage != 0 || v.abort { log_abort!( "sequences: Aborting merging of an update expression because of \ usage counts ({}, ref = {}, pat = {})", @@ -2426,9 +2430,11 @@ impl Optimizer<'_> { pat_usage: Default::default(), target: &left_id, in_lhs: false, + abort: false, + in_abort: false, }; b.visit_with(&mut v); - if v.expr_usage != 1 || v.pat_usage != 0 { + if v.expr_usage != 1 || v.pat_usage != 0 || v.abort { log_abort!( "sequences: Aborting because of usage counts ({}{:?}, ref = {}, pat = {})", left_id.sym, From aea22707768d9a3c14b11cb4e6883587f4b4e147 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Donny/=EA=B0=95=EB=8F=99=EC=9C=A4?= Date: Mon, 24 Jul 2023 12:09:02 +0900 Subject: [PATCH 4/5] More --- .../src/compress/optimize/sequences.rs | 14 ++++++++++++++ 1 file changed, 14 insertions(+) diff --git a/crates/swc_ecma_minifier/src/compress/optimize/sequences.rs b/crates/swc_ecma_minifier/src/compress/optimize/sequences.rs index 9112ef4f2dc6..b7873cfb1eb8 100644 --- a/crates/swc_ecma_minifier/src/compress/optimize/sequences.rs +++ b/crates/swc_ecma_minifier/src/compress/optimize/sequences.rs @@ -2542,6 +2542,20 @@ impl Visit for UsageCounter<'_> { self.in_abort = old_in_abort; } + fn visit_await_expr(&mut self, e: &AwaitExpr) { + let old_in_abort = self.in_abort; + self.in_abort = true; + e.visit_children_with(self); + self.in_abort = old_in_abort; + } + + fn visit_yield_expr(&mut self, e: &YieldExpr) { + let old_in_abort = self.in_abort; + self.in_abort = true; + e.visit_children_with(self); + self.in_abort = old_in_abort; + } + fn visit_pat(&mut self, p: &Pat) { let old = self.in_lhs; self.in_lhs = true; From f1eb588eea06372aa30a98c25c0bd0ff291d83b8 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Donny/=EA=B0=95=EB=8F=99=EC=9C=A4?= Date: Mon, 24 Jul 2023 12:09:25 +0900 Subject: [PATCH 5/5] Update test refs --- .../swc_ecma_minifier/tests/fixture/issues/7697/1/output.js | 4 ++++ 1 file changed, 4 insertions(+) create mode 100644 crates/swc_ecma_minifier/tests/fixture/issues/7697/1/output.js diff --git a/crates/swc_ecma_minifier/tests/fixture/issues/7697/1/output.js b/crates/swc_ecma_minifier/tests/fixture/issues/7697/1/output.js new file mode 100644 index 000000000000..bde1103104cc --- /dev/null +++ b/crates/swc_ecma_minifier/tests/fixture/issues/7697/1/output.js @@ -0,0 +1,4 @@ +let id = 0; +export function getId() { + return id %= 9999, `${id++}`; +}