4 * pack a javascript file, and return a shorter version!
6 * a bit picky at present with ; and crlf reading...
7 * @arg ts {TokenStream}
12 public errordomain CompressWhiteError {
16 public string CompressWhite (TokenStream ts, Packer packer, bool keepWhite) // throws CompressWhiteError,TokenStreamError
18 //keepWhite = keepWhite || false;
20 //var str = File.read(fn);
30 if (tok.type == "WHIT") {
36 // just spaces, not \n!
37 //if (tok.data.indexOf("\n") < 0) {
43 if (tok.data == "}") {
45 if (ts.lookTok(0).type == "NAME" && ts.look(1,true).name == "NEWLINE") {
46 ts.look(0,true).outData = ts.look(0,true).data+"\n";
52 // add semi-colon's where linebreaks are used... - not foolproof yet.!
53 if (tok.type == "NAME") {
54 //var tokident = ts.look(-1).data + tok.data + ts.look(1).data + ts.look(2).data;
55 // a = new function() {}
56 if (ts.lookTok(1).data == "=" && ts.lookTok(2).name == "NEW" &&
57 ts.lookTok(3).name == "FUNCTION") {
65 // if next is not ';' -> make it so...
67 if (ts.lookTok(1).data != ";" && ts.lookTok(1).data != "}" && ts.lookTok(1).name == "NEWLINE") {
68 ts.look(0,true).outData = ts.lookTok(0).data +";";
74 // a = function() { ... -- add a semi colon a tthe end if not one there..
76 if (ts.lookTok(1).data == "=" && ts.lookTok(2).name == "FUNCTION") {
78 //println("got = function() ");
84 ts.cursor+=2; // move two along, and balance...
86 if (tok.data != "(" || ts.balance("(").size < 1 ){
88 print("balance ( issue on line %d\n", ts.toArray().get(cu).line);
90 print(">>>>>>>>>>>>>>>>>HERE>>>>>>>>>>>>");
93 throw new CompressWhiteError.BRACE( "could not find end lbrace!!!" );
95 //print("AFTER BALANCE (");
96 //ts.dump(cu, ts.cursor);
97 //ts.cursor--; // cursor at the (
98 if (ts.balance("{").size < 1 ){
101 print(">>>>>>>>>>>>>>>>>HERE>>>>>>>>>>>>");
104 throw new CompressWhiteError.BRACE( "could not find end lbrace!!!");
106 //print('FN: '+ts.tokens[cu].toString());
107 //print('F1: '+ts.lookTok(1).toString());
108 //print('F2: '+ts.look(1,true).toString());
110 // if next is not ';' -> make it so...
111 // although this var a=function(){},v,c; causes
112 if (ts.lookTok(1).data != ";" && ts.lookTok(1).data != "}" && ts.look(1,true).name == "NEWLINE") {
114 ts.look(0,true).outData = ts.look(0,true).data+";";
115 // print("ADDING SEMI: " + ts.look(0).toString());
116 //ts.dump(cu, ts.cursor+2);
119 //ts.dump(cu, ts.cursor+2);
124 // next item is a name..
125 if ((ts.lookTok(1).type == "NAME" || ts.lookTok(1).type == "KEYW" ) && ts.look(1,true).name == "NEWLINE") {
126 // preserve linebraek
127 ts.look(0,true).outData = ts.look(0,true).data+"\n";
129 // method call followed by name..
130 if (ts.lookTok(1).data == "(") {
134 // although this var a=function(){},v,c; causes
136 if (ts.lookTok(1).type == "NAME" && ts.look(1,true).name == "NEWLINE") {
138 ts.look(0,true).outData = ts.look(0,true).data+"\n";
146 // function a () { ... };
148 if (ts.look(-1).isTypeN(Script.TOKfunction) && ts.look(1).isTypeN(Script.TOKlparen)) {
150 //println("got = function() ");
153 ts.balance("lparen");
154 ts.balance("lbrace");
155 // if next is not ';' -> make it so...
156 // although this var a=function(){},v,c; causes
157 if (!ts.look(1).isData(';') && !ts.look(1).isData('}') && ts.look(1,true).isLineBreak()) {
158 ts.cur().outData = ts.cur().data+";";
168 if (ts.lookTok(1).data == "=" && ts.lookTok(2).data == "{") {
170 //println("----------*** 3 *** --------------");
173 if (ts.balance("{").size < 1 ){
176 print(">>>>>>>>>>>>>>>>>HERE>>>>>>>>>>>>");
179 throw new CompressWhiteError.BRACE("could not find end lbrace!!!");
181 // if next is not ';' -> make it so...
183 if (ts.lookTok(1).data != ";" && ts.lookTok(1).data != "}" && ts.look(1,true).name=="NEWLINE") {
184 ts.look(0,true).outData = ts.look(0,true).data +";";
192 // a = function(....) { }
199 //println("got Token: " + tok.type);
203 switch(tok.data.up()) {
204 // things that need space appending
208 // if next item is a identifier..
209 if (ts.lookTok(1).type == "NAME" || Regex.match_simple("^[a-z]+$", ts.lookTok(1).data, GLib.RegexCompileFlags.CASELESS) ) { // as include is a keyword for us!!
210 tok.outData = tok.data + " ";
215 case "RETURN": // if next item is not a semi; (or }
216 if (ts.lookTok(1).data == ";" || ts.lookTok(1).data == "}") {
219 tok.outData = tok.data + " ";
224 case "ELSE": // if next item is not a semi; (or }
225 if (ts.lookTok(1).name != "IF") {
228 // add a space if next element is 'IF'
229 tok.outData = tok.data + " ";
232 case "++": // if previous was a plus or next is a + add a space..
233 case "--": // if previous was a - or next is a - add a space..
235 var p = (tok.data == "--" ? "-" : "+");
237 if (ts.lookTok(1).data == p) {
238 tok.outData = tok.data + " ";
240 if (ts.lookTok(-1).data == p) {
241 tok.outData = " " + tok.data;
246 case "IN": // before and after??
249 tok.outData = " " + tok.data + " ";
252 case "VAR": // always after..
259 tok.outData = tok.data + " ";
263 case "TYPEOF": // what about typeof(
264 if (ts.lookTok(1).data != "(") {
265 tok.outData = tok.data + " ";
269 //remove semicolon before brace --
270 //if(ts.look(1).isTypeN(Script.TOKrbrace)) {
282 // NOW OUTPUT THE THING.
283 //var f = new File(minfile, File.NEW);
287 //try { out.length = ts.slen; } catch (e) {} // prealloc.
293 tok = keepWhite ? ts.next() : ts.nextTok();
298 if (tok.type == "COMM") {
302 ///print(tok.type + ':' + tok.data);
304 if (tok.type == "NAME" &&
305 tok.identifier != null &&
306 tok.identifier.mungedValue.length > 0) {
307 //f.write(tok.identifier.mungedValue);
308 //print("MUNGED: " + tok.identifier.mungedValue);
309 outstr += tok.identifier.mungedValue;
313 // at this point we can apply a text translation kit...
315 //if ((tok.type == "STRN") && (tok.name== "DOUBLE_QUOTE")) {
316 // if (packer && packer.stringHandler) {
317 // outstr += packer.stringHandler(tok);
322 outstr += tok.outData != "" ? tok.outData : tok.data;
324 if ((tok.outData == ";") && (outstr.length - outoff > 255)) {
325 outoff = outstr.length;
331 // remove the last ';' !!!
332 if (out.substring(out.length-1) == ';') {
333 return out.substring(0,out.length-1);