dvidvi 1.0, Copyright (C) 1988-2011, Radical Eye Software
Anyone may freely use, modify, and/or distribute this file, without limitation.

Here's a little hack I threw together for those doing pagination
tricks.  Any improvements are appreciated.  Enjoy!
The dvidvi program converts a dvi file into another dvi file,
with perhaps certain changes.  Invocation is

        dvidvi param infile outfile

What are the parameters?  The 'easy' paramaters are the following:

	-f n     page n is first page selected
	-l n     page n is last page selected
	-n n     select at most n pages. Notice that n is the number of pages
		 selected, independently of the number of pages actually
		 contained in a sheet
	-i { n1..n2 | n1 }[,...]
		 include pages (ranges allowed). When this option is
		 used, ONLY the specified pages are selected. However,
		 we can exclude from these pages with the option -x
	-x { n1..n2 | n1 }[,...]
		 exclude pages (ranges allowed)
	-q       work in quiet mode, that is do not print in the screen
		 messages of how the work is being done.
	-r       reverse the order of the pages.

The page numbers for the above options -f -l -i and -x can be specified
in different ways.

1) If a number n is given, it is interpreted as the n'th page from the
begining of the .dvi file. Of course, this number is independent of the
page number assigned by TeX.

2) TeX page numbers are those who are actually written in the page;
these page numbers can be modified, for example, by using the TeX commands
\pagenumbering, \setcounter{page}{n}, and \addtocounter{page}{n}.
A TeX page number can be specified by preceding the number n with the
character @. Thus, if you specify -f @25 -l @30 you select the pages
between 25 and 30, these numbers being those assigned by TeX.

3) However, several pages can have the same TeX page number in a .dvi file.
For example, the introductory pages in a book are numbered i, ii, and so on
until the first chapter begins and then, the pages are numbered 1, 2, etc.
In this case, the pages numbered i and 1 in the .dvi file have the same TeX
page number. If you want to select for example the second occurrence of the
page numbered 1, you can specify a page number as (@2)1. Thus @1 is equivalent
to (@1)1. For example, if you specify -f (@2)1 -l(@2)10 you select the pages
between 1 and 10 of the first chapter, not the introductory pages between
i and x.

There is another parameter that tells dvidvi how you want to change page
layout and specifications. This is the -m parameter.

        The number preceding the colon is the modulo value.  Everything
will be done in chunks of pages this big.  If there is no colon, than the
default value is assumed to be one.  The last chunk of pages is padded
with as many blank pages as necessary.

        Following the colon is a comma-separated list of page numbers.
These page numbers are with respect to the current chunk of pages, and
must lie in the range zero to the modulo value less one.  If a negative
sign precedes the number, then the page is taken from the mirror chunk;
if there are m chunks, then the mirror chunk of chunk n is the chunk
numbered m-n-1.  Put simply, it is the chunk numbered the same, only
from the end.  This can be used to reverse pages.  If no number is
given, the page number defaults to 1.

        Following each page number is an optional offset value in
parenthesis, which consists of a pair of comma-separated dimensions.
Each dimension is a decimal number with an optional unit of measure.
The default unit of measure is inches, or the last unit of measure
used.  All units are in true dimensions.  Allowable units of measure
are the same that TeX allows:  in, mm, cm, pt, pc, dd, and cc.

        Simple enough, eh?  Okay, let's do some simple things.

-m -      Reverses the order of the pages.  This time, both the modulo and
	  the page number are defaulted.

-m 2:0    Selects the first, third, fifth, etc. pages from the file.  Print
	  this one after printing the next, taking the paper out of the
	  feed tray and reinserting it into the paper feed.

-m 2:-1   Selects the second, fourth, etc. pages, and writes them in reverse
	  order.
-m 4:-1,2(4.25in,0in)
-m 4:-3,0(4.25in,0in)
	 Useful for printing a little booklet, four pages to a sheet,
	 double-sided, for stapling in the middle.  Print the first one,
	 put the stack back into the printer upside down, and print the
	 second.  The `in' specifications are superfluous.
-m ,(1pt,1)
        Scare your system administrator!  Actually, things are so
        blurry with this option, you may want to send enemies letters
        printed like this.  *Long* letters.
-m 4:0(5.5in,4.25),3(0,4.25)
-m 4:1(0in,4.25),2(5.5,4.25)
        Print a four-page card on one sheet.  Print the first, rotate
        the paper 180 degrees and feed it again.  (PostScript people
        can do funny tricks with PostScript so this isn't necessary.)

Enjoy; this is an early release, so make suggestions, improvements,
and I'll get back to you with a better version later.


======================================================================


CTAN SOURCE TREE INFORMATION


This CTAN source tree has been automatically extracted from the texk
Subversion repository at svn://tug.org/texlive/trunk/Build/source/texk/.

It is not possible to use the supplied configure script.
In fact, if you call it; you will be told as such.

This source can only be compiled in a texk build environment.
You will need to download the whole environment, please refer to
http://www.tug.org/texlive/svn/.

It all boils down to a Subversion checkout of
svn://tug.org/texlive/trunk/Build/source
This will be the source tree that you can use for compilation. The
CTAN directory is there for archival and informational purpose.

For your convenience, the original configure script from the texk
source tree is available in this directory as configure.texk.

For the CTAN team,

    Joachim Schrod <jschrod@acm.org>