@@ -7861,11 +7861,13 @@ merge(Compressor.prototype, {
|
|||||||
var prop = this.property;
|
var prop = this.property;
|
||||||
if (expr.may_throw_on_access(compressor)) {
|
if (expr.may_throw_on_access(compressor)) {
|
||||||
if (!this.optional) return this;
|
if (!this.optional) return this;
|
||||||
prop = prop.drop_side_effect_free(compressor);
|
if (prop.has_side_effects(compressor)) {
|
||||||
if (!prop) return expr.drop_side_effect_free(compressor, first_in_statement);
|
prop = prop.drop_side_effect_free(compressor);
|
||||||
var node = this.clone();
|
if (!prop) return expr.drop_side_effect_free(compressor, first_in_statement);
|
||||||
node.property = prop;
|
var node = this.clone();
|
||||||
return node;
|
node.property = prop;
|
||||||
|
return node;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
expr = expr.drop_side_effect_free(compressor, first_in_statement);
|
expr = expr.drop_side_effect_free(compressor, first_in_statement);
|
||||||
if (!expr) return prop.drop_side_effect_free(compressor, first_in_statement);
|
if (!expr) return prop.drop_side_effect_free(compressor, first_in_statement);
|
||||||
|
|||||||
@@ -305,3 +305,25 @@ issue_4947_2: {
|
|||||||
expect_stdout: "PASS"
|
expect_stdout: "PASS"
|
||||||
node_version: ">=14"
|
node_version: ">=14"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
issue_5039: {
|
||||||
|
options = {
|
||||||
|
ie8: true,
|
||||||
|
side_effects: true,
|
||||||
|
toplevel: true,
|
||||||
|
unused: true,
|
||||||
|
}
|
||||||
|
input: {
|
||||||
|
var a = a?.[function f() {
|
||||||
|
f;
|
||||||
|
a;
|
||||||
|
}];
|
||||||
|
console.log("PASS");
|
||||||
|
}
|
||||||
|
expect: {
|
||||||
|
(function f() {});
|
||||||
|
console.log("PASS");
|
||||||
|
}
|
||||||
|
expect_stdout: "PASS"
|
||||||
|
node_version: ">=14"
|
||||||
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user