summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAndrew Innes <andrewi@gnu.org>1999-01-17 18:57:20 +0000
committerAndrew Innes <andrewi@gnu.org>1999-01-17 18:57:20 +0000
commit52cf535f30ce1451cf6370af483f73a05fd5cfe9 (patch)
tree5b425e76918a0743bccd0c5c71a270e502f94a92
parent1ccaea525e5580acbd88624ecc9554d2a6b7d641 (diff)
downloademacs-52cf535f30ce1451cf6370af483f73a05fd5cfe9.tar.gz
(ps-printer-name): Update docstring about usage on
MS-DOS and MS-Windows. (ps-lpr-command): Update docstring as for lpr-command. (ps-print-region-function): New variable. (ps-do-despool): Use it. (ps-do-despool) [ms-dos, windows-nt]: Remove special case code for DOS/Windows.
-rw-r--r--lisp/ps-print.el77
1 files changed, 36 insertions, 41 deletions
diff --git a/lisp/ps-print.el b/lisp/ps-print.el
index 995c6b5f386..1b3f3855d41 100644
--- a/lisp/ps-print.el
+++ b/lisp/ps-print.el
@@ -1027,28 +1027,33 @@ For more information about PostScript document comments, see:
"*The name of a local printer for printing PostScript files.
On Unix-like systems, a string value should be a name understood by
-lpr's -P option; otherwise the value should be nil.
-
-On MS-DOS and MS-Windows systems, if the value is a string, then it is
-taken as the name of the device to which PostScript files are written.
-By default it is the same as `printer-name'; typical non-default
-settings would be \"LPT1\" to \"LPT3\" for parallel printers, or
-\"COM1\" to \"COM4\" or \"AUX\" for serial printers, or
-\"//hostname/printer\" for a shared network printer. You can also set
-it to a name of a file, in which case the output gets appended to that
-file. \(Note that `ps-print' package already has facilities for
-printing to a file, so you might as well use them instead of changing
-the setting of this variable.\) If you want to silently discard the
-printed output, set this to \"NUL\".
-
-On DOS/Windows, if the value is anything but a string, PostScript files
-will be piped to the program given by `ps-lpr-command', with switches
-given by `ps-lpr-switches', which see."
- :type '(choice file (other :tag "Pipe to ps-lpr-command" pipe))
+lpr's -P option; a value of nil means use the value of `printer-name'
+instead. Any other value will be ignored.
+
+On MS-DOS and MS-Windows systems, a string value is taken as the name of
+the printer device or port to which PostScript files are written,
+provided `ps-lpr-command' is \"\". By default it is the same as
+`printer-name'; typical non-default settings would be \"LPT1\" to
+\"LPT3\" for parallel printers, or \"COM1\" to \"COM4\" or \"AUX\" for
+serial printers, or \"//hostname/printer\" for a shared network printer.
+You can also set it to a name of a file, in which case the output gets
+appended to that file. \(Note that `ps-print' package already has
+facilities for printing to a file, so you might as well use them instead
+of changing the setting of this variable.\) If you want to silently
+discard the printed output, set this to \"NUL\"."
+ :type '(choice file)
:group 'ps-print)
(defcustom ps-lpr-command lpr-command
- "*The shell command for printing a PostScript file."
+ "*Name of program for printing a PostScript file.
+
+On MS-DOS and MS-Windows systems, if the value is an empty string then
+Emacs will write directly to the printer port named by `ps-printer-name'.
+The programs `print' and `nprint' (the standard print programs on Windows
+NT and Novell Netware respectively) are handled specially, using
+`ps-printer-name' as the destination for output; any other program is
+treated like `lpr' except that an explicit filename is given as the last
+argument."
:type 'string
:group 'ps-print)
@@ -1057,6 +1062,12 @@ given by `ps-lpr-switches', which see."
:type '(repeat string)
:group 'ps-print)
+(defcustom ps-print-region-function nil
+ "Function to call to print the region on a PostScript printer.
+See definition of `ps-do-despool' for calling conventions."
+ :type 'function
+ :group 'ps-print)
+
;;; Page layout
;; All page dimensions are in PostScript points.
@@ -4229,28 +4240,12 @@ If FACE is not a valid face name, it is used default face."
(and (stringp ps-printer-name)
(list (concat "-P" ps-printer-name)))
ps-lpr-switches)))
- (if (and (memq system-type '(ms-dos windows-nt))
- (or (and (boundp 'dos-ps-printer)
- (stringp (symbol-value 'dos-ps-printer)))
- (stringp ps-printer-name)))
- (let ((printer (or (and (boundp 'dos-ps-printer)
- (stringp (symbol-value 'dos-ps-printer))
- (symbol-value 'dos-ps-printer))
- ps-printer-name))
- ;; It seems that we must be careful about the
- ;; directory name that gets added by write-region
- ;; when using the standard "PRN" or "LPTx" ports.
- ;; The call can fail if the directory is on a
- ;; network drive.
- (safe-dir (or (getenv "windir") (getenv "TMPDIR") "c:/")))
- (write-region (point-min) (point-max)
- (expand-file-name printer safe-dir) t 0))
- (apply 'call-process-region
- (point-min) (point-max) ps-lpr-command nil
- (and (fboundp 'start-process) 0)
- nil
- (ps-flatten-list ; dynamic evaluation
- (mapcar 'ps-eval-switch ps-lpr-switches))))))
+ (apply (or ps-print-region-function 'call-process-region)
+ (point-min) (point-max) ps-lpr-command nil
+ (and (fboundp 'start-process) 0)
+ nil
+ (ps-flatten-list ; dynamic evaluation
+ (mapcar 'ps-eval-switch ps-lpr-switches)))))
(and ps-razzle-dazzle (message "Printing...done")))
(kill-buffer ps-spool-buffer)))