From: Alex Lam S.L Date: Mon, 17 Apr 2017 09:24:29 +0000 (+0800) Subject: fix `reduce_vars` on boolean binary expressions (#1819) X-Git-Url: https://git.ndcode.org/public/gitweb.cgi?a=commitdiff_plain;h=6d5f341999da7dfad708979151932fd9d8242ebd;p=UglifyJS.git fix `reduce_vars` on boolean binary expressions (#1819) Side effects of `&&` and `||` have not mattered until #1814, which takes assignment expressions into account. --- diff --git a/lib/compress.js b/lib/compress.js index 7324fe0e..f49dd60e 100644 --- a/lib/compress.js +++ b/lib/compress.js @@ -340,6 +340,14 @@ merge(Compressor.prototype, { }); } } + if (node instanceof AST_Binary + && (node.operator == "&&" || node.operator == "||")) { + node.left.walk(tw); + push(); + node.right.walk(tw); + pop(); + return true; + } if (node instanceof AST_If) { node.condition.walk(tw); push(); diff --git a/test/compress/reduce_vars.js b/test/compress/reduce_vars.js index 82b00211..94d37cb7 100644 --- a/test/compress/reduce_vars.js +++ b/test/compress/reduce_vars.js @@ -2217,3 +2217,26 @@ try_abort: { } expect_stdout: "1 undefined" } + +boolean_binary_assign: { + options = { + evaluate: true, + reduce_vars: true, + unused: true, + } + input: { + !function() { + var a; + void 0 && (a = 1); + console.log(a); + }(); + } + expect: { + !function() { + var a; + void 0; + console.log(a); + }(); + } + expect_stdout: "undefined" +}