fix corner case in merge_vars (#4151)
This commit is contained in:
@@ -4331,7 +4331,7 @@ merge(Compressor.prototype, {
|
||||
|
||||
AST_Scope.DEFMETHOD("merge_variables", function(compressor) {
|
||||
if (!compressor.option("merge_vars")) return;
|
||||
var self = this, segment = {};
|
||||
var self = this, segment = {}, root;
|
||||
var first = [], last = [], index = 0;
|
||||
var declarations = new Dictionary();
|
||||
var references = Object.create(null);
|
||||
@@ -4414,10 +4414,8 @@ merge(Compressor.prototype, {
|
||||
if (node instanceof AST_Scope) {
|
||||
push();
|
||||
segment.block = node;
|
||||
if (node instanceof AST_Lambda && node.name) {
|
||||
if (node !== self) segment.loop = true;
|
||||
references[node.name.definition().id] = false;
|
||||
}
|
||||
if (node === self) root = segment;
|
||||
if (node instanceof AST_Lambda && node.name) references[node.name.definition().id] = false;
|
||||
descend();
|
||||
pop();
|
||||
return true;
|
||||
@@ -4563,7 +4561,8 @@ merge(Compressor.prototype, {
|
||||
definition: def,
|
||||
});
|
||||
}
|
||||
refs.start = self;
|
||||
if (segment.block !== self) return references[def.id] = false;
|
||||
refs.start = root;
|
||||
}
|
||||
prev[def.id] = last.length;
|
||||
last.push({
|
||||
|
||||
Reference in New Issue
Block a user