|
|
DataMuseum.dkPresents historical artifacts from the history of: DKUUG/EUUG Conference tapes |
This is an automatic "excavation" of a thematic subset of
See our Wiki for more about DKUUG/EUUG Conference tapes Excavated with: AutoArchaeologist - Free & Open Source Software. |
top - metrics - downloadIndex: T d
Length: 63473 (0xf7f1)
Types: TextFile
Names: »diss.sty«
└─⟦9ae75bfbd⟧ Bits:30007242 EUUGD3: Starter Kit
└─⟦3658e588a⟧ »EurOpenD3/mail/mh/mh-6.7.tar.Z«
└─⟦c75e36ecb⟧
└─⟦this⟧ »mh-6.7/papers/doclib/diss.sty«
% UCI Dissertation Style for AmSTeX.
% @(#)$Id: diss.sty,v 1.3 90/04/05 15:20:23 sources Exp $
% Tim Morgan with many suggestions, bug fixes, etc, from Marshall Rose
% Based originally on Michael Spivak's AMSPPT.STY.
% When edits are made to this file, the version number should be incremented.
\def\version{103}
\let\fmtversion=\version % These two control sequences are defined
\def\fmtname{dissertation} % in plain.tex, so we do it here too.
% Assumes the following hidden definitions from plain.tex:
% \z@ is defined from plain.tex as 0pt (and magically can
% be used as the integer constant 0 also).
% \p@ is the same, but 1pt
% \@ne is 1
% \m@ne is -1
% \tw@ is 2
% \thr@@ is 3
% \@m is 1000
% \@M is 10000
% And the following scratch register definitions:
% \dimen@ is \dimendef'd to be \dimen0
% \skip@ is \skipdef'd to be \skip0
% \count@ is \count255
\catcode`\@=11 % So we can use a special character
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% PARAMETERS DIFFERENT THAN IN PLAIN %
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% These are words which TeX doesn't hyphenate perfectly.
% Unfortunately, the plural forms must be included also.
\hyphenation{com-put-er com-mun ap-pen-dix cart-wheel data-base Dijk-stra}
\hyphenation{in-fra-struc-ture man-u-script mi-cro-fiche para-mil-i-tary}
\hyphenation{post-am-ble pre-am-ble sub-scrib-er wave-guide sub-scrib-ers}
\hyphenation{com-put-ers cart-wheels data-bases in-fra-struc-tures}
\hyphenation{man-u-scripts mi-cro-fiches post-am-bles pre-am-bles}
\hyphenation{buf-fer buf-fers des-ig-na-ted par-a-graph par-a-graphs}
\hyphenation{key-stroke key-strokes usu-al-ly}
\def\normal@topskip{0.48cm}
\topskip=\normal@topskip % For correct page positioning, do NOT
\hoffset=0.5in % change any of these values!!!
\voffset=0.07cm
\hsize=15.2cm
\vsize=22.2cm
\normallineskiplimit=\p@ % Min. dist. btw. lines.
\parindent=1cm % Normal indentation.
\hfuzz=0.115\p@ % So we hear fewer complaints. Good up to
\vfuzz=0.115\p@ % 300 dpi.
\pretolerance=200 % At 12pt, these margins are kind of narrow
\tolerance=300 % so we have to be more tolerant.
\clubpenalty=\@M % Never allow these.
\widowpenalty=\@M
\newlinechar=`\^^J % For writing output to tty.
\uchyph=\z@ % Don't take any chances.
\brokenpenalty=\@M % Never hyphenate last line on a page.
\newcount\defaultinterlinepenalty % This probably won't make any
\defaultinterlinepenalty=\thr@@ % difference, so why not??
\interlinepenalty=\defaultinterlinepenalty
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% PARAMETERS DIFFERENT from AmSTeX %
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
\TagsOnRight % Set tags like a sane person does
%%%%%%%%%%%%%%%%%%%%%%%%
% EXTRA FONTS NEEDED %
%%%%%%%%%%%%%%%%%%%%%%%%
\newif\ifolddigits
\olddigitsfalse % Allow use of amcscod10 for citations
\def\useolddigits{%
\olddigitstrue
\oktell{Old Digits Mode}%
}
\font\sixrm=cmr6 \font\sixbf=cmbx6
\font\sixi=cmmi6 \skewchar\sixi='177
\font\sixsy=cmsy6 \skewchar\sixsy='60
\font\eightrm=cmr8 \font\eightsl=cmsl8 \font\eightit=cmti8
\font\eightsy=cmsy8 \skewchar\eightsy='60
\skewchar\eightsy='60 \font\eightbf=cmbx8
\font\eightex=cmex10 at 8\p@
\font\eighti=cmmi8 \skewchar\eighti='177
\font\ninerm=cmr9 \font\nineit=cmti9
\font\ninei=cmmi9 \skewchar\ninei='177
\font\ninesy=cmsy9 \skewchar\ninesy='60
\font\ninesl=cmsl9 \font\ninebf=cmbx9
\font\twelvecsc=cmcsc10 scaled \magstep1
\font\tencsc=cmcsc10
\font\eightcsc=cmcsc10 at 8\p@
\font\elevencsc=cmcsc10 scaled \magstephalf
\font\ninecsc=cmcsc10 at 9\p@
\let\tencscod=\tencsc
\let\eightcscod=\eightcsc
\font\eightsf=cmss10 at 8\p@
\font\tensf=cmss10
\font\twelvesf=cmss10 at 12\p@
\font\twelvett=cmtt10 scaled \magstep1
\font\eighttt=cmtt10 at 8\p@ % \tentt is predefined in plain.tex
\font\twelvebti=cmbti at 12\p@
\font\tenbti=cmbti
\font\eightbti=cmbti at 8\p@
\font\twelveex=cmex10 scaled \magstep1 \font\twelverm=cmr10 scaled \magstep1
\font\twelvesl=cmsl10 scaled \magstep1 \font\twelvebf=cmbx10 scaled \magstep1
\font\twelvei=cmmi10 scaled \magstep1 \skewchar\twelvei='177
\font\twelvesy=cmsy10 scaled \magstep1 \skewchar\twelvesy='60
\font\twelveit=cmti10 scaled \magstep1
\font\twelvechap@font=cmssbx10 at 14\p@
\font\twelvesec@font=cmss10 at 13\p@
\font\twelvesubsec@font=cmssi10 scaled \magstep1
\font\tenchap@font=cmssbx10 scaled \magstep1
\font\tensec@font=cmssbx10 scaled \magstephalf
\font\tensubsec@font=cmssi10
\font\eightchap@font=cmssbx10
\font\eightsec@font=cmss10 at 9\p@
\font\eightsubsec@font=cmssqi8
% Font selection
\newcount\font@no
\def\curfont{\ifcase\font@no\rm\or\it\or\sl\or\bf\or\tt\or\csc\or\bti\or\sf
\else\errmessage{Internal font confusion}\fi}
%%%%%%%%%%%%%%%%%%%%%
% SPACING CONTROL %
%%%%%%%%%%%%%%%%%%%%%
\newskip\normalabovedisplayskip
\newskip\normalbelowdisplayskip
\newskip\normalabovedisplayshortskip
\newskip\normalbelowdisplayshortskip
\newdimen\normalparskip \normalparskip=22.5\p@
\newdimen\parstretch \parstretch=8\p@
\newif\ifsinglespacing % Tells if we are currently in single space mode
\newif\ifhalfspacing % Special version of singlespacing, a little bigger.
% Actually tell TeX what spacing is wanted
\def\setbaselines{%
\baselineskip=\normalbaselineskip
\abovedisplayskip=\normalabovedisplayskip
\belowdisplayskip=\normalbelowdisplayskip
\abovedisplayshortskip=\normalabovedisplayshortskip
\belowdisplayshortskip=\normalbelowdisplayshortskip
% Compute \parskip for even paragraph spacing at all pt sizes
\dimen@=\normalparskip
\advance\dimen@ by -\normalbaselineskip
\parskip=\dimen@ plus\parstretch
}
% Go from double to single spacing
\def\reducespacing{%
\normalbaselineskip=0.64\normalbaselineskip
\normalabovedisplayskip=0.64\normalabovedisplayskip
\normalbelowdisplayskip=0.64\normalbelowdisplayskip
\normalabovedisplayshortskip=0.64\normalabovedisplayshortskip
\normalbelowdisplayshortskip=0.64\normalbelowdisplayshortskip
}
% Set halfspacing baseline etc starting from singlespacing mode
\def\sethalfspacing{%
\normalbaselineskip=1.28125\normalbaselineskip
\abovedisplayskip=1.28125\abovedisplayskip
\belowdisplayskip=1.28125\belowdisplayskip
\abovedisplayshortskip=1.28125\abovedisplayshortskip
\belowdisplayshortskip=1.28125\belowdisplayshortskip
}
% Go to single spacing if we're not there already
\def\singlespace{%
\normalspacing \reducespacing
\halfspacingfalse \singlespacingtrue
\setbaselines
}
% Go to 1-1/2 spacing.
\def\halfspace{%
\normalspacing \reducespacing \sethalfspacing
\singlespacingtrue \halfspacingtrue
\setbaselines
}
% Go to normal, doublespacing mode
\def\doublespace{%
\normalspacing
\singlespacingfalse \halfspacingfalse
\setbaselines
}
% Make sure we're doing the spacing we're supposed to be.
\def\setspacing{%
\normalspacing
\ifsinglespacing
\reducespacing
\ifhalfspacing \sethalfspacing \fi
\fi
\setbaselines
}
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% FOUR DIFFERENT POINT SIZES %
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
\def\twelvepoint{%
\def\big@@AmS{10.2\p@}%
\def\Big@@AmS{13.8\p@}%
\def\bigg@@AmS{17.4\p@}%
\def\Bigg@@AmS{21.0\p@}%
\let\smallertype=\tenpoint
\let\curtype=\twelvepoint
\def\biggertype{\errmessage{No larger point size available}}%
\def\normalspacing{%
\normalbaselineskip=22.8\p@
\normalabovedisplayskip=14.5\p@ plus 3\p@ minus 9\p@
\normalbelowdisplayskip=14.5\p@ plus 3\p@ minus 9\p@
\normalabovedisplayshortskip=\z@ plus 4\p@
\normalbelowdisplayshortskip=9\p@ plus 4\p@ minus 5\p@
}%
\def\rm{\font@no=0\fam\z@\twelverm}%
\def\it{\font@no=1\fam\itfam\twelveit}%
\def\sl{\font@no=2\fam\slfam\twelvesl}%
\def\bf{\font@no=3\fam\bffam\twelvebf}%
\def\tt{\font@no=4\fam\ttfam\twelvett \spaceskip.5em plus.25em
minus.15em }%
\def\csc{\font@no=5\twelvecsc}%
\def\bti{\font@no=6\twelvebti}%
\def\sf{\font@no=7\twelvesf}%
\let\sc=\csc
\ifolddigits
\let\cite@font=\tencscod
\else
\let\cite@font=\elevencsc
\fi
\textfont\z@=\twelverm \scriptfont\z@=\ninerm \scriptscriptfont\z@=\sixrm
\textfont\@ne=\twelvei \scriptfont\@ne=\ninei \scriptscriptfont\@ne=\sixi
\textfont\tw@=\twelvesy \scriptfont\tw@=\ninesy \scriptscriptfont\tw@=\sixsy
\textfont\thr@@=\twelveex \scriptfont\thr@@=\twelveex
\scriptscriptfont\thr@@=\twelveex
\textfont\itfam=\twelveit
\textfont\slfam=\twelvesl
\textfont\ttfam=\twelvett
\textfont\bffam=\twelvebf \scriptfont\bffam=\ninebf
\scriptscriptfont\bffam=\sixbf
\let\chap@font=\twelvechap@font
\let\sec@font=\twelvesec@font
\let\subsec@font=\twelvesubsec@font
\let\subsubsec@font=\twelvebf
\def\oldstyle{\fam1\twelvei}%
\setspacing
\curfont
\ifundefined{everypointsize}\else\everypointsize{twelve}{12}\fi
}
\def\tenpoint{%
\def\big@@AmS{8.5\p@}%
\def\Big@@AmS{11.5\p@}%
\def\bigg@@AmS{14.5\p@}%
\def\Bigg@@AmS{17.5\p@}%
\let\smallertype=\eightpoint
\let\curtype=\tenpoint
\let\biggertype=\twelvepoint
\def\normalspacing{%
\normalbaselineskip=18.9\p@
\normalabovedisplayskip=12\p@ plus 3\p@ minus 9\p@
\normalbelowdisplayskip=12\p@ plus 3\p@ minus 9\p@
\normalabovedisplayshortskip=\z@ plus 3\p@
\normalbelowdisplayshortskip=7\p@ plus 3\p@ minus 4\p@
}%
\def\rm{\font@no=0\fam\z@\tenrm}%
\def\it{\font@no=1\fam\itfam\tenit}%
\def\sl{\font@no=2\fam\slfam\tensl}%
\def\bf{\font@no=3\fam\bffam\tenbf}%
\def\tt{\font@no=4\fam\ttfam\tentt \spaceskip.5em plus.25em
minus.15em }%
\def\csc{\font@no=5\tencsc}
\def\bti{\font@no=6\tenbti}%
\def\sf{\font@no=7\tensf}%
\let\sc=\csc
\ifolddigits
\let\cite@font=\eightcscod
\else
\let\cite@font=\ninecsc
\fi
\textfont\z@=\tenrm \scriptfont\z@=\sevenrm \scriptscriptfont\z@=\fiverm
\textfont\@ne=\teni \scriptfont\@ne=\seveni \scriptscriptfont\@ne=\fivei
\textfont\tw@=\tensy \scriptfont\tw@=\sevensy \scriptscriptfont\tw@=\fivesy
\textfont\thr@@=\tenex \scriptfont\thr@@=\tenex
\scriptscriptfont\thr@@=\tenex
\textfont\itfam=\tenit
\textfont\slfam=\tensl
\textfont\ttfam=\tentt
\textfont\bffam=\tenbf \scriptfont\bffam=\sevenbf
\scriptscriptfont\bffam=\fivebf
\let\chap@font=\tenchap@font
\let\sec@font=\tensec@font
\let\subsec@font=\tensubsec@font
\let\subsubsec@font=\tenbf
\def\oldstyle{\fam1\teni}%
\setspacing
\curfont
\ifundefined{everypointsize}\else\everypointsize{ten}{10}\fi
}
\def\eightpoint{%
\def\big@@AmS{6.8\p@}%
\def\Big@@AmS{9.2\p@}%
\def\bigg@@AmS{11.6\p@}%
\def\Bigg@@AmS{14.0\p@}%
\def\smallertype{\errmessage{No smaller point size available}}%
\let\curtype=\eightpoint
\let\biggertype=\tenpoint
\def\normalspacing{%
\normalbaselineskip=15\p@
\normalabovedisplayskip=10\p@ plus 2.4\p@ minus 7.2\p@
\normalbelowdisplayskip=10\p@ plus 2.4\p@ minus 7.2\p@
\normalabovedisplayshortskip=\z@ plus 2.4\p@
\normalbelowdisplayshortskip=55.6\p@ plus 2.4\p@ minus 3.2\p@
}%
\def\rm{\font@no=0\fam\z@\eightrm}%
\def\it{\font@no=1\fam\itfam\eightit}%
\def\sl{\font@no=2\fam\slfam\eightsl}%
\def\bf{\font@no=3\fam\bffam\eightbf}%
\def\tt{\font@no=4\fam\ttfam\eighttt \spaceskip.5em plus.25em
minus.15em }%
\def\csc{\font@no=5\eightcsc}%
\def\bti{\font@no=6\eightbti}%
\def\sf{\font@no=7\eightsf}%
\let\sc=\csc
\def\cite@font{\errmessage{You may not do citations in 8 point}}
\textfont\z@=\eightrm \scriptfont\z@=\sixrm \scriptscriptfont\z@=\fiverm
\textfont\@ne=\eighti \scriptfont\@ne=\sixi \scriptscriptfont\@ne=\fivei
\textfont\tw@=\eightsy \scriptfont\tw@=\sixsy \scriptscriptfont\tw@=\fivesy
\textfont\thr@@=\eightex \scriptfont\thr@@=\eightex
\scriptscriptfont\thr@@=\eightex
\textfont\itfam=\eightit
\textfont\slfam=\eightsl
\textfont\ttfam=\eighttt
\textfont\bffam=\eightbf \scriptfont\bffam=\sixbf
\scriptscriptfont\bffam=\fivebf
\let\chap@font=\eightchap@font
\let\sec@font=\eightsec@font
\let\subsec@font=\eightsubsec@font
\let\subsubsec@font=\eightbf
\def\oldstyle{\fam1\eighti}%
\setspacing
\curfont
\ifundefined{everypointsize}\else\everypointsize{eight}{10}\fi
}
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% TABLE of CONTENTS Macros %
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% This set of macros allows you to build a table of contents for a document
% automatically in TeX. There are only three control sequences which you
% will need to use. The first is \inicont, which initializes the macros.
% This package works by writing the appropriate lines into a file called
% \jobname.toc in your account. This file is read by \printcontents or
% by \printcont in PRINT-PRELIM.TEX.
%
\newwrite\cont@file % Get a free channel to write to
\newif\ifcont@closed
\cont@closedtrue % Haven't opened contents file yet
\newwrite\fig@file
\newwrite\tab@file
\newif\iffig@closed
\fig@closedtrue % Or the list of figures file
\newif\iftab@closed
\tab@closedtrue % Or the tables file
\def\contitle{\jobname.toc} % Default name of contents file
\def\figtitle{\jobname.lof} % ditto for figures file
\def\tabtitle{\jobname.lot} % ditto for tables file
% Make sure the contents file is open before writing to it
\def\opencontfile{%
\ifcont@closed
\immediate\openout\cont@file=\contitle
\cont@closedfalse
\fi
}
%
% This control sequence adds its argument to the table of contents.
%
\def\content#1{%
\opencontfile
\let\\=\space
\write\cont@file{\string\Z{#1}{\the\pageno}}%
}
%
% This control sequence is the same as \content except that the first
% box written will have two leading spaces to indent it.
%
\def\subcontent#1{%
\opencontfile
\let\\=\space
\write\cont@file{\string\Z{\string\hskip \parindent{}#1}{\the\pageno}}%
}
% And the same thing for sub-sections
\def\subsubcontent#1{%
\opencontfile
\let\\=\space
\write\cont@file{\string\Z{\string\hskip 2\parindent{}#1}{\the\pageno}}%
}
% And the same thing for sub-sub-sections
\def\subsubsubcontent#1{%
\opencontfile
\let\\=\space
\write\cont@file{\string\Z{\string\hskip 3\parindent{}#1}{\the\pageno}}%
}
% Simple table-of-contents printer for \articlestyle.
% For dissertations, use the one in print-prelim.tex.
% Use this macro as the last thing in your report, since it makes
% the page numbers be in romannumerals at the bottom of the page.
\def\printcontents{%
\closeout \cont@file
\null\vfill\supereject % Close output, end last page
\twelvepoint\rm % Make sure we're in normal mode
\pageno=\m@ne % Contents get roman numerals.
\plain@page@numbers % Put page #s at bottom only
\oktell{Table of Contents}
\null \vskip .8in minus\baselineskip
\centerline{\chap@font Contents}
\vskip \tw@\baselineskip
\rightline{Page}
\begingroup % Temporarily change \baselineskip to avoid
% underfull \vbox's during output errors.
\baselineskip=\@ne\baselineskip plus .05\baselineskip
\def\Z##1##2{\line{\ignorespaces##1\leaders
\hbox to.7em{.\hfil}\hfil\hbox to2em{\hss##2}}}
\catcode`@=11
\let\\=\space
\input\contitle \relax
\endgroup % Also undoes the \catcode change
}
%%%%%%%%%%%%%%%%%%%%%%%%
% NUMBERED FOOTNOTES %
%%%%%%%%%%%%%%%%%%%%%%%%
% First, modify \vfootnote from Plain to use smallertype and singlespace
\def\vfootnote#1{%
\insert\footins\bgroup\tenpoint\singlespace
\interlinepenalty\interfootnotelinepenalty
\splittopskip\ht\strutbox % top baseline for broken footnotes
\splitmaxdepth\dp\strutbox \floatingpenalty\@MM
\leftskip\z@skip \rightskip\z@skip \spaceskip\z@skip \xspaceskip\z@skip
\parindent=.13in
\textindent{#1}\footstrut\futurelet\next\fo@t
}
% Allocate a counter for the numbered footnotes
\newcount\note@count \note@count=\@ne
\def\nfootnote#1{%
\unskip\footnote{$^{\number\note@count}$}{#1}%
\global\advance\note@count by\@ne
}
% Same except that trailing period or comma is ``tucked'' under
% the note mark. \ntucknote provides auto numbering.
\def\ntucknote#1#2{\nfootnote{#1}\llap{#2}}
\def\tucknote#1#2#3{\footnote{#1}{#2}\llap{#3}}
%%%%%%%%%%%%%%%%%%%%
% UTILITY MACROS %
%%%%%%%%%%%%%%%%%%%%
% Insert a discretionary hyphen. For use in restricted
% horizontal mode, as in the bibliography.
\def\hyphenbreak{\discretionary{-}{}{-}}
% Check if a macro name is currently undefined (from The TeXbook)
\def\ifundefined#1{\expandafter\ifx\csname#1\endcsname\relax}
% Terminal input and output routines and auxilary stuff
\newwrite\undef@out@chan % Allocate a channel for the tty
\def\tell#1{{\let\\=\space\immediate\write\undef@out@chan{#1}}}
\def\ask#1{\read-16 to #1} % Read from tty w/o prompt
% Sanitize a string before \write'ing it.
% Call with \unexpanded{op}{msg}
% Modified from version in The TeXbook, originally by Todd Allen
\long\def\unexpanded#1#2{%
\def\finwrite{#1}%
{\aftergroup\finwrite\aftergroup{\sanitize@uci#2\endsanity@uci}}%
}
\def\sanitize@uci{\futurelet\next@uci\sanswitch@uci}
\def\sanswitch@uci{\ifx\next@uci\endsanity@uci
\else\ifx\next@uci\\\aftergroup\space\let\next@uci=\eat@uci
\else\ifcat\noexpand\next@uci\space\aftergroup\space\let\next@uci=\eat@uci
\else\ifcat\noexpand\next@uci\bgroup\aftergroup{\let\next@uci=\eat@uci
\else\ifcat\noexpand\next@uci\egroup\aftergroup}\let\next@uci=\eat@uci
\else\let\next@uci=\copytoken@uci\fi\fi\fi\fi\fi \next@uci
}
\def\eat@uci{\afterassignment\sanitize@uci \let\next@uci= }
\long\def\copytoken@uci#1{%
\ifcat\noexpand#1\relax\aftergroup\noexpand
\else\ifcat\noexpand#1\noexpand~\aftergroup\noexpand
\fi
\fi
\aftergroup#1\sanitize@uci
}
\def\endsanity@uci\endsanity@uci{}
% Now use the sanity stuff to make a sane tell command. This macro
% actually takes one argument, but since it's the last for \unexpanded,
% we avoid scanning it twice by not picking it up here.
\def\sanetell{\unexpanded{\immediate\write\undef@out@chan}}
% Produce verbatim listings of various sorts
\def\uncatcodespecials{\def\do##1{\catcode`##1=12 } \dospecials}
\def\setupverbatim{%
\par \tt \spaceskip=\z@ % Want fixed tt spacing now
\obeylines \uncatcodespecials \obeyspaces \verbatimdefs
}
% This macro turns on verbatim mode until ?endverbatim is seen.
\def\verbatim{%
\begingroup \setupverbatim
\parskip=\z@ plus .05\baselineskip \parindent=\z@
\catcode`\ =13 \catcode`\^^M=13 \catcode`\?=\z@
\verbatimgobble
}
{\catcode`\^^M=13{\catcode`\ =13\gdef\verbatimdefs{\def^^M{\ \par}\let =\ }}
\gdef\verbatimgobble#1^^M{}%
}
% This defines ?endverbatim to end the group which begins with \verbatim
\let\endverbatim=\endgroup
% Input a file in verbatim mode. Sometimes useful for including
% real-life examples into a paper.
\def\verbfile#1{%
\begingroup\setupverbatim
\parskip=\z@ plus .05\baselineskip \parindent=\z@
\input#1 \endgroup
}
% This is the same as the above, but it adds line numbers to each
% line of the file printed. \lineno@uci has the obvious use.
\newcount\lineno@uci
\def\listing#1{%
\lineno@uci=\z@
\begingroup\setupverbatim
\parskip=\z@ plus .05\baselineskip \parindent=20\p@
\everypar{\advance\lineno@uci by\@ne \llap{\the\lineno@uci\ \ }}%
\input#1
\endgroup
}
% Draw a little qed symbol (black box)
\def\qed{\hbox{\hskip\p@ \vrule width4\p@ height6\p@ depth1.5\p@ \hskip\p@}}
% Conditions -- from AmSppt
\newif\ifrunin@AmS
\runin@AmSfalse
\let\runin=\runin@AmStrue
\newdimen\cond@dimen
\newdimen\condindent % Amount each nested condition is indented
\condindent=.5in % Default indentation amount
% This is used in \conditions
\def\firstcon@AmS#1:{%
\ifrunin@AmS
{\rm\ignorespaces#1\unskip}\ignorespaces
\runin@AmSfalse
\else
\par
\ifdim\lastskip<\smallskipamount
\removelastskip \penalty55 \smallskip
\fi
\\#1:%
\fi
}
% Do one item of the conditions. This is really \\ in disguise.
\def\cond@item#1:{%
\par\noindent
\hbox to \cond@dimen{\hfil\rm\ignorespaces#1\unskip\quad}%
\hangafter1
\hangindent\cond@dimen\ignorespaces
}
\cond@dimen=\z@ % Value for outermost block
% Do the main stuff for \conditions.
\def\conditions{%
\par
\let\\=\cond@item
\begingroup
\advance\cond@dimen by\condindent
\firstcon@AmS
}
% Exit special stuff for \conditions.
\def\endconditions{%
\par\smallbreak\endgroup
\ifdim\cond@dimen>\z@ \cond@item \fi % If ending an inner condition
}
% Automatically numbered items
\newcount\item@count
\newdimen\item@dimen \item@dimen=\z@
\def\item@prefix{}
\def\beginitems{%
\begingroup
\advance \parindent by\item@dimen
\ifnum\item@dimen>\z@
\edef\item@prefix{\item@prefix\number\item@count.}
\else
\item@dimen=1cm
\fi
\item@count=\z@ \singlespace \interlinepenalty=200
}
\def\enditems{\par\endgroup}
\def\nitem{\advance\item@count by\@ne \item{\item@prefix\number\item@count.}}
% Turn back on the \+ construct of plain TeX.
\def\tabalign{\us@true\m@ketabbox}
\outer\def\+{\tabalign}
% Fix AmSTeX's definition used in its definition of ~ (tie).
\def\s@AmS{\penalty\@M\ifx\tok@AmS\Space@AmS\else\ \fi}
% And make \/ work the way it does in plain.tex
\let\/=\ic@AmS
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% PAGE CONTROL and OBJECT MANIPULATION %
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% This definition doesn't blow up if you're in vertical mode already
\def\pagebreak{\ifhmode\vadjust{\break}\else\break\relax}
% This definition clears out all previous inserts etc to
% guarantee that the following stuff is at the top of a page.
\def\clearpage{\vfill\supereject}
% This macro keeps the stuff in the argument on the same page, leaving
% blank space on this page if necessary
\def\keep{\par\setbox\z@=\vbox\bgroup}
\def\endkeep{%
\egroup
\dimen@=\ht\z@
\advance\dimen@ by\dp\z@
\vskip\z@ plus\dimen@
\penalty\z@
\vskip\z@ plus-\dimen@
\vskip\parskip
\box\z@
\goodbreak
}
\def\filkeep{%
\egroup
\filbreak
\vskip\parskip
\box\z@
\goodbreak
}
% List macros from the TeXbook
\toksdef\ta=\z@ \toksdef\tb=\tw@
\newif\ifresult@uci
% usage: \newlist\list
\def\newlist#1{\let#1=\empty}
% usage: \append{item}\to\list
\def\append#1\to#2{\ta={\\{#1}}\tb=\expandafter{#2}\edef#2{\the\tb\the\ta}}
\def\gappend#1\to#2{\ta={\\{#1}}\tb=\expandafter{#2}\xdef#2{\the\tb\the\ta}}
% usage: \cardinality\list\to\counter
\def\cardinality#1\to#2{#2=\z@ \long\def\\##1{\advance#2 by\@ne }#1}
% usage: \ifismember{item}\of\list ... \else ... \fi
\def\ifismember#1\of#2{%
\def\given@uci{#1}%
\result@ucifalse
\def\\##1{%
\def\next@uci{##1}%
\ifx\next@uci\given@uci \result@ucitrue\fi
}%
#2%
\ifresult@uci
}
% usage: \ifwasmember{item}\of\list ... \else ... \fi
% side effect: removes {item} from \list if present
\def\ifwasmember#1\of#2{%
\newlist\ref@mtr
\def\given@uci{#1}%
\result@ucifalse
\def\\##1{%
\def\next@uci{##1}%
\ifx\next@uci\given@uci
\result@ucitrue
\else
\append ##1\to\ref@mtr
\fi
}%
#2%
\let#2=\ref@mtr
\ifresult@uci
}
% Append #1 to list #2 if #1 is not already in #2
\def\addtolist#1\to#2{%
\ifismember#1\of#2%
\else
\append #1\to #2%
\fi
}
% Same thing, but do it \global'ly
\def\gaddtolist#1\to#2{%
\ifismember#1\of#2%
\else
\gappend#1\to#2%
\fi
}
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% STUFF for BIBLIOGRAPHY and APPENDICES %
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% Bibliography Package:
% Original version by Michal Spivak
% Updated for JACM format and automated by Tim Morgan
% Final cleanup, and much-improved automation, by Marshall Rose
% Additional work and IEEE support by TM.
% Simple appendix entry builder
\def\appendix#1#2{%
\par
\clearpage
\ifoddpages
\ifodd\pageno \else \null\vfill\eject\fi
\fi
\pageno@foot
\begingroup
\setbox\z@=\hbox{#1}%
\ifdim\wd\z@>\z@
\content{Appendix #1: #2}%
\oktell{Appendix #1: #2}%
\def\title{Appendix #1\\#2}%
\else
\content{Appendix: #2}%
\oktell{Appendix: #2}%
\def\title{Appendix\\#2}%
\fi
\let\\=\cr \tabskip=\z@ \chap@font
\halign to\hsize{\centerline{\ignorespaces##\unskip}\cr\title\cr}%
\endgroup
\nobreak
\vskip 1.0in minus 0.15in
}
% Citations:
% We keep a running list, \ref@set, which is
% all the things which were \cite'd throughout the paper, with
% only one entry for each different key.
%
% There are three versions of each of the citation
% commands:
% 1. The \def'd version is the normal one used throughout the paper.
% 2. Within a figure, table, etc,'s caption, because of the use of
% \def and \edef, a special version which just produces the
% citation without the \gaddtolist command is used. These
% definitions are predefined, and are \let to be \cite etc with
% \no@cites, for speed.
%
% When the user requests a citation with key, we first look it up
% in a translation table called \key@table, organized as a list of
% <key, printed-key> pairs, to see if it really should be
% printed differently. The user can specify this translation table using
% the \printkey command. If a key is not in the table, it is printed
% as-is.
% We keep the dimension \key@size as the largest printed key so far.
% This value can then be used to print the keys in the bibliography
% optimally, rather than just trying to guess. Each time we print a
% (in \use@key), we see if it's longer than \key@size, and if so then
% we set \key@size = its width.
\newdimen\key@size
\key@size=\z@ % Init. value so \key@size is made as small as possible
% Invisible citation. usage: \icite{key}
\def\icite#1{%
\gaddtolist#1\to\ref@set
}
% Management of \key@table stuff. This table is formatted as
% \\{real-key}{printed-key}...
\newlist\key@table
% Add a pair of items to the list. This should be done before any
% citations are made, for obvious reasons.
% #1=real key (the one you use in the paper and bibliography)
% #2=the key that gets printed in the output
\def\printkey#1#2{%
\ta={\\{#1}{#2}}%
\tb=\expandafter{\key@table}%
\xdef\key@table{\the\tb\the\ta}%
}
% Print a key, looking it up in the table. #1 is \whatever which
% expands to the key used by the user. The definition of \\ here
% makes use of the format of the \key@table, so that the table is
% actually EXECUTED, hence making lookup relatively fast.
\newif\if@not@printed@
\def\use@key#1{%
\@not@printed@true
\def\\##1##2{%
\if@not@printed@
\def\temp@uci{##1}%
\ifx\temp@uci#1%
\@not@printed@false
\setbox\z@=\hbox{[##2]\enspace}%
\ifdim\wd\z@>\key@size \global\key@size=\wd\z@ \fi
##2%
\fi
\fi
}%
\key@table
\if@not@printed@
\setbox\z@=\hbox{\cite@font[\ignorespaces#1\unskip]\enspace}%
\ifdim\wd\z@>\key@size \global\key@size=\wd\z@ \fi
#1%
\fi
}
% This macro moves forward until it hits \end, skipping spaces.
% Each time it hits a comma, or when it hits and \end, it
% adds whatever has been collected so far (in \@total) to
% \ref@set and to the output list. It is assumed that \@total
% has been set to \empty before this routine is called (this is done
% by \@@cite, below).
\def\@icite#1{%
\if#1\end
\expandafter\gaddtolist\@total\to\ref@set
\use@key\@total
\let\@next=\relax % Exit loop after this time
\else
\if#1,% % We have a complete key now.
\expandafter\gaddtolist\@total\to\ref@set
\use@key\@total,\space
\global\let\@total=\empty
\else
\xdef\@total{\@total#1}% Add new char to total
\fi
\let\@next=\@icite % Continue looping until done
\fi
\@next
}
% Initialize and call \@icite. Used in \cite, \citep, \citepp
\def\@@cite#1{\global\let\@total=\empty\@icite#1\end}
% usage: \cite{key [, key...]}
\def\cite#1{%
{\cite@font[\@@cite{#1}]}%
}
% usage: \citep{key}{page}
\def\citep#1#2{%
{\cite@font[\@@cite{#1}, \hbox{\rm p \ignorespaces#2\unskip}]}%
}
% usage: \citepp{key}{pages}
\def\citepp#1#2{%
{\cite@font[\@@cite{#1}, \hbox{\rm pp \ignorespaces#2\unskip}]}%
}
% These three definitions are used in \no@cites, below. They
% don't handle extraneous spaces as well as the normal
% definition, but they should be sufficient for most people.
\def\i@cite#1{{\cite@font[\noexpand\noexpand\noexpand\@@cite{#1}]}}
\def\i@citep#1#2{{\cite@font[\noexpand\noexpand\noexpand\@@cite{#1},\space
\hbox{\noexpand\noexpand\noexpand\rm p \ignorespaces#2\unskip}]}%
}
\def\i@citepp#1#2{{\cite@font[\noexpand\noexpand\noexpand\@@cite{#1},\space
\hbox{\noexpand\noexpand\noexpand\rm pp \ignorespaces#2\unskip}]}%
}
% Turn off adding citations to \ref@set. This is needed when
% using \cite etc inside a caption for tables, figures, etc.
% \no@cites is undone by exiting an enclosing group.
\def\no@cites{%
\let\citepp=\i@citepp
\let\citep=\i@citep
\let\cite=\i@cite
}
%%%%%%%%%%%%%%%%%%%%%%
% References Section %
%%%%%%%%%%%%%%%%%%%%%%
% The basic strategy is as follows. We read the bib. file, which is
% assumed to be in sorted order of keys/author names. Each
% entry is of the form \ref{key}. We see if that key is in the table
% \ref@set, which is a table of all the keys we've \cite'd. If the key
% isn't in the list, we print it in parens and go on to the next entry.
% Otherwise, we print the key in square brackets, and format the
% bibliography entry according to the format (JACM or IEEE). We print a
% warning if the key is in the \ref@seen list. We add the key to
% the \ref@seen list. The key is removed from the \ref@set list if it
% was there. At the end of the references (\endreferences), we check
% if there are any keys left in \ref@set. If so, the bib. file was
% deficient, and we print a warning message (it should probably be a
% fatal error message).
% Annotation control
\newif\ifinclude@annos % Should annotations be printed?
\include@annosfalse % By default, no
\def\annotate{% % ``official'' command
\include@annostrue
\oktell{Annotating bibliography}%
}
\newif\ifin@anno % True while doing an annotation
\in@annofalse
\def\refi@AmS{F} % This starts as False
% Begin an annotation -- must be in vertical mode. Just gather
% text into box0 for use by \endanno. We do a couple of consistency
% checks at the beginning.
\def\anno{%
\ifhmode
\message{You forgot the \noexpand\endref command!}
\message{I've inserted one for you.}
\endanno
\fi
\if F\refi@AmS
\errmessage{No \noexpand\ref command before first \noexpand\anno}
\fi
\let\\=\newline
\in@annotrue
\setbox\z@=\vbox\bgroup
}
% End of an annotation. Decide if it should be typeset or skipped.
\def\endanno{%
\egroup % End the group for box0
\in@annofalse % No longer doing an annotation
\if T\refed@uci % If previous reference was used,
\ifinclude@annos {% And if we're producing an annotated bib.,
\vskip\parskip
\interlinepenalty=\defaultinterlinepenalty
\unvbox\z@ % Then include annotation as normal paragraph(s)
\par
}\fi
\fi
}
\global\newlist\ref@set % list of all references cited
\global\newlist\ref@seen % list of all references defined
\def\reftitle{References} % Default title for bibliography
% usage: \references (begin the References section)
\def\references{%
\vfill\supereject % Begin new page, clear out everything
\ifoddpages % Make sure start on even page.
\ifodd\pageno \relax \else \null\vfill\eject \fi
\fi
\begingroup % Following changes are local to bib.
\twelvepoint % Get good appearance
\singlespace
\no@cites % \cite's just produce [key]
\parskip=0.6\baselineskip plus5\p@ minus4\p@
\tolerance=5000 % Must be extremely tolerant!
\pretolerance=300
\interlinepenalty=400 % To discourage breaking a reference
% across page boundaries
\uchyph=\@ne % Needed to try hyphenating title words
\sfcode`.=\@m % Like \frenchspacing, but only for
% periods
% Now we output the title and so forth.
\centerline{\csc \reftitle}%
\nobreak
\medskip
\content\reftitle % Tell user and TOC.
\oktell\reftitle
\pageno@foot % Put page # in special place
% Special definitions within reference mode
\let\year=\yr
\let\month=\mon
}
% usage: \endreferences (end the References section)
\def\endreferences{%
\par % Make sure last printed reference is finished up.
\cardinality\ref@set\to\count@
\ifnum\count@>\z@
\def\\##1{[##1] }
\ifnum\count@>1
\message{Warning: \number\count@\space undefined citations: \ref@set}
\else
\message{Warning: One undefined citation: \ref@set}
\fi
\fi
\endgroup % End of \references group
}
% References Database
\newbox\bybox@AmS \newbox\bysamebox@AmS
\newbox\paperbox@AmS \newbox\paperinfobox@AmS
\newbox\jourbox@AmS \newbox\jourinfobox@AmS
\newbox\volbox@AmS \newbox\issuebox@AmS
\newbox\monbox@AmS \newbox\yrbox@AmS
\newbox\pagesbox@AmS \newbox\editorbox@AmS
\newbox\bookbox@AmS \newbox\bookinfobox@AmS
\newbox\publbox@AmS \newbox\publaddrbox@AmS
\newbox\finalinfobox@AmS\newbox\wastebox@uci
\newbox\talkbox@AmS \newbox\keybox@AmS
\newbox\editorsbox@AmS
\def\using@IEEE{F} % By default, not using IEEE format
% reset a \keyword to the ``not used'' condition
\def\refset@AmS#1{%
\expandafter\gdef\csname is\expandafter\eat@AmS
\string#1@AmS\endcsname{F}\expandafter
\setbox\csname\expandafter\eat@AmS\string#1box@AmS\endcsname=\null
}
% reset \keyword's
\def\ref@AmS{%
\refset@AmS\key \refset@AmS\finalinfo
\refset@AmS\by \gdef\isbysame@AmS{F}%
\refset@AmS\paper \refset@AmS\paperinfo
\refset@AmS\jour \refset@AmS\jourinfo
\refset@AmS\vol \refset@AmS\issue
\refset@AmS\mon \refset@AmS\yr
\refset@AmS\pages \gdef\ispage@AmS{F}%
\refset@AmS\book \refset@AmS\bookinfo
\refset@AmS\publ \refset@AmS\publaddr
\refset@AmS\editor \refset@AmS\talk
\refset@AmS\editors
\gdef\istoappear@AmS{F}%
\gdef\isinbook@AmS{F}%
\bgroup
\ignorespaces
}
% usage: \ref{citation} \keywords arguments ... \endref. We make sure
% we aren't still doing an \anno first.
\def\ref#1{%
\ifin@anno
\message{You forgot an \noexpand\endanno command,}
\message{but I forgive you this time.}
\endanno
\fi
\def\refi@AmS{T}%
\ifwasmember#1\of\ref@set
\def\refed@uci{T}%
\okmessage{[#1]}%
\else
\def\refed@uci{F}%
\okmessage{(#1)}%
\fi
\ifismember#1\of\ref@seen
\sanetell{multiply defined: [#1]}%
\else
\append#1\to\ref@seen
\fi
\def\refl@AmS{F}%
\def\\{\egroup\endref@AmS\gdef\refi@AmS{F}\ref@AmS}%
\ref@AmS
\gdef\@total{#1}%
\key \if T\refed@uci
\use@key\@total
\fi\egroup\setbox\wastebox@uci=\hbox\bgroup\ignorespaces
}
% End of a reference.
%
% Note that \endref@AmS is \let to be whichever \endref@xxx command
% is being used; default is \endref@JACM for JACM format.
%
% If we printed the reference, \endref@AmS will
% have set \bysamebox@AmS to be a box containing a box
% containing a rule and a period. This is unboxed if a subsequent
% reference which gets printed uses \bysame. Otherwise, we here
% save the \by field (if given) so that if a subsequent reference
% using \bysame gets used, we'll know who the author was, even though
% the reference which gave the author(s) wasn't printed. Tricky, huh?
\def\endref{%
\egroup\gdef\refl@AmS{T}%
\if T\refed@uci
\endref@AmS
\else
\if T\isby@AmS
\setbox\bysamebox@AmS=\box\bybox@AmS
\fi
\fi
\par
}
% define a \keyword. #1=keyword, #2=font to use, or {}
\def\refdef@AmS#1#2{%
\def#1{%
\egroup
\expandafter\gdef
\csname is\expandafter\eat@AmS\string#1@AmS\endcsname{T}%
\expandafter\setbox
\csname\expandafter\eat@AmS\string#1box@AmS\endcsname
=\hbox\bgroup#2\ignorespaces
}%
}
% define the keywords
\refdef@AmS\by\by@font \refdef@AmS\paper{}
\refdef@AmS\paperinfo{} \refdef@AmS\jour\book@font
\refdef@AmS\vol\book@font \refdef@AmS\issue{}
\refdef@AmS\mon{} \refdef@AmS\yr{}
\refdef@AmS\pages{} \refdef@AmS\talk{}
\refdef@AmS\book\book@font \refdef@AmS\bookinfo{}
\refdef@AmS\publ{} \refdef@AmS\publaddr{}
\refdef@AmS\finalinfo{} \refdef@AmS\editor{}
\refdef@AmS\jourinfo{} \refdef@AmS\key\cite@font
\refdef@AmS\editors{}
% These don't fit the normal pattern.
\def\bysame{\egroup\gdef\isbysame@AmS{T}\bgroup}
\def\page{\egroup\gdef\ispage@AmS{T}\setbox\pagesbox@AmS=\hbox\bgroup
\ignorespaces}
\def\toappear{\egroup\gdef\istoappear@AmS{T}\bgroup}
\def\inbook{\egroup\gdef\isinbook@AmS{T}\setbox\bookbox@AmS=\hbox\bgroup
\book@font\ignorespaces
}
% This is the font we normally print book and journal titles in, but we
% use \twelveit for IEEE format.
\let\book@font=\twelvesl
% Similarly, this is the font to use for the author's name(s).
% Optionally, the user can ask for the cite font instead (this is
% not necessarily related to use of the IEEE format).
\let\by@font=\twelverm
% As an option, the user can have the author's name(s) in caps-small-caps.
\def\AuthorsInCSC{%
\let\by@font=\elevencsc
\oktell{Authors in CSC mode}%
}
% Define some aliases for some of the above, for user convenience.
\let\pp=\pages
\let\pgs=\pages
\let\pg=\page
\let\p=\page
\let\journal=\jour
\let\volume=\vol
\let\author=\by
\let\authors=\by
\let\ieee@editors=\editors % Save it in case we use IEEE format
\let\editors=\editor % If using default JACM format
\let\other=\talk
\let\no=\issue
% Helpers to \endref@AmS, which speed things up a lot, and/or
% make the code more compact.
\def\a@comma{, } % Used in next routine. Predefined for speed of \let.
\def\setpunct@AmS{\let\prepunct@AmS=\a@comma}
\def\ppunbox@AmS#1{\prepunct@AmS\unhbox#1\unskip}
% Actually do some typesetting (finally). As mentioned above,
% \endref@AmS is called to print a reference if we want it. It
% is \let to be either \endref@JACM or \endref@IEEE (or possibly
% some other format in the future) depending on the desired
% format.
%
% For some reason, the ~'s don't see to tie things, so some
% \hbox's were introduced.
%
% There is unfortunately a lot of common code between the
% different formats. Here are some sections which were easy to
% pull out:
\def\endref@startup{%
% Test to see if there is anything in the wastebox
\setbox\wastebox@uci=\hbox{\unhbox\wastebox@uci\unskip}%
\ifdim\wd\wastebox@uci>\z@
\errmessage{Keyword omitted after \noexpand\ref}%
\fi
\let\prepunct@AmS=\empty
\vskip\parskip
\noindent \hangafter=\@ne
}
% This is the text printed for the JACM format for papers
% appearing in a book.
\def\appearing@in{Appearing in }
% Common code at the end of \endref@JACM and \endref@IEEE.
% The argument is the date routine to use.
\def\endref@finishup#1{%
\if T\istalk@AmS
\dimen@=\wd\talkbox@AmS
\ifdim\dimen@>\z@
\ppunbox@AmS\talkbox@AmS\setpunct@AmS
\fi
\fi
\if T\isbook@AmS
\ppunbox@AmS\bookbox@AmS \setpunct@AmS
\editor@ref
\fi
\if T\isinbook@AmS
\prepunct@AmS\appearing@in\unhbox\bookbox@AmS\unskip \setpunct@AmS
\editor@ref \gdef\isbook@AmS{T}%
\fi
\if T\isbookinfo@AmS
\ppunbox@AmS\bookinfobox@AmS\setpunct@AmS
\fi
\if T\using@IEEE
\if T\ispubladdr@AmS
\ppunbox@AmS\publaddrbox@AmS
\if T\ispubl@AmS \def\prepunct@AmS{: }\else\setpunct@AmS\fi
\fi
\if T\ispubl@AmS
\ppunbox@AmS\publbox@AmS\setpunct@AmS
\fi
\else
\if T\ispubl@AmS
\ppunbox@AmS\publbox@AmS\setpunct@AmS
\fi
\if T\ispubladdr@AmS
\ppunbox@AmS\publaddrbox@AmS\setpunct@AmS
\fi
\fi
\if T\isbook@AmS
\if T\isvol@AmS
\prepunct@AmS Vol.~\unhbox\volbox@AmS\unskip\setpunct@AmS
\fi
\if T\isyr@AmS
\ppunbox@AmS\yrbox@AmS\setpunct@AmS
\fi
\if T\istoappear@AmS
\ (to appear)\setpunct@AmS
\fi
\if T\ispages@AmS
\prepunct@AmS pp.~\unhbox\pagesbox@AmS\unskip\setpunct@AmS
\fi
\if T\ispage@AmS
\prepunct@AmS p.~\unhbox\pagesbox@AmS\unskip\setpunct@AmS
\fi
\fi
\if T\istalk@AmS
#1% This is the date routine to use.
\fi
\if T\isfinalinfo@AmS
\period\unhbox\finalinfobox@AmS
\else
\if T\refl@AmS .
\else ;
\fi
\fi
}
% Print editor(s) if and as appropriate.
\def\editor@ref{%
\if T\using@IEEE
\if T\iseditor@AmS
\ppunbox@AmS\editorbox@AmS, Ed.\setpunct@AmS
\fi
\if T\iseditors@AmS
\ppunbox@AmS\editorsbox@AmS, Eds.\setpunct@AmS
\fi
\else
\if T\iseditor@AmS
\ppunbox@AmS\editorbox@AmS\ (ed.)\setpunct@AmS
\fi
\fi
}
% This routine prints the date in the JACM format
\def\date@JACM{%
\if T\isyr@AmS
\/\ (%
\if T\ismon@AmS
\unhbox\monbox@AmS\unskip,
\fi
\unhbox\yrbox@AmS\unskip)\setpunct@AmS
\else
\if T\ismon@AmS
\ppunbox@AmS\monbox@AmS\setpunct@AmS
\fi
\fi
}
% This prints the date in the IEEE format.
\def\date@IEEE{%
\if T\isyr@AmS
\prepunct@AmS
\if T\ismon@AmS
\unhbox\monbox@AmS\unskip\a@comma
\fi
\unhbox\yrbox@AmS\unskip\setpunct@AmS
\else
\if T\ismon@AmS
\ppunbox@AmS\monbox@AmS\setpunct@AmS
\fi
\fi
}
% This version produces JACM format references.
\def\endref@JACM{%
\endref@startup
\if T\refi@AmS
\hbox to \key@size{\cite@font [\unhbox\keybox@AmS\unskip]\hfil}%
\hangindent=\key@size
\if T\isby@AmS
\unhcopy\bybox@AmS\unskip
\def\prepunct@AmS{\hskip7\p@ plus5\p@\relax}%
\setbox\z@=\hbox{\unhbox\bybox@AmS\unskip}%
\dimen@=\wd\z@ % We want \dimen0=max(\wd0, 2in)
\ifdim\dimen@>2in \dimen@=2in \fi
\setbox\bysamebox@AmS=\hbox{\hbox to\dimen@{\leaders\hrule\hfill.}}%
\else
\if T\isbysame@AmS
\unhcopy\bysamebox@AmS\unskip
\def\prepunct@AmS{\hskip7\p@ plus5\p@\relax}%
\fi
\fi
\fi
\if T\ispaper@AmS
\ppunbox@AmS\paperbox@AmS\def\prepunct@AmS{. }%
\fi
\if T\ispaperinfo@AmS
\ppunbox@AmS\paperinfobox@AmS\def\prepunct@AmS{. }%
\fi
\if T\isjour@AmS
\ppunbox@AmS\jourbox@AmS\setpunct@AmS
\editor@ref
\if T\isjourinfo@AmS
\ppunbox@AmS\jourinfobox@AmS\setpunct@AmS
\fi
\if T\isvol@AmS
\ \unhbox\volbox@AmS\unskip
\fi
\if T\isissue@AmS
\ppunbox@AmS\issuebox@AmS\setpunct@AmS
\fi
\date@JACM
\if T\istoappear@AmS
\ (to appear)\setpunct@AmS
\fi
\if T\ispages@AmS
\ppunbox@AmS\pagesbox@AmS\setpunct@AmS
\fi
\if T\ispage@AmS
\prepunct@AmS p.~\unhbox\pagesbox@AmS\unskip\setpunct@AmS
\fi
\fi
\endref@finishup\date@JACM
}
% This version produces IEEE format references.
\def\endref@IEEE{%
\endref@startup
\if T\refi@AmS
\hbox to \key@size{\cite@font [\unhbox\keybox@AmS\unskip]\hfil}%
\hangindent=\key@size
\if T\isby@AmS \unhcopy\bybox@AmS\unskip\setpunct@AmS
\setbox\z@=\hbox{\unhbox\bybox@AmS\unskip}%
\dimen@=\wd\z@ % We want \dimen0=max(\wd0, 2in)
\ifdim\dimen@>2in \dimen@=2in \fi
\setbox\bysamebox@AmS=\hbox{\hbox to\dimen@{\leaders\hrule\hfill}}%
\else
\if T\isbysame@AmS
\unhcopy\bysamebox@AmS\unskip\setpunct@AmS
\fi
\fi
\fi
\if T\ispaper@AmS
\prepunct@AmS``\unhbox\paperbox@AmS\unskip,''
\let\prepunct@AmS=\empty
\fi
\if T\ispaperinfo@AmS
\ppunbox@AmS\paperinfobox@AmS\def\prepunct@AmS{, }%
\fi
\if T\isjour@AmS
\ppunbox@AmS\jourbox@AmS\setpunct@AmS
\editor@ref
\if T\isjourinfo@AmS
\ppunbox@AmS\jourinfobox@AmS\setpunct@AmS
\fi
\if T\isvol@AmS
\prepunct@AmS vol.~\unhbox\volbox@AmS\unskip\setpunct@AmS
\fi
\if T\isissue@AmS
\prepunct@AmS no.~\unhbox\issuebox@AmS\unskip\setpunct@AmS
\fi
\if T\istoappear@AmS
\ (to appear)\setpunct@AmS
\fi
\if T\ispages@AmS
\prepunct@AmS pp.~\unhbox\pagesbox@AmS\unskip\setpunct@AmS
\fi
\if T\ispage@AmS
\prepunct@AmS p.~\unhbox\pagesbox@AmS\unskip\setpunct@AmS
\fi
\if T\ispubladdr@AmS
\ppunbox@AmS\publaddrbox@AmS
\if T\ispubl@AmS \def\prepunct@AmS{: }\else\setpunct@AmS\fi
\fi
\if T\ispubl@AmS
\ppunbox@AmS\publbox@AmS\setpunct@AmS
\fi
\let\ispubl@AmS=F\let\ispubladdr@AmS=F% For finishup routine
\date@IEEE
\fi
\endref@finishup\date@IEEE
}
% By default, we use JACM format references
\let\endref@AmS=\endref@JACM
% But it's possible to get the other format
\def\IEEE{%
\gdef\using@IEEE{T}% Now we're using IEEE format.
\let\editors=\ieee@editors
\let\endref@AmS=\endref@IEEE
\refdef@AmS\vol{}% Vol not printed in slanted any more.
\global\let\appearing@in=\empty % Don't say that in IEEE format.
\let\volume=\vol
\let\book@font=\twelveit % Book and journal titles in this font.
\oktell{IEEE Bibliography Style}%
}
% References Dump
\newwrite\dump@file
\catcode`\{=12 \catcode`\}=12 \catcode`\%=12 \catcode`\[=1 \catcode`\]=2
\def\ref@open[{]
\def\ref@close[}]
\def\ref@comment[%]
\catcode`\{=1 \catcode`\}=2 \catcode`\%=14 \catcode`\[=12 \catcode`\]=12
\def\refdump{%
\vfill\supereject
\begingroup
\content\reftitle
\tell{Dumping \reftitle\space to refdump.tex}%
\immediate\openout\dump@file=refdump
\immediate\write\dump@file{%
\noexpand\catcode`\noexpand\@=11 ^^J%
\noexpand\let\noexpand\content=\noexpand\eat@AmS^^J%
\noexpand\pageno=\the\pageno^^J%
\noexpand\def\noexpand\ref@set\ref@open\ref@comment
}%
\def\\##1{\immediate\write\dump@file{ \noexpand\\{##1}\ref@comment}}%
\ref@set
\immediate\write\dump@file{%
\ref@close^^J%
}%
\immediate\closeout\dump@file
\endgroup
}
%%%%%%%%%%%%%%%%%%%%
% OUTPUT CONTROL %
%%%%%%%%%%%%%%%%%%%%
% Control for informational messages. Default is \verbose mode.
\newif\iftell@all
\let\verbose=\tell@alltrue
\let\quiet=\tell@allfalse
\verbose
\def\oktell#1{\iftell@all\tell{#1}\fi}
\def\okmessage#1{\iftell@all\message{#1}\fi}
% Chapter macro parameters
\newcount\chapterno
\chapterno=\z@ % Number of current chapter
\newif\ifnumber@chapters
\number@chapterstrue % By default, number the chapters
\def\nochapternumbers{%
\number@chaptersfalse
\oktell{No Chapter Numbers mode}%
}
% Same thing for sections, subsections, etc
\newcount\sectno \sectno=\@ne
\newcount\subsectno \subsectno=\@ne
\newcount\subsubsectno \subsubsectno=\@ne
\newif\ifnumber@sections
\def\numbersections{%
\number@sectionstrue
\oktell{Section Numbers mode}%
}
%%%%%%%%%%%%%%%%%%%%%%%%%%%
% OUTPUT CONTROL MACROS %
%%%%%%%%%%%%%%%%%%%%%%%%%%%
% Center, left justify, right justify -- avoid exceeding margins
\def\centerline#1{\line{\hfill#1\hfill}}
\def\leftline#1{\line{#1\hfill}}
\def\rightline#1{\line{\hfill#1}}
\def\threepart#1#2#3{\line{\hskip\leftskip\rlap{#1}\hfill#2\hfill
\llap{#3}\hskip\rightskip}}
% End of the main body of the document
\let\enddiss=\bye
% Summary Information
\outer\def\showsummary{%
\begingroup
\def\note##1##2##3##4{%
\count@=##1
\advance\count@ by##3
\ifcase\count@
\message{No ##2s##4}\or
\message{1 ##2##4}\else
\message{\the\count@\space ##2s##4}\fi
}%
\note\fignumber{figure}{-1}{,}%
\note\tablenumber{table}{-1}{,}%
\note\note@count{footnote}{-1}{,}%
\cardinality\ref@set\to\count@
\note\count@{citation}{0}{.}%
\endgroup
}
% Real version of ragged right margins
\def\raggedright{%
\rightskip=\z@ plus 2em
\oktell{Raggedright mode}%
}
% Disallow hyphenation -- a very dangerous thing
\def\nohyphens{%
\hyphenpenalty=\@M\tolerance=500\pretolerance=\@M
\oktell{Nohyphens mode}%
}
% Allow capitalized words to be hyphenated
\def\hyphenall{%
\uchyph=\@ne
\oktell{Hyphenating all words}%
}
% Handle a long quotation in a standard way
\def\bigquote#1\endbigquote{%
\par
\vskip \baselineskip \vskip -\parskip
{ \advance\rightskip by30\p@
\advance\leftskip by30\p@
\smallertype
\singlespace
\let\\=\newline
\noindent\llap{``}\ignorespaces#1\unskip''\par
}% End of singlespacing and special indentation
\vskip \baselineskip \vskip -\parskip
}
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% CHAPTERS, SECTIONS, FIGURES, TABLES %
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% What to do at the beginning of a chapter
\def\chapter#1\endchapter{
\chapter@base #1\endchapter
\oktell{Chapter \number\chapterno: #1}
\content{Chapter \number\chapterno: #1}
}
% This boolean controls whether chapters are made to start only on
% odd pages.
\newif\ifoddpages
\oddpagesfalse
\def\twosided{% This is the ``official'' command
\oddpagestrue
\oktell{Twosided mode}%
}
% The guts of the \chapter command. \chapter==\chapter@base when
% in \articlestyle.
\def\chapter@base#1\endchapter{
\par
\clearpage % Clean up from prev chapter
\ifoddpages % Make sure start on even page.
\ifodd\pageno \relax \else \null\vfill\eject \fi
\fi
\pageno@foot % Page #ing special for chap pages
\advance\chapterno by\@ne
\ifnumber@chapters
\centerline{\chap@font CHAPTER \number\chapterno}% Do heading
\fi
\sectno=\z@
\subsectno=\z@
\subsubsectno=\z@
{\let\\=\cr \tabskip=\z@ \chap@font % Center the chapter title
\halign to\hsize{\centerline{\ignorespaces##\unskip}\cr#1\cr}
}
\nobreak % Shouldn't happen anyway
\vskip 1.0in minus 0.15in
}
% What to do at the beginning of a section
\outer\def\section{\dosection}
\def\dosection#1{%
\skip@=\lastskip % \par resets \lastskip, apparently
\par
% This junk trys to provide consistent spacing
\dimen@=\baselineskip
\ifdim\skip@<\dimen@
\ifdim\skip@=\z@
\penalty-200
\fi
\vskip \dimen@ plus .5\baselineskip
\fi
\ifnumber@sections
\advance\sectno by\@ne
\subsectno=\z@
\subsubsectno=\z@
\leftline{\sec@font\number\sectno. #1}
\else
\leftline{\sec@font#1}
\fi
\subcontent{#1}
\sanetell{ Section: #1}
\nobreak
\vskip \z@ plus .15\baselineskip
\vskip -\parskip
}
% And for sub-sections
\outer\def\subsection{\dosubsection}
\def\dosubsection#1{%
\skip@=\lastskip
\par
\dimen@=.6\baselineskip
\ifdim\skip@<\dimen@
\ifdim\skip@=\z@
\penalty-100
\fi
\vskip \dimen@ plus .3\baselineskip
\fi
\ifnumber@sections
\advance\subsectno by\@ne
\subsubsectno=\z@
\leftline{\subsec@font\number\sectno.\number\subsectno. #1}
\else
\leftline{\subsec@font#1}
\fi
\subsubcontent{#1}
\sanetell{ \\Subsection: #1}
\nobreak
\vskip \z@ plus .1\baselineskip
\vskip -\parskip
}
% And for sub-sub-sections
\outer\def\subsubsection{\dosubsubsection}
\def\dosubsubsection#1{%
\skip@=\lastskip
\par
\dimen@=.5\baselineskip
\ifdim\skip@<\dimen@
\ifdim\skip@=\z@
\penalty-50
\fi
\vskip \dimen@ plus .3\baselineskip
\fi
\ifnumber@sections
\advance\subsubsectno by\@ne
\leftline{\subsubsec@font\number\sectno.\number\subsectno
.\number\subsubsectno. #1}
\else
\leftline{\subsubsec@font#1}
\fi
\subsubsubcontent{#1}
\sanetell{ \\\\Subsubsection: #1}
\nobreak
\vskip -\parskip
}
% This is an alternate definition for plain TeX's \@ins,
% omitting the \par. It is for use during \figure etc. Reason:
% If you use \figure right after \section, it would otherwise
% become a legal place for a page break.
\def\@ins@uci{\begingroup\setbox\z@\vbox\bgroup}
% This is \endinsert from plain.tex, but \midinsert's are not converted
% to \topinsert's, since that can lead to figures getting out of order.
% This can lead to excessive blank space at the bottom of the page, but
% that's life. Makes use of \keep...\endkeep type stuff.
\def\endinsert{\egroup % finish the \vbox
\if@mid \dimen@\ht\z@ \advance\dimen@\dp\z@
\advance\dimen@12\p@
\vskip\z@ plus\dimen@
\penalty\z@
\vskip\z@ plus-\dimen@
\bigskip\box\z@\bigbreak
\else\insert\topins{\penalty100 % floating insertion
\splittopskip\z@skip
\splitmaxdepth\maxdimen \floatingpenalty\z@
\ifp@ge \dimen@\dp\z@
\vbox to\vsize{\unvbox\z@\kern-\dimen@}% depth is zero
\else \box\z@\nobreak\bigskip\fi}\fi\endgroup}
% This macro provides rudamentary support for figures. The
% argument to \figure is the name of the file containing the tpic (or whatever)
% output. The second argument is the caption for the picture.
% As usual, TeX's delayed paging and midinserting causes expansion-timing
% problems which have to be kludged around.
\newif\iftopfigs \topfigstrue
\def\domidfigs{%
\topfigsfalse
\oktell{Midfigs mode}%
}
% Counters for figures/diagrams/examples and tables
\newcount\fignumber \fignumber=\@ne
\newcount\tablenumber \tablenumber=\@ne
% Helper for \figure, \example, and \diagram. Define \lastfigure and
% \this@insert, increment the figure number for next time, and make sure
% the figures list file is open for writing.
% #1=the caption, to be written to the figures list file
\def\advance@figno#1{%
\xdef\lastfigure{\the\fignumber}% Remember the current figure number
\begingroup\no@cites
\let\\=\space
\xdef\this@insert{\write\noexpand\fig@file{\noexpand\noexpand
\noexpand\listfig{\lastfigure}{#1}%
{\noexpand\number\noexpand\pageno}%
}%
}%
\endgroup
\global\advance\fignumber by\@ne
\iffig@closed % Open figures file if not already
\immediate\openout\fig@file=\figtitle
\global\fig@closedfalse
\fi
}
% Bump the table number after defining \lasttable. Prepare \this@insert.
% Define \table@caption.
\def\advance@tablenumber#1{%
\xdef\lasttable{\the\tablenumber}% Remember the current figure number
\begingroup \no@cites \let\\=\space
\xdef\this@insert{\write\noexpand\tab@file{\noexpand\noexpand
\noexpand\listfig{\lasttable}{#1}%
{\noexpand\number\noexpand\pageno}%
}%
}%
\endgroup
\global\advance\tablenumber by\@ne
\gdef\table@caption{#1}%
}
\newif\ifpage@figs \page@figsfalse
% Special mode to put figures/diagrams/examples on separate pages
\def\pagefigs{%
\oktell{Page Figures mode}%
\page@figstrue
}
% Usage: \figure{filename}{caption with \\'s}
\def\figure#1#2{%
\begingroup % Hide anything that crazy user does!
\advance@figno{#2}%
% Now do mid or top insert as appropriate
\let\@ins=\@ins@uci
\ifpage@figs
\shipout\vbox to\vsize\bgroup
{\smallertype\rm\input #1\relax\centerline{\box\graph}}%
\vfill
\centerline{Figure \lastfigure}\this@insert
\egroup
\else \iftopfigs \topinsert \else \midinsert \fi
\hrule
\vskip .5\baselineskip
{\smallertype\rm\input #1\relax\centerline{\box\graph}}%
\vskip .5\baselineskip plus .5\baselineskip
\centerline{\twelvebf Figure \lastfigure}%
\this@insert
\let\\=\cr \tabskip=\z@
\halign to\hsize{\centerline{\ignorespaces##\unskip}\cr#2\cr}%
\vskip2\p@
\hrule
\endinsert
\fi
\endgroup
}
% Allow user to specify arbitrary diagrams. The arguments are:
% #1=name of the file containing the commands to form the diagram,
% #2=caption for the figure, possibly containing \\'s.
\def\diagram#1#2{%
\begingroup
\advance@figno{#2}%
% Do mid or top insert as appropriate
\let\@ins=\@ins@uci
\ifpage@figs
\shipout\vbox to\vsize\bgroup
{\smallertype\rm\input #1\relax}%
\vfill
\centerline{\twelverm Figure \lastfigure}\this@insert
\egroup
\else \iftopfigs \topinsert \else \midinsert \fi
\hrule
\vskip .5\baselineskip
{\smallertype\rm\input #1\relax}%
\vskip .5\baselineskip plus .5\baselineskip
\centerline{\twelvebf Figure \lastfigure}%
\this@insert
\let\\=\cr \tabskip=\z@
\halign to \hsize{\centerline{\ignorespaces##\unskip}\cr#2\cr}%
\vskip2\p@
\hrule
\endinsert
\fi
\endgroup
}
% Allow user to include verbatim examples from files. The arguments are:
% #1=name of the file containing the text of the example,
% #2=caption for the figure, possibly containing \\'s.
\def\example#1#2{%
\begingroup
\advance@figno{#2}%
% Do mid or top insert as appropriate
\let\@ins=\@ins@uci
\ifpage@figs
\shipout\vbox to\vsize\bgroup
\vbox{\smallertype\singlespace\verbfile{#1}}%
\vfill
\centerline{\twelverm Figure \lastfigure}\this@insert
\egroup
\else \iftopfigs \topinsert \else \midinsert \fi
\hrule
\vskip .5\baselineskip
\vbox{\smallertype\singlespace\verbfile{#1}}%
\vskip .5\baselineskip plus .5\baselineskip
\centerline{\twelvebf Figure \lastfigure}%
\this@insert
\let\\=\cr \tabskip=\z@
\halign to \hsize{\centerline{\ignorespaces##\unskip}\cr#2\cr}%
\vskip2\p@
\hrule
\endinsert
\fi
\endgroup
}
% Similar thing for tables
% usage: \table{caption} ...text... \endtable
\def\table#1{%
\begingroup % Hide user zingers
\advance@tablenumber{#1}%
\setbox\z@=\vbox\bgroup
}
% End of the table body specification.
\def\endtable{%
\egroup % End the definition of \box0.
% Now do top or mid insert
\let\@ins=\@ins@uci
\iftab@closed % Open output file if necessary
\immediate\openout\tab@file=\tabtitle
\global\tab@closedfalse
\fi
\ifpage@figs
\shipout\vbox to\vsize\bgroup
\box\z@
\vfill
\centerline{\twelverm Table \lasttable}\this@insert
\egroup
\else \iftopfigs \topinsert \else \midinsert \fi
\hrule
\vskip .5\baselineskip
\box\z@ % Insert the material here.
\vskip .5\baselineskip plus .5\baselineskip
\centerline{\twelvebf Table \lasttable}%
\this@insert
\let\\=\cr \tabskip=\z@
\halign to\hsize{\centerline{\ignorespaces##\unskip}\cr\table@caption
\cr}%
\vskip2\p@
\hrule
\endinsert
\fi
\endgroup
}
% End of the table body specification for a full-page table.
\def\endtablepage{%
\egroup % End the definition of \box0.
% Now do top or mid insert
\let\@ins=\@ins@uci
\iftab@closed % Open output file if necessary
\immediate\openout\tab@file=\tabtitle
\global\tab@closedfalse
\fi
\ifpage@figs
\shipout\vbox to\vsize\bgroup
\box\z@
\vfill
\centerline{\twelverm Table \lasttable}\this@insert
\egroup
\else \pageinsert
\hrule
\vskip .5\baselineskip
\box\z@ % Insert the material here.
\vskip .5\baselineskip plus .5\baselineskip
\centerline{\twelvebf Table \lasttable}%
\this@insert
\let\\=\cr \tabskip=\z@
\halign to\hsize{\centerline{\ignorespaces##\unskip}\cr\table@caption
\cr}%
\vskip2\p@
\hrule
\endinsert
\fi
\endgroup
}
% Environment for report generation -- use only at the beginning!
% Since sections are the biggest division, the table of contents
% stuff is redefined, and chapter numbering is turned off so that
% \chapter can be used for the first-page title. The title page
% gets no page number (page # 0). The user can get to the
% normal chapter font as \titlefont, and the section font as
% \authorfont.
\def\articlestyle{%
\nochapternumbers
\let\subsubsubcontent=\subsubcontent
\let\subsubcontent=\subcontent
\let\subcontent=\content
\let\chapter=\chapter@base
\pageno=\z@
\let\titlefont=\chap@font
\let\authorfont=\sec@font
\oktell{Articlestyle mode}%
}
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% PAGE NUMBERING and OUTPUT ROUTINES %
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% This macro produces a blank, numbered page of output
\def\blankpage{\pageinsert \null\vfill \endinsert}
% This defintion of \folio differs from Plain's in that (a) page
% numbers are printed in 12pt, and (b) roman numeral ones are
% printed in italics. It makes use of a trick, that
% \romannumeral0 produces no output, which we need for title
% pages and things, so we make their page numbers be 0.
\def\folio{\ifnum\pageno>\z@
{\twelverm\number\pageno}\else
{\twelveit\romannumeral-\pageno}\fi
}
% Permanent definitions of macros which get switched in and out
% with \let's. Do not change any of these !!!
\def\uci@headpage{\hfill\folio}
\def\uci@footpage{\hfill\folio\hfill}
\headline={\uci@headline}
\footline={\uci@footline}
% If this is used as the footline, it causes a page number to be
% printed, but with the side-effect of making the headline blank
% and the footline a page number again. This is used on pages
% like the first of a chapter.
\def\no@foot{%
\uci@footpage
\global\let\uci@footline=\hfil
\global\let\uci@headline=\uci@headpage
}
% This macro causes the page number to be at the bottom of the current
% page, and after it has been used there once, it moves to the
% top right of each page. It also sets \dimen\topins=0pt so that
% any material \topinsert'd on these pages will get carried over
% to subsequent pages.
\def\pageno@foot{%
\dimen\topins=\z@
\let\uci@headline=\hfil
\let\uci@footline=\no@foot
}
% Executing this causes page numbers to be at the bottom only, as
% with the plain TeX format.
\def\plain@page@numbers{%
\let\uci@headline=\hfil % Initial values similar to plain's
\let\uci@footline=\uci@footpage
}
% Change plain's \makeheadline and \makefootline to position page
% numbers as required.
\def\makeheadline{%
\vbox to\z@{\vskip-22.65\p@
\line{\vbox to8.5\p@{}\the\headline}\vss}\nointerlineskip
}
\def\makefootline{\baselineskip=1.6cm\line{\the\footline}}
% Define an output routine which will restore \dimen\topins
% after \chapter, \references, etc, title pages, which have
% \dimen\topins=0pt
\def\dissoutput{\shipout\vbox{\makeheadline\pagebody\makefootline}%
\advancepageno \global\dimen\topins=\vsize
\ifnum\outputpenalty>-\@MM \else\dosupereject\fi
}
\let\output@AmS=\dissoutput
\dimen\topins=\vsize % Don't insert more than will fit on one page
% Output Routines: We adjust the \raggedbottom command of plain
% TeX so that the extra space is no more than 1in, and so that
% the space is put above footnotes instead of below. NOTE: Since
% we put a \vfil below the page contents, the topskip glue will
% never actually be stretched. Its stretchability is just to
% let TeX know about the raggedness in computing when to make a
% page break. Since it's 1in, the \vfil will never be stretched to
% more than that amount.
\def\raggedbottom{\topskip=\normal@topskip plus1in \r@ggedbottomtrue
\oktell{Ragged bottom mode}}
\def\normalbottom{\topskip=\normal@topskip\r@ggedbottomfalse
\oktell{Normal bottom mode}}
\def\pagecontents{%
\ifvoid\topins\else\unvbox\topins\fi
\dimen@=\dp\@cclv \unvbox\@cclv % open up \box255
\ifr@ggedbottom \kern-\dimen@ \vfil\fi
\ifvoid\footins \else % footnote info is present
\vskip\skip\footins
\footnoterule
\unvbox\footins
\fi
}
%%%%%%%%%%%%%%%%%%%%
% INITIALIZATION %
%%%%%%%%%%%%%%%%%%%%
\font@no=0 % Default font=\rm,
\twelvepoint % point size,
\doublespace % and spacing
\plain@page@numbers % Page nos like plain's
% Note that normally in AmSTeX, the @ character may not be used.
% But in the dissertation style, @ may be used as a normal character,
% As it can in plain TeX.
\catcode`\@=12
% Eat any further \documentstyle commands
\def\documentstyle#1{}
% This prints out our welcome message, and it computes the time
% and date string once per run, which saves time if they're used
% more than once. Since \catcode`@=12 at the time this is
% executed, it can't contain any @-type macros.
\everyjob={%
\begingroup
\xdef\today{%
\ifcase\month
\the\month\or
January\or
February\or
March\or
April\or
May\or
June\or
July\or
August\or
September\or
October\or
November\or
December\else
\the\month
\fi\space\the\day, \the\year
}%
\count0=\time
\count1=\count0
\divide\count0by60
\count2=\count0
\multiply\count0by60
\advance\count1by-\count0
\ifnum\count2>11
\ifnum\count2>12 \advance\count2by-12\fi
\def\ampm{PM}%
\else
\ifnum\count2=0 \advance\count2by12\fi
\def\ampm{AM}%
\fi
\xdef\daytime{%
\ifnum\count2<10 0\fi \the\count2:%
\ifnum\count1<10 0\fi \the\count1
\ampm
}%
\endgroup
\tell{AmSTeX Dissertation Style, version \version}%
}
\edef\temp@uci{\the\everyjob}
\temp@uci