@@ -759,11 +759,13 @@ merge(Compressor.prototype, {
|
||||
node.walk(scanner);
|
||||
});
|
||||
if (node.rest) {
|
||||
var fixed_node;
|
||||
if (save) fixed = compressor.option("rests") && function() {
|
||||
var value = save();
|
||||
return value instanceof AST_Array ? make_node(AST_Array, node, {
|
||||
elements: value.elements.slice(node.elements.length),
|
||||
}) : node;
|
||||
if (!(value instanceof AST_Array)) return node;
|
||||
if (!fixed_node) fixed_node = make_node(AST_Array, node);
|
||||
fixed_node.elements = value.elements.slice(node.elements.length);
|
||||
return fixed_node;
|
||||
};
|
||||
node.rest.walk(scanner);
|
||||
}
|
||||
@@ -843,11 +845,12 @@ merge(Compressor.prototype, {
|
||||
return arg || make_node(AST_Undefined, iife);
|
||||
}, visit);
|
||||
});
|
||||
var rest = fn.rest;
|
||||
var rest = fn.rest, fixed_node;
|
||||
if (rest) scan_declaration(tw, compressor, rest, compressor.option("rests") && function() {
|
||||
return fn.rest === rest ? make_node(AST_Array, fn, {
|
||||
elements: iife.args.slice(fn.argnames.length),
|
||||
}) : rest;
|
||||
if (fn.rest !== rest) return rest;
|
||||
if (!fixed_node) fixed_node = make_node(AST_Array, fn);
|
||||
fixed_node.elements = iife.args.slice(fn.argnames.length);
|
||||
return fixed_node;
|
||||
}, visit);
|
||||
walk_lambda(fn, tw);
|
||||
var safe_ids = tw.safe_ids;
|
||||
|
||||
Reference in New Issue
Block a user