[open-ils-commits] r8165 - in branches/rel_1_2/Open-ILS/xul/staff_client/chrome/content: main util

svn at svn.open-ils.org svn at svn.open-ils.org
Thu Dec 6 18:17:35 EST 2007


Author: phasefx
Date: 2007-12-06 17:57:45 -0500 (Thu, 06 Dec 2007)
New Revision: 8165

Modified:
   branches/rel_1_2/Open-ILS/xul/staff_client/chrome/content/main/constants.js
   branches/rel_1_2/Open-ILS/xul/staff_client/chrome/content/util/file.js
   branches/rel_1_2/Open-ILS/xul/staff_client/chrome/content/util/print.js
Log:
banging on the 'dos print' kludge.  There was a 1.2 regression involving a file path, which still needs to be tested with an actual windows machine and receipt printer.  This changeset also adds linux lpr support for 'dos print'.  I may need to use this print strategy for incremental printing, as much as it pains me.

Modified: branches/rel_1_2/Open-ILS/xul/staff_client/chrome/content/main/constants.js
===================================================================
--- branches/rel_1_2/Open-ILS/xul/staff_client/chrome/content/main/constants.js	2007-12-06 22:11:22 UTC (rev 8164)
+++ branches/rel_1_2/Open-ILS/xul/staff_client/chrome/content/main/constants.js	2007-12-06 22:57:45 UTC (rev 8165)
@@ -1,5 +1,15 @@
 dump('Loading constants.js\n');
 
+const MODE_RDONLY   = 0x01;
+const MODE_WRONLY   = 0x02;
+const MODE_CREATE   = 0x08;
+const MODE_APPEND   = 0x10;
+const MODE_TRUNCATE = 0x20;
+const MODE_SYNC     = 0x40;
+const MODE_EXCL     = 0x80;
+const PERMS_FILE      = 0644;
+const PERMS_DIR      = 0755;
+
 const my_constants = {
 	'magical_statuses' : {
 		'1' : { 'disable_in_copy_editor' : true, 'block_mark_item_action' : true }, /* | Checked out    | t */

Modified: branches/rel_1_2/Open-ILS/xul/staff_client/chrome/content/util/file.js
===================================================================
--- branches/rel_1_2/Open-ILS/xul/staff_client/chrome/content/util/file.js	2007-12-06 22:11:22 UTC (rev 8164)
+++ branches/rel_1_2/Open-ILS/xul/staff_client/chrome/content/util/file.js	2007-12-06 22:57:45 UTC (rev 8165)
@@ -166,7 +166,7 @@
 
 			this._f = Components.classes["@mozilla.org/network/file-input-stream;1"]
 				.createInstance(Components.interfaces.nsIFileInputStream);
-			this._f.init(this._file, 0x01, 0, 0);
+			this._f.init(this._file, MODE_RDONLY, 0, 0);
 			/*
 			this._f.QueryInterface(Components.interfaces.nsILineInputStream);
 			this._istream = this._f;
@@ -188,23 +188,31 @@
 
 	'_create_output_stream' : function(param) {
 		try {
-			//dump('_create_output_stream('+param+')\n');
+			//dump('_create_output_stream('+param+') for '+this._file.path+'\n');
 			
 			netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect UniversalPreferencesWrite UniversalBrowserWrite UniversalPreferencesRead UniversalBrowserRead UniversalFileRead");
 
 			if (!this._file) throw('Must .get() a file first.');
 
-			if (! this._file.exists()) this._file.create( 0, 0640 );
-
+			if (! this._file.exists()) {
+                if (param == 'truncate+exec') {
+                    this._file.create( 0, 0777 );
+                } else {
+                    this._file.create( 0, PERMS_FILE );
+                }
+            }
 			this._output_stream = Components.classes["@mozilla.org/network/file-output-stream;1"]
 				.createInstance(Components.interfaces.nsIFileOutputStream);
 			switch(param){
 				case 'append' :
-					this._output_stream.init(this._file, 0x02 | 0x08 | 0x10 | 0x40, 0644, 0);
+					this._output_stream.init(this._file, MODE_WRONLY | MODE_APPEND, PERMS_FILE, 0);
 				break;
+                case 'truncate+exec' :
+					this._output_stream.init(this._file, MODE_WRONLY | MODE_CREATE | MODE_TRUNCATE, PERMS_FILE, 0);
+                break;
 				case 'truncate' :
 				default:
-					this._output_stream.init(this._file, 0x02 | 0x08 | 0x20 | 0x40, 0644, 0);
+					this._output_stream.init(this._file, MODE_WRONLY | MODE_CREATE | MODE_TRUNCATE, PERMS_FILE, 0);
 				break;
 			}
 

Modified: branches/rel_1_2/Open-ILS/xul/staff_client/chrome/content/util/print.js
===================================================================
--- branches/rel_1_2/Open-ILS/xul/staff_client/chrome/content/util/print.js	2007-12-06 22:11:22 UTC (rev 8164)
+++ branches/rel_1_2/Open-ILS/xul/staff_client/chrome/content/util/print.js	2007-12-06 22:57:45 UTC (rev 8165)
@@ -282,22 +282,24 @@
 			var text = w;
 
 			var file = new util.file('receipt.txt');
-			file.write_content('truncate',text); file.close();
+			file.write_content('truncate',text); 
+            var path = file._file.path;
+            file.close();
 			
 			file = new util.file('receipt.bat');
-			if (! file._file.exists()) { 
-				file.write_content('truncate','copy chrome\\open_ils_staff_client\\content\\conf\\receipt.txt lpt1 /b\n');
-				file.close();
-				file = new util.file('receipt.bat');
-			}
+			file.write_content('truncate+exec','#!/bin/sh\ncopy ' + path + ' lpt1 /b\nlpr ' + path + '\n');
+            file.close();
+			file = new util.file('receipt.bat');
 
 			var process = Components.classes["@mozilla.org/process/util;1"].createInstance(Components.interfaces.nsIProcess);
 			process.init(file._file);
 
 			var args = [];
 
-			process.run(true, args, args.length);
+			dump('process.run = ' + process.run(true, args, args.length) + '\n');
 
+            file.close();
+
 		} catch (e) {
 			//alert('Probably not printing: ' + e);
 			this.error.sdump('D_ERROR','_NSPrint_dos_print PRINT EXCEPTION: ' + js2JSON(e) + '\n');



More information about the open-ils-commits mailing list