enhance side_effects (#4638)

This commit is contained in:
Alex Lam S.L
2021-02-10 10:09:54 +00:00
committed by GitHub
parent 5ec82e5801
commit a98ec7e4df
3 changed files with 77 additions and 3 deletions

View File

@@ -6922,9 +6922,29 @@ merge(Compressor.prototype, {
exprs = trim(exprs, compressor, first_in_statement, array_spread); exprs = trim(exprs, compressor, first_in_statement, array_spread);
return exprs && make_sequence(self, exprs.map(convert_spread)); return exprs && make_sequence(self, exprs.map(convert_spread));
} }
var def; if (compressor.option("yields") && is_generator(exp)) {
if ((is_arrow(exp) && !exp.value || exp instanceof AST_AsyncFunction || exp instanceof AST_Function) var call = self.clone();
&& !(exp.name && (def = exp.name.definition()).references.length > def.replaced)) { call.expression = make_node(AST_Function, exp, exp);
call.expression.body = [];
var opt = call.transform(compressor);
if (opt !== call) return opt.drop_side_effect_free(compressor, first_in_statement);
}
var drop_body = false;
if (compressor.option("arrows") && is_arrow(exp)) {
if (exp.value) {
exp.value = exp.value.drop_side_effect_free(compressor);
} else {
drop_body = true;
}
} else if (exp instanceof AST_AsyncFunction || exp instanceof AST_Function) {
if (exp.name) {
var def = exp.name.definition();
drop_body = def.references.length == def.replaced;
} else {
drop_body = true;
}
}
if (drop_body) {
exp.process_expression(false, function(node) { exp.process_expression(false, function(node) {
var value = node.value && node.value.drop_side_effect_free(compressor, true); var value = node.value && node.value.drop_side_effect_free(compressor, true);
return value ? make_node(AST_SimpleStatement, node, { return value ? make_node(AST_SimpleStatement, node, {

View File

@@ -456,6 +456,7 @@ collapse_property_lambda: {
drop_return: { drop_return: {
options = { options = {
arrows: true,
side_effects: true, side_effects: true,
} }
input: { input: {
@@ -474,6 +475,21 @@ drop_return: {
node_version: ">=4" node_version: ">=4"
} }
drop_value: {
options = {
arrows: true,
side_effects: true,
}
input: {
((a, b) => a + b)(console.log(42));
}
expect: {
((a, b) => {})(console.log(42));
}
expect_stdout: "42"
node_version: ">=4"
}
reduce_iife_1: { reduce_iife_1: {
options = { options = {
evaluate: true, evaluate: true,

View File

@@ -667,6 +667,44 @@ inline_nested_yield: {
node_version: ">=4" node_version: ">=4"
} }
drop_body: {
options = {
side_effects: true,
yields: true,
}
input: {
(function*([ , a = console.log("foo") ]) {
console.log("bar");
})([ console.log("baz") ]);
}
expect: {
[ [ , 0[0] = console.log("foo") ] ] = [ [ console.log("baz") ] ];
}
expect_stdout: [
"baz",
"foo",
]
node_version: ">=6"
}
drop_unused_call: {
options = {
inline: true,
side_effects: true,
toplevel: true,
unused: true,
yields: true,
}
input: {
var a = function*(){}(console.log("PASS"));
}
expect: {
console.log("PASS");
}
expect_stdout: "PASS"
node_version: ">=4"
}
issue_4454_1: { issue_4454_1: {
rename = false rename = false
options = { options = {