Skip to content

Commit

Permalink
fix(es/minifier): Make Finalizer handle hoisted_props correctly (#…
Browse files Browse the repository at this point in the history
…8738)

**Related issue:**

 - Closes #8737
  • Loading branch information
kdy1 authored Mar 13, 2024
1 parent 391d6f6 commit 95761b7
Show file tree
Hide file tree
Showing 10 changed files with 193 additions and 11 deletions.
63 changes: 63 additions & 0 deletions crates/swc/tests/fixture/issues-8xxx/8737/input/.swcrc
Original file line number Diff line number Diff line change
@@ -0,0 +1,63 @@
{
"jsc": {
"parser": {
"syntax": "ecmascript",
"jsx": false
},
"target": "es5",
"loose": false,
"minify": {
"compress": {
"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": false,
"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
},
"mangle": false
}
},
"module": {
"type": "es6"
},
"isModule": true
}
14 changes: 14 additions & 0 deletions crates/swc/tests/fixture/issues-8xxx/8737/input/1.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
d(() => {
var obj = {
key: "some string",
};

var b = () => {
switch (a) {
default:
break;
}
return obj.key;
};
return () => b;
});
8 changes: 8 additions & 0 deletions crates/swc/tests/fixture/issues-8xxx/8737/output/1.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
d(function() {
var b = function() {
return a, "some string";
};
return function() {
return b;
};
});
1 change: 1 addition & 0 deletions crates/swc_ecma_minifier/src/compress/optimize/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -269,6 +269,7 @@ impl Vars {
|| !self.lits.is_empty()
|| !self.lits_for_cmp.is_empty()
|| !self.lits_for_array_access.is_empty()
|| !self.hoisted_props.is_empty()
|| !self.removed.is_empty()
{
let mut v = Finalizer {
Expand Down
33 changes: 22 additions & 11 deletions crates/swc_ecma_minifier/src/compress/optimize/util.rs
Original file line number Diff line number Diff line change
Expand Up @@ -405,24 +405,35 @@ impl VisitMut for Finalizer<'_> {
}

fn visit_mut_expr(&mut self, n: &mut Expr) {
if let Expr::Ident(i) = n {
if let Some(expr) = self.lits.get(&i.to_id()) {
*n = *expr.clone();
match n {
Expr::Ident(i) => {
if let Some(expr) = self.lits.get(&i.to_id()) {
*n = *expr.clone();
return;
}
}
} else {
n.visit_mut_children_with(self);
}

if let Expr::Member(e) = n {
if let Expr::Ident(obj) = &*e.obj {
if let MemberProp::Ident(prop) = &e.prop {
if let Some(ident) = self.hoisted_props.get(&(obj.to_id(), prop.sym.clone())) {
Expr::Member(e) => {
if let Expr::Ident(obj) = &*e.obj {
let sym = match &e.prop {
MemberProp::Ident(i) => &i.sym,
MemberProp::Computed(e) => match &*e.expr {
Expr::Lit(Lit::Str(s)) => &s.value,
_ => return,
},
_ => return,
};

if let Some(ident) = self.hoisted_props.get(&(obj.to_id(), sym.clone())) {
self.changed = true;
*n = ident.clone().into();
return;
}
}
}
_ => {}
}

n.visit_mut_children_with(self);
}

fn visit_mut_stmts(&mut self, n: &mut Vec<Stmt>) {
Expand Down
10 changes: 10 additions & 0 deletions crates/swc_ecma_minifier/tests/fixture/issues/8737/2/input.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
d(function () {
var obj = {
key: "some string"
}, b = function () {
return a, obj.key;
};
return function () {
return b;
};
});
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
d(function() {
var b = function() {
return a, "some string";
};
return function() {
return b;
};
});
47 changes: 47 additions & 0 deletions crates/swc_ecma_minifier/tests/fixture/issues/8737/config.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,47 @@
{
"defaults": true,
"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": false,
"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
}
14 changes: 14 additions & 0 deletions crates/swc_ecma_minifier/tests/fixture/issues/8737/input.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
d(() => {
var obj = {
key: "some string",
};

var b = () => {
switch (a) {
default:
break;
}
return obj.key;
};
return () => b;
});
6 changes: 6 additions & 0 deletions crates/swc_ecma_minifier/tests/fixture/issues/8737/output.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
d(()=>{
var obj = {
key: "some string"
}, b = ()=>(a, obj.key);
return ()=>b;
});

0 comments on commit 95761b7

Please sign in to comment.