From 709b3c7cd62ca8818e3856d8dc3faf5bade02a1d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Donny/=EA=B0=95=EB=8F=99=EC=9C=A4?= Date: Mon, 25 Oct 2021 06:51:08 +0900 Subject: [PATCH] fix(es/transforms/optimization): Fix `inline_globals` (#2524) swc_ecma_transforms_optimization: - `inline_globals`: Skip assignment to `process.env.FOO`. (#2499) --- Cargo.lock | 2 +- cspell.json | 1 + ecmascript/transforms/optimization/Cargo.toml | 2 +- .../optimization/src/inline_globals.rs | 30 +++++++++++++++++++ 4 files changed, 33 insertions(+), 2 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index 5318f53176b7..8936d67c51ad 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -2884,7 +2884,7 @@ dependencies = [ [[package]] name = "swc_ecma_transforms_optimization" -version = "0.60.0" +version = "0.60.1" dependencies = [ "ahash", "dashmap", diff --git a/cspell.json b/cspell.json index 1bf1c627be8b..cfc020e4e504 100644 --- a/cspell.json +++ b/cspell.json @@ -25,6 +25,7 @@ "cname", "combinator", "Combinator", + "cond", "Cond", "constness", "corejs", diff --git a/ecmascript/transforms/optimization/Cargo.toml b/ecmascript/transforms/optimization/Cargo.toml index 0df8dd9c94e3..e08c65ba07ef 100644 --- a/ecmascript/transforms/optimization/Cargo.toml +++ b/ecmascript/transforms/optimization/Cargo.toml @@ -6,7 +6,7 @@ edition = "2018" license = "Apache-2.0/MIT" name = "swc_ecma_transforms_optimization" repository = "https://github.com/swc-project/swc.git" -version = "0.60.0" +version = "0.60.1" # See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html [features] diff --git a/ecmascript/transforms/optimization/src/inline_globals.rs b/ecmascript/transforms/optimization/src/inline_globals.rs index 490eb5cf0fa6..42f6b346a3b0 100644 --- a/ecmascript/transforms/optimization/src/inline_globals.rs +++ b/ecmascript/transforms/optimization/src/inline_globals.rs @@ -68,6 +68,24 @@ impl Parallel for InlineGlobals { impl VisitMut for InlineGlobals { noop_visit_mut_type!(); + fn visit_mut_assign_expr(&mut self, n: &mut AssignExpr) { + n.right.visit_mut_with(self); + + match &mut n.left { + PatOrExpr::Expr(l) => { + (&mut **l).visit_mut_children_with(self); + } + PatOrExpr::Pat(l) => match &mut **l { + Pat::Expr(l) => { + (&mut **l).visit_mut_children_with(self); + } + _ => { + l.visit_mut_with(self); + } + }, + } + } + fn visit_mut_expr(&mut self, expr: &mut Expr) { match expr { Expr::Ident(Ident { ref sym, span, .. }) => { @@ -336,4 +354,16 @@ mod tests { "const test = process.env['x']", "const test = 'FOO'" ); + + test!( + Default::default(), + |tester| inline_globals( + envs(tester, &[("x", "BAR")]), + globals(tester, &[]), + Default::default(), + ), + issue_2499_1, + "process.env.x = 'foo'", + "process.env.x = 'foo'" + ); }