lamy@ai.toronto.edu (12/01/86)
I have received many requests for software that allows including Macintosh and other PostScript illustrations in TeX output. So here it comes, in 3 parts. dvi2ps.c A translator from TeX dvi output to PostScript. This version fixes trivial bugs (use of tolower under Berkeley) and trivial changes in the processing of \special inclusions. I've included it in its entirety because of popular demand. findfile.c findfile.h commands.h all used by above. Makefile cheapo version dvi2ps.1 n/troff version of the man page, courtesy bur@iro.udem.cdn tex.ps The header file used by dvi2ps. This version modified to be more portable and to behave itself properly wrt PostScript illustrations. Overrides some definitions from the LaserPrep file below. LaserPrep.uu uuencoded version of LaserPrep.ps The header file needed for Macintosh illustrations, with all the patches that made it here. I have broken so many mailers and it has been damaged by so many other mailers that I had to choose that route. Bugs you don't report won't get fixed. In the queue: including troff preprocessor (pic, grap, S, ideal, ...) output in TeX documents, and posting the software we have here for doing inclusions in troff documents. Jean-Francois Lamy AI Group, Dept of Computer Science CSNet: lamy@ai.toronto.edu University of Toronto EAN: lamy@ai.toronto.cdn Toronto, ON, Canada M5S 1A4 UUCP: lamy@utai.uucp ------------------------------------------------------------------------------- #! /bin/sh # This is a shell archive, meaning: # 1. Remove everything above the #! /bin/sh line. # 2. Save the resulting text in a file. # 3. Execute the file with /bin/sh (not csh) to create the files: # dvi2ps.l # Makefile # tex.ps # commands.h # findfile.h # This archive created: Sun Nov 30 19:04:41 1986 export PATH; PATH=/bin:$PATH if test -f 'dvi2ps.l' then echo shar: will not over-write existing file "'dvi2ps.l'" else cat << \SHAR_EOF > 'dvi2ps.l' .TH DVI2PS 1 "14 November 1986" .SH NAME dvi2ps \- convert a DVI file to PostScript .SH SYNOPSIS .B dvi2ps .RB [ \-a .IR pxldir ] .RB [ \-c ] .RB [ \-d ] .RB [ \-f .IR n ] .RB [ \-h ] .RB [ \-i .IR file ] .RB [ \-m .IR n ] .if n .ti +0.5i .RB [ \-n .IR n ] .RB [ \-o .IR str ] .RB [ \-p ] .RB [ \-q ] .if t .ti +0.5i .RB [ \-r ] .RB [ \-s ] .RB [ \-t .IR n ] .RB [ \-w ] .if n .ti +0.5i \fIdvifile\fP[\fB.dvi\fP] .SH DESCRIPTION This program converts a DVI file to PostScript, and writes the result to standard output. The result requires a small amount of PostScript source to precede it to the printer, before it can be successfully printed. (By default, that PostScript code is prepended to the output.) .SH OPTIONS .IP "\fB\-a \fIpxldir" specify different area for PXL files. Directory .I pxldir is searched for all PXL files, instead of the default directory. .IP \fB\-c create an output file in the spool directory. This is fairly Apollo-specific, and may be disabled at other sites. When given, the output is directed to a file with a unique name, created in a spool directory. .IP \fB\-d select debugging output (you probably don't want to). .IP "\fB\-f \fIn" specify a starting page number (this is a TeX page number \- \\count0). .IP \fB\-h do not copy the standard header file. This option prevents the standard PostScript header file being prepended to the output. .IP "\fB\-i \fIfile" copy the named file to the output. The contents of the file named will be copied to the output after the standard header file has been copied. .TP \fB\-m0\fP | \fB\-mh\fP | \fB\-m1\fP | \fB\-m2\fP | \fB\-m3\fP | \fB\-m4\fP specify a magstep to use to print the document. This overrides whatever might be in the DVI file. .IP "\fB\-m \fIn" specify a magnification to use to print the document. This should probably be one of the magic numbers 1000, 1095, 1200, 1440, 1728, or 2074, but no checking is done. Note: if your site does not have the complete set of 300 dpi fonts, this option might be disabled. .IP "\fB\-n \fIn" specify the number of copies to print. .IP "\fB\-o \fIstr" specify a printing option. Valid options are .BR letter , .BR note , .BR legal , .BR landscape , .BR envelope , and .BR manualfeed . This argument may be repeated several times. .B envelope is a variant of .B landscape that selects manual feed and does proper positioning for regular envelopes. .IP \fB\-p do not preload font information. Occasionally there may be insufficent memory to hold the information about all of the fonts in the system. Portions of the document may be converted by including the .B \-p option on the command line. This will prevent the preloading of all fonts into the system and instead use demand loading of the font tables. .IP \fB\-q be quiet. Don't chatter about pages converted, etc. .IP \fB\-r stack pages in reverse order. Normally, the DVI pages are processed in reverse order, with the result that they are stacked in the correct order in the output tray. This option reverses that. .IP \fB\-s turn on printing of statistics. Some versions of .I dvi2ps will optionally print statistics about font usage and some other information that is generally only interesting to developers. On these systems, .B \-s turns on the statistics printing. .IP "\fB\-t \fIn" specify an ending page number. .IP \fB\-w Don't print out warnings. .SH NOTES This is a `bare bones' DVI-to-PostScript program. Minimal error checking is done. Not all fonts are available in the resolution needed to display on the laser printer; when a missing font is encountered, .I dvi2ps will continue to process your DVI file, and will log a warning message. Gaps will appear in the document where the missing characters should have been. It can take up to 60 seconds for the first page to be output. After a head of steam has been built up, it can roll along at 5-10 seconds per page. .SH PostScript ILLUSTRATIONS This program supports use of the \fB\\special\fP command in TeX to include special PostScript code for graphics, etc. Specifying \fB\\special{psfile=foo.ps}\fP in the TeX source will result in the contents of file .I foo.ps (assumed to contain PostScript code) being copied into the output at that point. For most included graphics, the user's (0,0) point will be set to the point of the \fB\\special\fP command with .I x and .I y coordinates increasing up and to the right and in units of PostScript points (72/inch) \(em thus you must explicitly leave space above the \fB\\special\fP command for most graphics. For graphics produced by Apple Macintoshes (i.e., MacDraw, MacPaint, etc.), the top left corner of the drawing will be at the point of the \fB\\special\fP command; in this case you must leave the required space below the \fB\\special\fP. The \fB\\special\fP string can contain any number of the following .I keyword=value pairs, separated by blanks: .ta 10n .TP 24n \fIKeyword Value Type (dimensions in points: 72 pt = 1 in) .TP psfile string \- PostScript file to include .PD 0 .TP hsize dimension \- maximum horizontal size (for clipping) .TP vsize dimension \- maximum vertical size (for clipping). Use negative values to specify a clipping region below the current position. .TP hoffset dimension \- amount to shift right .TP voffset dimension \- amount to shift up .TP hscale number \- scale factor in x-dimension .TP vscale number \- scale factor in y-dimension .TP rotation number \- counter-clockwise rotation angle .PD .DT .PP Thus: .ce \fB\\special{psfile=foo.ps hoffset=72 hscale=0.9 vscale=0.9}\fP will shift the graphics produced by file .I foo.ps right by 1", and will draw it at 0.9 normal size. .B hsize and .B vsize are given relative to the (0,0) point of the drawing and are unaffected by offsets and scales. Offsets are given relative to the point of the \fB\\special\fP command, and are unaffected by scales. If Macintosh drawings are to be included, the proper LaserPrep file must be downloaded to the printer, either permanently or as another header file in addition to the standard .I tex.ps header file. .SH FILES .PD 0 .TP 2.2i *.dvi TeX DeVice Independent output file .TP /usr/lib/tex/fonts/*.*pxl default area for PXL files (TeX font rasters) .TP /usr/lib/tex/ps/tex.ps PostScript support code .PD .SH "SEE ALSO" tex(1) .SH BUGS There is likely a limit to the size of documents that can be printed (at least, on the Apple LaserWriter). If you get VMerrors reported when printing, use the .B \-f and .B \-t options, to select a range of pages. The exact limit is unknown, but is probably well in excess of 50 pages for `normal' documents, decreasing with number of different fonts used, size of fonts, etc. .SH AUTHORS Mark Senn wrote the early versions of this program for the BBN BitGraph. Stephan Bechtolsheim, Bob Brown, Richard Furuta, James Schaad and Robert Wells improved it. Norm Hutchinson ported the program to the Sun. Neal Holtz ported it to the Apollo, and then to produce PostScript. Scott Jones added intelligent font substitution. Jean-Francois Lamy fixed the interface for PostScript illustrations. (PostScript is a trademark of Adobe Systems, Inc.) SHAR_EOF fi # end of overwriting check if test -f 'Makefile' then echo shar: will not over-write existing file "'Makefile'" else cat << \SHAR_EOF > 'Makefile' # The following file and directory specifications may need changing at # your site: # # where are the bitmaps stored? FONTAREA=/usr/lib/tex/fonts # # where is the header file to be found? # (Here, the ps directory under lib/tex is in fact a link to where all ps # files are kept. You must create a directory or a link yourself) HDRFILE=/usr/lib/tex/ps/tex.ps # # where is the software to be installed BINAREA=/usr/local # # an Apollo-specific spool file SPOOLFILE=/usr/spool/laserwriter/apollo # CFLAGS = -DFONTAREA=\"${FONTAREA}\" -DHDRFILE=\"${HDRFILE}\" \ -DSPOOLFILE=\"${SPOOLFILE}\" -O all: dvi2ps dvi2ps: dvi2ps.o findfile.o cc ${CFLAGS} -o dvi2ps dvi2ps.o findfile.o install: all install -s -m 755 dvi2ps ${BINAREA}/dvi2ps cp tex.ps ${HDRFILE} # # The following may be useful if you are trying to run this as a # printcap filter # applef: applef.c ${CC} -o applef ${CFLAGS} applef.c dvipsf: dvipsf.c ${CC} -o dvipsf ${CFLAGS} dvipsf.c SHAR_EOF fi # end of overwriting check if test -f 'tex.ps' then echo shar: will not over-write existing file "'tex.ps'" else cat << \SHAR_EOF > 'tex.ps' %! $Header: tex.ps,v 1.5 86/11/27 10:30:54 lamy Exp $ % % for use by dvi2ps Version 2.11 or later. % % a start (Ha!) at a TeX mode for PostScript. % The following defines procedures assumed and used by program "dvi2ps" % and must be downloaded or sent as a header file for all TeX jobs. % % Original author: % Neal Holtz, Carleton University, Ottawa, Canada % <holtz@cascade.carleton.cdn> % <holtz%cascade.carleton.cdn@relay.cs.net> % June, 1985 Last Modified: Aug 25/85 % % PostScript illustration support: % Jean-Francois Lamy, AI group, University of Toronto, Canada % lamy@ai.toronto.edu, lamy@ai.toronto.cdn % % $Log: tex.ps,v $ % Revision 1.5 86/11/27 10:30:54 lamy % Mixing Mac and other PostScript illustrations now possible. % vsize positive now means "above current point". % % Revision 1.4 86/10/30 12:43:24 lamy % Now uses the rotate operator for landscape and envelope modes. % Used to be convoluted, non portable code to avoid round-off errors % that do not seem to be present on any of our printers. % % Revision 1.3 86/10/30 12:27:50 lamy % Fixed bug in @bop1 that caused top lines to be clipped when using proc.sty % % 86-07-17 jfl % Added envelope keyword definition. Same as landscape but positioned % so that an envelope inserted upside down is printed correctly % This reduces the occurence of paper jams. % % 86-06-23 JF Lamy, U. of Toronto <lamy@ai.toronto.edu, lamy@utai.uucp> % Updated to support the Macintosh LaserWriter driver version 3.x % instead of 1.1. Added rotation of illustrations. % % oystr 12-Feb-1986 % Changed @dc macro to check for badly formed bits in character % definitions. Can get a <> bit map if a character is not actually % in the font file. This is absolutely guaranteed to drive the % printer nuts - it will appear that you can no longer define a % new font, although the built-ins will still be there. % % To convert this file into a downloaded file instead of a header % file, uncomment all of the lines beginning with %-% %-%0000000 % Server loop exit password %-%serverdict begin exitserver %-% systemdict /statusdict known %-% {statusdict begin 9 0 3 setsccinteractive /waittimeout 300 def end} %-% if /TeXDict 200 dict def % define a working dictionary TeXDict begin % start using it. % units are in "dots" (300/inch) /Resolution 300 def /Inch {Resolution mul} def % converts inches to internal units /PageCounter statusdict begin pagecount end def % so we can report # pages printed /Mtrx 6 array def %%%%%%%%%%%%%%%%%%%%% Page setup (user) options %%%%%%%%%%%%%%%%%%%%%%%% % dvi2ps will output coordinates in the TeX system ([0,0] 1" down and in % from top left, with y +ive downward). The default PostScript system % is [0,0] at bottom left, y +ive up. The Many Matrix Machinations in % the following code are an attempt to reconcile that. The intent is to % specify the scaling as 1 and have only translations in the matrix to % properly position the text. Caution: the default device matrices are % *not* the same in all PostScript devices; that should not matter in most % of the code below (except for lanscape mode -- in that, rotations of % -90 degrees resulted in the the rotation matrix [ e 1 ] % [ 1 e ] % where the "e"s were almost exactly but not quite zeros. % /@letter { letter initmatrix 72 Resolution div dup neg scale % set scaling to 1. 310 -3005 translate % move origin to top (these are not exactly 1" Mtrx currentmatrix pop % and -10" because margins aren't set exactly right) } def % note mode is like letter, except it uses less VM /@note { note initmatrix 72 Resolution div dup neg scale % set scaling to 1. 310 -3005 translate % move origin to top Mtrx currentmatrix pop } def /@landscape { letter initmatrix 72 Resolution div dup neg scale % set scaling to 1. -90 rotate % it would be nice to be able to do this % Mtrx currentmatrix 0 0.0 put % but instead we have to do things % % like this because what should be zero % Mtrx 1 -1.0 put % terms aren't (and text comes out wobbly) % Mtrx 2 1.0 put % Fie! This likely will not work on QMS printers % Mtrx 3 0.0 put % (nor on others where the device matrix is not like % Mtrx setmatrix % like it is on the LaserWriter). 300 310 translate % move origin to top Mtrx currentmatrix pop } def /@legal { legal initmatrix 72 Resolution div dup neg scale % set scaling to 1. 295 -3880 translate % move origin to top Mtrx currentmatrix pop } def /@manualfeed { statusdict /manualfeed true put } def % n @copies - set number of copies /@envelope { statusdict /manualfeed true put letter initmatrix 72 Resolution div dup neg scale -90 rotate % Mtrx currentmatrix 0 0.0 put % Mtrx 1 -1.0 put % Mtrx 2 1.0 put % Mtrx 3 0.0 put % Mtrx setmatrix 450 1275 translate % upper right corner of regular envelope % when fed manually 300 310 translate Mtrx currentmatrix pop } def /@copies { /#copies exch def } def %%%%%%%%%%%%%%%%%%%% Procedure Defintions %%%%%%%%%%%%%%%%%%%%%%%%%% /@newfont % id @newfont - -- initialize a new font dictionary { /newname exch def pop newname 7 dict def % allocate new font dictionary newname load begin /FontType 3 def /FontMatrix [1 0 0 -1 0 0] def /FontBBox [0 0 1 1] def /BitMaps 128 array def /BuildChar {CharBuilder} def /Encoding 128 array def 0 1 127 {Encoding exch /.undef put} for end newname newname load definefont pop } def % the following is the only character builder we need. it looks up the % char data in the BitMaps array, and paints the character if possible. % char data -- a bitmap descriptor -- is an array of length 6, of % which the various slots are: /ch-image {ch-data 0 get} def % the hex string image /ch-width {ch-data 1 get} def % the number of pixels across /ch-height {ch-data 2 get} def % the number of pixels tall /ch-xoff {ch-data 3 get} def % number of pixels below origin /ch-yoff {ch-data 4 get} def % number of pixels to left of origin /ch-tfmw {ch-data 5 get} def % spacing to next character /CharBuilder % fontdict ch Charbuilder - -- image one character { /ch-code exch def % save the char code /font-dict exch def % and the font dict. /ch-data font-dict /BitMaps get ch-code get def % get the bitmap descriptor for char ch-data null eq not { ch-tfmw 0 ch-xoff neg ch-yoff neg ch-width ch-xoff sub ch-height ch-yoff sub setcachedevice ch-width ch-height true [1 0 0 1 ch-xoff ch-yoff] {ch-image} imagemask } if } def /@sf % fontdict @sf - -- make that the current font { setfont() pop } def % in the following, the font-cacheing mechanism requires that % a name unique in the particular font be generated /@dc % char-data ch @dc - -- define a new character bitmap { /ch-code exch def % ++oystr 12-Feb-86++ dup 0 get length 2 lt { pop [ <00> 1 1 0 0 8.00 ] } % replace <> with null if % --oystr 12-Feb-86-- /ch-data exch def currentfont /BitMaps get ch-code ch-data put currentfont /Encoding get ch-code dup ( ) cvs cvn % generate a unique name simply from the character code put } def /@bop0 % n @bop0 - -- begin the char def section of a new page { } def /@bop1 % n @bop1 - -- begin a brand new page { pop erasepage initgraphics Mtrx setmatrix 0 0 moveto /SaveImage save def } def /@eop % - @eop - -- end a page { showpage SaveImage restore } def /@start % - @start - -- start everything { @note % (there is not much to do) } def /@end % - @end - -- done the whole shebang { end } def /p % x y p - -- move to position { moveto } def /r % x r - -- move right { 0 rmoveto } def /s % string s - -- show the string { show } def /c % ch c - -- show the character (code given) { c-string exch 0 exch put c-string show } def /c-string ( ) def /ru % dx dy ru - -- set a rule (rectangle) { /dy exch neg def % because dy is height up from bottom /dx exch def /x currentpoint /y exch def def % remember current point newpath x y moveto dx 0 rlineto 0 dy rlineto dx neg 0 rlineto closepath fill x y moveto } def %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% %% the \special command junk %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % The structure of the PostScript produced by dvi2ps for \special is: % @beginspecial % - any number of @hsize, @hoffset, @hscale, etc., commands % @setspecial % - the users file of PostScript commands % @endspecial % The @beginspecial command recognizes whether the Macintosh Laserprep % has been loaded or not, and redfines some Mac commands if so. % The @setspecial handles the users shifting, scaling, clipping commands % The following are user settable options from the \special command. /@SpecialDefaults { /hsi 72 8.5 mul def % 8.5 Inch def /vsi 72 11 mul def % 11 Inch def /hof 0 def /vof 0 def /hsc 1 def /vsc 1 def /rotat 0 def /CLIP false def } def % d @hsize - specify a horizontal clipping dimension % these 2 are executed before the MacDraw initializations /@hsize {/hsi exch def /CLIP true def} def /@vsize {/vsi exch def /CLIP true def} def % d @hoffset - specify a shift for the drwgs /@hoffset {/hof exch def} def /@voffset {/vof exch def} def % s @hscale - set scale factor /@hscale {/hsc exch def} def /@vscale {/vsc exch def} def % r @rotation - set rotation angle /@rotation {/rotat exch def} def /@setclipper { CLIP { newpath 0 0 moveto hsi 0 rlineto 0 vsi rlineto hsi neg 0 rlineto closepath clip } if } def % this will be invoked as the result of a \special command (for the % inclusion of PostScript graphics). The basic idea is to change all % scaling and graphics back to defaults, but to shift the origin % to the current position on the page (left margin?) /@beginspecial % - @beginspecial - -- enter special mode { gsave /SpecialSave save def % the following magic incantation establishes the current point as % the users origin, and reverts back to default scalings, rotations currentpoint transform initgraphics itransform translate @SpecialDefaults % setup default offsets, scales, sizes @MacSetUp % fix up Mac stuff } def /@setspecial % to setup user specified offsets, scales, sizes (for clipping) { hof vof translate @setclipper hsc vsc scale rotat rotate } def /@endspecial % - @endspecial - -- leave special mode { SpecialSave restore grestore } def % - @MacSetUp - turn-off/fix-up all the LaserPrep stuff that might hurt us /@MacSetUp { userdict /md known % if md is defined { userdict /md get type /dicttype eq % and if it is a dictionary { /MacDrwgs true def md begin % then redefine some stuff /txpose{ 1 -1 scale % make y coordinates relative to top of figure } bind def % ignore Mac page breaks /cp {pop pop} bind def end } if } if } def end % revert to previous dictionary SHAR_EOF fi # end of overwriting check if test -f 'commands.h' then echo shar: will not over-write existing file "'commands.h'" else cat << \SHAR_EOF > 'commands.h' /* * * $Revision: 1.1 $ * $Log: commands.h,v $ * Revision 1.1 83/11/23 10:56:00 mds * Initial revision * * */ #define SETC_000 0 #define SETC_001 1 #define SETC_002 2 #define SETC_003 3 #define SETC_004 4 #define SETC_005 5 #define SETC_006 6 #define SETC_007 7 #define SETC_008 8 #define SETC_009 9 #define SETC_010 10 #define SETC_011 11 #define SETC_012 12 #define SETC_013 13 #define SETC_014 14 #define SETC_015 15 #define SETC_016 16 #define SETC_017 17 #define SETC_018 18 #define SETC_019 19 #define SETC_020 20 #define SETC_021 21 #define SETC_022 22 #define SETC_023 23 #define SETC_024 24 #define SETC_025 25 #define SETC_026 26 #define SETC_027 27 #define SETC_028 28 #define SETC_029 29 #define SETC_030 30 #define SETC_031 31 #define SETC_032 32 #define SETC_033 33 #define SETC_034 34 #define SETC_035 35 #define SETC_036 36 #define SETC_037 37 #define SETC_038 38 #define SETC_039 39 #define SETC_040 40 #define SETC_041 41 #define SETC_042 42 #define SETC_043 43 #define SETC_044 44 #define SETC_045 45 #define SETC_046 46 #define SETC_047 47 #define SETC_048 48 #define SETC_049 49 #define SETC_050 50 #define SETC_051 51 #define SETC_052 52 #define SETC_053 53 #define SETC_054 54 #define SETC_055 55 #define SETC_056 56 #define SETC_057 57 #define SETC_058 58 #define SETC_059 59 #define SETC_060 60 #define SETC_061 61 #define SETC_062 62 #define SETC_063 63 #define SETC_064 64 #define SETC_065 65 #define SETC_066 66 #define SETC_067 67 #define SETC_068 68 #define SETC_069 69 #define SETC_070 70 #define SETC_071 71 #define SETC_072 72 #define SETC_073 73 #define SETC_074 74 #define SETC_075 75 #define SETC_076 76 #define SETC_077 77 #define SETC_078 78 #define SETC_079 79 #define SETC_080 80 #define SETC_081 81 #define SETC_082 82 #define SETC_083 83 #define SETC_084 84 #define SETC_085 85 #define SETC_086 86 #define SETC_087 87 #define SETC_088 88 #define SETC_089 89 #define SETC_090 90 #define SETC_091 91 #define SETC_092 92 #define SETC_093 93 #define SETC_094 94 #define SETC_095 95 #define SETC_096 96 #define SETC_097 97 #define SETC_098 98 #define SETC_099 99 #define SETC_100 100 #define SETC_101 101 #define SETC_102 102 #define SETC_103 103 #define SETC_104 104 #define SETC_105 105 #define SETC_106 106 #define SETC_107 107 #define SETC_108 108 #define SETC_109 109 #define SETC_110 110 #define SETC_111 111 #define SETC_112 112 #define SETC_113 113 #define SETC_114 114 #define SETC_115 115 #define SETC_116 116 #define SETC_117 117 #define SETC_118 118 #define SETC_119 119 #define SETC_120 120 #define SETC_121 121 #define SETC_122 122 #define SETC_123 123 #define SETC_124 124 #define SETC_125 125 #define SETC_126 126 #define SETC_127 127 #define SET1 128 #define SET2 129 #define SET3 130 #define SET4 131 #define SET_RULE 132 #define PUT1 133 #define PUT2 134 #define PUT3 135 #define PUT4 136 #define PUT_RULE 137 #define NOP 138 #define BOP 139 #define EOP 140 #define PUSH 141 #define POP 142 #define RIGHT1 143 #define RIGHT2 144 #define RIGHT3 145 #define RIGHT4 146 #define W0 147 #define W1 148 #define W2 149 #define W3 150 #define W4 151 #define X0 152 #define X1 153 #define X2 154 #define X3 155 #define X4 156 #define DOWN1 157 #define DOWN2 158 #define DOWN3 159 #define DOWN4 160 #define Y0 161 #define Y1 162 #define Y2 163 #define Y3 164 #define Y4 165 #define Z0 166 #define Z1 167 #define Z2 168 #define Z3 169 #define Z4 170 #define FONT_00 171 #define FONT_01 172 #define FONT_02 173 #define FONT_03 174 #define FONT_04 175 #define FONT_05 176 #define FONT_06 177 #define FONT_07 178 #define FONT_08 179 #define FONT_09 180 #define FONT_10 181 #define FONT_11 182 #define FONT_12 183 #define FONT_13 184 #define FONT_14 185 #define FONT_15 186 #define FONT_16 187 #define FONT_17 188 #define FONT_18 189 #define FONT_19 190 #define FONT_20 191 #define FONT_21 192 #define FONT_22 193 #define FONT_23 194 #define FONT_24 195 #define FONT_25 196 #define FONT_26 197 #define FONT_27 198 #define FONT_28 199 #define FONT_29 200 #define FONT_30 201 #define FONT_31 202 #define FONT_32 203 #define FONT_33 204 #define FONT_34 205 #define FONT_35 206 #define FONT_36 207 #define FONT_37 208 #define FONT_38 209 #define FONT_39 210 #define FONT_40 211 #define FONT_41 212 #define FONT_42 213 #define FONT_43 214 #define FONT_44 215 #define FONT_45 216 #define FONT_46 217 #define FONT_47 218 #define FONT_48 219 #define FONT_49 220 #define FONT_50 221 #define FONT_51 222 #define FONT_52 223 #define FONT_53 224 #define FONT_54 225 #define FONT_55 226 #define FONT_56 227 #define FONT_57 228 #define FONT_58 229 #define FONT_59 230 #define FONT_60 231 #define FONT_61 232 #define FONT_62 233 #define FONT_63 234 #define FNT1 235 #define FNT2 236 #define FNT3 237 #define FNT4 238 #define XXX1 239 #define XXX2 240 #define XXX3 241 #define XXX4 242 #define FNT_DEF1 243 #define FNT_DEF2 244 #define FNT_DEF3 245 #define FNT_DEF4 246 #define PRE 247 #define POST 248 #define POST_POST 249 SHAR_EOF fi # end of overwriting check if test -f 'findfile.h' then echo shar: will not over-write existing file "'findfile.h'" else cat << \SHAR_EOF > 'findfile.h' /* findfile.h * Copyright 1985 Massachusetts Institute of Technology */ extern int findfile(); /* int findfile(dirvec,dirveclen,area, name, mag, s, nname, nmag) * char *dirvec[],*area,*name,*s,*nname; * int dirveclen,mag,*nmag; */ SHAR_EOF fi # end of overwriting check # End of shell archive exit 0
lamy@ai.toronto.edu (12/01/86)
part 2 of 3 #! /bin/sh # This is a shell archive, meaning: # 1. Remove everything above the #! /bin/sh line. # 2. Save the resulting text in a file. # 3. Execute the file with /bin/sh (not csh) to create the files: # dvi2ps.c # This archive created: Sun Nov 30 19:06:07 1986 export PATH; PATH=/bin:$PATH if test -f 'dvi2ps.c' then echo shar: will not over-write existing file "'dvi2ps.c'" else cat << \SHAR_EOF > 'dvi2ps.c' #define VERSION "2.11" /* $Header: dvi2ps.c,v 1.3 86/11/27 13:55:03 lamy Exp $ * * AUTHOR(s) * Mark Senn wrote the early versions of this program for the * BBN BitGraph. Stephan Bechtolsheim, Bob Brown, Richard * Furuta, James Schaad and Robert Wells improved it. Norm * Hutchinson ported the program to the Sun. Neal Holtz ported * it to the Apollo, and from there to producing PostScript * output. Scott Jones added intelligent font substitution. * Jean-Francois Lamy fixed the PostScript interface for illustrations. * */ /* Basic method: * Using the local font cacheing machinery that was in the previewer, * we can easily manage to send the bitmap for each chracter only once. * Two passes are made over each page in the DVI file. The first pass * simply outputs the bitmaps for all characters on that page that haven't * been sent before. The second pass outputs all the character setting * and positioning commands. This allows us to bracket the setting portion * with PostScript save's and restore's, thus reclaiming considerable * virtual memory after each page. * * All coordinates are output in the PostScript system (TeX origin), * and in integer units of rasters (300/inch) -- except for character * widths, which are sent as floating point numbers. * * About 2 pages of PostScript support code must be sent to the LaserWriter * before this stuff goes. It is automatically included unless the * -h option is given. */ /* Change log: * * Early 1985, (nmh) -- ported sun version to Apollo. * A little later (nmh) -- changed to continue on in the event of missing * font files. * 30-Mar-85 (nmh) -- added -a option to specify a different PXL area * 30-Mar-85 (nmh) -- changed default PXL area to /pxl118 * 31-Mar-85 (nmh) -- fixed bug in OpenFontFile() regarding more than MAXOPEN * PXL files -- changed to mark files as closed in font_entry. * 7-Apr-85 (nmh) -- made command line argument decoding case insensitive. * cleaned up handling of DVI file name argument. * 30-May-85 (nmh) -- new version; hacked to output PostScript commands * 6-Jun-85 (nmh) -- added relative positioning (20% smaller PostScript output) * add -m option to specify mag * 11-Jun-85 (nmh) -- fixed bug regarding char spacings in very long "words" * 12-Jun-85 (nmh) -- v1.02 - process DVI pages in reverse order * 13-Jun-85 (nmh) -- fixed bug re PXL files getting opened too often when no PreLoad * 14-Jun-85 (nmh) -- font dict created in PostScript only when 1st char of font downloaded * add -m0 -mh -m1 etc. to specify magsteps * 16-Aug-85 (nmh) -- added -c option t0 create output file in spool area (Apollo specific) * added -h option to copy header file to output * added -o option to pass options through to PostScript * 20-Aug-85 (nmh) -- v1.03 * 24-Aug-85 (nmh) -- add -q option (for quiet operation). * changed -o option to check PostScript option * changed to output coordinates in TeX system (but * scaled to raster units) -- (0,0) at 1" in and down from * top left (better for use with different size paper). * -- v2.00 * 25-Aug-85 (nmh) -- added dictionary enclosure to Tex.ps, and output * suitable prolog here. * 26-Aug-85 (nmh) -- changes to tex.ps to support Macintosh documents. * 14-Sep-85 (nmh) -- added keyword=value decoding to \special; * 15-Sep-85 (nmh) -- added -i file option. * 23-Sep-85 (saj) -- added font substitution for case when font is * unavailable at requested mag. (a frequent occurrence * with some macro packages like LaTeX) * 24-Jun-86 (jfl) -- Support Mac illustrations produced by LaserWriter * driver 3.0 Changed tex.ps * Added rotation for \special inclusions * Embedded ^D are ignored in included PostScript files */ /**********************************************************************/ /************************ Global Definitions ************************/ /**********************************************************************/ /* This version purports to drive a PostScript device (slowly) */ typedef int BOOLEAN; #define NEW(A) ((A *) malloc(sizeof(A))) #define DEBUG 1 /* for massive printing of input */ /* trace information; select by -d */ /* option after filename: */ /* dviview filename -d */ #ifdef DEBUG int Debug = 0; #endif /* to enable statistics reporting via -s option */ #define STATS #define BINARYOPEN fopen /* byte-oriented host version */ #define ARITHRSHIFT 1 /* define if ">>" operator is a */ /* sign-propagating arithmetic */ /* right shift */ #define USEGLOBALMAG 1 /* when defined, the dvi global */ /* magnification is applied */ /* We can leave USEGLOBALMAG undefined when we have a limited number of font magnifications (at 300dpi) available. Otherwise, we will simply complain about missing PXL files */ /* #undef USEGLOBALMAG */ /* define for "optimal" relative postioning, rather than absolute. Relative can reduce size of postcript output 20% (and reduce print time by almost as much */ #define USERELPOS 1 #define DVIFORMAT 2 #define TRUE 1 #define FALSE 0 #define FIRSTPXLCHAR 0 #define LASTPXLCHAR 127 #ifndef FONTAREA #define FONTAREA "/usr/lib/tex/fonts" #endif #ifndef HDRFILE #define HDRFILE "/usr/lib/tex.ps" #endif #ifdef apollo #ifndef SPOOLFILE #define SPOOLFILE "/local/spool/laser/tex." #endif #define MAXFLEN 28 #endif apollo #ifdef apollo #define MAXOPEN 45 /* limit on number of open PXL files */ #else !apollo #define MAXOPEN 12 /* limit on number of open PXL files */ #endif #define NPXLCHARS 128 #define PXLID 1001 #define READ 4 /* for access() */ #define RESOLUTION 300 #define hconvRESOLUTION 300 #define vconvRESOLUTION 300 #define STACKSIZE 100 #define STRSIZE 257 #define NONEXISTANT -1 /* offset for PXL files not found */ #define NO_FILE (FILE *)-1 #ifdef apollo /* define for enabling of -c option (create output file) */ #define CREOPT #endif apollo /**********************************************************************/ /*********************** external definitions ***********************/ /**********************************************************************/ #include "commands.h" #include <sys/param.h> #include <signal.h> #include <stdio.h> #include "findfile.h" #include <ctype.h> int access(); char *index(); char *malloc(); int free(); char *rindex(); char *sprintf(); char *strcpy(); char *logname(); #define EQ(a,b) (strcmp(a,b)==0) /* output a formatted string */ #define EMIT fprintf /* output a simple string */ #define EMITS(s) fputs(s,outfp) /* output an escaped octal number */ #define EMITO(c) PutOct(c) /* output a decimal integer */ #define EMITN(n) PutInt(n) /* output a byte value in Hex */ #define EMITH(h) putc(*(digit+((h>>4)&0xF)),outfp),\ putc(*(digit+(h&0xF)),outfp) /* output a single character */ #define EMITC(c) putc(c,outfp) /* output a scaled X dimension */ #define EMITX(x) PutInt(PixRound(x,hconv)) /* output a scaled Y dimension */ #define EMITY(y) PutInt(PixRound(y,vconv)) /* formatted i/o was killing us, so build some tables */ char *digit = "0123456789ABCDEF"; int dummyInt; short dummyShort; char dummyChar; /**********************************************************************/ /************************* Global Procedures ************************/ /**********************************************************************/ /* Note: Global procedures are declared here in alphabetical order, with those which do not return values typed "void". Their bodies occur in alphabetical order following the main() procedure. The names are kept unique in the first 6 characters for portability. */ void AbortRun(); float ActualFactor(); void AllDone(); FILE* BINARYOPEN(); int ChkOpt(); /* Check PostScript option for validity */ void CopyFile(); void DecodeArgs(); void DoSpecial(); void EmitChar(); void Fatal(); void FindPostAmblePtr(); void GetBytes(); void GetFontDef(); char *GetKeyStr(); int GetKeyVal(); int HasBeenRead(); int IsSame(); void lcase(); char ToLower(); void MoveDown(); void MoveOver(); int NoSignExtend(); /* see cautionary note in code, re arithmetic vs logical shifts */ void OpenFontFile(); #ifdef CREOPT FILE* OpenOutput(); #endif CREOPT int PixRound(); void PutInt(); int ReadFontDef(); void ReadPostAmble(); void SetChar(); void SetFntNum(); void SetPosn(); void SetRule(); void SetString(); int SignExtend(); /* see cautionary note in code, re arithmetic vs logical shifts */ void SkipFontDef(); void Warning(); /**********************************************************************/ /*********************** Font Data Structures ***********************/ /**********************************************************************/ struct char_entry { /* character entry */ unsigned short width, height;/* width and height in pixels */ short xOffset, yOffset; /* x offset and y offset in pixels */ struct { int isloaded; union { int fileOffset; long *pixptr; } address; } where; int tfmw; /* TFM width */ }; struct font_entry { /* font entry */ int k, c, s, d, a, l; char n[STRSIZE]; /* FNT_DEF command parameters */ int font_space; /* computed from FNT_DEF s parameter */ int font_mag; /* computed from FNT_DEF s and d parameters */ char psname[STRSIZE]; /* PostScript name of the font */ char name[STRSIZE]; /* full name of PXL file */ FILE *font_file_id; /* file identifier (NO_FILE if none) */ int magnification; /* magnification read from PXL file */ int designsize; /* design size read from PXL file */ struct char_entry ch[NPXLCHARS];/* character information */ struct font_entry *next; int ncdl; /* # of different chars actually downloaded */ #ifdef STATS int nbpxl; /* # of bytes of PXL data downloaded */ int ncts; /* total # of characters typeset */ #endif }; struct pixel_list { FILE *pixel_file_id; /* file identifier */ int use_count; /* count of "opens" */ }; /**********************************************************************/ /************************* Global Variables *************************/ /**********************************************************************/ int FirstPage = -1000000; /* first page to print (uses count0) */ int LastPage = 1000000; /* last page to print */ char filename[STRSIZE]; /* DVI file name */ int G_create = FALSE; /* create an output file in spool area ? */ int G_errenc = FALSE; /* has an error been encountered? */ int G_header = TRUE; /* copy header file to output? */ char G_Logname[STRSIZE]; /* name of log file, if created */ int G_interactive = FALSE; /* is the program running interactively */ /* (i.e., standard output not redirected)? */ int G_logging = 0; /* Are we logging warning messages? */ int G_logfile = FALSE; /* Are these messages going to a log file? */ FILE *G_logfp; /* log file pointer (for errors) */ char G_progname[STRSIZE]; /* program name */ int G_quiet = FALSE; /* for quiet operation */ int G_nowarn = FALSE; /* don't print out warnings */ int hconv, vconv; /* converts DVI units to pixels */ int den; /* denominator specified in preamble */ FILE *dvifp = NULL; /* DVI file pointer */ int PreLoad = TRUE; /* preload the font descriptions? */ struct font_entry *prevfont=NULL; /* font_entry pointer, previous character */ struct font_entry *fontptr; /* font_entry pointer */ struct font_entry *hfontptr=NULL;/* font_entry pointer */ int h; /* current horizontal position */ int hh = 0; /* current h on device */ char *Ifile[100]; /* files to include */ int v; /* current vertical position */ int vv = 0; /* current v on device */ int mag; /* magnification specified in preamble */ int ncopies = 1; /* number of copies to print */ int ndone = 0; /* number of pages converted */ int nif = 0; /* number of files to include */ int nopen; /* number of open PXL files */ int nps = 0; /* number of PostScript commands to send */ int num; /* numerator specified in preamble */ #ifdef CREOPT char outfname[256]; /* name of output file */ #endif CREOPT FILE *outfp = NULL; /* output file */ struct font_entry *pfontptr = NULL; /* previous font_entry pointer */ struct pixel_list pixel_files[MAXOPEN+1]; /* list of open PXL file identifiers */ long postambleptr; /* Pointer to the postamble */ FILE *pxlfp; /* PXL file pointer */ char *PXLpath; /* PXL path name for search */ long ppagep; /* previous page pointer */ char *PScmd[100]; /* PostScript commands to send */ int Reverse = TRUE; /* process DVI pages in reverse order ? */ char rootname[STRSIZE]; /* DVI filename without extension */ #ifdef STATS int Stats = FALSE; /* are we reporting stats ? */ int Snbpxl = 0; /* # of bytes of pixel data */ int Sonbpx = 0; /* "optimal" number of bytes of pixel data */ int Sndc = 0; /* # of different characters typeset */ int Stnc = 0; /* total # of chars typeset */ int Snbpx0, Sndc0, Stnc0; /* used for printing incremental changes per dvi page */ #endif int usermag = 0; /* user specified magnification */ /**********************************************************************/ /******************************* main *******************************/ /**********************************************************************/ main(argc, argv) int argc; char *argv[]; { struct stack_entry { /* stack entry */ int h, v, w, x, y, z; /* what's on stack */ }; int command; /* current command */ int count[10]; /* the 10 counters at begining of each page */ long cpagep; /* current page pointer */ int Emitting = FALSE; /* are we outputting typsetting instructions? */ register int i; /* command parameter; loop index */ int k; /* temporary parameter */ char n[STRSIZE]; /* command parameter */ int PassNo = 0; /* which pass over the DVI page are we on? */ int SkipMode = FALSE; /* in skip mode flag */ int sp; /* stack pointer */ struct stack_entry stack[STACKSIZE]; /* stack */ int t; /* temporary */ char SpecialStr[STRSIZE]; /* "\special" strings */ register struct char_entry *tcharptr; /* temporary char_entry ptr*/ int val, val2; /* temporarys to hold command information*/ int w; /* current horizontal spacing */ int x; /* current horizontal spacing */ int y; /* current vertical spacing */ int z; /* current vertical spacing */ nopen = 0; strcpy(G_progname, argv[0]); PXLpath = FONTAREA; /* default font area */ DecodeArgs( argc, argv ); #ifdef apollo set_sbrk_size( 2048*1024 ); #endif if ((i = NoSignExtend(dvifp, 1)) != PRE) { fprintf(stderr,"\n"); Fatal("%s: PRE doesn't occur first--are you sure this is a DVI file?\n\n", G_progname); } i = SignExtend(dvifp, 1); if (i != DVIFORMAT) { fprintf(stderr,"\n"); Fatal("%s: DVI format = %d, can only process DVI format %d files\n\n", G_progname, i, DVIFORMAT); } #ifdef CREOPT if( G_create ) outfp = OpenOutput(); else #endif CREOPT outfp = stdout; /* it is important that these be the very first things output !!! */ if( G_header ) CopyFile( HDRFILE ); for( i=0; i<nif; i++ ) /* copy all included files */ CopyFile( Ifile[i] ); EMIT(outfp, "TeXDict begin @start\n"); EMIT(outfp, "%%%%Title: %s\n", filename); EMIT(outfp, "%%%%Creator: %s\n", G_progname); EMIT(outfp, "%%%%EndProlog\n"); for( i=0; i<nps; i++ ) /* prefix valid PostScript options with a "@" */ if( ChkOpt(PScmd[i]) ) EMIT(outfp, "@%s\n", PScmd[i]); else Fatal( "%s is an invalid option\n", PScmd[i] ); if( ncopies > 1 ) EMIT(outfp, "%d @copies\n", ncopies); if (Reverse) { ReadPostAmble(PreLoad); fseek(dvifp, ppagep, 0); } else { if (PreLoad) { ReadPostAmble(TRUE); fseek(dvifp, (long) 14, 0); } else { num = NoSignExtend(dvifp, 4); den = NoSignExtend(dvifp, 4); mag = NoSignExtend(dvifp, 4); #ifdef USEGLOBALMAG if( usermag > 0 && usermag != mag ) fprintf(stderr, "DVI magnification of %d over-ridden by user mag of %d\n", mag, usermag ); #endif if( usermag > 0 ) mag = usermag; #ifndef USEGLOBALMAG if( mag != 1000 ) fprintf(stderr, "Magnification of %d ignored.\n", mag); #endif hconv = DoConv(num, den, hconvRESOLUTION); vconv = DoConv(num, den, vconvRESOLUTION); } k = NoSignExtend(dvifp, 1); GetBytes(dvifp, n, k); } PassNo = 0; while (TRUE) switch (command=NoSignExtend(dvifp, 1)) { case SET1:case SET2:case SET3:case SET4: val = NoSignExtend(dvifp, command-SET1+1); if (!SkipMode) SetChar(val, command, PassNo); break; case SET_RULE: val = NoSignExtend(dvifp, 4); val2 = NoSignExtend(dvifp, 4); if (Emitting) SetRule(val, val2, 1); break; case PUT1:case PUT2:case PUT3:case PUT4: val = NoSignExtend(dvifp,command-PUT1+1); if (!SkipMode) SetChar(val, command, PassNo); break; case PUT_RULE: val = NoSignExtend(dvifp, 4); val2 = NoSignExtend(dvifp, 4); if (Emitting) SetRule(val, val2, 0); break; case NOP: break; case BOP: cpagep = ftell(dvifp) - 1; for (i=0; i<=9; i++) count[i] = NoSignExtend(dvifp, 4); ppagep = NoSignExtend(dvifp, 4); h = v = w = x = y = z = 0; hh = vv = 0; sp = 0; fontptr = NULL; prevfont = NULL; if( count[0] < FirstPage || count[0] > LastPage ) SkipMode = TRUE; else SkipMode = FALSE; Emitting = (PassNo != 0) && !SkipMode; if( !SkipMode ) { if( PassNo == 0) { EMIT(outfp,"%d @bop0\n", count[0]); #ifdef STATS if( Stats ) { Sndc0 = Sndc; Stnc0 = Stnc; Snbpx0 = Snbpxl; } #endif if( !G_quiet ) fprintf(stderr, "[%d", count[0] ); } else EMIT(outfp,"%d @bop1\n", count[0]); } break; case EOP: if( !SkipMode ) { if( PassNo == 0 ) { /* start second pass on current page */ fseek(dvifp,cpagep,0); PassNo = 1; } else { /* end of second pass, and of page processing */ EMIT(outfp,"@eop\n"); #ifdef STATS if( Stats ) fprintf(stderr," - %d total ch, %d diff ch, %d pxl bytes]\n", Stnc-Stnc0, Sndc-Sndc0, Snbpxl-Snbpx0); else #endif if( !G_quiet ) { fprintf(stderr,"] "); if( (++ndone % 10) == 0 ) fprintf(stderr,"\n"); } PassNo = 0; } } else PassNo = 0; if( PassNo == 0 && Reverse ) { if( ppagep > 0 ) fseek(dvifp, ppagep, 0); else AllDone(); } break; case PUSH: if (sp >= STACKSIZE) Fatal("stack overflow"); stack[sp].h = h; stack[sp].v = v; stack[sp].w = w; stack[sp].x = x; stack[sp].y = y; stack[sp].z = z; sp++; break; case POP: --sp; if (sp < 0) Fatal("stack underflow"); h = stack[sp].h; v = stack[sp].v; w = stack[sp].w; x = stack[sp].x; y = stack[sp].y; z = stack[sp].z; break; case RIGHT1:case RIGHT2:case RIGHT3:case RIGHT4: val = SignExtend(dvifp,command-RIGHT1+1); if (Emitting) MoveOver(val); break; case W0: if (Emitting) MoveOver(w); break; case W1:case W2:case W3:case W4: w = SignExtend(dvifp,command-W1+1); if (Emitting) MoveOver(w); break; case X0: if (Emitting) MoveOver(x); break; case X1:case X2:case X3:case X4: x = SignExtend(dvifp,command-X1+1); if (Emitting) MoveOver(x); break; case DOWN1:case DOWN2:case DOWN3:case DOWN4: val = SignExtend(dvifp,command-DOWN1+1); if (Emitting) MoveDown(val); break; case Y0: if (Emitting) MoveDown(y); break; case Y1:case Y2:case Y3:case Y4: y = SignExtend(dvifp,command-Y1+1); if (Emitting) MoveDown(y); break; case Z0: if (Emitting) MoveDown(z); break; case Z1:case Z2:case Z3:case Z4: z = SignExtend(dvifp,command-Z1+1); if (Emitting) MoveDown(z); break; case FNT1:case FNT2:case FNT3:case FNT4: if (!SkipMode) { SetFntNum(NoSignExtend(dvifp,command-FNT1+1), Emitting); } break; case XXX1:case XXX2:case XXX3:case XXX4: k = NoSignExtend(dvifp,command-XXX1+1); GetBytes(dvifp, SpecialStr, k); if(Emitting) DoSpecial(SpecialStr, k); break; case FNT_DEF1:case FNT_DEF2:case FNT_DEF3:case FNT_DEF4: k = NoSignExtend(dvifp, command-FNT_DEF1+1); if (PreLoad || HasBeenRead(k) ) { SkipFontDef (k); } else { ReadFontDef (k); } break; case PRE: Fatal("PRE occurs within file"); break; case POST: AllDone(); break; case POST_POST: Fatal("POST_POST with no preceding POST"); break; default: if (command >= FONT_00 && command <= FONT_63) {if (!SkipMode) SetFntNum(command - FONT_00, Emitting);} else if (command >= SETC_000 && command <= SETC_127) {if (!SkipMode) SetString(command, PassNo);} else Fatal("%d is an undefined command", command); break; } } /*-->AbortRun*/ /**********************************************************************/ /*************************** AbortRun *******************************/ /**********************************************************************/ void AbortRun(code) int code; { exit(code); } /*-->ActualFactor*/ /**********************************************************************/ /************************** ActualFactor ****************************/ /**********************************************************************/ float /* compute the actual size factor given the approximation */ ActualFactor(unmodsize) int unmodsize; /* actually factor * 1000 */ { float realsize; /* the actual magnification factor */ realsize = (float)unmodsize / 1000.0; /* a real hack to correct for rounding in some cases--rkf */ if(unmodsize==1095) realsize = 1.095445; /*stephalf*/ else if(unmodsize==1315) realsize=1.314534; /*stepihalf*/ else if(unmodsize==1577) realsize=1.577441; /*stepiihalf*/ else if(unmodsize==1893) realsize=1.892929; /*stepiiihalf*/ else if(unmodsize==2074) realsize=2.0736; /*stepiv*/ else if(unmodsize==2488) realsize=2.48832; /*stepv*/ else if(unmodsize==2986) realsize=2.985984; /*stepiv*/ /* the remaining magnification steps are represented with sufficient accuracy already */ return(realsize); } /*-->AllDone*/ /**********************************************************************/ /****************************** AllDone ******************************/ /**********************************************************************/ void AllDone() { char t; struct font_entry *p; int per; EMIT(outfp,"@end\n"); if( !G_quiet ) fprintf(stderr,"\n"); #ifdef CREOPT if( G_create ) { fclose(outfp); if( !G_quiet ) fprintf(stderr, "Output written on \"%s\"\n", outfname ); } #endif CREOPT if (G_errenc && G_logging == 1 && G_logfile) { fseek(G_logfp, 0, 0); while ((t=getc(G_logfp)) != EOF) putchar(t); } if (G_logging == 1 && G_logfile) printf("Log file created\n"); #ifdef STATS if (Stats) { fprintf( stderr, "Total chars diff chars pxl bytes\n" ); fprintf( stderr, " # %% # %% # %%\n" ); fprintf( stderr, "------- --- ------ --- ----- ---\n" ); for( p=hfontptr; p!=NULL; p=p->next ) { fprintf( stderr, "%7d%4d", p->ncts, (100*p->ncts + Stnc/2)/Stnc ); fprintf( stderr, "%9d%4d", p->ncdl, (100*p->ncdl + Sndc/2)/Sndc ); fprintf( stderr, "%8d%4d", p->nbpxl, (100*p->nbpxl + Snbpxl/2)/Snbpxl ); fprintf( stderr, " %s\n", p->psname ); } fprintf(stderr, "\nTotal number of characters typeset: %d\n", Stnc); fprintf(stderr, "Number of different characters downloaded: %d\n", Sndc); fprintf(stderr, "Number of bytes of pxl data downloaded: %d\n", Snbpxl); fprintf(stderr, "Optimal # of bytes of pxl data: %d\n", Sonbpx); } #endif AbortRun(G_errenc); } /*-->ChkOpt*/ /* check a user supplied option for validity */ /*********************************************************************/ /****************************** ChkOpt *******************************/ /*********************************************************************/ #define ISOPT(s) if( EQ(str,s) ) return( TRUE ) int ChkOpt( str ) char *str; { lcase(str); ISOPT("note"); /* its a shame to build this into the program */ ISOPT("letter"); ISOPT("legal"); ISOPT("landscape"); ISOPT("manualfeed"); ISOPT("envelope"); return( FALSE ); } /*-->CopyFile*/ /* copy a file straight through to output */ /*********************************************************************/ /***************************** CopyFile ******************************/ /*********************************************************************/ void CopyFile( str ) char *str; { FILE *spfp; char t; if( (spfp=fopen(str,"r")) == NULL ) { fprintf(stderr,"Unable to open file %s\n", str ); return; } if( !G_quiet ) fprintf(stderr," [%s", str); while( (t = getc(spfp)) != EOF ) { if ( t != '\004' ) EMITC(t); } fclose(spfp); if( !G_quiet ) fprintf(stderr,"]"); } /*-->DecodeArgs*/ /*********************************************************************/ /***************************** DecodeArgs ****************************/ /*********************************************************************/ void DecodeArgs( argc, argv ) int argc; char *argv[]; { int argind; /* argument index for flags */ char curarea[STRSIZE]; /* current file area */ char curname[STRSIZE]; /* current file name */ char *tcp, *tcp1; /* temporary character pointers */ argind = 1; while (argind < argc) { tcp = argv[argind]; if (*tcp == '-') switch(isupper(*++tcp) ? (*tcp-'A')+'a' : *tcp) { case 'a': /* a selects different pxl font area */ PXLpath = argv[++argind]; break; #ifdef CREOPT case 'c': /* create an output file in spool area */ G_create = TRUE; break; #endif CREOPT #ifdef DEBUG case 'd': /* d selects Debug output */ Debug = TRUE; break; #endif case 'f': /* next arg is starting pagenumber */ if( ++argind >= argc || sscanf(argv[argind], "%d", &FirstPage) != 1 ) Fatal("Argument is not a valid integer\n", 0); break; case 'h': /* don't copy PostScript header file through to output */ G_header = FALSE; break; case 'i': /* next arg is a PostScript file to copy */ if( ++argind >= argc ) Fatal("No argument following -i\n", 0); Ifile[nif++] = argv[argind]; break; case 'l': /* l prohibits logging of errors */ G_logging = -1; break; #ifdef USEGLOBALMAG case 'm': /* specify magnification to use */ switch( ToLower(*++tcp) ) { case '\0': /* next arg is a magnification to use */ if( ++argind >= argc || sscanf(argv[argind], "%d", &usermag) != 1 ) Fatal("Argument is not a valid integer\n", 0); break; case '0': usermag = 1000; break; case 'h': usermag = 1095; break; case '1': usermag = 1200; break; case '2': usermag = 1440; break; case '3': usermag = 1728; break; case '4': usermag = 2074; break; case '5': usermag = 2488; break; default: Fatal("%c is a bad mag step\n", *tcp); } break; #endif case 'n': /* next arg is number of copies to print */ if( ++argind >= argc || sscanf(argv[argind], "%d", &ncopies) != 1 ) Fatal("Argument is not a valid integer\n", 0); break; case 'o': /* next arg is a PostScript command to send */ if( ++argind >= argc ) Fatal("No argument following -o\n", 0); PScmd[nps++] = argv[argind]; break; case 'p': /* p prohibits pre-font loading */ PreLoad = 0; Reverse = FALSE; /* must then process in forward order */ break; case 'q': /* quiet operation */ G_quiet = TRUE; break; case 'r': /* don't process pages in reverse order */ Reverse = FALSE; break; #ifdef STATS case 's': /* print some statistics */ Stats = TRUE; break; #endif case 't': /* next arg is ending pagenumber */ if( ++argind >= argc || sscanf(argv[argind], "%d", &LastPage) != 1 ) Fatal("Argument is not a valid integer\n", 0); break; case 'w': /* don't print out warnings */ G_nowarn = TRUE; break; default: printf("%c is not a legal flag\n", *tcp); } else { tcp = rindex(argv[argind], '/'); /* split into directory + file name */ if (tcp == NULL) { curarea[0] = '\0'; tcp = argv[argind]; } else { strcpy(curarea, argv[argind]); curarea[tcp-argv[argind]+1] = '\0'; tcp += 1; } strcpy(curname, tcp); tcp1 = rindex(tcp, '.'); /* split into file name + extension */ if (tcp1 == NULL) { strcpy(rootname, curname); strcat(curname, ".dvi"); } else { *tcp1 = '\0'; strcpy(rootname, curname); *tcp1 = '.'; } strcpy(filename, curarea); strcat(filename, curname); if ((dvifp=BINARYOPEN(filename,"r")) == NULL) { fprintf(stderr,"\n"); fprintf(stderr,"%s: can't find DVI file \"%s\"\n\n", G_progname, filename); AbortRun(1); } strcpy(G_Logname, curname); strcat(G_Logname, ".log"); } argind++; } if (dvifp == NULL) { fprintf(stderr, "\nusage: %s [-a area] [-c] [-h] [-o option] [-p] [-s] [-r] [-f n] [-t n] [-m{0|h|1|2|3|4| mag] [-a fontarea] dvifile\n\n", G_progname); AbortRun(1); } } /*-->DoConv*/ /*********************************************************************/ /******************************** DoConv ***************************/ /*********************************************************************/ int DoConv(num, den, convResolution) { register float conv; conv = ((float)num/(float)den) * #ifdef USEGLOBALMAG /* ActualFactor(mag) * why was this in as Actual Factor? jls */ ((float) mag/1000.0) * #endif ((float)convResolution/254000.0); return((int) (1.0 / conv + 0.5)); } /*-->DoSpecial*/ /*********************************************************************/ /***************************** DoSpecial ***************************/ /*********************************************************************/ typedef enum {None, String, Integer, Number, Dimension} ValTyp; typedef struct { char *Key; /* the keyword string */ char *Val; /* the value string */ ValTyp vt; /* the value type */ union { /* the decoded value */ int i; float n; } v; } KeyWord; typedef struct { char *Entry; ValTyp Type; } KeyDesc; #define PSFILE 0 KeyDesc KeyTab[] = {{"psfile", String}, {"hsize", Dimension}, {"vsize", Dimension}, {"hoffset", Dimension}, {"voffset", Dimension}, {"hscale", Number}, {"vscale", Number}, {"rotation", Dimension}}; #define NKEYS (sizeof(KeyTab)/sizeof(KeyTab[0])) void DoSpecial( str, n ) /* interpret a \special command, made up of keyword=value pairs */ char *str; int n; { char spbuf[STRSIZE]; char *sf = NULL; KeyWord k; int i; str[n] = '\0'; spbuf[0] = '\0'; SetPosn(h, v); EMITS("@beginspecial\n"); while( (str=GetKeyStr(str,&k)) != NULL ) { /* get all keyword-value pairs */ /* for compatibility, single words are taken as file names */ if( k.vt == None && access(k.Key,0) == 0) { if( sf ) Warning(" More than one \\special file name given. %s ignored", sf ); strcpy(spbuf, k.Key); sf = spbuf; } else if( GetKeyVal( &k, KeyTab, NKEYS, &i ) && i != -1 ) { if( i == PSFILE ) { if( sf ) Warning(" More than one \\special file name given. %s ignored", sf ); strcpy(spbuf, k.Val); sf = spbuf; } else /* the keywords are simply output as PS procedure calls */ EMIT(outfp, "%f @%s\n", k.v.n, KeyTab[i].Entry); } else Warning(" Invalid keyword or value in \\special - \"%s\" ignored", k.Key ); } EMITS("@setspecial\n"); if( sf ) CopyFile( sf ); else Warning(" No special file name provided."); EMITS("@endspecial\n"); } /*-->EmitChar*/ /**********************************************************************/ /**************************** EmitChar ******************************/ /**********************************************************************/ void EmitChar(c, ce) /* output a character bitmap */ int c; struct char_entry *ce; { int i; register int j; register unsigned char *sl; register int cc; int nbpl, nwpl; float cw; /* char width, in "dots" - we rely on PostScript maintaining sufficient accuracy */ /* Output in PostScript coord system (y +ive up, x +ive right) (0,0) of char bitmap at lower left. Output scan lines from bottom to top */ if( fontptr->ncdl == 0 ) /* open font dict before first char */ EMIT(outfp,"[ %d ] /%s @newfont\n", fontptr->font_mag, fontptr->psname ); if( fontptr != prevfont ) { /* because this isn't done on pass 0 */ EMIT(outfp,"%s @sf\n", fontptr->psname); prevfont = fontptr; } EMITS("[<"); cc = 2; nbpl = (ce->width + 7) >> 3; nwpl = (ce->width + 31) >> 5; for(i = ce->height-1; i >= 0; i--) { sl = (unsigned char *)(ce->where.address.pixptr + i*nwpl); for(j = 0; j < nbpl; j++, sl++) { if( cc > 100 ) { EMITS("\n "); cc = 2; } EMITH(*sl); cc += 2; } } cw = (float)ce->tfmw / (float)hconv; EMIT(outfp,"> %d %d %d %d %.3f] %d @dc\n", nbpl<<3, ce->height, ce->xOffset, (((int)ce->height)-ce->yOffset)-1, cw, c); fontptr->ncdl += 1; #ifdef STATS Snbpxl += nbpl*ce->height; fontptr->nbpxl += nbpl*ce->height; Sonbpx += (ce->width*ce->height + 7) >> 3; Sndc += 1; #endif } /*-->Fatal*/ /**********************************************************************/ /****************************** Fatal *******************************/ /**********************************************************************/ void Fatal(fmt, a, b, c)/* issue a fatal error message */ char *fmt; /* format */ char *a, *b, *c; /* arguments */ { if (G_logging == 1 && G_logfile) { fprintf(G_logfp, "%s: FATAL--", G_progname); fprintf(G_logfp, fmt, a, b, c); fprintf(G_logfp, "\n"); } fprintf(stderr,"\n"); fprintf(stderr, "%s: FATAL--", G_progname); fprintf(stderr, fmt, a, b, c); fprintf(stderr, "\n\n"); if (G_logging == 1) printf("Log file created\n"); #ifdef CREOPT if (G_create && outfp != NULL) { fclose(outfp); unlink(outfname); } #endif CREOPT AbortRun(1); } /*-->FindPostAmblePtr*/ /**********************************************************************/ /************************ FindPostAmblePtr **************************/ /**********************************************************************/ void FindPostAmblePtr(postambleptr) long *postambleptr; /* this routine will move to the end of the file and find the start of the postamble */ { int i; fseek (dvifp, (long) 0, 2); /* goto end of file */ *postambleptr = ftell (dvifp) - 4; fseek (dvifp, *postambleptr, 0); while (TRUE) { fseek (dvifp, --(*postambleptr), 0); if (((i = NoSignExtend(dvifp, 1)) != 223) && (i != DVIFORMAT)) Fatal ("Bad end of DVI file"); if (i == DVIFORMAT) break; } fseek (dvifp, (*postambleptr) - 4, 0); (*postambleptr) = NoSignExtend(dvifp, 4); fseek (dvifp, *postambleptr, 0); } /*-->GetBytes*/ /**********************************************************************/ /***************************** GetBytes *****************************/ /**********************************************************************/ void GetBytes(fp, cp, n) /* get n bytes from file fp */ register FILE *fp; /* file pointer */ register char *cp; /* character pointer */ register int n; /* number of bytes */ { while (n--) *cp++ = getc(fp); } /*-->GetFontDef*/ /**********************************************************************/ /**************************** GetFontDef *****************************/ /**********************************************************************/ void GetFontDef() /*********************************************************************** Read the font definitions as they are in the postamble of the DVI file. ***********************************************************************/ { char str[50], *calloc (); unsigned char byte; int i, fnamelen; while (((byte = NoSignExtend(dvifp, 1)) >= FNT_DEF1) && (byte <= FNT_DEF4)) { switch (byte) { case FNT_DEF1: ReadFontDef (NoSignExtend(dvifp, 1)); break; case FNT_DEF2: ReadFontDef (NoSignExtend(dvifp, 2)); break; case FNT_DEF3: ReadFontDef (NoSignExtend(dvifp, 3)); break; case FNT_DEF4: ReadFontDef (NoSignExtend(dvifp, 4)); break; default: Fatal ("Bad byte value in font defs"); break; } } if (byte != POST_POST) Fatal ("POST_POST missing after fontdefs"); } /*-->GetKeyStr*/ /**********************************************************************/ /***************************** GetKeyStr ****************************/ /**********************************************************************/ /* extract first keyword-value pair from string (value part may be null) * return pointer to remainder of string * return NULL if none found */ char KeyStr[STRSIZE]; char ValStr[STRSIZE]; char *GetKeyStr( str, kw ) char *str; KeyWord *kw; { char *s, *k, *v, t; if( !str ) return( NULL ); for( s=str; *s == ' '; s++ ) ; /* skip over blanks */ if( *s == '\0' ) return( NULL ); for( k=KeyStr; /* extract keyword portion */ *s != ' ' && *s != '\0' && *s != '='; *k++ = *s++ ) ; *k = '\0'; kw->Key = KeyStr; kw->Val = v = NULL; kw->vt = None; for( ; *s == ' '; s++ ) ; /* skip over blanks */ if( *s != '=' ) /* look for "=" */ return( s ); for( s++ ; *s == ' '; s++ ) ; /* skip over blanks */ if( *s == '\'' || *s == '\"' ) /* get string delimiter */ t = *s++; else t = ' '; for( v=ValStr; /* copy value portion up to delim */ *s != t && *s != '\0'; *v++ = *s++ ) ; if( t != ' ' && *s == t ) s++; *v = '\0'; kw->Val = ValStr; kw->vt = String; return( s ); } /*-->GetKeyVal*/ /**********************************************************************/ /***************************** GetKeyVal ****************************/ /**********************************************************************/ /* get next keyword-value pair * decode value according to table entry */ int GetKeyVal( kw, tab, nt, tno) KeyWord *kw; KeyDesc tab[]; int nt; int *tno; { int i; char c = '\0'; *tno = -1; for(i=0; i<nt; i++) if( IsSame(kw->Key, tab[i].Entry) ) { *tno = i; switch( tab[i].Type ) { case None: if( kw->vt != None ) return( FALSE ); break; case String: if( kw->vt != String ) return( FALSE ); break; case Integer: if( kw->vt != String ) return( FALSE ); if( sscanf(kw->Val,"%d%c", &(kw->v.i), &c) != 1 || c != '\0' ) return( FALSE ); break; case Number: case Dimension: if( kw->vt != String ) return( FALSE ); if( sscanf(kw->Val,"%f%c", &(kw->v.n), &c) != 1 || c != '\0' ) return( FALSE ); break; } kw->vt = tab[i].Type; return( TRUE ); } return( TRUE ); } /*-->HasBeenRead*/ /**********************************************************************/ /*************************** HasBeenRead ****************************/ /**********************************************************************/ int HasBeenRead(k) int k; { struct font_entry *ptr; ptr = hfontptr; while ((ptr!=NULL) && (ptr->k!=k)) ptr = ptr->next; return( ptr != NULL ); } /*-->IsSame*/ /**********************************************************************/ /******************************* IsSame *****************************/ /**********************************************************************/ int IsSame(a, b) /* compare strings, ignore case */ char *a, *b; { for( ; *a != '\0'; ) if( ToLower(*a++) != ToLower(*b++) ) return( FALSE ); return( *a == *b ? TRUE : FALSE ); } /*-->lcase*/ /**********************************************************************/ /**************************** lcase *********************************/ /**********************************************************************/ void lcase(s) char *s; { char *t; for(t=s; *t != '\0'; t++) *t = ToLower(*t); return; } /*-->ToLower*/ /**********************************************************************/ /**************************** ToLower *********************************/ /**********************************************************************/ char ToLower(c) char c; { return( isupper(c)?tolower(c):c ); } /*-->MoveDown*/ /**********************************************************************/ /**************************** MoveDown ******************************/ /**********************************************************************/ void MoveDown(a) int a; { v += a; } /*-->MoveOver*/ /**********************************************************************/ /**************************** MoveOver ******************************/ /**********************************************************************/ void MoveOver(b) int b; { h += b; } /*-->NoSignExtend*/ /**********************************************************************/ /*************************** NoSignExtend ***************************/ /**********************************************************************/ int NoSignExtend(fp, n) /* return n byte quantity from file fd */ register FILE *fp; /* file pointer */ register int n; /* number of bytes */ { register int x; /* number being constructed */ x = 0; while (n--) { x <<= 8; x |= getc(fp); } return(x); } /*-->OpenFontFile*/ /**********************************************************************/ /************************** OpenFontFile *****************************/ /**********************************************************************/ void OpenFontFile() /*********************************************************************** The original version of this dvi driver reopened the font file each time the font changed, resulting in an enormous number of relatively expensive file openings. This version keeps a cache of up to MAXOPEN open files, so that when a font change is made, the file pointer, pxlfp, can usually be updated from the cache. When the file is not found in the cache, it must be opened. In this case, the next empty slot in the cache is assigned, or if the cache is full, the least used font file is closed and its slot reassigned for the new file. Identification of the least used file is based on the counts of the number of times each file has been "opened" by this routine. On return, the file pointer is always repositioned to the beginning of the file. ***********************************************************************/ { register int i,least_used,current; #ifdef DEBUG if (Debug) printf("Open Font file\n"); #endif if (pfontptr == fontptr) return; /* we need not have been called */ for (current = 1; (current <= nopen) && (pixel_files[current].pixel_file_id != fontptr->font_file_id); ++current) ; /* try to find file in open list */ if (current <= nopen) /* file already open */ { if( (pxlfp = pixel_files[current].pixel_file_id) != NO_FILE ) fseek(pxlfp,0,0); /* reposition to start of file */ } else /* file not in open list */ { if (nopen < MAXOPEN) /* just add it to list */ current = ++nopen; else /* list full -- find least used file, */ { /* close it, and reuse slot for new file */ least_used = 1; for (i = 2; i <= MAXOPEN; ++i) if (pixel_files[least_used].use_count > pixel_files[i].use_count) least_used = i; if (pixel_files[least_used].pixel_file_id != NO_FILE) { FILE *fid; struct font_entry *fp; fid = pixel_files[least_used].pixel_file_id; fp=hfontptr; /* mark file as being closed in the entry */ while (fp!=NULL && fp->font_file_id != fid) fp = fp->next; if (fp==NULL) Fatal("Open file %x not found in font entry list.\n", fid); else { fp->font_file_id = NULL; #ifdef STATS if (Stats) fprintf(stderr, "PXL file %s closed.\n", fp->name); #endif } fclose( fid ); } current = least_used; } if ((pxlfp=BINARYOPEN(fontptr->name,"r")) == NULL) { Warning("PXL file %s could not be opened",fontptr->name); pxlfp = NO_FILE; } else { #ifdef STATS if (Stats) fprintf(stderr, "PXL file %s opened.\n", fontptr->name); #endif } pixel_files[current].pixel_file_id = pxlfp; pixel_files[current].use_count = 0; } pfontptr = fontptr; /* make previous = current font */ fontptr->font_file_id = pxlfp; /* set file identifier */ pixel_files[current].use_count++; /* update reference count */ } #ifdef CREOPT /*-->OpenOutput*/ /* generate a unique file name and open it */ /**********************************************************************/ /*************************** OpenOutput *******************************/ /**********************************************************************/ FILE* OpenOutput() { FILE* fp; long t; int n = 0; char *p, *pp, b[256]; int nd; time( &t ); t = t % 100000; strcpy( outfname, SPOOLFILE ); sprintf( b, "%s.%s.%x", logname(), rootname, t ); if( (nd=strlen(b)-MAXFLEN) > 0 ) { for(pp=(p=rindex(b,'.')); p && *p != '\0'; *(pp-nd) = *p++, pp++) ; *(pp-nd) = '\0'; } strcat( outfname, b ); while( access(outfname,0) == 0 ) { n += 1; if( n > 10 ) Fatal( "Unable to create a unique output file name: %s\n", outfname ); strcpy( outfname, SPOOLFILE ); sprintf( b, "%s.%s.%x.%d", logname(), rootname, t, n ); if( (nd=strlen(b)-MAXFLEN) > 0 ) { for(pp=(p=rindex(b,'.')); p && *p != '\0'; *(pp-nd) = *p++, pp++) ; *(pp-nd) = '\0'; } strcat( outfname, b ); } if( (fp=fopen(outfname,"w")) == NULL ) Fatal("Unable to create output file: %s\n", outfname); return( fp ); } #endif CREOPT /*-->PixRound*/ /**********************************************************************/ /***************************** PixRound *****************************/ /**********************************************************************/ int PixRound(x, conv) /* return rounded number of pixels */ register int x; /* in DVI units */ int conv; /* conversion factor */ { return((int)((x + (conv >> 1)) / conv)); } /*-->PutInt*/ /**********************************************************************/ /***************************** PutInt *******************************/ /**********************************************************************/ void PutInt(n) /* output an integer followed by a space */ register int n; { char buf[10]; register char *b; if( n == 0 ) EMITC('0'); else { if( n < 0 ) { EMITC('-'); n = -n; } for(b=buf; n>0; ) { *b++ = digit[n%10]; n /= 10; } for( ; b>buf; ) EMITC(*--b); } EMITC(' '); } /*-->PutOct*/ /**********************************************************************/ /***************************** PutOct *******************************/ /**********************************************************************/ void PutOct(n) /* output an 3 digit octal number preceded by a "\" */ register int n; { EMITC( '\\' ); EMITC( digit[(n&0300)>>6] ); EMITC( digit[(n&0070)>>3] ); EMITC( digit[n&0007] ); } /*-->ReadFontDef*/ /**********************************************************************/ /**************************** ReadFontDef ***************************/ /**********************************************************************/ int ReadFontDef(k) int k; { int t, i; register struct font_entry *tfontptr;/* temporary font_entry pointer */ register struct char_entry *tcharptr;/* temporary char_entry pointer */ char *direct, *tcp, *tcp1; int found; char curarea[STRSIZE]; int cmag; int nmag; char nname[128]; if ((tfontptr = NEW(struct font_entry)) == NULL) Fatal("can't malloc space for font_entry"); tfontptr->next = hfontptr; tfontptr->font_file_id = NULL; fontptr = hfontptr = tfontptr; tfontptr->ncdl = 0; #ifdef STATS tfontptr->nbpxl = 0; tfontptr->ncts = 0; #endif tfontptr->k = k; tfontptr->c = NoSignExtend(dvifp, 4); /* checksum */ tfontptr->s = NoSignExtend(dvifp, 4); /* space size */ tfontptr->d = NoSignExtend(dvifp, 4); /* design size */ tfontptr->a = NoSignExtend(dvifp, 1); /* area length for font name */ tfontptr->l = NoSignExtend(dvifp, 1); /* device length */ GetBytes(dvifp, tfontptr->n, tfontptr->a+tfontptr->l); tfontptr->n[tfontptr->a+tfontptr->l] = '\0'; tfontptr->font_space = tfontptr->s/6; /* never used */ tfontptr->font_mag = (int)((ActualFactor((int)(((float)tfontptr->s/ (float)tfontptr->d)*1000.0 + 0.5)) * #ifdef USEGLOBALMAG ActualFactor(mag) * #endif (float)RESOLUTION * 5.0) + 0.5); if (!findfile(&PXLpath,1,"",tfontptr->n,tfontptr->font_mag,tfontptr->name, nname, &nmag)) Fatal("no font %s.%d",tfontptr->n,mag); sprintf(tfontptr->psname, "%s.%d", tfontptr->n, tfontptr->font_mag); if (tfontptr != pfontptr) OpenFontFile(); if ( pxlfp == NO_FILE ) { /* allow missing pxl files */ tfontptr->magnification = 0; tfontptr->designsize = 0; for (i = FIRSTPXLCHAR; i <= LASTPXLCHAR; i++) { tcharptr = &(tfontptr->ch[i]); tcharptr->width = 0; tcharptr->height = 0; tcharptr->xOffset= 0; tcharptr->yOffset = 0; tcharptr->where.isloaded = FALSE; tcharptr->where.address.fileOffset = NONEXISTANT; tcharptr->tfmw = 0; } return; } if ((t = NoSignExtend(pxlfp, 4)) != PXLID) Fatal("PXL ID = %d, can only process PXL ID = %d files", t, PXLID); fseek(pxlfp, -20, 2); t = NoSignExtend(pxlfp, 4); if ((tfontptr->c != 0) && (t != 0) && (tfontptr->c != t)) Warning("font = \"%s\",\n-->font checksum = %d,\n-->dvi checksum = %d", tfontptr->name, tfontptr->c, t); tfontptr->magnification = NoSignExtend(pxlfp, 4); tfontptr->designsize = NoSignExtend(pxlfp, 4); fseek(pxlfp, NoSignExtend(pxlfp, 4) * 4, 0); for (i = FIRSTPXLCHAR; i <= LASTPXLCHAR; i++) { tcharptr = &(tfontptr->ch[i]); tcharptr->width = NoSignExtend(pxlfp, 2); tcharptr->height = NoSignExtend(pxlfp, 2); tcharptr->xOffset= SignExtend(pxlfp, 2); tcharptr->yOffset = SignExtend(pxlfp, 2); tcharptr->where.isloaded = FALSE; tcharptr->where.address.fileOffset = NoSignExtend(pxlfp, 4) * 4; tcharptr->tfmw = ((float)NoSignExtend(pxlfp, 4)*(float)tfontptr->s) / (float)(1<<20); } } /*-->ReadPostAmble*/ /**********************************************************************/ /************************** ReadPostAmble ***************************/ /**********************************************************************/ void ReadPostAmble(load) int load; /*********************************************************************** This routine is used to read in the postamble values. It initializes the magnification and checks the stack height prior to starting printing the document. ***********************************************************************/ { FindPostAmblePtr (&postambleptr); if (NoSignExtend(dvifp, 1) != POST) Fatal ("POST missing at head of postamble"); #ifdef DEBUG if (Debug) fprintf (stderr, "got POST command\n"); #endif ppagep = NoSignExtend(dvifp, 4); num = NoSignExtend(dvifp, 4); den = NoSignExtend(dvifp, 4); mag = NoSignExtend(dvifp, 4); #ifdef USEGLOBALMAG if( usermag > 0 && usermag != mag ) fprintf(stderr, "DVI magnification of %d over-ridden by user mag of %d\n", mag, usermag ); #endif if( usermag > 0 ) mag = usermag; #ifndef USEGLOBALMAG if( mag != 1000 ) fprintf(stderr, "Magnification of %d ignored.\n", mag); #endif hconv = DoConv(num, den, hconvRESOLUTION); vconv = DoConv(num, den, vconvRESOLUTION); NoSignExtend(dvifp, 4); /* height-plus-depth of tallest page */ NoSignExtend(dvifp, 4); /* width of widest page */ if (NoSignExtend(dvifp, 2) >= STACKSIZE) Fatal ("Stack size is too small"); NoSignExtend(dvifp, 2); /* this reads the number of pages in */ /* the DVI file */ #ifdef DEBUG if (Debug) fprintf (stderr, "now reading font defs"); #endif if (load) GetFontDef (); } /*-->SetChar*/ /**********************************************************************/ /***************************** SetChar ******************************/ /**********************************************************************/ int buffer[8]; LoadAChar(c, ptr) int c; register struct char_entry *ptr; { long *pr; register int nints; if (ptr->where.address.fileOffset == NONEXISTANT) { ptr->where.address.pixptr = NULL; ptr->where.isloaded = TRUE; return; } OpenFontFile(); fseek(pxlfp, ptr->where.address.fileOffset, 0); nints = ((ptr->width + 31) >> 5) * ptr->height; if( (pr = (long *)malloc( nints*sizeof(long) )) == NULL ) Fatal("Unable to allocate memory for char\n"); fread(pr, 4, nints, pxlfp); ptr->where.address.pixptr = pr; ptr->where.isloaded = TRUE; EmitChar(c, ptr); /* we should really free the space used by the PXL data after this point, but it is not large, and besides, we may want to be more clever in the future, about sending bitmaps. So keep the data around */ } void SetChar(c, command, PassNo) int c, command, PassNo; { register struct char_entry *ptr; /* temporary char_entry pointer */ int k; ptr = &(fontptr->ch[c]); if (!ptr->where.isloaded) LoadAChar(c, ptr); if (PassNo==0) return; SetPosn(h,v); if (fontptr->font_file_id != NO_FILE) { /* ignore missing fonts */ EMITN(c); EMITS("c\n"); hh += ptr->tfmw; } if (command <= SET4) h += ptr->tfmw; #ifdef STATS Stnc += 1; fontptr->ncts += 1; #endif } /*-->SetFntNum*/ /**********************************************************************/ /**************************** SetFntNum *****************************/ /**********************************************************************/ void SetFntNum(k, Emitting) int k, Emitting; /* this routine is used to specify the font to be used in printing future characters */ { fontptr = hfontptr; while ((fontptr!=NULL) && (fontptr->k!=k)) fontptr = fontptr->next; if (fontptr == NULL) Fatal("font %d undefined", k); if (Emitting && (fontptr->font_file_id != NO_FILE) ) EMIT(outfp,"%s @sf\n", fontptr->psname); } /*-->SetPosn*/ /**********************************************************************/ /***************************** SetPosn ******************************/ /**********************************************************************/ void SetPosn(x, y) /* output a positioning command */ int x, y; { int rx,ry; #ifdef USERELPOS if (y == vv) { /* use relative movement if just moving horizontally */ if ( x != hh ) { EMITN(rx=PixRound(x-hh,hconv)); EMITS("r "); hh += rx*hconv; } } else { #endif EMITN(rx=PixRound(x,hconv)); EMITN(ry=PixRound(y,vconv)); EMITS("p "); hh = rx*hconv; /* must know where device "really" is horizontally, for rel. posning. */ vv = y; /* but we always use direct positioning for vertical movement */ #ifdef USERELPOS } #endif } /*-->SetRule*/ /**********************************************************************/ /***************************** SetRule ******************************/ /**********************************************************************/ void SetRule(a, b, Set) int a, b; BOOLEAN Set; { /* this routine will draw a rule */ if( a > 0 && b > 0 ) { SetPosn(h,v); /* lower left corner */ EMITN(PixRound(b,hconv)); /* width */ EMITN(PixRound(a,vconv)); /* height */ EMITS("ru\n"); } if (Set) h += b; } /*-->SetString*/ /**********************************************************************/ /***************************** SetString ****************************/ /**********************************************************************/ void SetString(firstch, PassNo) /* read and set a consecutive string of chars */ int firstch, PassNo; { char s[256]; register char *sp; register int c; register struct char_entry *ptr; int len, hhold; /* read entire string of chars */ for(c = firstch, sp = s; c >= SETC_000 && c <= SETC_127; ) { *sp++ = c; c = NoSignExtend(dvifp, 1); } fseek(dvifp, -1, 1); /* backup one character */ len = sp - s; /* NULL's are valid chars, so cant use for string termination */ /* ensure that all characters are loaded, */ for(sp = s; sp < s+len; sp++) { ptr = &(fontptr->ch[*sp]); if( !(ptr->where.isloaded) ) LoadAChar(*sp, ptr); } /* emit the instructions */ if( PassNo == 0 ) return; SetPosn(h, v); if( fontptr->font_file_id != NO_FILE ) { /* ignore missing fonts */ if( len <= 1 ) { EMITN(s[0]); EMITS("c\n"); } else { EMITC('('); for( sp=s; sp < s+len; sp++) { if( *sp < ' ' || *sp >= 0177 ) EMITO(*sp); else if( *sp == '(' || *sp == ')' || *sp == '\\') { EMITC('\\'); EMITC(*sp); } else EMITC(*sp); } EMITS(") s\n"); } } /* compute updated positions */ hhold = hh; for(sp = s; sp < s+len; sp++) { ptr = &(fontptr->ch[*sp]); h += ptr->tfmw; hh += ptr->tfmw; } if( fontptr->font_file_id == NO_FILE ) hh = hhold; /* because it didn't move */ #ifdef STATS Stnc += len; fontptr->ncts += len; #endif } /*-->SignExtend*/ /**********************************************************************/ /**************************** SignExtend ****************************/ /**********************************************************************/ int SignExtend(fp, n) /* return n byte quantity from file fd */ register FILE *fp; /* file pointer */ register int n; /* number of bytes */ { int n1; /* number of bytes */ register int x; /* number being constructed */ x = getc(fp); /* get first (high-order) byte */ n1 = n--; while (n--) { x <<= 8; x |= getc(fp); } /* NOTE: This code assumes that the right-shift is an arithmetic, rather than logical, shift which will propagate the sign bit right. According to Kernighan and Ritchie, this is compiler dependent! */ x<<=32-8*n1; x>>=32-8*n1; /* sign extend */ #ifdef DEBUG if (Debug) { fprintf(stderr,"\tSignExtend(fp,%d)=%X\n",n1,x); } #endif return(x); } /*-->SkipFontDef*/ /**********************************************************************/ /**************************** SkipFontDef ***************************/ /**********************************************************************/ void SkipFontDef(k) int k; { int a, l; char n[STRSIZE]; NoSignExtend(dvifp, 4); NoSignExtend(dvifp, 4); NoSignExtend(dvifp, 4); a = NoSignExtend(dvifp, 1); l = NoSignExtend(dvifp, 1); GetBytes(dvifp, n, a+l); } /*-->Warning*/ /**********************************************************************/ /***************************** Warning ******************************/ /**********************************************************************/ void Warning(fmt, a, b, c) /* issue a warning */ char *fmt; /* format */ char *a, *b, *c; /* arguments */ { if (G_logging == 0) { if (G_logfile) G_logfp=fopen(G_Logname,"w+"); else { G_logfp=stderr; if( G_nowarn ) return; } G_logging = 1; if (G_logfp == NULL) G_logging = -1; } G_errenc = TRUE; if (G_logging == 1) { fprintf(G_logfp, fmt, a, b, c); fprintf(G_logfp,"\n"); } } SHAR_EOF fi # end of overwriting check # End of shell archive exit 0
lamy@ai.toronto.edu (12/01/86)
part 3 of 3 #! /bin/sh # This is a shell archive, meaning: # 1. Remove everything above the #! /bin/sh line. # 2. Save the resulting text in a file. # 3. Execute the file with /bin/sh (not csh) to create the files: # findfile.c # LaserPrep.uu # This archive created: Sun Nov 30 19:06:12 1986 export PATH; PATH=/bin:$PATH if test -f 'findfile.c' then echo shar: will not over-write existing file "'findfile.c'" else cat << \SHAR_EOF > 'findfile.c' /* findfile.c * Copyright 1985 Massachusetts Institute of Technology */ #include <stdio.h> #include <sys/types.h> #include <sys/dir.h> #include "findfile.h" int findfileindir(area, name, mag, s, nname, nmag) char *area,*name,*s,*nname; int mag,*nmag; { FILE *f; char buf[BUFSIZ]; int found = 0; sprintf(s,"%s/SUBDIR",area); if (!access(s,0)) sprintf(s,"%s/%s/%s.%dpxl",area,name,name,mag); else sprintf(s,"%s/%s.%dpxl",area,name,mag); if (!access(s,4)) { strcpy(nname,name); *nmag = mag; return(-1); } else { sprintf(buf,"%s/NEEDED",area); if (!access(buf,2)) { sprintf(s,"%s.%dpxl\n",name,mag); f = fopen(buf,"r+"); while (fgets(buf,sizeof(buf),f)) if (!strcmp(buf,s)) found++; if (!found) fputs(s,f); fclose(f); } return(0); } } /* true if it found a file, false otherwise; name is in s */ int findfile(dirvec,dirveclen,area, name, mag, s, nname, nmag) char *dirvec[],*area,*name,*s,*nname; int dirveclen,mag,*nmag; { int i,point; char family[128]; strcpy(nname,name); *nmag = mag; point = -1; (void) sscanf(name,"%[^0123456789.]%d",family,&point); /* First check dir area given in DVI file */ if (*area && findfileindir(area, name, mag, s, nname, nmag)) return(-1); /* Then check along dirvec */ for (i = 0; i < dirveclen; i++) if (findfileindir(dirvec[i], name, mag, s, nname, nmag)) return(-1); /* next check for closest magnification along dirvec */ return(findanyfile(dirvec,dirveclen,family,point,mag,name,s,nname,nmag)); } int strdiff(s1,s2) char *s1,*s2; { register int diff = 0; while (*s1 && *s2) diff += abs(*s1++ - *s2++); while (*s1) diff += *s1++; while (*s2) diff += *s2++; return(diff); } scanpdir(dir,name, family,point,mag, bestfamily,bestname,bestpoint,bestmag, min_df,min_dp,min_dm) char *dir,*name,*family,*bestfamily,*bestname; int point,mag,*bestpoint,*bestmag,*min_df,*min_dp,*min_dm; { DIR *dirstream; struct direct *dirrecord; char qfamily[128]; int qpoint,qmag,df,dp,dm; if (dirstream = opendir(dir)) { while (dirrecord = readdir(dirstream)) { if (!strcmp(dirrecord->d_name+dirrecord->d_namlen-3,"pxl")) { qpoint = -1; qmag = -1; (void) sscanf(dirrecord->d_name,"%[^0123456789.]%d.%d", qfamily,&qpoint,&qmag); df = strdiff(family,qfamily); dp = abs(point - qpoint); dm = abs(mag - qmag); if ((df < *min_df) || (df == *min_df && dp < *min_dp) || (df == *min_df && dp == *min_dp && dm < *min_dm)) { sprintf(bestname,"%s/%s",dir,dirrecord->d_name); strcpy(bestfamily,qfamily); *bestpoint = qpoint; *bestmag = qmag; *min_df = df; *min_dp = dp; *min_dm = dm; } } } closedir(dirstream); } } scandir(dir,name, family,point,mag, bestfamily,bestname,bestpoint,bestmag, min_df,min_dp,min_dm) char *dir,*name,*family,*bestfamily,*bestname; int point,mag,*bestpoint,*bestmag,*min_df,*min_dp,*min_dm; { DIR *dirstream; struct direct *dirrecord; int df; char pdir[MAXNAMLEN]; if (dirstream = opendir(dir)) { while (dirrecord = readdir(dirstream)) { if (dirrecord->d_name[0] != '.') { df = strdiff(name,dirrecord->d_name); if (df <= *min_df) { sprintf(pdir,"%s/%s",dir,dirrecord->d_name); scanpdir(pdir,name, family,point,mag, bestfamily,bestname,bestpoint,bestmag, min_df,min_dp,min_dm); } } } closedir(dirstream); } } /* finds the best match to the desired font */ int findanyfile(dirvec,dirveclen,family,point,mag,name,s,nname,nmag) char *dirvec[],*family,*name,*s,*nname; int dirveclen,point,mag,*nmag; { char foo[MAXNAMLEN],bestname[MAXNAMLEN],bestfamily[128]; int min_df,min_dp,min_dm,df,dp,dm,i,bestpoint,bestmag; bestname[0] = '\0'; min_df = min_dp = min_dm = 9999999; for (i = 0; i < dirveclen; i++) { sprintf(foo,"%s/SUBDIR",dirvec[i]); if (!access(foo,0)) scandir(dirvec[i],name, family,point,mag, bestfamily,bestname,&bestpoint,&bestmag, &min_df,&min_dp,&min_dm); else scanpdir(dirvec[i],name, family,point,mag, bestfamily,bestname,&bestpoint,&bestmag, &min_df,&min_dp,&min_dm); } if (bestname[0]) { if (bestpoint > 0) sprintf(nname,"%s%d",bestfamily,bestpoint); else strcpy(nname,bestfamily); *nmag = bestmag; strcpy(s,bestname); if ((strcmp(bestfamily,family) || bestpoint != point || abs(bestmag - mag) > 2)) fprintf(stderr, "Substituted font %s at mag %d for %s at mag %d.\n", nname,(bestmag * 4 + 3) / 6, name,(mag * 4 + 3) / 6); return(-1); } return(0); } SHAR_EOF fi # end of overwriting check if test -f 'LaserPrep.uu' then echo shar: will not over-write existing file "'LaserPrep.uu'" else cat << \SHAR_EOF > 'LaserPrep.uu' begin 644 LaserPrep.ps M)2$*)3 P,# P,# P,# *)2!#;W!Y4FEG:'0@07!P;&4@0V]M<'5T97(L($EN M8RX@,3DX-"P@,3DX-2 @($%L;"!2:6=H=',@4F5S97)V960N"B4*)2 D2&5A M9&5R.B!,87-E<E!R97 N<',L=B T,"XT(#@V+S$Q+S(W(#$T.C0T.C(X(&QA M;7D@17AP("0*)0HE("1,;V<Z"4QA<V5R4')E<"YP<RQV("0*)2!2979I<VEO M;B T,"XT(" X-B\Q,2\R-R @,30Z-#0Z,C@@(&QA;7D*)2!A;&P@9F]N="!R M92UE;F-O9&EN9R]R96YA;6EN9R!N;W<@9&]N92!A="!T:&4@96YD+@HE( HE M(%)E=FES:6]N(#0P+C,@(#@V+S$Q+S W(" Q,#HR,3HU-B @;&%M>0HE(%)E M;6]V960@8VAA<F%C=&5R<R!W:71H(&AI9V@M;W)D97(@8FET('-E="!T:&%T M(&-A=7-E9"!#4TYE="!M86EL"B4@97AC:&%N9V5S('1O(&9R965Z92X@($1E M9FEN:71I;VX@;V8@7'AS(&AA9"!-+4H@32U*('-E<G9E<F1I8W0@:6YS=&5A M9 HE(&]F(# @<V5R=F5R9&EC="P@<V\@=&AI<R!K:6QL<R!T=V\@8FER9',@ M=VET:"!O;F4@<W1O;F4N"B4@"B4@4F5V:7-I;VX@-# N,B @.#8O,3 O,S @ M(#$Y.C4R.C4P("!L86UY"B4@06QL(&9O;G1S('1H870@:&%V92!A('-T86YD M87)D(&5N8V]D:6YG(&%R92!R96UA<'!E9"!T;R!!<'!L90HE(&-O;G9E;G1I M;VYS(&%N9"!G:79E;B!A(%Q?7U]?7U\@;F%M92X@(%1H:7,@:7,@;F]W(&1O M;F4@:6X*)2!A(&QO;W @:6YS=&5A9"!O9B!B>2!E;G5M97)A=&EO;BX@($9O M;G1S(&QI:V4@4WEM8F]L(&%N9 HE(%IA<&9$:6YG8F%T<R!T:&%T(&%L<F5A M9'D@:&%V92!A(')E;6%P<&EN9R!A<F4@<VEM<&QY(&=I=F5N"B4@82!<7U]? M7U]?(&YA;64N("!#;V1E(&-O=7)T97-Y(&]F($=L96X@4F5I9"!A="!!9&]B M92!I;F,N"B4@"B4@4F5V:7-I;VX@-# N,2 @.#8O,3 O,S @(#$Y.C0T.C,Q M("!L86UY"B4@0V]M;65N=&5D(&]U="!C;V1E('1O(&UA:V4@=&AE(&1E9FEN M:71I;VYS(')E<VED96YT(&EN('!R:6YT97(*)2!-861E(&)I=&UA<"!S;6]O M=&AI;F<@=&\@=V]R:R!B>2!P=7-H:6YG('1H92!S=')I;F<@;V8@96YC<GEP M=&5D"B4@8V]M;6%N9',@97AP96-T960@8GD@965X96,@;VX@=&AE('-T86-K M(&EN<W1E860@;V8@;&5T=&EN9R!I="!R96%D"B4@=6YT:6P@96YD(&]F(&9I M;&4@*'=H:6-H('!R979E;G1E9"!T:&4@=7-E<B=S(&IO8B!F<F]M(&)E:6YG M('1H97)E*0HE(%)E;6]V960@:G5N:R!A="!T:&4@96YD(&]F('1H92!F:6QE M+@HE( HE(%)E=FES:6]N(#0P+C @(#@V+S$P+S,P(" Q.3HS,#HS." @;&%M M>0HE($]R:6=I;F%L(&9I;&4L(&%S(&5X=')A8W1E9"!B>2!T>7!I;F<@8V]N M=')O;"U+(&EM;65D:6%T96QY(&%F=&5R"B4@<V5L96-T:6YG('1H92!P<FEN M="!O<&5R871I;VX@:6X@86X@87!P;&EC871I;VXN"B4@"B5[87!P;&5D:6-T M('9E<G-I;VX@(S0P"B4@<V5R=F5R9&EC="!B96=I;B!E>&ET<V5R=F5R"G-Y M<W1E;61I8W0@+V-U<G)E;G1P86-K:6YG(&MN;W=N>V-U<G)E;G1P86-K:6YG M('1R=64@<V5T<&%C:VEN9WUI9@HO3%=[<V%V92!S=&%T=7-D:6-T("]P<F]D M=6-T(&=E="A,87-E<E=R:71E<BEA;F-H;W)S96%R8V@*97AC:"!P;W![;&5N M9W1H(# @97%[,7U[,GUI9F5L<V5]>S!]:69E;'-E(&5X8V@@<F5S=&]R97UB M:6YD(&1E9@HO3%<K>TQ7(#(@97%]8FEN9"!D968*+V]K>W-Y<W1E;61I8W0@ M+W-T871U<V1I8W0@:VYO=VX@9'5P>TQ7(# @9W0@86YD?6EF?6)I;F0@9&5F M"B5O:WMS=&%T=7-D:6-T(&)E9VEN(#D@<V-C:6YT97)A8W1I=F4@,R!N92!E M>&-H(# @;F4@;W)[.2 P(#,@<V5T<V-C:6YT97)A8W1I=F5]:68*)7=A:71T M:6UE;W5T(#,P,"!L='LO=V%I='1I;65O=70@,S P(&1E9GUI9B!E;F1]:68* M+VUD(#(U,"!D:6-T(&1E9B!M9"!B96=I;@HO878@-# @9&5F"B]4('1R=64@ M9&5F"B]&(&9A;'-E(&1E9@HO8VD@,"!D968*+VUL(# @9&5F"B]A;" P(&1E M9@HO=&<@,"!D968*+W-B(#4P,"!S=')I;F<@9&5F"B]M='@@;6%T<FEX(&1E M9@HO<S<U(#<U('-T<FEN9R!D968*+W,X(#@@<W1R:6YG(&1E9@HO<S$@*" I M(&1E9@HO<'AS(#$@9&5F"B]P>7,@,2!D968*+VYL=R N,C0@9&5F"B]P<'(@ M6RTS,B M,CDN-3(@-S8R(#4X,BXT.%T@9&5F"B]P9W,@,3,R,"!D968*+W!O M<B!T<G5E(&1E9@HO>&(@-3 P(&%R<F%Y(&1E9@HO<V\@=')U92!D968*+V9I M;&QF;&%G(&9A;'-E(&1E9@HO<&YM(#$@9&5F"B]F;78@=')U92!D968*+W-F M;"!F86QS92!D968*+VUA(# @9&5F"B]F:V(@=')U92!D968*+V9G("A2=F1< M,# Q7# P,5PP,#!<,# P7#$W-RD@9&5F"B]B9&9[8FEN9"!D969]8FEN9"!D M968*+WAD9GME>&-H(&1E9GUB9&8*+WAL>VYE9R!E>&-H(&YE9R!T<F%N<VQA M=&5]8F1F"B]F<'MP;G-H(# @;F4@<&YS=B P(&YE(&%N9'UB9&8*+W9R8EL* M>V9P>V=S879E(#$@<V5T;&EN97=I9'1H('!N<V@@<&YS=B!S8V%L92!S=')O M:V4@9W)E<W1O<F5]:68@;F5W<&%T:'UB:6YD"B]E;V9I;&P@;&]A9 ID=7 * M+VYE=W!A=&@@;&]A9 HR(&EN9&5X"F1U< I[8VQI<"!N97=P871H?6)I;F0* M>WUB:6YD"F1U< HR(&-O<'D*761E9@IC=7)R96YT<V-R965N("]S<&8@>&1F M("]R;W0@>&1F("]F<F5Q('AD9@HO9&]O<'MV<F(@97AC:"!G970@97AE8WUB M9&8*+W!S=7LO<&=S('AD9B R(&EN9&5X("XW,B!M=6P@97AC:"!D:78@+W!Y M<R!X9&8@9&EV("XW,B!M=6P@+W!X<R!X9&8@<'!R(&%S=&]R92!P;W @+W!O M<B!X9&8@<VX@86YD("]S;R!X9&9]8F1F"B]T>'!O<V5[=7-E<F1I8W0@+VYO M=&4@:VYO=VX@<&=S(#$V.# @97$@,2!I;F1E>"!A;F1[;&5G86Q]:68*<&=S M(#$R,3(@97%[9'5P>VYO=&5]:68@-30@,S(N-"!T<F%N<VQA=&5]:68@<&=S M(#$T,#,@97$@=7-E<F1I8W0@+V$T<VUA;&P@:VYO=VX@86YD>V$T<VUA;&Q] M:68*<&=S(#$S,C @97$@86YD>VYO=&5]:68@<'AS('!Y<R!S8V%L92!P<'(@ M86QO860@<&]P('!O<GMP;W @97AC:"!N96<@97AC:"!T<F%N<VQA=&4@<&]P M?0I[=')A;G-L871E('!O<"!P;W @,C<P(')O=&%T97UI9F5L<V4@,2 M,2!S M8V%L97UB9&8*+V9R>S,@:6YD97@@,R!I;F1E>"!X;"!P<'(@86QO860@<&]P M(#,@+3$@<F]L;" R(&UU;"!A9&0@,R Q(')O;&P@97AC:" R(&UU;"!A9&0* M-B R(')O;&P@,R M,2!R;VQL('-U8B S(#$@<F]L;"!E>&-H('-U8B S(#$@ M<F]L;"!E>&-H(#,@+3$@<F]L;"!D:78@,R Q(')O;&P@9&EV(&5X8V@@<V-A M;&5]8F1F"B]L=W-[<VAO=WUB9&8*+W1V>W-H;W<@<&]P('!O<'UB9&8*+V]B M;'M[,"XR,3(U-3<@;75L?7MP;W @,'UI9F5L<V5]8F1F"B]P=WMF9R W("]0 M<F5S97)V95=I9'1H(&MI9GMP;W!]>S$R-WUI9F5L<V4@<'5T?6)D9@HO<V9D M>W!S(&9G(#4@+3$@<F]L;"!G970@;75L(#$P,"!D:78@,"!P<R U("TQ(')O M;&P@;V)L('!S(&YE9R P(# @-F$@87-T;W)E(&UA:V5F;VYT('-E=&9O;G1] M8F1F"B]F;G1[9FEN9&9O;G0@<V9D?6)D9@HO8G1[<V$@,R Q(')O;&P@,R!I M;F1E>"!A;F0@<'5T?6)D9@HO<V$H7# P,%PP,#!<,# P7# P,%PP,#!<,# P M7# P,%PP,#!<,# P*61E9@HO9G-[," Q(&)T(#$@,B!B=" R(#0@8G0@,R X M(&)T(#0@,38@8G0@-2 S,B!B=" V(#8T(&)T(#<@,3(X(&)T('-A(&5X8V@@ M."!E>&-H('!U='UB9&8*+VUX,2!M871R:7@@9&5F"B]M>#(@;6%T<FEX(&1E M9@HO;7@S(&UA=')I>"!D968*+V1G9GMF9R W(&=E="!C=7)R96YT9F]N='UB M9&8*+V=F>WUB9&8*+V)U>V-U<G)E;G1P;VEN="!C=7)R96YT9W)A>2!C=7)R M96YT;&EN97=I9'1H(&-U<G)E;G1L:6YE8V%P(&-U<G)E;G1L:6YE:F]I;B!C M=7)R96YT9&%S:"!E>&-H(&%L;V%D(&QE;F=T: IF9R U('-F;'LQ?7LP?6EF M96QS92!P=70@;6P@86P@=&<@8VD@<&YS=B!P;G-H"C)T(&%L;V%D('!O<" S M82!A;&]A9"!P;W @;7@R(&%L;V%D('!O<"!M>#$@86QO860@<&]P(&UT>"!C M=7)R96YT;6%T<FEX(&%L;V%D('!O< IM>#,@86QO860@<&]P('!S('!M(')E M<W1O<F4@+W!S('AD9B!M>#,@87-T;W)E('!O<'UB9&8*+V)N>R]P;2!S879E M(&1E9B!M>#,@<V5T;6%T<FEX(&YE=W!A=&@@," P(&UO=F5T;R!C="!D=7 @ M,SD@9V5T(# @97AC:"!G971I;G1E<G9A;"!C=G@@97AE8PIM='@@87-T;W)E M('-E=&UA=')I>"!M>#$@87-T;W)E('!O<"!M>#(@87-T;W)E('!O<" S82!A M<W1O<F4@<&]P"C)T(&%S=&]R92!P;W @+W!N<V@@>&1F("]P;G-V('AD9B!G M=R O8VD@>&1F("]T9R!X9&8@+V%L('AD9B O;6P@>&1F"B]S9FP@9F<@-2!G M970@,"!N92!D968@87)R87D@87-T;W)E(&5X8V@@<V5T9&%S:"!S971L:6YE M:F]I;B!S971L:6YE8V%P"G-E=&QI;F5W:61T:"!S971G<F%Y(&UO=F5T;WUB M9&8*+V9C>W-A=F4@=FUS=&%T=7,@97AC:"!S=6(@-3 P,# @;'0*>R@E)5M\ M,'Q=)24I/7!R:6YT(&9L=7-H?6EF('!O<"!R97-T;W)E?6)D9@HO=&-[,S(W M-C@@9&EV(&%D9" S(#$@<F]L;" S,C<V."!D:78@861D(#)T(&%S=&]R92!P M;W!]8F1F"B\S82!;," P(#!=(&1E9@HO,G0@,B!A<G)A>2!D968*+W1P>S-A M(&%S=&]R92!P;W!]8F1F"B]T='MM>#(@8W5R<F5N=&UA=')I>"!P;W @8W5R M<F5N='!O:6YT(#(@8V]P>2 R="!A;&]A9"!P;W @<6$@,B!C;W!Y('1R86YS M;&%T92 S82!A;&]A9"!P;W @97AC:"!D=7 @,"!E<0I[<&]P?7LQ(&5Q>RTQ M(#%]>S$@+3%]:69E;'-E('-C86QE?6EF96QS92!R;W1A=&4@<&]P(&YE9R!E M>&-H(&YE9R!E>&-H('1R86YS;&%T92!M;W9E=&]]8F1F"B]T97MM>#(@<V5T M;6%T<FEX?6)D9@HO9'1B>R]F:V(@9F%L<V4@9&5F("]T9R!C=7)R96YT9W)A M>2!D968@+V-I(# @9&5F("]M;" P(&1E9B O86P@,"!D968@,R!E<7LQ('-E M=&=R87E]:69]8F1F"B]T8GLS(&5Q>S$@<V5T9W)A>7UI9B!P;W @<&]P('!O M<'UB9&8*+V1A;7MM;"!A9&0@+VUL('AD9B!D=7 @;&5N9W1H('-B(&5X8V@@ M8VD@97AC:"!D=7 *8VD@861D("]C:2!X9&8@9V5T:6YT97)V86P@8V]P>2!D M=7 @=VD@<&]P(&1U<"!A;"!A9&0@+V%L('AD9@IC=7)R96YT9W)A>7MS971G M<F%Y(&1U<"!M;"!M=6P@,R M,2!R;VQL(')S?7UB9&8*+V%M>W!O<"!S82 R M(&=E=" P(&YE>V1U<"!W:2!P;W @9'5P(#,@+3$@<F]L;"!R<WU[<VAO=WUI M9F5L<V5]8F1F"B]T:'LS("TQ(')O;&P@9&EV(#,@,2!R;VQL(&5X8V@@9&EV M(#(@8V]P>2!M>#$@<V-A;&4@<&]P('-C86QE("]S9FP@=')U92!D969]8F1F M"B]T=7LQ(#$@;7@Q(&ET<F%N<V9O<FT@<V-A;&4@+W-F;"!F86QS92!D969] M8F1F"B]T<WLQ(#$@;7@Q('1R86YS9F]R;2!S8V%L92 O<V9L('1R=64@9&5F M?6)D9@HO9GI[+W!S('AD9GUB9&8*+V1F<WMD=7 @9G-[9G-]?6)D9@HO9&9Z M>V1U<"!F>GMF>GU]8F1F"B]T;7MS879E(&5X8VA[9'5P('1Y<&4@9'5P("]A M<G)A>71Y<&4@97$@97AC:" O<&%C:V5D87)R87ET>7!E(&5Q(&]R"GME>&5C M?7MD=7 @='EP92 O9&EC='1Y<&4@97%[9FMB>W-E=&9O;G0@9F<@97AC:" W M(&5X8V@@<'5T?7MP;W @<&]P?6EF96QS97UI9GUI9F5L<V5]9F]R86QL"F-U M<G)E;G1P;VEN=" S("TQ(')O;&P@<F5S=&]R92!M;W9E=&]]8F1F"B]D:V)[ M8V]U;G1T;VUA<FL@>&(@97AC:" P(&5X8V@@9V5T:6YT97)V86P@87-T;W)E M(&5X8V@@<&]P(&5S?6)D9@HO:V)[?6)D9@HO9'9[9'5P(# @;F5[9&EV?7MP M;W!]:69E;'-E?6)D9@HO97-[,R M,2!R;VQL(&1U<"!S82 X(&=E= IS82 Q M(&=E=" P(&YE>R]M;"!M;" N,B!P<R!M=6P@<W5B(&1E9GUI9@IN97MF<WU[ M<&]P?6EF96QS92!E>&-H(&1U<" Q(&5Q"GMP;W @+W1V(&%L(&UL(&=T>R]L M;"!L;V%D("]M;"!M;"!A;"!D=B!D969]>WMS:&]W('!O<"!P;W!]+VUL(#$@ M9&5F?6EF96QS92!D969]>V1U<" S(&5Q"GMP;W @+W1V(&%L(&UL(&=T>R]L M;"!L;V%D("]M;"!M;"!A;"!D=B!D969]>VUL(&%L('-U8B P(')M;W9E=&][ M<VAO=R!P;W @<&]P?2]M;" Q(&1E9GUI9F5L<V4@9&5F?7LR(&5Q"GLO='8@ M86P@;6P@9W1[+VQL(&QO860@+VUL(&UL(&%L(&1V(&1E9GU[;6P@86P@<W5B M(#(@9&EV(# @<FUO=F5T;WMS:&]W('!O<"!P;W!]+VUL(#$@9&5F?6EF96QS M92!D969]"GLO='8@+VQL(&QO860@+VUL(&UL(&%L(&1V(&1E9B!D969]:69E M;'-E?6EF96QS97UI9F5L<V4@=&T@=&<@<V5T9W)A>7UB9&8*+W!O<#1[<&]P M('!O<"!P;W @<&]P?6)D9@HO:71[<V9L>VUX,2!I=')A;G-F;W)M?6EF?6)D M9@HO9VU[97AC:"!I="!M;W9E=&]]8F1F"B]L;7MD;&T@97AE8WUB9&8*+V1L M;7M[<&]P(&-U<G)E;G1P;VEN="!S9FQ[;7@Q('1R86YS9F]R;7UI9B!E>&-H M('!O<"!S=6(@,"!E>&-H(&ET(')M;W9E=&]]?6)D9@HO9FU[<W1A='5S9&EC M=" O;6%N=6%L9F5E9"!K;F]W;GUB9&8*+W-E>W-T871U<V1I8W0@97AC:" O M;6%N=6%L9F5E9"!E>&-H('!U='UB9&8*+VUF>V1U<" O;6$@97AC:"!D968@ M,"!G='MF;2!S92 O=#$@-2!S="!O:R!M82 Q(&=T(&%N9'LO=#(@,"!S=" O M=#,@,"!S= IS=&%T=7-D:6-T("]M86YU86QF965D=&EM96]U=" S-C P('!U M= I]:69]:69]8F1F"B]J;GMO:WMS=&%T=7-D:6-T(&5X8V@@+VIO8FYA;64@ M97AC:"!P=71]>W!O<'UI9F5L<V5]8F1F"B]P96Y[<&YM(&UU;" O<&YS:"!X M9&8@<&YM(&UU;" O<&YS=B!X9&8@<&YS:"!S971L:6YE=VED=&A]8F1F"B]M M:6Y[,B!C;W!Y(&=T>V5X8VA]:68@<&]P?6)D9@HO;6%X>S(@8V]P>2!L='ME M>&-H?6EF('!O<'UB9&8*+V1H>V9G(#8@,2!P=70@87)R87D@87-T;W)E(&5X M8V@@<&]P(&5X8V@@<&]P(&5X8V@@<V5T9&%S:'UB9&8*+VEH6V-U<G)E;G1D M87-H761E9@HO<FA[9F<@-B P('!U="!I:"!A;&]A9"!P;W @<V5T9&%S:'UB M9&8*+V1L>V=S879E(&YL=R!P>7,@9&EV('-E=&QI;F5W:61T:" P('-E=&=R M87E]8F1F"B]D;&EN>V5X8V@@8W5R<F5N='!O:6YT(&YE=W!A=&@@;6]V971O M(&QI;F5T;R!C=7)R96YT<&]I;G0@<W1R;VME(&=R97-T;W)E(&UO=F5T;WUB M9&8*+VQI;GMF9R V(&=E=" P(&YE>VQI;F5T;R!C=7)R96YT<&]I;G0@,"!D M;V]P(&UO=F5T;WT*>V5X8V@@8W5R<F5N='!O:6YT("]P;FQV('AD9B O<&YL M:"!X9&8@9W-A=F4@;F5W<&%T:" O0'D@>&1F("] >"!X9&8@9G![<&YL:"! M>"!L='MP;FQV($!Y(&=E"GMP;FQH('!N;'8@;6]V971O($!X($!Y(&QI;F5T M;R!P;G-H(# @<FQI;F5T;PHP('!N<W8@<FQI;F5T;R!P;FQH('!N<V@@861D M('!N;'8@<&YS=B!A9&0@;&EN971O('!N<V@@;F5G(# @<FQI;F5T;WT*>W!N M;&@@<&YL=B!M;W9E=&\@<&YS:" P(')L:6YE=&\@0'@@<&YS:"!A9&0@0'D@ M;&EN971O(# @<&YS=B!R;&EN971O"G!N<V@@;F5G(# @<FQI;F5T;R!P;FQH M('!N;'8@<&YS=B!A9&0@;&EN971O?6EF96QS97U[<&YL=B! >2!G= I[0'@@ M0'D@;6]V971O('!N<V@@,"!R;&EN971O('!N;&@@<&YS:"!A9&0@<&YL=B!L M:6YE=&\@,"!P;G-V(')L:6YE=&\*<&YS:"!N96<@,"!R;&EN971O($!X($!Y M('!N<W8@861D(&QI;F5T;WU[<&YL:"!P;FQV(&UO=F5T;R!P;G-H(# @<FQI M;F5T;PHP('!N<W8@<FQI;F5T;R! >"!P;G-H(&%D9"! >2!P;G-V(&%D9"!L M:6YE=&\@<&YS:"!N96<@,"!R;&EN971O"C @<&YS=B!N96<@<FQI;F5T;WUI M9F5L<V5]:69E;'-E"F-L;W-E<&%T:"!F:6QL?6EF($!X($!Y(&=R97-T;W)E M(&UO=F5T;WUI9F5L<V5]8F1F"B]G=WLO<&YM(&9G(#,@9V5T(&9G(#0@9V5T M(&1I=B!D969]8F1F"B]L=WMF9R!E>&-H(#0@97AC:"!P=70@9F<@97AC:" S M(&5X8V@@<'5T(&=W('!N<W8@<&YS:"!P96Y]8F1F"B]B87)C>R] 9B!X9&8@ M+T!O<"!X9&8@+T!E('AD9B O0',@>&1F("] <B!X9&8*+T!B('AD9B O0&P@ M>&1F("] ="!X9&8@9W-A=F4*0'(@0&P@861D(#(@9&EV($!B($!T(&%D9" R M(&1I=B!T<F%N<VQA=&4@;F5W<&%T:" P(# @;6]V971O"D!R($!L('-U8B! M8B! ="!S=6(@;71X(&-U<G)E;G1M871R:7@@<&]P('-C86QE($!F>VYE=W!A M=&A]:68*," P(# N-2! <R! 92!A<F,*;71X('-E=&UA=')I>"! ;W @9&]O M<"!G<F5S=&]R97UB9&8*+V%R>V1U<" P(&5Q(&)A<F-]8F1F"B]O=GLP(&5X M8V@@,S8P(&5X8V@@=')U92!B87)C?6)D9@HO<F-[+T!O<"!X9&8@8W5R<F5N M='!O:6YT(#8@,B!R;VQL(&YE=W!A=&@@-"!C;W!Y"C0@,B!R;VQL(&5X8V@@ M;6]V971O(#8@+3$@<F]L;"!L:6YE=&\@;&EN971O(&QI;F5T;R!C;&]S97!A M=&@*0&]P(&1O;W @;6]V971O?6)D9@HO;75P>V1U<"!P;G-H(#(@9&EV(&QE M(&5X8V@@<&YS=B R(&1I=B!L92!O<GUB9&8*+W)R>R] ;W @>&1F(#(N(&1I M=B O0'<@>&1F(#(N(&1I=B O0&@@>&1F"B] <B!X9&8@+T!B('AD9B O0&P@ M>&1F("] ="!X9&8*0'0@0&(@97$@0&P@0'(@97$@0'<@;75P(&]R(&]R>T!T M($!L($!B($!R($!O<"!R8WT*>T!R($!L('-U8B R+B!D:78@9'5P($!W(&QT M>R] =R!X9&9]>W!O<'UI9F5L<V4*0&(@0'0@<W5B(#(N(&1I=B!D=7 @0'<@ M;'1[+T!W('AD9GU[<&]P?6EF96QS90I ;W @,"!E<7LO0'<@0'<@<&YS:" R M(&1I=B R(&-O<'D@9W1[<W5B(&1E9GU[,"!P;W T?6EF96QS97UI9@IC=7)R M96YT<&]I;G0@;F5W<&%T: I <B! ;"!A9&0@,BX@9&EV($!T(&UO=F5T;PI M<B! ="! <B! 8B! =R!A<F-T;R!P;W T"D!R($!B($!L($!B($!W(&%R8W1O M('!O<#0*0&P@0&(@0&P@0'0@0'<@87)C=&\@<&]P- I ;"! ="! <B! ="! M=R!A<F-T;R!P;W T"F-L;W-E<&%T:"! ;W @9&]O<"!M;W9E=&]]:69E;'-E M?6)D9@HO<')[9W-A=F4@;F5W<&%T:" O<&Q[97AC:"!M;W9E=&\@+W!L>V5X M8V@@;&EN971O?61E9GUD969]8F1F"B]P;'ME>&-H(&QI;F5T;WUB9&8*+V5P M>V1U<" P(&5Q>WMM;W9E=&]]>V5X8V@@;&EN?7M]>R@E)5M\,7Q=)24I/2!F M;'5S:'UP871H9F]R86QL"G!O<"!G<F5S=&]R97U[9&]O<"!G<F5S=&]R97UI M9F5L<V4@8W5R<F5N='!O:6YT(&YE=W!A=&@@;6]V971O?6)D9@HO9W)[-C0N M(&1I=B!S971G<F%Y?6)D9@HO<&%T>W,X(&-O<'D@<&]P(#DN,S<U(#![,2!A M9&0@-"!M=6P@8W9I(',X(&5X8V@@9V5T(&5X8V@@,2!A9&0@-"!M=6P@8W9I M(#<@<W5B(&)I='-H:69T(#$@86YD?7-E='-C<F5E;B!G<GUB9&8*+W-G>V9R M97$@<F]T("]S<&8@;&]A9"!S971S8W)E96X@9W)]8F1F"B]D8WMT<F%N<V9O M<FT@<F]U;F0@+C4@<W5B(&5X8V@@<F]U;F0@+C4@<W5B(&5X8V@@:71R86YS M9F]R;7UB9&8*+W-N>W5S97)D:6-T("]S;6]O=&@@:VYO=VY]8F1F"B]X.'LS M(&)I='-H:69T?6)D9@HO>#1[,B!B:71S:&EF='UB9&8*+V0T>RTR(&)I='-H M:69T?6)D9@HO>&9[+C$R(&UU;"!E>&-H(#@N(&1I=GUB9&8*+V1B>R]B;6]D M92!X9&8*<V%V92 Y(#$@<F]L;"!S;B!A;F0@." T(')O;&P@>&8@97AC:"!D M8R!T<F%N<VQA=&4@;F5W<&%T:" P(# @;6]V971O"C(@8V]P>2!X9B N.38@ M;75L(&5X8V@@<V-A;&4@<&]P"C @," Q(#$@-2 M,2!R;VQL(#<@:6YD97@@ M,B!S=6(@97AC:"!D:78@,3(P,"!D:78@<W5B(#$P(')C(&-L:7 @;F5W<&%T M:" P(# @;6]V971O"F)M;V1E(# @97$@8FUO9&4@-"!E<2!O<GLQ('-E=&=R M87D@+C4@+C4@:61T<F%N<V9O<FT@86)S(&5X8V@@86)S"C(@8V]P>2!N96<@ M,2!A9&0@97AC:"!N96<@,2!A9&0@97AC:" R(')C?6EF"F)M;V1E(#,@97$@ M8FUO9&4@-R!E<2!O<GLQ?7LP?6EF96QS92!S971G<F%Y"B] 9B H)7-T9&EN M*2AR*2!F:6QE(&1E9@I[>#0@+T!D>2!X9&8@,B!S=6(@>#0@+T!D>"!X9&8@ M+T!I9'@@>&1F"D!I9'@@-2!B:71S:&EF="! 9'D@8FUO9&4@,"!E<2!B;6]D M92 Q(&5Q(&)M;V1E(#,@97$@;W(@;W(@0&1X(# @,"! 9'D@." P(#9A(&%S M=&]R90I[0&8@0&1Y(&0T(#0@861D($!I9'@@;75L('-T<FEN9R!R96%D:&5X M<W1R:6YG('!O< ID=7 @;&5N9W1H($!I9'@@>#0@<W5B(#0@8FET<VAI9G0@ M<W1R:6YG"F1U<" S(#$@<F]L;"! 9'@@."!A9&0@9#0@<VUO;W1H?6EM86=E M;6%S:WT*>R] 9'D@>&1F(#(@<W5B("] 9'@@>&1F("] :61X('AD9@HO0'AS M($!I9'@@<W1R:6YG(&1E9@HO0'![0&8@0'AS(')E861H97AS=')I;F<@<&]P M?61E9@I <"! <"! :61X(#,@8FET<VAI9G0@0&1Y(&)M;V1E(# @97$@8FUO M9&4@,2!E<2!B;6]D92 S(&5Q(&]R(&]R($!D>" P(# @0&1Y(# @," V82!A M<W1O<F4*>T!P?6EM86=E;6%S:R! <"! <"!P;W T?6EF96QS92!R97-T;W)E M?6)D9@HO=V0@,30@9&EC="!D968*+VUF;VYT(#$T(&1I8W0@9&5F"B]M9&9[ M;69O;G0@=V-H96-K(&YO='LO;69O;G0@,30@9&EC="!D969]:68@;69O;G0@ M8F5G:6X@>&1F(&5N9'UB9&8*+V-F>WLQ(&EN9&5X("]&240@;F5[=&UP(#,@ M,2!R;VQL('!U='U[<&]P('!O<'UI9F5L<V5]9F]R86QL?6)D9@HO;79[9FUV M>W1M<" O16YC;V1I;F<@;6%C=F5C('!U='UI9GUB9&8*+V1U>V9I;F1F;VYT M(&1U<"!L96YG=&@@9&EC=" O=&UP(&5X8V@@9&5F(&-F?6)D9@HO;F9[=&UP M(&1E9FEN969O;G0@<&]P?6)D9@HO<F9[+V9M=B!E>&-H(&1E9B!D=2!M=B!N M9GUB9&8*+V9E>W1M<" O16YC;V1I;F<@,B!C;W!Y(&=E="!D=7 @;&5N9W1H M(&%R<F%Y(&-O<'D@<'5T?6)D9@HO8V5[=&UP("]%;F-O9&EN9R!G970@,R Q M(')O;&P@<'5T?6)D9@HO>'-[,"!S97)V97)D:6-T(&)E9VEN(&5X:71S97)V M97)]8F1F"B]B;6)C>W=D(&)E9VEN"B]C<B!X9&8@+V9D('AD9B!S879E(&9D M("]L;W<@9V5T(&-R('@T(#8@9V5T:6YT97)V86P@9'5P(#,@9V5T(#(U-2!E M<7MP;W @," P(# @," P(# @<V5T8V%C:&5D979I8V5]>V9D(&)E9VEN"F1U M<" T(&=E=" X(&)I='-H:69T(#$@:6YD97@@-2!G970@861D"F5X8V@@9'5P M(# @9V5T(#@@8FET<VAI9G0@,2!I;F1E>" Q(&=E="!A9&0@97AC:"!D=7 @ M,B!G970@:VT@861D(&5X8V@@,R!G970@>&T@86QO860@<&]P"F5N9"!D=7 @ M<V-A;&4@+W-H('AD9B O<W<@>&1F(&YE9R O9&5S8R!X9&8*+VAW9"!L;V%D M(# @9V5T(&1I=B T(#$@<F]L;" O8V]F9B!X9&8@9'5P("]C;&]C('AD9B!S M=6(@+V)I='<@>&1F"C @8V]F9B!D97-C(&)I='<@8V]F9B!A9&0@<V@@<V5T M8V%C:&5D979I8V4*8FET=R P(&YE>V-O9F8@9&5S8R!T<F%N<VQA=&4@;F5W M<&%T:" P(# @;6]V971O"FUA<FL@8VQO8R X(&UO9"!D=7 @8FET=R!A9&0@ M9'5P(#@@9&EV(&-E:6QI;F<@8W9I(#$@861D(&1U<" Q(&%N9" P(&YE>S$@ M861D?6EF("]B>7<@>&1F"ELR(#<@-"!I;F1E>"!S=6(@8FET<VAI9G0@,2!S M=6(@,B W(#0@:6YD97@@."!M;V0@<W5B(&)I='-H:69T(#$@<W5B(&YO= HS M(&EN9&5X(#@@:61I=B Q('-U8B!D=7 @,"!G97M[,C4U(&5X8VA]<F5P96%T M?7MP;W @86YD?6EF96QS92 P(#!="B]R9R!B>7<@<V@@<V][-"!A9&1]:68@ M;75L('-T<FEN9R!D968*<W<@."!I9&EV(&9D("]H;2!G970@8VQO8R X(&ED M:78@<V][8GEW(#$@8FET<VAI9G1]>S!]:69E;'-E"G-H>S(@:6YD97@@,B!I M;F1E>"!B>7<@9V5T:6YT97)V86P@<F<@,B!I;F1E>"!B>7<@9V5T:6YT97)V M86P@8V]P>2!P;W *8GEW(&%D9"!E>&-H(#,@:6YD97@@861D(&5X8VA]<F5P M96%T"C @,2!R9R!L96YG=&@@,2!S=6)[<F<@,2!I;F1E>"!G970@-B!I;F1E M>" R(&EN9&5X(&)Y=R!M;V0@9V5T(&%N9"!R9R S(#$@<F]L;"!P=71]9F]R M"F)Y=R!X."!D=7 @<V@@<V-A;&4@<V][>#0@<V@@>#0@=')U92 R(&EN9&5X M(# @,"!S:"!X-"!N96<*,3,@:6YD97@@>#0@."!A9&0@,2!I;F1E>"!N96<@ M-F$@87-T;W)E>V)Y=R!S:"!M=6P@,38@;75L('-T<FEN9R!R9R Q(&EN9&5X M(&)Y=R!X."!S;6]O=&A]:6UA9V5M87-K?0I[<V@@=')U92 R(&EN9&5X(# @ M,"!S:"!N96<@,3,@:6YD97@@<V@@-F$@87-T;W)E>W)G?6EM86=E;6%S:WUI M9F5L<V4@8VQE87)T;VUA<FM]:68*?6EF96QS92!R97-T;W)E(&5N9'UB9&8* M+V)B>S,@:6YD97@@9&EV(#0@,2!R;VQL"C(@:6YD97@@9&EV(#$@-2 R(')O M;&P*97AC:"!D:78@-" Q(')O;&P*-"!A<G)A>2!A<W1O<F4@+T9O;G1"0F]X M(&UD9@I]8F1F"B]H=V0@3%<K>RXY-GU[,2Y]:69E;'-E"B]E>&-H(&QO860@ M+V1I=B!L;V%D(#0@+V%R<F%Y(&QO860@+V%S=&]R92!L;V%D("]X;2 O;61F M(&-V> HX($Q7*WMP86-K961A<G)A>7U[87)R87D@87-T;W)E?6EF96QS92!C M=G@@8F1F"B]B9GL*;69O;G0@8F5G:6X*+T9O;G14>7!E(#,@9&5F"B]&;VYT M36%T<FEX(%LQ(# @," Q(# @,%T@9&5F"B]%;F-O9&EN9R!M86-V96,@9&5F M"B]"=6EL9$-H87(@+V)M8F,@;&]A9"!D968*96YD"FUF;VYT(&1E9FEN969O M;G0@<&]P"GUB9&8*+W=I($Q7*WLO<W1R:6YG=VED=&@@;&]A9'T*>WMG<V%V M92 P(# @," P(# @," P(# @;6]V971O(&QI;F5T;R!L:6YE=&\@;&EN971O M(&-L;W-E<&%T:"!C;&EP('-T<FEN9W=I9'1H(&=R97-T;W)E?6)I;F1]:69E M;'-E(&1E9@HO87!S>S @9V5T(#$R-"!E<7UB9&8*+V%P;GMS-S4@8W9S(&%P M<WUB9&8*+WAC>W,W-2!C=G,@9'5P?6)D9@HO>'![<'5T(&-V;GUB9&8*+W-C M<WMX8R S(#8W('!U="!D=7 @," Y-2!X<'UB9&8*+W-O<WMX8R S(#<Y('AP M?6)D9@HO<V)S>WAC(#$@-C8@>'!]8F1F"B]S:7-[>&,@,B W,R!X<'UB9&8* M+W-O8GMX8R R(#<Y('AP?6)D9@HO<W-S>WAC(#0@.#,@>'!]8F1F"B]D9'ME M>&-H(#$@:6YD97@@861D(#,@,2!R;VQL(&%D9"!E>&-H?6)D9@HO<VUC>VUO M=F5T;R!D=7 @;'=S?6)D9@HO:W=N>V1U<"!&;VYT1&ER96-T;W)Y(&5X8V@@ M:VYO=VY[9FEN9&9O;G0@97AC:"!P;W!]?6)D9@HO9VQ[,2!C=7)R96YT9W)A M>2!S=6(@<V5T9W)A>7UB9&8*+VUM>R]M9F]N=" Q,"!D:6-T(&1E9B!M9F]N M="!B96=I;@HO1F]N=$UA=')I>"!;,2 P(# @,2 P(#!=(&1E9@HO1F]N=%1Y M<&4@,R!D968*+T5N8V]D:6YG(&UA8W9E8R!D968*+V1F(#0@:6YD97@@9FEN M9&9O;G0@9&5F"B]&;VYT0D)O>"!;," P(#$@,5T@9&5F"B]X9&$@>&1F("]M M8F,@>&1F"B]"=6EL9$-H87)[=V0@8F5G:6X@+V-R('AD9B O9F0@>&1F("]C M<R!S,2!D=7 @,"!C<B!P=70@9&5F(&9D("]M8F,@9V5T(&5X96,@96YD?61E M9@IE>&5C(&5N9"!M9F]N="!D969I;F5F;VYT?6)D9@HO86-[9'5P('-C<R!K M=VY[97AC:" O;V9D(&5X8V@@9FEN9&9O;G0@9&5F("]T;7 @;V9D(&UA>&QE M;F=T:" Q(&%D9"!D:6-T(&1E9B!O9F0@8V8@;78*=&UP(&1U<"!D=7 @+U-T M<F]K95=I9'1H(&YL=R Q,# P(&UU;"!P>7,@9&EV('!S(&1I=B!D=7 @,3(@ M;'1[<&]P(#$R?6EF('!U= HO4&%I;G14>7!E(#(@<'5T(&1E9FEN969O;G1] M:69E;'-E?6)D9@HO;6)[9'5P('-B<R!K=VY[97AC:'MP;W!]>V)B8WU[?6UM M?6EF96QS92!S9F1]8F1F"B]M;WMD=7 @<V]S(&MW;GME>&-H>W!O<'U[8F]C M?7M];6U]:69E;'-E('-F9'UB9&8*+VUS>V1U<"!S<W,@:W=N>V5X8VA[<&]P M?7MB<V-]>WUM;7UI9F5L<V4@<V9D?6)D9@HO;W5[9'5P('-O<R!K=VY[97AC M:"!D=7 @86,@<&]P>W-C<R!F:6YD9F]N=" O9&8R('AD9GU[86]C?7M];6U] M:69E;'-E('-F9'UB9&8*+W-U>V1U<"!S<W,@:W=N>V5X8V@@9'5P(&%C('!O M<'MS8W,@9FEN9&9O;G0@+V1F,B!X9&9]>V%S8WU[?6UM?6EF96QS92!S9F1] M8F1F"B]A;WLO9FUV('1R=64@9&5F(&]U?6)D9B O87-[+V9M=B!T<G5E(&1E M9B!S=7UB9&8@+W9O>R]F;78@9F%L<V4@9&5F(&]U?6)D9B O=G-[+V9M=B!F M86QS92!D968@<W5]8F1F"B]B8F-[+V1A("XP,R!D968@9F0@+V1F(&=E="!S M971F;VYT"F=S879E(&-S('=I(&5X8V@@9&$@861D(&5X8V@@9W)E<W1O<F4@ M<V5T8VAA<G=I9'1H"F-S(# @,"!S;6,@9&$@,"!S;6,@9&$@9&$@<VUC(# @ M9&$@;6]V971O(&QW<WUB9&8*+V)O8WLO9&$@,2!P<R!D:78@9&5F(&9D("]D M9B!G970@<V5T9F]N= IG<V%V92!C<R!W:2!E>&-H(&1A(&%D9"!E>&-H(&=R M97-T;W)E('-E=&-H87)W:61T: IC<R P(# @<VUC(&1A(# @<VUC(&1A(&1A M('-M8R P(&1A('-M8R!G;"!D82 R+B!D:78@9'5P(&UO=F5T;R!L=W-]8F1F M"B]B<V-[+V1A(#$@<',@9&EV(&1E9@HO9',@+C U(&1E9B O9&$R(&1A(#(N M(&1I=B!D968@9F0@+V1F(&=E="!S971F;VYT"F=S879E(&-S('=I(&5X8V@@ M9',@861D(&1A,B!A9&0@97AC:"!G<F5S=&]R92!S971C:&%R=VED=&@*8W,@ M9',@9&$R(&%D9" N,#$@861D(# @<VUC(# @9',@9&$R('-U8B!T<F%N<VQA M=&4@," P('-M8PID82 P('-M8R!D82!D82!S;6,@,"!D82!S;6,@9VP@9&$@ M,BX@9&EV(&1U<"!M;W9E=&\@;'=S?6)D9@HO86]C>V9D("]D9B!G970@<V5T M9F]N= IG<V%V92!C<R!W:2!G<F5S=&]R92!S971C:&%R=VED=&@*9VP@8W,@ M," P('-M8R!F9" O9&8R(&=E="!S971F;VYT(&=L(# @,"!M;W9E=&\@;'=S M?6)D9@HO87-C>R]D82 N,#4@9&5F(&9D("]D9B!G970@<V5T9F]N= IG<V%V M92!C<R!W:2!E>&-H(&1A(&%D9"!E>&-H(&=R97-T;W)E('-E=&-H87)W:61T M: IC<R!D82 N,#$@861D(# @<VUC(# @9&$@=')A;G-L871E(&=L(# @,"!S M;6,@9VP@9F0@+V1F,B!G970@<V5T9F]N=" P(# @;6]V971O(&QW<WUB9&8* M+V1L>7LO0'0@97AC:"!S='M ="!T:&5[97AI='UI9GUL;V]P?6)D9@HO<W1[ M,3 P,"!M=6P@=7-E<G1I;64@861D(&1U<" R,30W-#@S-C0W(&=T>S(Q-#<T M.#,V-#<@<W5B?6EF(&1E9GUB9&8*+W1H97MU<V5R=&EM92!S=6(@9'5P(# @ M;'0@97AC:" M,C$T-S0X,S8T."!G="!A;F1]8F1F"B]L<V9[1F]N=$1I<F5C M=&]R>7MP;W @9'5P(&%P;GL](&9L=7-H?7MD=7 @<S<U(&1U<" P("A\7U]? M7U]?*2!P=71I;G1E<G9A; HW(#8X(&=E=&EN=&5R=F%L(&-V<R!L96YG=&@@ M-R!A9&0@<S<U(# @,R M,2!R;VQL(&=E=&EN=&5R=F%L(&-V;@I&;VYT1&ER M96-T;W)Y(&5X8V@@:VYO=VY[<&]P?7L](&9L=7-H?6EF96QS97T*:69E;'-E M?69O<F%L;" O*B ](&9L=7-H?6)D9@HO-F$@-B!A<G)A>2!D968*+S)A(#(@ M87)R87D@9&5F"B\S<2 S(&%R<F%Y(&1E9@HO<7-[,R M,2!R;VQL('-U8B!E M>&-H(#,@+3$@<F]L;"!S=6(@97AC:'UB9&8*+W%A>S,@+3$@<F]L;"!A9&0@ M97AC:" S("TQ(')O;&P@861D(&5X8VA]8F1F"B]Q;7LS("TQ(')O;&P@,2!I M;F1E>"!M=6P@,R Q(')O;&P@;75L?6)D9@HO<6Y[-F$@97AC:"!G970@;75L M?6)D9@HO<4$@+C$V-C8V-R!D968@+W%"("XX,S,S,S,@9&5F("]Q0R N-2!D M968*+W%X>S9A(&%S=&]R92!P;W *<4$@,"!Q;B!Q0B R('%N(&%D9" @('%! M(#$@<6X@<4(@,R!Q;B!A9&0*<4(@,B!Q;B!Q02 T('%N(&%D9" @('%"(#,@ M<6X@<4$@-2!Q;B!A9&0*<4,@,B!Q;B!Q0R T('%N(&%D9" @('%#(#,@<6X@ M<4,@-2!Q;B!A9&1]8F1F"B]Q<'LV(&-O<'D@,3(@+3(@<F]L;"!P;W @<&]P M?6)D9@HO<6-[97AC:"!Q<"!Q>"!C=7)V971O?6)D9@HO<6E[>V5X8V@@-"!C M;W!Y(#)A(&%S=&]R92!A;&]A9"!P;W @<6$@+C4@<6T@;F5W<&%T:"!M;W9E M=&]]>V5X8V@@,B!C;W!Y(#8@+3(@<F]L;" R('%M('%S(#0@,B!R;VQL?6EF M96QS97UB9&8*+W%Q>WMQ8R R82!A;&]A9"!P;W @<7@@8W5R=F5T;WU[97AC M:" T(&-O<'D@<7,@<6$@<7@@8W5R=F5T;WUI9F5L<V5]8F1F"B]P='MC=7)R M96YT<&]I;G0@;F5W<&%T:"!M;W9E=&]]8F1F"B]Q9GLO9FEL;&9L86<@=')U M92!D969]8F1F"B]E8WLQ(&%N9" P(&YE>S @9&]O<'UI9B!G<F5S=&]R92!C M=7)R96YT<&]I;G0@;F5W<&%T:"!M;W9E=&\@+V9I;&QF;&%G(&9A;'-E(&1E M9GUB9&8*+V5U>V-U<G)E;G1P;VEN="!F<'LP(&5P?7MG<F5S=&]R92!N97=P M871H?6EF96QS92!M;W9E=&\@+V9I;&QF;&%G(&9A;'-E(&1E9GUB9&8*+V)P M>V-U<G)E;G1P;VEN="!N97=P871H(#(@8V]P>2!M;W9E=&]]8F1F"B]E9GMG M<V%V92!F:6QL9FQA9WMG<V%V92!E;V9I;&P@9W)E<W1O<F5]:69]8F1F"B]S M;7MD=7 @,"!E>&-H>S,R(&5Q>S$@861D?6EF?69O<F%L;'UB9&8*+VQL>S,@ M,2!R;VQL(&5X8V@@9'5P(&%B<R N,# Q(&QT>W!O<"!P;W @<&]P?0I[<W5B M(&1U<"!A8G,@+C4@;'1[<&]P('-H;W=]>S$@:6YD97@@<VT*9F<@-R!G970@ M9'5P(#$R-R!N97LT(#$@<F]L;"!E>&-H('!O<"!D=B P(#0@+3(@<F]L;"!E M>&-H('=I9'1H<VAO=WT*>W!O<"!D=7 @,"!E<2 S(&EN9&5X(# @;&4@;W)[ M<&]P(&QE;F=T:"!D:78@," S("TQ(')O;&P@87-H;W=]"GLQ,"!M=6P@97AC M:"!L96YG=&@@861D(&1I=B!D=7 @,3 @;75L(# @,S(@-" M,2!R;VQL(# @ M-B M,2!R;VQL(&%W:61T:'-H;W<*?6EF96QS97UI9F5L<V5]:69E;'-E?6EF M96QS97UB9&8*+V1S<WMC=7)R96YT9F]N="!B=2 P('-A(#8@9V5T(# @;F5[ M<&]P(#%]>W-A(#<@9V5T(# @97%[<&]P(#)]:69]:69E;'-E('-A(#$@9V5T M(# @;F4*+WQ?7U]?7U]3>6UB;VP@<V$@-"!G970@,"!N97MV<WU[<V$@,R!G M970@,"!N97MV;WU[9FYT?6EF96QS97UI9F5L<V4@8FX@9F<@-R!G970@8W5R M<F5N=&9O;G1]8F1F"B]S<WMD<W,@<&]P('!O<'UB9&8*+V1P9GMF9R W(&=E M=" X("TQ(')O;&P@9'5P('-E=&9O;G1]8F1F"B]P9GMS971F;VYT?6)D9@HO M;6-[," S(#$@<F]L;"!T<F%N<V9O<FT@;F5G(&5X8V@@<&]P?6)D9@HO<G-[ M<V$@,B!G970@,"!N97MG<V%V92 Q(&EN9&5X(# *+U5N9&5R;&EN95!O<VET M:6]N(&MI9GMM8WU[<',@+3$P(&1I=GUI9F5L<V4*+U5N9&5R;&EN951H:6-K M;F5S<R!K:69[;6-]>W!S(#$U(&1I=GUI9F5L<V4*<V5T;&EN97=I9'1H(&-U M<G)E;G1P;VEN=" S("TQ(')O;&P@<W5B(&UO=F5T;PIS82 T(&=E=" P(&YE M>V=S879E(&-U<G)E;G1L:6YE=VED=&@@,BX@9&EV(&1U<"!R;6]V971O(&-U M<G)E;G1P;VEN="!T<F%N<VQA=&4@,B!C;W!Y(')L:6YE=&\*<W1R;VME(&=R M97-T;W)E?6EF('-A(#,@9V5T('-A(#0@9V5T(&]R(# @;F4@,R Q(')O;&P@ M,B!I;F1E>'MG<V%V92!G;" R(&-O<'D@<FQI;F5T;R!S=')O:V4@9W)E<W1O M<F5]:68*<FQI;F5T;WMS=')O:V5P871H(&YL=R!P>7,@9&EV('-E=&QI;F5W M:61T:'UI9B!S=')O:V4@9W)E<W1O<F5]:68@='9]8F1F"B]S9W1[,B!C;W!Y M(&MN;W=N>V=E="!T<G5E?7MP;W @<&]P(&9A;'-E?6EF96QS97UB9&8*+VMI M9GMC=7)R96YT9F]N="!D=7 @+T9O;G1-871R:7@@9V5T(&5X8V@@+T9O;G1) M;F9O('-G='MT<G5E?7MC=7)R96YT9F]N=" O9&8@<V=T"GMD=7 @+T9O;G1) M;F9O('-G='LS(#$@<F]L;" O1F]N=$UA=')I>"!G970@;71X(&-O;F-A=&UA M=')I>"!E>&-H('1R=65]>W!O<"!P;W @<&]P(&9A;'-E?0II9F5L<V5]>W!O M<"!P;W @9F%L<V5]:69E;'-E?6EF96QS97LS("TQ(')O;&P@<V=T>V5X8V@@ M=')U97U[<&]P(&9A;'-E?6EF96QS97U[9F%L<V5]:69E;'-E?6)D9@HO8FQA M;FL@+U1I;65S+5)O;6%N(&9I;F1F;VYT("]#:&%R4W1R:6YG<R!G970@+W-P M86-E(&=E="!D968*+VUA8W9E8R R-38@87)R87D@9&5F"B].54P@+U-/2" O M4U18("]%5%@@+T5/5" O14Y1("]!0TL@+T)%3" O0E,@+TA4("],1B O5E0@ M+T9&("]#4B O4T\@+U-)"B]$3$4@+T1#,2 O1$,R("]$0S,@+T1#-" O3D%+ M("]364X@+T540B O0T%.("]%32 O4U5"("]%4T,@+T93("]'4R O4E,@+U53 M"FUA8W9E8R P(#,R(&=E=&EN=&5R=F%L(&%S=&]R92!P;W *;6%C=F5C(#,R M("]4:6UE<RU2;VUA;B!F:6YD9F]N=" O16YC;V1I;F<@9V5T"C,R(#DV(&=E M=&EN=&5R=F%L('!U=&EN=&5R=F%L(&UA8W9E8R!D=7 @,SD@+W%U;W1E<VEN M9VQE('!U=" Y-B O9W)A=F4@<'5T"B]!9&EE<F5S:7,@+T%R:6YG("]#8V5D M:6QL82 O16%C=71E("].=&EL9&4@+T]D:65R97-I<R O561I97)E<VES("]A M86-U=&4*+V%G<F%V92 O86-I<F-U;69L97@@+V%D:65R97-I<R O871I;&1E M("]A<FEN9R O8V-E9&EL;&$@+V5A8W5T92 O96=R879E"B]E8VER8W5M9FQE M>" O961I97)E<VES("]I86-U=&4@+VEG<F%V92 O:6-I<F-U;69L97@@+VED M:65R97-I<R O;G1I;&1E("]O86-U=&4*+V]G<F%V92 O;V-I<F-U;69L97@@ M+V]D:65R97-I<R O;W1I;&1E("]U86-U=&4@+W5G<F%V92 O=6-I<F-U;69L M97@@+W5D:65R97-I<PHO9&%G9V5R("]D96=R964@+V-E;G0@+W-T97)L:6YG M("]S96-T:6]N("]B=6QL970@+W!A<F%G<F%P:" O9V5R;6%N9&)L<PHO<F5G M:7-T97)E9" O8V]P>7)I9VAT("]T<F%D96UA<FL@+V%C=71E("]D:65R97-I M<R O;F]T97%U86P@+T%%("]/<VQA<V@*+VEN9FEN:71Y("]P;'5S;6EN=7,@ M+VQE<W-E<75A;" O9W)E871E<F5Q=6%L("]Y96X@+VUU("]P87)T:6%L9&EF M9B O<W5M;6%T:6]N"B]P<F]D=6-T("]P:2 O:6YT96=R86P@+V]R9&9E;6EN M:6YE("]O<F1M87-C=6QI;F4@+T]M96=A("]A92 O;W-L87-H"B]Q=65S=&EO M;F1O=VX@+V5X8VQA;61O=VX@+VQO9VEC86QN;W0@+W)A9&EC86P@+V9L;W)I M;B O87!P<F]X97%U86P@+T1E;'1A("]G=6EL;&5M;W1L969T"B]G=6EL;&5M M;W1R:6=H=" O96QL:7!S:7,@+V)L86YK("]!9W)A=F4@+T%T:6QD92 O3W1I M;&1E("]/12 O;V4*+V5N9&%S:" O96UD87-H("]Q=6]T961B;&QE9G0@+W%U M;W1E9&)L<FEG:'0@+W%U;W1E;&5F=" O<75O=&5R:6=H=" O9&EV:61E("]L M;WIE;F=E"B]Y9&EE<F5S:7,@+UED:65R97-I<R O9G)A8W1I;VX@+V-U<G)E M;F-Y("]G=6EL<VEN9VQL969T("]G=6EL<VEN9VQR:6=H=" O9FD@+V9L"B]D M86=G97)D8FP@+W!E<FEO9&-E;G1E<F5D("]Q=6]T97-I;F=L8F%S92 O<75O M=&5D8FQB87-E("]P97)T:&]U<V%N9" O06-I<F-U;69L97@@+T5C:7)C=6UF M;&5X("]!86-U=&4*+T5D:65R97-I<R O16=R879E("])86-U=&4@+TEC:7)C M=6UF;&5X("])9&EE<F5S:7,@+TEG<F%V92 O3V%C=71E("]/8VER8W5M9FQE M> HO87!P;&4@+T]G<F%V92 O56%C=71E("]58VER8W5M9FQE>" O56=R879E M("]D;W1L97-S:2 O8VER8W5M9FQE>" O=&EL9&4*+VUA8W)O;B O8G)E=F4@ M+V1O=&%C8V5N=" O<FEN9R O8V5D:6QL82 O:'5N9V%R=6UL875T("]O9V]N M96L@+V-A<F]N"FUA8W9E8R Q,C@@,3(X(&=E=&EN=&5R=F%L(&%S=&]R92!P M;W *+WQ?7U]?7U]396%T=&QE("](96QV971I8V$@9FEN9&9O;G0@9'5P(&QE M;F=T:" Q(&%D9"!D:6-T("]T;7 @>&1F(&-F(&UV"B]M>'9;+WIE<F\@+V]N M92 O='=O("]T:')E92 O9F]U<B O9FEV92 O<VEX("]S979E;B O96EG:'0@ M+VYI;F4@+V-O;6UA("]P97)I;V0@+V1O;&QA<B O;G5M8F5R<VEG;@HO<&5R M8V5N=" O<&QU<R O:'EP:&5N("]%("]P87)E;FQE9G0@+W!A<F5N<FEG:'0@ M+W-P86-E761E9@IT;7 @+TUE=')I8W,@,C$@9&EC="!D=7 @8F5G:6X@;7AV M>S8P,"!D969]9F]R86QL(&5N9"!P=70*=&UP(&)E9VEN("]&;VYT0D)O>"!& M;VYT0D)O>"!;," P(# @,%T@87-T;W)E(&1E9B!E;F0*=&UP(&1E9FEN969O M;G0@<&]P"F9A;'-E>PHO<F1[+T!T(#4@<W0@,'MR96%D4E,R,S)[97AC:" Q M(&%D9"!E>&-H(#$@:6YD97@@,R!E<7ME>&ET?0I[<&]P?6EF96QS97U[0'0@ M=&AE>S @97AI='UI9GUI9F5L<V5];&]O<"!E>&-H('!O<'UB9&8*+W-F>S8V M('=R:71E4E,R,S(@<F0@-C0@97$@*$)"1D="*2!T>2!G970@=W)I=&524S(S M,B!R9" V-"!E<2!A;F1]8F1F"B]A9GMR9" V-"!N97LO0'@@-"XU('-T>W-F M>V5X:71]:68@0'@@=&AE"GLO0'@@-"XU('-T*"4E6W-T871U<SH@<')O8FQE M;2!W:71H(&5X=&5R;F%L('!A<&5R(&9E961E<ETE)2D](&9L=7-H?6EF?6QO M;W!]:69]8F1F"B]K9GMA9B!H<" H0D)$0T4I('1Y(&=E="!W<FET95)3,C,R M?6)D9@HO:'![>W0Q('1H97LO=#$@=#(@=&AE('1Y(#0@97$@;W)[>W0S('1H M97ME>&ET?6EF?6QO;W @,3@@<W0@,3A]>SD@<W0@.7UI9F5L<V4*9'5P(#(@ M861D("]T,B!E>&-H('-T(#0N-2!A9&0@+W0S(&5X8V@@<W0@97AI='UI9GUL M;V]P?6)D9@HO9GA[;6$@,2!G="!O:R!A;F1[;6$@-2!E<7LO0'0@-"XU('-T M>W!O(#4R-#(X."!A;F0@,"!E<7ME>&ET?6EF"D!T('1H97LH)25;<W1A='5S M.B!P87!E<B!J86U=)24I(#T@9FQU<V@@+T!T(#0N-2!S='UI9GUL;V]P("] M>" T+C4@<W0*<F0@-C0@97$@<V8@86YD>WLV-B!W<FET95)3,C,R(&MF(&5X M:71]>R]T>2 H # , S #(I('1Y(&=E="!D969]:69E;'-E($!X('1H90I[ M*"4E6W-T871U<SH@97AT97)N86P@9F5E9&5R(&]U="!O9B!P87!E<ETE)2D] M(&9L=7-H("] >" T+C4@<W1]:68@<V9];&]O<'U[:V9]:69E;'-E?6EF?6)D M9@HO<W![(V-O<&EE<R!D=7 @=7-E<F1I8W0@+R-C;W!I97,@,2!P=70@,2!G M97LQ('-U8GMF>"!C;W!Y<&%G97UR97!E870@9G@@<VAO=W!A9V5]>S$@9V5[ M9G@@<VAO=W!A9V5]>V5R87-E<&%G97UI9F5L<V5]:69E;'-E?6)D9@HO<'![ M(V-O<&EE<R!U<V5R9&EC=" O(V-O<&EE<R Q('!U='MF>"!C;W!Y<&%G97UR M97!E871]8F1F"GU[+W-P("]S:&]W<&%G92!L;V%D(&1E9B O<' @+V-O<'EP M86=E(&QO860@9&5F?6EF96QS90HO;V1[*%)V9%PP,#%<,# Q7# P,%PP,#!< M,3<W*2!F9R!C;W!Y('!O<"!T>'!O<V4@;F5W<&%T:"!C;&EP<&%T:"!M87)K M"GMT<F%N<V9O<FU[:71R86YS9F]R;2!M;W9E=&]]?7MT<F%N<V9O<FU[:71R M86YS9F]R;2!L:6YE=&]]?0I[-B M,B!R;VQL('1R86YS9F]R;2 V("TR(')O M;&P@=')A;G-F;W)M(#8@+3(@<F]L;"!T<F%N<V9O<FT*>VET<F%N<V9O<FT@ M-B R(')O;&P@:71R86YS9F]R;2 V(#(@<F]L;"!I=')A;G-F;W)M(#8@,B!R M;VQL(&-U<G9E=&]]?0I[>V-L;W-E<&%T:'U]<&%T:&9O<F%L;"!N97=P871H M(&-O=6YT=&]M87)K(&%R<F%Y(&%S=&]R92 O9V,@>&1F('!O<"!C=" S.2 P M('!U= HQ,"!F>B P(&9S(#(@1B O?%]?7U]?7T-O=7)I97(@9FYT?6)D9@HO M8V1[?6)D9@HO;W![+W-F;"!F86QS92!D968@+W!M('-A=F4@9&5F?6)D9@HO M8W![;F]T>W5S97)D:6-T("\C8V]P:65S(# @<'5T?6EF(&UA(# @9W1[>W0Q M('1H97ME>&ET?6EF?6QO;W!]:69[<'!]>W-P?6EF96QS92!P;2!R97-T;W)E M?6)D9@HO<'A[," S(#$@<F]L;"!T<"!T='UB9&8*+W!Y>WUB9&8*+W!S8GLO M=7,@<V%V92!D969]8F1F"B]P<V5[=7,@<F5S=&]R97UB9&8*+V-T(#0P('-T M<FEN9R!D968*+VYC>V-U<G)E;G1P;VEN="!I;FET8VQI<"!N97=P871H(&=C M>V1U<"!T>7!E(&1U<" O87)R87ET>7!E(&5Q(&5X8V@@+W!A8VME9&%R<F%Y M='EP92!E<2!O<GME>&5C?6EF?0IF;W)A;&P@8VQI<"!N97=P871H(&UO=F5T M;WUB9&8*+VMP>V-T(# @,B!I;F1E>"!L96YG=&@@,B!I;F1E>" S.2 R(&EN M9&5X('!U="!G971I;G1E<G9A;"!C;W!Y(&-V>"!E>&5C(&UX,R!C=7)R96YT M;6%T<FEX('!O<'UB9&8*96YD"DQ7(#$@97$@=7-E<F1I8W0@+V$T<VUA;&P@ M:VYO=VX@;F]T(&%N9'LO831S;6%L; I;6S,P," W,B!D:78@," P("TS,# @ M-S(@9&EV("TQ,C @,S,X,5T*,C@P(#,R-34*>W-T871U<V1I8W0@+VIO8G-T M871E("AP<FEN=&EN9RD@<'5T(# @<V5T8FQI;FL*;6%R9VEN<PIE>&-H(#$Y M-B!A9&0@97AC:" S,#0@861D(#@@9&EV(')O=6YD(&-V:2!F<F%M971O<F]K M970*<W1A='5S9&EC=" O:F]B<W1A=&4@*&)U<WDI('!U= HQ('-E=&)L:6YK M?0HO9G)A;65D979I8V4@;&]A9 HV," T-7MD=7 @;75L(&5X8V@@9'5P(&UU M;"!A9&0@,2XP(&5X8V@@<W5B?2]S971S8W)E96X@;&]A9 I[?2]S971T<F%N M<V9E<B!L;V%D("]I;FET9W)A<&AI8W,@;&]A9" O97)A<V5P86=E(&QO861= M8W9X"G-T871U<V1I8W0@8F5G:6X@8FEN9"!E;F0@<F5A9&]N;'D@9&5F?6EF M"G-Y<W1E;61I8W0@+V-U<G)E;G1P86-K:6YG(&MN;W=N>W-E='!A8VMI;F=] M:68*/#%!-S-$-S%!.38Q1D)",D%#,3E"134X1#(V03(Y1#4X14,S030W-$-& M144S1$5&,CDP145",C@U,C0Q041!,C5"13DV1$0R14$P0T$P.#,Q0D,Q,#$Q M,#$S145$,#$V1$,Q1$5#148U148Q,S0Y0C P1C(T0C0Q1$(Q-3A&,T1$1D1! M-$(W034U-T4U04,Q138W.3E%-#9#0S(Y,4(P0D1".#4T.$4V.$%"-D9&,T)$ M-48W,S5!139$-31#-3$V03,S0S)"-D1#,T,V-S$S-CA$,4)#,#%$,T-",34T M139"0C)!,$$X-D%#-#0Y13$X14(X-T1!130P.$1#,D%"-$$V03 Q0D1!0CA! M1#=!0C@R.#5#,3$W.$$R1C4Y0T8Y,4,T1C@T,$$T.#0Y0C$P-D(S-30U034Q M13,Y-S)%-C5&.#-!-C5&-D(Q03DV13A&-$8U049%.3DX-T%$-39#-3)%.$5" M1$(R-D$Y1#9&-D9#0C<S,#0R04(R.$1#.48Y,4(V044T.3(X14-%-39!,C<X M13!!-C=$,C8Y1$1%-D-#,3@W039#,#=$,#@W.$(T-C5&.34Y,$%!-S@P,3@U M13E#,#4P.#=!0D,P.4,Q13-%,D4U13 U-45!-4%",#)%03$T148X.$5$1C(X M14(Q04-%0S5&140W.38P1D$S.3 Q13%%04,P.4,T134Q-4,T0D5%1$4P,S=# M144P-$1&-D-%,3!!.#<R-3$W04-&-T,W,S$W,T)%,S@T-SA%.#DW.35"0SDY M,D)%.#1!-S)#-$%&-#(P03(P1#=$-D$P.3A$-T4P0C1!,S4W.$,Q13!&,T,P M1#,W0D-%1#A!0S(S035#,D,V-D%!049#,C<X.3(W145$0CA#-#9&,T8U-#@P M0D0S-C@P-CDX-S4Y0SDW03<Q-T%%-3$T,T8V-31$.#4X1#-!,S)%,T(W1#(U M-30R,#0W,3DW-S1&-3!"-T-!-D-%-T(Y0T0V.3@T.#(P03)&,T$Y0D8Q,S%! M,T9&,D,T03A$1$1!-4-!0D4X0C1%,#-".34Y1CDY.$$S,S%$0T(V14(T-3)& M,S8Y,#4X-3(Q-3E$138W140W0D4P.4,Y-30V1CDX1C8T0C4Y,C-",3(Q1#=" M0C4Q04%%-3=%,C<T-S1&-3A&034R038X030T-S)%,S0P0S<V0T4Y-C5$1CA% M0S8U0C,S04(P0D9"-3E$0D)$.#@X0C8V-S@Y03-#-CE!.3$X,30U-44Q039& M,3$V,T-&-T5"03-".3 Y1C9#-C-!0C$R03(T0D4W0C<S.3<V145%,#5!,#-! M.#@R03<W1#)"-4$Q,$,Y134Q130S0C X1#-&,40X1$4V0C4V1C)"1#8Q14)% M1#,U-#5%,T4W1#<Q,T)"-T8Q14)",3%".44T,3%".4,Q.4$V1#-&13,V,#5% M.$-$.4$T0C8S,D)!048P-#E$,40X0D4P,CDT1#DW,#<T-#8X1$(P.3)".3DW M1D)&-C1!,CA"0S<Q,S Q,T,V14-!0D$Y,4(U0S9!,#0X-$5#,D-!035",#(W M1#1",#8X1C=$-S,Y.48X,D%$0T,X0C P-4%!148U-#DP-3-#,D(R,3)&-3(T M-T4P1D8T0C)#,34U1$5".38U,#!%040P1#9#,C9",S1#-$8V,C@T1CA"1#@Q M,T1%1C)%,3@Y.#$S,49!0C="0T8V,T8S-C,T1$1#.#E#-C4X0D8Y,4$T134Y M,#$P13<Y13$W,44X13E"130T,S@R,3,V-30V1D8V-30W13<V0T$X13$T0S1! M-$)"13$W-T,W-#DS-$1%0C1!-T1&.#(S03%%-S9",4$Y,40W.48U1# P.48S M1$,Y.3)#-SE%0T0Y1$(T-D9%049$,38T1#0V-$(P-D1#13E"1$(S,T-$.48Q M,3 W-C)!-S=%-#@V.#$Y0D$Y.3@P-44T-44S045&,35!1D$Q-S9"-3(W.#8V M-48R1$,P-C5!-C!!,T(R0T5".$9$030Y0S<W.#,S.44R,$(R-3$Y,3=&-S0Y M1C-"0CE!,C V,3 S.$5#-39$.4)!-CDQ,S S0C@T.#@Q1#!!-3E&1#<Q-S8Y M,#0Y0C0Y-D$X0D$W-SA%-C0T,CE$,4(X03@Y.#,Q-38X1CDR-D1$,C,U,# P M1#!#1#-!,$0R035#-S0U-3@R,C5"1# U04-$141!-$1%1D8T.$4S.3%%-T$Q M03)$-49",S8P-T4R03E%,T(S1#=!1C9!.#DQ0T4T,#1!0S(P1C9!031!-4$T M.$%".30X-#DU.38Y,C5!,C S,#4T,S@R-35&040S,# U,D4X1#%#04%!,S9% M.49&0C@R-D8X,$8T0C<Y048P,S,U1$(Q.3(P-#4P-D$X041$-38Y0S(R,3,V M-#$R-D%&,C9#13DV-$)&-#!$13,P0D8U.4-".#0Y138Q03%#0S<Y0D)$-#0V M1#<X.3 X,T8Y-D8Y.# S03-"-S$S-CDU1C(Y-#5#0S,X14,V,S,P.# X03)# M,D,Q-4,U,D8Q0T)&,4,S,T(S.$(P1C(S04$S,C4Q-40S1D8W-3@W-#A",T5% M-45$0S<Y14%&,T)!.#=!,# T-#-$-#8V,D1!.3-!-4(S.3E#.3%"1C-",38Y M14-#1#)%03E!.$)&,S(Y,D-$034T,#0Q-$4Q-S5!,#@S13DR,34V,S0U.30Y M,D8R,44R,34U,4(T0D1!1D8S1C,Y,C<Q,C5!,S W048T1C,U-C<R,C<T1C8P M-D4V.4,T,C(Y038T-C9#,T1"0S<X0C8Y1D8V03E$,#(W0D%"1$,W-D4X-$(S M14$W,3(W-S8Q,40W-4$T.38R-C)&1C0T,4)!-C9#0SE"03%!.#1&,39"-CA% M0T(Y,CE"03A#,35".#,V0T4V1$,S.$-&145&0T,S.#$R,T(W,31&,3%&.3-# M,3DQ-S,Q0T8Q-$$U-#0X144S,44R1D(X-D8U0C<W-3@S,S<X0D0P139".4%" M1C(S-T8W,$1"13=%.#4S-C)%1C-!1$4Q1$(V1# P14)&-S9#.4,U,3-!,38T M-#,V1D9%1#,V-#$S,T$P.$8T.#4Q.$1%0C0T,3$P,D(U0C$X0T,W-$8P-C9& M0C9%-S9%0S,U.44S04)%,44X.$1$-3DU135&0SDU,T$U1CDS.# Q-$8U,T9& M,$(T,#DP1$5&0C-$,C<S0S5#,D%!0S$Y138X,C,R03DQ-C R,3E&0T%$0C4Q M.$4Y-T0Y.$0Q,3DX,#(X-T,R,S4Y,C@U13<S04%$,3<Q-$8T0S1",3!&,C8V M,45#1C$R1C1&04)#03 P030Y-T1#03 R,C4X0T$T,T$R,CA%1D8P1$0S-T0Q M1#4X-C$R-D(P-D1!0C4V.3(V,4(P0D,X.3(X.48X-40W1#1&0C@X1#8W-S@R M-#5$13(P.$%!0S T,3)%-3@W1#-&,# Q03,W0D-"1#4W.3<V1$,X-41%,$,R M-T4U-D,X-3DS.#1#,41",3DV1#4S-C(V-3$T,4)&,3=$-$4P-$5&0T$X0T1$ M,3<R,#,U-C P-#-&1#<U.#A#,3 Q144S,D,W03(R,C4Q.$5&0T9!03DU,T-$ M-40Y-S-%.38R-S$R0C8T-31".# U-S4W-3$S03$T0T4Y0C=",S4U,34R,$(U M1D%"-3DR-35$-D%&0C Q,T0S-S0S-4(V-$-"-3$V0T1$1D8X,C,V141!141& M.#,T-41%-SDP.4$Q,39$.48T,C!$.$8V13DY.3=$1#!&13$P0S@X,4%%.#@W M04-%0C$Q,3DW-$0P-3A#-4(U,S$R.#)&,34Q,#5%-S<V-C-!-C5!,S-!1#=% M.4%#-S=%130X1D0T1CA"-C,X-4(Y.3,W.4,X-D(T-#@R03,R044P0S$R,S,W M0C!$.3)#,S4V,3-$-D-$-D8W139",4(X0D$W,C<Q,T,R-$0T-4,Q,S<V-49$ M-48W,T8S1$)!0C@R04)",S5!,3 V03%%0S(X,49!0C,S-40T.$0T.$0S0C(U M1$$Q.35&.44P1D0Y,44S03A&045",3A&,D)#,T4T.$4V.#0X.$$Y-#$W03DR M-S=$1D1&1D$T-C$P.#%#-S4W,#-#,$)!138Y,31&.4%&.$0S.3,R,C,W0C<R M1C!#.4,Y.$5"-CDW1#=%,3$P-T4S-30S,CE&-3A",#<R,3@X1D%%.#4X.3$U M14,V0S4T0S4S,S)"-D5!1# U,C,T-T$V,39#.4)#.#9!,C@U-#DS-3 Y0CA$ M03@V,#A$1#@W-3$R,30P.3%$,3E$0S4X-#,Y14(W.34T130T1#E!,#1#044W M-S0V,4,V-CDR1C=",D1&-#-&-S4X-T4P.44R-T9$,CDR.$(X1# W.#$P0C0U M.4(Q,3,V,T-#-$(T0SE!,3,P,C8V,D5!,48T,C$X03$W,D4U14$S031!1CE" M1C-!-#@Y0T,Y-D4W148V13 S.3@U-S(S-#(V1#0V,48T0C X,D1"1C X,30Q M-SDY-3-#,D)%-3<T1C0R.3A"0D0R,$$T1CE$03@S,$(W.$9$,C(U,#4U,3$P M139%-4)#,#<R0S(X,#8W13 Y-CA&1D8R-S,S1#E"1D0X-C0R-3@X1D8S.#1! M.#<T.34V.41$-41%,S5$.#0W,S4Q0S Q,D4W,#9&0C<W0S<W,40Y.#-%0C@Q M.3=!,#0U-3=!04)&1C!"1D0S13(V031&-D,S-C,P-4(S1#="-D$V13@V1#)" M-40T-$9!,C,U,C=$139$,C=!,D0U,D(X,31!,$,X-T%%-S=$,$,V1D8X.#@U M,4%"-#4X-C8S0S!$0D,S-D,T0S1%,#)!-S9%,3-%,D)#-C1!1#-&-$(R-$%! M,#DW0S X1#=".34V1#5%1D9%-SDT0T%&.34T0T4Q-S)&1#4W,CA!0SDR-D0Q M1CA&.3,T13)$-44Q,#-%-$$Y03 R,C!"1C$W1C1!.#,X.4$X.# V.38R,$(P M03 P0C0Q-3 V,C8Q0C@W.# S13(Q1$1%048Q.$)"-S,X,S$V-4)!-3(P,S@R M.#9#,S@W,$(Q,$(W.#=%0S V-C(P-30W,S$W1$5&-S$X1$(S-4-#-T5&1#E! M13-!1#4R,#0X0S5",48P,#4W.3,U-#DV-C$X149!.34S,#4U13DU,T)#-C!! M0D(T-S=".#DT-C@U1$,W0C(U,$$R,45!,$-&-3)#.#$P-3$U,D%#-34T,T$S M,C1%-35!045$,#=",$9!,D)%.# U13DQ,S(X0C P13(S0S=%,D-"0S=#0D9$ M1#A&1$(R-CA!,D(S03=$-T%$0T,Y.4(V-$(T1#(S,#8T.$4Y0T,Y.#9!,S0W M-C$Y0C)",40Q-S$Y-#4Y,49"13 V.#$S-T)"-4-$,D1!-#@Q0C!#1C@W-$(S M-C<S,S Q1D9".4,U0S$P-T9!0SDR-T,U-C4S0C0Q.$4W14,S0C5&-T)"140U M0S0U0D0S-S<S-S@X0C5",#A$.48Y.#(W131"-3 T,S@X,D1%03@V-#=&.4)! M-S!",S-&,T4P,3@Q.$4R,#<V-C,S-D5!0S1#1$4S,D0U,#,Y.3,S03!%0D)# M0D5&1D5!0C,W134P.#8V-S0U-#9!0S$V-#<Q-T0Y,C Y0D9&,3!#-S9#.#E% M,#9&0D4P13DW-S,U-S!&0C4Y,$0X-C,U,C)#,S=&13A$.$5!-35%-C9$034V M134U.3E#.4%".# X-3<S-D)&,#9!13,T1C9#.#0Q-4,V1C4U0D$T,S@X,D(V M,C8T-#A%1D,U14,Q.$$U,D4T,3A%,D$V-#<V030X0C4Y.$,P.$,V.30T-CDQ M,C Y,D0W,C!%1C@S13@V1#,W-#(S-S$P134V-$9%1$%&-3 U0T9%.$(P0S)! M-S Y1#<R-#(R0S)%.#=%1#-",T$W0C1%-S,S-#,S,$-%1#9$1D,Q-4(W1$4S M,3,W0D8Y,4%#.#=$,3(V.3$T.$9!141!.#9!-S8Y-34V.3<W-S4Y-T,R03@V M,C X,$,T-T-$-31#-48R-S-"-3%#-3<T-$4R0C8R-3-$0CDV.35&0T,R13@W M-C<Q-$,X0C0W04$Y1$(Y,D8W-C-&,T,T.$-&148R-S$X,T4S.41#,#0Q14(V M1$(W135"13$P0C)#,SA"03DU03-".$(R,T4X,$,R0S%",D$Q,S%!048Q1#$S M.$-",C1&0T9#1CE&,3@U.#)$,44S1$-$030T-30R.#4Q0C5&-$4Y,3E#0T5% M-T-$1D4V0S-#13=#.#,Y-SDU-3!#13<Q13$U.3DT-4,W13=&,D4R-#%"14)% M0S-"-S!#.#5$-D4R,D,R,D4R-$0T130V,#$R0D%#-$-#,SDY13%#-#(Y1D$Y M,C)&-D5&0SA"0S,T13DW1C5&0SA!0CDQ,#5$,#@U.3A!0C-$-S!&-#-#-T9" M.41&-D,U-C9&1D4Q-C-#.3=#.4,U-SDY038T034V-D)".$-$-#!$.$4R,S<P M,$0U,T(U.#<W048R,D$P0C4Q-39$1C T-D-&,S=&-C$W.$,Q,#=%1D0X0C(Y M.#,Y,#8S1C(X049%0T8X.31#,S U-$%#.#%&0D9"-D0Q-C$V13(R,#@R0S@Q M0C<Q0C5!,#DW.3-%-S(V,T,V0S9%13%#-S)&-3,V0D$Y1C)&0CDW-T%#138X M13<Q-D$Q0S,X,C$W-D%!.#<Y-S$P-4%"0S)#.3!#-#9&14(Y0T0W0S=&,3=! M,#)!-T4X.$,Y1D%!0S S,T(R,$0T,3 R1$$Q,T(R,S@P-3(U1C0W13X*;VL@ M=7-E<F1I8W0@+W-M;V]T:"!K;F]W;B!N;W0@86YD>V5E>&5C?6EF"B4@9F]N M='!R97 N<',)"0D)9W)E:60@5&AU(%-E<" R-2 Q-3HT,#HP,R Q.3@V"B4* M)2!097)F;W)M<R!F;VYT(')E;6%P<&EN9R!F;W(@86QL(&9O;G1S('1H870@ M:&%V92!T:&4@<W1A;F1A<F0@96YC;V1I;F<*)2!I+F4N('1H870@:&%V92!N M;W0@8F5E;B!R96UA<'!E9 IM9"!B96=I;@HE(')E;6%P(%IA<&9$:6YG8F%T M<R!I9B!K;F]W;B @+2T@:F9L"D9O;G1$:7)E8W1O<GD@+UIA<&9$:6YG8F%T M<R!K;F]W;GL*(" @+WQ?7U]?7U]:87!F1&EN9V)A=',@+UIA<&9$:6YG8F%T M<R!D=2!F90H@(" Q,C@@+V$X.2!C92 Q,CD@+V$Y,"!C92 Q,S @+V$Y,R!C M92 Q,S$@+V$Y-"!C92 Q,S(@+V$Y,2!C90H@(" Q,S,@+V$Y,B!C92 Q,S0@ M+V$R,#4@8V4@,3,U("]A.#4@8V4@,3,V("]A,C V(&-E(#$S-R O83@V(&-E M"B @(#$S." O83@W(&-E(#$S.2 O83@X(&-E(#$T,"]A.34@8V4@,30Q("]A M.38@8V4*(" @;F9](&EF"B]S8W)A=&-H(#$P,"!S=')I;F<@9&5F"D9O;G1$ M:7)E8W1O<GD@>PH@('!O<"!S8W)A=&-H(&-V<R!D=7 @,"!G970@9'5P(#8U M(&QT(&5X8V@@.3 @9W0@;W(@>PH@(" @<&]P(" @)24@:6=N;W)E(&%N>2!F M;VYT(&YA;64@=&AA="!D;V5S;B=T('-T87)T('=I=&@@82!L971T97(*("!] M>PH@(" @)24@<V5T('5P(&%N9"!C86QL('1H92 O<F8@<F]U=&EN92!I;B!M M9"!D:6-T:6]N87)Y.@H@(" @9'5P(&QE;F=T:"!S=')I;F<@8V]P>2 O(VYM M(&5X8V@@9&5F"B @(" C;FT@;&5N9W1H(#<@861D('-T<FEN9PH@(" @9'5P M(# @*'Q?7U]?7U\I('!U=&EN=&5R=F%L"B @("!D=7 @-R C;FT@<'5T:6YT M97)V86P@8W9N"B @("!D=7 @1F]N=$1I<F5C=&]R>2!E>&-H(&MN;W=N('L* M"6-L96%R"B @("!]>PH@(" @(" @("-N;2!C=FX@9'5P"B @(" @(" @9FEN M9&9O;G0@+T5N8V]D:6YG(&=E="!3=&%N9&%R9$5N8V]D:6YG(&5Q"B @(" @ M(" @>W1R=65]>V9A;'-E?6EF96QS90H)<F8))2!S=&%C:SH@+WQ?7U]?7U]& M;VYT3F%M92 O1F]N=$YA;64@/&)O;VQE86X^"B @("!](&EF96QS90H@('T@ =:69E;'-E"GT@8FEN9"!F;W)A;&P*96YD("5M9 H@ end SHAR_EOF echo "attempting to extract LaserPrep.ps by uudecoding LaserPrep.uu" uudecode LaserPrep.uu fi # end of overwriting check # End of shell archive exit 0