avoid suboptimal termination in passes (#2787)
This commit is contained in:
@@ -171,7 +171,8 @@ merge(Compressor.prototype, {
|
|||||||
node.process_expression(true);
|
node.process_expression(true);
|
||||||
}
|
}
|
||||||
var passes = +this.options.passes || 1;
|
var passes = +this.options.passes || 1;
|
||||||
var last_count = 1 / 0;
|
var min_count = 1 / 0;
|
||||||
|
var stopping = false;
|
||||||
var mangle = { ie8: this.option("ie8") };
|
var mangle = { ie8: this.option("ie8") };
|
||||||
for (var pass = 0; pass < passes; pass++) {
|
for (var pass = 0; pass < passes; pass++) {
|
||||||
node.figure_out_scope(mangle);
|
node.figure_out_scope(mangle);
|
||||||
@@ -183,9 +184,15 @@ merge(Compressor.prototype, {
|
|||||||
node.walk(new TreeWalker(function() {
|
node.walk(new TreeWalker(function() {
|
||||||
count++;
|
count++;
|
||||||
}));
|
}));
|
||||||
this.info("pass " + pass + ": last_count: " + last_count + ", count: " + count);
|
this.info("pass " + pass + ": last_count: " + min_count + ", count: " + count);
|
||||||
if (count >= last_count) break;
|
if (count < min_count) {
|
||||||
last_count = count;
|
min_count = count;
|
||||||
|
stopping = false;
|
||||||
|
} else if (stopping) {
|
||||||
|
break;
|
||||||
|
} else {
|
||||||
|
stopping = true;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (this.option("expression")) {
|
if (this.option("expression")) {
|
||||||
|
|||||||
Reference in New Issue
Block a user