x.target = "output.pathname.js"
x.debugTarget = "output.pathname.debug.js"
-
-x.debugTranslateTarget : "/tmp/output.translate.js" << this used to be the single vs double quotes.. we may not use it in future..
-x.translateJSON: "/tmp/translate.json",
+
-x.packAll(); // writes files etc..
+x.pack(); // writes files etc..
*</code>
*
/**
* @cfg {String} tmpDir (optional) where to put the temporary files.
* if you set this, then files will not be cleaned up
+ *
+ * at present we need tmpfiles - as we compile multiple files into one.
+ * we could do this in memory now, as I suspect vala will not be as bad as javascript for leakage...
+ *
*/
public string tmpDir = "/tmp"; // FIXME??? in ctor?
// list of files to compile...
Gee.ArrayList<string> files;
-
-
+ /**
+ * @cfg debug -- pretty obvious.
+ */
+
public string activeFile = "";
- public string out = ""; // if no target is specified - then this will contain the result
+ public string outstr = ""; // if no target is specified - then this will contain the result
public Packer(string target, string targetDebug = "")
{
this.target = target;
this.targetDebug = targetDebug;
-
+ this.files = new Gee.ArrayList<string>();
+
+ new Lang_Class(); ///initilizaze lang..
+
}
public void loadSourceIndexes(Gee.ArrayList<string> indexes)
}
}
- public void loadFiles(Gee.ArrayList<string> fs)
+ public void loadFiles(string[] fs)
{
foreach(var f in fs) {
+ GLib.debug("add File: %s", f);
this.files.add(f); //?? easier way?
}
}
-
+ public void loadFile(string f)
+ {
+ GLib.debug("add File: %s", f);
+ this.files.add(f);
+ GLib.debug("FILE LEN: %d", this.files.size);
+ }
public void pack()
{
print("reading %s\n",file );
- if (FileUtils.test (file, FileTest.EXISTS) && ! FileUtils.test (file, FileTest.IS_DIR)) {
+ if (!FileUtils.test (file, FileTest.EXISTS) || FileUtils.test (file, FileTest.IS_DIR)) {
print("SKIP (is not a file) %s\n ", file);
continue;
}
var loaded_string = false;
- string file_contents;
+ string file_contents = "";
// debug Target
if (this.targetDebugStream !=null) {
// this might happen if tmpDir is set ..
- if (true && FileUtils.test (minfile, FileTest.EXISTS)) {
+ if (false && FileUtils.test (minfile, FileTest.EXISTS)) {
var otv = File.new_for_path(file).query_info (FileAttribute.TIME_MODIFIED, 0).get_modification_time();
var mtv = File.new_for_path(minfile).query_info (FileAttribute.TIME_MODIFIED, 0).get_modification_time();
}
- print("COMPRESSING ");
+ print("COMPRESSING\n");
//var codeComp = pack(str, 10, 0, 0);
if (FileUtils.test (minfile, FileTest.EXISTS)) {
FileUtils.remove(minfile);
FileUtils.get_contents(file,out file_contents);
}
- var str = this.packFile(file_contents, file, minfile);
+ this.packFile(file_contents, file, minfile);
}
-
-
- // if we are translating, write the translations strings at the top
- // of the file..
- /*
- if (this.translateJSON) {
-
-
- print("MERGING LANGUAGE");
- var out = "if (typeof(_T) == 'undefined') { _T={};}\n";
- if (this.target) {
- File.write(this.target, out);
- } else {
- this.out += out;
- }
-
- File.write(this.translateJSON, "");
- for(var i=0; i < this.files.length; i++) {
- var file = this.files[i];
- var transfile= this.tmpDir + '/' +file.replace(/\//g, '.') +'.lang.trans';
- var transmd5 = this.tmpDir + '/' +file.replace(/\//g, '.') +'.lang';
- if (File.exists(transmd5)) {
- var str = File.read(transmd5);
- if (str.length) {
- if (this.target) {
- File.append(this.target, str + "\n");
- } else {
- this.out += str + "\n";
- }
-
- }
- if (this.cleanup) {
- File.remove(transmd5);
- }
- }
- if (File.exists(transfile)) {
- var str = File.read(transfile);
- if (str.length) {
- File.append(this.translateJSON, str);
- }
- if (this.cleanup) {
- File.remove(transfile);
- }
- }
-
-
- }
- }
- */
+
print("MERGING SOURCE");
for(var i=0; i < this.files.size; i++) {
this.targetStream.write((str + "\n").data);
} else {
- this.out += "//" + file + "\n";
- this.out += str + "\n";
+ this.outstr += "//" + file + "\n";
+ this.outstr += str + "\n";
}
}
//var ts = new TokenStream(toks);
//print(JSON.stringify(toks, null,4 )); Seed.quit();
var ts = new Collapse(toks.tokens);
+
+ //ts.dumpAll(""); print("Done collaps"); Process.exit(1);
+
// print(JSON.stringify(ts.tokens, null,4 )); Seed.quit();
//return;//
var sp = new ScopeParser(ts);
//print(sp.warnings.join("\n"));
- var outf = CompressWhite(new TokenStream(toks), this, this.keepWhite); // do not kill whitespace..
-
+ var outf = CompressWhite(new TokenStream(toks.tokens), this, this.keepWhite); // do not kill whitespace..
+
if (outf.length > 0) {
FileUtils.set_contents(minfile, outf);
- }
+ } else {
+
- return out;
+ return outf;