diff --git a/lib/compress.js b/lib/compress.js index db6967d7..69c954b3 100644 --- a/lib/compress.js +++ b/lib/compress.js @@ -9174,17 +9174,20 @@ Compressor.prototype.compress = function(node) { child = parent; parent = compressor.parent(level++); if (parent instanceof AST_Binary) { - var op = parent.operator; - if (!lazy_op[op]) return; - var left = parent.left; - if (left === child) continue; - if (match(left)) switch (op) { - case "&&": - node[negated ? "falsy" : "truthy"] = true; + switch (child) { + case parent.left: + if (lazy_op[parent.operator]) continue; break; - case "||": - case "??": - node[negated ? "truthy" : "falsy"] = true; + case parent.right: + if (match(parent.left)) switch (parent.operator) { + case "&&": + node[negated ? "falsy" : "truthy"] = true; + break; + case "||": + case "??": + node[negated ? "truthy" : "falsy"] = true; + break; + } break; } } else if (parent instanceof AST_Conditional) { diff --git a/test/compress/booleans.js b/test/compress/booleans.js index d6b93fe5..92680682 100644 --- a/test/compress/booleans.js +++ b/test/compress/booleans.js @@ -762,3 +762,27 @@ issue_5228: { } expect_stdout: "true" } + +issue_5469: { + options = { + assignments: true, + booleans: true, + conditionals: true, + dead_code: true, + evaluate: true, + pure_getters: "strict", + side_effects: true, + } + input: { + console.log(function f(a) { + a && 42[a = A && null]; + }()); + } + expect: { + console.log(function f(a) { + a && A, + 0; + }()); + } + expect_stdout: "undefined" +}