From 3dd495ecdd231a6b245ab002f61805b21114924b Mon Sep 17 00:00:00 2001 From: "Alex Lam S.L" Date: Thu, 7 Dec 2017 01:01:52 +0800 Subject: [PATCH] improve `if_return` (#2558) `return void x()` => `x()` --- lib/compress.js | 30 +++++++++++++++++++++++------- test/compress/return_undefined.js | 22 ++++++++++++++++++++++ 2 files changed, 45 insertions(+), 7 deletions(-) diff --git a/lib/compress.js b/lib/compress.js index 914fdd06..3f0414e2 100644 --- a/lib/compress.js +++ b/lib/compress.js @@ -1211,10 +1211,19 @@ merge(Compressor.prototype, { var stat = statements[i]; var next = statements[i + 1]; - if (in_lambda && stat instanceof AST_Return && !stat.value && !next) { - CHANGED = true; - statements.length--; - continue; + if (in_lambda && !next && stat instanceof AST_Return) { + if (!stat.value) { + CHANGED = true; + statements.length--; + continue; + } + if (stat.value instanceof AST_UnaryPrefix && stat.value.operator == "void") { + CHANGED = true; + statements[i] = make_node(AST_SimpleStatement, stat, { + body: stat.value.expression + }); + continue; + } } if (stat instanceof AST_If) { @@ -1301,9 +1310,16 @@ merge(Compressor.prototype, { && prev instanceof AST_If && prev.body instanceof AST_Return && i + 2 == statements.length && next instanceof AST_SimpleStatement) { CHANGED = true; - statements.push(make_node(AST_Return, next, { - value: null - }).transform(compressor)); + stat = stat.clone(); + stat.alternative = make_node(AST_BlockStatement, next, { + body: [ + next, + make_node(AST_Return, next, { + value: null + }) + ] + }); + statements.splice(i, 2, stat.transform(compressor)); continue; } } diff --git a/test/compress/return_undefined.js b/test/compress/return_undefined.js index 9662aa51..4d2b4257 100644 --- a/test/compress/return_undefined.js +++ b/test/compress/return_undefined.js @@ -122,3 +122,25 @@ return_undefined: { } } } + +return_void: { + options = { + if_return: true, + inline: true, + reduce_vars: true, + unused: true, + } + input: { + function f() { + function g() { + h(); + } + return g(); + } + } + expect: { + function f() { + h(); + } + } +} -- 2.34.1