X-Git-Url: http://git.roojs.org/?p=gnome.introspection-doc-generator;a=blobdiff_plain;f=JSDOC%2FCompressWhite.js;h=13d6df7d2ffb93c497dcbad5cc57e86ee2abeac4;hp=42f1ee27594e3001e5da7ba5ff2bccadebb8f00b;hb=6534df3589197eabe11704e9f7a18cff965898f2;hpb=ef17767fc104a36dc84e37c31fc6bf85c0e6636f diff --git a/JSDOC/CompressWhite.js b/JSDOC/CompressWhite.js index 42f1ee2..13d6df7 100644 --- a/JSDOC/CompressWhite.js +++ b/JSDOC/CompressWhite.js @@ -8,9 +8,9 @@ @arg packer {Packer} */ -CompressWhite = function (ts, packer) +CompressWhite = function (ts, packer, keepWhite) { - + keepWhite = keepWhite || false; ts.rewind(); //var str = File.read(fn); var rep_var = 1; @@ -21,6 +21,7 @@ CompressWhite = function (ts, packer) break; } if (tok.type == "WHIT") { + continue; //if (tok._isDoc) { // continue; @@ -32,7 +33,16 @@ CompressWhite = function (ts, packer) } - + if (tok.data == "}") { + + if (ts.lookTok(1).type == 'NAME' && ts.look(1,true).name == "NEWLINE") { + + ts.look(0).outData = ts.look(0).data+"\n"; + } + // restore.. + + continue; + } // add semi-colon's where linebreaks are used... - not foolproof yet.! if (tok.type == "NAME") { //var tokident = ts.look(-1).data + tok.data + ts.look(1).data + ts.look(2).data; @@ -48,7 +58,7 @@ CompressWhite = function (ts, packer) ts.balance("{"); // if next is not ';' -> make it so... - if (ts.lookTok(1).data != ';' && ts.lookTok(1).data != '}' && ts.lookTok(1,true).name = ="NEWLINE") { + if (ts.lookTok(1).data != ';' && ts.lookTok(1).data != '}' && ts.lookTok(1,true).name == "NEWLINE") { ts.look(0).outData = ts.cur().data +";"; } // restore.. @@ -62,17 +72,63 @@ CompressWhite = function (ts, packer) //println("got = function() "); var cu = ts.cursor; - ts.balance("("); - ts.balance("{"); + if (!ts.balance("(") ){ + ts.dump(cu-40, cu); + print(">>>>>>>>>>>>>>>>>HERE>>>>>>>>>>>>"); + ts.dump(cu, cu+40); + + throw "could not find end lbrace!!!"; + } + //print("AFTER BALANCE ("); + //ts.dump(cu, ts.cursor); + //ts.cursor--; // cursor at the ( + if (!ts.balance("{") ){ + ts.dump(cu-40, cu); + print(">>>>>>>>>>>>>>>>>HERE>>>>>>>>>>>>"); + ts.dump(cu, cu+40); + + throw "could not find end lbrace!!!"; + } + //print('FN: '+ts.tokens[cu].toString()); + //print('F1: '+ts.lookTok(1).toString()); + //print('F2: '+ts.look(1,true).toString()); + // if next is not ';' -> make it so... // although this var a=function(){},v,c; causes - if (!ts.lookTok(1).isData(';') && !ts.lookTok(1).isData('}') && ts.lookTok(1,true).isLineBreak()) { - ts.cur().outData = ts.look(0).data+";"; + if (ts.lookTok(1).data != ';' && ts.lookTok(1).data != '}' && ts.look(1,true).name == "NEWLINE") { + + ts.look(0).outData = ts.look(0).data+";"; + // print("ADDING SEMI: " + ts.look(0).toString()); + //ts.dump(cu, ts.cursor+2); + } + + //ts.dump(cu, ts.cursor+2); + // restore.. + ts.cursor = cu; + continue; + } + // next item is a name.. + if ((ts.lookTok(1).type == 'NAME' || ts.lookTok(1).type == 'KEYW' ) && ts.look(1,true).name == "NEWLINE") { + // preserve linebraek + ts.look(0).outData = ts.look(0).data+"\n"; + } + // method call followed by name.. + if (ts.lookTok(1).data == "(") { + var cu = ts.cursor; + + ts.balance("("); + // although this var a=function(){},v,c; causes + + if (ts.lookTok(1).type == 'NAME' && ts.look(1,true).name == "NEWLINE") { + + ts.look(0).outData = ts.look(0).data+"\n"; } // restore.. ts.cursor = cu; continue; } + + // function a () { ... }; /* if (ts.look(-1).isTypeN(Script.TOKfunction) && ts.look(1).isTypeN(Script.TOKlparen)) { @@ -95,17 +151,21 @@ CompressWhite = function (ts, packer) // a = { .... - if (ts.look(1).data == '=' && ts.look(2).data == '{')) { + if (ts.lookTok(1).data == '=' && ts.lookTok(2).data == '{') { // freeze time.. //println("----------*** 3 *** --------------"); var cu = ts.cursor; if (!ts.balance("{") ){ + ts.dump(cu-40, cu); + print(">>>>>>>>>>>>>>>>>HERE>>>>>>>>>>>>"); + ts.dump(cu, cu+40); + throw "could not find end lbrace!!!"; } // if next is not ';' -> make it so... - - if (!ts.look(1).data == ';' && ts.look(1).data != '}' && ts.look(1,true).name=="NEWLINE") { + + if (ts.lookTok(1).data != ';' && ts.lookTok(1).data != '}' && ts.look(1,true).name=="NEWLINE") { ts.look(0).outData = ts.look(0).data +";"; } // restore.. @@ -114,6 +174,8 @@ CompressWhite = function (ts, packer) } // any more?? + // a = function(....) { } + } @@ -188,7 +250,7 @@ CompressWhite = function (ts, packer) tok.outData = tok.data + " "; } continue; - case ";" + case ";": //remove semicolon before brace -- //if(ts.look(1).isTypeN(Script.TOKrbrace)) { // tok.outData = ''; @@ -209,14 +271,19 @@ CompressWhite = function (ts, packer) var outoff = 0; out.length = ts.slen; // prealloc. out = ''; + var tok; while (true) { - var tok = ts.nextTok(); + + tok = keepWhite ? ts.next() : ts.nextTok(); + if (!tok) { break; } + if (tok.name == "COMM") { + tok.outData == '\n'; + } - - if (tok.type == "NAME" && tok.identifier && tok.identifier.mungedValue.length) { + if (tok.type == "NAME" && tok.identifier && tok.identifier.mungedValue && tok.identifier.mungedValue.length) { //f.write(tok.identifier.mungedValue); out += tok.identifier.mungedValue; continue; @@ -224,14 +291,14 @@ CompressWhite = function (ts, packer) // at this point we can apply a text translation kit... - if (tok.type == 'STRN') && (tok.name== 'DOUBLE_QUOTE') { - if (packer.stringHandler) { + if ((tok.type == 'STRN') && (tok.name== 'DOUBLE_QUOTE')) { + if (packer && packer.stringHandler) { out += packer.stringHandler(tok); continue; } } - //f.write(tok.outData); - out += tok.outData; + + out += tok.outData !== false ? tok.outData : tok.data; if ((tok.outData == ';') && (out.length - outoff > 255)) { outoff = out.length;