From 81c7ca6923ca9431e92c76da199b08531d685da0 Mon Sep 17 00:00:00 2001 From: Gerd Moellmann Date: Wed, 15 Mar 2000 13:39:19 +0000 Subject: [PATCH] *** empty log message *** --- etc/ChangeLog | 6 +++ etc/ps-prin0.ps | 115 ++++++++++++++++++++++++++++++++++++++++++++++++ lisp/ChangeLog | 10 +++++ 3 files changed, 131 insertions(+) create mode 100644 etc/ps-prin0.ps diff --git a/etc/ChangeLog b/etc/ChangeLog index 8114b967728..f3511fc0ca4 100644 --- a/etc/ChangeLog +++ b/etc/ChangeLog @@ -1,3 +1,9 @@ +2000-03-15 Vinicius Jose Latorre + + * ps-print0.ps: New file. + + * ps-prin1.ps, ps-prin3.ps: Eliminate CheckConfig. + 2000-01-05 Vinicius Jose Latorre * ps-prin1.ps, ps-prin2.ps, ps-prin3.ps: New files. diff --git a/etc/ps-prin0.ps b/etc/ps-prin0.ps new file mode 100644 index 00000000000..a58b9888d26 --- /dev/null +++ b/etc/ps-prin0.ps @@ -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 diff --git a/lisp/ChangeLog b/lisp/ChangeLog index ff0533f6d99..445c90ae0a4 100644 --- a/lisp/ChangeLog +++ b/lisp/ChangeLog @@ -1,3 +1,13 @@ +2000-03-15 Vinicius Jose Latorre + + * 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 * international/ccl.el (ccl-compile-expression): Don't generate -- 2.39.5