diff options
-rw-r--r-- | lib/compress.js | 26 | ||||
-rw-r--r-- | test/compress/arrows.js | 16 | ||||
-rw-r--r-- | test/compress/yields.js | 38 |
3 files changed, 77 insertions, 3 deletions
diff --git a/lib/compress.js b/lib/compress.js index a0e018e3..5a2a0543 100644 --- a/lib/compress.js +++ b/lib/compress.js @@ -6922,9 +6922,29 @@ merge(Compressor.prototype, { exprs = trim(exprs, compressor, first_in_statement, array_spread); return exprs && make_sequence(self, exprs.map(convert_spread)); } - var def; - if ((is_arrow(exp) && !exp.value || exp instanceof AST_AsyncFunction || exp instanceof AST_Function) - && !(exp.name && (def = exp.name.definition()).references.length > def.replaced)) { + if (compressor.option("yields") && is_generator(exp)) { + var call = self.clone(); + 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) { var value = node.value && node.value.drop_side_effect_free(compressor, true); return value ? make_node(AST_SimpleStatement, node, { diff --git a/test/compress/arrows.js b/test/compress/arrows.js index 57d8d395..fbb18b95 100644 --- a/test/compress/arrows.js +++ b/test/compress/arrows.js @@ -456,6 +456,7 @@ collapse_property_lambda: { drop_return: { options = { + arrows: true, side_effects: true, } input: { @@ -474,6 +475,21 @@ drop_return: { 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: { options = { evaluate: true, diff --git a/test/compress/yields.js b/test/compress/yields.js index cd2518d6..7ba19bfd 100644 --- a/test/compress/yields.js +++ b/test/compress/yields.js @@ -667,6 +667,44 @@ inline_nested_yield: { 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: { rename = false options = { |