@@ -5788,15 +5788,12 @@ merge(Compressor.prototype, {
|
|||||||
if (!in_use || node.left === sym && indexOf_assign(def, node) < 0) {
|
if (!in_use || node.left === sym && indexOf_assign(def, node) < 0) {
|
||||||
value = get_rhs(node);
|
value = get_rhs(node);
|
||||||
if (node.write_only === true) {
|
if (node.write_only === true) {
|
||||||
value = value.drop_side_effect_free(compressor) || make_node(AST_Number, node, {
|
value = value.drop_side_effect_free(compressor)
|
||||||
value: 0
|
|| make_node(AST_Number, node, { value: 0 });
|
||||||
});
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if (!in_use || node.expression === sym && indexOf_assign(def, node) < 0) {
|
} else if (!in_use || node.expression === sym && indexOf_assign(def, node) < 0) {
|
||||||
value = make_node(AST_Number, node, {
|
value = make_node(AST_Number, node, { value: 0 });
|
||||||
value: 0
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
if (value) {
|
if (value) {
|
||||||
if (parent instanceof AST_Sequence && parent.tail_node() !== node) {
|
if (parent instanceof AST_Sequence && parent.tail_node() !== node) {
|
||||||
@@ -7168,7 +7165,7 @@ merge(Compressor.prototype, {
|
|||||||
assign = assign.clone();
|
assign = assign.clone();
|
||||||
assign.right = cond;
|
assign.right = cond;
|
||||||
expressions = expressions.slice(0, -2);
|
expressions = expressions.slice(0, -2);
|
||||||
expressions.push(assign);
|
expressions.push(assign.drop_side_effect_free(compressor, first_in_statement));
|
||||||
}
|
}
|
||||||
return expressions === this.expressions ? this : make_sequence(this, expressions);
|
return expressions === this.expressions ? this : make_sequence(this, expressions);
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -506,3 +506,34 @@ issue_4366_2: {
|
|||||||
expect_stdout: "PASS"
|
expect_stdout: "PASS"
|
||||||
node_version: ">=4"
|
node_version: ">=4"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
issue_4668: {
|
||||||
|
options = {
|
||||||
|
conditionals: true,
|
||||||
|
keep_fargs: false,
|
||||||
|
keep_fnames: true,
|
||||||
|
reduce_vars: true,
|
||||||
|
side_effects: true,
|
||||||
|
toplevel: true,
|
||||||
|
unused: true,
|
||||||
|
}
|
||||||
|
input: {
|
||||||
|
function f(a) {
|
||||||
|
var b, c;
|
||||||
|
function g() {
|
||||||
|
return a = 0 + a, !d || (a = 0);
|
||||||
|
}
|
||||||
|
c = g();
|
||||||
|
}
|
||||||
|
console.log(f());
|
||||||
|
var d = 0;
|
||||||
|
}
|
||||||
|
expect: {
|
||||||
|
console.log(function f() {
|
||||||
|
(function g() {
|
||||||
|
0;
|
||||||
|
})();
|
||||||
|
}());
|
||||||
|
}
|
||||||
|
expect_stdout: "undefined"
|
||||||
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user