%%% The grfpaste package %%% LaTeX support for TeXplorators / M. Spivak dvipaste program %%% David Carlisle This package can redistributed and/or modified under the terms of the LaTeX Project Public License Distributed from CTAN archives in directory macros/latex/base/lppl.txt; either version 1 of the License, or (at your option) any later version. Dvipaste comes with a plain TeX based set of macros in a file dvipaste.tex that provide an interface to the dvipaste program. That file works perfectly well in LaTeX with only minor modifications (specifically using \@@line instead of \line, and \c@page instead of \pageno). A dvipaste.sty constructed by just such modifications may be found distributed with Jean-Pierre Drucbert's `export' package on ctan. However I thought that it would be more in the `LaTeX spirit' to provide an interface via the existing LaTeX graphics package. The files produced by this grfpaste package should be fully compatible with dvipaste.tex or dvipaste.sty. That is, if dvi fragments are created using the plain TeX interface they may be included using \includegraphics via this package, and conversely if this package is used with the [write] or [writepages] options to produce a file of dvi fragments for including in another file, then the dvi file (and it's accompanying `.dat' file of size information) may be included either with this package, or via the original dvipaste.tex interface. Currently the LaTeX interface uses the graphicx package, it would be possible to also provide an interface to the more basic graphics package, but that is not done here. The package is used in one of two forms. 1 Producing DVI Fragments ========================= 1a Writing out boxes. =========================== \documentclass{article} \usepackage[write]{grfpaste} \begin{document} \sendout{\parbox[b]{2cm}{one \sf two three \tt four \it five}} \sendout[abc]{hello} \sendout{\parbox[t]{2cm}{one \sf two three \tt four \it five}} \end{document} If the package is used with the [write] option then the document should just consist of \sendout commands, the argument of each will be marked as a `fragment' that may be pasted into another DVI file by the dvipaste program. An auxiliary file with extension .dat will be created which contains the size of each of these fragments. Normally the fragments will be accessed by their number, starting from 1, but you may optionally supply a label, as in `abc' above which allows fragments to be referenced more easily. The above example forms the example document grfp1.tex in this distribution. 1b Writing out whole pages. =========================== \documentclass{article} \usepackage[writepages]{grfpaste} \begin{document} ... \end{document} If the package is used with the [writepages] option then each indivdual page will be marked as a `fragment' for later processing by dvipaste. The fragments will be numbered consecutively, starting from 1, whatever the value of the page counter. See the example document grfp2.tex. 2 Using DVI Fragments ========================= \documentclass{article} \usepackage{grfpaste} \begin{document} aaa\fbox{\includegraphics [num=1,natheight=19,natdepth=2pt,natwidth=57]{grfp1.dvi}}bbb xxx\fbox{\includegraphics[num=2]{grfp1.dvi}}yyy xxx\fbox{\includegraphics[ref=abc]{grfp1.dvi}}yyy Page 3 of grfp2.dvi: aaa\fbox{\includegraphics[num=3]{grfp2}}bbb \end{document} To use the fragments then load the package with no option (or equivalently with the [include] option). You may also use any options understood by the graphicx package, these will be passed on to graphicx which is loaded by this package. To load the first fragment of a given dvi file you just need \includegraphics{filename} or \includegraphics{filename.dvi} (.dvi is added as one of the default extensions by this package) To access later fragments then you use the new num=?? key to specify the fragment number, as demonstrated above. If there are a lot of fragments maintaining the correct number may be inconvenient so you may instead use the ref= key to refer to a label previously supplied by the \sendout command. Note this label information is added to the .dat file in the form of a comment(after %) and so the .dat file is still compatible with dvipaste.tex, but if that is used, then the numeric form must be used. Thus the two examples above with num=2 and ref=abc include the same fragment from the file grfp1.dvi. Normally the size of the graphic is read from the `.dat' file which is the `read file' for the dvi graphic type, in the terminoligy of the graphics package documentation. If you have lost the .dat file, or wish to override it with altered sizes, you may specify the natural size using the natheight, natwidth and natdepth keys. As usual these take a dimension but the units may be omitted in which case bp are assumed. natheight and natwidth are standard graphicx keys, but natdepth is new, as these fragments are TeX boxes, so have height and depth, unlike most other graphic formats that may be included, which always have zero depth. The \sendout command defined by the [write] option matches that used in the plain TeX support, but the plain TeX version does not use \includegraphics to include the fragment. It defines a command \paste to achieve this. In order to help move documents between the two versions, a [defpaste] option is provided for this package which specifies that a compatible \paste command should be defined. It is defined to be the equivalent call to \includegraphics, \includegraphics[num=#2]{#1}. See the example file grfp3.tex to see examples of including dvi fragments. 3 Putting it all together ========================= a) Produce one or more files of fragments using LaTeX and this package with the [write] or [writepages] options. (or plain TeX using dvipaste.tex). b) LaTeX your master document, including this package and using \includegraphics to include the fragments at the appropriate points. At this stage the file will have blank spaces (but if the correct size) at the points where the dvi fragments should appear c) Run dvipaste on the master dvi file. It will incorporate the fragments and re-write the file. d) Preview or print the modified dvi file in your usual manner. 4 Running the examples ========================= grfp1.tex is an example of using the [write] option grfp2.tex is an example of using the [writepages] option grfp3.tex is an example of using the [include] option To process the final document (grfp3.dvi) the following steps need be taken. latex grfp1 latex grfp2 latex grfp2 latex grfp3 dvipaste grfp3 Note that grfp2 needs to be processed twice to generate a full table of contents. After grfp3.tex is processed by LaTeX the dvi file will show blank spaces at the points that the fragments are to be included. These will be filled in by running dvipaste, after which the grfp3.dvi may be processed by your driver in the normal way. 5 Compiling dvipaste.c ====================== /* config.h for LINUX machines for dvipaste.c (DPC) */ #define ANSI #undef MICROSOFTC #define LITTLENDIAN /* I guess this is what was meant. */ /* (dvipaste.c defines strcmp to itself */ /* leaving stricmp undefined) .*/ #ifndef MICROSOFTC #define strnicmp strncmp #define stricmp strcmp #endif #ifdef ANSI /* Other things in ANSI C are good, but this is a crock */ #define READ_BINARY "rb" #define WRITE_BINARY "wb" #else /* The good old simple and logical K&R I/O */ #define READ_BINARY "r" #define WRITE_BINARY "w" #endif When I tried compiling dvipaste.c I got error due to the function stricmp being undefined. The file has a circular definition of strcmp to itself which looks like a typo, so I corrected that by making stricmp an alias for strcmp by altering config.h as above (which also sets LITTLENDIAN for Linux. It seems to work for me, but no promises. The above suggested config.h leaves stricmp meaning the same thing as strcmp (string comparison). Jean-Pierre Drucbert points out that stricmp is (on systems that it is defined) a case-insensitive comparison function, and that rather than the crude substitution above one may define it as follows. str{n}icmp is not available on all systems. So I got the following code in ci.c : #include <ctype.h> #include "config.h" /* * str{n}icmp - case-insensitive flavors of strcmp(), strncmp() */ #ifdef PROTOS int stricmp(register char *s1, register char *s2) #else int stricmp(s1, s2) register char *s1, *s2; #endif { register char c1, c2; for ( ; (c1 = TOLOWER(*s1)) == (c2 = TOLOWER(*s2)); s1++, s2++) if (c1 == '\0') return 0; return c1 - c2; } #ifdef PROTOS int strnicmp(register char *s1, register char *s2, int n) #else int strnicmp(s1, s2, n) register char *s1, *s2; int n; #endif { register char c1, c2; for ( ; --n >= 0 && (c1 = TOLOWER(*s1)) == (c2 = TOLOWER(*s2)); s1++, s2++) if (c1 == '\0') return 0; return n < 0 ? 0 : c1 - c2; } By default dvipaste.c has #define STRINGSIZE (5124) /* maximum string size */ Jean-Pierre Drucbert commented: it is necessary to increase STRINGSIZE if you paste a lot of dvi pieces (I increased it from 40592 to 2597888). In practice, do not export more than ~100 pieces from one file. You can import a lot more into one file. So it is preferable to import from several files if you have more than 100 pieces to import.