@@ -759,11 +759,13 @@ merge(Compressor.prototype, {
|
|||||||
node.walk(scanner);
|
node.walk(scanner);
|
||||||
});
|
});
|
||||||
if (node.rest) {
|
if (node.rest) {
|
||||||
|
var fixed_node;
|
||||||
if (save) 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, {
|
if (!(value instanceof AST_Array)) return node;
|
||||||
elements: value.elements.slice(node.elements.length),
|
if (!fixed_node) fixed_node = make_node(AST_Array, node);
|
||||||
}) : node;
|
fixed_node.elements = value.elements.slice(node.elements.length);
|
||||||
|
return fixed_node;
|
||||||
};
|
};
|
||||||
node.rest.walk(scanner);
|
node.rest.walk(scanner);
|
||||||
}
|
}
|
||||||
@@ -843,11 +845,12 @@ merge(Compressor.prototype, {
|
|||||||
return arg || make_node(AST_Undefined, iife);
|
return arg || make_node(AST_Undefined, iife);
|
||||||
}, visit);
|
}, visit);
|
||||||
});
|
});
|
||||||
var rest = fn.rest;
|
var rest = fn.rest, fixed_node;
|
||||||
if (rest) scan_declaration(tw, compressor, rest, compressor.option("rests") && function() {
|
if (rest) scan_declaration(tw, compressor, rest, compressor.option("rests") && function() {
|
||||||
return fn.rest === rest ? make_node(AST_Array, fn, {
|
if (fn.rest !== rest) return rest;
|
||||||
elements: iife.args.slice(fn.argnames.length),
|
if (!fixed_node) fixed_node = make_node(AST_Array, fn);
|
||||||
}) : rest;
|
fixed_node.elements = iife.args.slice(fn.argnames.length);
|
||||||
|
return fixed_node;
|
||||||
}, visit);
|
}, visit);
|
||||||
walk_lambda(fn, tw);
|
walk_lambda(fn, tw);
|
||||||
var safe_ids = tw.safe_ids;
|
var safe_ids = tw.safe_ids;
|
||||||
|
|||||||
@@ -1151,3 +1151,57 @@ issue_5128_2: {
|
|||||||
expect_stdout: "PASS"
|
expect_stdout: "PASS"
|
||||||
node_version: ">=6"
|
node_version: ">=6"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
issue_5165_1: {
|
||||||
|
options = {
|
||||||
|
conditionals: true,
|
||||||
|
dead_code: true,
|
||||||
|
evaluate: true,
|
||||||
|
reduce_vars: true,
|
||||||
|
rests: true,
|
||||||
|
side_effects: true,
|
||||||
|
switches: true,
|
||||||
|
unsafe: true,
|
||||||
|
}
|
||||||
|
input: {
|
||||||
|
console.log(function([ ...a ]) {
|
||||||
|
switch (a) {
|
||||||
|
case a:
|
||||||
|
return "PASS";
|
||||||
|
}
|
||||||
|
}([]));
|
||||||
|
}
|
||||||
|
expect: {
|
||||||
|
console.log(function([ ...a ]) {
|
||||||
|
return "PASS";
|
||||||
|
}([]));
|
||||||
|
}
|
||||||
|
expect_stdout: "PASS"
|
||||||
|
node_version: ">=6"
|
||||||
|
}
|
||||||
|
|
||||||
|
issue_5165_2: {
|
||||||
|
options = {
|
||||||
|
conditionals: true,
|
||||||
|
dead_code: true,
|
||||||
|
evaluate: true,
|
||||||
|
reduce_vars: true,
|
||||||
|
rests: true,
|
||||||
|
side_effects: true,
|
||||||
|
switches: true,
|
||||||
|
unsafe: true,
|
||||||
|
}
|
||||||
|
input: {
|
||||||
|
console.log(function(...a) {
|
||||||
|
switch (a) {
|
||||||
|
case a:
|
||||||
|
return "PASS";
|
||||||
|
}
|
||||||
|
}());
|
||||||
|
}
|
||||||
|
expect: {
|
||||||
|
console.log("PASS");
|
||||||
|
}
|
||||||
|
expect_stdout: "PASS"
|
||||||
|
node_version: ">=6"
|
||||||
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user