changeset 22678:e3fe83134880

(direct-print-region-function): Renamed from dos-print-region-function. Added &rest keyword. (print-region-function): Set to direct-print-region-function. (lpr-headers-switches): Initialize. (ps-lpr-command): Initialize. (ps-lpr-switches): Initialize.
author Richard M. Stallman <rms@gnu.org>
date Fri, 03 Jul 1998 19:54:01 +0000
parents a05b1e5f4389
children 08902da4c832
files lisp/dos-w32.el
diffstat 1 files changed, 56 insertions(+), 0 deletions(-) [+]
line wrap: on
line diff
--- a/lisp/dos-w32.el	Fri Jul 03 19:53:47 1998 +0000
+++ b/lisp/dos-w32.el	Fri Jul 03 19:54:01 1998 +0000
@@ -252,6 +252,62 @@
 		  '(raw-text-dos . raw-text-dos)
 		'(undecided-dos . undecided-dos)))
 
+;; Support for printing under DOS/Windows, see lpr.el and ps-print.el.
+(defvar printer-name)
+
+(defun direct-print-region-function (start end
+					   &optional lpr-prog
+					   delete-text buf display
+					   &rest rest)
+  "DOS/Windows-specific function to print the region on a printer.
+Writes the region to the device or file which is a value of
+`printer-name' \(which see\).  Ignores any arguments beyond
+START and END."
+
+  ;; DOS printers need the lines to end with CR-LF pairs, so make
+  ;; sure it always happens that way, unless the buffer is binary.
+  (let* ((coding coding-system-for-write)
+	 (coding-base
+	  (if (null coding) 'undecided (coding-system-base coding)))
+	 (eol-type (coding-system-eol-type coding-base)))
+    (or (eq coding-system-for-write 'no-conversion)
+	(setq coding-system-for-write
+	      (aref eol-type 1)))	; force conversion to DOS EOLs
+    (write-region start end
+		  (or (and (boundp 'dos-printer) dos-printer)
+		      printer-name)
+		  t 0)
+    ;; Make each print-out start on a new page, but don't waste
+    ;; paper if there was a form-feed at the end of this file.
+    (if (not (char-equal (char-after (1- end)) ?\C-l))
+	(write-region "\f" nil
+		      (or (and (boundp 'dos-printer) dos-printer)
+			  printer-name)
+		      t 0))))
+
+;; Set this to nil if you have a port of the `lpr' program and
+;; you want to use it for printing.  If the default setting is
+;; in effect, `lpr-command' and its switches are ignored when
+;; printing with `lpr-xxx' and `print-xxx'.
+(setq print-region-function 'direct-print-region-function)
+
+;; Set this to nil if you have a port of the `pr' program
+;; (e.g., from GNU Textutils), or if you have an `lpr'
+;; program (see above) that can print page headers.
+;; If `lpr-headers-switches' is non-nil (the default) and
+;; `print-region-function' is set to `dos-print-region-function',
+;; then requests to print page headers will be silently
+;; ignored, and `print-buffer' and `print-region' produce
+;; the same output as `lpr-buffer' and `lpr-region', accordingly.
+(setq lpr-headers-switches "(page headers are not supported)")
+
+(defvar ps-printer-name)
+
+(setq ps-lpr-command "gs")
+
+(setq ps-lpr-switches '("-q" "-dNOPAUSE" "-sDEVICE=epson" "-r240x60"
+			  "-sOutputFile=LPT1" "-"))
+
 (provide 'dos-w32)
 
 ;;; dos-w32.el ends here