changeset 28155:f568116325f9

*** empty log message ***
author Gerd Moellmann <gerd@gnu.org>
date Wed, 15 Mar 2000 13:39:19 +0000
parents 16202d8d02cf
children 2e784b17f85a
files etc/ChangeLog etc/ps-prin0.ps lisp/ChangeLog
diffstat 3 files changed, 131 insertions(+), 0 deletions(-) [+]
line wrap: on
line diff
--- a/etc/ChangeLog	Wed Mar 15 13:39:10 2000 +0000
+++ b/etc/ChangeLog	Wed Mar 15 13:39:19 2000 +0000
@@ -1,3 +1,9 @@
+2000-03-15  Vinicius Jose Latorre  <vinicius@cpqd.com.br>
+
+	* ps-print0.ps: New file.
+	
+	* ps-prin1.ps, ps-prin3.ps: Eliminate CheckConfig.
+
 2000-01-05  Vinicius Jose Latorre  <vinicius@cpqd.com.br>
 
 	* ps-prin1.ps, ps-prin2.ps, ps-prin3.ps: New files.
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/etc/ps-prin0.ps	Wed Mar 15 13:39:19 2000 +0000
@@ -0,0 +1,115 @@
+% === BEGIN ps-print prologue 0
+
+%%BeginProcSet: ErrorHandler
+% Downloaded Error Break-page handler
+% Adapted from:
+%     PostScript Language Program Design,
+%     Adobe Systems Incorporated.
+%     Appendix A, pages 217-219
+
+/ps$brkpage where{pop}
+{
+ /ps$brkpage 64 dict def
+ ps$brkpage begin
+  /tx 0 def /ty 0 def /toy 0 def /tox 0 def
+  /prnt{
+   dup type /stringtype ne{=string cvs}if
+   dup length 6 mul
+   /tx exch def /ty 10 def
+   currentpoint /toy exch def /tox exch def
+   1 setgray newpath
+   tox toy 2 sub moveto
+   0 ty rlineto tx 0 rlineto
+   0 ty neg rlineto
+   closepath fill
+   tox toy moveto 0 setgray show
+  }bind def
+  /nl{currentpoint exch pop lmargin exch moveto 0 -10 rmoveto}def
+  /=={/cp 0 def typeprint nl}def
+  /typeprint{dup type dup currentdict exch known{exec}{unknowntype}ifelse}readonly def
+  /lmargin 72 def
+  /rmargin 72 def
+  /tprint{
+   dup length cp add rmargin gt{nl /cp 0 def}if
+   dup length cp add /cp exch def
+   prnt
+  }readonly def
+  /cvsprint{=string cvs tprint( )tprint}readonly def
+  /unknowntype{exch pop cvlit(??)tprint cvsprint}readonly def
+  /integertype{cvsprint}readonly def
+  /realtype{cvsprint}readonly def
+  /booleantype{cvsprint}readonly def
+  /operatortype{(//)tprint cvsprint}readonly def
+  /marktype{pop(-mark-)tprint}readonly def
+  /dicttype{pop(-dictionary-)tprint}readonly def
+  /nulltype{pop(-null-)tprint}readonly def
+  /filetype{pop(-filestream-)tprint}readonly def
+  /savetype{pop(-savelevel-)tprint}readonly def
+  /fonttype{pop(-fontid-)tprint}readonly def
+  /nametype{dup xcheck not{(/)tprint}if cvsprint}readonly def
+  /stringtype{
+   dup rcheck
+   {(\()tprint tprint(\))tprint}
+   {pop(-string-)tprint}ifelse}readonly def
+  /arraytype{
+   dup rcheck
+   {dup xcheck
+    {({)tprint{typeprint}forall(})tprint}
+    {([)tprint{typeprint}forall(])tprint}ifelse}
+   {pop(-array-)tprint}ifelse}readonly def
+  /packedarraytype{
+   dup rcheck
+   {dup xcheck
+    {({)tprint{typeprint}forall(})tprint}
+    {([)tprint{typeprint}forall(])tprint}ifelse}
+   {pop(-packedarray-)tprint}ifelse}readonly def
+  /courier /Courier findfont 10 scalefont def
+  /OLDhandleerror errordict /handleerror get def
+ end %ps$brkpage
+
+ /handleerror{
+  systemdict begin $error begin ps$brkpage begin
+  newerror
+  {/newerror false store vmstatus pop pop 0 ne{grestoreall}if
+   initgraphics
+   ErrorMessage 1 and 0 ne{ % print on paper
+    courier setfont lmargin 720 moveto
+    (# ERROR: )prnt errorname prnt nl
+    (# OFFENDING COMMAND: )prnt /command load prnt
+    $error /ostack known
+    {nl nl(# STACK:)prnt nl nl $error /ostack get aload length{==}repeat}if
+    $error /errorinfo known
+    {nl nl(# ERRORINFO:)prnt nl nl $error /errorinfo get aload length{==}repeat}if
+    systemdict /showpage get exec}if
+   ErrorMessage 2 and 0 ne{ % send back to printing system
+    (\%\%[ Error: )print errorname =print
+    (; OffendingCommand: )print/command load =print
+    $error /errorinfo known
+    {(; ErrorInfo:)print $error /errorinfo get aload length{( )=print =print}repeat}if
+    ( ]\%\%)= flush
+    (\%\%[ Rest of job is ignored ]\%\%)= flush}if
+   /newerror true store}if
+  end end end
+  stop
+ } % handleerror
+ dup 0 systemdict put % replace name by actual dict object
+ dup 4 ps$brkpage put % replace name by dict object
+ bind readonly
+
+ errordict 3 1 roll put % put proc in errordict as /handleerror
+}ifelse
+%%EndProcSet
+
+gs_languagelevel 2 ne{ % operators for language level 2 only
+ /<<{mark}bind def
+ />>{counttomark 2 idiv dup dict begin{def}repeat pop currentdict end}bind def
+ /setpagedevice{pop}bind def
+}if
+
+/setduplexmode where{pop}
+{/setduplexmode /duplexmode where{pop{duplexmode}}{{pop}}ifelse bind def}ifelse
+
+/settumble where{pop}
+{/settumble /tumble where{pop{tumble}}{{pop}}ifelse bind def}ifelse
+
+% === END ps-print prologue 0
--- a/lisp/ChangeLog	Wed Mar 15 13:39:10 2000 +0000
+++ b/lisp/ChangeLog	Wed Mar 15 13:39:19 2000 +0000
@@ -1,3 +1,13 @@
+2000-03-15  Vinicius Jose Latorre  <vinicius@cpqd.com.br>
+
+	* ps-print.el: PostScript user-defined prologue, PostScript error
+	handler, doc fix.
+	(ps-print-version): New version number (5.1).
+	(ps-user-defined-prologue, ps-error-handler-message)
+	(ps-print-prologue-0, ps-error-handler-alist): New vars.
+	(ps-setup, ps-begin-file, ps-begin-job): Code fix.
+	(ps-insert-string): New function.
+	
 2000-03-15  Kenichi Handa  <handa@etl.go.jp>
 
 	* international/ccl.el (ccl-compile-expression): Don't generate