aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAlex Lam S.L <alexlamsl@gmail.com>2020-07-01 04:33:48 +0100
committerGitHub <noreply@github.com>2020-07-01 11:33:48 +0800
commit484d3fd8c77d8d144c97b312cc2be17586fce995 (patch)
treec94ade7131d4a60f62e7909e5abdb27655b6cc3c
parent3bf8699f951c32a93414d1ac4c72364e2e282b33 (diff)
downloadtracifyjs-484d3fd8c77d8d144c97b312cc2be17586fce995.tar.gz
tracifyjs-484d3fd8c77d8d144c97b312cc2be17586fce995.zip
fix corner case in `side_effects` (#4009)
fixes #4008
-rw-r--r--lib/compress.js10
-rw-r--r--test/compress/side_effects.js66
2 files changed, 67 insertions, 9 deletions
diff --git a/lib/compress.js b/lib/compress.js
index 10a84c6b..2c8c7769 100644
--- a/lib/compress.js
+++ b/lib/compress.js
@@ -5303,10 +5303,7 @@ merge(Compressor.prototype, {
return make_sequence(this, [ expression, property ]);
});
def(AST_SymbolRef, function(compressor) {
- if (!this.is_declared(compressor)) return this;
- var def = this.definition();
- if (member(this, def.references)) def.replaced++;
- return null;
+ return this.is_declared(compressor) ? null : this;
});
def(AST_This, return_null);
def(AST_Unary, function(compressor, first_in_statement) {
@@ -5314,10 +5311,7 @@ merge(Compressor.prototype, {
this.write_only = !this.expression.has_side_effects(compressor);
return this;
}
- if (this.operator == "typeof" && this.expression instanceof AST_SymbolRef) {
- this.expression.definition().replaced++;
- return null;
- }
+ if (this.operator == "typeof" && this.expression instanceof AST_SymbolRef) return null;
var expression = this.expression.drop_side_effect_free(compressor, first_in_statement);
if (first_in_statement && expression && is_iife_call(expression)) {
if (expression === this.expression && this.operator == "!") return this;
diff --git a/test/compress/side_effects.js b/test/compress/side_effects.js
index 412a38cb..244e3881 100644
--- a/test/compress/side_effects.js
+++ b/test/compress/side_effects.js
@@ -298,7 +298,7 @@ operator_in: {
expect_stdout: "PASS"
}
-issue_3983: {
+issue_3983_1: {
options = {
collapse_vars: true,
conditionals: true,
@@ -323,7 +323,71 @@ issue_3983: {
}
expect: {
var a = "PASS";
+ g();
+ function g() {}
console.log(a);
}
expect_stdout: "PASS"
}
+
+issue_3983_2: {
+ options = {
+ collapse_vars: true,
+ conditionals: true,
+ evaluate: true,
+ inline: true,
+ passes: 2,
+ reduce_vars: true,
+ side_effects: true,
+ toplevel: true,
+ unused: true,
+ }
+ input: {
+ var a = "PASS";
+ function f() {
+ g && g();
+ }
+ f();
+ function g() {
+ 0 ? a : 0;
+ }
+ var b = a;
+ console.log(a);
+ }
+ expect: {
+ console.log("PASS");
+ }
+ expect_stdout: "PASS"
+}
+
+issue_4008: {
+ options = {
+ collapse_vars: true,
+ evaluate: true,
+ inline: true,
+ pure_getters: "strict",
+ reduce_vars: true,
+ side_effects: true,
+ toplevel: true,
+ }
+ input: {
+ var a = "PASS";
+ function f(b, b) {
+ console.log(b);
+ }
+ f && f(a && a[a]);
+ console.log(a);
+ }
+ expect: {
+ var a = "PASS";
+ function f(b, b) {
+ console.log(b);
+ }
+ f(a[a]);
+ console.log(a);
+ }
+ expect_stdout: [
+ "undefined",
+ "PASS",
+ ]
+}