@@ -7671,12 +7671,21 @@ merge(Compressor.prototype, {
|
||||
return expressions === this.expressions ? this : make_sequence(this, expressions);
|
||||
});
|
||||
def(AST_Sub, function(compressor, first_in_statement) {
|
||||
if (this.expression.may_throw_on_access(compressor)) return this;
|
||||
var expression = this.expression.drop_side_effect_free(compressor, first_in_statement);
|
||||
if (!expression) return this.property.drop_side_effect_free(compressor, first_in_statement);
|
||||
var property = this.property.drop_side_effect_free(compressor);
|
||||
if (!property) return expression;
|
||||
return make_sequence(this, [ expression, property ]);
|
||||
var expr = this.expression;
|
||||
var prop = this.property;
|
||||
if (expr.may_throw_on_access(compressor)) {
|
||||
if (!this.optional) return this;
|
||||
prop = prop.drop_side_effect_free(compressor);
|
||||
if (!prop) return expr.drop_side_effect_free(compressor, first_in_statement);
|
||||
var node = this.clone();
|
||||
node.property = prop;
|
||||
return node;
|
||||
}
|
||||
expr = expr.drop_side_effect_free(compressor, first_in_statement);
|
||||
if (!expr) return prop.drop_side_effect_free(compressor, first_in_statement);
|
||||
prop = prop.drop_side_effect_free(compressor);
|
||||
if (!prop) return expr;
|
||||
return make_sequence(this, [ expr, prop ]);
|
||||
});
|
||||
def(AST_SymbolRef, function(compressor) {
|
||||
return this.is_declared(compressor) && can_drop_symbol(this, compressor) ? null : this;
|
||||
|
||||
Reference in New Issue
Block a user