home *** CD-ROM | disk | FTP | other *** search
/ Meeting Pearls 3 / Meeting_Pearls_III.iso / Pearls / texmf / inputs / latex / unpacked / letter.dtx (.txt) < prev    next >
LaTeX Document  |  1995-06-21  |  62KB  |  1,640 lines

  1. % \iffalse meta-comment
  2. % Copyright 1993-1995 the LaTeX3 project and any individual authors
  3. % listed elsewhere in this file.  All rights reserved.
  4. % For further copyright information see the file legal.txt, and any
  5. % other copyright notices in this file.
  6. % This file is part of the LaTeX2e system.
  7. % ----------------------------------------
  8. %   This system is distributed in the hope that it will be useful,
  9. %   but WITHOUT ANY WARRANTY; without even the implied warranty of
  10. %   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
  11. %   For error reports concerning UNCHANGED versions of this file no more
  12. %   than one year old, see bugs.txt.
  13. %   Please do not request updates from us directly.  Primary
  14. %   distribution is through the CTAN archives.
  15. % IMPORTANT COPYRIGHT NOTICE:
  16. % You are NOT ALLOWED to distribute this file alone.
  17. % You are allowed to distribute this file under the condition that it is
  18. % distributed together with all the files listed in manifest.txt.
  19. % If you receive only some of these files from someone, complain!
  20. % Permission is granted to copy this file to another file with a clearly
  21. % different name and to customize the declarations in that copy to serve
  22. % the needs of your installation, provided that you comply with
  23. % the conditions in the file legal.txt.
  24. % However, NO PERMISSION is granted to produce or to distribute a
  25. % modified version of this file under its original name.
  26. % You are NOT ALLOWED to change this file.
  27. % \fi
  28. % \CheckSum{984}
  29. %% \CharacterTable
  30. %%  {Upper-case    \A\B\C\D\E\F\G\H\I\J\K\L\M\N\O\P\Q\R\S\T\U\V\W\X\Y\Z
  31. %%   Lower-case    \a\b\c\d\e\f\g\h\i\j\k\l\m\n\o\p\q\r\s\t\u\v\w\x\y\z
  32. %%   Digits        \0\1\2\3\4\5\6\7\8\9
  33. %%   Exclamation   \!     Double quote  \"     Hash (number) \#
  34. %%   Dollar        \$     Percent       \%     Ampersand     \&
  35. %%   Acute accent  \'     Left paren    \(     Right paren   \)
  36. %%   Asterisk      \*     Plus          \+     Comma         \,
  37. %%   Minus         \-     Point         \.     Solidus       \/
  38. %%   Colon         \:     Semicolon     \;     Less than     \<
  39. %%   Equals        \=     Greater than  \>     Question mark \?
  40. %%   Commercial at \@     Left bracket  \[     Backslash     \\
  41. %%   Right bracket \]     Circumflex    \^     Underscore    \_
  42. %%   Grave accent  \`     Left brace    \{     Vertical bar  \|
  43. %%   Right brace   \}     Tilde         \~}
  44. % \iffalse
  45. % \section{Identification}
  46. %    This document class can only be used with \LaTeXe, so we make
  47. %    sure that an appropriate message is displayed when another \TeX{}
  48. %    format is used.
  49. %    \begin{macrocode}
  50. %<+letter>\NeedsTeXFormat{LaTeX2e}[1994/12/01]
  51. %    \end{macrocode}
  52. %    Announce the Class name and its version.
  53. %    \begin{macrocode}
  54. %<+letter>\ProvidesClass{letter}
  55. %<*driver>
  56.        \ProvidesFile{letter.drv}
  57. %</driver>
  58.               [1995/05/25 v1.2s
  59. %<+letter>               Standard LaTeX document class]
  60. %    \end{macrocode}
  61. % \section{The documentation driver file}
  62. %    We have our own document class to format the \LaTeXe
  63. %    documentation.
  64. % \fi
  65. % \changes{v1.0.6}{1993/12/07}{Use class ltxdoc document class}
  66. % \iffalse
  67. %    \begin{macrocode}
  68. %<*driver>
  69. \documentclass{ltxdoc}
  70. %    \end{macrocode}
  71. %    We don't want everything to appear in the index.
  72. %    \begin{macrocode}
  73. \DoNotIndex{\@Alph,\@alph,\@arabic,\@badmath}
  74. \DoNotIndex{\@centercr}
  75. \DoNotIndex{\@empty,\@ignoretrue}
  76. \DoNotIndex{\@ixpt}
  77. \DoNotIndex{\@M,\@minus,\@ne,\@plus}
  78. \DoNotIndex{\\,\addtolength}
  79. \DoNotIndex{\advance}
  80. \DoNotIndex{\ast,\begin,\begingroup,\bfseries,\bgroup,\box}
  81. \DoNotIndex{\bullet}
  82. \DoNotIndex{\cdot,\cr,\day,\DeclareOption}
  83. \DoNotIndex{\def,\DocInput,\documentclass}
  84. \DoNotIndex{\DoNotIndex,\egroup,\ifx,\else,\fi,\endtrivlist}
  85. \DoNotIndex{\EnableCrossrefs,\end,\end@dblfloat,\end@float,\endgroup}
  86. \DoNotIndex{\endlist,\everycr,\ExecuteOptions}
  87. \DoNotIndex{\filedate,\filename,\fileversion}
  88. \DoNotIndex{\global,\halign,\hangindent,\hbox,\hfil,\hfill,\hrule}
  89. \DoNotIndex{\hsize,\hskip,\hspace,\hss,\ifcase,\or,\fi}
  90. \DoNotIndex{\ifvmode,\fi,\ifnum,\fi,\input}
  91. \DoNotIndex{\kern,\leavevmode,\let,\leftmark}
  92. \DoNotIndex{\list,\llap,\long,\m@ne,\m@th,\mark}
  93. \DoNotIndex{\month,\newcommand,\newcounter,\newenvironment}
  94. \DoNotIndex{\NeedsTeXFormat,\newdimen}
  95. \DoNotIndex{\newpage,\nobreak,\noindent,\number}
  96. \DoNotIndex{\p@}
  97. \DoNotIndex{\pagestyle,\par}
  98. \DoNotIndex{\penalty,\PrintChanges,\PrintIndex,\ProcessOptions}
  99. \DoNotIndex{\protect,\ProvidesClass,\raggedbottom,\raggedright}
  100. \DoNotIndex{\refstepcounter,\relax,\renewcommand,\reset@font}
  101. \DoNotIndex{\rightmargin,\rlap,\rmfamily}
  102. \DoNotIndex{\setbox,\setcounter,\setlength}
  103. \DoNotIndex{\skip,\slshape,\space}
  104. \DoNotIndex{\trivlist,\typeout,\tw@}
  105. \DoNotIndex{\vskip,\vspace,\year,\z@}
  106. \CodelineNumbered
  107. \CodelineIndex
  108. \EnableCrossrefs
  109. \RecordChanges
  110. %    \end{macrocode}
  111. %    We use so many \file{docstrip} modules that we set the
  112. %    \texttt{StandardModuleDepth} counter to 1.
  113. %    \begin{macrocode}
  114. \setcounter{StandardModuleDepth}{1}
  115. %    \end{macrocode}
  116. %    The following command retrieves the date and version information
  117. %    from the file.
  118. %    \begin{macrocode}
  119. \GetFileInfo{letter.drv}
  120. %    \end{macrocode}
  121. %    Some commonly used abbreviations
  122. %    \begin{macrocode}
  123. \newcommand*{\Lopt}[1]{\textsf {#1}}
  124. \newcommand*{\file}[1]{\texttt {#1}}
  125. \newcommand*{\Lcount}[1]{\textsl {\small#1}}
  126. \newcommand*{\pstyle}[1]{\textsl {#1}}
  127. %    \end{macrocode}
  128. %    We also want the full details.
  129. %    \begin{macrocode}
  130. \begin{document}
  131. \DocInput{letter.dtx}
  132. \PrintIndex
  133. % ^^A\PrintChanges
  134. \end{document}
  135. %</driver>
  136. %    \end{macrocode}
  137. % \fi
  138. % \changes{v1.1}{1993/12/18}{Changes to make it work with
  139. %    compatibility mode.}
  140. % \changes{v1.1a}{1993/12/19}{Removed float parms}
  141. % \changes{v1.1c}{1994/01/17}{Moved definition of \cs{@textop} to
  142. %    initialization section, to counteract setting of \cs{@texttop} in
  143. %    \cs{raggedbottom}.}
  144. % \changes{v1.1d}{1994/01/20}{Corrected margins: Now computed from
  145. %    \cs{paperwidth} and \cs{textwidth}, so that the text is
  146. %    horizontally centered.}
  147. % \changes{v1.1e}{1994/02/03}{Corrected checksum}
  148. % \changes{v1.2a}{1994/02/12}{Removed onecolumn and twocolumn options.}
  149. % \changes{v1.2a}{1994/02/12}{Changed label producing commands in .aux
  150. %    file.}
  151. % \changes{v1.2b}{1994/02/28}{Moved driver further up.}
  152. % \changes{v1.2c}{1994/03/08}{Always write .aux file.}
  153. % \changes{v1.2f}{1994/04/29}{Use LaTeX instead of LaTeX2e in messages}
  154. % \changes{v1.2f}{1994/04/29}{Removed \cs{typeout} message}
  155. % \changes{v1.2g}{1994/05/01}{Removed the use of \cs{fileversion}
  156. %    c.s.}
  157. % \changes{v1.2j}{1994/06/01}{Corrected driver code.}
  158. % \changes{v1.2k}{1994/06/17}{Various documentation enhancements}
  159. % \changes{v1.2p}{1994/12/11}{Use \cs{newcommand*} to define
  160. %    user-level commands that take an argument}
  161. % \changes{v1.2q}{1995/05/17}{cleaned up \cs{changes entries}}
  162. % \changes{v1.2q}{1995/05/18}{replaced \cs{hbox to} by \cs{hb@xt@}}
  163. % \changes{v1.2r}{1995/05/23}{removed a superfluous brace}
  164. % \iffalse
  165. % Copyright (C) 1994 LaTeX3 project, Frank Mittelbach
  166. % and Rainer Sch\"opf, all rights reserved.
  167. % \fi
  168. % \author{Leslie Lamport and Frank Mittelbach and Rainer Sch\"opf}
  169. % \title{Standard Letter Document Class for \LaTeX{} version 2e}
  170. % \maketitle
  171. % \tableofcontents
  172. % \StopEventually
  173. % \section{Initial Code}
  174. %    In this part we define a few commands that are used later on.
  175. % \begin{macro}{\@ptsize}
  176. %    This control sequence is used to store the second digit of the
  177. %    pointsize we are typesetting in. So, normally, it's value is one
  178. %    of 0, 1 or 2.
  179. %    \begin{macrocode}
  180. %<*letter>
  181. \newcommand\@ptsize{}
  182. %    \end{macrocode}
  183. % \end{macro}
  184. % \subsection{Setting Paper Sizes}
  185. %    The variables |\paperwidth| and |\paperheight| should reflect the
  186. %    physical paper size after trimming. For desk printer output this
  187. %    is usually the real paper size since there is no post-processing.
  188. % \changes{v1.0a}{1993/12/14}{Corrected typo, A4 is not 279 mm high}
  189. %    \begin{macrocode}
  190. \DeclareOption{a4paper}
  191.    {\setlength\paperheight {297mm}%
  192.     \setlength\paperwidth  {210mm}}
  193. \DeclareOption{a5paper}
  194.    {\setlength\paperheight {210mm}%
  195.     \setlength\paperwidth  {148mm}}
  196. \DeclareOption{b5paper}
  197.    {\setlength\paperheight {250mm}%
  198.     \setlength\paperwidth  {176mm}}
  199. \DeclareOption{letterpaper}
  200.    {\setlength\paperheight {11in}%
  201.     \setlength\paperwidth  {8.5in}}
  202. \DeclareOption{legalpaper}
  203.    {\setlength\paperheight {14in}%
  204.     \setlength\paperwidth  {8.5in}}
  205. \DeclareOption{executivepaper}
  206.    {\setlength\paperheight {10.5in}%
  207.     \setlength\paperwidth  {7.25in}}
  208. %    \end{macrocode}
  209. % \changes{v1.2o}{1994/08/26}{Added the option \textsf{landscape}}
  210. %    The option \Lopt{landscape} switches the values of |\paperheight|
  211. %    and |\paperwidth|, assuming the dimensions wer given for portrait
  212. %    paper.
  213. %    \begin{macrocode}
  214. \DeclareOption{landscape}
  215.    {\setlength\@tempdima   {\paperheight}%
  216.     \setlength\paperheight {\paperwidth}%
  217.     \setlength\paperwidth  {\@tempdima}}
  218. %    \end{macrocode}
  219. % \subsection{Choosing the type size}
  220. %    The type size options are handled by defining |\@ptsize| to
  221. %    contain the last digit of the size in question and branching on
  222. %    |\ifcase| statements. This is done for historical reasons to stay
  223. %    compatible with other packages that use the |\@ptsize| variable
  224. %    to select special actions. It makes the declarations of size
  225. %    options less than 10pt difficult, although one can probably use
  226. %    \texttt{9} and \texttt{8} assuming that a class wont define both
  227. %    \Lopt{8pt} and \Lopt{18pt} options.
  228. %    \begin{macrocode}
  229. \DeclareOption{10pt}{\renewcommand\@ptsize{0}}
  230. \DeclareOption{11pt}{\renewcommand\@ptsize{1}}
  231. \DeclareOption{12pt}{\renewcommand\@ptsize{2}}
  232. %    \end{macrocode}
  233. %  \subsection{Two-side or one-side printing}
  234. %    Two-sided printing was not supported in the \LaTeX~2.09 version
  235. %    of this document class.
  236. % \changes{v1.2e}{1994/04/28}{Added oneside option and twoside option
  237. %    in native mode}
  238. %    \begin{macrocode}
  239. \if@compatibility
  240.   \DeclareOption{twoside}{\@latexerr{No `twoside' layout for letters}%
  241.                                    \@eha}
  242. \else
  243.   \DeclareOption{twoside}{\@twosidetrue  \@mparswitchtrue}
  244. %    \end{macrocode}
  245. %    \begin{macrocode}
  246. \DeclareOption{oneside}{\@twosidefalse \@mparswitchfalse}
  247. %    \end{macrocode}
  248. %  \subsection{Draft option}
  249. %    If the user requests \Lopt{draft} we show any overfull boxes.
  250. %    We could probably add some more interesting stuff to this option.
  251. %    \begin{macrocode}
  252. \DeclareOption{draft}{\setlength\overfullrule{5pt}}
  253. \DeclareOption{final}{\setlength\overfullrule{0pt}}
  254. %    \end{macrocode}
  255. %  \subsection{Equation numbering on the left}
  256. %    The option \Lopt{leqno} can be used to get the equation numbers
  257. %    on the left side of the equation.
  258. % \changes{v1.1c}{1994/01/17}{Option leqno now read from
  259. %    \file{leqno.clo}.}
  260. %    \begin{macrocode}
  261. \DeclareOption{leqno}{\input{leqno.clo}}
  262. %    \end{macrocode}
  263. %  \subsection{Flush left displays}
  264. %    The option \Lopt{fleqn} redefines the displayed math environments
  265. %    in such a way that they come out flush left, with an indentation
  266. %    of |\mathindent| from the prevailing left margin.
  267. % \changes{v1.1}{1993/12/18}{Corrected typo in \cs{renewcommand},
  268. %    doubled hash marks.}
  269. % \changes{v1.1c}{1994/01/17}{Option fleqn now read from
  270. %    \file{fleqn.clo}.}
  271. %    \begin{macrocode}
  272. \DeclareOption{fleqn}{\input{fleqn.clo}}
  273. %    \end{macrocode}
  274. % \section{Executing Options}
  275. %    Here we execute the default options to initialize certain
  276. %    variables.
  277. % \changes{v1.2e}{1994/04/28}{Added execution of `oneside' option}
  278. %    \begin{macrocode}
  279. \ExecuteOptions{letterpaper,10pt,oneside,onecolumn,final}
  280. %    \end{macrocode}
  281. %    The |\ProcessOptions| command causes the execution of the code
  282. %    for every option \Lopt{foo} which is declared and for which the
  283. %    user typed the \Lopt{foo} option in his |\documentclass| command.
  284. %    For every option \Lopt{bar} he typed, which is not declared, the
  285. %    option is assumed to be a global option.  All options will be
  286. %    passed as document options to any |\usepackage| command in the
  287. %    document preamble.
  288. %    \begin{macrocode}
  289. \ProcessOptions
  290. %    \end{macrocode}
  291. %    Now that all the options have been executed we can load the
  292. %    chosen class option file that contains all size dependant code.
  293. %    \begin{macrocode}
  294. \input{size1\@ptsize.clo}
  295. %    \end{macrocode}
  296. %  \section{Loading Packages}
  297. %  The standard class files do not load additional packages.
  298. % \section{Document Layout}
  299. % \label{sec:maincode}
  300. %  In this section we are finally dealing with the nasty typographical
  301. %  details.
  302. % \subsection{Paragraphing}
  303. % \begin{macro}{\lineskip}
  304. % \begin{macro}{\normallineskip}
  305. %    These parameters control \TeX's behavior when two lines tend to
  306. %    come too close together.
  307. %    \begin{macrocode}
  308. \setlength\lineskip{1\p@}
  309. \setlength\normallineskip{1\p@}
  310. %    \end{macrocode}
  311. % \end{macro}
  312. % \end{macro}
  313. % \begin{macro}{\baselinestretch}
  314. %    This is used as a multiplier for |\baselineskip|. The default is
  315. %    to {\em not\/} stretch the baselines.
  316. %    \begin{macrocode}
  317. \renewcommand\baselinestretch{}
  318. %    \end{macrocode}
  319. % \end{macro}
  320. % \begin{macro}{\parskip}
  321. % \begin{macro}{\parindent}
  322. %    |\parskip| gives extra vertical space between paragraphs and
  323. %    |\parindent| is the width of the paragraph indentation.
  324. %    Letters are typeset without paragraph indentation.
  325. %    \begin{macrocode}
  326. \setlength\parskip{0.7em}
  327. \setlength\parindent{0\p@}
  328. %    \end{macrocode}
  329. % \end{macro}
  330. % \end{macro}
  331. % \begin{macro}{\@lowpenalty}
  332. % \begin{macro}{\@medpenalty}
  333. % \begin{macro}{\@highpenalty}
  334. %    The commands |\nopagebreak| and |\nolinebreak| put in penalties
  335. %    to discourage these breaks at the point they are put in.
  336. %    They use |\@lowpenalty|, |\@medpenalty| or |\@highpenalty|,
  337. %    dependant on their argument.
  338. %    \begin{macrocode}
  339. \@lowpenalty   51
  340. \@medpenalty  151
  341. \@highpenalty 301
  342. %    \end{macrocode}
  343. % \end{macro}
  344. % \end{macro}
  345. % \end{macro}
  346. % \begin{macro}{\clubpenalty}
  347. % \begin{macro}{\widowpenalty}
  348. %    These penalties are used to discourage club and widow lines.
  349. %    Because we use their default values we only show them here,
  350. %    commented out.
  351. %    \begin{macrocode}
  352. % \clubpenalty  150
  353. % \widowpenalty 150
  354. %    \end{macrocode}
  355. % \end{macro}
  356. % \end{macro}
  357. % \begin{macro}{\displaywidowpenalty}
  358. % \begin{macro}{\predisplaypenalty}
  359. % \begin{macro}{\postdisplaypenalty}
  360. %    Discourage (but not so much) widows in front of a math display
  361. %    and forbid breaking directly in front of a display. Allow break
  362. %    after a display without a penalty. Again the default values are
  363. %    used, therefore we only show them here.
  364. %    \begin{macrocode}
  365. % \displaywidowpenalty 50
  366. % \predisplaypenalty   10000
  367. % \postdisplaypenalty  0
  368. %    \end{macrocode}
  369. % \end{macro}
  370. % \end{macro}
  371. % \end{macro}
  372. % \begin{macro}{\interlinepenalty}
  373. %    Allow the breaking of a page in the middle of a paragraph.
  374. %    \begin{macrocode}
  375. % \interlinepenalty 0
  376. %    \end{macrocode}
  377. % \end{macro}
  378. % \begin{macro}{\brokenpenalty}
  379. %    We allow the breaking of a page after a hyphenated line.
  380. %    \begin{macrocode}
  381. % \brokenpenalty 0
  382. %    \end{macrocode}
  383. % \end{macro}
  384. % \subsection{Page Layout}
  385. %    All margin dimensions are measured from a point one inch from the
  386. %    top and lefthand side of the page.
  387. % \subsubsection{Vertical spacing}
  388. % \begin{macro}{\headheight}
  389. % \begin{macro}{\headsep}
  390. %    The |\headheight| is the height of the box that will contain the
  391. %    running head. The |\headsep| is the distance between the bottom
  392. %    of the running head and the top of the text. |\topskip| is the
  393. %    |\baselineskip| for the first line on a page, its value depends
  394. %    on the size option that was specified. Therefore it is
  395. %    initialized in one of the \file{size1x.clo} files.
  396. %    \begin{macrocode}
  397. \setlength\headheight{12\p@}
  398. \setlength\headsep   {45\p@}
  399. %    \end{macrocode}
  400. % \end{macro}
  401. % \end{macro}
  402. % \begin{macro}{\footskip}
  403. %    The distance from the baseline of the box which contains the
  404. %    running footer to the baseline of last line of text is controlled
  405. %    by the |\footskip|.
  406. %    Bottom of page:
  407. %    \begin{macrocode}
  408. \setlength\footskip{25\p@}
  409. %    \end{macrocode}
  410. % \end{macro}
  411. % \changes{v1.2n}{1994/07/13}{Setting of \cs{maxdepth} and
  412. %    \cs{@maxdepth} already happens in the size.. files, removed
  413. %    here}
  414. % \subsubsection{The dimension of text}
  415. % \begin{macro}{\textwidth}
  416. %    When we are in compatibility mode we have to make sure that the
  417. %    dimensions of the printed area are not different from what the
  418. %    user was used to see.
  419. % \changes{v1.2n}{1994/07/13}{Setting \cs{textwidth} to a fixed value
  420. %    should only happen in compatibility mode}
  421. %    \begin{macrocode}
  422. \if@compatibility
  423.   \setlength\textwidth{365\p@}
  424. %    \end{macrocode}
  425. % \end{macro}
  426. % \begin{macro}{\textheight}
  427. %    Now that we have computed the width of the text, we have to take
  428. %    care of the height. The |\textheight| is the height of text
  429. %    (including footnotes and figures, excluding running head and
  430. %    foot).
  431. % \changes{v1.2n}{1994/07/13}{Setting \cs{textheight} to a fixed value
  432. %    should only happen in compatibility mode}
  433. %    \begin{macrocode}
  434.   \setlength\textheight{505\p@}
  435. %    \end{macrocode}
  436. %    In native mode we use the dimensions as they were computed by one
  437. %    of the \Lopt{xxpt} options, together with one of the
  438. %    \Lopt{..paper} options.
  439. % \end{macro}
  440. % \subsubsection{Margins}
  441. % \begin{macro}{\oddsidemargin}
  442. % \begin{macro}{\evensidemargin}
  443. % \begin{macro}{\marginparwidth}
  444. % \changes{v1.1d}{1994/01/20}{Corrected margins: Now computed from
  445. %    \cs{paperwidth} and \cs{textwidth}.}  The values of
  446. %    |\oddsidemargin| and |\evensidemargin| are computed from those of
  447. %    |\paperwidth| and |\textwidth|.
  448. % \changes{v1.2n}{1994/07/13}{Added fixed values for these parameters
  449. %    in compatibillity mode}
  450. %    \begin{macrocode}
  451. \if@compatibility
  452.   \setlength\oddsidemargin{53pt}
  453.   \setlength\evensidemargin{53pt}
  454.   \setlength\marginparwidth{90pt}
  455. \else
  456.   \setlength\@tempdima{\paperwidth}
  457.   \addtolength\@tempdima{-2in}
  458.   \addtolength\@tempdima{-\textwidth}
  459.   \setlength\oddsidemargin   {.5\@tempdima}
  460.   \setlength\evensidemargin  {\oddsidemargin}
  461.   \setlength\marginparwidth  {90\p@}
  462. %    \end{macrocode}
  463. % \end{macro}
  464. % \end{macro}
  465. % \end{macro}
  466. % \begin{macro}{\marginparsep}
  467. % \begin{macro}{\marginparpush}
  468. %    The horizontal space between the main text and marginal notes is
  469. %    determined by |\marginparsep|, the minimum vertical separation
  470. %    between two marginal notes is controlled by |\marginparpush|.
  471. %    \begin{macrocode}
  472. \setlength\marginparsep {11\p@}
  473. \setlength\marginparpush{5\p@}
  474. %    \end{macrocode}
  475. % \end{macro}
  476. % \end{macro}
  477. % \begin{macro}{\topmargin}
  478. %    The |\topmargin| is the distance between the top of `the
  479. %    printable area' --which is 1 inch below the top of the paper--
  480. %    and the top of the box which contains the running head.
  481. %    It can now be computed from the values set above.
  482. %    \begin{macrocode}
  483. \setlength\topmargin{27pt}
  484. %    \end{macrocode}
  485. % \end{macro}
  486. % \subsubsection{Footnotes}
  487. % \begin{macro}{\footnotesep}
  488. %    |\footnotesep| is the height of the strut placed at the beginning
  489. %    of every footnote. It equals the  height of a normal
  490. %    |\footnotesize| strut in this
  491. %    class, thus no extra space occurs between footnotes.
  492. %    \begin{macrocode}
  493. \setlength\footnotesep{12\p@}
  494. %    \end{macrocode}
  495. % \end{macro}
  496. % \begin{macro}{\footins}
  497. %    |\skip\footins| is the space between the last line of the main
  498. %    text and the top of the first footnote.
  499. %    \begin{macrocode}
  500. \setlength{\skip\footins}{10\p@ \@plus 2\p@ \@minus 4\p@}
  501. %    \end{macrocode}
  502. % \end{macro}
  503. % \subsection{Page Styles}
  504. %    The page style \pstyle{foo} is defined by defining the command
  505. %    |\ps@foo|.   This command should make only local definitions.
  506. %    There should be no stray spaces in the definition, since they
  507. %    could lead to mysterious extra spaces in the output (well, that's
  508. %    something that should be always avoided).
  509. % \begin{macro}{\@evenhead}
  510. % \begin{macro}{\@oddhead}
  511. % \begin{macro}{\@evenfoot}
  512. % \begin{macro}{\@oddfoot}
  513. %    The |\ps@...| command defines the macros |\@oddhead|,
  514. %    |\@oddfoot|, |\@evenhead|, and |\@evenfoot| to define the running
  515. %    heads and feet---e.g., |\@oddhead| is the macro to produce the
  516. %    contents of the heading box for odd-numbered pages.  It is called
  517. %    inside an |\hbox| of width |\textwidth|.
  518. % \end{macro}
  519. % \end{macro}
  520. % \end{macro}
  521. % \end{macro}
  522. % \subsubsection{Marking conventions}
  523. %    To make headings determined by the sectioning commands, the page
  524. %    style defines the commands |\chaptermark|, |\sectionmark|,
  525. %    \ldots, where |\chaptermark{|\meta{text}|}| is called by
  526. %    |\chapter| to set a mark, and so on.
  527. %    The |\...mark| commands and the |\...head| macros are defined
  528. %    with the help of the following macros.  (All the |\...mark|
  529. %    commands should be initialized to no-ops.)
  530. %    \LaTeX{} extends \TeX's |\mark| facility by producing two kinds
  531. %    of marks, a `left' and a `right' mark, using the following
  532. %    commands:
  533. %    \begin{flushleft}
  534. %     |\markboth{|\meta{left}|}{|\meta{right}|}|: Adds both marks.
  535. %     |\markright{|\meta{right}|}|: Adds a `right' mark.
  536. %     |\leftmark|: Used in the |\@oddhead|, |\@oddfoot|, |\@evenhead|
  537. %                  or |\@evenfoot| macros, it gets the current `left'
  538. %                  mark.  |\leftmark| works like \TeX's |\botmark|
  539. %                  command.
  540. %     |\rightmark|: Used in the |\@oddhead|, |\@oddfoot|, |\@evenhead|
  541. %                   or  |\@evenfoot| macros, it gets the current
  542. %                   `right' mark. |\rightmark| works like \TeX's
  543. %                   |\firstmark| command.
  544. %    \end{flushleft}
  545. %    The marking commands work reasonably well for right marks
  546. %    `numbered within' left marks--e.g., the left mark is changed by a
  547. %    |\chapter| command and the right mark is changed by a |\section|
  548. %    command.  However, it does produce somewhat anomalous results if
  549. %    two |\markboth|'s occur on the same page.
  550. %    Commands like |\tableofcontents| that should set the marks in some
  551. %    page styles use a |\@mkboth| command, which is |\let| by the
  552. %    pagestyle command (|\ps@...|)  to |\markboth| for setting the
  553. %    heading or to |\@gobbletwo| to do nothing.
  554. %    \begin{macrocode}
  555. % %%%\mark{{}{}}   % Initializes TeX's marks   <--- can vanish
  556. %    \end{macrocode}
  557. % \subsubsection{Defining the page styles}
  558. % \label{sec:pagestyle}
  559. %    The pagestyles \pstyle{empty} and \pstyle{plain} are defined in
  560. %    \file{latex.tex}.
  561. % \begin{macro}{\ps@headings}
  562. %    The definition of the page style \pstyle{headings} has to be
  563. %    different for two sided printing than it is for one sided
  564. %    printing.
  565. % \changes{v1.2e}{1994/04/28}{Added twoside support}
  566. %    \begin{macrocode}
  567. \if@twoside
  568.   \def\ps@headings{%
  569. %    \end{macrocode}
  570. %    The running feet are empty in this page style.
  571. %    \begin{macrocode}
  572.       \let\@oddfoot\@empty\let\@evenfoot\@empty
  573. %    \end{macrocode}
  574. %    The running head contains some information about this letter. The
  575. %    head is the same for even and odd pages.
  576. % \changes{v1.2i}{1994/05/12}{Made running heads the same on odd and
  577. %    even pages}
  578. % \changes{v1.2k}{1994/06/17}{Added a missing brace}
  579. %    \begin{macrocode}
  580.       \def\@oddhead{\slshape\headtoname{} \ignorespaces\toname
  581.                     \hfil \@date
  582.                     \hfil \pagename{} \thepage}%
  583.       \let\@evenhead\@oddhead}
  584. %    \end{macrocode}
  585. %    For one sided printing we don't need to define |\@evenhead| so
  586. %    the definition is somewhat simpler.
  587. %    \begin{macrocode}
  588. \else
  589.   \def\ps@headings{%
  590.       \let\@oddfoot\@empty
  591.       \def\@oddhead{\slshape\headtoname{} \ignorespaces\toname
  592.                     \hfil \@date
  593.                     \hfil \pagename{} \thepage}}
  594. %    \end{macrocode}
  595. % \end{macro}
  596. % \begin{macro}{\ps@empty}
  597. %    The definition of the page style \pstyle{empty} is simple:
  598. %    No running head or foot at all.
  599. % \changes{v1.2e}{1994/04/28}{Also make even feet and head empty}
  600. %    \begin{macrocode}
  601. \def\ps@empty{%
  602.       \let\@oddfoot\@empty\let\@oddhead\@empty
  603.       \let\@evenfoot\@empty\let\@evenhead\@empty}
  604. %    \end{macrocode}
  605. % \end{macro}
  606. % \begin{macro}{\ps@firstpage}
  607. %    The page style \pstyle{firstpage} puts the telephone number
  608. %    in the proper place for the letterhead. It should be adapted
  609. %    to site conventions. The size of the number is determined
  610. %    depending on the main size.
  611. %    \begin{macrocode}
  612. \def\ps@firstpage{%
  613.      \let\@oddhead\@empty
  614.      \def\@oddfoot{\raisebox{-45\p@}[\z@]{%
  615.         \hb@xt@\textwidth{\hspace*{100\p@}%
  616.           \ifcase \@ptsize\relax
  617.              \normalsize
  618.           \or
  619.              \small
  620.           \or
  621.              \footnotesize
  622.           \fi
  623.         \fromlocation \hfill \telephonenum}}\hss}}
  624. %    \end{macrocode}
  625. % \end{macro}
  626. % \begin{macro}{\ps@plain}
  627. %    The definition of the page style \pstyle{plain} is again simple.
  628. % \changes{v1.2e}{1994/04/28}{Added definition of \cs{@evenfoot}
  629. %    because of twoside option}
  630. % \changes{v1.2s}{1995/05/25}{replace \cs{rmfamily} with
  631. %    \cs{normalfont} (PR 1578)}
  632. %    \begin{macrocode}
  633. \def\ps@plain{%
  634.       \let\@oddhead\@empty
  635.       \def\@oddfoot{\normalfont\hfil\thepage\hfil}%
  636.       \def\@evenfoot{\normalfont\hfil\thepage\hfil}}
  637. %    \end{macrocode}
  638. % \end{macro}
  639. % \section{Document Markup}
  640. % \subsection{Global Declarations}
  641. % \begin{macro}{\name}
  642. % \begin{macro}{\signature}
  643. % \begin{macro}{\address}
  644. % \begin{macro}{\location}
  645. % \begin{macro}{\telephone}
  646. % The following declarations, shown with examples, give information
  647. % about the sender:
  648. % \begin{itemize}
  649. %   \item |\name{Dr. L. User}| : to be used for the return address on
  650. %          the envelope.
  651. %    \begin{macrocode}
  652. \newcommand*{\name}[1]{\def\fromname{#1}}
  653. %    \end{macrocode}
  654. %   \item |\signature{Larry User}| : goes after the closing.
  655. %    \begin{macrocode}
  656. \newcommand*{\signature}[1]{\def\fromsig{#1}}
  657. %    \end{macrocode}
  658. %   \item |\address{3245 Foo St.\\Gnu York}| : used as the return
  659. %          address in the
  660. %          letter and on the envelope.  If not declared, then an
  661. %          institutional standard address is used.
  662. %    \begin{macrocode}
  663. \newcommand*{\address}[1]{\def\fromaddress{#1}}
  664. %    \end{macrocode}
  665. %   \item |\location{Room 374}| : Acts as modifier to the standard
  666. %          institutional address.
  667. %    \begin{macrocode}
  668. \newcommand*{\location}[1]{\def\fromlocation{#1}}
  669. %    \end{macrocode}
  670. %   \item |\telephone{(415)123-4567}| : Just in case some style puts it
  671. %          on the letter.
  672. % \changes{v1.2m}{1994/06/23}{Removed typo (\#[] instead of [1])}
  673. %    \begin{macrocode}
  674. \newcommand*{\telephone}[1]{\def\telephonenum{#1}}
  675. %    \end{macrocode}
  676. % \end{itemize}
  677. % \end{macro}
  678. % \end{macro}
  679. % \end{macro}
  680. % \end{macro}
  681. % \end{macro}
  682. % \begin{macro}{\fromname}
  683. % \begin{macro}{\fromsig}
  684. % \begin{macro}{\fromaddress}
  685. % \begin{macro}{\fromlocation}
  686. % \begin{macro}{\telephonenum}
  687. %    We make sure that the internal control sequences that are used to
  688. %    store the information exist and are empty.
  689. %    \begin{macrocode}
  690. \name{}
  691. \signature{}
  692. \address{}
  693. \location{}
  694. \telephone{}
  695. %    \end{macrocode}
  696. % \end{macro}
  697. % \end{macro}
  698. % \end{macro}
  699. % \end{macro}
  700. % \end{macro}
  701. % \begin{macro}{\makelabels}
  702. %     The |\makelabels| declaration causes mailing labels to be made.
  703. %    \begin{macrocode}
  704. \newcommand*{\makelabels}{%
  705. %    \end{macrocode}
  706. %    At the beginning of the document, we need to activate the
  707. %    |\@mlabel| and |\@startlabels| commands, as well as  write
  708. %    |\@startlabels| to the |.aux| file.
  709. %    \begin{macrocode}
  710.   \AtBeginDocument{%
  711.      \let\@startlabels\startlabels
  712.      \let\@mlabel\mlabel
  713.      \if@filesw
  714.        \immediate\write\@mainaux{\string\@startlabels}\fi}%
  715. %    \end{macrocode}
  716. %    At the end of the document we need to write |\clearpage| to the
  717. %    |.aux| file.
  718. %    \begin{macrocode}
  719.   \AtEndDocument{%
  720.      \if@filesw\immediate\write\@mainaux{\string\clearpage}\fi}}
  721. %    \end{macrocode}
  722. %    |\makelabels| is allowed only before the |\begin{document}|
  723. %    command.
  724. %    \begin{macrocode}
  725. \@onlypreamble\makelabels
  726. %    \end{macrocode}
  727. % \end{macro}
  728. % \subsection{The generic letter commands}
  729. % \begin{environment}{letter}
  730. %     The letter environment creates a new letter, starting from page 1.
  731. %     (The first page is unnumbered.)  It has a single argument, which
  732. %     is the addressee and his address, as in
  733. %\begin{verbatim}
  734. %  \begin{letter}{Sam Jones \\
  735. %                 Institute for Retarded Study\\
  736. %                 Princeton, N.J.}
  737. %\end{verbatim}
  738. %     Local declarations, such as |\address|, can follow the
  739. %     |\begin{letter}|.
  740. % \changes{v1.2e}{1994/04/28}{When printing twosided a new letter
  741. %    shouldn't start on the back of the previous one. Added insertion
  742. %    of a blank page when necessary.}
  743. %    \begin{macrocode}
  744. \newenvironment{letter}[1]
  745.   {\newpage
  746.     \if@twoside \ifodd\c@page
  747.                 \else\thispagestyle{empty} \hbox{}\newpage\fi
  748.     \fi
  749.     \c@page\@ne
  750.     \interlinepenalty=200 % smaller than the TeXbook value
  751. %    \end{macrocode}
  752. %    The |\leavevmode| and |\ignorespaces| commands are there for
  753. %    protecting against an empty argument.
  754. %    \begin{macrocode}
  755.     \@processto{\leavevmode\ignorespaces #1}}
  756. %    \end{macrocode}
  757. %    The end of the environment possibly writes the address
  758. %    information on the \file{.aux} file.
  759. % \changes{v1.2p}{1994/12/11}{No longer redefine \cs{protect} but use
  760. %    one of the available settings}
  761. %    \begin{macrocode}
  762.   {\stopletter\@@par\pagebreak\@@par
  763.     \if@filesw
  764.       \begingroup
  765.         \let\\=\relax
  766.         \let\protect\@unexpandable@protect
  767.         \immediate\write\@auxout{%
  768.           \string\@mlabel{\returnaddress}{\toname\\\toaddress}}%
  769.       \endgroup
  770.     \fi}
  771. %    \end{macrocode}
  772. % \end{environment}
  773. % \begin{macro}{\@processto}
  774. % \begin{macro}{\@xproc}
  775. % \begin{macro}{\@yproc}
  776. %    |\@processto| gets the |\toname| and |\toaddress| from the letter
  777. %    environment's macro argument. |\@xproc| and |\@yproc| are auxiliary
  778. %    macros.
  779. %    \begin{macrocode}
  780. \long\def\@processto#1{\@xproc #1\\@@@\ifx\toaddress\@empty
  781.     \else \@yproc #1@@@\fi}
  782. \long\def\@xproc #1\\#2@@@{\def\toname{#1}\def\toaddress{#2}}
  783. \long\def\@yproc #1\\#2@@@{\def\toaddress{#2}}
  784. %    \end{macrocode}
  785. % \end{macro}
  786. % \end{macro}
  787. % \end{macro}
  788. % \subsubsection{Page breaking control}
  789. % \begin{macro}{\stopbreaks}
  790. %    When the command |\stopbreaks| is issued no page breaks should
  791. %    occur until |\startbreaks| is called.
  792. %    \begin{macrocode}
  793. \newcommand*{\stopbreaks}{\interlinepenalty \@M
  794.    \def\par{\@@par\nobreak}\let\\=\@nobreakcr
  795.    \let\vspace\@nobreakvspace}
  796. %    \end{macrocode}
  797. % \end{macro}
  798. % \begin{macro}{\nobreakvspace}
  799. % \begin{macro}{\nobreakvspacex}
  800. % \begin{macro}{\nobreakcr}
  801. %    These are needed by |\stopbreaks|
  802. %    \begin{macrocode}
  803. \def\@nobreakvspace{\@ifstar{\@nobreakvspacex}{\@nobreakvspacex}}
  804. \def\@nobreakvspacex#1{\ifvmode\nobreak\vskip #1\relax\else
  805.                \@bsphack\vadjust{\nobreak\vskip #1}\@esphack\fi}
  806. \def\@nobreakcr{\vadjust{\penalty\@M}\@ifstar{\@xnewline}{\@xnewline}}
  807. %    \end{macrocode}
  808. % \end{macro}
  809. % \end{macro}
  810. % \end{macro}
  811. % \begin{macro}{\startbreaks}
  812. %    This cancels the effect of |\stopbreaks|.
  813. %    \begin{macrocode}
  814. \newcommand*{\startbreaks}{\let\\=\@normalcr
  815.    \interlinepenalty 200\def\par{\@@par\penalty 200\relax}}
  816. %    \end{macrocode}
  817. % \end{macro}
  818. % \begin{macro}{\longindentation}
  819. %    The size of the indent to use before the closing of the letter.
  820. %    \begin{macrocode}
  821. \newdimen\longindentation
  822. \longindentation=.5\textwidth
  823. %    \end{macrocode}
  824. % \end{macro}
  825. % \begin{macro}{\indentedwidth}
  826. %    The width of the closing of the letter.
  827. %    \begin{macrocode}
  828. \newdimen\indentedwidth
  829. \indentedwidth=\textwidth
  830. \advance\indentedwidth -\longindentation
  831. %    \end{macrocode}
  832. % \end{macro}
  833. % \begin{macro}{\opening}
  834. %     Text is begun with the |\opening| command, whose argument
  835. %     generates the salutation, as in
  836. %\begin{verbatim}
  837. %      \opening{Dear Henry,}
  838. %\end{verbatim}
  839. %    This should produce everything up to and including the `Dear Henry,'
  840. %    and a \par command that follows. Since there's a |\vfil| at the
  841. %    bottom of every page, it can add vertical fill to position a short
  842. %    letter. It should use the following commands:
  843. %   \begin{itemize}
  844. %   \item |\toname| : name part of `to' address.
  845. %                     Will be one line long. 
  846. %   \item |\toaddress| : address part of `to' address.
  847. %                        The lines separated by |\\|.
  848. %   \item |\fromname| : name of sender.
  849. %   \item |\fromaddress| : argument of current |\address|
  850. %     declaration-- null if none.  Should use standard institutional
  851. %     address if null. 
  852. %   \item |\fromlocation| : argument of current |\location|
  853. %     declaration--null if none.
  854. %   \item |\telephonenum| : argument of current |\telephone|
  855. %     declaration--null if none.
  856. %    \end{itemize}
  857. %    \begin{macrocode}
  858. \newcommand*{\opening}[1]{\ifx\@empty\fromaddress
  859.   \thispagestyle{firstpage}%
  860.     {\raggedleft\@date\par}%
  861.   \else  % home address
  862.     \thispagestyle{empty}%
  863.     {\raggedleft\begin{tabular}{l}\ignorespaces
  864.       \fromaddress \\*[2\parskip]%
  865.       \@date \end{tabular}\par}%
  866.   \fi
  867.   \vspace{2\parskip}%
  868.   {\raggedright \toname \\ \toaddress \par}%
  869.   \vspace{2\parskip}%
  870.   #1\par\nobreak}
  871. %    \end{macrocode}
  872. % \end{macro}
  873. % \begin{macro}{\closing}
  874. %     The body of the letter follows, ended by a |\closing| command,
  875. %     as in
  876. %\begin{verbatim}
  877. %            \closing{Yours truly,}
  878. %\end{verbatim}
  879. %     This command generates the closing matter, and the signature.
  880. %     An obvious thing to do is to use a |\parbox| for the closing
  881. %     and the signature.  Should use the following:
  882. %    \begin{itemize}
  883. %      \item |\fromsig| : argument of current |\signature| declaration
  884. %                   or, if null, the |\fromname|.
  885. %      \item |\stopbreaks| : a macro that inhibits page breaking.
  886. %    \end{itemize}
  887. %    \begin{macrocode}
  888. \newcommand{\closing}[1]{\par\nobreak\vspace{\parskip}%
  889.   \stopbreaks
  890.   \noindent
  891.   \ifx\@empty\fromaddress\else
  892.   \hspace*{\longindentation}\fi
  893.   \parbox{\indentedwidth}{\raggedright
  894.        \ignorespaces #1\\[6\medskipamount]%
  895.        \ifx\@empty\fromsig
  896.            \fromname
  897.        \else \fromsig \fi\strut}%
  898.    \par}
  899. %    \end{macrocode}
  900. % \end{macro}
  901. % \begin{macro}{\smallskipamount}
  902. % \begin{macro}{\mdeskipamount}
  903. % \begin{macro}{\bigskipamount}
  904. %   Of these three, only |\medskipmount| is actually used above.
  905. %    \begin{macrocode}
  906. %\smallskipamount=.5\parskip
  907. \medskipamount=\parskip
  908. %\bigskipamount=2\parskip
  909. %    \end{macrocode}
  910. % \end{macro}
  911. % \end{macro}
  912. % \end{macro}
  913. % \begin{macro}{\cc}
  914. % \begin{macro}{\encl}
  915. % \begin{macro}{\ps}
  916. %    After the |\closing| you can put arbitrary stuff, which is typeset
  917. %    with zero |\parindent| and no page breaking.  Commands designed
  918. %    for use after the closing are:
  919. %    \begin{verbatim}
  920. %  \cc{Tinker\\Evers\\Chance}
  921. %\end{verbatim}
  922. %    which produces:\\
  923. %    \begin{tabular}{ll}
  924. %        cc: & Tinker\\
  925. %            & Evers\\
  926. %            & Chance
  927. %    \end{tabular}\\
  928. %    Note the obvious use of |\parbox|.
  929. % \changes{v1.2s}{1995/05/25}{replace \cs{reset@font} with
  930. %    \cs{normalfont}; remove \cs{rm}}
  931. %    \begin{macrocode}
  932. \newcommand*{\cc}[1]{%
  933.   \par\noindent
  934.   \parbox[t]{\textwidth}{%
  935.     \@hangfrom{\normalfont\ccname: }%
  936.     \ignorespaces #1\strut}\par}
  937. %    \end{macrocode}
  938. %\begin{verbatim}
  939. %  \encl{Foo(2)\\Bar}
  940. %\end{verbatim}
  941. %    which produces:\\
  942. %    \begin{tabular}{ll}
  943. %        encl: & Foo(2)\\
  944. %              & Bar
  945. %    \end{tabular}
  946. %    \begin{macrocode}
  947. \newcommand*{\encl}[1]{%
  948.   \par\noindent
  949.   \parbox[t]{\textwidth}{%
  950.     \@hangfrom{\normalfont\enclname: }%
  951.     \ignorespaces #1\strut}\par}
  952. %    \end{macrocode}
  953. %    The only thing |\ps| needs to do is call |\startbreaks|,
  954. %        which allows page breaking again.
  955. %    \begin{macrocode}
  956. \newcommand*{\ps}{\par\startbreaks}
  957. %    \end{macrocode}
  958. % \end{macro}
  959. % \end{macro}
  960. % \end{macro}
  961. % \begin{macro}{\stopletter}
  962. %     The |\stopletter| command is called by |\endletter| to do the
  963. %     following:
  964. %    \begin{itemize}
  965. %     \item Add any desired  fill  or other material at the end of the
  966. %       letter.
  967. %     \item Define |\returnaddress| to be the return address for the
  968. %       mailing
  969. %      label.  More precisely, it is the first argument of the |\mlabel|
  970. %       command described below. It should be defined to null if the
  971. %       return address doesn't appear on the labels.  Any command,
  972. %       other than |\\|, that should not be expanded until the |\mlabel|
  973. %       command is actually executed must be preceded by |\protect|.
  974. %       Whenever possible, |\protect| commands in the definition of
  975. %       |\returnaddress|---it's much more efficient that way.  In
  976. %       particular, when the standard return address is used, you
  977. %       should define |\returnaddress| to something like
  978. %       |\protect\standardreturnaddress|.
  979. %    \end{itemize}
  980. %    \begin{macrocode}
  981. \newcommand*{\stopletter}{}
  982. %    \end{macrocode}
  983. % \end{macro}
  984. % \subsection{Customizing the labels}
  985. %    Commands for generating the labels are put on the \file{.aux} file,
  986. %    which is read in and processed by the |\end{document}| command.
  987. %    You have to define the following two commands:
  988. %    \begin{itemize}
  989. %    \item |\startlabels| : Should reset the page layout parameters if
  990. %      necessary. 
  991. %    \item |\mlabel\marg{return address}\marg{to adress}| : Command to
  992. %      generate a single label.
  993. %    \end{itemize}
  994. %     
  995. % \begin{macro}{\returnaddress}
  996. %    The return address for the mailing labels can be stored in this
  997. %    macro.
  998. %    \begin{macrocode}
  999. \newcommand*{\returnaddress}{}
  1000. %    \end{macrocode}
  1001. % \end{macro}
  1002. % \begin{macro}{\labelcount}
  1003. %    A register to count the labels 
  1004. %    \begin{macrocode}
  1005. \newcount\labelcount
  1006. %    \end{macrocode}
  1007. % \end{macro}
  1008. % \begin{macro}{\startlabels}
  1009. %     The following |\startlabels| command sets things up for
  1010. %     producing labels in two columns of five 2" $\times$ 4-1/4"
  1011. %     labels each, suitable for reproducing onto Avery brand number
  1012. %     5352 address labels.
  1013. % \changes{v1.2q}{1995/03/14}{changed value of \cs{columnsep} by 1pt}
  1014. %    \begin{macrocode}
  1015. \newcommand*{\startlabels}{\labelcount\z@
  1016.   \pagestyle{empty}%
  1017.   \let\@texttop\relax
  1018.   \topmargin -50\p@
  1019.   \headsep \z@
  1020.   \oddsidemargin -35\p@
  1021.   \evensidemargin -35\p@
  1022.   \textheight 10in
  1023.   \@colht\textheight  \@colroom\textheight \vsize\textheight
  1024.   \textwidth 550\p@
  1025.   \columnsep 26\p@
  1026.   \ifcase \@ptsize\relax
  1027.     \normalsize
  1028.   \or
  1029.     \small
  1030.   \or
  1031.     \footnotesize
  1032.   \fi
  1033.   \baselineskip \z@
  1034.   \lineskip \z@
  1035.   \boxmaxdepth \z@
  1036.   \parindent \z@
  1037.   \twocolumn\relax}
  1038. %    \end{macrocode}
  1039. % \end{macro}
  1040. % \begin{macro}{\@startlabels}
  1041. %    |\@startlabels| is the command name that is written to the |.aux|
  1042. %    file. It is a no-op at first, and defined to be the same as
  1043. %    |\startlabels| in the |\begin{document}| hook.
  1044. %    \begin{macrocode}
  1045. \let\@startlabels=\relax
  1046. %    \end{macrocode}
  1047. % \end{macro}
  1048. % \begin{macro}{\mlabel}
  1049. %    This command prints an address label; it is used when the user
  1050. %    specified |\makelabels| in the preamble of his document. The
  1051. %    command |\mlabel| takes two arguments; the second argument is
  1052. %    supposed to be the address; the first argument can be used to
  1053. %    print a return address. In this document class we ignore the
  1054. %    first argument. Also the labels are supposed to be 2~inch high
  1055. %    and 3.6~inch wide. When your address labels have a different you
  1056. %    will have to defined your own |\mlabel| command.
  1057. % \changes{v1.2p}{1994/12/11}{Redefined \cs{mlabel} to not use the
  1058. %    \cs{setbox} primitive}
  1059. % \changes{v1.2q}{1995/03/14}{changed width of the labels slightly to
  1060. %    prevent \LaTeX\ stuffing two on each line}
  1061. %    \begin{macrocode}
  1062. \newcommand*{\mlabel}[2]{%
  1063.   \parbox[b][2in][c]{262\p@}{\strut\ignorespaces #2}%
  1064. %    \end{macrocode}
  1065. % \end{macro}
  1066. % \begin{macro}{\@mlabel}
  1067. %    |\@mlabel| is written to the \file{.aux} file in place of |\mlabel|.
  1068. %    That allows to define it as a no-op per default, and activate it
  1069. %    in the |\begin{document}| hook.
  1070. %    \begin{macrocode}
  1071. \let\@mlabel=\@gobbletwo
  1072. %    \end{macrocode}
  1073. % \end{macro}
  1074. % \subsection{Lists}
  1075. % \subsubsection{General List Parameters}
  1076. %    The following commands are used to set the default values for the
  1077. %    list environment's parameters. See the \LaTeX{} manual for an
  1078. %    explanation of the meanings of the parameters.  Defaults for the
  1079. %    list environment are set as follows.  First, |\rightmargin|,
  1080. %    |\listparindent| and |\itemindent| are set to 0pt.  Then, for a
  1081. %    \texttt{K}th level list, the command |\@listK| is called, where
  1082. %    `\texttt{K}' denotes `\texttt{i}', `\texttt{ii}', ... ,
  1083. %    `\texttt{vi}'.  (I.e., |\@listiii| is called for a third-level
  1084. %    list.)  By convention, |\@listK| should set |\leftmargin| to
  1085. %    |\leftmarginK|.
  1086. % \begin{macro}{\leftmargin}
  1087. % \begin{macro}{\leftmargini}
  1088. % \begin{macro}{\leftmarginii}
  1089. % \begin{macro}{\leftmarginiii}
  1090. % \begin{macro}{\leftmarginiv}
  1091. % \begin{macro}{\leftmarginv}
  1092. % \begin{macro}{\leftmarginvi}
  1093. % For efficiency, level-one list's values are defined at top level, and
  1094. % |\@listi| is defined to set only |\leftmargin|.
  1095. %    \begin{macrocode}
  1096. \setlength\leftmargini  {2.5em}
  1097. %    \end{macrocode}
  1098. %    The following three are calculated so  that they are larger than
  1099. %    the sum of |\labelsep| and the width of the default labels (which
  1100. %    are `(m)', `vii.' and `M.').
  1101. %    \begin{macrocode}
  1102. \setlength\leftmarginii  {2.2em}
  1103. \setlength\leftmarginiii {1.87em}
  1104. \setlength\leftmarginiv  {1.7em}
  1105. \setlength\leftmarginv  {1em}
  1106. \setlength\leftmarginvi {1em}
  1107. %    \end{macrocode}
  1108. %    Here we set the top level leftmargin.
  1109. %    \begin{macrocode}
  1110. \setlength\leftmargin    {\leftmargini}
  1111. %    \end{macrocode}
  1112. % \end{macro}
  1113. % \end{macro}
  1114. % \end{macro}
  1115. % \end{macro}
  1116. % \end{macro}
  1117. % \end{macro}
  1118. % \end{macro}
  1119. % \begin{macro}{\labelsep}
  1120. % \begin{macro}{\labelwidth}
  1121. %    |\labelsep| is the distance between the label and the text of an
  1122. %    item; |\labelwidth| is the width of the label.
  1123. %    \begin{macrocode}
  1124. \setlength  \labelsep  {5\p@}
  1125. \setlength  \labelwidth{\leftmargini}
  1126. \addtolength\labelwidth{-\labelsep}
  1127. %    \end{macrocode}
  1128. % \end{macro}
  1129. % \end{macro}
  1130. % \begin{macro}{\partopsep}
  1131. %    When the user leaves a blank line before the environment an extra
  1132. %    vertical space of |\partopsep| is inserted, in addition to
  1133. %    |\parskip| and |\topsep|.
  1134. %    \begin{macrocode}
  1135. \setlength\partopsep{0\p@}
  1136. %    \end{macrocode}
  1137. % \end{macro}
  1138. % \begin{macro}{\@beginparpenalty}
  1139. % \begin{macro}{\@endparpenalty}
  1140. %    These penalties are inserted before and after a list or paragraph
  1141. %    environment. They are set to a bonus value to encourage page
  1142. %    breaking at these points.
  1143. % \begin{macro}{\@itempenalty}
  1144. %    This penalty is inserted between list items.
  1145. %    \begin{macrocode}
  1146. \@beginparpenalty -\@lowpenalty
  1147. \@endparpenalty   -\@lowpenalty
  1148. \@itempenalty     -\@lowpenalty
  1149. %    \end{macrocode}
  1150. % \end{macro}
  1151. % \end{macro}
  1152. % \end{macro}
  1153. % \begin{macro}{\@listI}
  1154. % \begin{macro}{\@listi}
  1155. % |\@listI| defines top level and |\@listi| values of
  1156. % |\leftmargin|, |\parsep|, |\topsep|, and |\itemsep|
  1157. %    \begin{macrocode}
  1158. \def\@listI{\setlength\leftmargin{\leftmargini}
  1159.             \setlength\parsep {0\p@}%
  1160.             \setlength\topsep {.4em}%
  1161.             \setlength\itemsep{.4em}}
  1162. \let\@listi\@listI
  1163. %    \end{macrocode}
  1164. %    We have to initialize these parameters.
  1165. %    \begin{macrocode}
  1166. \@listi
  1167. %    \end{macrocode}
  1168. % \end{macro}
  1169. % \end{macro}
  1170. % \begin{macro}{\@listii}
  1171. % \begin{macro}{\@listiii}
  1172. % \begin{macro}{\@listiv}
  1173. % \begin{macro}{\@listv}
  1174. % \begin{macro}{\@listvi}
  1175. %    Here are the same macros for the higher level lists.
  1176. %    \begin{macrocode}
  1177. \def\@listii {\setlength  \leftmargin{\leftmarginii}%
  1178.               \setlength  \labelwidth{\leftmarginii}%
  1179.               \addtolength\labelwidth{-\labelsep}}
  1180. \def\@listiii{\setlength  \leftmargin{\leftmarginiii}%
  1181.               \setlength  \labelwidth{\leftmarginiii}%
  1182.               \addtolength\labelwidth{-\labelsep}%
  1183.               \setlength  \topsep    {.2em}%
  1184.               \setlength  \itemsep   {\topsep}}
  1185. \def\@listiv {\setlength  \leftmargin{\leftmarginiv}%
  1186.               \setlength  \labelwidth{\leftmarginiv}%
  1187.               \addtolength\labelwidth{-\labelsep}}
  1188. \def\@listv  {\setlength  \leftmargin{\leftmarginv}%
  1189.               \setlength  \labelwidth{\leftmarginv}%
  1190.               \addtolength\labelwidth{-\labelsep}}
  1191. \def\@listvi {\setlength  \leftmargin{\leftmarginvi}%
  1192.               \setlength  \labelwidth{\leftmarginvi}%
  1193.               \addtolength\labelwidth{-\labelsep}}
  1194. %    \end{macrocode}
  1195. % \end{macro}
  1196. % \end{macro}
  1197. % \end{macro}
  1198. % \end{macro}
  1199. % \end{macro}
  1200. % \subsubsection{Enumerate}
  1201. %    The enumerate environment uses  four counters: \Lcount{enumi},
  1202. %    \Lcount{enumii}, \Lcount{enumiii} and \Lcount{enumiv}, where
  1203. %    \Lcount{enumN} controls the numbering of the Nth level
  1204. %    enumeration.
  1205. % \begin{macro}{\theenumi}
  1206. % \begin{macro}{\theenumii}
  1207. % \begin{macro}{\theenumiii}
  1208. % \begin{macro}{\theenumiv}
  1209. %    The counters are already defined in \file{latex.tex}, but their
  1210. %    representation is changed here.
  1211. %    \begin{macrocode}
  1212. \renewcommand\theenumi{\@arabic\c@enumi}
  1213. \renewcommand\theenumii{\@alph\c@enumii}
  1214. \renewcommand\theenumiii{\@roman\c@enumiii}
  1215. \renewcommand\theenumiv{\@Alph\c@enumiv}
  1216. %    \end{macrocode}
  1217. % \end{macro}
  1218. % \end{macro}
  1219. % \end{macro}
  1220. % \end{macro}
  1221. % \begin{macro}{\labelenumi}
  1222. % \begin{macro}{\labelenumii}
  1223. % \begin{macro}{\labelenumiii}
  1224. % \begin{macro}{\labelenumiv}
  1225. %    The commands |\labelenumi| ... |\labelenumiv| generate the label
  1226. %    for each item.
  1227. %    \begin{macrocode}
  1228. \newcommand\labelenumi{\theenumi.}
  1229. \newcommand\labelenumii{(\theenumii)}
  1230. \newcommand\labelenumiii{\theenumiii.}
  1231. \newcommand\labelenumiv{\theenumiv.}
  1232. %    \end{macrocode}
  1233. % \end{macro}
  1234. % \end{macro}
  1235. % \end{macro}
  1236. % \end{macro}
  1237. % \begin{macro}{\p@enumii}
  1238. % \begin{macro}{\p@enumiii}
  1239. % \begin{macro}{\p@enumiv}
  1240. %    The expansion of |\p@enumN||\theenumN| defines the output of a
  1241. %    |\ref| command when referencing an item of the Nth level of an
  1242. %    enumerated list.
  1243. %    \begin{macrocode}
  1244. \renewcommand\p@enumii{\theenumi}
  1245. \renewcommand\p@enumiii{\theenumi(\theenumii)}
  1246. \renewcommand\p@enumiv{\p@enumiii\theenumiii}
  1247. %    \end{macrocode}
  1248. % \end{macro}
  1249. % \end{macro}
  1250. % \end{macro}
  1251. % \subsubsection{Itemize}
  1252. % \begin{macro}{\labelitemi}
  1253. % \begin{macro}{\labelitemii}
  1254. % \changes{v1.2h}{1994/05/06}{Inserted \cs{normalfont}}
  1255. % \begin{macro}{\labelitemiii}
  1256. % \begin{macro}{\labelitemiv}
  1257. % Itemization is controlled by  |\labelitemi|,
  1258. % |\labelitemii|, |\labelitemiii|, and |\labelitemiv|, which define
  1259. % the labels of the various itemization levels: the symbols used are
  1260. % bullet, bold en-dash, asterisk and centered dot.
  1261. % \changes{v1.2n}{1994/07/11}{renamed \cs{labelitemiiii} to
  1262. %    \cs{labelitemiii}}
  1263. %    \begin{macrocode}
  1264. \newcommand\labelitemi{$\m@th\bullet$}
  1265. \newcommand\labelitemii{\normalfont\bfseries --}
  1266. \newcommand\labelitemiii{$\m@th\ast$}
  1267. \newcommand\labelitemiv{$\m@th\cdot$}
  1268. %    \end{macrocode}
  1269. % \end{macro}
  1270. % \end{macro}
  1271. % \end{macro}
  1272. % \end{macro}
  1273. % \subsubsection{Description}
  1274. % \begin{environment}{description}
  1275. %    The description environment is defined here -- while the itemize
  1276. %    and enumerate environments are defined in \file{latex.tex}.
  1277. %    \begin{macrocode}
  1278. \newenvironment{description}
  1279.                {\list{}{\labelwidth\z@ \itemindent-\leftmargin
  1280.                         \let\makelabel\descriptionlabel}}
  1281.                {\endlist}
  1282. %    \end{macrocode}
  1283. % \end{environment}
  1284. % \begin{macro}{\descriptionlabel}
  1285. %    To change the formatting of the label, you must redefine
  1286. %    |\descriptionlabel|.
  1287. % \changes{v1.2q}{1995/03/14}{made command short}
  1288. %    \begin{macrocode}
  1289. \newcommand*{\descriptionlabel}[1]{\hspace\labelsep
  1290.                                 \normalfont\bfseries #1}
  1291. %    \end{macrocode}
  1292. % \end{macro}
  1293. % \subsection{Defining new environments}
  1294. % \subsubsection{Verse}
  1295. % \begin{environment}{verse}
  1296. %   The verse environment is defined by making clever use of the
  1297. %   list environment's parameters.  The user types |\\| to end a line.
  1298. %   This is implemented by |\let|'ing |\\| equal |\@centercr|.
  1299. %    \begin{macrocode}
  1300. \newenvironment{verse}
  1301.                {\let\\=\@centercr
  1302.                 \list{}{\setlength\itemsep{\z@}%
  1303.                         \setlength\itemindent{-15\p@}%
  1304.                         \setlength\listparindent{\itemindent}%
  1305.                         \setlength\rightmargin{\leftmargin}%
  1306.                         \addtolength\leftmargin{15\p@}}%
  1307.                 \item[]}
  1308.                {\endlist}
  1309. %    \end{macrocode}
  1310. % \end{environment}
  1311. % \subsubsection{Quotation}
  1312. % \begin{environment}{quotation}
  1313. %   The quotation environment is also defined by making clever use of
  1314. %   the list environment's parameters. The lines in the environment
  1315. %   are set smaller than |\textwidth|. The first line of a paragraph
  1316. %   inside this environment is indented.
  1317. %    \begin{macrocode}
  1318. \newenvironment{quotation}
  1319.                {\list{}{\setlength\listparindent{1.5em}%
  1320.                         \setlength\itemindent{\listparindent}%
  1321.                         \setlength\rightmargin{\leftmargin}}%
  1322.                 \item[]}
  1323.                {\endlist}
  1324. %    \end{macrocode}
  1325. % \end{environment}
  1326. % \subsubsection{Quote}
  1327. % \begin{environment}{quote}
  1328. %   The quote environment is like the quotation environment except
  1329. %   that paragraphs are not indented.
  1330. %    \begin{macrocode}
  1331. \newenvironment{quote}
  1332.                {\list{}{\setlength\rightmargin{\leftmargin}}%
  1333.                 \item[]}
  1334.                {\endlist}
  1335. %    \end{macrocode}
  1336. % \end{environment}
  1337. % \subsubsection{Theorem}
  1338. %    This document class does not define it's own theorem environments,
  1339. %    the defaults, supplied by \file{latex.ltx} are available.
  1340. % \subsection{Setting parameters for existing environments}
  1341. % \subsubsection{Array and tabular}
  1342. % \begin{macro}{\arraycolsep}
  1343. %    The columns in an array environment are separated by
  1344. %    2|\arraycolsep|.
  1345. %    \begin{macrocode}
  1346. \setlength\arraycolsep{5\p@}
  1347. %    \end{macrocode}
  1348. % \end{macro}
  1349. % \begin{macro}{\tabcolsep}
  1350. %    The columns in an tabular environment are separated by
  1351. %    2|\tabcolsep|.
  1352. %    \begin{macrocode}
  1353. \setlength\tabcolsep{6\p@}
  1354. %    \end{macrocode}
  1355. % \end{macro}
  1356. % \begin{macro}{\arrayrulewidth}
  1357. %    The width of vertical rules in the array and tabular environments
  1358. %    is given by |\arrayrulewidth|.
  1359. %    \begin{macrocode}
  1360. \setlength\arrayrulewidth{.4\p@}
  1361. %    \end{macrocode}
  1362. % \end{macro}
  1363. % \begin{macro}{\doublerulesep}
  1364. %    The space between adjacent rules in the array and tabular
  1365. %    environments is given by |\doublerulesep|.
  1366. %    \begin{macrocode}
  1367. \setlength\doublerulesep{2\p@}
  1368. %    \end{macrocode}
  1369. % \end{macro}
  1370. % \subsubsection{Tabbing}
  1371. % \begin{macro}{\tabbingsep}
  1372. %    This controls the space that the |\'| command puts in. (See
  1373. %    \LaTeX{} manual for an explanation.)
  1374. %    \begin{macrocode}
  1375. \setlength\tabbingsep{\labelsep}
  1376. %    \end{macrocode}
  1377. % \end{macro}
  1378. % \subsubsection{Minipage}
  1379. % \begin{macro}{\@minipagerestore}
  1380. %    The macro |\@minipagerestore| is called upon entry to a minipage
  1381. %    environment to set up things that are to be handled differently
  1382. %    inside a minipage environment. In the current styles, it does
  1383. %    nothing.
  1384. % \end{macro}
  1385. % \begin{macro}{\@mpfootins}
  1386. %    Minipages have their own footnotes; |\skip||\@mpfootins| plays
  1387. %    same r\^ole for footnotes in a minipage as |\skip||\footins| does
  1388. %    for ordinary footnotes.
  1389. %    \begin{macrocode}
  1390. \skip\@mpfootins = \skip\footins
  1391. %    \end{macrocode}
  1392. % \end{macro}
  1393. % \subsubsection{Framed boxes}
  1394. % \begin{macro}{\fboxsep}
  1395. %    The space left by |\fbox| and |\framebox| between the box and the
  1396. %    text in it.
  1397. % \begin{macro}{\fboxrule}
  1398. %    The width of the rules in the box made by |\fbox| and |\framebox|.
  1399. %    \begin{macrocode}
  1400. \setlength\fboxsep{3\p@}
  1401. \setlength\fboxrule{.4\p@}
  1402. %    \end{macrocode}
  1403. % \end{macro}
  1404. % \end{macro}
  1405. % \subsubsection{Equation and eqnarray}
  1406. % \begin{macro}{\theequation}
  1407. %    The equation counter will be typeset using arabic numbers.
  1408. %    \begin{macrocode}
  1409. \renewcommand\theequation{\@arabic\c@equation}
  1410. %    \end{macrocode}
  1411. % \end{macro}
  1412. % \begin{macro}{\jot}
  1413. %    |\jot| is the extra space added between lines of an eqnarray
  1414. %    environment. The default value is used.
  1415. %    \begin{macrocode}
  1416. % \setlength\jot{3pt}
  1417. %    \end{macrocode}
  1418. % \end{macro}
  1419. % \begin{macro}{\@eqnnum}
  1420. %    The macro |\@eqnnum| defines how equation numbers are to appear in
  1421. %    equations. Again the default is used.
  1422. %    \begin{macrocode}
  1423. % \def\@eqnnum{(\theequation)}
  1424. %    \end{macrocode}
  1425. % \end{macro}
  1426. % \subsection{Font changing}
  1427. %    Here we supply the declarative font changing commands that were
  1428. %    common in \LaTeX\ version 2.09 and earlier. These commands work
  1429. %    in text mode \emph{and} in math mode. They are provided for
  1430. %    compatibility, but one should start using the |\text...| and
  1431. %    |\math...| commands instead. These commands are redefined using
  1432. %    |\@renewfontswitch|, a command with three arguments: the user
  1433. %    command to be defined; \LaTeX\ commands to execute in text mode
  1434. %    and \LaTeX\ commands to execute in math mode.
  1435. %  \begin{macro}{\rm}
  1436. %  \begin{macro}{\tt}
  1437. %  \begin{macro}{\sf}
  1438. %    The commands to change the family.
  1439. % \changes{v1.0a}{1993/12/14}{Added compatibility mode support.}
  1440. % \changes{v1.1}{1993/12/18}{Changed \cs{@newfontswitch} to
  1441. %    \cs{@renewfontswitch}, removed switch.}
  1442. % \changes{v1.2d}{1994/04/14}{\cs{@renewfontswitch} has become
  1443. %    \cs{DeclareOldFontCommand}}
  1444. %    \begin{macrocode}
  1445. \DeclareOldFontCommand{\rm}{\normalfont\rmfamily}{\mathrm}
  1446. \DeclareOldFontCommand{\sf}{\normalfont\sffamily}{\mathsf}
  1447. \DeclareOldFontCommand{\tt}{\normalfont\ttfamily}{\mathtt}
  1448. %    \end{macrocode}
  1449. %  \end{macro}
  1450. %  \end{macro}
  1451. %  \end{macro}
  1452. %  \begin{macro}{\bf}
  1453. %    The command to change to the bold series. One should use
  1454. %    |\mdseries| to explicitly switch back to medium series.
  1455. % \changes{v1.0a}{1993/12/14}{Added compatibility mode support.}
  1456. % \changes{v1.1}{1993/12/18}{Changed \cs{@newfontswitch} to
  1457. %    \cs{@renewfontswitch}, removed switch.}
  1458. %    \begin{macrocode}
  1459. \DeclareOldFontCommand{\bf}{\normalfont\bfseries}{\mathbf}
  1460. %    \end{macrocode}
  1461. %  \end{macro}
  1462. %  \begin{macro}{\sl}
  1463. %  \begin{macro}{\it}
  1464. %  \begin{macro}{\sc}
  1465. %    And the commands to change the shape of the font. The slanted and
  1466. %    small caps shapes are not available by default as math alphabets,
  1467. %    so those changes do nothing in math mode. One should use
  1468. %    |\upshape| to explicitly change back to the upright shape.
  1469. % \changes{v1.0a}{1993/12/14}{Added compatibility mode support.}
  1470. % \changes{v1.1}{1993/12/18}{Changed \cs{@newfontswitch} to
  1471. %    \cs{@renewfontswitch}, removed switch.}
  1472. % \changes{v1.1b}{1993/12/20}{Added forgotten re.}
  1473. %    \begin{macrocode}
  1474. \DeclareOldFontCommand{\it}{\normalfont\itshape}{\mathit}
  1475. \DeclareOldFontCommand{\sl}{\normalfont\slshape}{\relax}
  1476. \DeclareOldFontCommand{\sc}{\normalfont\scshape}{\relax}
  1477. %    \end{macrocode}
  1478. %  \end{macro}
  1479. %  \end{macro}
  1480. %  \end{macro}
  1481. % \begin{macro}{\cal}
  1482. % \changes{v1.0a}{1993/12/14}{Macro added}
  1483. % \begin{macro}{\mit}
  1484. % \changes{v1.0a}{1993/12/14}{Macro added}
  1485. %    The commands |\cal| and |\mit| should only be used in math mode,
  1486. %    outside math mode they have no effect. Currently the New Font
  1487. %    Selection Scheme defines these commands to generate warning
  1488. %    messages. Therefore we have to define them `by hand'.
  1489. % \changes{v1.2p}{1994/12/11}{Now define \cs{cal} and \cs{mit} using
  1490. %    \cs{DeclareRobustCommand*}}
  1491. %    \begin{macrocode}
  1492. \DeclareRobustCommand*{\cal}{\@fontswitch{\relax}{\mathcal}}
  1493. \DeclareRobustCommand*{\mit}{\@fontswitch{\relax}{\mathnormal}}
  1494. %    \end{macrocode}
  1495. %  \end{macro}
  1496. %  \end{macro}
  1497. % \subsection{Footnotes}
  1498. % \begin{macro}{\footnoterule}
  1499. %    Usually, footnotes are separated from the main body of the text
  1500. %    by a small rule. This rule is drawn by the macro |\footnoterule|.
  1501. %    We have to make sure that the rule takes no vertical space (see
  1502. %    \file{plain.tex}) so we compensate for the natural height of the
  1503. %    rule of 0.4pt by adding the right amount of vertical skip.
  1504. %    To prevent the rule from colliding with the footnote we first add
  1505. %    a little negative vertical skip, then we put the rule and make
  1506. %    sure we end up at the same point where we begun this operation.
  1507. %    \begin{macrocode}
  1508. \renewcommand\footnoterule{%
  1509.   \kern-\p@
  1510.   \hrule \@width .4\columnwidth
  1511.   \kern .6\p@}
  1512. %    \end{macrocode}
  1513. % \end{macro}
  1514. % \begin{macro}{\c@footnote}
  1515. %    A counter for footnotes.
  1516. %    \begin{macrocode}
  1517. % \newcounter{footnote}
  1518. %    \end{macrocode}
  1519. % \end{macro}
  1520. % \begin{macro}{\@makefntext}
  1521. % \changes{v1.2c}{1994/03/08}{Always call \cs{@makefnmark}.}
  1522. %    The footnote mechanism of \LaTeX{} calls the macro |\@makefntext|
  1523. %    to produce the actual footnote. The macro gets the text of the
  1524. %    footnote as its argument and should use |\@makefnmark| to produce
  1525. %    the mark of the footnote. The macro |\@makefntext| is called when
  1526. %    effectively inside a |\parbox| of width |\columnwidth| (i.e.,
  1527. %    with |\hsize| = |\columnwidth|).
  1528. %   An example of what can be achieved is given by the following piece
  1529. %   of \TeX\ code.
  1530. % \begin{verbatim}
  1531. %          \long\def\@makefntext#1{%
  1532. %             \@setpar{\@@par
  1533. %                      \@tempdima = \hsize
  1534. %                      \advance\@tempdima-10pt
  1535. %                      \parshape \@ne 10pt \@tempdima}%
  1536. %             \par
  1537. %             \parindent 1em\noindent
  1538. %             \hb@xt@\z@{\hss\@makefnmark}#1}
  1539. % \end{verbatim}
  1540. %    The effect of this definition is that all lines of the footnote
  1541. %    are indented by 10pt, while the first line of a new paragraph is
  1542. %    indented by 1em. To change these dimensions, just substitute the
  1543. %    desired value for `10pt' (in both places) or `1em'.  The mark is
  1544. %    flush right against the footnote.
  1545. %    In these document class we use a simpler macro, in which the
  1546. %    footnote text is set like an ordinary text paragraph, with no
  1547. %    indentation except on the first line of a paragraph, and the
  1548. %    first line of the footnote. Thus, all the macro must do is set
  1549. %    |\parindent| to the appropriate value for succeeding paragraphs
  1550. %    and put the proper indentation before the mark.
  1551. %    \begin{macrocode}
  1552. \long\def\@makefntext#1{%
  1553.     \noindent
  1554.     \hangindent 5\p@
  1555.     \hb@xt@5\p@{\hss\@makefnmark}#1}
  1556. %    \end{macrocode}
  1557. % \end{macro}
  1558. % \begin{macro}{\@makefnmark}
  1559. %    The footnote markers that are printed in the text to point to the
  1560. %    footnotes should be produced by the macro |\@makefnmark|. We use
  1561. %    the default definition for it.
  1562. %    \begin{macrocode}
  1563. %\def\@makefnmark{\hbox{$^{\@thefnmark}\m@th$}}
  1564. %    \end{macrocode}
  1565. % \end{macro}
  1566. % \subsection{Words}
  1567. % \begin{macro}{\ccname}
  1568. % \begin{macro}{\enclname}
  1569. % \begin{macro}{\pagename}
  1570. % \begin{macro}{\headtoname}
  1571. %     This document class is for documents prepared in the English
  1572. %     language. To prepare a version for another language, various
  1573. %     English words must be replaced.  All the English words that
  1574. %     require replacement are  defined below in command names.
  1575. %    \begin{macrocode}
  1576. \newcommand*{\ccname}{cc}
  1577. \newcommand*{\enclname}{encl}
  1578. \newcommand*{\pagename}{Page}
  1579. \newcommand*{\headtoname}{To}
  1580. %    \end{macrocode}
  1581. % \end{macro}
  1582. % \end{macro}
  1583. % \end{macro}
  1584. % \end{macro}
  1585. % \subsection{Date}
  1586. % \begin{macro}{\today}
  1587. %    This macro uses the \TeX\ primitives |\month|, |\day| and |\year|
  1588. %    to provide the date of the \LaTeX-run.
  1589. %    \begin{macrocode}
  1590. \newcommand*{\today}{\ifcase\month\or
  1591.   January\or February\or March\or April\or May\or June\or
  1592.   July\or August\or September\or October\or November\or December\fi
  1593.   \space\number\day, \number\year}
  1594. %    \end{macrocode}
  1595. % \end{macro}
  1596. % \subsection{Two column mode}
  1597. % \begin{macro}{\columnsep}
  1598. %    This gives the distance between two columns in two column mode.
  1599. %    \begin{macrocode}
  1600. \setlength\columnsep{10\p@}
  1601. %    \end{macrocode}
  1602. % \end{macro}
  1603. % \begin{macro}{\columnseprule}
  1604. %    This gives the width of the rule between two columns in two
  1605. %    column mode. We have no visible rule.
  1606. %    \begin{macrocode}
  1607. \setlength\columnseprule{0\p@}
  1608. %    \end{macrocode}
  1609. % \end{macro}
  1610. % \subsection{The page style} 
  1611. %    We have \pstyle{plain} pages in this document class by
  1612. %    default. We use arabic page numbers.
  1613. %    \begin{macrocode}
  1614. \pagestyle{plain}
  1615. \pagenumbering{arabic}
  1616. %    \end{macrocode}
  1617. % \subsection{Single or double sided printing}
  1618. %    We don't try to make each page as long as all the others.
  1619. %    \begin{macrocode}
  1620. \raggedbottom
  1621. %    \end{macrocode}
  1622. % \begin{macro}{\@texttop}
  1623. %    The document class letter sets |\@texttop| to |\vskip| 0pt
  1624. %    \texttt{plus} .00006fil on the first page of a letter, which
  1625. %    centers a short letter on the page. This fil value may have to be
  1626. %    changed for other letterheads.  This setting has to be done after
  1627. %    |\raggedbottom| is executed, since the latter sets |\@texttop| to
  1628. %    |\relax|.
  1629. %    \begin{macrocode}
  1630. \def\@texttop{\ifnum\c@page=1\vskip \z@ plus.00006fil\relax\fi}
  1631. %    \end{macrocode}
  1632. % \end{macro}
  1633. %    We always start in one column mode.
  1634. %    \begin{macrocode}
  1635. \onecolumn
  1636. %</letter>
  1637. %    \end{macrocode}
  1638. % \Finale
  1639. \endinput
  1640.