aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--lib/compress.js29
-rw-r--r--test/compress/collapse_vars.js167
2 files changed, 195 insertions, 1 deletions
diff --git a/lib/compress.js b/lib/compress.js
index 9b054ca3..85ad449e 100644
--- a/lib/compress.js
+++ b/lib/compress.js
@@ -1382,7 +1382,34 @@ merge(Compressor.prototype, {
}
function is_last_node(node, parent) {
- if (node instanceof AST_Call) return true;
+ if (node instanceof AST_Call) {
+ var fn = node.expression;
+ if (fn instanceof AST_SymbolRef) fn = fn.fixed_value();
+ if (!(fn instanceof AST_Lambda)) return true;
+ if (fn.collapse_scanning) return false;
+ fn.collapse_scanning = true;
+ var replace = can_replace;
+ can_replace = false;
+ var after = stop_after;
+ var if_hit = stop_if_hit;
+ 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.value) stat.value.transform(scanner);
+ break;
+ }
+ stat.transform(scanner);
+ }
+ scan_rhs = rhs_fn;
+ stop_if_hit = if_hit;
+ stop_after = after;
+ can_replace = replace;
+ delete fn.collapse_scanning;
+ if (!abort) return false;
+ abort = false;
+ return true;
+ }
if (node instanceof AST_Exit) {
if (in_try) {
if (in_try.bfinally) return true;
diff --git a/test/compress/collapse_vars.js b/test/compress/collapse_vars.js
index c3832d43..4cd59a4c 100644
--- a/test/compress/collapse_vars.js
+++ b/test/compress/collapse_vars.js
@@ -7491,3 +7491,170 @@ issue_3671: {
}
expect_stdout: "1"
}
+
+call_1: {
+ options = {
+ collapse_vars: true,
+ }
+ input: {
+ (function(a) {
+ a = console;
+ (function() {})();
+ a.log("PASS");
+ })();
+ }
+ expect: {
+ (function(a) {
+ (function() {})();
+ (a = console).log("PASS");
+ })();
+ }
+ expect_stdout: "PASS"
+}
+
+call_1_symbol: {
+ options = {
+ collapse_vars: true,
+ reduce_vars: true,
+ }
+ input: {
+ (function(a) {
+ function f() {}
+ a = console;
+ f();
+ a.log(typeof f);
+ })();
+ }
+ expect: {
+ (function(a) {
+ function f() {}
+ f();
+ (a = console).log(typeof f);
+ })();
+ }
+ expect_stdout: "function"
+}
+
+call_2: {
+ options = {
+ collapse_vars: true,
+ }
+ input: {
+ (function(a) {
+ a = console;
+ (function() {
+ return 42;
+ console.log("FAIL");
+ })();
+ a.log("PASS");
+ })();
+ }
+ expect: {
+ (function(a) {
+ (function() {
+ return 42;
+ console.log("FAIL");
+ })();
+ (a = console).log("PASS");
+ })();
+ }
+ expect_stdout: "PASS"
+}
+
+call_2_symbol: {
+ options = {
+ collapse_vars: true,
+ reduce_vars: true,
+ }
+ input: {
+ (function(a) {
+ function f() {
+ return 42;
+ console.log("FAIL");
+ }
+ a = console;
+ f();
+ a.log(typeof f);
+ })();
+ }
+ expect: {
+ (function(a) {
+ function f() {
+ return 42;
+ console.log("FAIL");
+ }
+ f();
+ (a = console).log(typeof f);
+ })();
+ }
+ expect_stdout: "function"
+}
+
+call_3: {
+ options = {
+ collapse_vars: true,
+ }
+ input: {
+ (function(a) {
+ a = console;
+ (function() {
+ a = {
+ log: function() {
+ console.log("PASS");
+ }
+ }
+ })();
+ a.log("FAIL");
+ })();
+ }
+ expect: {
+ (function(a) {
+ a = console;
+ (function() {
+ a = {
+ log: function() {
+ console.log("PASS");
+ }
+ }
+ })();
+ a.log("FAIL");
+ })();
+ }
+ expect_stdout: "PASS"
+}
+
+call_3_symbol: {
+ options = {
+ collapse_vars: true,
+ reduce_vars: true,
+ }
+ input: {
+ (function(a) {
+ function f() {
+ a = {
+ log: function() {
+ console.log(typeof f);
+ }
+ }
+ }
+ a = console;
+ f();
+ a.log("FAIL");
+ })();
+ }
+ expect: {
+ (function(a) {
+ function f() {
+ a = {
+ log: function() {
+ console.log(typeof f);
+ }
+ }
+ }
+ a = console;
+ f();
+ a.log("FAIL");
+ })();
+ }
+ expect_stdout: "function"
+}