aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--lib/compress.js9
-rw-r--r--test/compress/functions.js162
2 files changed, 171 insertions, 0 deletions
diff --git a/lib/compress.js b/lib/compress.js
index 79bf99b2..46a7816e 100644
--- a/lib/compress.js
+++ b/lib/compress.js
@@ -6444,6 +6444,15 @@ merge(Compressor.prototype, {
fixed = make_node(AST_Function, fixed, fixed);
fixed.name = make_node(AST_SymbolLambda, fixed.name, fixed.name);
}
+ if (fixed instanceof AST_Lambda) {
+ var scope = self.scope;
+ fixed.enclosed.forEach(function(def) {
+ if (fixed.variables.has(def.name)) return;
+ if (scope.var_names()[def.name]) return;
+ scope.enclosed.push(def);
+ scope.var_names()[def.name] = true;
+ });
+ }
var value;
if (def.recursive_refs > 0) {
value = fixed.clone(true);
diff --git a/test/compress/functions.js b/test/compress/functions.js
index 4f3139b1..8795afb1 100644
--- a/test/compress/functions.js
+++ b/test/compress/functions.js
@@ -3594,3 +3594,165 @@ inline_use_strict: {
}
expect_stdout: "foobar"
}
+
+pr_3595_1: {
+ options = {
+ collapse_vars: false,
+ inline: true,
+ reduce_funcs: true,
+ reduce_vars: true,
+ toplevel: true,
+ unused: true,
+ }
+ input: {
+ var g = [ "PASS" ];
+ function problem(arg) {
+ return g.indexOf(arg);
+ }
+ function unused(arg) {
+ return problem(arg);
+ }
+ function a(arg) {
+ return problem(arg);
+ }
+ function b(problem) {
+ return g[problem];
+ }
+ function c(arg) {
+ return b(a(arg));
+ }
+ console.log(c("PASS"));
+ }
+ expect: {
+ var g = [ "PASS" ];
+ function problem(arg) {
+ return g.indexOf(arg);
+ }
+ console.log((arg = "PASS", function(problem) {
+ return g[problem];
+ }(function(arg) {
+ return problem(arg);
+ }(arg))));
+ var arg;
+ }
+ expect_stdout: "PASS"
+}
+
+pr_3595_2: {
+ options = {
+ collapse_vars: true,
+ inline: true,
+ reduce_funcs: true,
+ reduce_vars: true,
+ toplevel: true,
+ unused: true,
+ }
+ input: {
+ var g = [ "PASS" ];
+ function problem(arg) {
+ return g.indexOf(arg);
+ }
+ function unused(arg) {
+ return problem(arg);
+ }
+ function a(arg) {
+ return problem(arg);
+ }
+ function b(problem) {
+ return g[problem];
+ }
+ function c(arg) {
+ return b(a(arg));
+ }
+ console.log(c("PASS"));
+ }
+ expect: {
+ var g = [ "PASS" ];
+ function problem(arg) {
+ return g.indexOf(arg);
+ }
+ console.log(function(problem) {
+ return g[problem];
+ }(function(arg) {
+ return problem(arg);
+ }("PASS")));
+ }
+ expect_stdout: "PASS"
+}
+
+pr_3595_3: {
+ options = {
+ collapse_vars: true,
+ inline: true,
+ passes: 2,
+ reduce_funcs: true,
+ reduce_vars: true,
+ toplevel: true,
+ unused: true,
+ }
+ input: {
+ var g = [ "PASS" ];
+ function problem(arg) {
+ return g.indexOf(arg);
+ }
+ function unused(arg) {
+ return problem(arg);
+ }
+ function a(arg) {
+ return problem(arg);
+ }
+ function b(problem) {
+ return g[problem];
+ }
+ function c(arg) {
+ return b(a(arg));
+ }
+ console.log(c("PASS"));
+ }
+ expect: {
+ var g = [ "PASS" ];
+ console.log(function(problem) {
+ return g[problem];
+ }(function(arg) {
+ return g.indexOf(arg);
+ }("PASS")));
+ }
+ expect_stdout: "PASS"
+}
+
+pr_3595_4: {
+ options = {
+ collapse_vars: true,
+ inline: true,
+ passes: 3,
+ reduce_funcs: true,
+ reduce_vars: true,
+ toplevel: true,
+ unused: true,
+ }
+ input: {
+ var g = [ "PASS" ];
+ function problem(arg) {
+ return g.indexOf(arg);
+ }
+ function unused(arg) {
+ return problem(arg);
+ }
+ function a(arg) {
+ return problem(arg);
+ }
+ function b(problem) {
+ return g[problem];
+ }
+ function c(arg) {
+ return b(a(arg));
+ }
+ console.log(c("PASS"));
+ }
+ expect: {
+ var g = [ "PASS" ];
+ console.log((problem = g.indexOf("PASS"), g[problem]));
+ var problem;
+ }
+ expect_stdout: "PASS"
+}