From 1529ab965a4a434e6024977a53f8460f6a474086 Mon Sep 17 00:00:00 2001 From: David Glasser Date: Wed, 16 Jan 2013 14:59:19 -0500 Subject: Fix output for arrays containing undefined values. 1b6bcca7 was a first attempt at this. That commit made Uglify stop replacing holes with undefined, but instead it started replacing undefined with holes. This is slightly problematic, because there is a difference between a hole and an undefined value. More problematically, it changed [1,undefined] to [1,] which generally doesn't even parse as a hole (just as a trailing comma), so it didn't even preserve the length of the array! Instead, parse holes as their own special AST node which prints invisibly. --- lib/ast.js | 5 +++++ lib/output.js | 6 ++++-- lib/parse.js | 2 +- test/compress/arrays.js | 12 ++++++++++++ 4 files changed, 22 insertions(+), 3 deletions(-) create mode 100644 test/compress/arrays.js diff --git a/lib/ast.js b/lib/ast.js index c0b263e7..62bdd8db 100644 --- a/lib/ast.js +++ b/lib/ast.js @@ -863,6 +863,11 @@ var AST_Undefined = DEFNODE("Undefined", null, { value: (function(){}()) }, AST_Atom); +var AST_Hole = DEFNODE("Hole", null, { + $documentation: "A hole in an array", + value: (function(){}()) +}, AST_Atom); + var AST_Infinity = DEFNODE("Infinity", null, { $documentation: "The `Infinity` value", value: 1/0 diff --git a/lib/output.js b/lib/output.js index 464a4593..5da27e7d 100644 --- a/lib/output.js +++ b/lib/output.js @@ -984,8 +984,7 @@ function OutputStream(options) { if (len > 0) output.space(); a.forEach(function(exp, i){ if (i) output.comma(); - if (!(exp instanceof AST_Undefined)) - exp.print(output); + exp.print(output); }); if (len > 0) output.space(); }); @@ -1036,6 +1035,9 @@ function OutputStream(options) { DEFPRINT(AST_Undefined, function(self, output){ output.print("void 0"); }); + DEFPRINT(AST_Hole, function(self, output){ + output.print(""); + }); DEFPRINT(AST_Infinity, function(self, output){ output.print("1/0"); }); diff --git a/lib/parse.js b/lib/parse.js index 5b6820ff..01fbb88f 100644 --- a/lib/parse.js +++ b/lib/parse.js @@ -1131,7 +1131,7 @@ function parse($TEXT, options) { if (first) first = false; else expect(","); if (allow_trailing_comma && is("punc", closing)) break; if (is("punc", ",") && allow_empty) { - a.push(new AST_Undefined({ start: S.token, end: S.token })); + a.push(new AST_Hole({ start: S.token, end: S.token })); } else { a.push(expression(false)); } diff --git a/test/compress/arrays.js b/test/compress/arrays.js new file mode 100644 index 00000000..10fe6eb5 --- /dev/null +++ b/test/compress/arrays.js @@ -0,0 +1,12 @@ +holes_and_undefined: { + input: { + x = [1, 2, undefined]; + y = [1, , 2, ]; + z = [1, undefined, 3]; + } + expect: { + x=[1,2,void 0]; + y=[1,,2]; + z=[1,void 0,3]; + } +} -- cgit v1.2.3