if (this.debugTarget) {
File.write(this.debugTarget, "");
}
+ if (this.debugTranslateTarget) {
+ File.write(this.debugTarget, "");
+ }
for(var i=0; i < this.files.length; i++) {
var file = this.files[i];
}
}
-
+
print("COMPRESSING ");
//var codeComp = pack(str, 10, 0, 0);
if (File.exists(minfile)) {
}
var str = File.read(file);
var str = this.pack(str, file, minfile);
- if (str.length) {
- File.write(minfile, str);
- }
-
- }
+ }
+
+
+
+ // if we are translating, write the translations strings at the top
+ // of the file..
+
if (this.translateJSON) {
} else {
this.out += out;
}
-
-
-
+
File.write(this.translateJSON, "");
for(var i=0; i < this.files.length; i++) {
var file = this.files[i];
sp.mungeSymboltree();
this.timerPrint("Munged Sym tree");
print(sp.warnings.join("\n"));
-
+ this.timerPrint("Compressed");
var out = CompressWhite(new TokenStream(toks), this, this.keepWhite); // do not kill whitespace..
this.timerPrint("Compressed");
+
+ if (out.length) {
+ File.write(minfile, out);
+ }
+
return out;
* -> this file will need inserting at the start of the application....
* -> we need to generate 2 files,
* -> a reference used to do the translation, and the _T file..
+ *
+ *
+ * We store the trsum on the token...
*
*/
writeTranslateFile : function(fn, minfile, toks)
{
- var map = {};
+ var map = {}; // 'string=> md5sum'
var _this = this;
- toks.forEach(function (t) {
- if (t.type == 'STRN' && t.name == 'DOUBLE_QUOTE') {
- var sval = t.data.substring(1,t.data.length-1);
- var ffn = fn.substring(_this.prefix.length);
- map[sval] = _this.md5(ffn + '-' + sval);
+ var t, last, next;
+
+
+ var tokfind = function (j,dir) {
+ while (1) {
+ if ((dir < 0) && (j < 0)) {
+ return false;
+ }
+ if ((dir > 0) && (j >= toks.length)) {
+ return false;
+ }
+ j += dir;
+ if (toks[j].type != 'WHIT') {
+ return toks[j];
+ }
}
- })
+ return false;
+
+ }
+
+
+ for (var i=0;i<toks.length;i++) {
+
+ t = toks[i];
+ if (t.type != 'STRN') {
+ continue;
+ }
+ if (t.name != 'DOUBLE_QUOTE') {
+ continue;
+ }
+
+ last = tokfind(i,-1);
+ next = tokfind(i,+1);
+
+ // we have to ignore key values on objects
+
+ // defined by
+ // last == '{' or ',' and
+ // next == ':'
+
+ if (next &&
+ next.type == 'PUNC' &&
+ next.data == ':' &&
+ last &&
+ last.type == 'PUNC' &&
+ (last.data == ',' || last.data == '{')
+ ){
+ continue; // found object key... - we can not translate these
+ }
+
+ var sval = t.data.substring(1,t.data.length-1);
+ var ffn = fn.substring(_this.prefix.length);
+
+ t.trsum = _this.md5(ffn + '-' + sval);
+ map[sval] = t.trsum;
+
+
+
+ }
+
var transfile = minfile + '.lang.trans';
var transmd5 = minfile + '.lang';
if (!v.length) {
continue;
}
- File.append(transfile, l + "\n\t" + JSON.stringify(v) + " : " + JSON.stringify(v));
+ File.append(transfile, l + "\n\t\"" + v + "\" : \"" + v +"\"");
l = ',';
// strings are raw... - as the where encoded to start with!!!
- File.append(transmd5, '_T["' + this.md5(ffn + '-' + v) + '"]='+JSON.stringify(v)+";\n");
+ // so we should not need to encode them again.. - just wrap with "
+ File.append(transmd5, '_T["' + this.md5(ffn + '-' + v) + '"]="'+v+"\";\n");
}
File.append(transfile, "\n},"); // always one trailing..
return data;
}
+ if (typeof(tok.trsum) == 'undefined') {
+ return data;
+ }
+
+ return '_T["' + tok.trsum + '"]';
+
var sval = data.substring(1,data.length-1);
// we do not clean up... quoting here!??!!?!?!?!?