aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--lib/compress.js39
-rw-r--r--test/compress/dead-code.js38
2 files changed, 60 insertions, 17 deletions
diff --git a/lib/compress.js b/lib/compress.js
index 0d19640d..43ee1126 100644
--- a/lib/compress.js
+++ b/lib/compress.js
@@ -6543,23 +6543,28 @@ merge(Compressor.prototype, {
}
}
} else if (self.left instanceof AST_SymbolRef) {
+ if (self.left.is_immutable()) return strip_assignment();
var def = self.left.definition();
- if (def.scope === compressor.find_parent(AST_Lambda)) {
- if (self.left.is_immutable()) return strip_assignment();
- var level = 0, node, parent = self;
- do {
- node = parent;
- parent = compressor.parent(level++);
- if (parent instanceof AST_Exit) {
- if (in_try(level, parent)) break;
- if (is_reachable(def.scope, [ def ])) break;
- def.fixed = false;
- return strip_assignment();
- }
- } while (parent instanceof AST_Binary && parent.right === node
- || parent instanceof AST_Sequence && parent.tail_node() === node
- || parent instanceof AST_UnaryPrefix);
- }
+ var local = def.scope.resolve() === compressor.find_parent(AST_Lambda);
+ var level = 0, node, parent = self;
+ do {
+ node = parent;
+ parent = compressor.parent(level++);
+ if (parent instanceof AST_Assign) {
+ if (!(parent.left instanceof AST_SymbolRef)) continue;
+ if (parent.left.definition() !== def) continue;
+ def.fixed = false;
+ return strip_assignment();
+ } else if (parent instanceof AST_Exit) {
+ if (!local) break;
+ if (in_try(level, parent)) break;
+ if (is_reachable(def.scope, [ def ])) break;
+ def.fixed = false;
+ return strip_assignment();
+ }
+ } while (parent instanceof AST_Binary && parent.right === node
+ || parent instanceof AST_Sequence && parent.tail_node() === node
+ || parent instanceof AST_UnaryPrefix);
}
}
self = self.lift_sequences(compressor);
@@ -6599,7 +6604,7 @@ merge(Compressor.prototype, {
self.right = make_node(AST_Null, right);
var may_throw = node.may_throw(compressor);
self.right = right;
- var scope = self.left.definition().scope;
+ var scope = self.left.definition().scope.resolve();
var parent;
while ((parent = compressor.parent(level++)) !== scope) {
if (parent instanceof AST_Try) {
diff --git a/test/compress/dead-code.js b/test/compress/dead-code.js
index 93fc9f41..abc7384d 100644
--- a/test/compress/dead-code.js
+++ b/test/compress/dead-code.js
@@ -1064,3 +1064,41 @@ issue_3552: {
}
expect_stdout: "PASS"
}
+
+unreachable_assign: {
+ options = {
+ dead_code: true,
+ }
+ input: {
+ console.log(A = "P" + (A = "A" + (B = "S" + (A = B = "S"))), A, B);
+ }
+ expect: {
+ console.log(A = "P" + "A" + (B = "S" + "S"), A, B);
+ }
+ expect_stdout: "PASS PASS SS"
+}
+
+catch_return_assign: {
+ options = {
+ dead_code: true,
+ }
+ input: {
+ console.log(function() {
+ try {
+ throw "FAIL";
+ } catch (e) {
+ return e = "PASS";
+ }
+ }());
+ }
+ expect: {
+ console.log(function() {
+ try {
+ throw "FAIL";
+ } catch (e) {
+ return "PASS";
+ }
+ }());
+ }
+ expect_stdout: "PASS"
+}