<BEEBE.TEX.DVI>00REVHST.TXT.200, 17-Nov-87 20:02:40, Edit by BEEBE This file contains a reverse chronological log of changes made to the TeX DVI Driver family. Version history: 2.10 [01-Nov-87] 2.09 [23-Sep-87] 2.08 [15-Aug-87] 2.07 [15-Apr-87] 2.06 [1986-1987] The version number does not change with minor modifications that affect only a few drivers, so the file write dates on the master directories at Utah (and recorded on distribution tapes and floppies) must be consulted to determine whether a particular distribution contains these corrections. Where feasible, this change log contains sufficient information to allow hand installation of bug fixes. Changes will generally not be logged at new versions, since they may be extensive. [07-Jun-88] {Thanks to Hans Irtel <irtel%vax1.rz.uni-regensburg.dbp.de@RELAY.CS.NET>} In initglob.h about line 51, change size_limit = 255; /* largest character size */ to size_limit = 128; /* largest character size */ The HP LaserJet Plus has a character cell height and width range limitation of 1..255, but further restricts individual character dimensions to 0..128. This bug is exposed if you attempt to print characters at size magstep 4 or larger, such as the following test TeX file supplied by William E. Anderson <anderson@cme-durer.arpa>: \magnification=\magstep4 $$f(x)=\int{g(x)\over x}\,dx$$ \vfill\eject\bye for which the integral sign will be lost without the fix, and will appear once the fix is applied. [31-May-88] Issued newsletter #17. [30-May-88] {Thanks to Jerry Leichter (LEICHTER@Venus.YCC.Yale.Edu) for providing an example that exposed this bug.} In dvijep.c, rules are output one dot too high. According to the HP documentation, the position of a rule is the upper-left corner. I took this to mean that the rule would be output starting just under the pixel at (x,y) in that corner. What they must mean is that (x,y) is the position of the pixel in the upper-left corner of the filled area. Change the definitions of RULE() and RULE2() about line 160 to reduce the height value by 1 in the arguments to MOVETO(): diff -c dvijep.c,75 dvijep.c *** dvijep.c,75 Wed May 18 09:42:01 1988 --- dvijep.c Mon May 30 19:03:07 1988 *************** *** 162,174 **** lower-left corner, while the LaserJet Plus uses the upper-left corner. */ #define RULE(x,y,width,height) {\ ! MOVETO(x,(y)+height);PUTESC;\ sprintf(plotfs,"*c%da%dbP",width,height); OUTST(plotfs);\ } /* Set rule of same size as previous one at TeX position (x,y). The device coordinates will be changed on completion. */ #define RULE2(x,y) {\ ! MOVETO(x,(y)+rule_height);\ PUTESC;OUTST("*cP");\ } /* Set the current font and character in preparation for a DOWNLOADCHAR */ --- 162,174 ---- lower-left corner, while the LaserJet Plus uses the upper-left corner. */ #define RULE(x,y,width,height) {\ ! MOVETO(x,(y)+height-1);PUTESC;\ sprintf(plotfs,"*c%da%dbP",width,height); OUTST(plotfs);\ } /* Set rule of same size as previous one at TeX position (x,y). The device coordinates will be changed on completion. */ #define RULE2(x,y) {\ ! MOVETO(x,(y)+rule_height-1);\ PUTESC;OUTST("*cP");\ } /* Set the current font and character in preparation for a DOWNLOADCHAR */ The same correction must be made to dvilzr.c for the DataProducts laser printer. I had previously received reports of suspicions of an error in dvijep's rule positions, but no one ever was able to supply an example that I could reproduce locally. Here is Jerry's excellent little test file: \documentstyle[12pt]{article} \def\vec(#1,#2){\put(0,0){\vector(#1,#2){50}}} \begin{document} \setlength{\unitlength}{.01in} \begin{picture}(0,0)(100,100) \vec(-1,0) \vec(1,0) \vec(0,1) \vec(0,-1) % \vec(-4,1)\vec(-3,1)\vec(-2,1)\vec(-1,1) \vec(4,1)\vec(3,1)\vec(2,1)\vec(1,1) % \vec(-3,2)\vec(-1,2) \vec(3,2)\vec(1,2) % \vec(-4,3)\vec(-2,3)\vec(-1,3) \vec(4,3)\vec(2,3)\vec(1,3) % \vec(-3,4)\vec(-1,4) \vec(3,4)\vec(1,4) % \vec(-4,-1)\vec(-3,-1)\vec(-2,-1)\vec(-1,-1) \vec(4,-1)\vec(3,-1)\vec(2,-1)\vec(1,-1) % \vec(-3,-2)\vec(-1,-2) \vec(3,-2)\vec(1,-2) % \vec(-4,-3)\vec(-2,-3)\vec(-1,-3) \vec(4,-3)\vec(2,-3)\vec(1,-3) % \vec(-3,-4)\vec(-1,-4) \vec(3,-4)\vec(1,-4) % \end{picture} \end{document} When printed with dvialw, the two horizontal rules are printed correctly; before the above correction to dvijep, they were one pixel too high, (this gives a visible white streak). The correction should also fix the misalignment with the arrowheads. [30-May-88] The following bug in dvialw.c was fixed on 3-Feb-88, but unfortunately didn't make it into this log. diff -c dvialw.c,78 dvialw.c,79 *** dvialw.c,78 Sun Nov 1 11:21:38 1987 --- dvialw.c,79 Wed Feb 3 16:38:28 1988 *************** *** 1080,1085 **** --- 1080,1086 ---- } OUT_CHR('('); OUT_XCHR(c); + OUT_CHR(')'); if (ycp != str_ycp) { OUT_NUM(xcp); There was a missing ')' in the output. [26-May-88] Issued newsletter #16. [18-May-88] In dvijep.c about line 180, change {PUTESC; sprintf(plotfs,"*c%dE",MAP_CHAR(ch)); OUTST(plotfs); }\ to {PUTESC; sprintf(plotfs,"*cd%dE",MAP_CHAR(ch)); OUTST(plotfs); }\ This correction sets the font number to 0; the old one works on the HP LaserJet, but might break on clones. [14-Apr-88] Changed system() in vaxvms.c to allow warning and information status returns to be treated as success. The body of system() now reads: t.dsc$w_length = strlen(s); t.dsc$a_pointer = s; t.dsc$b_class = DSC$K_CLASS_S; t.dsc$b_dtype = DSC$K_DTYPE_T; /* The 3 low-order bits of stat are 0 (warning), 1 (success), 2 (error), 3 (information), or 4 (severe or fatal error) Consider values of 0, 1, or 3 to be success. LIB$SPAWN will usually return SS$_NORMAL, independent of the value of stat. */ if (LIB$SPAWN(&t,0,0,0,0,0,&stat) != SS$_NORMAL) return (127); switch (stat & 7) { case 0: case 1: case 3: return (0); default: return (127); } [07-Mar-88] Changed type of main() in keytst.c and lptops.c from void to int, and inserted return(0) at end to keep lint and VAX VMS C compiler happy. Draft ANSI C (Oct-86 and Jan-88) does not specify what the type of main() should be, and most compilers don't care. VMS C 2.3 however produces an annoying warning message if main() is not of type int; I view this behavior as erroneous, because main() is only a convention in C, and it is possible to write C programs in many implementations that do not have a main(). [02-Mar-88] Added code to findpost.h to ignore trailing NULs in a .DVI file, borrowing code from readpxl.h and readgf.h that do the same thing for font files. Users (including me) have been annoyed by the inability of the drivers to handle a .DVI file which has passed through a VAX VMS system where gratuitous NULs are appended to pad the file length to a multiple of 512 bytes. This effort revealed another problem under VAX VMS, and that is that the code in FSEEK() in vaxvms.c on a request to position at end-of-file actually positions before the last character, instead of after it. An attempt at correcting this was foiled by the VMS library ftell() which returns 0 when the position set by FSEEK() is outside the actual file limits, and while FTELL() can correct the brain-damaged value returned by ftell(), it cannot distinguish a nonsensical 0 result from ftell() at end-of-file from one at the beginning of the file. Consequently, it has been necessary in findpost.h to bump the postambleptr value by one. Since this modification can be installed independently in even old versions of the DVI driver family, and a context difference listing is larger than findpost.h, here is the complete new version: /* -*-C-*- findpost.h */ /*-->findpost*/ /**********************************************************************/ /****************************** findpost ******************************/ /**********************************************************************/ void findpost() { register long postambleptr; register BYTE i; register UNSIGN16 the_char; /* loop index */ (void) FSEEK (dvifp, 0L, 2); /* goto end of file */ /* VAX VMS binary files are stored with NUL padding to the next 512 byte multiple. We therefore search backwards to the last non-NULL byte to find the real end-of-file, then move back from that. Even if we are not on a VAX VMS system, the DVI file might have passed through one on its way to the current host, so we ignore trailing NULs on all machines. */ while (FSEEK(dvifp,-1L,1) == 0) { the_char = (UNSIGN16)fgetc(dvifp); if (the_char) break; /* exit leaving pointer PAST last non-NUL */ UNGETC((char)the_char,dvifp); } postambleptr = FTELL(dvifp) - 4; #if OS_VAXVMS /* There is a problem with FSEEK() that I cannot fix just now. A request to position to end-of-file cannot be made to work correctly, so FSEEK() positions in front of the last byte, instead of past it. We therefore modify postambleptr accordingly to account for this. */ postambleptr++; #endif (void) FSEEK (dvifp, postambleptr, 0); while (TRUE) { (void) FSEEK (dvifp, --(postambleptr), 0); if (((i = (BYTE)nosignex(dvifp,(BYTE)1)) != 223) && (i != DVIFORMAT)) (void)fatal("findpost(): Bad end of DVI file"); if (i == DVIFORMAT) break; } (void) FSEEK (dvifp, postambleptr - 4, 0); (void) FSEEK (dvifp, (long)nosignex(dvifp,(BYTE)4), 0); } [06-Feb-88] Revised lpt.ps to handle formfeed and tabs. [17-Nov-87] Installation of the DVI driver family under Microsoft C Version 5.0 resulted in a number of changes more fully described in 01README.TXT (to be included in the next DVI newsletter). This is the first compiler that fully conforms to draft ANSI C (October 1986) in both the language and the run-time library. Added missing typecast in dvieps.c and dvie72.c. In dvihead.h, added #include's for io.h and time.h for IBM_PC_MICROSOFT. Added two missing typecasts in dvijep.c, and inserted the missing condition "(t->istoobig) ||" to BIGCHAR(). In gblprocs.h, replaced ANSI flag by ANSI_LIBRARY and ANSI_PROTOTYPES to distinguish between library conformance, and ANSI function prototype use, and adjusted many function declarations accordingly. In keybrd.c, provided alternate name for interrupt(); its use otherwise causes an compiler error with MSC 5.0. In keydef.h, replaced ANSI section by ANSI_LIBRARY and ANSI_PROTOTYPE sections. In keytst.c, added some comments, and changed the test to loop a maximum of five times with no input. Introduced an implementation of sleep() for OS_PCDOS. In lptops.c, replaced ANSI section by ANSI_LIBRARY and ANSI_PROTOTYPE sections, and reset a couple of constants to type long. In machdefs.h, replaced ANSI section by ANSI_LIBRARY and ANSI_PROTOTYPE sections, and for IBM_PC_MICROSOFT, defined float to be double to reduce data conversion warnings. In main.h, removed #include's of stdlib.h and string.h; they are already in machdefs.h. In option.h, removed use of ABS() for a floating-point argument to remove data conversion warning. In texidx.c, changed preprocessor symbol MSC to IBM_PC_MICROSOFT. In tosprx.c, replaced ANSI section by ANSI_LIBRARY and ANSI_PROTOTYPE sections. Revised IBM PC-specific version of Make to work with Microsoft C Version 5.0, eliminating some severe limitations imposed by Wizard C, and permitting the MAKEFILE.MSC to be completely self-contained, instead of having to reference MAKEFILE.1 .. MAKEFILE.4. Several new features were also implemented in Make; they are described in a 00README.TXT file in the PCMAKE directory. [01-Nov-87] Replaced references to (void)fprintf(..., plotfp) with references to new macros OUTF(...), OUTF2(...), and OUTF3(...), or existing ones OUTC() and OUTS(). Replaced all instances of putc(*c++,plotfp) by "OUTC(*c);c++". Since putc() is usually a macro, there is a potential incorrect side effect if its first argument is evaluated more than once. Most C implementations use it only in the two branches of a conditional expression, which is safe. [01-Nov-87] Completed major overhaul of dvijep.c. The font deletion mechanism was not successful, partly because the font number was not subsequently reset in one place, but mostly because it causes a page eject. This would make it impossible to print some documents. dvijep now keeps track of both the number of fonts in use on the current page, and the total number in use in the document. When either of these limits is reached, the characters in those fonts are sent as bitmaps, instead of as downloaded fonts. It is still possible to have a document which is too complex for the LaserJet to print (raising error code 21 on the printer front panel status display), but that is now a limit imposed by the printer, rather than the DVI driver, and cannot be gotten around. There is room for further work here, however. Most documents do not require an excessively large number of fonts. For example, dvidriver.ltx uses 23 fonts, and weave.tex uses 15, but the TeXbook uses 54. When the DVI driver begins execution, through the call chain main() -> dvifile() -> readpost() -> getfntdf() -> readfont() -> reldfont() -> read{pk|gf|pxl}() -> newfont(), it normally reads in the font definitions from the DVI file postamble and assigns font numbers in order of occurrence, and builds its internal font and character tables. Later, as pages are processed, font changes occasioned by DVI fnt_num_0 .. fnt_num_63 and fnt1 .. fnt4 commands result in setting the global flag font_switched, which in turn causes setchar() and setstr() to output font switch commands to the device. The implication of this for dvijep is that all fonts beyond the first 32 are marked as non-downloadable. In the case of the TeXbook, it turns out that this includes the heavily-used cmr, cmsy, and cmmi fonts at 5, 6, 7, 8, 9, and 10 pt sizes, which means that almost all of the characters set on a page will be sent as bitmaps, instead of as downloaded characters. On my HP LaserJet Plus, every page raised printer error code 21. This might not happen on an HP LaserJet Series II, which can have substantially more memory, but I haven't one locally to try the experiment. The solution to this problem is to delay font number assignment until the font is actually referenced. Since a considerably smaller number of fonts are needed on each page, it is then possible to download most of them, and a font-rich document like the TeXbook can be printed successfully in sections. The change involves moving the body of newfont() to a new function, makefont(), and having newfont() only initialize the font_number with a special "undefined" value. The macro SET_CURRENT_FONT has become big enough that it has been transformed into a function, setfont(). setfont() now checks font_number for the undefined value, and in such a case, calls makefont() to assign the font a number and create it in the printer. With this change, the TeXbook can be printed successfully. [30-Oct-87] Changed vaxvms.c, gblprocs.h, openfont.h, and machdefs.h to support dynamic determination of the limit on the number of open files for VAX VMS. This is a VMS quota parameter whose dynamic value depends on the number of subprocesses. Previously, a user with too small a limit would find the dvi drivers could fail because the hard limit on the number of open font files was too large. [29-Oct-87] In LW78.C, removed typeout of final CR LF in Get_Msg(), and inserted system call to dismiss the process until the output buffer is empty at the start of Put_Packet(). LW78 had been experiencing I/O error returns from the Apple LaserWriter Plus, and when I attempted to copy a PostScript file directly to the printer, the same thing happened, only much earlier in the job. This raised the suspicion of buffer overrun in the printer. Three experiments using a 100-page document with (1) a 5-second sleep before outputting each buffer, (2) process dismissal until the buffer was empty, and (3) the Kermit TRANSMIT command (which waits for a prompt from the LaserWriter after each line) all resulted in successful printing, and I have confidence that this change in LW78 will provide superior performance. With the new LW78, I sent dvidriver.dvi-alw with the modified BOP and EOP definitions given below, and printed the 100 pages at an average rate of 5 pages per minute. Virtual memory usage was initially 2Kb to 4Kb per page while fonts were being downloaded, and in later pages, dropped to a low of 1105 bytes/page. Pages with that low figure had only text set on them, and no fonts downloaded, with the text guarded by save/restore sequences. That virtual memory was still consumed leads one to wonder if there is not a bug in the PostScript memory allocation code which causes some "seepage" loss. If one of dvialw's macros were leaving unclaimable garbage behind, one would expect that the garbage amount would vary, but many different pages had the same 1105 bytes/page consumption. Total virtual memory consumed by the job was 112Kb, with 78Kb remaining available at end-of-job. [27-Oct-87] Simplified beginning-of-page and end-of-page code in prtpage.h by creating bopact() and eopact() routines in several drivers, and removed bopact.h and eopact.h (which were previously used only by dvibit), including references to them in makefile.*. [27-Oct-87] Numerous small editorial changes for code consistency, and to reduce the number of warnings from the lint utility. [27-Oct-87] {Thanks to John Pavel (mcvax!nplpsg!jrp@uunet.uu.net) for urging this change} On Unix only, Version 2.10 now permits input to come from stdin, and output to go to stdout, allowing use of the drivers as filters. This choice is automatically made when no file names are specified on the command line. Use of stdout for binary files is generally impossible for other operating systems, which either make a distinction between text and binary file formats, or use line terminators other than <LF>, necessitating translation of Unix end-of-line '\n' on input and output. With the exception of dvialw, all the drivers produce binary output files. [27-Oct-87] {Thanks to Bernhard Nebel (NEBEL@DB0TUI11.BITNET) for useful suggestions} Completed major overhaul of dvialw.c. A fundamental problem with existing PostScript interpreters is that they lack garbage collection, and the PostScript programmer is expected to manage storage with save/restore command judiciously wrapped around throw-away code. The problem this poses for a TeX environment is that one does not wish to discard downloaded fonts, since they will likely be needed again. In the previous version of dvialw, the -s and -v options provided some user control of this, but such user control is only of marginal utility. It proved interesting to install the following PostScript code segment immediately before the BOJ (beginning of job) command in an output file from dvialw produced from Appendix F of the TeXBook. The TeXbook uses 54 fonts, and therefore puts a sizeable burden on a printer that has only limited font memory. % These provide alternate definitions of BOP and EOP in dvialw.ps % which cause CPU time and virtual memory statistics to be printed % at the bottom of each output page /BOP { clear Mtrx setmatrix 25 0 translate vmstatus pop /VMUSED exch def pop usertime } bdf /EOP { /#copies exch def /USERTIMEIN exch def save /pt {Resolution 72 div mul} def /Helvetica-BoldOblique findfont 12 pt scalefont setfont /SP {12 pt 0 pt rmoveto} def /PN {SP 10 vmstr cvrs show} def /vmstr 15 string def 36 pt 36 pt moveto ([VMstatus:) show vmstatus PN PN PN (]) show SP SP ([VMpage:) show vmstatus pop exch pop VMUSED sub PN (]) show SP SP ([Page time:) show usertime USERTIMEIN sub PN ( msec]) show restore showpage } bdf With this addition, each page now carries both memory usage and (printer) CPU time statistics at the bottom of each page. On the Apple LaserWriter with paper type "note", there is about 250Kb of virtual memory available at job start. Here is a table of the memory requirements for successive pages of Appendix F of the TeXbook: ---- ----------- ----------- Page DVIALW 2.09 DVIALW 2.10 ---- ----------- ----------- 431 4953 432 26057 433 3713 434 9693 435 27948 21101 436 18971 13421 437 15644 10109 438 21764 15324 439 27064 19596 440 8172 6628 ---- ----------- ----------- Version 2.09 reached a VM error condition (virtual memory exhausted) on page 434, while Version 2.10 was able to proceed 4 pages beyond that before hitting the same limit. Each page in Version 2.10 requires about 30% less virtual memory. Initially, I wrote a short filter program that moved the text strings on each page to after the font download sequences, wrapping the text in a save/restore pair to recover the virtual memory needed to store them. This proved to be quite straightforward, requiring only about 60 lines of C code. To implement the same facility in dvialw proved much more complex, because I was not willing to suffer the performance penalty of reading each page of the DVI file twice, once to collect needed fonts, and a second time to set text and rules. Instead, a completely new mechanism is implemented whereby output is channelled through several new routines, which ultimately reach the low-level textchr() routine which gets a single character to process. Based on a global flag, textchr() either outputs this immediately (e.g. for macros, rules, and font downloading), or stores it in an internal buffer (text setting). On the basis of examination of .dvi-alw files for the DVI driver manual, and the TeXbook, the internal buffer is chosen to be large enough so that it will usually only need to be dumped once per page. PostScript loop tests on the Apple LaserWriter Plus (Version 38.0 PostScript) give execution times of about 0.25 msec for one iteration of an empty loop, determined by executing usertime 10000 {} repeat usertime exch sub and 55 msec for one save/restore pair: usertime 1000 {save restore} repeat usertime exch sub Consequently, one does NOT want to do a save/restore around every string, but only around large groups of strings. Because of the use of relative coordinates in most output typeset text (the T macro instead of the S macro), and the use of remembered rule widths (w and h in the B and Q macros), it is not trivial to correctly handle the case of more than one bufferful per page (since intervening non-buffered output might change the font or current point), and it took a considerable number of iterations to get it working satisfactorily, with the buffer size temporarily set artificially low. Having the output being filtered through a central location, textchr(), has made it possible to further economize on the output volume (e.g by collapsing <letter><newline><open-paren> to <letter><open-paren>, and to more closely approach a constant line width (except for PostScript from a \special{} command, which is output verbatim). Some operating systems have trouble with long lines in files, and Version 2.10 should now largely remove this problem. The line breaking algorithm implemented in textchr() and textflush() is far from trivial, because PostScript does not uniformly recognize <backslash><newline> as a continuation sequence that can be discarded; instead, it permits this continuation mechanism only in parenthesized strings. Otherwise, comments cannot be continued, angle-bracketed strings can be continued by simply inserting a bare newline, and elsewhere, a newline can be used any place a blank is used. Some of the comment lines produced by dvialw are long; they are now split automatically by placing a hyphen in the last column of the line, and continuing with "%-" on the next line. Any software that takes advantage of the %%PageTable at the end will therefore need adjusting (I doubt that any exists, so this change does not concern me). It is regrettable that the PostScript developers did not give line continuation more thought. Font change commands are now defined more compactly as "F#" or "F##", where "#" is the sequential number of the font in the document. This further helps to reduce output volume. The initial font definitions (the NF macro) still use the full name, and carry a comment with the font file name, so it is still possible to easily find out what font file was used for any part of the output. The problem of corrupted font files has come to my attention on several occasions, so it is worthwhile to maintain this connection in dvialw, which is the only driver that produces human-readable printer output. On Appendix F of the TeXbook, these changes reduced the output file size by about 8% compared to Version 2.09, and about 9% when PS_SHORTLINES was non-zero. On the DVI driver manual (99 pages), the file size from Version 2.10 with PS_SHORTLINES defined was 15% shorter than that from Version 2.09. Since a non-zero PS_SHORTLINES produces marginally smaller output, it is now the default for all implementations, but it can be overridden by a compile-time redefinition. [22-Oct-87] {Thanks to Marcus Moehrmann (marcus%fkihh@unido.uucp)} Added drivers dvieps and dvie72 for Epson 9-pin printers and compatibles. dvieps is for 240H x 216V resolution, and dvie72 for 60H x 72V resolution (same as dviprx for Printronix printers). It was necessary to make a number of changes to the submitted code to bring it up-to-date with the rest of the family, and to conform to my coding practices. Since I do not have an Epson printer on which to test this locally, the version number carries the suffix "[experimental]". The same suffix appears in dvica2. These will be removed when the drivers are considered ready for final release, based on positive user feedback. [22-Oct-87] Added debug option 128 (DBG_SET_TEXT) to display each piece of text set by the driver, together with its page coordinates in dots, and its font name. This of course produces voluminous output, but is quite handy when you are trying to step a long way into execution to track down a bug. [22-Oct-87] All debug options have been turned into symbolic references, e.g. if (DBGOPT(DBG_OFF_PAGE)) instead of if (debug_code & 32) It was clearly a mistake not to have done this in the first place. I also wish that I had made these options sequential numbers, instead of powers of two, but it is probably too late to change that now. [12-Oct-87] Edited dviman.texinfo to bring it up-to-date with dvi.1l and dviman.ltx. [01-Oct-87] Created Unix-style man page file, dvi.1l. [01-Oct-87] Added support for a "-z" option (typein of "DVISPOOL dvifilename") for 4.xBSD Unix systems, which have imitated TOPS-20's STI% (Simulate Terminal Input) JSYS facility with ioctl(fildes, TIOCSTI, *char). [30-Sep-87] {Thanks to Stefan Kronberg (ZEFFI@FINABO.BITNET)} Added support of font files with up to 256 characters. Normal TeX Computer Modern fonts use only 128 characters per font, but extensions for European alphabets, and Japanese fonts, will require more than 128. Unfortunately, this was not quite as trivial as I had originally intended, where the values LASTPXLCHAR and NPXLCHARS in gendefs.h need only be increased from 127 and 128 to 255 and 256 respectively. The problem is that several loops used code like BYTE k; ... for (k = FIRSTPXLCHAR; k <= LASTPXLCHAR; ++k) With LASTPXLCHAR = 255, the last loop iteration will increment k to 256, but since it is a byte value, this wraps to 0, and the loop becomes infinite on a byte-oriented machine. This made it necessary to retype the offending loop indices as UNSIGN16. The context diff listing for these changes is rather long (about 1200 lines), so I do not include it here. [30-Sep-87] Changed -d option processing in option.h to allow multiple -d options to accumulate, instead of requiring them to be set with one -d option. The change is simple: replace debug_code = (BYTE)atoi(optstr+2); by debug_code |= (BYTE)atoi(optstr+2); [29-Sep-87] Because of problems on record-oriented file systems (VAX VMS being the worst offender), the code in dvialw.c does more when PS_SHORTLINES is defined; it now keeps track of output widths, and will not produce output lines more than a couple of characters longer than a fixed value, PS_MAXWIDTH. However, no such limit is placed on comments, or macros retrieved from dvialw.ps; both of these are already of limited length. Changed machdefs.h to allow PS_SHORTLINES to be set at compile time. A single experiment on a 20-page DVI file showed that the .dvi-alw output was about 3% longer when a version of dvialw with PS_SHORTLINES set was used. [29-Sep-87] {Thanks to John Pavel (mcvax!nplpsg!jrp@seismo.css.gov) and Brendan McKay (munnari!anucsd.oz!dbm@seismo.css.gov)} The code in dvialw.c in functions setchar() and setstr() emits a save/restore pair around a large character font definition. On the Apple LaserWriter Plus (which I only recently got as a replacement for our stolen ALW), this results in a "Fatal system error @ 0X2e6bec". The fix is fortunately simple. Change those two instances of OUTS("save"); (but NOT the one in special()) to OUTS("save /temporary_font NF 1 /temporary_font SF"); This will put the character in a temporary font which is discarded when the restore command is executed. Here is simple test file using cminch; it produces a large (~400Kb) .dvi-alw file. % test for dvialw downloading of large characters \font\bigfont=cminch This file tests a DVI driver's capability to support downloading of large characters. The following uninteresting tables of the Roman alphabet are printed in font {\it cminch\/}. \bigfont \obeylines ABC DEF GHI JKL MNO PQR STU VWX YZ \vfill\eject\end [29-Sep-87] {Thanks to John Pavel (mcvax!nplpsg!jrp@seismo.css.gov)} Removed obsolete SHORTLINES references from machdefs.h; PS_SHORTLINES remains, and can now be set in machdefs.h, instead of only in dvialw.c. The default setting in machdefs.h now is #define PS_SHORTLINES 0 and dvialw.c now has #ifndef PS_SHORTLINES #define PS_SHORTLINES 0 /* run with long output lines */ #endif [28-Sep-87] Updated all makefiles to include a generic target dvi$(PGM) and an extra compilation flag value XCFLAGS, so test versions can be constructed by a command like "make PGM=foo XCFLAGS=-g dvifoo". [28-Sep-87] {Thanks to Ian Young (ian@latlog.uucp)} At the end of readgf.h, newfont() is called before the loop which retrieves character metrics via chargf(). This is incorrect for HPJETPLUS, where the newfont() code in dvijep.c uses some of the metrics. For the other devices, newfont() only sets values in the font character tables. Therefore, move the newfont() call to AFTER the loop, so that the code reads in readgf.H: for (the_char = FIRSTPXLCHAR; the_char <= LASTPXLCHAR; the_char++) { /* Get remaining character metrics, and ignore error returns for now. */ tcharptr = &(fontptr->ch[the_char]); if (tcharptr->fontrp >= 0L) (void)chargf(the_char,(void(*)())NULL); } #if (BBNBITGRAPH | HPJETPLUS | POSTSCRIPT | IMPRESS | CANON_A2) (void)newfont(); #endif [28-Sep-87] On Unix systems, getlogin() returns (char*)NULL if the process is not attached to a terminal, in particular, if the process is attached to a pseudo-terminal (pty), such as a window or an editor shell buffer. The way to get the real login name in these circumstances is to use cuserid((char*)NULL) in place of getlogin(), and I have according made that change in dvialw.c and lptops.c, and added appropriate function declarations in gblprocs.h. This change affects only text output in a PostScript comment. Both cuserid() and getlogin() are defined in 4.2BSD Unix, AT&T SYS V Unix, HPUX, KCC (version 4), and IEEE Posix (which draft ANSI C follows). PCC and V7 Unix had only getlogin(). VAX VMS C has only cuserid(). KCC (version 3), Microsoft C, Lattice C, and Wizard C have neither. [23-Sep-87] {Version 2.09 announcement} Testing of the Free Software Foundation gcc compiler has uncovered two bugs so far in the compiler (they are being fixed rapidly). gcc produces code for both VAX and Motorola architectures, and is being used to develop the GNU operating system. The testing also found a serious bug in my code which unfortunately impacts most of the DVI drivers, and can be the cause of core dumps or other failures. The value of XSIZE in dvi*.c is currently computed as XDPI*XPSIZE, that is, the number of dots across the page. Unfortunately, one or more local arrays are later allocated and used with the assumption that XSIZE is a multiple of the machine word size, HOST_WORD_SIZE, and in dvijet, it was assumed to be a multiple of 2*HOST_WORD_SIZE. This bug was never caught on the DEC-20, because there stacks grow upward, so beyond-bounds references to stack arrays may just be writing into unused memory. However, on the VAX, Intel iAPX, and Motorola architectures, stacks grow downward, and such references can wipe out the call history, precipitating at best an address exception or illegal instruction violation when the return instruction is executed. This would only happen if text was set against the right-hand side of the page, and since TeX documents usually produce wide margins, this may be unlikely to happen. To avoid complex dimension computations, and preserve uniformity of definition among the family, XSIZE is now increased to a multiple of 2*HOST_WORD_SIZE throughout. The fix is to change #define XSIZE (XDPI*XPSIZE) /* number of horizontal dots */ to #define XSIZE (((XDPI*XPSIZE+2*HOST_WORD_SIZE-1)/\ (2*HOST_WORD_SIZE))*(2*HOST_WORD_SIZE)) /* number of horizontal dots; */ /* MUST BE multiple of */ /* 2*HOST_WORD_SIZE */ in all the dvi*.c files. I view this bug fix to be important enough to warrant a version number change, so the family is now at version 2.09. The following Unix script can be used on Unix systems to automate the patch: #!/bin/csh foreach f (dvi*.c) echo $f mv $f $f-old sed -f bugfix.sed <$f-old >$f end Here is bugfix.sed: s|"2.08|"2.09| s|(XDPI\*XPSIZE)[ ]*/\* number of horizontal dots \*/|(((XDPI*XPSIZE+2*HOST_WORD_SIZE-1)/\\\ (2*HOST_WORD_SIZE))*(2*HOST_WORD_SIZE))\ /* number of horizontal dots; */\ /* MUST BE multiple of */\ /* 2*HOST_WORD_SIZE */| [23-Sep-87] In openfont.h, nopen is incremented when the requested font is not found in the list of currently open files, but the code forgets to decrement it if the request font never gets successfully opened, which can happen if the font file cannot be found, and no substitution font is provided. Change the code about line 185 to decrement nopen on open failure, so that it now reads: if (fontfp == (FILE*)NULL) { --nopen; /* don't count this failed open */ (void)sprintf(message,"Font file [%s [mag %d]] could not be \ [18-Sep-87] In LW78.C, Wait_For_Printer_Ready(), removed output of Ctl-D; with the Apple LaserWriter Plus, this causes the printer to respond to the following Ctl-T with "printer busy", instead of "idle", like the old Apple LaserWriter did. [18-Sep-87] {Thanks to Mic Kaczmarczik (CC.KCACMARCZIK@A20.CC.UTEXAS.EDU)} When dvialw.ps is modified to select LANDSCAPE mode instead of NOTE (portrait), the output is positioned incorrectly, and character bitmaps look somewhat ragged. The former is due to a missing translation command, and the latter to tiny non-zero transformation matrix elements which introduce computed coordinates which are in error by one pixel. I have also taken the liberty of installing a fix for the fact that NOTE is not defined on non-Apple PostScript printers. It should no longer be necessary to edit dvialw.ps for Texas Instruments, QMS, et al PostScript printers. There is one problem with this change, and that is that the SNAP call in the CharBuilder routine must now be executed for each character set on the page, so the output may prove to be somewhat slower. To check this, I downloaded dvialw.ps to our new Apple LaserWriter Plus, then executed TeXdict begin usertime 10000 {0 0 SNAP pop pop} repeat usertime exch sub pstack which results in a time of 70844 msec for 10000 calls, or an extra overhead of 7 msec per character. Repeating the experiment using an empty procedure body gives a loop overhead time of 0.2 msec. With an average of 3000 characters set per page, this amounts to 21 sec per page, which is definitely not negligible. You may therefore wish to leave the SNAP call out of a version of dvialw.ps that is used only for portrait orientation output. Similar timing loops can be used to reveal an average execution time of 1 msec for any arithmetic operation (+-/*); PostScript interpreters badly need hardware floating-point support! There is a repeatable difference of about 10% increase in speed when operands are floating-point instead of integer values. dvialw could be changed to write floating-point values instead of integer ones, with a tradeoff of slightly increased output file size to be balanced against slightly faster arithmetic. At the same time, I increased XPSIZE to 14 in dvialw.c so that landscape mode output is not clipped. Future work should introduce a general flexible solution to the problem of paper size specification for all of the drivers. Here is a context difference which records the changes. Additions are flagged with a "+" in the first column, and changes with a "!", with the old code first, and the new second. *** dvialw.ps-old Wed Jul 29 14:35:41 1987 --- dvialw.ps Fri Sep 18 17:48:10 1987 *************** *** 1,3 **** --- 1,10 ---- + % <BEEBE.TEX.DVI>DVIALW.PS.17, 18-Sep-87 17:48:04, Edit by BEEBE + % Add test for note paper and if unknown, use letter paper instead. + % Non-Apple PostScript implementations do not know about note paper + % but its use on the Apple LaserWriter gains 92K of virtual memory + % <BEEBE.TEX.DVI>DVIALW.PS.16, 18-Sep-87 15:50:52, Edit by BEEBE + % Modify coordinate computations to remove round-off errors + % in landscape mode, and correct landscape page origin % <BEEBE.TEX.DVI>DVIALW.PS.14, 22-Jun-87 09:55:05, Edit by BEEBE % Add missing "0 900 translate Mtrx currentmatrix pop" to /LEGAL % <BEEBE.TEX.DVI>DVIALW.PS.13, 7-Jan-87 17:38:51, Edit by BEEBE *************** *** 110,116 **** /BOJ { 72 Resolution div 72 Resolution div scale ! NOTE % default page format } bdf % BOP -- beginning of page --- 117,126 ---- /BOJ { 72 Resolution div 72 Resolution div scale ! userdict /note known ! {NOTE} % default page format for ALW ! {LETTER} % default page format for others ! ifelse } bdf % BOP -- beginning of page *************** *** 146,151 **** --- 156,162 ---- ch-xoff neg ch-yoff ch-height sub ch-width ch-xoff sub ch-yoff setcachedevice + 0 0 SNAP translate ch-width ch-height true [ 1 0 0 -1 ch-xoff ch-yoff ] {ch-image} imagemask } if *************** *** 185,190 **** --- 196,202 ---- 72 Resolution div dup scale 0 3300 translate -90 rotate + 0 -750 translate Mtrx currentmatrix pop } bdf *************** *** 271,276 **** --- 283,292 ---- % SF -- set new font at scale nnn (nnn = 1 normally; 2 gives double size chars) % Usage -- nnn /fontname SF /SF {findfont exch scalefont setfont} bdf() pop + + % SNAP -- convert coordinates to integer device coordinates and back again + % Usage -- xxx yyy SNAP (leave xxx' yyy' on stack) + /SNAP {transform 2 {floor 0.5 add exch} repeat itransform} bdf % T -- move absolute horizontally and show string, updating horizontal position % to new endpt [08-Sep-87] In lptops.c, change OUTSTR(getlogin()); to if (getlogin() != (char*)NULL) OUTSTR(getlogin()); because getlogin() can sometimes return a null pointer, instead of a null string. [31-Aug-87] {Thanks to HUXTABLE@UKANVAX.BITNET} In gblprocs.h in the ANSI type declarations for dvifile and main, change "char *[0]" to "char *[]". The "[0]" is an odd production of Microsoft C which was used to prepare the type declarations at compile time. It sneaked through the editing (it is not needed for Microsoft C to compile these). VAX VMS C version 2.3-024 now supports ANSI function declaration prototypes; I don't have it up yet. [14-Aug-87] Released Version 2.08 in time for TUG meeting. [14-Aug-87] {Thanks to Matthias Moritz (U608017@NHYKUN11.EARN) for Atari support additions} Merged in support for the Atari 520ST+ using the Mark Williams C Compiler. makefile.ast should build it. Since this involves changes in many routines, I took the opportunity to introduce a few other changes as well, and incremented the version number of dvi*.c from 2.07 to 2.08. The new versions should be functionally identical to the previous ones for virtually everyone. The Mark Williams compiler has some limitations, and could not handle long macro definitions, in particular DEBUG_OPEN and FONTLIST. I have therefore made DEBUG_OPEN() expand to dbgopen(), where the latter is defined at the end of dviinit.h; this does not follow my standard practice of one function per file. FONTLIST was simply removed, and the two instances of its use were replaced by its definition. There are about 40 instances in the driver source code of macros continued over multiple lines. They are written that way to prevent long lines in the source code (80 is the absolute limit), which is an even more serious barrier to portability. The default stacksize on the Atari is often too small; for the time being, main programs have been set to declare a larger stack. On PC DOS (which Atari GEMDOS resembles), the Microsoft EXEMOD utility can be used to change the stacksize of an executable program without requiring code modification. I don't know whether there is something similar on the Atari. I removed the OS_xxxx-dependent conditional code in dvi*.c for output file extension selection, by introduction of a new variable, DVIPREFIX, in machdefs.h. This is prepended to the default file extension, which is now always identical to the letters following dvi in the dvi*.c files. On systems which do not support long file extensions, it will be a null string; otherwise, it will be "dvi-". In dvialw.c, a genuine BUG surfaced; PSDEF_PATH should be #define'd to be subpath instead of SUBPATH. Otherwise, it cannot be overridden by an environment variable. Thanks to Matthias Moritz for catching this one. An experimental version of a Canon A2 driver has been added as dvica2.c, based on work by Pekka Pietilainen (TFYS-PP@FINOU.BITNET), starting from dvican.c. I have merged in his changes and removed Unix-isms. This driver is intentionally not included in the Makefiles. Only a few sites have the Canon A2 printer, and once more experience is obtained, it may replace dvican.c. If you have such a printer, you can easily modify the appropriate Makefile to support it, or you can just compile and load dvica2 manually. For debugging purposes, three additional option switches are accepted in option.h; they will disappear as the code settles. More experience with the drivers at many VAX VMS sites has indicated that variable-length record files for the output are probably undesirable until DEC gets its act in gear and makes all VMS utilities handle such files properly. I have therefore modified the code in dviinit.h to use the fixed-block binary format for all but POSTSCRIPT devices (for which the output is truly an ordinary text file); previously, this format was only selected for IMPRESS (dviimp). For non-Unix operating systems, it is generally necessary to open binary files differently than text files, since the C-runtime libraries use that distinction to decide how to translate Unix line terminators. Every system so far has used the letter "b" in the fopen() mode string to select this mode, and every Unix system ignores the "b", except Ultrix, which raises a run-time error, sigh... I have therefore replaced the mode string by RB_OPEN and WB_OPEN, and they are set in machdefs.h. For all Unix systems they will be "r" and "w", and for most non-Unix systems, "rb" and "wb". Lines longer than 80 characters in *.c and *.h files have been wrapped. The header "%!PS-Adobe-1.0" in dvialw.c has been shortened to "%!"; the Adobe TranScript spooler software thinks it is allowed to do page reversal when it sees this, but dvialw output pages cannot be reordered because fonts are defined only on demand. The similar header in lptops.c is all right; the pages there ARE independent. The sources have been run through 4.2BSD lint and System V lint. A number of missing typecasts have been supplied, and several unreferenced local variables have been eliminated. lint still produces many warnings, but the remaining ones seem to be benign, or simply red herrings. lint revealed numerous problems with texidx.c (which came from the GNU Project). I have eliminated unused variables and functions, but there remain some serious errors of incorrect argument lists to sort_in_core() and sort_offline(). I am not proposing to fix these now, because at least 3 comprehensive indexing packages for TeX have appeared recently, and texidx.c may rapidly become obsolete. I have changed the handling of some preprocessor symbols in several routines so as to eliminate redefinition warnings, and any assumptions that undefined symbols evaluate to 0. The draft ANSI C standard REQUIRES that all undefined symbols evaluate to 0 in preprocessor expressions, but many compilers to do yet follow this rule (VAX VMS C in particular). [15-Aug-87] {Thanks to Julian Perry (seismo!mcvax!zen.co.uk!jules)} The code in option.h in the -o switch section that forced page_begin[npage] <= page_end[npage] conflicts with negative page numbers for counting from the end. I have removed the code there, and then in dvifile.h, before the main page loop, inserted code to reset the page_begin[] and page_end[] arrays to positive values (this can only be done after page_count is known), and to order them properly. [10-Aug-87] {Thanks to Gary Beihl (beihl%bell.cad.mcc.com@mcc.com)} In lw78.c and dvialw.c, change instances of time(0) to time((long*)NULL). [27-Jul-87] {Thanks to Charles Karney (Karney%ppc.mfenet@nmfecc.arpa)} Here are two small changes to vaxvms.c: In vmsexit(), we turn on a high bit on a non-zero status code to suppress a useless VMS message: 150,151c150,151 < exit((1 << 28) + 2); /* error */ < break; /* (suppresses %NONAME-E-NOMSG) */ --- > exit(2); /* error */ > break; 457d456 In system(), add a test for the status code returned by LIB$SPAWN; for the MAKE utility, this allows recognition of errors returned from a compilation. < int stat; 463,464c462 < return ((LIB$SPAWN(&t,0,0,0,0,0,&stat) == SS$_NORMAL) < && ((stat & 1) > 0)) ? 0 : 127; --- > return (LIB$SPAWN(&t) == SS$_NORMAL) ? 0 : 127; [20-Jul-87] Updated cross-referencing awk scripts for use on Sun OS 3.3 using standard cxref utility, replaced old x*.awk by xref, xref1.awk, xref2.awk, and xref3.awk, and replaced dvi.lrf and dvi.rby by dvi.xrf. [20-Jul-87] {Thanks to Eric M. Carroll (Eric.M.Carroll@uunet.uu.net)} In dvialw.c, getlogin() can return a NULL pointer, so we need to guard against that. Change (void)fprintf(plotfp,"%%%%Creator: %s and ",getlogin()); to (void)fprintf(plotfp,"%%%%Creator: %s and ", (getlogin() == (char*)NULL) ? "" : getlogin()); [08-Jul-87] Update makefile.* to reflect new dvil3p, and remove obsolete makefile.eun (for Eunice). [08-Jul-87] Add symbol DECLN03PLUS and change SUBPATH for Unix from /usr/lib/tex/inputs/ to /usr/lib/tex/macros to match Washington TeX distribution. [08-Jul-87] In gblprocs.h, add OS_VAXVMS to the list of hosts where sprintf() is not declared (because it is in system include files). [08-Jul-87] Change type of main() from void to int in gblprocs.h and main.h to bring them into conformance with the draft ANSI C Standard. [08-Jul-87] In fontfile.h, changed VMS section to allow for the possibility that TEXFONTS is a logical name list (thanks for John Sauter for this). [08-Jul-87] {Thanks to John Sauter (Sauter@dssdev.dec.com)} Add dvil3p.c for DEC LN03+ printer. [08-Jul-87] In dvil75.c in prtbmap(), change OUTC('-') to OUTS("-\n") so as to avoid long output lines. [10-Jun-87] Fix several spelling errors: machdefs.h: "you machine" -> "your machine" dvi.hlp: "cmr10.300pxl" -> "cmr10.1500pxl" "setenv VAR=value" -> "setenv VAR value" dviman.ltx: "cmr10.300pxl" -> "cmr10.1500pxl" "setenv VAR=value" -> "setenv VAR value" dviman.texinfo: "cmr10.300pxl" -> "cmr10.1500pxl" "setenv VAR=value" -> "setenv VAR value" [20-May-87] from Brendan Mackay (munnari!anucsd.oz!bdm@seismo.CSS.GOV) In openfont.h, the virtual font section can erroneously reference a null fontfp; change if (virt_font) to if (virt_font && (fontfp != (FILE*)NULL)) and if (virt_font && virt_save[fileno(fp)].base != (char *)NULL) to if (virt_font && (fp != (FILE*)NULL) && (virt_save[fileno(fp)].base != (char *)NULL)) [15-May-87] On line 127 of execute.c in the IBM PC-specific MAKE utility, change *str >= 'A' && *str <= 'A' || to *str >= 'A' && *str <= 'Z' || [29-Apr-87] from Brendan Mackay (munnari!anucsd.oz!bdm@seismo.CSS.GOV) In machdefs.h, change #define REWIND(fp) fseek(fp,0L,0) to #define REWIND(fp) FSEEK(fp,0L,0) This is not necessary for the family as distributed, but Brendan has implemented the virtual font changes necessary for VAX VMS; they should be incorporated in a future release. [29-Apr-87] from Brendan Mackay (munnari!anucsd.oz!bdm@seismo.CSS.GOV) The code for vms_read() [in vaxvms.c] has problems. One is that you don't test for end of file. The other is that there is a bug in the C library which prevents you asking for more than 65535 bytes at a time. It is documented that no more than 65535 bytes will be returned, but not that you can't ask for more. If you do, it reduces your request mod 65536! Here's a replacement: /**********************************************************************/ /*-->READ*/ int READ(file_desc,buffer,nbytes) register int file_desc; register char *buffer; register int nbytes; { register int ngot; register int left; for (left = nbytes; left > 0; /* NOOP */) { ngot = read(file_desc,buffer,(left > 65024 ? 65024 : left)); if (ngot < 0) return (-1); /* error occurred */ if (ngot == 0) /* eof occurred */ return(nbytes-left); buffer += ngot; left -= ngot; } return(nbytes-left); } [15-Apr-87] Completed version 2.07 for general release. [04-Apr-87] to [15-Apr-87] Changed texidx.c to check for special characters in generated \initial{} commands and suitably protect them. Changed dviinit.h to try to open output file and log file in current directory if open in the directory of the .dvi file fails (presumably because no write access to that directory). Adapted loadbmap() code from dvican.c to dvijep.c, and added function declaration in gblprocs.h, finally removing the limitation dvijep had for large font characters. Rearranged some struct members in gblvars.h to ease debugging. Added check in openfont.h for null pfontptr. Updated Makefile's and added ones for KCC, PCC, and VMS. Rewrote 00arit.c to test short, int, and long integer arithmetic. Changed version numbers in dvi*.c from 2.06 to 2.07. Split bopact.h (beginning of page action) out of eopact.h. Rewrote eopact.h to reflect new instant keyboard response and better control over page positioning. Increased value of BIGBGCHAR in dvibit.c to allow large characters to be sent as fonts, rather than bitmaps. There seems to be a bug in BitGraph Version 3.10 which causes characters to be overwritten at the right margin when the actual screen width is used. Reduced value of XSIZE in dvibit.c to fix the problem. Decreased YSIZE in dvibit.c to make space for larger command and status area at top of screen. Added keybrd.c and keydef.h to handle keyboard input. keybrd.c was a major effort (900 lines of code and comments), but now nicely hides the ugliness of instant keyboard input on all the operating systems presently supported in the DVI family. Removed references to Berkeley Unix sgtty.h file and tty structures in dvibit.c and gblvars.h; no longer needed since keybrd.c hides those details. Use JSok instead of JSerr in f20open.h to allow jsys() calls to work for both KCC-20 and PCC-20. Modified character screen clipping decision in setchar() in dvibit.c. Changed raster-op code from 3 to 9 in BBNDPD command in setchar() in dvibit.c so that display is correct with both inverse video and normal video. Split reldfont.h out of readfont.h to support font unloading needed for dvibit zoom commands. Added #include "reldfont.h" to dvi*.c. Removed conditionals around #include statements and put them in the #include'd file instead; this reduces the number of changes needed in the dvi*.c files as new implementations are made. This affects f20open.h, strchr.h, and strrchr.h. Added KCC support changes to dvihead.h, fatal.h, f20open.h, gblprocs.h, machdefs.h, main.h, strchr.h, strrchr.h, texid3.h. Added terminal backslash to lines in multi-line macro invocations in dvijep.c and getbmap.h (KCC restriction). Added new function declarations to gblprocs.h. Changed dimension of message[] in gblvars.h from MAXSTR to MAXMSG; it needs to be larger than MAXSTR in order to hold error messages containing strings of size MAXSTR. MAXMSG is defined in gendefs.h. Updated lptops.c and lw78.c for KCC. Added conditionals to lptops.c to initialize all unset symbols to 0 (KCC requires this), and default to OS_UNIX if no host is defined. Added KCC_20 and DECLA75 symbols to machdefs.h. Changed major DVI command loop in prtpage.h to call kbinput(), bopact(), and eopact() for BBN BitGraph, and changed full screen erase to partial erase to preserve command/status window. In texid3.c, changed short name readln to rdline to remove conflict with KCC library. Added GETCHAR routine to vaxvms.c; this is not needed by the DVI driver family, but the idea was used in keybrd.c. [01-Apr-87] Begin work on Version 2.07 General work: major changes to support new KCC-20 compiler, substantially enhance DVIBIT, and add DVIL75. ======================================================================== [01-Apr-87] End work on Version 2.06: [04-Mar-87] Added declaration of errno in dvihead.h for BSD41 and BSD42; they don't have it in errno.h. [04-Mar-87] Added test for null file pointer before calls to fclose() in abortrun.h and dviterm.h; failure to do so causes core dumps when exit() is entered in 4.1 and 4.2BSD Unix. [27-Feb-87] option.h did not support negative magnifications, like -m-0.5 and -m-1, which was advertised in the documentation, dviman.ltx. Code has now been added to handle that case. Without the fix, it is of course still possible to get any magnification value, since e.g. if -m1500 is the default on a 300 dpi printer, then -m-0.5 is equivalent to -m1369 (1369 = 1500/(1.2**(-0.5))). [26-Feb-87] In dispchar.h, change the line rightones[HOST_WORD_SIZE - 1 - bits_to_next] & to rightones[bits_to_next] & This code is not active for non 32-bit machines, or the IBM PC, and the local 32-bit Unix machines running the driver family have been using only the laser printer members, so the bug was not caught until we actually tried DVIPRX output under VAX VMS. The effect it has is that large vertical white streaks appear in the output bitmap; dispchar() is used by all the low-resolution dot matrix printers. [25-Feb-87] Added code to prtbmap() in dviprx.c to print bitmap in hexadecimal when (debug_code & 1) is non-zero. [21-Feb-87] In prtpage.h, corrected "\special" to "\\special"; this error was caught by the KCC-20 compiler. [10-Feb-87] Yesterday I discovered that VAX VMS 4.4 printf() wipes out the stack and kills the process if a long string is printed. This turns out to be the case in outline() in dvitos.c; the code has been modified to use fputs() there instead. [10-Feb-87] Several debugging sessions on VAX VMS stepping through the call chain fflush() -> _flsbuf() -> _flsbuf_record() -> write_record() -> write_buffer() -> write_imbed() -> write_output() ->signal() -> c$$translate() have made it clear that the simple scheme in dvi*.c and lptops.c of checking for a non-zero return value from fflush() or ferror() is an unreliable way to conclude a legitimate error (specifically, disk storage exhausted) exists. Consequently, these routines have been modified to call clearerr() at the beginning of loadchar() and prtbmap(), then to use a macro DISKFULL() to test for the error condition. DISKFULL() is defined in machdefs.h, and errno.h is now included by dvihead.h. This regrettably introduces small changes in a number of routines, but no other clean way of doing the job appeared to be feasible. [02-Feb-87] Changed "pagecollation on" to "pagecollation off" in dviimp.c. With version 3.3 of the Imagen Image Processor software, there seems to be a bug in that "pagecollation on" causes page reversal. I have reported this to Imagen. [20-Jan-87] Replaced page_xxx[] arguments to sscanf() in option.h with int temporaries p1,p2,p3; the page_xxx[] values are of type INT16 which does not match the %d format items. The use of sscanf() in fontsub() is okay. The one in special() in dvialw.c has the type COORDINATE for the variables llx, lly, urx, ury; the type has been changed to int. This bug surfaced on an HP Unix system with the FOCUS chip; it is disguised on the DEC-20 by virtue of short, int, and long all being one word long, and on the VAX and Intel architectures which address these values by their low-order, rather than high-order, byte (i.e. little Endian order). [16-Jan-87] Corrected error in tosprx.c which resulted in loss of first page, and added test to avoid unnecessary OR'ing zero bits into bitmap. [10-Jan-86] In machdefs.h, reset MAXOPEN to NFILES-6 or less, where NFILES is the limit on the number of open files set in stdio.h. It was previously NFILES-5, which can cause an abort with a message "unable to open error log file" because all file handles are in use. [07-Jan-86] Finished preliminary release of DVICAN for the Canon LBP-8 A2 laser printer. At present, this is forced to send bitmaps for every single typeset character, since the downloaded font mechanism does not work reliably. Canon's documentation is abysmal, and after tearing my hair out staring at hex dumps of the output of many test files, I received a hex dump of a file from a site in Holland using a driver obtained from Japan; to my surprise, they did not use the download mechanism, just bitmaps, so I expect they hit the same problems I did. I intend to try to find out more detailed information from the local Canon dealer--perhaps there is something magic missing. It is indeed suspicious however, when TeX input "ABABABABAB" produces "ABA A A A ", and "A SHORT STORY" produces "A SH RT T Y"--characters apparently randomly (though reproducibly) dropped from the printed page. The penalty for sending bitmaps instead of fonts is severe--on a 15-page test file, it took 10.8 times as many bytes/page as DVIJEP, averaging nearly 95K characters/page, for a throughput of one printed page every 2 to 4 minutes, instead of the 4/minute available from the LaserJet Plus. [20-Dec-86] Updated DVIBIT, fixing several things that had been broken by changes which could not be tested earlier, and improving the interactive interface. End-of-page action in prtpage.h has been expanded and moved out to eopact.h. Warning messages are suppressed for DVIBIT when quiet mode (-q) is selected to avoid needlessly trashing the screen. Default magnification for low-resolution devices changed from 579 (magstep -3 in 200dpi family) to 603 (magstep -5 in 300dpi family). Added run-time selectable virtual font support for performance improvement, particular on networked file systems where the overhead of reading small packets becomes unacceptably large. With .PK fonts, most font files for normal sized text are 4K to 8K bytes, and for SliTeX text, 15K to 20K bytes. With up to 15 fonts open, this probably requires less than 200K bytes of memory, which is available for the non-bitmapped drivers even on my IBM PC. [15-Dec-86] Reorganized machdefs.h to group each set of machine-specific changes inside one conditional for that machine. Removed #undef's--if the compiler warns of redefinitions, that is useful feedback that the right set has been chosen. Completed port to VAX VMS. VMS C has an incomplete library and faulty implementations of fseek(), ftell(), and ungetc(). To get around these, macros FSEEK, FTELL, and UNGETC have been used throughout the code, and machdefs.h will define them to point to special versions found in vaxvms.c in the OS_VAXVMS conditional section. The VMS debugger, particular in screen mode where the source code, output, and debug input are displayed in three windows is excellent, though unnecessarily verbose. VMS C makes memory page 0 inaccessible. This caught two instances of dereferencing of NULL pointers in movedown.h and moveover.h. Logical names for VAX VMS are chosen to match the Kellerman and Smith TeX implementation. DVI and font file formats are assumed to be fixed binary; stream files would be better (since fseek() and ftell() work properly for them, and padding to block boundaries is unnecessary), but their use would require rewriting change files for all the TeXware. [05-Dec-86] In dviinit.h (TOPS-20 and VMS only), fix bug causing referencing of *(NULL + 1). Change "if (isdigit(*(tcp1+1)))" to "if ((tcp1 != (char*)NULL) && isdigit(*(tcp1+1)))" [15-Nov-86] In fontfile.h (bug found Unix conditional code, but could happen if other machines were added), in the loop beginning m = 0; /* index in filelist[] */ for (k = 0; k < MAXFORMATS; ++k) /* loop over possible file types */ { *filelist[k] = '\0'; /* Initially, all filenames are empty */ the filelist[] entry is cleared on each loop iteration, but in the Unix code section, it is actually advancing over two entries at a time. The initialization must be moved out into a separate new loop preceding the old one: for (k = 0; k < MAXFORMATS; ++k) *filelist[k] = '\0'; /* Initially, all filenames are empty */ [13-Nov-86] Update makefile.1, makefile.2, makefile.msc for IBM PC. [13-Nov-86] Add extra library .h file #include's in dvihead.h for IBM PC MICROSOFT C library function declarations. [12-Nov-86] Change malloc to MALLOC in getbmap.h, loadchar.h, machdefs.h, and readfont.h; for IBM PC Microsoft, this is defined to use calloc() instead of malloc() in machdefs.h. This seems to remove a long-standing bug of the driver hanging the machine after printing the last page, presumably while in the free() calls in dviterm(). I made extensive tests on the DEC-20 to try to reproduce this bug, by using DDT to introduce code that initializes the free stack area and malloc()'d memory to values which would cause integer overflow if used as integers, and would cause illegal memory references if used as pointers. No failure could be precipitated by this. On the IBM PC, the symptom was that the driver would run on a freshly-booted machine (booting sets memory to a specific non-zero bit pattern), but if other programs had been run, it would sometimes hang. I found that by using the debugger to preinitialize memory to a fixed bit pattern before running DVIJEP, I could repeatedly run DVIJEP all night long. The change from malloc() to calloc(), which zeroes the returned memory, permitted DVIJEP to run successfully 85 times in a row; when I subsequently reran the old version, it hung the PC. Recent netmail has carried numerous discussions of irregularities of both Lattice and Microsoft C malloc()'s; this may be one more manifestation. [31-Oct-86] Fixed a dumb typo in dvialw.c and dvijep.c; in setstr(), change (void)fprintf(stderr,isprint(c) ? "%c" : "\\%03o",c); to (void)fprintf(stderr,isprint(str[k]) ? "%c" : "\\%03o",str[k]); [24-Oct-86] Whoops! Somehow, warning() lost its code to write its message on stderr as well as the log file. At the end, add the lines NEWLINE(stderr); #if (OS_TOPS20 | OS_VAXVMS) (void)putc('%',stderr); /* percent at start of line */ #endif (void)fputs(msg,stderr); NEWLINE(stderr); if (g_logname[0]) { (void)fprintf(stderr, "Current TeX page counters: [%s]",tctos()); NEWLINE(stderr); } The check of g_logname[0] suppresses an attempt to supply page counters when no .DVI file has yet been opened. [24-Oct-86] If an invalid option is detected in option(), then warning() and/or fatal() will be called. However, there is not yet a file name available for a log file, and g_dolog is initially TRUE, so both warning() and fatal() will abort because the log file cannot be opened. Change the "if (g_dolog ...) statements in fatal.h and warning.h to include the condition "&& g_logname[0]". Since C requires external variables to be initialized to zero, g_logname[0] = '\0' when option() is called, and no attempt will be made to open the log file in warning() and fatal(). [21-Oct-86] For TOPS-20 only, set output and log file generation retention counts to zero, implying all generations will be kept. That way, if the user runs dvixxx for the same file, but with different parameters (-x and -y are good examples), the earlier versions will not be lost. This adds some new flags to machdefs.h, and some additional code to dviinit.h, fatal.h, and warning.h right after their fopen() calls. fopen(,"w+") will reuse an existing file, so we changed the logfile generation to "-1", always giving a new file. [21-Oct-86] In prtpage.h, inserted rule_height = -1; /* reset last rule parameters */ rule_width = -1; before line str_ycp = -1; in POSTSCRIPT section (about line 115) of case BOP. I caught this when I did `dvialw foo.dvi.*' today-- after the first file, the PostScript output contained a reference to the Q macro before a B had been issued to define h and w, the previous bar dimensions. [13-Oct-86] Added -d32 option to cause display of all truncated off-page text strings. This was prompted by my wasting time looking for what I thought was a bug in setstr() with long strings. Changes in functions setstr() and setchar() in dvialw.c and dvijep.c, and setchar.h, as well as documentation in dviman.ltx and dviman.texinfo. [15-Sep-86] Added -z option for PostScript and HP LaserJet Plus on TOPS-20 only; this types in a command "DVISPOOL: dvifilename\n", permitting the user to define a spooler for the DVI file. This typein is not automatic as in TOPS-20 TeX, because it may interfere with batch and .mic files; however, the final newline is supplied, because it is assumed the user wanted it if the option switch was given. Changes in dviterm.h, gblvars.h, option.h, and usage.h, with new BOOLEAN global variable "spool_output". [15-Sep-86] Added page_step[] to allow printing pages in steps other 1, such as for duplex printing, and option -obeginpage:endpage:steppage; this required changes in dvifile.h, gblvars.h, main.h, option.h, and usage.h. [09-Sep-86] Changed checksum error message in readgf.h, readpk.h, and readpxl.h to output checksums in octal and hexadecimal as well as decimal, and explain why the mismatch is likely to have occurred. Changed debug_code to debug_code & 4 in dvijep.c, and updated dviman.ltx to define settings of -d# option for selective debug output. Added DEBUG_OPEN() calls to dvialw.c, dviinit.h, fatal.h, fontsub.h, openfont.h, and warning.h, and definition of DEBUG_OPEN() to gendefs.h. Delete doubled word in comment in charpk.h. Insert typecast in fillrect.h: *p = (UNSIGN32)ONES. Insert typecast in dvibit.c: tcharptr->istoobig = ((int)(tcharptr->hp* ((tcharptr->wp+15) >> 4)) >= BIGBGCHAR); Change macro argument c to ch in dvijep.c (Microsoft C version 4.0 otherwise thinks that the c in the format specification is to be expanded too): #define SETCHARCODE(fontnumber,ch) {\ if (fontnumber)\ (void)fprintf(plotfp,"\033*c%dd%dE",fontnumber,MAPCHAR(ch));\ else\ (void)fprintf(plotfp,"\033*cd%dE",MAPCHAR(ch));\ } [04-Sep-86] Fixed handling of -o-# in option.h; I forgot to check for signs in skipping the number. [28-Aug-86] Wrote errshow.c; it is a filter which merges the error message file output by Microsoft C with a copy of the source line causing the error message. [28-Aug-86] Minor changes for type matching. Added typecasts in chargf.h, charpk.h, dvialw.c, and dvijep.c. Changed type declarations of m_begin, m_end, m_step in dvitype.h, of k in fontfile.h, and of fontfile() arguments in gblprocs.h. Added code for IBM_PC_MICROSOFT to include stdlib.h and string.h in main.h. Version 3.0 of Microsoft C has a number of errors and inconsistencies in the library file type declarations for stdio.h and string.h. I fixed declarations and use of putc(), putchar(), fileno(), _flsbuf(), thereby eliminating "strong type mismatch" errors on every instance of use of these functions. Declarations of argument types for strxxx() have int instead of char, and unsigned int instead of int, for strchr(), strlen(), strrchr(), strncpy(), strncat(), and strncmp(), which is at variance with Kernighan & Ritchie, and with Harbison & Steele, so use of these still gives type mismatch errors. I am not fixing the library file declarations pending seeing what Version 4.0 has to offer, and what the ANSI C Standard committee does with them. [21-Aug-86] Add -e option in option.h for run-time command-line definition of ``environment'' variables, and move initialization of xx_index out of initglob() into dvifile(). This was prompted by the use of Unix server invocations of the drivers through calls to ``system("dvixxx filename")''. Such a call creates a new shell which, although it inherits the caller's environment, may in fact require different environment variables, especially for things like FONTLIST and TEXFONTS. [21-Aug-86] Change fontlist.h, gendefs.h, and openfont.h to support a more general mechanism of font file name generation. fontlist() now returns a list of pointers to a series of possible font file names; the first null string in the list terminates it. The Unix and VAX VMS code sections in fontlist.h now generate names with the magnification both in the directory name as well as in the extension. This was prompted by a local need at Utah with some networked Unix workstations which have both flavors of font file storage. [21-Aug-86] Change handling of TeX \countn values to INT32, instead of UNSIGN32; roman-numeral pages come out with negative page numbers in PLAIN.TEX. This affects the declaration and use of tex_counters[] in dviinit.h, gblvars.h, prtpage.h, and tctos.h. [18-Aug-86] Allow negative page numbers on -o#:# switch to mean pages from end (-1 = last, -2 = next to last, etc.). sscanf() format change in option(), and introduce PAGENUMBER() macro in dvifile(). [15-Aug-86] Conversion of the font magnification factor for *.*pxl files in fontfile.h to dots/inch for the *.*gf and *.*pk files forgot to round up. Thus, mag 1643 became 328 instead of 329. Because fontfile() gets a truncated magnification value, the rounding is non-trivial; comments in fontfile() describe what is necessary. ; Local Modes: ; Mode:Text ; Comment Column:0 ; Auto Fill Mode:1 ; Fill Column:65 ; Fill Prefix:" " ; Indent Tabs Mode:0 ; End: