aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAlex Lam S.L <alexlamsl@gmail.com>2020-12-25 11:27:05 +0000
committerGitHub <noreply@github.com>2020-12-25 19:27:05 +0800
commitf345175bc2aef3cb9d3ceb6ec241cf191dd70eb7 (patch)
tree58ef049e91359552f79934d394832c8be551086f
parentbb45f48ab74c25a108bb480ca5dd24f94599a35a (diff)
downloadtracifyjs-f345175bc2aef3cb9d3ceb6ec241cf191dd70eb7.tar.gz
tracifyjs-f345175bc2aef3cb9d3ceb6ec241cf191dd70eb7.zip
fix corner case in `merge_vars` (#4455)
fixes #4454
-rw-r--r--lib/compress.js2
-rw-r--r--test/compress/async.js56
2 files changed, 57 insertions, 1 deletions
diff --git a/lib/compress.js b/lib/compress.js
index 33aa5b91..0718e5c7 100644
--- a/lib/compress.js
+++ b/lib/compress.js
@@ -5187,7 +5187,7 @@ merge(Compressor.prototype, {
} else if ((ldef = self.variables.get(def.name)) !== def) {
if (ldef && root === segment) references[ldef.id] = false;
return references[def.id] = false;
- } else if (compressor.exposed(def) || sym.name == "arguments") {
+ } else if (compressor.exposed(def) || sym.name == "arguments" || sym.name == "await") {
return references[def.id] = false;
} else {
var refs = declarations.get(def.id) || [];
diff --git a/test/compress/async.js b/test/compress/async.js
index bf4d55c8..19b90f51 100644
--- a/test/compress/async.js
+++ b/test/compress/async.js
@@ -640,3 +640,59 @@ issue_4417: {
expect_stdout: "undefined"
node_version: ">=8"
}
+
+issue_4454_1: {
+ rename = false
+ options = {
+ merge_vars: true,
+ }
+ input: {
+ function f(a) {
+ (async function(b = console.log(a)) {})();
+ var await = 42..toString();
+ console.log(await);
+ }
+ f("PASS");
+ }
+ expect: {
+ function f(a) {
+ (async function(b = console.log(a)) {})();
+ var await = 42..toString();
+ console.log(await);
+ }
+ f("PASS");
+ }
+ expect_stdout: [
+ "PASS",
+ "42",
+ ]
+ node_version: ">=8"
+}
+
+issue_4454_2: {
+ rename = true
+ options = {
+ merge_vars: true,
+ }
+ input: {
+ function f(a) {
+ (async function(b = console.log(a)) {})();
+ var await = 42..toString();
+ console.log(await);
+ }
+ f("PASS");
+ }
+ expect: {
+ function f(b) {
+ (async function(c = console.log(b)) {})();
+ var b = 42..toString();
+ console.log(b);
+ }
+ f("PASS");
+ }
+ expect_stdout: [
+ "PASS",
+ "42",
+ ]
+ node_version: ">=8"
+}