@@ -2371,8 +2371,9 @@ merge(Compressor.prototype, {
|
|||||||
var lhs = expr.left;
|
var lhs = expr.left;
|
||||||
if (!(lhs instanceof AST_SymbolRef)) break;
|
if (!(lhs instanceof AST_SymbolRef)) break;
|
||||||
if (is_undeclared_ref(lhs)) break;
|
if (is_undeclared_ref(lhs)) break;
|
||||||
|
if (lhs.scope !== scope) break;
|
||||||
var def = lhs.definition();
|
var def = lhs.definition();
|
||||||
if (def.scope !== lhs.scope) break;
|
if (def.scope !== scope) break;
|
||||||
if (def.orig.length > def.eliminated + 1) break;
|
if (def.orig.length > def.eliminated + 1) break;
|
||||||
if (def.orig[0].TYPE != "SymbolVar") break;
|
if (def.orig[0].TYPE != "SymbolVar") break;
|
||||||
var name = make_node(AST_SymbolVar, lhs, lhs);
|
var name = make_node(AST_SymbolVar, lhs, lhs);
|
||||||
|
|||||||
@@ -782,3 +782,36 @@ issue_3791_2: {
|
|||||||
}
|
}
|
||||||
expect_stdout: "function"
|
expect_stdout: "function"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
issue_3795: {
|
||||||
|
options = {
|
||||||
|
collapse_vars: true,
|
||||||
|
conditionals: true,
|
||||||
|
dead_code: true,
|
||||||
|
evaluate: true,
|
||||||
|
join_vars: true,
|
||||||
|
loops: true,
|
||||||
|
passes: 2,
|
||||||
|
reduce_vars: true,
|
||||||
|
toplevel: true,
|
||||||
|
unused: true,
|
||||||
|
}
|
||||||
|
input: {
|
||||||
|
var a = "FAIL";
|
||||||
|
function f(b) {
|
||||||
|
for (var i = 1; b && i; --i) return 0;
|
||||||
|
a = "PASS";
|
||||||
|
}
|
||||||
|
var c = f(a = "");
|
||||||
|
console.log(a);
|
||||||
|
}
|
||||||
|
expect: {
|
||||||
|
var a = "FAIL";
|
||||||
|
(function(b) {
|
||||||
|
a = "";
|
||||||
|
a = "PASS";
|
||||||
|
})();
|
||||||
|
console.log(a);
|
||||||
|
}
|
||||||
|
expect_stdout: "PASS"
|
||||||
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user