pack.js
[gnome.introspection-doc-generator] / pack.js
diff --git a/pack.js b/pack.js
old mode 100644 (file)
new mode 100755 (executable)
index e406787..bdd5734
--- a/pack.js
+++ b/pack.js
@@ -5,20 +5,22 @@
  *
  * compresses files listed as arguments and outputs result
  */
-
+TextStream      = imports['JSDOC/TextStream.js'].TextStream;
 TokenReader     = imports['JSDOC/TokenReader.js'].TokenReader;
 ScopeParser     = imports['JSDOC/ScopeParser.js'].ScopeParser;
 TokenStream     = imports['JSDOC/TokenStream.js'].TokenStream;
 CompressWhite   = imports['JSDOC/CompressWhite.js'].CompressWhite;
-
+File = imports.File.File;
  
  
 function pack(str)
 {
     
-    var tr = new  TokenReader();
-    var toks = tr.tokenize(str,false); // dont merge xxx + . + yyyy etc.
-    var sp = new  ScopeParser(new   TokenStream(toks));
+    var tr = new  TokenReader(  { keepDocs :true, keepWhite : true,  keepComments : true, sepIdents : true });
+    var toks = tr.tokenize(new TextStream(str) ); // dont merge xxx + . + yyyy etc.
+    var ts = new   TokenStream(toks);
+   // ts.dump();
+    var sp = new  ScopeParser(ts);
     sp.buildSymbolTree();
     sp.mungeSymboltree();
     print(sp.warnings.join("\n"));
@@ -28,6 +30,36 @@ function pack(str)
 }
 
 
-var args = Array.prototype.slice.call(arguments);
-print(args.join());
+var args = Array.prototype.slice.call(Seed.argv);
+args.shift(); //seed
+args.shift(); // pack.js
+var files = [];
+var outfn = '';
+if (!args.length) {
+    print( "no files selected");
+    Seed.quit();
+}
+for(var i =0; i < args.length;i++) {
+    if (args[i] == '-o') {
+        outfn = args[i+1];
+        i++;
+        continue;
+    }
+    files.push(args[i]);
+}
+print(files.join(', '));
+if (!files.length) {
+    throw "no files selected";
+}
+var out = '';
+files.forEach(function(f) {
+    out = pack(File.read(f)) + "\n";
+});
+if (outfn) {
+    File.write(outfn, out);
+    Seed.quit();
+}
+print(out);
+
+