aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAlex Lam S.L <alexlamsl@gmail.com>2020-01-30 09:04:44 +0800
committerGitHub <noreply@github.com>2020-01-30 09:04:44 +0800
commit79c60032a55b518e07acb45237e527b4fe61c8e6 (patch)
tree75ee56238ebb10f04ebc2c512a903252c11f4977
parenta3754068dde7a51ab41b59a6d8a17a3a8c022564 (diff)
downloadtracifyjs-79c60032a55b518e07acb45237e527b4fe61c8e6.tar.gz
tracifyjs-79c60032a55b518e07acb45237e527b4fe61c8e6.zip
fix corner case in `collapse_vars` (#3701)
fixes #3700
-rw-r--r--lib/compress.js2
-rw-r--r--test/compress/collapse_vars.js31
2 files changed, 32 insertions, 1 deletions
diff --git a/lib/compress.js b/lib/compress.js
index e6a064dd..5d14963f 100644
--- a/lib/compress.js
+++ b/lib/compress.js
@@ -1395,7 +1395,7 @@ merge(Compressor.prototype, {
var rhs_fn = scan_rhs;
for (var i = 0; !abort && i < fn.body.length; i++) {
var stat = fn.body[i];
- if (stat instanceof AST_Exit) {
+ if (stat instanceof AST_Return) {
if (stat.value) stat.value.transform(scanner);
break;
}
diff --git a/test/compress/collapse_vars.js b/test/compress/collapse_vars.js
index f109e93e..58ae5c62 100644
--- a/test/compress/collapse_vars.js
+++ b/test/compress/collapse_vars.js
@@ -7734,3 +7734,34 @@ issue_3698_3: {
}
expect_stdout: "2"
}
+
+issue_3700: {
+ options = {
+ collapse_vars: true,
+ }
+ input: {
+ var a = "FAIL";
+ try {
+ a = "PASS";
+ (function() {
+ throw 0;
+ })();
+ a = 1 + a;
+ } catch (e) {
+ }
+ console.log(a);
+ }
+ expect: {
+ var a = "FAIL";
+ try {
+ a = "PASS";
+ (function() {
+ throw 0;
+ })();
+ a = 1 + a;
+ } catch (e) {
+ }
+ console.log(a);
+ }
+ expect_stdout: "PASS"
+}