From: Mihai Bazon Date: Mon, 18 May 2015 10:56:04 +0000 (+0300) Subject: Fix compressing conditionals X-Git-Url: https://git.ndcode.org/public/gitweb.cgi?a=commitdiff_plain;h=a5b60217cede3f214153e62087d32274aa0859e5;p=UglifyJS.git Fix compressing conditionals Only transform foo() ? EXP(x) : EXP(y) into EXP(foo() ? x : y) if EXP has no side effects. Fix #710 --- diff --git a/lib/compress.js b/lib/compress.js index 944db1d2..530e7c2f 100644 --- a/lib/compress.js +++ b/lib/compress.js @@ -2356,6 +2356,7 @@ merge(Compressor.prototype, { if (consequent instanceof AST_Call && alternative.TYPE === consequent.TYPE && consequent.args.length == alternative.args.length + && !consequent.expression.has_side_effects(compressor) && consequent.expression.equivalent_to(alternative.expression)) { if (consequent.args.length == 0) { return make_node(AST_Seq, self, { diff --git a/test/compress/conditionals.js b/test/compress/conditionals.js index 299097be..1b961812 100644 --- a/test/compress/conditionals.js +++ b/test/compress/conditionals.js @@ -153,6 +153,7 @@ cond_1: { conditionals: true }; input: { + var do_something; // if undeclared it's assumed to have side-effects if (some_condition()) { do_something(x); } else { @@ -160,6 +161,7 @@ cond_1: { } } expect: { + var do_something; do_something(some_condition() ? x : y); } } @@ -169,7 +171,7 @@ cond_2: { conditionals: true }; input: { - var x; + var x, FooBar; if (some_condition()) { x = new FooBar(1); } else { @@ -177,7 +179,7 @@ cond_2: { } } expect: { - var x; + var x, FooBar; x = new FooBar(some_condition() ? 1 : 2); } } @@ -187,6 +189,7 @@ cond_3: { conditionals: true }; input: { + var FooBar; if (some_condition()) { new FooBar(1); } else { @@ -194,6 +197,7 @@ cond_3: { } } expect: { + var FooBar; some_condition() ? new FooBar(1) : FooBar(2); } } @@ -203,6 +207,7 @@ cond_4: { conditionals: true }; input: { + var do_something; if (some_condition()) { do_something(); } else { @@ -210,6 +215,7 @@ cond_4: { } } expect: { + var do_something; some_condition(), do_something(); } }