Homepage: https://www.emacswiki.org/cgi-bin/wiki/ViniciusJoseLatorre
Author: Jacques Duthen (was, Jim Thompson (was, Kenichi Handa, Vinicius Jose Latorre
Print text from the buffer as PostScript
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; About ps-print -------------- This package provides printing of Emacs buffers on PostScript printers; the buffer's bold and italic text attributes are preserved in the printer output. ps-print is intended for use with Emacs, together with a fontifying package such as font-lock or hilit. ps-print uses the same face attributes defined through font-lock or hilit to print a PostScript file, but some faces are better seeing on the screen than on paper, specially when you have a black/white PostScript printer. ps-print allows a remap of face to another one that it is better to print, for example, the face font-lock-comment-face (if you are using font-lock) could have bold or italic attribute when printing, besides foreground color. This remap improves printing look (see How Ps-Print Maps Faces). Using ps-print -------------- ps-print provides eight commands for generating PostScript images of Emacs buffers: ps-print-buffer ps-print-buffer-with-faces ps-print-region ps-print-region-with-faces ps-spool-buffer ps-spool-buffer-with-faces ps-spool-region ps-spool-region-with-faces These commands all perform essentially the same function: they generate PostScript images suitable for printing on a PostScript printer or displaying with GhostScript. These commands are collectively referred to as "ps-print- commands". The word "print" or "spool" in the command name determines when the PostScript image is sent to the printer: print - The PostScript image is immediately sent to the printer; spool - The PostScript image is saved temporarily in an Emacs buffer. Many images may be spooled locally before printing them. To send the spooled images to the printer, use the command `ps-despool'. The spooling mechanism was designed for printing lots of small files (mail messages or netnews articles) to save paper that would otherwise be wasted on banner pages, and to make it easier to find your output at the printer (it's easier to pick up one 50-page printout than to find 50 single-page printouts). ps-print has a hook in the `kill-emacs-hook' so that you won't accidentally quit from Emacs while you have unprinted PostScript waiting in the spool buffer. If you do attempt to exit with spooled PostScript, you'll be asked if you want to print it, and if you decline, you'll be asked to confirm the exit; this is modeled on the confirmation that Emacs uses for modified buffers. The word "buffer" or "region" in the command name determines how much of the buffer is printed: buffer - Print the entire buffer. region - Print just the current region. The -with-faces suffix on the command name means that the command will include font, color, and underline information in the PostScript image, so the printed image can look as pretty as the buffer. The ps-print- commands without the -with-faces suffix don't include font, color, or underline information; images printed with these commands aren't as pretty, but are faster to generate. Two ps-print- command examples: ps-print-buffer - print the entire buffer, without font, color, or underline information, and send it immediately to the printer. ps-spool-region-with-faces - print just the current region; include font, color, and underline information, and spool the image in Emacs to send to the printer later. Invoking Ps-Print ----------------- To print your buffer, type M-x ps-print-buffer or substitute one of the other seven ps-print- commands. The command will generate the PostScript image and print or spool it as specified. By giving the command a prefix argument C-u M-x ps-print-buffer it will save the PostScript image to a file instead of sending it to the printer; you will be prompted for the name of the file to save the image to. The prefix argument is ignored by the commands that spool their images, but you may save the spooled images to a file by giving a prefix argument to `ps-despool': C-u M-x ps-despool When invoked this way, `ps-despool' will prompt you for the name of the file to save to. Any of the `ps-print-' commands can be bound to keys; I recommend binding `ps-spool-buffer-with-faces', `ps-spool-region-with-faces', and `ps-despool'. Here are the bindings I use on my Sun 4 keyboard: (global-set-key 'f22 'ps-spool-buffer-with-faces) ;f22 is prsc (global-set-key '(shift f22) 'ps-spool-region-with-faces) (global-set-key '(control f22) 'ps-despool) The Printer Interface --------------------- The variables `ps-lpr-command' and `ps-lpr-switches' determine what command is used to send the PostScript images to the printer, and what arguments to give the command. These are analogous to `lpr-command' and `lpr-switches'. Make sure that they contain appropriate values for your system; see the usage notes below and the documentation of these variables. The variable `ps-printer-name' determines the name of a local printer for printing PostScript files. The variable `ps-printer-name-option' determines the option used by some utilities to indicate the printer name, it's used only when `ps-printer-name' is a non-empty string. If you're using lpr utility to print, for example, `ps-printer-name-option' should be set to "-P". NOTE: `ps-lpr-command' and `ps-lpr-switches' take their initial values from the variables `lpr-command' and `lpr-switches'. If you have `lpr-command' set to invoke a pretty-printer such as `enscript', then ps-print won't work properly. `ps-lpr-command' must name a program that does not format the files it prints. `ps-printer-name' takes its initial value from the variable `printer-name'. `ps-printer-name-option' tries to guess which system Emacs is running and takes its initial value in accordance with this guess. The variable `ps-print-region-function' specifies a function to print the region on a PostScript printer. See definition of `call-process-region' for calling conventions. The fourth and the sixth arguments are both nil. The variable `ps-manual-feed' indicates if the printer will manually feed paper. If it's nil, automatic feeding takes place. If it's non-nil, manual feeding takes place. The default is nil (automatic feeding). The variable `ps-end-with-control-d' specifies whether C-d (\x04) should be inserted at end of PostScript generated. Non-nil means do so. The default is nil (don't insert). If you're using Emacs for Windows 98/NT or MS-DOS, don't forget to customize the following variables: `ps-printer-name', `ps-printer-name-option', `ps-lpr-command', `ps-lpr-switches' and `ps-spool-config'. See these variables documentation in the code or by typing, for example, C-h v ps-printer-name RET. The Page Layout --------------- All dimensions are floats in PostScript points. 1 inch == 2.54 cm == 72 points 1 cm == (/ 1 2.54) inch == (/ 72 2.54) points The variable `ps-paper-type' determines the size of paper ps-print formats for; it should contain one of the symbols: `a4' `a3' `letter' `legal' `letter-small' `tabloid' `ledger' `statement' `executive' `a4small' `b4' `b5'. If variable `ps-warn-paper-type' is nil, it's *not* given an error if PostScript printer doesn't have a paper with the size indicated by `ps-paper-type', instead it uses the default paper size. If variable `ps-warn-paper-type' is non-nil, it's given an error if PostScript printer doesn't have a paper with the size indicated by `ps-paper-type'. It's used when `ps-spool-config' is set to `setpagedevice' (see section Duplex Printers). The default value is non-nil (it gives an error). The variable `ps-landscape-mode' determines the orientation of the printing on the page: nil means `portrait' mode, non-nil means `landscape' mode. There is no oblique mode yet, though this is easy to do in ps. In landscape mode, the text is NOT scaled: you may print 70 lines in portrait mode and only 50 lines in landscape mode. The margins represent margins in the printed paper: the top margin is the margin between the top of the page and the printed header, whatever the orientation is. The variable `ps-number-of-columns' determines the number of columns both in landscape and portrait mode. You can use: - (the standard) one column portrait mode. - (my favorite) two columns landscape mode (which spares trees). but also: - one column landscape mode for files with very long lines. - multi-column portrait or landscape mode. The variable `ps-print-upside-down' determines other orientation for printing page: nil means `normal' printing, non-nil means `upside-down' printing (that is, the page is rotated by 180 grades). The default value is nil (`normal' printing). The `upside-down' orientation can be used in portrait or landscape mode. The variable `ps-selected-pages' specifies which pages to print. If it's nil, all pages are printed. If it's a list, the list element may be an integer or a cons cell (FROM . TO) designating FROM page to TO page; any invalid element is ignored, that is, an integer lesser than one or if FROM is greater than TO. Otherwise, it's treated as nil. The default value is nil (print all pages). After ps-print processing `ps-selected-pages' is set to nil. But the latest `ps-selected-pages' is saved in `ps-last-selected-pages' (see it for documentation). So you can restore the latest selected pages by using `ps-last-selected-pages' or by calling `ps-restore-selected-pages' command (see it for documentation). The variable `ps-even-or-odd-pages' specifies if it prints even/odd pages. Valid values are: nil print all pages. even-page print only even pages. odd-page print only odd pages. even-sheet print only even sheets. odd-sheet print only odd sheets. Any other value is treated as nil. The default value is nil. See `ps-even-or-odd-pages' for more detailed documentation. Horizontal layout ----------------- The horizontal layout is determined by the variables `ps-left-margin' `ps-inter-column' `ps-right-margin' as follows: ------------------------------------------ | | | | | | | | | lm | text | ic | text | ic | text | rm | | | | | | | | | ------------------------------------------ If `ps-number-of-columns' is 1, `ps-inter-column' is not relevant. Usually, lm = rm > 0 and ic = lm If (ic < 0), the text of adjacent columns can overlap. Vertical layout --------------- The vertical layout is determined by the variables `ps-bottom-margin' `ps-top-margin' `ps-header-offset' `ps-footer-offset' as follows: |--------| |--------| |--------| |--------| | tm | | tm | | tm | | tm | |--------| |--------| |--------| |--------| | header | | | | header | | | |--------| | | |--------| | | | ho | | | | ho | | | |--------| | | |--------| | | | | | | | | | | | text | or | text | or | text | or | text | | | | | | | | | | | |--------| |--------| | | | | | fo | | fo | | | | | |--------| |--------| | | | | | footer | | footer | | | |--------| |--------| |--------| |--------| | bm | | bm | | bm | | bm | |--------| |--------| |--------| |--------| If `ps-print-header' is nil, `ps-header-offset' is not relevant. If `ps-print-footer' is nil, `ps-footer-offset' is not relevant. The margins represent margins in the printed paper: the top margin is the margin between the top of the page and the printed header, whatever the orientation is; the bottom margin is the margin between the bottom of the page and the printed footer, whatever the orientation is. Headers & Footers ----------------- ps-print can print headers at the top of each column or at the top of each page; the default headers contain the following four items: on the left, the name of the buffer and, if the buffer is visiting a file, the file's directory; on the right, the page number and date of printing. The default headers look something like this: ps-print.el 1/21 /home/jct/emacs-lisp/ps/new 94/12/31 When printing on duplex printers, left and right are reversed so that the page numbers are toward the outside (cf. `ps-spool-duplex'). Headers are configurable: To turn them off completely, set `ps-print-header' to nil. To turn off the header's gaudy framing box, set `ps-print-header-frame' to nil. The variable `ps-header-frame-alist' specifies header frame properties alist. Valid frame properties are: fore-color Specify the foreground frame color. It should be a float number between 0.0 (black color) and 1.0 (white color), a string which is a color name, or a list of 3 float numbers which corresponds to the Red Green Blue color scale, each float number between 0.0 (dark color) and 1.0 (bright color). The default is 0 ("black"). back-color Specify the background frame color (similar to fore-color). The default is 0.9 ("gray90"). shadow-color Specify the shadow color (similar to fore-color). The default is 0 ("black"). border-color Specify the border color (similar to fore-color). The default is 0 ("black"). border-width Specify the border width. The default is 0.4. Any other property is ignored. Don't change this alist directly, instead use customization, or `ps-value', `ps-get', `ps-put' and `ps-del' functions (see them for documentation). To print only one header at the top of each page, set `ps-print-only-one-header' to t. To switch headers, set `ps-switch-header' to: nil Never switch headers. t Always switch headers. duplex Switch headers only when duplexing is on, that is, when `ps-spool-duplex' is non-nil (see Duplex Printers). Any other value is treated as t. The default value is `duplex'. The font family and size of text in the header are determined by the variables `ps-header-font-family', `ps-header-font-size' and `ps-header-title-font-size' (see below). The variable `ps-header-line-pad' determines the portion of a header title line height to insert between the header frame and the text it contains, both in the vertical and horizontal directions: .5 means half a line. Page numbers are printed in `n/m' format, indicating page n of m pages; to omit the total page count and just print the page number, set `ps-show-n-of-n' to nil. The amount of information in the header can be changed by changing the number of lines. To show less, set `ps-header-lines' to 1, and the header will show only the buffer name and page number. To show more, set `ps-header-lines' to 3, and the header will show the time of printing below the date. To change the content of the headers, change the variables `ps-left-header' and `ps-right-header'. These variables are lists, specifying top-to-bottom the text to display on the left or right side of the header. Each element of the list should be a string or a symbol. Strings are inserted directly into the PostScript arrays, and should contain the PostScript string delimiters '(' and ')'. Symbols in the header format lists can either represent functions or variables. Functions are called, and should return a string to show in the header. Variables should contain strings to display in the header. In either case, function or variable, the PostScript string delimiters are added by ps-print, and should not be part of the returned value. Here's an example: say we want the left header to display the text Moe Larry Curly where we have a function to return "Moe" (defun moe-func () "Moe") a variable specifying "Larry" (setq larry-var "Larry") and a literal for "Curly". Here's how `ps-left-header' should be set: (setq ps-left-header (list 'moe-func 'larry-var "(Curly)")) Note that Curly has the PostScript string delimiters inside his quotes -- those aren't misplaced Lisp delimiters! Without them, PostScript would attempt to call the undefined function Curly, which would result in a PostScript error. Since most printers don't report PostScript errors except by aborting the print job, this kind of error can be hard to track down. Consider yourself warned! ps-print also print footers. The footer variables are: `ps-print-footer', `ps-footer-offset', `ps-print-footer-frame', `ps-footer-font-family', `ps-footer-font-size', `ps-footer-line-pad', `ps-footer-lines', `ps-left-footer', `ps-right-footer' and `ps-footer-frame-alist'. These variables are similar to those one that control headers. The variables `ps-print-only-one-header' and `ps-switch-header' also control the footer (The same way that control header). As a footer example, if you want to have a centered page number in the footer but without headers, set: (setq ps-print-header nil ps-print-footer t ps-print-footer-frame nil ps-footer-lines 1 ps-right-footer nil ps-left-footer (list (concat "{pagenumberstring dup stringwidth pop" " 2 div PrintWidth 2 div exch sub 0 rmoveto}"))) PostScript Prologue Header -------------------------- It is possible to add PostScript prologue header comments besides that ps-print generates by setting the variable `ps-print-prologue-header'. `ps-print-prologue-header' may be a string or a symbol function which returns a string. Note that this string is inserted on PostScript prologue header section which is used to define some document characteristic through PostScript special comments, like "%%Requirements: jog\n". By default `ps-print-prologue-header' is nil. ps-print always inserts the %%Requirements: comment, so if you need to insert more requirements put them first in `ps-print-prologue-header' using the "%%+" comment. For example, if you need to set numcopies to 3 and jog on requirements and set %%LanguageLevel: to 2, do: (setq ps-print-prologue-header "%%+ numcopies(3) jog\n%%LanguageLevel: 2\n") The duplex requirement is inserted by ps-print (see section Duplex Printers). Do not forget to terminate the string with "\n". For more information about PostScript document comments, see: PostScript Language Reference Manual (2nd edition) Adobe Systems Incorporated Appendix G: Document Structuring Conventions -- Version 3.0 It is also possible to add an user defined PostScript prologue code before all generated prologue code by setting the variable `ps-user-defined-prologue'. `ps-user-defined-prologue' may be a string or a symbol function which returns a string. Note that this string is inserted after `ps-adobe-tag' and PostScript prologue comments, and before ps-print PostScript prologue code section. That is, this string is inserted after error handler initialization and before ps-print settings. By default `ps-user-defined-prologue' is nil. It's strongly recommended only insert PostScript code and/or comments specific for your printing system particularities. For example, some special initialization that only your printing system needs. Do not insert code for duplex printing, n-up printing or error handler, ps-print handles this in a suitable way. For more information about PostScript, see: PostScript Language Reference Manual (2nd edition) Adobe Systems Incorporated As an example for `ps-user-defined-prologue' setting: ;; Setting for HP PostScript printer (setq ps-user-defined-prologue (concat "<> setpagedevice")) PostScript Error Handler ------------------------ ps-print instruments generated PostScript code with an error handler. The variable `ps-error-handler-message' specifies where the error handler message should be sent. Valid values are: none catch the error and *DON'T* send any message. paper catch the error and print on paper the error message. This is the default value. system catch the error and send back the error message to printing system. This is useful only if printing system send back an email reporting the error, or if there is some other alternative way to report back the error from the system to you. paper-and-system catch the error, print on paper the error message and send back the error message to printing system. Any other value is treated as `paper'. Duplex Printers --------------- If you have a duplex-capable printer (one that prints both sides of the paper), set `ps-spool-duplex' to t. ps-print will insert blank pages to make sure each buffer starts on the correct side of the paper. The variable `ps-spool-config' specifies who is the responsible for setting duplex and page size. Valid values are: lpr-switches duplex and page size are configured by `ps-lpr-switches'. Don't forget to set `ps-lpr-switches' to select duplex printing for your printer. setpagedevice duplex and page size are configured by ps-print using the setpagedevice PostScript operator. nil duplex and page size are configured by ps-print *not* using the setpagedevice PostScript operator. Any other value is treated as nil. The default value is `lpr-switches'. WARNING: The setpagedevice PostScript operator affects ghostview utility when viewing file generated using landscape. Also on some printers, setpagedevice affects zebra stripes; on other printers, setpagedevice affects the left margin. Besides all that, if your printer does not have the paper size specified by setpagedevice, your printing will be aborted. So, if you need to use setpagedevice, set `ps-spool-config' to `setpagedevice', generate a test file and send it to your printer; if the printed file isn't ok, set `ps-spool-config' to nil. The variable `ps-spool-tumble' specifies how the page images on opposite sides of a sheet are oriented with respect to each other. If `ps-spool-tumble' is nil, produces output suitable for binding on the left or right. If `ps-spool-tumble' is non-nil, produces output suitable for binding at the top or bottom. It has effect only when `ps-spool-duplex' is non-nil. The default value is nil. Some printer system prints a header page and forces the first page be printed on header page back, when using duplex. If your printer system has this behavior, set variable `ps-banner-page-when-duplexing' to t. When `ps-banner-page-when-duplexing' is non-nil, it prints a blank page as the very first printed page. So, it behaves as the very first character of buffer (or region) is ^L (\014). The default for `ps-banner-page-when-duplexing' is nil (*don't* skip the very first page). N-up Printing ------------- The variable `ps-n-up-printing' specifies the number of pages per sheet of paper. The value specified must be between 1 and 100. The default is 1. NOTE: some PostScript printer may crash printing if `ps-n-up-printing' is set to a high value (for example, 23). If this happens, set a lower value. The variable `ps-n-up-margin' specifies the margin in points between the sheet border and the n-up printing. The default is 1 cm (or 0.3937 inches, or 28.35 points). If variable `ps-n-up-border-p' is non-nil a border is drawn around each page. The default is t. The variable `ps-n-up-filling' specifies how page matrix is filled on each sheet of paper. Following are the valid values for `ps-n-up-filling' with a filling example using a 3x4 page matrix: left-top 1 2 3 4 left-bottom 9 10 11 12 5 6 7 8 5 6 7 8 9 10 11 12 1 2 3 4 right-top 4 3 2 1 right-bottom 12 11 10 9 8 7 6 5 8 7 6 5 12 11 10 9 4 3 2 1 top-left 1 4 7 10 bottom-left 3 6 9 12 2 5 8 11 2 5 8 11 3 6 9 12 1 4 7 10 top-right 10 7 4 1 bottom-right 12 9 6 3 11 8 5 2 11 8 5 2 12 9 6 3 10 7 4 1 Any other value is treated as `left-top'. The default value is left-top. Control And 8-bit Characters ---------------------------- The variable `ps-print-control-characters' specifies whether you want to see a printable form for control and 8-bit characters, that is, instead of sending, for example, a ^D (\004) to printer, it is sent the string "^D". Valid values for `ps-print-control-characters' are: 8-bit This is the value to use when you want an ASCII encoding of any control or non-ASCII character. Control characters are encoded as "^D", and non-ASCII characters have an octal encoding. control-8-bit This is the value to use when you want an ASCII encoding of any control character, whether it is 7 or 8-bit. European 8-bits accented characters are printed according the current font. control Only ASCII control characters have an ASCII encoding. European 8-bits accented characters are printed according the current font. nil No ASCII encoding. Any character is printed according the current font. Any other value is treated as nil. The default is `control-8-bit'. Characters TAB, NEWLINE and FORMFEED are always treated by ps-print engine. Printing Multi-byte Buffer -------------------------- See ps-mule.el for documentation. Line Number ----------- The variable `ps-line-number' specifies whether to number each line; non-nil means do so. The default is nil (don't number each line). The variable `ps-line-number-color' specifies the color for line number. See `ps-zebra-color' for documentation. The default is "black" (or 0.0, or '(0.0 0.0 0.0)). The variable `ps-line-number-font' specifies the font for line number. The default is "Times-Italic". The variable `ps-line-number-font-size' specifies the font size in points for line number. See `ps-font-size' for documentation. The default is 6. The variable `ps-line-number-step' specifies the interval that line number is printed. For example, if `ps-line-number-step' is set to 2, the printing will look like: 1 one line one line 3 one line one line 5 one line one line ... Valid values are: integer an integer that specifies the interval that line number is printed. If it's lesser than or equal to zero, it's used the value 1. `zebra' specifies that only the line number of the first line in a zebra stripe is to be printed. Any other value is treated as `zebra'. The default value is 1, so each line number is printed. The variable `ps-line-number-start' specifies the starting point in the interval given by `ps-line-number-step'. For example, if `ps-line-number-step' is set to 3 and `ps-line-number-start' is set to 3, the printing will look like: one line one line 3 one line one line one line 6 one line one line one line 9 one line one line ... The values for `ps-line-number-start': * If `ps-line-number-step' is an integer, must be between 1 and the value of `ps-line-number-step' inclusive. * If `ps-line-number-step' is set to `zebra', must be between 1 and the value of `ps-zebra-stripe-height' inclusive. The default value is 1, so the line number of the first line of each interval is printed. Zebra Stripes ------------- Zebra stripes are a kind of background that appear "underneath" the text and can make the text easier to read. They look like this: XXXXXXXXXXXXXXXXXXXXXXXX XXXXXXXXXXXXXXXXXXXXXXXX XXXXXXXXXXXXXXXXXXXXXXXX XXXXXXXXXXXXXXXXXXXXXXXX XXXXXXXXXXXXXXXXXXXXXXXX XXXXXXXXXXXXXXXXXXXXXXXX The blocks of X's represent rectangles filled with a light gray color. Each rectangle extends all the way across the page. The height, in lines, of each rectangle is controlled by the variable `ps-zebra-stripe-height', which is 3 by default. The distance between stripes equals the height of a stripe. The variable `ps-zebra-stripes' controls whether to print zebra stripes. Non-nil means yes, nil means no. The default is nil. The variable `ps-zebra-color' controls the zebra stripes gray scale or RGB color. It should be a float number between 0.0 (black color) and 1.0 (white color), a string which is a color name, or a list of 3 numbers which corresponds to the Red Green Blue color scale. The default is 0.95 (or "gray95", or '(0.95 0.95 0.95)). The variable `ps-zebra-stripe-follow' specifies how zebra stripes continue on next page. Visually, valid values are (the character `+' at right of each column indicates that a line is printed): nil `follow' `full' `full-follow' Current Page -------- ----------- --------- ---------------- 1 XXXXX + 1 XXXXXXXX + 1 XXXXXX + 1 XXXXXXXXXXXXX + 2 XXXXX + 2 XXXXXXXX + 2 XXXXXX + 2 XXXXXXXXXXXXX + 3 XXXXX + 3 XXXXXXXX + 3 XXXXXX + 3 XXXXXXXXXXXXX + 4 + 4 + 4 + 4 + 5 + 5 + 5 + 5 + 6 + 6 + 6 + 6 + 7 XXXXX + 7 XXXXXXXX + 7 XXXXXX + 7 XXXXXXXXXXXXX + 8 XXXXX + 8 XXXXXXXX + 8 XXXXXX + 8 XXXXXXXXXXXXX + 9 XXXXX + 9 XXXXXXXX + 9 XXXXXX + 9 XXXXXXXXXXXXX + 10 + 10 + 11 + 11 + -------- ----------- --------- ---------------- Next Page -------- ----------- --------- ---------------- 12 XXXXX + 12 + 10 XXXXXX + 10 + 13 XXXXX + 13 XXXXXXXX + 11 XXXXXX + 11 + 14 XXXXX + 14 XXXXXXXX + 12 XXXXXX + 12 + 15 + 15 XXXXXXXX + 13 + 13 XXXXXXXXXXXXX + 16 + 16 + 14 + 14 XXXXXXXXXXXXX + 17 + 17 + 15 + 15 XXXXXXXXXXXXX + 18 XXXXX + 18 + 16 XXXXXX + 16 + 19 XXXXX + 19 XXXXXXXX + 17 XXXXXX + 17 + 20 XXXXX + 20 XXXXXXXX + 18 XXXXXX + 18 + 21 + 21 XXXXXXXX + 22 + 22 + -------- ----------- --------- ---------------- Any other value is treated as nil. See also section How Ps-Print Has A Text And/Or Image On Background. Hooks ----- ps-print has the following hook variables: `ps-print-hook' It is evaluated once before any printing process. This is the right place to initialize ps-print global data. For an example, see section Adding a New Font Family. `ps-print-begin-sheet-hook' It is evaluated on each beginning of sheet of paper. If `ps-n-up-printing' is equal to 1, `ps-print-begin-page-hook' is never evaluated. `ps-print-begin-page-hook' It is evaluated on each beginning of page, except in the beginning of page that `ps-print-begin-sheet-hook' is evaluated. `ps-print-begin-column-hook' It is evaluated on each beginning of column, except in the beginning of column that `ps-print-begin-page-hook' is evaluated or that `ps-print-begin-sheet-hook' is evaluated. Font Managing ------------- ps-print now knows rather precisely some fonts: the variable `ps-font-info-database' contains information for a list of font families (currently mainly `Courier' `Helvetica' `Times' `Palatino' `Helvetica-Narrow' `NewCenturySchlbk'). Each font family contains the font names for standard, bold, italic and bold-italic characters, a reference size (usually 10) and the corresponding line height, width of a space and average character width. The variable `ps-font-family' determines which font family is to be used for ordinary text. If its value does not correspond to a known font family, an error message is printed into the `*Messages*' buffer, which lists the currently available font families. The variable `ps-font-size' determines the size (in points) of the font for ordinary text, when generating PostScript. Its value is a float or a cons of floats which has the following form: (LANDSCAPE-SIZE . PORTRAIT-SIZE) Similarly, the variable `ps-header-font-family' determines which font family is to be used for text in the header. The variable `ps-header-font-size' determines the font size, in points, for text in the header (similar to `ps-font-size'). The variable `ps-header-title-font-size' determines the font size, in points, for the top line of text in the header (similar to `ps-font-size'). The variable `ps-line-spacing' determines the line spacing, in points, for ordinary text, when generating PostScript (similar to `ps-font-size'). The default value is 0 (zero = no line spacing). The variable `ps-paragraph-spacing' determines the paragraph spacing, in points, for ordinary text, when generating PostScript (similar to `ps-font-size'). The default value is 0 (zero = no paragraph spacing). To get all lines with some spacing set both `ps-line-spacing' and `ps-paragraph-spacing' variables. The variable `ps-paragraph-regexp' specifies the paragraph delimiter. It should be a regexp or nil. The default value is "[ \t]*$", that is, an empty line or a line containing only spaces and tabs. The variable `ps-begin-cut-regexp' and `ps-end-cut-regexp' specify the start and end of a region to cut out when printing. As an example, variables `ps-begin-cut-regexp' and `ps-end-cut-regexp' may be set to "^Local Variables:" and "^End:", respectively, in order to leave out some special printing instructions from the actual print. Special printing instructions may be appended to the end of the file just like any other buffer-local variables. See section "Local Variables in Files" on Emacs manual for more information. Variables `ps-begin-cut-regexp' and `ps-end-cut-regexp' control together what actually gets printed. Both variables may be set to nil in which case no cutting occurs. By default, both variables are set to nil. Adding a New Font Family ------------------------ To use a new font family, you MUST first teach ps-print this font, i.e., add its information to `ps-font-info-database', otherwise ps-print cannot correctly place line and page breaks. For example, assuming `Helvetica' is unknown, you first need to do the following ONLY ONCE: - create a new buffer - generate the PostScript image to a file (C-u M-x ps-print-buffer) - open this file and find the line: `% 3 cm 20 cm moveto 10/Courier ReportFontInfo showpage' - delete the leading `%' (which is the PostScript comment character) - replace in this line `Courier' by the new font (say `Helvetica') to get the line: `3 cm 20 cm moveto 10/Helvetica ReportFontInfo showpage' - send this file to the printer (or to ghostscript). You should read the following on the output page: For Helvetica 10 point, the line height is 11.56, the space width is 2.78 and a crude estimate of average character width is 5.09243 - Add these values to the `ps-font-info-database': (setq ps-font-info-database (append '((Helvetica ; the family key (fonts (normal . "Helvetica") (bold . "Helvetica-Bold") (italic . "Helvetica-Oblique") (bold-italic . "Helvetica-BoldOblique")) (size . 10.0) (line-height . 11.56) (space-width . 2.78) (avg-char-width . 5.09243))) ps-font-info-database)) - Now you can use this font family with any size: (setq ps-font-family 'Helvetica) - if you want to use this family in another Emacs session, you must put into your `~/.emacs': (require 'ps-print) (setq ps-font-info-database (append ...))) if you don't want to load ps-print, you have to copy the whole value: (setq ps-font-info-database '()) or, use `ps-print-hook' (see section Hooks): (add-hook 'ps-print-hook (lambda () (or (assq 'Helvetica ps-font-info-database) (setq ps-font-info-database (append ...))))) You can create new `mixed' font families like: (my-mixed-family (fonts (normal . "Courier-Bold") (bold . "Helvetica") (italic . "ZapfChancery-MediumItalic") (bold-italic . "NewCenturySchlbk-BoldItalic") (w3-table-hack-x-face . "LineDrawNormal")) (size . 10.0) (line-height . 10.55) (space-width . 6.0) (avg-char-width . 6.0)) Now you can use your new font family with any size: (setq ps-font-family 'my-mixed-family) Note that on above example the `w3-table-hack-x-face' entry refers to a face symbol, so when printing this face it'll be used the font `LineDrawNormal'. If the face `w3-table-hack-x-face' is remapped to use bold and/or italic attribute, the corresponding entry (bold, italic or bold-italic) will be used instead of `w3-table-hack-x-face' entry. Note also that the font family entry order is irrelevant, so the above example could also be written: (my-mixed-family (size . 10.0) (fonts (w3-table-hack-x-face . "LineDrawNormal") (bold . "Helvetica") (bold-italic . "NewCenturySchlbk-BoldItalic") (italic . "ZapfChancery-MediumItalic") (normal . "Courier-Bold")) (avg-char-width . 6.0) (space-width . 6.0) (line-height . 10.55)) Despite the note above, it is recommended that some convention about entry order be used. You can get information on all the fonts resident in YOUR printer by uncommenting the line: % 3 cm 20 cm moveto ReportAllFontInfo showpage The PostScript file should be sent to YOUR PostScript printer. If you send it to ghostscript or to another PostScript printer, you may get slightly different results. Anyway, as ghostscript fonts are autoload, you won't get much font info. Note also that ps-print DOESN'T download any font to your printer, instead it uses the fonts resident in your printer. How Ps-Print Deals With Faces ----------------------------- The ps-print-*-with-faces commands attempt to determine which faces should be printed in bold or italic, but their guesses aren't always right. For example, you might want to map colors into faces so that blue faces print in bold, and red faces in italic. It is possible to force ps-print to consider specific faces bold, italic or underline, no matter what font they are displayed in, by setting the variables `ps-bold-faces', `ps-italic-faces' and `ps-underlined-faces'. These variables contain lists of faces that ps-print should consider bold, italic or underline; to set them, put code like the following into your init file: (setq ps-bold-faces '(my-blue-face)) (setq ps-italic-faces '(my-red-face)) (setq ps-underlined-faces '(my-green-face)) Faces like bold-italic that are both bold and italic should go in *both* lists. ps-print keeps internal lists of which fonts are bold and which are italic; these lists are built the first time you invoke ps-print. For the sake of efficiency, the lists are built only once; the same lists are referred in later invocations of ps-print. Because these lists are built only once, it's possible for them to get out of sync, if a face changes, or if new faces are added. To get the lists back in sync, you can set the variable `ps-build-face-reference' to t, and the lists will be rebuilt the next time ps-print is invoked. If you need that the lists always be rebuilt when ps-print is invoked, set the variable `ps-always-build-face-reference' to t. If you need to print without worrying about face background color, set the variable `ps-use-face-background' which specifies if face background should be used. Valid values are: t always use face background color. nil never use face background color. (face...) list of faces whose background color will be used. Any other value will be treated as t. The default value is nil. How Ps-Print Deals With Color ----------------------------- ps-print detects faces with foreground and background colors defined and embeds color information in the PostScript image. The default foreground and background colors are defined by the variables `ps-default-fg' and `ps-default-bg'. On black/white printers, colors are displayed in gray scale. To turn off color output, set `ps-print-color-p' to nil. You can also set `ps-print-color-p' to 'black-white to have a better looking on black/white printers. See also `ps-black-white-faces' for documentation. ps-print also detects if the text foreground and background colors are equals when `ps-fg-validate-p' is non-nil. In this case, if these colors are used, no text will appear. You can use `ps-fg-list' to give a list of foreground colors to be used when text foreground and background colors are equals. It'll be used the first foreground color in `ps-fg-list' which is different from the background color. If `ps-fg-list' is nil, the default foreground color is used. How Ps-Print Maps Faces ----------------------- As ps-print uses PostScript to print buffers, it is possible to have other attributes associated with faces. So the new attributes used by ps-print are: strikeout - like underline, but the line is in middle of text. overline - like underline, but the line is over the text. shadow - text will have a shadow. box - text will be surrounded by a box. outline - print characters as hollow outlines. See the documentation for `ps-extend-face'. Let's, for example, remap `font-lock-keyword-face' to another foreground color and bold attribute: (ps-extend-face '(font-lock-keyword-face "RoyalBlue" nil bold) 'MERGE) If you want to use a new face, define it first with `defface', and then call `ps-extend-face' to specify how to print it. How Ps-Print Has A Text And/Or Image On Background -------------------------------------------------- ps-print can print texts and/or EPS PostScript images on background; it is possible to define the following text attributes: font name, font size, initial position, angle, gray scale and pages to print. It has the following EPS PostScript images attributes: file name containing the image, initial position, X and Y scales, angle and pages to print. See documentation for `ps-print-background-text' and `ps-print-background-image'. For example, if we wish to print text "preliminary" on all pages and text "special" on page 5 and from page 11 to page 17, we could specify: (setq ps-print-background-text '(("preliminary") ("special" "LeftMargin" "BottomMargin PrintHeight add" ; X and Y position ; (upper left corner) nil nil nil "PrintHeight neg PrintPageWidth atan" ; angle 5 (11 . 17)) ; page list )) Similarly, we could print image "~/images/EPS-image1.ps" on all pages and image "~/images/EPS-image2.ps" on page 5 and from page 11 to page 17, we specify: (setq ps-print-background-image '(("~/images/EPS-image1.ps" "LeftMargin" "BottomMargin") ; X and Y position (lower left corner) ("~/images/EPS-image2.ps" "LeftMargin" "BottomMargin PrintHeight 2 div add" ; X and Y pos. ; (upper left corner) nil nil nil 5 (11 . 17)) ; page list )) If it is not possible to read (or does not exist) an image file, that file is ignored. The printing order is: 1. Print background color 2. Print zebra stripes 3. Print background texts that it should be on all pages 4. Print background images that it should be on all pages 5. Print background texts only for current page (if any) 6. Print background images only for current page (if any) 7. Print header 8. Print buffer text (with faces, if specified) and line number Utilities --------- Some tools are provided to help you customize your font setup. `ps-setup' returns (some part of) the current setup. To avoid wrapping too many lines, you may want to adjust the left and right margins and the font size. On UN*X systems, do: pr -t file | awk '{printf "%3d %s\n", length($0), $0}' | sort -r | head to determine the longest lines of your file. Then, the command `ps-line-lengths' will give you the correspondence between a line length (number of characters) and the maximum font size which doesn't wrap such a line with the current ps-print setup. The commands `ps-nb-pages-buffer' and `ps-nb-pages-region' display the correspondence between a number of pages and the maximum font size which allow the number of lines of the current buffer or of its current region to fit in this number of pages. NOTE: line folding is not taken into account in this process and could change the results. The command `ps-print-customize' activates a customization buffer for ps-print options. New since version 1.5 --------------------- Color output capability. Automatic detection of font attributes (bold, italic). Configurable headers with page numbers. Slightly faster. Support for different paper sizes. Better conformance to PostScript Document Structure Conventions. New since version 2.8 --------------------- [vinicius] Vinicius Jose Latorre 2007-10-27 `ps-fg-validate-p', `ps-fg-list' 2004-02-29 `ps-time-stamp-yyyy-mm-dd', `ps-time-stamp-iso8601' 2001-06-19 `ps-time-stamp-locale-default' 2001-05-30 Handle before-string and after-string overlay properties. 2001-04-07 `ps-line-number-color', `ps-print-footer', `ps-footer-offset', `ps-print-footer-frame', `ps-footer-font-family', `ps-footer-font-size', `ps-footer-line-pad', `ps-footer-lines', `ps-left-footer', `ps-right-footer', `ps-footer-frame-alist' and `ps-header-frame-alist'. 2001-03-28 `ps-line-spacing', `ps-paragraph-spacing', `ps-paragraph-regexp', `ps-begin-cut-regexp' and `ps-end-cut-regexp'. 2000-11-22 `ps-line-number-font', `ps-line-number-font-size' and `ps-end-with-control-d'. 2000-08-21 `ps-even-or-odd-pages' 2000-06-17 `ps-manual-feed', `ps-warn-paper-type', `ps-print-upside-down', `ps-selected-pages', `ps-last-selected-pages', `ps-restore-selected-pages', `ps-switch-header', `ps-line-number-step', `ps-line-number-start', `ps-zebra-stripe-follow' and `ps-use-face-background'. 2000-03-10 PostScript error handler. `ps-user-defined-prologue' and `ps-error-handler-message'. 1999-12-11 `ps-print-customize'. 1999-07-03 Better customization. `ps-banner-page-when-duplexing' and `ps-zebra-color'. 1999-05-13 N-up printing. Hook: `ps-print-begin-sheet-hook'. [kenichi] 1999-05-09 Ken'ichi Handa `ps-print-region-function' [vinicius] Vinicius Jose Latorre 1999-03-01 PostScript tumble and setpagedevice. 1998-09-22 PostScript prologue header comment insertion. Skip invisible text better. [kenichi] 1998-08-19 Ken'ichi Handa Multi-byte buffer handling. [vinicius] Vinicius Jose Latorre 1998-03-06 Skip invisible text. 1997-11-30 Hooks: `ps-print-hook', `ps-print-begin-page-hook' and `ps-print-begin-column-hook'. Put one header per page over the columns. Better database font management. Better control characters handling. 1997-11-21 Dynamic evaluation at print time of `ps-lpr-switches'. Handle control characters. Face remapping. New face attributes. Line number. Zebra stripes. Text and/or image on background. [jack] 1996-05-17 Jacques Duthen Font family and float size for text and header. Landscape mode. Multiple columns. Tools for page setup. Known bugs and limitations of ps-print -------------------------------------- Automatic font-attribute detection doesn't work well. Users having problems with auto-font detection should use the lists `ps-italic-faces', `ps-bold-faces' and `ps-underlined-faces' and/or turn off automatic detection by setting `ps-auto-font-detect' to nil. Still too slow; could use some hand-optimization. Default background color isn't working. Faces are always treated as opaque. Fixed-pitch fonts work better for line folding, but are not required. `ps-nb-pages-buffer' and `ps-nb-pages-region' don't take care of folding lines. Things to change ---------------- Avoid page break inside a paragraph. Add `ps-non-bold-faces' and `ps-non-italic-faces' (should be easy). Improve the memory management for big files (hard?). `ps-nb-pages-buffer' and `ps-nb-pages-region' should take care of folding lines. Acknowledgments --------------- Thanks to Eduard Wiebe for fixing face background/foreground extraction. Thanks to Friedrich Delgado Friedrichs for new label printer page sizes. Thanks to Michael Piotrowski for improving the DSC compliance of the generated PostScript. Thanks to Adam Doppelt for face mapping suggestion for black/white PostScript printers. Thanks to Toni Ronkko for line and paragraph spacing, region to cut out when printing and footer suggestions. Thanks to Pavel Janik ml for documentation correction. Thanks to Corinne Ilvedson for line number font size suggestion. Thanks to Gord Wait for `ps-user-defined-prologue' example setting for HP PostScript printer. Thanks to Paul Furnanz for XEmacs compatibility suggestion for `ps-postscript-code-directory' variable. Thanks to David X Callaway for helping debugging PostScript level 1 compatibility. Thanks to Colin Marquardt for: - upside-down, line number step, line number start and zebra stripe follow suggestions. - `ps-time-stamp-yyyy-mm-dd' and `ps-time-stamp-iso8601' suggestion. - and for XEmacs beta-tests. Thanks to Klaus Berndl for user defined PostScript prologue code suggestion, for odd/even printing suggestion and for `ps-prologue-file' enhancement. Thanks to Ken'ichi Handa for multi-byte buffer handling. Thanks to Matthew O Persico for line number on empty columns. Thanks to Theodore Jump for adjust PostScript code order on last page. Thanks to Roland Ducournau for `ps-print-control-characters' variable documentation. Thanks to Marcus G Daniels for a better database font management. Thanks to Martin Boyer for some ideas on putting one header per page over the columns and correct line numbers when printing a region. Thanks to Steven L Baur for dynamic evaluation at print time of `ps-lpr-switches'. Thanks to Kevin Rodgers for handling control characters (his code was severely modified, but the main idea was kept). Thanks to some suggestions on: * Face color map: Marco Melgazzi * XEmacs compatibility: William J. Henney * Check `ps-paper-type': Sudhakar Frederick Thanks to Jacques Duthen (Jack) for version 3.4 I started from. [vinicius] Thanks to Jim Thompson @?> for the 2.8 version I started from. [jack] Thanks to Kevin Rodgers for adding support for color and the invisible property. Thanks to Avishai Yacobi, avishaiy@mcil.comm.mot.com, for writing the initial port to Emacs 19. His code is no longer part of ps-print, but his work is still appreciated. Thanks to Remi Houdaille and Michel Train for adding underline support. Their code also is no longer part of ps-print, but their efforts are not forgotten. Thanks also to all of you who mailed code to add features to ps-print; although I didn't use your code, I still appreciate your sharing it with me. Thanks to all who mailed comments, encouragement, and criticism. Thanks also to all who responded to my survey; I had too many responses to reply to them all, but I greatly appreciate your interest. Jim ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;