diff options
author | Mihai Bazon <mihai@bazon.net> | 2012-09-03 12:11:44 +0300 |
---|---|---|
committer | Mihai Bazon <mihai@bazon.net> | 2012-09-03 12:11:44 +0300 |
commit | 6d0db4ce14fd67681bdda1d1861517763eff4c6e (patch) | |
tree | eae00c1f5d5408888e9dfd3b61798b040f0d091a /lib/output.js | |
parent | d7c1dc6c0578b55eefc3bc94556146dce6e1a8cb (diff) | |
download | tracifyjs-6d0db4ce14fd67681bdda1d1861517763eff4c6e.tar.gz tracifyjs-6d0db4ce14fd67681bdda1d1861517763eff4c6e.zip |
an AST_If is too a StatementWithBody
Diffstat (limited to 'lib/output.js')
-rw-r--r-- | lib/output.js | 28 |
1 files changed, 16 insertions, 12 deletions
diff --git a/lib/output.js b/lib/output.js index 810a66a1..c321d46d 100644 --- a/lib/output.js +++ b/lib/output.js @@ -447,6 +447,10 @@ function OutputStream(options) { }); }; + AST_StatementWithBody.DEFMETHOD("_do_print_body", function(output){ + force_statement(this.body, output); + }); + DEFPRINT(AST_Statement, function(self, output){ self.body.print(output); output.semicolon(); @@ -476,7 +480,7 @@ function OutputStream(options) { DEFPRINT(AST_Do, function(self, output){ output.print("do"); output.space(); - force_statement(self.body, output); + self._do_print_body(output); output.space(); output.print("while"); output.space(); @@ -492,7 +496,7 @@ function OutputStream(options) { self.condition.print(output); }); output.space(); - force_statement(self.body, output); + self._do_print_body(output); }); DEFPRINT(AST_For, function(self, output){ output.print("for"); @@ -517,7 +521,7 @@ function OutputStream(options) { } }); output.space(); - force_statement(self.body, output); + self._do_print_body(output); }); DEFPRINT(AST_ForIn, function(self, output){ output.print("for"); @@ -530,7 +534,7 @@ function OutputStream(options) { self.object.print(output); }); output.space(); - force_statement(self.body, output); + self._do_print_body(output); }); DEFPRINT(AST_With, function(self, output){ output.print("with"); @@ -539,7 +543,7 @@ function OutputStream(options) { self.expression.print(output); }); output.space(); - force_statement(self.body, output); + self._do_print_body(output); }); /* -----[ functions ]----- */ @@ -606,22 +610,22 @@ function OutputStream(options) { // IF *without* an ELSE block (then the outer ELSE would refer // to the inner IF). This function checks for this case and // adds the block brackets if needed. - if (!self.consequent) + if (!self.body) return output.semicolon(); - if (self.consequent instanceof AST_Do + if (self.body instanceof AST_Do && output.option("ie_proof")) { // https://github.com/mishoo/UglifyJS/issues/#issue/57 IE // croaks with "syntax error" on code like this: if (foo) // do ... while(cond); else ... we need block brackets // around do/while - make_block(self.consequent, output); + make_block(self.body, output); return; } - var b = self.consequent; + var b = self.body; while (true) { if (b instanceof AST_If) { if (!b.alternative) { - make_block(self.consequent, output); + make_block(self.body, output); return; } b = b.alternative; @@ -631,7 +635,7 @@ function OutputStream(options) { } else break; } - self.consequent.print(output); + self.body.print(output); }; DEFPRINT(AST_If, function(self, output){ output.print("if"); @@ -647,7 +651,7 @@ function OutputStream(options) { output.space(); self.alternative.print(output); } else { - force_statement(self.consequent, output); + self._do_print_body(output); } }); |