aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--lib/compress.js6
-rw-r--r--test/compress/if_return.js21
2 files changed, 25 insertions, 2 deletions
diff --git a/lib/compress.js b/lib/compress.js
index fcbbffb3..4f942429 100644
--- a/lib/compress.js
+++ b/lib/compress.js
@@ -2027,8 +2027,10 @@ merge(Compressor.prototype, {
function handle_if_return(statements, compressor) {
var self = compressor.self();
- var multiple_if_returns = has_multiple_if_returns(statements);
+ var parent = compressor.parent();
var in_lambda = self instanceof AST_Lambda;
+ var in_iife = in_lambda && parent && parent.TYPE == "Call";
+ var multiple_if_returns = has_multiple_if_returns(statements);
for (var i = statements.length; --i >= 0;) {
var stat = statements[i];
var j = next_index(i);
@@ -2156,7 +2158,7 @@ merge(Compressor.prototype, {
// the example code.
var prev = statements[prev_index(i)];
if (compressor.option("sequences") && in_lambda && !stat.alternative
- && prev instanceof AST_If && prev.body instanceof AST_Return
+ && (!prev && in_iife || prev instanceof AST_If && prev.body instanceof AST_Return)
&& next_index(j) == statements.length && next instanceof AST_SimpleStatement) {
CHANGED = true;
stat = stat.clone();
diff --git a/test/compress/if_return.js b/test/compress/if_return.js
index 82df1cea..836fab17 100644
--- a/test/compress/if_return.js
+++ b/test/compress/if_return.js
@@ -573,3 +573,24 @@ issue_3600: {
}
expect_stdout: "1"
}
+
+iife_if_return_simple: {
+ options = {
+ conditionals: true,
+ if_return: true,
+ inline: true,
+ sequences: true,
+ side_effects: true,
+ }
+ input: {
+ (function() {
+ if (console)
+ return console.log("PASS");
+ console.log("FAIL");
+ })();
+ }
+ expect: {
+ console ? console.log("PASS") : console.log("FAIL");
+ }
+ expect_stdout: "PASS"
+}