@@ -618,7 +618,7 @@ merge(Compressor.prototype, {
|
|||||||
node.value.walk(tw);
|
node.value.walk(tw);
|
||||||
pop(tw);
|
pop(tw);
|
||||||
var save = fixed;
|
var save = fixed;
|
||||||
fixed = function() {
|
if (save) fixed = function() {
|
||||||
var value = save();
|
var value = save();
|
||||||
return is_undefined(value) ? make_sequence(node, [ value, node.value ]) : node.name;
|
return is_undefined(value) ? make_sequence(node, [ value, node.value ]) : node.name;
|
||||||
};
|
};
|
||||||
@@ -631,7 +631,7 @@ merge(Compressor.prototype, {
|
|||||||
var save = fixed;
|
var save = fixed;
|
||||||
node.elements.forEach(function(node, index) {
|
node.elements.forEach(function(node, index) {
|
||||||
if (node instanceof AST_Hole) return reset_flags(node);
|
if (node instanceof AST_Hole) return reset_flags(node);
|
||||||
fixed = function() {
|
if (save) fixed = function() {
|
||||||
return make_node(AST_Sub, node, {
|
return make_node(AST_Sub, node, {
|
||||||
expression: save(),
|
expression: save(),
|
||||||
property: make_node(AST_Number, node, {
|
property: make_node(AST_Number, node, {
|
||||||
@@ -642,7 +642,7 @@ merge(Compressor.prototype, {
|
|||||||
node.walk(scanner);
|
node.walk(scanner);
|
||||||
});
|
});
|
||||||
if (node.rest) {
|
if (node.rest) {
|
||||||
fixed = compressor.option("rests") && function() {
|
if (save) fixed = compressor.option("rests") && function() {
|
||||||
var value = save();
|
var value = save();
|
||||||
return value instanceof AST_Array ? make_node(AST_Array, node, {
|
return value instanceof AST_Array ? make_node(AST_Array, node, {
|
||||||
elements: value.elements.slice(node.elements.length),
|
elements: value.elements.slice(node.elements.length),
|
||||||
@@ -663,7 +663,7 @@ merge(Compressor.prototype, {
|
|||||||
node.key.walk(tw);
|
node.key.walk(tw);
|
||||||
pop(tw);
|
pop(tw);
|
||||||
}
|
}
|
||||||
fixed = function() {
|
if (save) fixed = function() {
|
||||||
var key = node.key;
|
var key = node.key;
|
||||||
var type = AST_Sub;
|
var type = AST_Sub;
|
||||||
if (typeof key == "string") {
|
if (typeof key == "string") {
|
||||||
@@ -736,25 +736,31 @@ merge(Compressor.prototype, {
|
|||||||
scan_declaration(tw, compressor, arg, function() {
|
scan_declaration(tw, compressor, arg, function() {
|
||||||
var j = fn.argnames.indexOf(arg);
|
var j = fn.argnames.indexOf(arg);
|
||||||
return (j < 0 ? value : iife.args[j]) || make_node(AST_Undefined, iife);
|
return (j < 0 ? value : iife.args[j]) || make_node(AST_Undefined, iife);
|
||||||
}, function(node, fixed) {
|
}, visit);
|
||||||
var d = node.definition();
|
|
||||||
if (fixed && safe && d.fixed === undefined) {
|
|
||||||
mark(tw, d);
|
|
||||||
tw.loop_ids[d.id] = tw.in_loop;
|
|
||||||
var value = iife.args[i];
|
|
||||||
d.fixed = fixed;
|
|
||||||
d.fixed.assigns = [ arg ];
|
|
||||||
} else {
|
|
||||||
d.fixed = false;
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
|
if (fn.rest) scan_declaration(tw, compressor, fn.rest, compressor.option("rests") && function() {
|
||||||
|
return make_node(AST_Array, fn, {
|
||||||
|
elements: iife.args.slice(fn.argnames.length),
|
||||||
});
|
});
|
||||||
|
}, visit);
|
||||||
walk_lambda(fn, tw);
|
walk_lambda(fn, tw);
|
||||||
var safe_ids = tw.safe_ids;
|
var safe_ids = tw.safe_ids;
|
||||||
pop(tw);
|
pop(tw);
|
||||||
walk_defuns(tw, fn);
|
walk_defuns(tw, fn);
|
||||||
if (!aborts) tw.safe_ids = safe_ids;
|
if (!aborts) tw.safe_ids = safe_ids;
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
|
function visit(node, fixed) {
|
||||||
|
var d = node.definition();
|
||||||
|
if (fixed && safe && d.fixed === undefined) {
|
||||||
|
mark(tw, d);
|
||||||
|
tw.loop_ids[d.id] = tw.in_loop;
|
||||||
|
d.fixed = fixed;
|
||||||
|
d.fixed.assigns = [ node ];
|
||||||
|
} else {
|
||||||
|
d.fixed = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
def(AST_Assign, function(tw, descend, compressor) {
|
def(AST_Assign, function(tw, descend, compressor) {
|
||||||
|
|||||||
@@ -846,3 +846,75 @@ issue_4556: {
|
|||||||
expect_stdout: "undefined"
|
expect_stdout: "undefined"
|
||||||
node_version: ">=6"
|
node_version: ">=6"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
issue_4560_1: {
|
||||||
|
options = {
|
||||||
|
evaluate: true,
|
||||||
|
reduce_vars: true,
|
||||||
|
toplevel: true,
|
||||||
|
}
|
||||||
|
input: {
|
||||||
|
var a = 0;
|
||||||
|
(function(...{
|
||||||
|
[a++]: {},
|
||||||
|
}) {})(2);
|
||||||
|
console.log(a);
|
||||||
|
}
|
||||||
|
expect: {
|
||||||
|
var a = 0;
|
||||||
|
(function(...{
|
||||||
|
[a++]: {},
|
||||||
|
}) {})(2);
|
||||||
|
console.log(a);
|
||||||
|
}
|
||||||
|
expect_stdout: "1"
|
||||||
|
node_version: ">=6"
|
||||||
|
}
|
||||||
|
|
||||||
|
issue_4560_2: {
|
||||||
|
options = {
|
||||||
|
reduce_vars: true,
|
||||||
|
toplevel: true,
|
||||||
|
unused: true,
|
||||||
|
}
|
||||||
|
input: {
|
||||||
|
var a = 0;
|
||||||
|
(function(...{
|
||||||
|
[a++]: {},
|
||||||
|
}) {})(2);
|
||||||
|
console.log(a);
|
||||||
|
}
|
||||||
|
expect: {
|
||||||
|
var a = 0;
|
||||||
|
(function(...{
|
||||||
|
[a++]: {},
|
||||||
|
}) {})(2);
|
||||||
|
console.log(a);
|
||||||
|
}
|
||||||
|
expect_stdout: "1"
|
||||||
|
node_version: ">=6"
|
||||||
|
}
|
||||||
|
|
||||||
|
issue_4560_3: {
|
||||||
|
options = {
|
||||||
|
collapse_vars: true,
|
||||||
|
reduce_vars: true,
|
||||||
|
toplevel: true,
|
||||||
|
}
|
||||||
|
input: {
|
||||||
|
var a = 0, b;
|
||||||
|
[ ...{
|
||||||
|
[a++]: b,
|
||||||
|
} ] = [ "PASS" ];
|
||||||
|
console.log(b);
|
||||||
|
}
|
||||||
|
expect: {
|
||||||
|
var a = 0, b;
|
||||||
|
[ ...{
|
||||||
|
[a++]: b,
|
||||||
|
} ] = [ "PASS" ];
|
||||||
|
console.log(b);
|
||||||
|
}
|
||||||
|
expect_stdout: "PASS"
|
||||||
|
node_version: ">=6"
|
||||||
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user