diff options
author | Alex Lam S.L <alexlamsl@gmail.com> | 2019-04-25 04:14:21 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2019-04-25 04:14:21 +0800 |
commit | a206964c0a69776e498ba838e55d0f85946cd27e (patch) | |
tree | 7ed1a96e5ed372099935193d370f8a5150abc2ff | |
parent | c56d89f804e852f8678fa7557f781de893c138bf (diff) | |
download | tracifyjs-a206964c0a69776e498ba838e55d0f85946cd27e.tar.gz tracifyjs-a206964c0a69776e498ba838e55d0f85946cd27e.zip |
enhance `side_effects` (#3383)
-rw-r--r-- | lib/compress.js | 16 | ||||
-rw-r--r-- | test/compress/conditionals.js | 19 | ||||
-rw-r--r-- | test/compress/issue-1639.js | 13 | ||||
-rw-r--r-- | test/compress/sequences.js | 2 |
4 files changed, 36 insertions, 14 deletions
diff --git a/lib/compress.js b/lib/compress.js index 0a195940..13fc953d 100644 --- a/lib/compress.js +++ b/lib/compress.js @@ -4172,10 +4172,18 @@ merge(Compressor.prototype, { var right = this.right.drop_side_effect_free(compressor, first_in_statement); if (!right) return this.left.drop_side_effect_free(compressor, first_in_statement); if (lazy_op[this.operator]) { - if (right === this.right) return this; - var node = this.clone(); - node.right = right.drop_side_effect_free(compressor); - return node; + var node; + if (right === this.right) { + node = this; + } else { + node = this.clone(); + node.right = right.drop_side_effect_free(compressor); + } + return (first_in_statement ? best_of_statement : best_of_expression)(node, make_node(AST_Binary, this, { + operator: node.operator == "&&" ? "||" : "&&", + left: node.left.negate(compressor, first_in_statement), + right: node.right + })); } else { var left = this.left.drop_side_effect_free(compressor, first_in_statement); if (!left) return right; diff --git a/test/compress/conditionals.js b/test/compress/conditionals.js index 78c0ca24..a208165f 100644 --- a/test/compress/conditionals.js +++ b/test/compress/conditionals.js @@ -1416,3 +1416,22 @@ issue_3271: { } expect_stdout: "1 1" } + +iife_condition: { + options = { + conditionals: true, + side_effects: true, + } + input: { + if (function() { + return console; + }()) + console.log("PASS"); + } + expect: { + !function() { + return console; + }() || console.log("PASS"); + } + expect_stdout: "PASS" +} diff --git a/test/compress/issue-1639.js b/test/compress/issue-1639.js index 80d45a76..1579e06e 100644 --- a/test/compress/issue-1639.js +++ b/test/compress/issue-1639.js @@ -1,4 +1,3 @@ - issue_1639_1: { options = { booleans: true, @@ -12,7 +11,6 @@ issue_1639_1: { } input: { var a = 100, b = 10; - var L1 = 5; while (--L1 > 0) { if ((--b), false) { @@ -21,7 +19,6 @@ issue_1639_1: { } } } - console.log(a, b); } expect: { @@ -29,7 +26,7 @@ issue_1639_1: { if (--b, 0) var ignore = 0; console.log(a, b); } - expect_stdout: true + expect_stdout: "100 6" } issue_1639_2: { @@ -44,25 +41,23 @@ issue_1639_2: { } input: { var a = 100, b = 10; - function f19() { if (++a, false) if (a) if (++a); } f19(); - console.log(a, b); } expect: { var a = 100, b = 10; function f19() { - ++a, 0; + ++a, 1; } f19(), console.log(a, b); } - expect_stdout: true + expect_stdout: "101 10" } issue_1639_3: { @@ -84,5 +79,5 @@ issue_1639_3: { a++, console.log(a, b); } - expect_stdout: true + expect_stdout: "101 10" } diff --git a/test/compress/sequences.js b/test/compress/sequences.js index 0670ab53..29cede40 100644 --- a/test/compress/sequences.js +++ b/test/compress/sequences.js @@ -702,7 +702,7 @@ side_effects_cascade_3: { } expect: { function f(a, b) { - !(b += a) && ((b = a) || (b -= a, b ^= a)), + (b += a) || (b = a) || (b -= a, b ^= a), a--; } } |