| 
									
										
										
										
											1998-03-03 22:02:19 +00:00
										 |  |  | % | 
					
						
							|  |  |  | % manual.cls for the Python documentation | 
					
						
							|  |  |  | % | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | \NeedsTeXFormat{LaTeX2e}[1995/12/01] | 
					
						
							|  |  |  | \ProvidesClass{manual} | 
					
						
							| 
									
										
										
										
											1998-03-04 21:47:59 +00:00
										 |  |  |              [1998/03/03 Document class (Python manual)] | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-04-25 04:12:17 +00:00
										 |  |  | \RequirePackage{pypaper} | 
					
						
							| 
									
										
										
										
											1998-03-03 22:02:19 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-04-25 04:12:17 +00:00
										 |  |  | % Change the options here to get a different set of basic options, but only | 
					
						
							|  |  |  | % if you have to.  Paper and font size should be adjusted in pypaper.sty. | 
					
						
							| 
									
										
										
										
											1998-03-03 22:02:19 +00:00
										 |  |  | % | 
					
						
							| 
									
										
										
										
											1998-04-25 04:12:17 +00:00
										 |  |  | \LoadClass[\py@paper,\py@ptsize,twoside,openright]{report} | 
					
						
							| 
									
										
										
										
											1998-03-03 22:02:19 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1999-06-29 18:15:59 +00:00
										 |  |  | \setcounter{secnumdepth}{2} | 
					
						
							| 
									
										
										
										
											1998-03-03 22:02:19 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | % Optional packages: | 
					
						
							|  |  |  | % | 
					
						
							|  |  |  | % If processing of these documents fails at your TeX installation, | 
					
						
							|  |  |  | % these may be commented out (independently) to make things work. | 
					
						
							|  |  |  | % These are both supplied with the current version of the teTeX | 
					
						
							|  |  |  | % distribution. | 
					
						
							|  |  |  | % | 
					
						
							|  |  |  | % The "fancyhdr" package makes nicer page footers reasonable to
 | 
					
						
							|  |  |  | % implement, and is used to put the chapter and section information in 
 | 
					
						
							|  |  |  | % the footers. | 
					
						
							|  |  |  | % | 
					
						
							|  |  |  | \RequirePackage{fancyhdr}\typeout{Using fancier footers than usual.} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-03-25 15:41:23 +00:00
										 |  |  | % Required packages: | 
					
						
							|  |  |  | % | 
					
						
							|  |  |  | % The "fncychap" package is used to get the nice chapter headers.  The | 
					
						
							|  |  |  | % .sty file is distributed with Python, so you should not need to disable
 | 
					
						
							|  |  |  | % it.  You'd also end up with a mixed page style; uglier than stock LaTeX! | 
					
						
							|  |  |  | % | 
					
						
							|  |  |  | \RequirePackage[Bjarne]{fncychap}\typeout{Using fancy chapter headings.} | 
					
						
							|  |  |  | % Do horizontal rules it this way to match: | 
					
						
							| 
									
										
										
										
											1998-04-28 18:31:50 +00:00
										 |  |  | \newcommand{\py@doHorizontalRule}{\mghrulefill{\RW}} | 
					
						
							| 
									
										
										
										
											1998-03-25 15:41:23 +00:00
										 |  |  | % | 
					
						
							| 
									
										
										
										
											1998-03-03 22:02:19 +00:00
										 |  |  | % | 
					
						
							|  |  |  | % This gives us all the Python-specific markup that we really want. | 
					
						
							|  |  |  | % This should come last.  Do not change this. | 
					
						
							|  |  |  | % | 
					
						
							|  |  |  | \RequirePackage{python} | 
					
						
							| 
									
										
										
										
											1998-03-04 21:47:59 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-07-23 17:36:14 +00:00
										 |  |  | % support for module synopsis sections: | 
					
						
							|  |  |  | \newcommand{\py@ModSynopsisFilename}{\jobname\thechapter.syn} | 
					
						
							|  |  |  | \let\py@OldChapter=\chapter | 
					
						
							|  |  |  | \renewcommand{\chapter}{
 | 
					
						
							|  |  |  |   \py@ProcessModSynopsis | 
					
						
							|  |  |  |   \py@closeModSynopsisFile | 
					
						
							|  |  |  |   \py@OldChapter | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-03-04 21:47:59 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | % Change the title page to look a bit better, and fit in with the | 
					
						
							|  |  |  | % fncychap ``Bjarne'' style a bit better. | 
					
						
							|  |  |  | % | 
					
						
							|  |  |  | \renewcommand{\maketitle}{%
 | 
					
						
							|  |  |  |   \begin{titlepage}% | 
					
						
							|  |  |  |     \let\footnotesize\small | 
					
						
							|  |  |  |     \let\footnoterule\relax | 
					
						
							| 
									
										
										
										
											1998-04-28 18:31:50 +00:00
										 |  |  |     \py@doHorizontalRule% | 
					
						
							| 
									
										
										
										
											2000-09-05 15:19:56 +00:00
										 |  |  |     \@ifundefined{pdfinfo}{}{{
 | 
					
						
							|  |  |  |       % This \def is required to deal with multi-line authors; it | 
					
						
							|  |  |  |       % changes \\ to ', ' (comma-space), making it pass muster for
 | 
					
						
							|  |  |  |       % generating document info in the PDF file. | 
					
						
							|  |  |  |       \def\\{, } | 
					
						
							| 
									
										
										
										
											1998-03-25 14:53:43 +00:00
										 |  |  |       \pdfinfo{
 | 
					
						
							|  |  |  |         /Author (\@author) | 
					
						
							|  |  |  |         /Title (\@title) | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2000-09-05 15:19:56 +00:00
										 |  |  |     }} | 
					
						
							| 
									
										
										
										
											1998-03-04 21:47:59 +00:00
										 |  |  |     \begin{flushright}% | 
					
						
							| 
									
										
										
										
											1998-04-28 18:31:50 +00:00
										 |  |  |       {\rm\Huge\py@HeaderFamily \@title \par}% | 
					
						
							| 
									
										
										
										
											2002-03-15 22:38:16 +00:00
										 |  |  |       {\em\LARGE\py@HeaderFamily \py@release\releaseinfo \par} | 
					
						
							| 
									
										
										
										
											1998-03-04 21:47:59 +00:00
										 |  |  |       \vfill | 
					
						
							| 
									
										
										
										
											1998-04-28 18:31:50 +00:00
										 |  |  |       {\LARGE\py@HeaderFamily \@author \par} | 
					
						
							| 
									
										
										
										
											1998-03-04 21:47:59 +00:00
										 |  |  |       \vfill\vfill | 
					
						
							|  |  |  |       {\large
 | 
					
						
							|  |  |  |        \@date \par | 
					
						
							|  |  |  |        \vfill | 
					
						
							| 
									
										
										
										
											1998-04-28 18:31:50 +00:00
										 |  |  |        \py@authoraddress \par | 
					
						
							| 
									
										
										
										
											1998-03-04 21:47:59 +00:00
										 |  |  |       }% | 
					
						
							|  |  |  |     \end{flushright}%\par | 
					
						
							|  |  |  |     \@thanks | 
					
						
							|  |  |  |   \end{titlepage}% | 
					
						
							|  |  |  |   \setcounter{footnote}{0}% | 
					
						
							|  |  |  |   \let\thanks\relax\let\maketitle\relax | 
					
						
							|  |  |  |   \gdef\@thanks{}\gdef\@author{}\gdef\@title{} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-03-05 16:41:42 +00:00
										 |  |  | % Catch the end of the {abstract} environment, but here make sure the | 
					
						
							|  |  |  | % abstract is followed by a blank page if the 'openright' option is used. | 
					
						
							|  |  |  | % | 
					
						
							| 
									
										
										
										
											1998-04-28 18:31:50 +00:00
										 |  |  | \let\py@OldEndAbstract=\endabstract | 
					
						
							| 
									
										
										
										
											1998-03-05 16:41:42 +00:00
										 |  |  | \renewcommand{\endabstract}{
 | 
					
						
							|  |  |  |   \if@openright | 
					
						
							|  |  |  |     \ifodd\value{page} | 
					
						
							|  |  |  |       \typeout{Adding blank page after the abstract.} | 
					
						
							|  |  |  |       \vfil\pagebreak | 
					
						
							|  |  |  |     \fi | 
					
						
							|  |  |  |   \fi | 
					
						
							| 
									
										
										
										
											1998-04-28 18:31:50 +00:00
										 |  |  |   \py@OldEndAbstract | 
					
						
							| 
									
										
										
										
											1998-03-05 16:41:42 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-03-04 21:47:59 +00:00
										 |  |  | % This wraps the \tableofcontents macro with all the magic to get the | 
					
						
							|  |  |  | % spacing right and have the right number of pages if the 'openright' | 
					
						
							|  |  |  | % option has been used.  This eliminates a fair amount of crud in the | 
					
						
							|  |  |  | % individual document files. | 
					
						
							|  |  |  | % | 
					
						
							| 
									
										
										
										
											1998-04-28 18:31:50 +00:00
										 |  |  | \let\py@OldTableofcontents=\tableofcontents | 
					
						
							| 
									
										
										
										
											1998-03-04 21:47:59 +00:00
										 |  |  | \renewcommand{\tableofcontents}{%
 | 
					
						
							|  |  |  |   \setcounter{page}{1}% | 
					
						
							|  |  |  |   \pagebreak% | 
					
						
							|  |  |  |   \pagestyle{plain}% | 
					
						
							|  |  |  |   {%
 | 
					
						
							|  |  |  |     \parskip = 0mm% | 
					
						
							| 
									
										
										
										
											1998-04-28 18:31:50 +00:00
										 |  |  |     \py@OldTableofcontents% | 
					
						
							| 
									
										
										
										
											1998-03-04 21:47:59 +00:00
										 |  |  |     \if@openright% | 
					
						
							|  |  |  |       \ifodd\value{page}% | 
					
						
							|  |  |  |         \typeout{Adding blank page after the table of contents.}% | 
					
						
							|  |  |  |         \pagebreak\hspace{0pt}% | 
					
						
							|  |  |  |       \fi% | 
					
						
							|  |  |  |     \fi% | 
					
						
							|  |  |  |     \cleardoublepage% | 
					
						
							|  |  |  |   }% | 
					
						
							|  |  |  |   \pagenumbering{arabic}% | 
					
						
							|  |  |  |   \@ifundefined{fancyhf}{}{\pagestyle{normal}}% | 
					
						
							| 
									
										
										
										
											1998-04-28 18:31:50 +00:00
										 |  |  |   \py@doing@page@targetstrue% | 
					
						
							| 
									
										
										
										
											1998-03-04 21:47:59 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											1998-04-20 16:55:14 +00:00
										 |  |  | % This is needed to get the width of the section # area wide enough in the | 
					
						
							|  |  |  | % library reference.  Doing it here keeps it the same for all the manuals. | 
					
						
							|  |  |  | % | 
					
						
							|  |  |  | \renewcommand*\l@section{\@dottedtocline{1}{1.5em}{2.6em}} | 
					
						
							|  |  |  | \renewcommand*\l@subsection{\@dottedtocline{2}{4.1em}{3.5em}} | 
					
						
							| 
									
										
										
										
											1998-07-24 13:54:29 +00:00
										 |  |  | \setcounter{tocdepth}{1} | 
					
						
							| 
									
										
										
										
											1998-04-17 02:45:41 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | % Fix the theindex environment to add an entry to the Table of
 | 
					
						
							|  |  |  | % Contents; this is much nicer than just having to jump to the end of
 | 
					
						
							|  |  |  | % the book and flip around, especially with multiple indexes. | 
					
						
							|  |  |  | % | 
					
						
							| 
									
										
										
										
											1998-04-28 18:31:50 +00:00
										 |  |  | \let\py@OldTheindex=\theindex | 
					
						
							| 
									
										
										
										
											1998-04-17 02:45:41 +00:00
										 |  |  | \renewcommand{\theindex}{
 | 
					
						
							|  |  |  |   \cleardoublepage | 
					
						
							| 
									
										
										
										
											1998-04-28 18:31:50 +00:00
										 |  |  |   \py@OldTheindex | 
					
						
							| 
									
										
										
										
											1998-04-17 02:45:41 +00:00
										 |  |  |   \addcontentsline{toc}{chapter}{\indexname} | 
					
						
							|  |  |  | } |