}
-
+ 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")) {
+ if (tok.type == "NAME") {
//var tokident = ts.look(-1).data + tok.data + ts.look(1).data + ts.look(2).data;
// a = new function() {}
if (ts.lookTok(1).data == '=' && ts.lookTok(2).name == 'NEW' &&
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..
ts.balance("{");
// 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.lookTok(1,true).name == "NEWLINE") {
+ ts.look(0).outData = ts.look(0).data+";";
+ }
+ // 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)) {
// 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();
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..
case "BREAK":
case "CONTINUE":
// if next item is a identifier..
- if (ts.look(1).isTypeN(Script.TOKidentifier) || ts.look(1).data.match(/^[a-z]+$/i) ) { // as include is a keyword for us!!
+ if (ts.lookTok(1).type == "NAME" || ts.lookTok(1).data.match(/^[a-z]+$/i) ) { // as include is a keyword for us!!
tok.outData = tok.data + " ";
}
continue;
case "RETURN": // if next item is not a semi; (or }
- if (ts.look(1).data == ';' || ts.look(1).data == '}') {
+ if (ts.lookTok(1).data == ';' || ts.lookTok(1).data == '}') {
continue;
}
tok.outData = tok.data + " ";
case "ELSE": // if next item is not a semi; (or }
- if (!ts.look(1).isTypeN(Script.TOKif)) {
+ if (!ts.lookTok(1).name == "IF") {
continue;
}
case "++": // if previous was a plus or next is a + add a space..
case "--": // if previous was a - or next is a - add a space..
- var p = (Script.TOKminusminus == tok.tokN ? '-' : '+');
+ var p = (tok.data == "--" ? '-' : '+');
- if (ts.look(1).data == p) {
+ if (ts.lookTok(1).data == p) {
tok.outData = tok.data + " ";
}
- if (ts.look(-1).data == p) {
+ if (ts.lookTok(-1).data == p) {
tok.outData = " " + tok.data;
}
tok.outData = tok.data + " ";
}
continue;
- case ";"
+ case ";":
//remove semicolon before brace --
//if(ts.look(1).isTypeN(Script.TOKrbrace)) {
// tok.outData = '';
out.length = ts.slen; // prealloc.
out = '';
while (true) {
- var tok = ts.next();
+ var tok = ts.nextTok();
+
if (!tok) {
break;
}
- if (tok._isWS) {
- continue;
- }
- if (tok.isTypeN(Script.TOKidentifier) && 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;
+ out += tok.identifier.mungedValue;
continue;
}
// at this point we can apply a text translation kit...
- if (tok.type == 'string') {
- 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;
- out += '\n';
+ out += "\n";
}
}
//f.close();