| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1 | \documentclass{howto} | 
|  | 2 | \usepackage{ltxmarkup} | 
|  | 3 |  | 
|  | 4 | \title{Documenting Python} | 
|  | 5 |  | 
| Skip Montanaro | 176bda4cd | 2002-04-19 04:50:44 +0000 | [diff] [blame] | 6 | \makeindex | 
|  | 7 |  | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 8 | \input{boilerplate} | 
|  | 9 |  | 
| Fred Drake | c7c9a64 | 1999-04-28 18:24:02 +0000 | [diff] [blame] | 10 | % Now override the stuff that includes author information; | 
|  | 11 | % Guido did *not* write this one! | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 12 |  | 
|  | 13 | \author{Fred L. Drake, Jr.} | 
|  | 14 | \authoraddress{ | 
| Fred Drake | 8fdb638 | 2000-10-28 04:08:38 +0000 | [diff] [blame] | 15 | PythonLabs \\ | 
| Fred Drake | 9120df3 | 2001-07-14 02:34:12 +0000 | [diff] [blame] | 16 | Email: \email{fdrake@acm.org} | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 17 | } | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 18 |  | 
|  | 19 |  | 
|  | 20 | \begin{document} | 
|  | 21 |  | 
|  | 22 | \maketitle | 
|  | 23 |  | 
|  | 24 | \begin{abstract} | 
|  | 25 | \noindent | 
| Fred Drake | 0299749 | 2000-09-21 05:26:43 +0000 | [diff] [blame] | 26 | The Python language has a substantial body of | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 27 | documentation, much of it contributed by various authors.  The markup | 
|  | 28 | used for the Python documentation is based on \LaTeX{} and requires a | 
|  | 29 | significant set of macros written specifically for documenting Python. | 
| Fred Drake | 5eb992b | 1999-06-11 14:25:45 +0000 | [diff] [blame] | 30 | This document describes the macros introduced to support Python | 
|  | 31 | documentation and how they should be used to support a wide range of | 
|  | 32 | output formats. | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 33 |  | 
|  | 34 | This document describes the document classes and special markup used | 
|  | 35 | in the Python documentation.  Authors may use this guide, in | 
|  | 36 | conjunction with the template files provided with the | 
|  | 37 | distribution, to create or maintain whole documents or sections. | 
|  | 38 | \end{abstract} | 
|  | 39 |  | 
|  | 40 | \tableofcontents | 
|  | 41 |  | 
|  | 42 |  | 
| Fred Drake | f1b3de8 | 2001-07-24 14:38:34 +0000 | [diff] [blame] | 43 | \section{Introduction \label{intro}} | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 44 |  | 
|  | 45 | Python's documentation has long been considered to be good for a | 
|  | 46 | free programming language.  There are a number of reasons for this, | 
|  | 47 | the most important being the early commitment of Python's creator, | 
|  | 48 | Guido van Rossum, to providing documentation on the language and its | 
|  | 49 | libraries, and the continuing involvement of the user community in | 
|  | 50 | providing assistance for creating and maintaining documentation. | 
|  | 51 |  | 
|  | 52 | The involvement of the community takes many forms, from authoring to | 
| Fred Drake | 7a737df | 1999-04-23 14:41:44 +0000 | [diff] [blame] | 53 | bug reports to just plain complaining when the documentation could | 
|  | 54 | be more complete or easier to use.  All of these forms of input from | 
|  | 55 | the community have proved useful during the time I've been involved | 
|  | 56 | in maintaining the documentation. | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 57 |  | 
| Fred Drake | 2c4e009 | 1999-03-29 14:55:55 +0000 | [diff] [blame] | 58 | This document is aimed at authors and potential authors of | 
| Fred Drake | 7a737df | 1999-04-23 14:41:44 +0000 | [diff] [blame] | 59 | documentation for Python.  More specifically, it is for people | 
|  | 60 | contributing to the standard documentation and developing additional | 
|  | 61 | documents using the same tools as the standard documents.  This | 
|  | 62 | guide will be less useful for authors using the Python documentation | 
|  | 63 | tools for topics other than Python, and less useful still for | 
|  | 64 | authors not using the tools at all. | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 65 |  | 
| Fred Drake | 2c4e009 | 1999-03-29 14:55:55 +0000 | [diff] [blame] | 66 | The material in this guide is intended to assist authors using the | 
|  | 67 | Python documentation tools.  It includes information on the source | 
|  | 68 | distribution of the standard documentation, a discussion of the | 
| Fred Drake | 7a737df | 1999-04-23 14:41:44 +0000 | [diff] [blame] | 69 | document types, reference material on the markup defined in the | 
|  | 70 | document classes, a list of the external tools needed for processing | 
| Fred Drake | 2c4e009 | 1999-03-29 14:55:55 +0000 | [diff] [blame] | 71 | documents, and reference material on the tools provided with the | 
|  | 72 | documentation resources.  At the end, there is also a section | 
| Fred Drake | 7a737df | 1999-04-23 14:41:44 +0000 | [diff] [blame] | 73 | discussing future directions for the Python documentation and where | 
|  | 74 | to turn for more information. | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 75 |  | 
| Fred Drake | f1b3de8 | 2001-07-24 14:38:34 +0000 | [diff] [blame] | 76 | \section{Directory Structure \label{directories}} | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 77 |  | 
|  | 78 | The source distribution for the standard Python documentation | 
|  | 79 | contains a large number of directories.  While third-party documents | 
|  | 80 | do not need to be placed into this structure or need to be placed | 
|  | 81 | within a similar structure, it can be helpful to know where to look | 
|  | 82 | for examples and tools when developing new documents using the | 
|  | 83 | Python documentation tools.  This section describes this directory | 
|  | 84 | structure. | 
|  | 85 |  | 
|  | 86 | The documentation sources are usually placed within the Python | 
| Fred Drake | 7a737df | 1999-04-23 14:41:44 +0000 | [diff] [blame] | 87 | source distribution as the top-level directory \file{Doc/}, but | 
|  | 88 | are not dependent on the Python source distribution in any way. | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 89 |  | 
|  | 90 | The \file{Doc/} directory contains a few files and several | 
|  | 91 | subdirectories.  The files are mostly self-explanatory, including a | 
|  | 92 | \file{README} and a \file{Makefile}.  The directories fall into | 
|  | 93 | three categories: | 
|  | 94 |  | 
|  | 95 | \begin{definitions} | 
|  | 96 | \term{Document Sources} | 
|  | 97 | The \LaTeX{} sources for each document are placed in a | 
| Fred Drake | 0299749 | 2000-09-21 05:26:43 +0000 | [diff] [blame] | 98 | separate directory.  These directories are given short | 
|  | 99 | names which vaguely indicate the document in each: | 
| Fred Drake | 2f4bebd | 1999-04-28 16:43:11 +0000 | [diff] [blame] | 100 |  | 
|  | 101 | \begin{tableii}{p{.75in}|p{3in}}{filenq}{Directory}{Document Title} | 
| Fred Drake | 31edf4d | 2000-09-07 20:06:07 +0000 | [diff] [blame] | 102 | \lineii{api/} | 
|  | 103 | {\citetitle[../api/api.html]{The Python/C API}} | 
|  | 104 | \lineii{dist/} | 
|  | 105 | {\citetitle[../dist/dist.html]{Distributing Python Modules}} | 
|  | 106 | \lineii{doc/} | 
|  | 107 | {\citetitle[../doc/doc.html]{Documenting Python}} | 
|  | 108 | \lineii{ext/} | 
|  | 109 | {\citetitle[../ext/ext.html]{Extending and Embedding the Python Interpreter}} | 
|  | 110 | \lineii{inst/} | 
|  | 111 | {\citetitle[../inst/inst.html]{Installing Python Modules}} | 
|  | 112 | \lineii{lib/} | 
|  | 113 | {\citetitle[../lib/lib.html]{Python Library Reference}} | 
|  | 114 | \lineii{mac/} | 
|  | 115 | {\citetitle[../mac/mac.html]{Macintosh Module Reference}} | 
|  | 116 | \lineii{ref/} | 
|  | 117 | {\citetitle[../ref/ref.html]{Python Reference Manual}} | 
|  | 118 | \lineii{tut/} | 
|  | 119 | {\citetitle[../tut/tut.html]{Python Tutorial}} | 
| Fred Drake | 2f4bebd | 1999-04-28 16:43:11 +0000 | [diff] [blame] | 120 | \end{tableii} | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 121 |  | 
|  | 122 | \term{Format-Specific Output} | 
| Fred Drake | 2c4e009 | 1999-03-29 14:55:55 +0000 | [diff] [blame] | 123 | Most output formats have a directory which contains a | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 124 | \file{Makefile} which controls the generation of that format | 
|  | 125 | and provides storage for the formatted documents.  The only | 
| Fred Drake | 2c4e009 | 1999-03-29 14:55:55 +0000 | [diff] [blame] | 126 | variations within this category are the Portable Document | 
|  | 127 | Format (PDF) and PostScript versions are placed in the | 
| Fred Drake | 7a737df | 1999-04-23 14:41:44 +0000 | [diff] [blame] | 128 | directories \file{paper-a4/} and \file{paper-letter/} (this | 
|  | 129 | causes all the temporary files created by \LaTeX{} to be kept | 
|  | 130 | in the same place for each paper size, where they can be more | 
|  | 131 | easily ignored). | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 132 |  | 
| Fred Drake | 2f4bebd | 1999-04-28 16:43:11 +0000 | [diff] [blame] | 133 | \begin{tableii}{p{.75in}|p{3in}}{filenq}{Directory}{Output Formats} | 
|  | 134 | \lineii{html/}{HTML output} | 
|  | 135 | \lineii{info/}{GNU info output} | 
| Fred Drake | d6bdb07 | 2002-01-17 12:35:20 +0000 | [diff] [blame] | 136 | \lineii{isilo/}{\ulink{iSilo}{http://www.isilo.com/} | 
|  | 137 | documents (for Palm OS devices)} | 
| Fred Drake | 2f4bebd | 1999-04-28 16:43:11 +0000 | [diff] [blame] | 138 | \lineii{paper-a4/}{PDF and PostScript, A4 paper} | 
|  | 139 | \lineii{paper-letter/}{PDF and PostScript, US-Letter paper} | 
|  | 140 | \end{tableii} | 
|  | 141 |  | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 142 | \term{Supplemental Files} | 
|  | 143 | Some additional directories are used to store supplemental | 
|  | 144 | files used for the various processes.  Directories are | 
|  | 145 | included for the shared \LaTeX{} document classes, the | 
|  | 146 | \LaTeX2HTML support, template files for various document | 
|  | 147 | components, and the scripts used to perform various steps in | 
|  | 148 | the formatting processes. | 
| Fred Drake | 2f4bebd | 1999-04-28 16:43:11 +0000 | [diff] [blame] | 149 |  | 
|  | 150 | \begin{tableii}{p{.75in}|p{3in}}{filenq}{Directory}{Contents} | 
|  | 151 | \lineii{perl/}{Support for \LaTeX2HTML processing} | 
|  | 152 | \lineii{templates/}{Example files for source documents} | 
|  | 153 | \lineii{texinputs/}{Style implementation for \LaTeX} | 
|  | 154 | \lineii{tools/}{Custom processing scripts} | 
|  | 155 | \end{tableii} | 
|  | 156 |  | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 157 | \end{definitions} | 
|  | 158 |  | 
| Fred Drake | 2c4e009 | 1999-03-29 14:55:55 +0000 | [diff] [blame] | 159 |  | 
| Fred Drake | f1b3de8 | 2001-07-24 14:38:34 +0000 | [diff] [blame] | 160 | \section{Style Guide \label{style-guide}} | 
| Fred Drake | 432cef0 | 2001-07-06 22:34:33 +0000 | [diff] [blame] | 161 |  | 
|  | 162 | The Python documentation should follow the \citetitle | 
| Fred Drake | 192b95b | 2003-07-11 03:34:17 +0000 | [diff] [blame^] | 163 | [http://developer.apple.com/documentation/UserExperience/Conceptual/APStyleGuide/AppleStyleGuide2003.pdf] | 
| Fred Drake | 432cef0 | 2001-07-06 22:34:33 +0000 | [diff] [blame] | 164 | {Apple Publications Style Guide} wherever possible.  This particular | 
|  | 165 | style guide was selected mostly because it seems reasonable and is | 
| Fred Drake | 192b95b | 2003-07-11 03:34:17 +0000 | [diff] [blame^] | 166 | easy to get online. | 
| Fred Drake | 432cef0 | 2001-07-06 22:34:33 +0000 | [diff] [blame] | 167 |  | 
|  | 168 | Topics which are not covered in the Apple's style guide will be | 
|  | 169 | discussed in this document if necessary. | 
|  | 170 |  | 
|  | 171 | Many special names are used in the Python documentation, including | 
|  | 172 | the names of operating systems, programming languages, standards | 
|  | 173 | bodies, and the like.  Many of these were assigned \LaTeX{} macros | 
|  | 174 | at some point in the distant past, and these macros lived on long | 
| Fred Drake | 9120df3 | 2001-07-14 02:34:12 +0000 | [diff] [blame] | 175 | past their usefulness.  In the current markup, most of these entities | 
|  | 176 | are not assigned any special markup, but the preferred spellings are | 
| Fred Drake | 432cef0 | 2001-07-06 22:34:33 +0000 | [diff] [blame] | 177 | given here to aid authors in maintaining the consistency of | 
|  | 178 | presentation in the Python documentation. | 
|  | 179 |  | 
| Fred Drake | 9120df3 | 2001-07-14 02:34:12 +0000 | [diff] [blame] | 180 | Other terms and words deserve special mention as well; these conventions | 
|  | 181 | should be used to ensure consistency throughout the documentation: | 
|  | 182 |  | 
| Fred Drake | 432cef0 | 2001-07-06 22:34:33 +0000 | [diff] [blame] | 183 | \begin{description} | 
| Fred Drake | 9120df3 | 2001-07-14 02:34:12 +0000 | [diff] [blame] | 184 | \item[CPU] | 
|  | 185 | For ``central processing unit.''  Many style guides say this | 
|  | 186 | should be spelled out on the first use (and if you must use it, | 
|  | 187 | do so!).  For the Python documentation, this abbreviation should | 
|  | 188 | be avoided since there's no reasonable way to predict which occurance | 
|  | 189 | will be the first seen by the reader.  It is better to use the | 
|  | 190 | word ``processor'' instead. | 
|  | 191 |  | 
|  | 192 | \item[\POSIX] | 
| Fred Drake | 432cef0 | 2001-07-06 22:34:33 +0000 | [diff] [blame] | 193 | The name assigned to a particular group of standards.  This is | 
| Fred Drake | 9120df3 | 2001-07-14 02:34:12 +0000 | [diff] [blame] | 194 | always uppercase.  Use the macro \macro{POSIX} to represent this | 
|  | 195 | name. | 
| Fred Drake | 432cef0 | 2001-07-06 22:34:33 +0000 | [diff] [blame] | 196 |  | 
|  | 197 | \item[Python] | 
|  | 198 | The name of our favorite programming language is always | 
|  | 199 | capitalized. | 
|  | 200 |  | 
|  | 201 | \item[Unicode] | 
|  | 202 | The name of a character set and matching encoding.  This is | 
| Fred Drake | 9120df3 | 2001-07-14 02:34:12 +0000 | [diff] [blame] | 203 | always written capitalized. | 
|  | 204 |  | 
|  | 205 | \item[\UNIX] | 
|  | 206 | The name of the operating system developed at AT\&T Bell Labs | 
|  | 207 | in the early 1970s.  Use the macro \macro{UNIX} to use this name. | 
| Fred Drake | 432cef0 | 2001-07-06 22:34:33 +0000 | [diff] [blame] | 208 | \end{description} | 
|  | 209 |  | 
|  | 210 |  | 
| Fred Drake | adade92 | 1999-04-22 13:05:27 +0000 | [diff] [blame] | 211 | \section{\LaTeX{} Primer \label{latex-primer}} | 
| Fred Drake | 2c4e009 | 1999-03-29 14:55:55 +0000 | [diff] [blame] | 212 |  | 
| Fred Drake | adade92 | 1999-04-22 13:05:27 +0000 | [diff] [blame] | 213 | This section is a brief introduction to \LaTeX{} concepts and | 
|  | 214 | syntax, to provide authors enough information to author documents | 
|  | 215 | productively without having to become ``\TeX{}nicians.'' | 
|  | 216 |  | 
| Fred Drake | 5eb992b | 1999-06-11 14:25:45 +0000 | [diff] [blame] | 217 | Perhaps the most important concept to keep in mind while marking up | 
| Fred Drake | 0299749 | 2000-09-21 05:26:43 +0000 | [diff] [blame] | 218 | Python documentation is that while \TeX{} is unstructured, \LaTeX{} was | 
| Fred Drake | 5eb992b | 1999-06-11 14:25:45 +0000 | [diff] [blame] | 219 | designed as a layer on top of \TeX{} which specifically supports | 
|  | 220 | structured markup.  The Python-specific markup is intended to extend | 
|  | 221 | the structure provided by standard \LaTeX{} document classes to | 
|  | 222 | support additional information specific to Python. | 
|  | 223 |  | 
| Fred Drake | adade92 | 1999-04-22 13:05:27 +0000 | [diff] [blame] | 224 | \LaTeX{} documents contain two parts: the preamble and the body. | 
|  | 225 | The preamble is used to specify certain metadata about the document | 
|  | 226 | itself, such as the title, the list of authors, the date, and the | 
|  | 227 | \emph{class} the document belongs to.  Additional information used | 
|  | 228 | to control index generation and the use of bibliographic databases | 
| Fred Drake | 7a737df | 1999-04-23 14:41:44 +0000 | [diff] [blame] | 229 | can also be placed in the preamble.  For most authors, the preamble | 
| Fred Drake | adade92 | 1999-04-22 13:05:27 +0000 | [diff] [blame] | 230 | can be most easily created by copying it from an existing document | 
|  | 231 | and modifying a few key pieces of information. | 
|  | 232 |  | 
|  | 233 | The \dfn{class} of a document is used to place a document within a | 
|  | 234 | broad category of documents and set some fundamental formatting | 
|  | 235 | properties.  For Python documentation, two classes are used: the | 
|  | 236 | \code{manual} class and the \code{howto} class.  These classes also | 
|  | 237 | define the additional markup used to document Python concepts and | 
|  | 238 | structures.  Specific information about these classes is provided in | 
| Fred Drake | 7a737df | 1999-04-23 14:41:44 +0000 | [diff] [blame] | 239 | section \ref{classes}, ``Document Classes,'' below.  The first thing | 
| Fred Drake | adade92 | 1999-04-22 13:05:27 +0000 | [diff] [blame] | 240 | in the preamble is the declaration of the document's class. | 
|  | 241 |  | 
|  | 242 | After the class declaration, a number of \emph{macros} are used to | 
|  | 243 | provide further information about the document and setup any | 
| Fred Drake | 7a737df | 1999-04-23 14:41:44 +0000 | [diff] [blame] | 244 | additional markup that is needed.  No output is generated from the | 
|  | 245 | preamble; it is an error to include free text in the preamble | 
|  | 246 | because it would cause output. | 
| Fred Drake | adade92 | 1999-04-22 13:05:27 +0000 | [diff] [blame] | 247 |  | 
|  | 248 | The document body follows the preamble.  This contains all the | 
| Fred Drake | 63568aa | 2000-10-19 05:36:10 +0000 | [diff] [blame] | 249 | printed components of the document marked up structurally.  Generic | 
| Fred Drake | 4c6f17a | 2001-04-18 05:12:47 +0000 | [diff] [blame] | 250 | \LaTeX{} structures include hierarchical sections, numbered and | 
|  | 251 | bulleted lists, and special structures for the document abstract and | 
|  | 252 | indexes. | 
| Fred Drake | adade92 | 1999-04-22 13:05:27 +0000 | [diff] [blame] | 253 |  | 
| Fred Drake | f1b3de8 | 2001-07-24 14:38:34 +0000 | [diff] [blame] | 254 | \subsection{Syntax \label{latex-syntax}} | 
| Fred Drake | 63568aa | 2000-10-19 05:36:10 +0000 | [diff] [blame] | 255 |  | 
| Fred Drake | 4c6f17a | 2001-04-18 05:12:47 +0000 | [diff] [blame] | 256 | There are some things that an author of Python documentation needs | 
|  | 257 | to know about \LaTeX{} syntax. | 
| Fred Drake | 63568aa | 2000-10-19 05:36:10 +0000 | [diff] [blame] | 258 |  | 
|  | 259 | A \dfn{comment} is started by the ``percent'' character | 
|  | 260 | (\character{\%}) and continues through the end of the line and all | 
|  | 261 | leading whitespace on the following line.  This is a little | 
|  | 262 | different from any programming language I know of, so an example | 
|  | 263 | is in order: | 
|  | 264 |  | 
|  | 265 | \begin{verbatim} | 
|  | 266 | This is text.% comment | 
|  | 267 | This is more text.  % another comment | 
|  | 268 | Still more text. | 
|  | 269 | \end{verbatim} | 
|  | 270 |  | 
|  | 271 | The first non-comment character following the first comment is the | 
|  | 272 | letter \character{T} on the second line; the leading whitespace on | 
|  | 273 | that line is consumed as part of the first comment.  This means | 
|  | 274 | that there is no space between the first and second sentences, so | 
|  | 275 | the period and letter \character{T} will be directly adjacent in | 
|  | 276 | the typeset document. | 
|  | 277 |  | 
|  | 278 | Note also that though the first non-comment character after the | 
|  | 279 | second comment is the letter \character{S}, there is whitespace | 
|  | 280 | preceding the comment, so the two sentences are separated as | 
|  | 281 | expected. | 
|  | 282 |  | 
|  | 283 | A \dfn{group} is an enclosure for a collection of text and | 
|  | 284 | commands which encloses the formatting context and constrains the | 
|  | 285 | scope of any changes to that context made by commands within the | 
|  | 286 | group.  Groups can be nested hierarchically.  The formatting | 
|  | 287 | context includes the font and the definition of additional macros | 
|  | 288 | (or overrides of macros defined in outer groups).  Syntactically, | 
|  | 289 | groups are enclosed in braces: | 
|  | 290 |  | 
|  | 291 | \begin{verbatim} | 
|  | 292 | {text in a group} | 
|  | 293 | \end{verbatim} | 
|  | 294 |  | 
| Fred Drake | 4c6f17a | 2001-04-18 05:12:47 +0000 | [diff] [blame] | 295 | An alternate syntax for a group using brackets, \code{[...]}, is | 
| Fred Drake | 63568aa | 2000-10-19 05:36:10 +0000 | [diff] [blame] | 296 | used by macros and environment constructors which take optional | 
|  | 297 | parameters; brackets do not normally hold syntactic significance. | 
|  | 298 | A degenerate group, containing only one atomic bit of content, | 
|  | 299 | does not need to have an explicit group, unless it is required to | 
|  | 300 | avoid ambiguity.  Since Python tends toward the explicit, groups | 
|  | 301 | are also made explicit in the documentation markup. | 
|  | 302 |  | 
|  | 303 | Groups are used only sparingly in the Python documentation, except | 
|  | 304 | for their use in marking parameters to macros and environments. | 
|  | 305 |  | 
| Fred Drake | 4c6f17a | 2001-04-18 05:12:47 +0000 | [diff] [blame] | 306 | A \dfn{macro} is usually a simple construct which is identified by | 
| Fred Drake | 63568aa | 2000-10-19 05:36:10 +0000 | [diff] [blame] | 307 | name and can take some number of parameters.  In normal \LaTeX{} | 
|  | 308 | usage, one of these can be optional.  The markup is introduced | 
|  | 309 | using the backslash character (\character{\e}), and the name is | 
|  | 310 | given by alphabetic characters (no digits, hyphens, or | 
|  | 311 | underscores).  Required parameters should be marked as a group, | 
|  | 312 | and optional parameters should be marked using the alternate | 
|  | 313 | syntax for a group. | 
|  | 314 |  | 
|  | 315 | For example, a macro named ``foo'' which takes a single parameter | 
|  | 316 | would appear like this: | 
|  | 317 |  | 
|  | 318 | \begin{verbatim} | 
|  | 319 | \name{parameter} | 
|  | 320 | \end{verbatim} | 
|  | 321 |  | 
|  | 322 | A macro which takes an optional parameter would be typed like this | 
|  | 323 | when the optional paramter is given: | 
|  | 324 |  | 
|  | 325 | \begin{verbatim} | 
|  | 326 | \name[optional] | 
|  | 327 | \end{verbatim} | 
|  | 328 |  | 
|  | 329 | If both optional and required parameters are to be required, it | 
|  | 330 | looks like this: | 
|  | 331 |  | 
|  | 332 | \begin{verbatim} | 
|  | 333 | \name[optional]{required} | 
|  | 334 | \end{verbatim} | 
|  | 335 |  | 
|  | 336 | A macro name may be followed by a space or newline; a space | 
|  | 337 | between the macro name and any parameters will be consumed, but | 
|  | 338 | this usage is not practiced in the Python documentation.  Such a | 
| Fred Drake | 4c6f17a | 2001-04-18 05:12:47 +0000 | [diff] [blame] | 339 | space is still consumed if there are no parameters to the macro, | 
| Fred Drake | 63568aa | 2000-10-19 05:36:10 +0000 | [diff] [blame] | 340 | in which case inserting an empty group (\code{\{\}}) or explicit | 
|  | 341 | word space (\samp{\e\ }) immediately after the macro name helps to | 
|  | 342 | avoid running the expansion of the macro into the following text. | 
|  | 343 | Macros which take no parameters but which should not be followed | 
|  | 344 | by a word space do not need special treatment if the following | 
|  | 345 | character in the document source if not a name character (such as | 
| Fred Drake | 4c6f17a | 2001-04-18 05:12:47 +0000 | [diff] [blame] | 346 | punctuation). | 
| Fred Drake | 63568aa | 2000-10-19 05:36:10 +0000 | [diff] [blame] | 347 |  | 
|  | 348 | Each line of this example shows an appropriate way to write text | 
|  | 349 | which includes a macro which takes no parameters: | 
|  | 350 |  | 
|  | 351 | \begin{verbatim} | 
|  | 352 | This \UNIX{} is followed by a space. | 
|  | 353 | This \UNIX\ is also followed by a space. | 
|  | 354 | \UNIX, followed by a comma, needs no additional markup. | 
|  | 355 | \end{verbatim} | 
|  | 356 |  | 
| Fred Drake | d097d48 | 2000-10-20 20:51:31 +0000 | [diff] [blame] | 357 | An \dfn{environment} is a larger construct than a macro, and can | 
| Fred Drake | 4c6f17a | 2001-04-18 05:12:47 +0000 | [diff] [blame] | 358 | be used for things with more content than would conveniently fit | 
| Fred Drake | d097d48 | 2000-10-20 20:51:31 +0000 | [diff] [blame] | 359 | in a macro parameter.  They are primarily used when formatting | 
|  | 360 | parameters need to be changed before and after a large chunk of | 
|  | 361 | content, but the content itself needs to be highly flexible.  Code | 
|  | 362 | samples are presented using an environment, and descriptions of | 
| Fred Drake | 4c6f17a | 2001-04-18 05:12:47 +0000 | [diff] [blame] | 363 | functions, methods, and classes are also marked using environments. | 
| Fred Drake | d097d48 | 2000-10-20 20:51:31 +0000 | [diff] [blame] | 364 |  | 
|  | 365 | Since the content of an environment is free-form and can consist | 
|  | 366 | of several paragraphs, they are actually marked using a pair of | 
|  | 367 | macros: \macro{begin} and \macro{end}.  These macros both take the | 
|  | 368 | name of the environment as a parameter.  An example is the | 
|  | 369 | environment used to mark the abstract of a document: | 
|  | 370 |  | 
|  | 371 | \begin{verbatim} | 
|  | 372 | \begin{abstract} | 
|  | 373 | This is the text of the abstract.  It concisely explains what | 
|  | 374 | information is found in the document. | 
|  | 375 |  | 
|  | 376 | It can consist of multiple paragraphs. | 
|  | 377 | \end{abstract} | 
|  | 378 | \end{verbatim} | 
|  | 379 |  | 
|  | 380 | An environment can also have required and optional parameters of | 
|  | 381 | its own.  These follow the parameter of the \macro{begin} macro. | 
|  | 382 | This example shows an environment which takes a single required | 
|  | 383 | parameter: | 
|  | 384 |  | 
|  | 385 | \begin{verbatim} | 
| Fred Drake | 2bbc697 | 2001-03-28 16:51:20 +0000 | [diff] [blame] | 386 | \begin{datadesc}{controlnames} | 
| Fred Drake | d097d48 | 2000-10-20 20:51:31 +0000 | [diff] [blame] | 387 | A 33-element string array that contains the \ASCII{} mnemonics for | 
|  | 388 | the thirty-two \ASCII{} control characters from 0 (NUL) to 0x1f | 
|  | 389 | (US), in order, plus the mnemonic \samp{SP} for the space character. | 
|  | 390 | \end{datadesc} | 
|  | 391 | \end{verbatim} | 
| Fred Drake | 63568aa | 2000-10-19 05:36:10 +0000 | [diff] [blame] | 392 |  | 
| Fred Drake | 4c6f17a | 2001-04-18 05:12:47 +0000 | [diff] [blame] | 393 | There are a number of less-used marks in \LaTeX{} which are used | 
| Fred Drake | e789ea1 | 2002-03-13 02:48:24 +0000 | [diff] [blame] | 394 | to enter characters which are not found in \ASCII{} or which a | 
|  | 395 | considered special, or \emph{active} in \TeX{} or \LaTeX.  Given | 
|  | 396 | that these are often used adjacent to other characters, the markup | 
|  | 397 | required to produce the proper character may need to be followed | 
|  | 398 | by a space or an empty group, or the markup can be enclosed in a | 
|  | 399 | group.  Some which are found in Python documentation are: | 
| Fred Drake | 63568aa | 2000-10-19 05:36:10 +0000 | [diff] [blame] | 400 |  | 
| Fred Drake | d097d48 | 2000-10-20 20:51:31 +0000 | [diff] [blame] | 401 | \begin{tableii}{c|l}{textrm}{Character}{Markup} | 
| Fred Drake | e789ea1 | 2002-03-13 02:48:24 +0000 | [diff] [blame] | 402 | \lineii{\textasciicircum}{\code{\e textasciicircum}} | 
|  | 403 | \lineii{\textasciitilde}{\code{\e textasciitilde}} | 
|  | 404 | \lineii{\textgreater}{\code{\e textgreater}} | 
|  | 405 | \lineii{\textless}{\code{\e textless}} | 
| Fred Drake | d097d48 | 2000-10-20 20:51:31 +0000 | [diff] [blame] | 406 | \lineii{\c c}{\code{\e c c}} | 
|  | 407 | \lineii{\"o}{\code{\e"o}} | 
|  | 408 | \lineii{\o}{\code{\e o}} | 
|  | 409 | \end{tableii} | 
| Fred Drake | 63568aa | 2000-10-19 05:36:10 +0000 | [diff] [blame] | 410 |  | 
|  | 411 |  | 
| Skip Montanaro | 176bda4cd | 2002-04-19 04:50:44 +0000 | [diff] [blame] | 412 | \subsection{Hierarchical Structure \label{latex-structure}} | 
| Fred Drake | 63568aa | 2000-10-19 05:36:10 +0000 | [diff] [blame] | 413 |  | 
| Fred Drake | d097d48 | 2000-10-20 20:51:31 +0000 | [diff] [blame] | 414 | \LaTeX{} expects documents to be arranged in a conventional, | 
|  | 415 | hierarchical way, with chapters, sections, sub-sections, | 
|  | 416 | appendixes, and the like.  These are marked using macros rather | 
|  | 417 | than environments, probably because the end of a section can be | 
|  | 418 | safely inferred when a section of equal or higher level starts. | 
|  | 419 |  | 
|  | 420 | There are six ``levels'' of sectioning in the document classes | 
| Fred Drake | 4c6f17a | 2001-04-18 05:12:47 +0000 | [diff] [blame] | 421 | used for Python documentation, and the deepest two | 
|  | 422 | levels\footnote{The deepest levels have the highest numbers in the | 
|  | 423 | table.} are not used.  The levels are: | 
| Fred Drake | d097d48 | 2000-10-20 20:51:31 +0000 | [diff] [blame] | 424 |  | 
|  | 425 | \begin{tableiii}{c|l|c}{textrm}{Level}{Macro Name}{Notes} | 
|  | 426 | \lineiii{1}{\macro{chapter}}{(1)} | 
|  | 427 | \lineiii{2}{\macro{section}}{} | 
|  | 428 | \lineiii{3}{\macro{subsection}}{} | 
| Fred Drake | b7a52c9 | 2000-11-27 20:10:18 +0000 | [diff] [blame] | 429 | \lineiii{4}{\macro{subsubsection}}{} | 
| Fred Drake | d097d48 | 2000-10-20 20:51:31 +0000 | [diff] [blame] | 430 | \lineiii{5}{\macro{paragraph}}{(2)} | 
|  | 431 | \lineiii{6}{\macro{subparagraph}}{} | 
|  | 432 | \end{tableiii} | 
|  | 433 |  | 
|  | 434 | \noindent | 
|  | 435 | Notes: | 
|  | 436 |  | 
|  | 437 | \begin{description} | 
|  | 438 | \item[(1)] | 
|  | 439 | Only used for the \code{manual} documents, as described in | 
|  | 440 | section \ref{classes}, ``Document Classes.'' | 
|  | 441 | \item[(2)] | 
|  | 442 | Not the same as a paragraph of text; nobody seems to use this. | 
|  | 443 | \end{description} | 
| Fred Drake | 2c4e009 | 1999-03-29 14:55:55 +0000 | [diff] [blame] | 444 |  | 
|  | 445 |  | 
| Fred Drake | adade92 | 1999-04-22 13:05:27 +0000 | [diff] [blame] | 446 | \section{Document Classes \label{classes}} | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 447 |  | 
|  | 448 | Two \LaTeX{} document classes are defined specifically for use with | 
|  | 449 | the Python documentation.  The \code{manual} class is for large | 
|  | 450 | documents which are sectioned into chapters, and the \code{howto} | 
|  | 451 | class is for smaller documents. | 
|  | 452 |  | 
|  | 453 | The \code{manual} documents are larger and are used for most of the | 
|  | 454 | standard documents.  This document class is based on the standard | 
|  | 455 | \LaTeX{} \code{report} class and is formatted very much like a long | 
| Fred Drake | 698d520 | 1999-11-10 15:54:57 +0000 | [diff] [blame] | 456 | technical report.  The \citetitle[../ref/ref.html]{Python Reference | 
|  | 457 | Manual} is a good example of a \code{manual} document, and the | 
|  | 458 | \citetitle[../lib/lib.html]{Python Library Reference} is a large | 
|  | 459 | example. | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 460 |  | 
|  | 461 | The \code{howto} documents are shorter, and don't have the large | 
|  | 462 | structure of the \code{manual} documents.  This class is based on | 
|  | 463 | the standard \LaTeX{} \code{article} class and is formatted somewhat | 
|  | 464 | like the Linux Documentation Project's ``HOWTO'' series as done | 
|  | 465 | originally using the LinuxDoc software.  The original intent for the | 
|  | 466 | document class was that it serve a similar role as the LDP's HOWTO | 
|  | 467 | series, but the applicability of the class turns out to be somewhat | 
| Fred Drake | 0299749 | 2000-09-21 05:26:43 +0000 | [diff] [blame] | 468 | broader.  This class is used for ``how-to'' documents (this | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 469 | document is an example) and for shorter reference manuals for small, | 
|  | 470 | fairly cohesive module libraries.  Examples of the later use include | 
| Fred Drake | 6a547c7 | 2000-09-15 22:11:24 +0000 | [diff] [blame] | 471 | \citetitle[http://starship.python.net/crew/fdrake/manuals/krb5py/krb5py.html]{Using | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 472 | Kerberos from Python}, which contains reference material for an | 
|  | 473 | extension package.  These documents are roughly equivalent to a | 
|  | 474 | single chapter from a larger work. | 
|  | 475 |  | 
|  | 476 |  | 
| Fred Drake | f1b3de8 | 2001-07-24 14:38:34 +0000 | [diff] [blame] | 477 | \section{Special Markup Constructs \label{special-constructs}} | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 478 |  | 
| Fred Drake | 2c4e009 | 1999-03-29 14:55:55 +0000 | [diff] [blame] | 479 | The Python document classes define a lot of new environments and | 
|  | 480 | macros.  This section contains the reference material for these | 
|  | 481 | facilities. | 
|  | 482 |  | 
| Fred Drake | af2b714 | 2000-09-14 20:11:05 +0000 | [diff] [blame] | 483 | \subsection{Markup for the Preamble \label{preamble-info}} | 
|  | 484 |  | 
|  | 485 | \begin{macrodesc}{release}{\p{ver}} | 
|  | 486 | Set the version number for the software described in the | 
|  | 487 | document. | 
|  | 488 | \end{macrodesc} | 
|  | 489 |  | 
|  | 490 | \begin{macrodesc}{setshortversion}{\p{sver}} | 
|  | 491 | Specify the ``short'' version number of the documented software | 
|  | 492 | to be \var{sver}. | 
|  | 493 | \end{macrodesc} | 
|  | 494 |  | 
| Fred Drake | e15956b | 2000-04-03 04:51:13 +0000 | [diff] [blame] | 495 | \subsection{Meta-information Markup \label{meta-info}} | 
|  | 496 |  | 
|  | 497 | \begin{macrodesc}{sectionauthor}{\p{author}\p{email}} | 
|  | 498 | Identifies the author of the current section.  \var{author} | 
|  | 499 | should be the author's name such that it can be used for | 
|  | 500 | presentation (though it isn't), and \var{email} should be the | 
|  | 501 | author's email address.  The domain name portion of | 
|  | 502 | the address should be lower case. | 
|  | 503 |  | 
|  | 504 | No presentation is generated from this markup, but it is used to | 
|  | 505 | help keep track of contributions. | 
|  | 506 | \end{macrodesc} | 
|  | 507 |  | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 508 | \subsection{Information Units \label{info-units}} | 
|  | 509 |  | 
| Fred Drake | 2f4bebd | 1999-04-28 16:43:11 +0000 | [diff] [blame] | 510 | XXX Explain terminology, or come up with something more ``lay.'' | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 511 |  | 
| Fred Drake | adade92 | 1999-04-22 13:05:27 +0000 | [diff] [blame] | 512 | There are a number of environments used to describe specific | 
|  | 513 | features provided by modules.  Each environment requires | 
|  | 514 | parameters needed to provide basic information about what is being | 
|  | 515 | described, and the environment content should be the description. | 
|  | 516 | Most of these environments make entries in the general index (if | 
|  | 517 | one is being produced for the document); if no index entry is | 
|  | 518 | desired, non-indexing variants are available for many of these | 
|  | 519 | environments.  The environments have names of the form | 
|  | 520 | \code{\var{feature}desc}, and the non-indexing variants are named | 
|  | 521 | \code{\var{feature}descni}.  The available variants are explicitly | 
|  | 522 | included in the list below. | 
|  | 523 |  | 
|  | 524 | For each of these environments, the first parameter, \var{name}, | 
|  | 525 | provides the name by which the feature is accessed. | 
|  | 526 |  | 
|  | 527 | Environments which describe features of objects within a module, | 
|  | 528 | such as object methods or data attributes, allow an optional | 
|  | 529 | \var{type name} parameter.  When the feature is an attribute of | 
|  | 530 | class instances, \var{type name} only needs to be given if the | 
|  | 531 | class was not the most recently described class in the module; the | 
|  | 532 | \var{name} value from the most recent \env{classdesc} is implied. | 
|  | 533 | For features of built-in or extension types, the \var{type name} | 
| Fred Drake | 7a737df | 1999-04-23 14:41:44 +0000 | [diff] [blame] | 534 | value should always be provided.  Another special case includes | 
|  | 535 | methods and members of general ``protocols,'' such as the | 
|  | 536 | formatter and writer protocols described for the | 
|  | 537 | \module{formatter} module: these may be documented without any | 
|  | 538 | specific implementation classes, and will always require the | 
|  | 539 | \var{type name} parameter to be provided. | 
| Fred Drake | adade92 | 1999-04-22 13:05:27 +0000 | [diff] [blame] | 540 |  | 
| Fred Drake | 7be440d | 2000-09-16 21:23:25 +0000 | [diff] [blame] | 541 | \begin{envdesc}{cfuncdesc}{\p{type}\p{name}\p{args}} | 
|  | 542 | Environment used to described a C function.  The \var{type} | 
|  | 543 | should be specified as a \keyword{typedef} name, \code{struct | 
|  | 544 | \var{tag}}, or the name of a primitive type.  If it is a pointer | 
| Fred Drake | 0299749 | 2000-09-21 05:26:43 +0000 | [diff] [blame] | 545 | type, the trailing asterisk should not be preceded by a space. | 
| Fred Drake | 7be440d | 2000-09-16 21:23:25 +0000 | [diff] [blame] | 546 | \var{name} should be the name of the function (or function-like | 
|  | 547 | pre-processor macro), and \var{args} should give the types and | 
|  | 548 | names of the parameters.  The names need to be given so they may | 
|  | 549 | be used in the description. | 
|  | 550 | \end{envdesc} | 
|  | 551 |  | 
| Fred Drake | 1251b0e | 2002-04-15 20:10:23 +0000 | [diff] [blame] | 552 | \begin{envdesc}{cmemberdesc}{\p{container}\p{type}\p{name}} | 
|  | 553 | Description for a structure member.  \var{container} should be | 
|  | 554 | the \keyword{typedef} name, if there is one, otherwise if should | 
|  | 555 | be \samp{struct \var{tag}}.  The type of the member should given | 
|  | 556 | as \var{type}, and the name should be given as \var{name}.  The | 
|  | 557 | text of the description should include the range of values | 
|  | 558 | allowed, how the value should be interpreted, and whether the | 
|  | 559 | value can be changed.  References to structure members in text | 
|  | 560 | should use the \macro{member} macro. | 
|  | 561 | \end{envdesc} | 
|  | 562 |  | 
| Fred Drake | 79bf99c | 2002-04-09 20:17:42 +0000 | [diff] [blame] | 563 | \begin{envdesc}{csimplemacrodesc}{\p{name}} | 
|  | 564 | Documentation for a ``simple'' macro.  Simple macros are macros | 
|  | 565 | which are used for code expansion, but which do not take | 
|  | 566 | arguments so cannot be described as functions.  This is not to | 
|  | 567 | be used for simple constant definitions.  Examples of it's use | 
|  | 568 | in the Python documentation include | 
|  | 569 | \csimplemacro{PyObject_HEAD} and | 
|  | 570 | \csimplemacro{Py_BEGIN_ALLOW_THREADS}. | 
|  | 571 | \end{envdesc} | 
|  | 572 |  | 
| Fred Drake | 7be440d | 2000-09-16 21:23:25 +0000 | [diff] [blame] | 573 | \begin{envdesc}{ctypedesc}{\op{tag}\p{name}} | 
|  | 574 | Environment used to described a C type.  The \var{name} | 
|  | 575 | parameter should be the \keyword{typedef} name.  If the type is | 
|  | 576 | defined as a \keyword{struct} without a \keyword{typedef}, | 
|  | 577 | \var{name} should have the form \code{struct \var{tag}}. | 
|  | 578 | \var{name} will be added to the index unless \var{tag} is | 
|  | 579 | provided, in which case \var{tag} will be used instead. | 
|  | 580 | \var{tag} should not be used for a \keyword{typedef} name. | 
|  | 581 | \end{envdesc} | 
|  | 582 |  | 
|  | 583 | \begin{envdesc}{cvardesc}{\p{type}\p{name}} | 
|  | 584 | Description of a global C variable.  \var{type} should be the | 
|  | 585 | \keyword{typedef} name, \code{struct \var{tag}}, or the name of | 
|  | 586 | a primitive type.  If variable has a pointer type, the trailing | 
| Fred Drake | 0299749 | 2000-09-21 05:26:43 +0000 | [diff] [blame] | 587 | asterisk should \emph{not} be preceded by a space. | 
| Fred Drake | 7be440d | 2000-09-16 21:23:25 +0000 | [diff] [blame] | 588 | \end{envdesc} | 
|  | 589 |  | 
| Fred Drake | adade92 | 1999-04-22 13:05:27 +0000 | [diff] [blame] | 590 | \begin{envdesc}{datadesc}{\p{name}} | 
|  | 591 | This environment is used to document global data in a module, | 
|  | 592 | including both variables and values used as ``defined | 
|  | 593 | constants.''  Class and object attributes are not documented | 
|  | 594 | using this environment. | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 595 | \end{envdesc} | 
| Fred Drake | 7a737df | 1999-04-23 14:41:44 +0000 | [diff] [blame] | 596 | \begin{envdesc}{datadescni}{\p{name}} | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 597 | Like \env{datadesc}, but without creating any index entries. | 
|  | 598 | \end{envdesc} | 
|  | 599 |  | 
| Fred Drake | 9f2376d | 2001-05-11 01:01:12 +0000 | [diff] [blame] | 600 | \begin{envdesc}{excclassdesc}{\p{name}\p{constructor parameters}} | 
|  | 601 | Descibe an exception defined by a class.  \var{constructor | 
|  | 602 | parameters} should not include the \var{self} parameter or | 
|  | 603 | the parentheses used in the call syntax.  To describe an | 
|  | 604 | exception class without describing the parameters to its | 
|  | 605 | constructor, use the \env{excdesc} environment. | 
|  | 606 | \end{envdesc} | 
|  | 607 |  | 
| Fred Drake | adade92 | 1999-04-22 13:05:27 +0000 | [diff] [blame] | 608 | \begin{envdesc}{excdesc}{\p{name}} | 
| Neal Norwitz | 847207a | 2003-05-29 02:17:23 +0000 | [diff] [blame] | 609 | Describe an exception.  In the case of class exceptions, the | 
| Fred Drake | 9f2376d | 2001-05-11 01:01:12 +0000 | [diff] [blame] | 610 | constructor parameters are not described; use \env{excclassdesc} | 
|  | 611 | to describe an exception class and its constructor. | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 612 | \end{envdesc} | 
|  | 613 |  | 
| Fred Drake | adade92 | 1999-04-22 13:05:27 +0000 | [diff] [blame] | 614 | \begin{envdesc}{funcdesc}{\p{name}\p{parameters}} | 
|  | 615 | Describe a module-level function.  \var{parameters} should | 
|  | 616 | not include the parentheses used in the call syntax.  Object | 
|  | 617 | methods are not documented using this environment.  Bound object | 
|  | 618 | methods placed in the module namespace as part of the public | 
|  | 619 | interface of the module are documented using this, as they are | 
|  | 620 | equivalent to normal functions for most purposes. | 
|  | 621 |  | 
|  | 622 | The description should include information about the parameters | 
|  | 623 | required and how they are used (especially whether mutable | 
|  | 624 | objects passed as parameters are modified), side effects, and | 
|  | 625 | possible exceptions.  A small example may be provided. | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 626 | \end{envdesc} | 
| Fred Drake | adade92 | 1999-04-22 13:05:27 +0000 | [diff] [blame] | 627 | \begin{envdesc}{funcdescni}{\p{name}\p{parameters}} | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 628 | Like \env{funcdesc}, but without creating any index entries. | 
|  | 629 | \end{envdesc} | 
|  | 630 |  | 
| Fred Drake | adade92 | 1999-04-22 13:05:27 +0000 | [diff] [blame] | 631 | \begin{envdesc}{classdesc}{\p{name}\p{constructor parameters}} | 
|  | 632 | Describe a class and its constructor.  \var{constructor | 
|  | 633 | parameters} should not include the \var{self} parameter or | 
|  | 634 | the parentheses used in the call syntax. | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 635 | \end{envdesc} | 
|  | 636 |  | 
| Fred Drake | 9f2376d | 2001-05-11 01:01:12 +0000 | [diff] [blame] | 637 | \begin{envdesc}{classdesc*}{\p{name}} | 
|  | 638 | Describe a class without describing the constructor.  This can | 
|  | 639 | be used to describe classes that are merely containers for | 
|  | 640 | attributes or which should never be instantiated or subclassed | 
|  | 641 | by user code. | 
|  | 642 | \end{envdesc} | 
|  | 643 |  | 
| Fred Drake | adade92 | 1999-04-22 13:05:27 +0000 | [diff] [blame] | 644 | \begin{envdesc}{memberdesc}{\op{type name}\p{name}} | 
|  | 645 | Describe an object data attribute.  The description should | 
|  | 646 | include information about the type of the data to be expected | 
|  | 647 | and whether it may be changed directly. | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 648 | \end{envdesc} | 
| Fred Drake | adade92 | 1999-04-22 13:05:27 +0000 | [diff] [blame] | 649 | \begin{envdesc}{memberdescni}{\op{type name}\p{name}} | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 650 | Like \env{memberdesc}, but without creating any index entries. | 
|  | 651 | \end{envdesc} | 
|  | 652 |  | 
| Fred Drake | adade92 | 1999-04-22 13:05:27 +0000 | [diff] [blame] | 653 | \begin{envdesc}{methoddesc}{\op{type name}\p{name}\p{parameters}} | 
|  | 654 | Describe an object method.  \var{parameters} should not include | 
|  | 655 | the \var{self} parameter or the parentheses used in the call | 
|  | 656 | syntax.  The description should include similar information to | 
|  | 657 | that described for \env{funcdesc}. | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 658 | \end{envdesc} | 
| Fred Drake | adade92 | 1999-04-22 13:05:27 +0000 | [diff] [blame] | 659 | \begin{envdesc}{methoddescni}{\op{type name}\p{name}\p{parameters}} | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 660 | Like \env{methoddesc}, but without creating any index entries. | 
|  | 661 | \end{envdesc} | 
|  | 662 |  | 
|  | 663 |  | 
| Fred Drake | f1b3de8 | 2001-07-24 14:38:34 +0000 | [diff] [blame] | 664 | \subsection{Showing Code Examples \label{showing-examples}} | 
| Fred Drake | 5eb992b | 1999-06-11 14:25:45 +0000 | [diff] [blame] | 665 |  | 
|  | 666 | Examples of Python source code or interactive sessions are | 
|  | 667 | represented as \env{verbatim} environments.  This environment | 
|  | 668 | is a standard part of \LaTeX{}.  It is important to only use | 
|  | 669 | spaces for indentation in code examples since \TeX{} drops tabs | 
|  | 670 | instead of converting them to spaces. | 
|  | 671 |  | 
|  | 672 | Representing an interactive session requires including the prompts | 
|  | 673 | and output along with the Python code.  No special markup is | 
| Fred Drake | 63568aa | 2000-10-19 05:36:10 +0000 | [diff] [blame] | 674 | required for interactive sessions.  After the last line of input | 
|  | 675 | or output presented, there should not be an ``unused'' primary | 
|  | 676 | prompt; this is an example of what \emph{not} to do: | 
|  | 677 |  | 
|  | 678 | \begin{verbatim} | 
|  | 679 | >>> 1 + 1 | 
|  | 680 | 2 | 
|  | 681 | >>> | 
|  | 682 | \end{verbatim} | 
| Fred Drake | 5eb992b | 1999-06-11 14:25:45 +0000 | [diff] [blame] | 683 |  | 
|  | 684 | Within the \env{verbatim} environment, characters special to | 
|  | 685 | \LaTeX{} do not need to be specially marked in any way.  The entire | 
|  | 686 | example will be presented in a monospaced font; no attempt at | 
|  | 687 | ``pretty-printing'' is made, as the environment must work for | 
| Fred Drake | 63568aa | 2000-10-19 05:36:10 +0000 | [diff] [blame] | 688 | non-Python code and non-code displays.  There should be no blank | 
|  | 689 | lines at the top or bottom of any \env{verbatim} display. | 
| Fred Drake | 5eb992b | 1999-06-11 14:25:45 +0000 | [diff] [blame] | 690 |  | 
| Fred Drake | 66eed24 | 2001-06-18 14:59:58 +0000 | [diff] [blame] | 691 | Longer displays of verbatim text may be included by storing the | 
|  | 692 | example text in an external file containing only plain text.  The | 
|  | 693 | file may be included using the standard \macro{verbatiminput} | 
|  | 694 | macro; this macro takes a single argument naming the file | 
|  | 695 | containing the text.  For example, to include the Python source | 
|  | 696 | file \file{example.py}, use: | 
|  | 697 |  | 
|  | 698 | \begin{verbatim} | 
|  | 699 | \verbatiminput{example.py} | 
|  | 700 | \end{verbatim} | 
|  | 701 |  | 
|  | 702 | Use of \macro{verbatiminput} allows easier use of special editing | 
|  | 703 | modes for the included file.  The file should be placed in the | 
|  | 704 | same directory as the \LaTeX{} files for the document. | 
|  | 705 |  | 
| Fred Drake | 5eb992b | 1999-06-11 14:25:45 +0000 | [diff] [blame] | 706 | The Python Documentation Special Interest Group has discussed a | 
|  | 707 | number of approaches to creating pretty-printed code displays and | 
|  | 708 | interactive sessions; see the Doc-SIG area on the Python Web site | 
|  | 709 | for more information on this topic. | 
|  | 710 |  | 
|  | 711 |  | 
| Fred Drake | f1b3de8 | 2001-07-24 14:38:34 +0000 | [diff] [blame] | 712 | \subsection{Inline Markup \label{inline-markup}} | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 713 |  | 
| Fred Drake | 87f768e | 1999-05-17 15:22:45 +0000 | [diff] [blame] | 714 | The macros described in this section are used to mark just about | 
|  | 715 | anything interesting in the document text.  They may be used in | 
|  | 716 | headings (though anything involving hyperlinks should be avoided | 
|  | 717 | there) as well as in the body text. | 
| Fred Drake | 2f4bebd | 1999-04-28 16:43:11 +0000 | [diff] [blame] | 718 |  | 
|  | 719 | \begin{macrodesc}{bfcode}{\p{text}} | 
|  | 720 | Like \macro{code}, but also makes the font bold-face. | 
|  | 721 | \end{macrodesc} | 
|  | 722 |  | 
|  | 723 | \begin{macrodesc}{cdata}{\p{name}} | 
|  | 724 | The name of a C-language variable. | 
|  | 725 | \end{macrodesc} | 
|  | 726 |  | 
|  | 727 | \begin{macrodesc}{cfunction}{\p{name}} | 
|  | 728 | The name of a C-language function.  \var{name} should include the | 
|  | 729 | function name and the trailing parentheses. | 
|  | 730 | \end{macrodesc} | 
|  | 731 |  | 
|  | 732 | \begin{macrodesc}{character}{\p{char}} | 
|  | 733 | A character when discussing the character rather than a one-byte | 
|  | 734 | string value.  The character will be typeset as with \macro{samp}. | 
|  | 735 | \end{macrodesc} | 
|  | 736 |  | 
| Fred Drake | 29a710f | 1999-11-10 22:51:18 +0000 | [diff] [blame] | 737 | \begin{macrodesc}{citetitle}{\op{url}\p{title}} | 
|  | 738 | A title for a referenced publication.  If \var{url} is specified, | 
|  | 739 | the title will be made into a hyperlink when formatted as HTML. | 
|  | 740 | \end{macrodesc} | 
|  | 741 |  | 
| Fred Drake | 2f4bebd | 1999-04-28 16:43:11 +0000 | [diff] [blame] | 742 | \begin{macrodesc}{class}{\p{name}} | 
|  | 743 | A class name; a dotted name may be used. | 
|  | 744 | \end{macrodesc} | 
|  | 745 |  | 
|  | 746 | \begin{macrodesc}{code}{\p{text}} | 
|  | 747 | A short code fragment or literal constant value.  Typically, it | 
|  | 748 | should not include any spaces since no quotation marks are | 
|  | 749 | added. | 
|  | 750 | \end{macrodesc} | 
|  | 751 |  | 
|  | 752 | \begin{macrodesc}{constant}{\p{name}} | 
|  | 753 | The name of a ``defined'' constant.  This may be a C-language | 
|  | 754 | \code{\#define} or a Python variable that is not intended to be | 
|  | 755 | changed. | 
|  | 756 | \end{macrodesc} | 
|  | 757 |  | 
| Fred Drake | 79bf99c | 2002-04-09 20:17:42 +0000 | [diff] [blame] | 758 | \begin{macrodesc}{csimplemacro}{\p{name}} | 
|  | 759 | The name of a ``simple'' macro.  Simple macros are macros | 
|  | 760 | which are used for code expansion, but which do not take | 
|  | 761 | arguments so cannot be described as functions.  This is not to | 
|  | 762 | be used for simple constant definitions.  Examples of it's use | 
|  | 763 | in the Python documentation include | 
|  | 764 | \csimplemacro{PyObject_HEAD} and | 
|  | 765 | \csimplemacro{Py_BEGIN_ALLOW_THREADS}. | 
|  | 766 | \end{macrodesc} | 
|  | 767 |  | 
| Fred Drake | 2f4bebd | 1999-04-28 16:43:11 +0000 | [diff] [blame] | 768 | \begin{macrodesc}{ctype}{\p{name}} | 
|  | 769 | The name of a C \keyword{typedef} or structure.  For structures | 
|  | 770 | defined without a \keyword{typedef}, use \code{\e ctype\{struct | 
|  | 771 | struct_tag\}} to make it clear that the \keyword{struct} is | 
|  | 772 | required. | 
|  | 773 | \end{macrodesc} | 
|  | 774 |  | 
|  | 775 | \begin{macrodesc}{deprecated}{\p{version}\p{what to do}} | 
|  | 776 | Declare whatever is being described as being deprecated starting | 
|  | 777 | with release \var{version}.  The text given as \var{what to do} | 
| Fred Drake | f79f2f9 | 2002-05-21 16:27:20 +0000 | [diff] [blame] | 778 | should recommend something to use instead.  It should be | 
|  | 779 | complete sentences.  The entire deprecation notice will be | 
|  | 780 | presented as a separate paragraph; it should either preceed or | 
|  | 781 | succeed the description of the deprecated feature. | 
| Fred Drake | 2f4bebd | 1999-04-28 16:43:11 +0000 | [diff] [blame] | 782 | \end{macrodesc} | 
|  | 783 |  | 
|  | 784 | \begin{macrodesc}{dfn}{\p{term}} | 
|  | 785 | Mark the defining instance of \var{term} in the text.  (No index | 
|  | 786 | entries are generated.) | 
|  | 787 | \end{macrodesc} | 
|  | 788 |  | 
| Fred Drake | d1fb779 | 1999-05-17 16:33:54 +0000 | [diff] [blame] | 789 | \begin{macrodesc}{e}{} | 
|  | 790 | Produces a backslash.  This is convenient in \macro{code} and | 
| Fred Drake | 31edf4d | 2000-09-07 20:06:07 +0000 | [diff] [blame] | 791 | similar macros, and is only defined there.  To create a | 
| Fred Drake | 2b85341 | 2000-04-11 19:08:30 +0000 | [diff] [blame] | 792 | backslash in ordinary text (such as the contents of the | 
|  | 793 | \macro{file} macro), use the standard \macro{textbackslash} macro. | 
| Fred Drake | d1fb779 | 1999-05-17 16:33:54 +0000 | [diff] [blame] | 794 | \end{macrodesc} | 
|  | 795 |  | 
| Fred Drake | 2f4bebd | 1999-04-28 16:43:11 +0000 | [diff] [blame] | 796 | \begin{macrodesc}{email}{\p{address}} | 
|  | 797 | An email address.  Note that this is \emph{not} hyperlinked in | 
| Fred Drake | e15956b | 2000-04-03 04:51:13 +0000 | [diff] [blame] | 798 | any of the possible output formats.  The domain name portion of | 
|  | 799 | the address should be lower case. | 
| Fred Drake | 2f4bebd | 1999-04-28 16:43:11 +0000 | [diff] [blame] | 800 | \end{macrodesc} | 
|  | 801 |  | 
|  | 802 | \begin{macrodesc}{emph}{\p{text}} | 
|  | 803 | Emphasized text; this will be presented in an italic font. | 
|  | 804 | \end{macrodesc} | 
|  | 805 |  | 
|  | 806 | \begin{macrodesc}{envvar}{\p{name}} | 
|  | 807 | An environment variable.  Index entries are generated. | 
|  | 808 | \end{macrodesc} | 
|  | 809 |  | 
|  | 810 | \begin{macrodesc}{exception}{\p{name}} | 
|  | 811 | The name of an exception.  A dotted name may be used. | 
|  | 812 | \end{macrodesc} | 
|  | 813 |  | 
|  | 814 | \begin{macrodesc}{file}{\p{file or dir}} | 
|  | 815 | The name of a file or directory.  In the PDF and PostScript | 
|  | 816 | outputs, single quotes and a font change are used to indicate | 
|  | 817 | the file name, but no quotes are used in the HTML output. | 
| Fred Drake | 64a5aaf | 2001-10-20 04:18:14 +0000 | [diff] [blame] | 818 | \warning{The \macro{file} macro cannot be used in the | 
|  | 819 | content of a section title due to processing limitations.} | 
| Fred Drake | 2f4bebd | 1999-04-28 16:43:11 +0000 | [diff] [blame] | 820 | \end{macrodesc} | 
|  | 821 |  | 
|  | 822 | \begin{macrodesc}{filenq}{\p{file or dir}} | 
|  | 823 | Like \macro{file}, but single quotes are never used.  This can | 
|  | 824 | be used in conjunction with tables if a column will only contain | 
|  | 825 | file or directory names. | 
| Fred Drake | 64a5aaf | 2001-10-20 04:18:14 +0000 | [diff] [blame] | 826 | \warning{The \macro{filenq} macro cannot be used in the | 
|  | 827 | content of a section title due to processing limitations.} | 
| Fred Drake | 2f4bebd | 1999-04-28 16:43:11 +0000 | [diff] [blame] | 828 | \end{macrodesc} | 
|  | 829 |  | 
|  | 830 | \begin{macrodesc}{function}{\p{name}} | 
|  | 831 | The name of a Python function; dotted names may be used. | 
|  | 832 | \end{macrodesc} | 
|  | 833 |  | 
| Fred Drake | 432cef0 | 2001-07-06 22:34:33 +0000 | [diff] [blame] | 834 | \begin{macrodesc}{infinity}{} | 
|  | 835 | The symbol for mathematical infinity: \infinity.  Some Web | 
|  | 836 | browsers are not able to render the HTML representation of this | 
|  | 837 | symbol properly, but support is growing. | 
|  | 838 | \end{macrodesc} | 
|  | 839 |  | 
| Fred Drake | 2f4bebd | 1999-04-28 16:43:11 +0000 | [diff] [blame] | 840 | \begin{macrodesc}{kbd}{\p{key sequence}} | 
|  | 841 | Mark a sequence of keystrokes.  What form \var{key sequence} | 
|  | 842 | takes may depend on platform- or application-specific | 
| Fred Drake | 07178d2 | 2001-07-12 02:08:29 +0000 | [diff] [blame] | 843 | conventions.  When there are no relevant conventions, the names | 
|  | 844 | of modifier keys should be spelled out, to improve accessibility | 
|  | 845 | for new users and non-native speakers.  For example, an | 
|  | 846 | \program{xemacs} key sequence may be marked like | 
|  | 847 | \code{\e kbd\{C-x C-f\}}, but without reference to a specific | 
|  | 848 | application or platform, the same sequence should be marked as | 
|  | 849 | \code{\e kbd\{Control-x Control-f\}}. | 
| Fred Drake | 2f4bebd | 1999-04-28 16:43:11 +0000 | [diff] [blame] | 850 | \end{macrodesc} | 
|  | 851 |  | 
|  | 852 | \begin{macrodesc}{keyword}{\p{name}} | 
|  | 853 | The name of a keyword in a programming language. | 
|  | 854 | \end{macrodesc} | 
|  | 855 |  | 
| Fred Drake | 8b3a7b5 | 2001-09-26 17:01:58 +0000 | [diff] [blame] | 856 | \begin{macrodesc}{mailheader}{\p{name}} | 
|  | 857 | The name of an \rfc{822}-style mail header.  This markup does | 
|  | 858 | not imply that the header is being used in an email message, but | 
|  | 859 | can be used to refer to any header of the same ``style.''  This | 
|  | 860 | is also used for headers defined by the various MIME | 
|  | 861 | specifications.  The header name should be entered in the same | 
|  | 862 | way it would normally be found in practice, with the | 
|  | 863 | camel-casing conventions being preferred where there is more | 
| Fred Drake | 203d91a | 2001-09-26 18:43:20 +0000 | [diff] [blame] | 864 | than one common usage.  The colon which follows the name of the | 
|  | 865 | header should not be included. | 
|  | 866 | For example: \code{\e mailheader\{Content-Type\}}. | 
| Fred Drake | 8b3a7b5 | 2001-09-26 17:01:58 +0000 | [diff] [blame] | 867 | \end{macrodesc} | 
|  | 868 |  | 
| Fred Drake | 2f4bebd | 1999-04-28 16:43:11 +0000 | [diff] [blame] | 869 | \begin{macrodesc}{makevar}{\p{name}} | 
|  | 870 | The name of a \program{make} variable. | 
|  | 871 | \end{macrodesc} | 
|  | 872 |  | 
|  | 873 | \begin{macrodesc}{manpage}{\p{name}\p{section}} | 
|  | 874 | A reference to a \UNIX{} manual page. | 
|  | 875 | \end{macrodesc} | 
|  | 876 |  | 
|  | 877 | \begin{macrodesc}{member}{\p{name}} | 
|  | 878 | The name of a data attribute of an object. | 
|  | 879 | \end{macrodesc} | 
|  | 880 |  | 
|  | 881 | \begin{macrodesc}{method}{\p{name}} | 
|  | 882 | The name of a method of an object.  \var{name} should include the | 
|  | 883 | method name and the trailing parentheses.  A dotted name may be | 
|  | 884 | used. | 
|  | 885 | \end{macrodesc} | 
|  | 886 |  | 
|  | 887 | \begin{macrodesc}{mimetype}{\p{name}} | 
| Fred Drake | 8b3a7b5 | 2001-09-26 17:01:58 +0000 | [diff] [blame] | 888 | The name of a MIME type, or a component of a MIME type (the | 
|  | 889 | major or minor portion, taken alone). | 
| Fred Drake | 2f4bebd | 1999-04-28 16:43:11 +0000 | [diff] [blame] | 890 | \end{macrodesc} | 
|  | 891 |  | 
|  | 892 | \begin{macrodesc}{module}{\p{name}} | 
| Fred Drake | 2b85341 | 2000-04-11 19:08:30 +0000 | [diff] [blame] | 893 | The name of a module; a dotted name may be used.  This should | 
|  | 894 | also be used for package names. | 
| Fred Drake | 2f4bebd | 1999-04-28 16:43:11 +0000 | [diff] [blame] | 895 | \end{macrodesc} | 
|  | 896 |  | 
|  | 897 | \begin{macrodesc}{newsgroup}{\p{name}} | 
| Fred Drake | 9120df3 | 2001-07-14 02:34:12 +0000 | [diff] [blame] | 898 | The name of a Usenet newsgroup. | 
| Fred Drake | 2f4bebd | 1999-04-28 16:43:11 +0000 | [diff] [blame] | 899 | \end{macrodesc} | 
|  | 900 |  | 
| Fred Drake | 92350b3 | 2001-10-09 18:01:23 +0000 | [diff] [blame] | 901 | \begin{macrodesc}{note}{\p{text}} | 
|  | 902 | An especially important bit of information about an API that a | 
|  | 903 | user should be aware of when using whatever bit of API the | 
|  | 904 | note pertains to.  This should be the last thing in the | 
|  | 905 | paragraph as the end of the note is not visually marked in | 
| Fred Drake | 64a5aaf | 2001-10-20 04:18:14 +0000 | [diff] [blame] | 906 | any way.  The content of \var{text} should be written in | 
|  | 907 | complete sentences and include all appropriate punctuation. | 
| Fred Drake | 92350b3 | 2001-10-09 18:01:23 +0000 | [diff] [blame] | 908 | \end{macrodesc} | 
|  | 909 |  | 
| Fred Drake | 432cef0 | 2001-07-06 22:34:33 +0000 | [diff] [blame] | 910 | \begin{macrodesc}{pep}{\p{number}} | 
|  | 911 | A reference to a Python Enhancement Proposal.  This generates | 
|  | 912 | appropriate index entries.  The text \samp{PEP \var{number}} is | 
|  | 913 | generated; in the HTML output, this text is a hyperlink to an | 
|  | 914 | online copy of the specified PEP. | 
|  | 915 | \end{macrodesc} | 
|  | 916 |  | 
|  | 917 | \begin{macrodesc}{plusminus}{} | 
|  | 918 | The symbol for indicating a value that may take a positive or | 
|  | 919 | negative value of a specified magnitude, typically represented | 
|  | 920 | by a plus sign placed over a minus sign.  For example: | 
| Fred Drake | 203d91a | 2001-09-26 18:43:20 +0000 | [diff] [blame] | 921 | \code{\e plusminus 3\%{}}. | 
| Fred Drake | 432cef0 | 2001-07-06 22:34:33 +0000 | [diff] [blame] | 922 | \end{macrodesc} | 
|  | 923 |  | 
| Fred Drake | 2f4bebd | 1999-04-28 16:43:11 +0000 | [diff] [blame] | 924 | \begin{macrodesc}{program}{\p{name}} | 
|  | 925 | The name of an executable program.  This may differ from the | 
|  | 926 | file name for the executable for some platforms.  In particular, | 
| Martin v. Löwis | 36a4d8c | 2002-10-10 18:24:54 +0000 | [diff] [blame] | 927 | the \file{.exe} (or other) extension should be omitted for | 
|  | 928 | Windows programs. | 
| Fred Drake | 2f4bebd | 1999-04-28 16:43:11 +0000 | [diff] [blame] | 929 | \end{macrodesc} | 
|  | 930 |  | 
| Fred Drake | 29a710f | 1999-11-10 22:51:18 +0000 | [diff] [blame] | 931 | \begin{macrodesc}{programopt}{\p{option}} | 
| Fred Drake | ce44498 | 2000-04-11 18:52:52 +0000 | [diff] [blame] | 932 | A command-line option to an executable program.  Use this only | 
| Greg Ward | 8b46c71 | 2002-06-29 01:23:45 +0000 | [diff] [blame] | 933 | for ``short'' options, and include the leading hyphen. | 
| Fred Drake | ce44498 | 2000-04-11 18:52:52 +0000 | [diff] [blame] | 934 | \end{macrodesc} | 
|  | 935 |  | 
|  | 936 | \begin{macrodesc}{longprogramopt}{\p{option}} | 
|  | 937 | A long command-line option to an executable program.  This | 
|  | 938 | should only be used for long option names which will be prefixed | 
|  | 939 | by two hyphens; the hyphens should not be provided as part of | 
|  | 940 | \var{option}. | 
| Fred Drake | 29a710f | 1999-11-10 22:51:18 +0000 | [diff] [blame] | 941 | \end{macrodesc} | 
|  | 942 |  | 
| Fred Drake | 2f4bebd | 1999-04-28 16:43:11 +0000 | [diff] [blame] | 943 | \begin{macrodesc}{refmodule}{\op{key}\p{name}} | 
|  | 944 | Like \macro{module}, but create a hyperlink to the documentation | 
|  | 945 | for the named module.  Note that the corresponding | 
|  | 946 | \macro{declaremodule} must be in the same document.  If the | 
|  | 947 | \macro{declaremodule} defines a module key different from the | 
|  | 948 | module name, it must also be provided as \var{key} to the | 
|  | 949 | \macro{refmodule} macro. | 
|  | 950 | \end{macrodesc} | 
|  | 951 |  | 
|  | 952 | \begin{macrodesc}{regexp}{\p{string}} | 
|  | 953 | Mark a regular expression. | 
|  | 954 | \end{macrodesc} | 
|  | 955 |  | 
|  | 956 | \begin{macrodesc}{rfc}{\p{number}} | 
|  | 957 | A reference to an Internet Request for Comments.  This generates | 
|  | 958 | appropriate index entries.  The text \samp{RFC \var{number}} is | 
|  | 959 | generated; in the HTML output, this text is a hyperlink to an | 
|  | 960 | online copy of the specified RFC. | 
|  | 961 | \end{macrodesc} | 
|  | 962 |  | 
|  | 963 | \begin{macrodesc}{samp}{\p{text}} | 
|  | 964 | A short code sample, but possibly longer than would be given | 
|  | 965 | using \macro{code}.  Since quotation marks are added, spaces are | 
|  | 966 | acceptable. | 
|  | 967 | \end{macrodesc} | 
|  | 968 |  | 
| Fred Drake | af2b714 | 2000-09-14 20:11:05 +0000 | [diff] [blame] | 969 | \begin{macrodesc}{shortversion}{} | 
|  | 970 | The ``short'' version number of the documented software, as | 
|  | 971 | specified using the \macro{setshortversion} macro in the | 
|  | 972 | preamble.  For Python, the short version number for a release is | 
|  | 973 | the first three characters of the \code{sys.version} value.  For | 
|  | 974 | example, versions 2.0b1 and 2.0.1 both have a short version of | 
|  | 975 | 2.0.  This may not apply for all packages; if | 
|  | 976 | \macro{setshortversion} is not used, this produces an empty | 
|  | 977 | expansion.  See also the \macro{version} macro. | 
|  | 978 | \end{macrodesc} | 
|  | 979 |  | 
| Fred Drake | 2f4bebd | 1999-04-28 16:43:11 +0000 | [diff] [blame] | 980 | \begin{macrodesc}{strong}{\p{text}} | 
|  | 981 | Strongly emphasized text; this will be presented using a bold | 
|  | 982 | font. | 
|  | 983 | \end{macrodesc} | 
|  | 984 |  | 
| Fred Drake | 432cef0 | 2001-07-06 22:34:33 +0000 | [diff] [blame] | 985 | \begin{macrodesc}{ulink}{\p{text}\p{url}} | 
|  | 986 | A hypertext link with a target specified by a URL, but for which | 
|  | 987 | the link text should not be the title of the resource.  For | 
|  | 988 | resources being referenced by name, use the \macro{citetitle} | 
|  | 989 | macro.  Not all formatted versions support arbitrary hypertext | 
|  | 990 | links.  Note that many characters are special to \LaTeX{} and | 
|  | 991 | this macro does not always do the right thing.  In particular, | 
|  | 992 | the tilde character (\character{\~}) is mis-handled; encoding it | 
|  | 993 | as a hex-sequence does work, use \samp{\%7e} in place of the | 
|  | 994 | tilde character. | 
|  | 995 | \end{macrodesc} | 
|  | 996 |  | 
| Fred Drake | d1fb779 | 1999-05-17 16:33:54 +0000 | [diff] [blame] | 997 | \begin{macrodesc}{url}{\p{url}} | 
|  | 998 | A URL (or URN).  The URL will be presented as text.  In the HTML | 
|  | 999 | and PDF formatted versions, the URL will also be a hyperlink. | 
| Fred Drake | 432cef0 | 2001-07-06 22:34:33 +0000 | [diff] [blame] | 1000 | This can be used when referring to external resources without | 
|  | 1001 | specific titles; references to resources which have titles | 
|  | 1002 | should be marked using the \macro{citetitle} macro.  See the | 
|  | 1003 | comments about special characters in the description of the | 
|  | 1004 | \macro{ulink} macro for special considerations. | 
| Fred Drake | d1fb779 | 1999-05-17 16:33:54 +0000 | [diff] [blame] | 1005 | \end{macrodesc} | 
|  | 1006 |  | 
| Fred Drake | 2f4bebd | 1999-04-28 16:43:11 +0000 | [diff] [blame] | 1007 | \begin{macrodesc}{var}{\p{name}} | 
|  | 1008 | The name of a variable or formal parameter in running text. | 
|  | 1009 | \end{macrodesc} | 
|  | 1010 |  | 
|  | 1011 | \begin{macrodesc}{version}{} | 
| Fred Drake | af2b714 | 2000-09-14 20:11:05 +0000 | [diff] [blame] | 1012 | The version number of the described software, as specified using | 
|  | 1013 | \macro{release} in the preamble.  See also the | 
|  | 1014 | \macro{shortversion} macro. | 
| Fred Drake | 2f4bebd | 1999-04-28 16:43:11 +0000 | [diff] [blame] | 1015 | \end{macrodesc} | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1016 |  | 
| Fred Drake | 3151f44 | 2001-04-18 05:19:06 +0000 | [diff] [blame] | 1017 | \begin{macrodesc}{versionadded}{\op{explanation}\p{version}} | 
| Fred Drake | c26cc91 | 2000-05-02 17:43:44 +0000 | [diff] [blame] | 1018 | The version of Python which added the described feature to the | 
| Fred Drake | 3151f44 | 2001-04-18 05:19:06 +0000 | [diff] [blame] | 1019 | library or C API.  \var{explanation} should be a \emph{brief} | 
|  | 1020 | explanation of the change consisting of a capitalized sentence | 
|  | 1021 | fragment; a period will be appended by the formatting process. | 
|  | 1022 | This is typically added to the end of the first paragraph of the | 
|  | 1023 | description before any availability notes.  The location should | 
|  | 1024 | be selected so the explanation makes sense and may vary as | 
|  | 1025 | needed. | 
| Fred Drake | c26cc91 | 2000-05-02 17:43:44 +0000 | [diff] [blame] | 1026 | \end{macrodesc} | 
|  | 1027 |  | 
|  | 1028 | \begin{macrodesc}{versionchanged}{\op{explanation}\p{version}} | 
|  | 1029 | The version of Python in which the named feature was changed in | 
|  | 1030 | some way (new parameters, changed side effects, etc.). | 
|  | 1031 | \var{explanation} should be a \emph{brief} explanation of the | 
| Fred Drake | 63568aa | 2000-10-19 05:36:10 +0000 | [diff] [blame] | 1032 | change consisting of a capitalized sentence fragment; a | 
| Fred Drake | c26cc91 | 2000-05-02 17:43:44 +0000 | [diff] [blame] | 1033 | period will be appended by the formatting process. | 
|  | 1034 | This is typically added to the end of the first paragraph of the | 
|  | 1035 | description before any availability notes and after | 
|  | 1036 | \macro{versionadded}.  The location should be selected so the | 
|  | 1037 | explanation makes sense and may vary as needed. | 
|  | 1038 | \end{macrodesc} | 
|  | 1039 |  | 
| Fred Drake | 92350b3 | 2001-10-09 18:01:23 +0000 | [diff] [blame] | 1040 | \begin{macrodesc}{warning}{\p{text}} | 
|  | 1041 | An important bit of information about an API that a user should | 
|  | 1042 | be very aware of when using whatever bit of API the warning | 
|  | 1043 | pertains to.  This should be the last thing in the paragraph as | 
| Fred Drake | 64a5aaf | 2001-10-20 04:18:14 +0000 | [diff] [blame] | 1044 | the end of the warning is not visually marked in any way.  The | 
|  | 1045 | content of \var{text} should be written in complete sentences | 
|  | 1046 | and include all appropriate punctuation.  This differs from | 
|  | 1047 | \macro{note} in that it is recommended over \macro{note} for | 
|  | 1048 | information regarding security. | 
| Fred Drake | 92350b3 | 2001-10-09 18:01:23 +0000 | [diff] [blame] | 1049 | \end{macrodesc} | 
|  | 1050 |  | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1051 |  | 
| Fred Drake | 6ca3377 | 2001-12-14 22:50:06 +0000 | [diff] [blame] | 1052 | \subsection{Miscellaneous Text Markup \label{misc-text-markup}} | 
|  | 1053 |  | 
|  | 1054 | In addition to the inline markup, some additional ``block'' markup | 
|  | 1055 | is defined to make it easier to bring attention to various bits of | 
|  | 1056 | text.  The markup described here serves this purpose, and is | 
|  | 1057 | intended to be used when marking one or more paragraphs or other | 
|  | 1058 | block constructs (such as \env{verbatim} environments). | 
|  | 1059 |  | 
|  | 1060 | \begin{envdesc}{notice}{\op{type}} | 
|  | 1061 | Label some paragraphs as being worthy of additional attention from | 
|  | 1062 | the reader.  What sort of attention is warrented can be indicated | 
|  | 1063 | by specifying the \var{type} of the notice.  The only values | 
|  | 1064 | defined for \var{type} are \code{note} and \code{warning}; these | 
|  | 1065 | are equivalent in intent to the inline markup of the same name. | 
|  | 1066 | If \var{type} is omitted, \code{note} is used.  Additional values | 
|  | 1067 | may be defined in the future. | 
|  | 1068 | \end{envdesc} | 
|  | 1069 |  | 
|  | 1070 |  | 
| Fred Drake | f1b3de8 | 2001-07-24 14:38:34 +0000 | [diff] [blame] | 1071 | \subsection{Module-specific Markup \label{module-markup}} | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1072 |  | 
|  | 1073 | The markup described in this section is used to provide information | 
|  | 1074 | about a module being documented.  A typical use of this markup | 
|  | 1075 | appears at the top of the section used to document a module.  A | 
|  | 1076 | typical example might look like this: | 
|  | 1077 |  | 
|  | 1078 | \begin{verbatim} | 
|  | 1079 | \section{\module{spam} --- | 
|  | 1080 | Access to the SPAM facility} | 
|  | 1081 |  | 
|  | 1082 | \declaremodule{extension}{spam} | 
| Fred Drake | 2c4e009 | 1999-03-29 14:55:55 +0000 | [diff] [blame] | 1083 | \platform{Unix} | 
| Fred Drake | 9120df3 | 2001-07-14 02:34:12 +0000 | [diff] [blame] | 1084 | \modulesynopsis{Access to the SPAM facility of \UNIX.} | 
| Fred Drake | 2c4e009 | 1999-03-29 14:55:55 +0000 | [diff] [blame] | 1085 | \moduleauthor{Jane Doe}{jane.doe@frobnitz.org} | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1086 | \end{verbatim} | 
|  | 1087 |  | 
| Fred Drake | 7932ed0 | 2000-08-11 17:37:33 +0000 | [diff] [blame] | 1088 | Python packages\index{packages} --- collections of modules that can | 
|  | 1089 | be described as a unit --- are documented using the same markup as | 
|  | 1090 | modules.  The name for a module in a package should be typed in | 
| Fred Drake | 432cef0 | 2001-07-06 22:34:33 +0000 | [diff] [blame] | 1091 | ``fully qualified'' form (it should include the package name). | 
| Fred Drake | 7932ed0 | 2000-08-11 17:37:33 +0000 | [diff] [blame] | 1092 | For example, a module ``foo'' in package ``bar'' should be marked as | 
| Fred Drake | 203d91a | 2001-09-26 18:43:20 +0000 | [diff] [blame] | 1093 | \code{\e module\{bar.foo\}}, and the beginning of the reference | 
| Fred Drake | 7932ed0 | 2000-08-11 17:37:33 +0000 | [diff] [blame] | 1094 | section would appear as: | 
|  | 1095 |  | 
|  | 1096 | \begin{verbatim} | 
|  | 1097 | \section{\module{bar.foo} --- | 
|  | 1098 | Module from the \module{bar} package} | 
|  | 1099 |  | 
|  | 1100 | \declaremodule{extension}{bar.foo} | 
|  | 1101 | \modulesynopsis{Nifty module from the \module{bar} package.} | 
|  | 1102 | \moduleauthor{Jane Doe}{jane.doe@frobnitz.org} | 
|  | 1103 | \end{verbatim} | 
|  | 1104 |  | 
|  | 1105 | Note that the name of a package is also marked using | 
|  | 1106 | \macro{module}. | 
|  | 1107 |  | 
| Fred Drake | adade92 | 1999-04-22 13:05:27 +0000 | [diff] [blame] | 1108 | \begin{macrodesc}{declaremodule}{\op{key}\p{type}\p{name}} | 
| Fred Drake | 87f768e | 1999-05-17 15:22:45 +0000 | [diff] [blame] | 1109 | Requires two parameters: module type (\samp{standard}, | 
|  | 1110 | \samp{builtin}, \samp{extension}, or \samp{}), and the module | 
|  | 1111 | name.  An optional parameter should be given as the basis for the | 
|  | 1112 | module's ``key'' used for linking to or referencing the section. | 
|  | 1113 | The ``key'' should only be given if the module's name contains any | 
|  | 1114 | underscores, and should be the name with the underscores stripped. | 
|  | 1115 | Note that the \var{type} parameter must be one of the values | 
|  | 1116 | listed above or an error will be printed.  For modules which are | 
|  | 1117 | contained in packages, the fully-qualified name should be given as | 
|  | 1118 | \var{name} parameter.  This should be the first thing after the | 
|  | 1119 | \macro{section} used to introduce the module. | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1120 | \end{macrodesc} | 
|  | 1121 |  | 
| Fred Drake | adade92 | 1999-04-22 13:05:27 +0000 | [diff] [blame] | 1122 | \begin{macrodesc}{platform}{\p{specifier}} | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1123 | Specifies the portability of the module.  \var{specifier} is a | 
|  | 1124 | comma-separated list of keys that specify what platforms the | 
|  | 1125 | module is available on.  The keys are short identifiers; | 
|  | 1126 | examples that are in use include \samp{IRIX}, \samp{Mac}, | 
|  | 1127 | \samp{Windows}, and \samp{Unix}.  It is important to use a key | 
| Fred Drake | 7a737df | 1999-04-23 14:41:44 +0000 | [diff] [blame] | 1128 | which has already been used when applicable.  This is used to | 
|  | 1129 | provide annotations in the Module Index and the HTML and GNU info | 
|  | 1130 | output. | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1131 | \end{macrodesc} | 
|  | 1132 |  | 
| Fred Drake | adade92 | 1999-04-22 13:05:27 +0000 | [diff] [blame] | 1133 | \begin{macrodesc}{modulesynopsis}{\p{text}} | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1134 | The \var{text} is a short, ``one line'' description of the | 
|  | 1135 | module that can be used as part of the chapter introduction. | 
| Fred Drake | adade92 | 1999-04-22 13:05:27 +0000 | [diff] [blame] | 1136 | This is must be placed after \macro{declaremodule}. | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1137 | The synopsis is used in building the contents of the table | 
|  | 1138 | inserted as the \macro{localmoduletable}.  No text is | 
|  | 1139 | produced at the point of the markup. | 
|  | 1140 | \end{macrodesc} | 
|  | 1141 |  | 
| Fred Drake | adade92 | 1999-04-22 13:05:27 +0000 | [diff] [blame] | 1142 | \begin{macrodesc}{moduleauthor}{\p{name}\p{email}} | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1143 | This macro is used to encode information about who authored a | 
|  | 1144 | module.  This is currently not used to generate output, but can be | 
|  | 1145 | used to help determine the origin of the module. | 
|  | 1146 | \end{macrodesc} | 
|  | 1147 |  | 
|  | 1148 |  | 
| Fred Drake | f1b3de8 | 2001-07-24 14:38:34 +0000 | [diff] [blame] | 1149 | \subsection{Library-level Markup \label{library-markup}} | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1150 |  | 
|  | 1151 | This markup is used when describing a selection of modules.  For | 
| Fred Drake | 698d520 | 1999-11-10 15:54:57 +0000 | [diff] [blame] | 1152 | example, the \citetitle[../mac/mac.html]{Macintosh Library | 
|  | 1153 | Modules} document uses this to help provide an overview of the | 
|  | 1154 | modules in the collection, and many chapters in the | 
|  | 1155 | \citetitle[../lib/lib.html]{Python Library Reference} use it for | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1156 | the same purpose. | 
|  | 1157 |  | 
|  | 1158 | \begin{macrodesc}{localmoduletable}{} | 
| Fred Drake | 2c4e009 | 1999-03-29 14:55:55 +0000 | [diff] [blame] | 1159 | If a \file{.syn} file exists for the current | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1160 | chapter (or for the entire document in \code{howto} documents), a | 
|  | 1161 | \env{synopsistable} is created with the contents loaded from the | 
|  | 1162 | \file{.syn} file. | 
|  | 1163 | \end{macrodesc} | 
|  | 1164 |  | 
|  | 1165 |  | 
| Fred Drake | f1b3de8 | 2001-07-24 14:38:34 +0000 | [diff] [blame] | 1166 | \subsection{Table Markup \label{table-markup}} | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1167 |  | 
|  | 1168 | There are three general-purpose table environments defined which | 
|  | 1169 | should be used whenever possible.  These environments are defined | 
|  | 1170 | to provide tables of specific widths and some convenience for | 
|  | 1171 | formatting.  These environments are not meant to be general | 
|  | 1172 | replacements for the standard \LaTeX{} table environments, but can | 
|  | 1173 | be used for an advantage when the documents are processed using | 
|  | 1174 | the tools for Python documentation processing.  In particular, the | 
|  | 1175 | generated HTML looks good!  There is also an advantage for the | 
| Fred Drake | 67f193f | 2001-07-09 16:04:03 +0000 | [diff] [blame] | 1176 | eventual conversion of the documentation to XML (see section | 
| Fred Drake | 2c4e009 | 1999-03-29 14:55:55 +0000 | [diff] [blame] | 1177 | \ref{futures}, ``Future Directions''). | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1178 |  | 
|  | 1179 | Each environment is named \env{table\var{cols}}, where \var{cols} | 
|  | 1180 | is the number of columns in the table specified in lower-case | 
|  | 1181 | Roman numerals.  Within each of these environments, an additional | 
|  | 1182 | macro, \macro{line\var{cols}}, is defined, where \var{cols} | 
|  | 1183 | matches the \var{cols} value of the corresponding table | 
| Fred Drake | 2c4e009 | 1999-03-29 14:55:55 +0000 | [diff] [blame] | 1184 | environment.  These are supported for \var{cols} values of | 
|  | 1185 | \code{ii}, \code{iii}, and \code{iv}.  These environments are all | 
| Fred Drake | da72b93 | 2000-09-21 15:58:02 +0000 | [diff] [blame] | 1186 | built on top of the \env{tabular} environment.  Variants based on | 
|  | 1187 | the \env{longtable} environment are also provided. | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1188 |  | 
| Fred Drake | 2b85341 | 2000-04-11 19:08:30 +0000 | [diff] [blame] | 1189 | Note that all tables in the standard Python documentation use | 
|  | 1190 | vertical lines between columns, and this must be specified in the | 
|  | 1191 | markup for each table.  A general border around the outside of the | 
|  | 1192 | table is not used, but would be the responsibility of the | 
| Fred Drake | da72b93 | 2000-09-21 15:58:02 +0000 | [diff] [blame] | 1193 | processor; the document markup should not include an exterior | 
|  | 1194 | border. | 
|  | 1195 |  | 
|  | 1196 | The \env{longtable}-based variants of the table environments are | 
|  | 1197 | formatted with extra space before and after, so should only be | 
|  | 1198 | used on tables which are long enough that splitting over multiple | 
|  | 1199 | pages is reasonable; tables with fewer than twenty rows should | 
|  | 1200 | never by marked using the long flavors of the table environments. | 
|  | 1201 | The header row is repeated across the top of each part of the | 
|  | 1202 | table. | 
| Fred Drake | 2b85341 | 2000-04-11 19:08:30 +0000 | [diff] [blame] | 1203 |  | 
| Fred Drake | adade92 | 1999-04-22 13:05:27 +0000 | [diff] [blame] | 1204 | \begin{envdesc}{tableii}{\p{colspec}\p{col1font}\p{heading1}\p{heading2}} | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1205 | Create a two-column table using the \LaTeX{} column specifier | 
|  | 1206 | \var{colspec}.  The column specifier should indicate vertical | 
|  | 1207 | bars between columns as appropriate for the specific table, but | 
|  | 1208 | should not specify vertical bars on the outside of the table | 
|  | 1209 | (that is considered a stylesheet issue).  The \var{col1font} | 
|  | 1210 | parameter is used as a stylistic treatment of the first column | 
|  | 1211 | of the table: the first column is presented as | 
|  | 1212 | \code{\e\var{col1font}\{column1\}}.  To avoid treating the first | 
| Fred Drake | adade92 | 1999-04-22 13:05:27 +0000 | [diff] [blame] | 1213 | column specially, \var{col1font} may be \samp{textrm}.  The | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1214 | column headings are taken from the values \var{heading1} and | 
|  | 1215 | \var{heading2}. | 
|  | 1216 | \end{envdesc} | 
|  | 1217 |  | 
| Fred Drake | da72b93 | 2000-09-21 15:58:02 +0000 | [diff] [blame] | 1218 | \begin{envdesc}{longtableii}{\unspecified} | 
|  | 1219 | Like \env{tableii}, but produces a table which may be broken | 
|  | 1220 | across page boundaries.  The parameters are the same as for | 
|  | 1221 | \env{tableii}. | 
|  | 1222 | \end{envdesc} | 
|  | 1223 |  | 
| Fred Drake | adade92 | 1999-04-22 13:05:27 +0000 | [diff] [blame] | 1224 | \begin{macrodesc}{lineii}{\p{column1}\p{column2}} | 
| Fred Drake | da72b93 | 2000-09-21 15:58:02 +0000 | [diff] [blame] | 1225 | Create a single table row within a \env{tableii} or | 
|  | 1226 | \env{longtableii} environment. | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1227 | The text for the first column will be generated by applying the | 
|  | 1228 | macro named by the \var{col1font} value when the \env{tableii} | 
|  | 1229 | was opened. | 
|  | 1230 | \end{macrodesc} | 
|  | 1231 |  | 
| Fred Drake | adade92 | 1999-04-22 13:05:27 +0000 | [diff] [blame] | 1232 | \begin{envdesc}{tableiii}{\p{colspec}\p{col1font}\p{heading1}\p{heading2}\p{heading3}} | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1233 | Like the \env{tableii} environment, but with a third column. | 
|  | 1234 | The heading for the third column is given by \var{heading3}. | 
|  | 1235 | \end{envdesc} | 
|  | 1236 |  | 
| Fred Drake | da72b93 | 2000-09-21 15:58:02 +0000 | [diff] [blame] | 1237 | \begin{envdesc}{longtableiii}{\unspecified} | 
|  | 1238 | Like \env{tableiii}, but produces a table which may be broken | 
|  | 1239 | across page boundaries.  The parameters are the same as for | 
|  | 1240 | \env{tableiii}. | 
|  | 1241 | \end{envdesc} | 
|  | 1242 |  | 
| Fred Drake | adade92 | 1999-04-22 13:05:27 +0000 | [diff] [blame] | 1243 | \begin{macrodesc}{lineiii}{\p{column1}\p{column2}\p{column3}} | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1244 | Like the \macro{lineii} macro, but with a third column.  The | 
|  | 1245 | text for the third column is given by \var{column3}. | 
|  | 1246 | \end{macrodesc} | 
|  | 1247 |  | 
| Fred Drake | adade92 | 1999-04-22 13:05:27 +0000 | [diff] [blame] | 1248 | \begin{envdesc}{tableiv}{\p{colspec}\p{col1font}\p{heading1}\p{heading2}\p{heading3}\p{heading4}} | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1249 | Like the \env{tableiii} environment, but with a fourth column. | 
|  | 1250 | The heading for the fourth column is given by \var{heading4}. | 
|  | 1251 | \end{envdesc} | 
|  | 1252 |  | 
| Fred Drake | da72b93 | 2000-09-21 15:58:02 +0000 | [diff] [blame] | 1253 | \begin{envdesc}{longtableiv}{\unspecified} | 
|  | 1254 | Like \env{tableiv}, but produces a table which may be broken | 
|  | 1255 | across page boundaries.  The parameters are the same as for | 
|  | 1256 | \env{tableiv}. | 
|  | 1257 | \end{envdesc} | 
|  | 1258 |  | 
| Fred Drake | adade92 | 1999-04-22 13:05:27 +0000 | [diff] [blame] | 1259 | \begin{macrodesc}{lineiv}{\p{column1}\p{column2}\p{column3}\p{column4}} | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1260 | Like the \macro{lineiii} macro, but with a fourth column.  The | 
|  | 1261 | text for the fourth column is given by \var{column4}. | 
|  | 1262 | \end{macrodesc} | 
|  | 1263 |  | 
| Fred Drake | f269e59 | 2001-07-17 23:05:57 +0000 | [diff] [blame] | 1264 | \begin{envdesc}{tablev}{\p{colspec}\p{col1font}\p{heading1}\p{heading2}\p{heading3}\p{heading4}\p{heading5}} | 
|  | 1265 | Like the \env{tableiv} environment, but with a fifth column. | 
|  | 1266 | The heading for the fifth column is given by \var{heading5}. | 
|  | 1267 | \end{envdesc} | 
|  | 1268 |  | 
|  | 1269 | \begin{envdesc}{longtablev}{\unspecified} | 
|  | 1270 | Like \env{tablev}, but produces a table which may be broken | 
|  | 1271 | across page boundaries.  The parameters are the same as for | 
|  | 1272 | \env{tablev}. | 
|  | 1273 | \end{envdesc} | 
|  | 1274 |  | 
|  | 1275 | \begin{macrodesc}{linev}{\p{column1}\p{column2}\p{column3}\p{column4}\p{column5}} | 
|  | 1276 | Like the \macro{lineiv} macro, but with a fifth column.  The | 
|  | 1277 | text for the fifth column is given by \var{column5}. | 
|  | 1278 | \end{macrodesc} | 
|  | 1279 |  | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1280 |  | 
|  | 1281 | An additional table-like environment is \env{synopsistable}.  The | 
|  | 1282 | table generated by this environment contains two columns, and each | 
|  | 1283 | row is defined by an alternate definition of | 
| Fred Drake | e15956b | 2000-04-03 04:51:13 +0000 | [diff] [blame] | 1284 | \macro{modulesynopsis}.  This environment is not normally used by | 
|  | 1285 | authors, but is created by the \macro{localmoduletable} macro. | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1286 |  | 
| Fred Drake | 0cac5f6 | 2001-08-14 21:36:19 +0000 | [diff] [blame] | 1287 | Here is a small example of a table given in the documentation for | 
|  | 1288 | the \module{warnings} module; markup inside the table cells is | 
|  | 1289 | minimal so the markup for the table itself is readily discernable. | 
|  | 1290 | Here is the markup for the table: | 
|  | 1291 |  | 
|  | 1292 | \begin{verbatim} | 
|  | 1293 | \begin{tableii}{l|l}{exception}{Class}{Description} | 
|  | 1294 | \lineii{Warning} | 
|  | 1295 | {This is the base class of all warning category classes.  It | 
|  | 1296 | is a subclass of \exception{Exception}.} | 
|  | 1297 | \lineii{UserWarning} | 
|  | 1298 | {The default category for \function{warn()}.} | 
|  | 1299 | \lineii{DeprecationWarning} | 
|  | 1300 | {Base category for warnings about deprecated features.} | 
|  | 1301 | \lineii{SyntaxWarning} | 
|  | 1302 | {Base category for warnings about dubious syntactic | 
|  | 1303 | features.} | 
|  | 1304 | \lineii{RuntimeWarning} | 
|  | 1305 | {Base category for warnings about dubious runtime features.} | 
| Barry Warsaw | b8c20a7 | 2002-08-14 16:40:54 +0000 | [diff] [blame] | 1306 | \lineii{FutureWarning} | 
|  | 1307 | {Base category for warnings about constructs that will change | 
|  | 1308 | semantically in the future.} | 
| Fred Drake | 0cac5f6 | 2001-08-14 21:36:19 +0000 | [diff] [blame] | 1309 | \end{tableii} | 
|  | 1310 | \end{verbatim} | 
|  | 1311 |  | 
|  | 1312 | Here is the resulting table: | 
|  | 1313 |  | 
|  | 1314 | \begin{tableii}{l|l}{exception}{Class}{Description} | 
|  | 1315 | \lineii{Warning} | 
|  | 1316 | {This is the base class of all warning category classes.  It | 
|  | 1317 | is a subclass of \exception{Exception}.} | 
|  | 1318 | \lineii{UserWarning} | 
|  | 1319 | {The default category for \function{warn()}.} | 
|  | 1320 | \lineii{DeprecationWarning} | 
|  | 1321 | {Base category for warnings about deprecated features.} | 
|  | 1322 | \lineii{SyntaxWarning} | 
|  | 1323 | {Base category for warnings about dubious syntactic | 
|  | 1324 | features.} | 
|  | 1325 | \lineii{RuntimeWarning} | 
|  | 1326 | {Base category for warnings about dubious runtime features.} | 
|  | 1327 | \end{tableii} | 
|  | 1328 |  | 
|  | 1329 | Note that the class names are implicitly marked using the | 
|  | 1330 | \macro{exception} macro, since that is given as the \var{col1font} | 
|  | 1331 | value for the \env{tableii} environment.  To create a table using | 
|  | 1332 | different markup for the first column, use \code{textrm} for the | 
|  | 1333 | \var{col1font} value and mark each entry individually. | 
|  | 1334 |  | 
|  | 1335 | To add a horizontal line between vertical sections of a table, use | 
|  | 1336 | the standard \macro{hline} macro between the rows which should be | 
|  | 1337 | separated: | 
|  | 1338 |  | 
|  | 1339 | \begin{verbatim} | 
|  | 1340 | \begin{tableii}{l|l}{constant}{Language}{Audience} | 
|  | 1341 | \lineii{APL}{Masochists.} | 
|  | 1342 | \lineii{BASIC}{First-time programmers on PC hardware.} | 
|  | 1343 | \lineii{C}{\UNIX{} \&\ Linux kernel developers.} | 
|  | 1344 | \hline | 
|  | 1345 | \lineii{Python}{Everyone!} | 
|  | 1346 | \end{tableii} | 
|  | 1347 | \end{verbatim} | 
|  | 1348 |  | 
|  | 1349 | Note that not all presentation formats are capable of displaying a | 
|  | 1350 | horizontal rule in this position.  This is how the table looks in | 
|  | 1351 | the format you're reading now: | 
|  | 1352 |  | 
|  | 1353 | \begin{tableii}{l|l}{constant}{Language}{Audience} | 
|  | 1354 | \lineii{APL}{Masochists.} | 
|  | 1355 | \lineii{C}{\UNIX{} \&\ Linux kernel developers.} | 
|  | 1356 | \lineii{JavaScript}{Web developers.} | 
|  | 1357 | \hline | 
|  | 1358 | \lineii{Python}{Everyone!} | 
|  | 1359 | \end{tableii} | 
|  | 1360 |  | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1361 |  | 
|  | 1362 | \subsection{Reference List Markup \label{references}} | 
|  | 1363 |  | 
|  | 1364 | Many sections include a list of references to module documentation | 
|  | 1365 | or external documents.  These lists are created using the | 
| Fred Drake | 5ed35fd | 2001-11-30 18:09:54 +0000 | [diff] [blame] | 1366 | \env{seealso} or \env{seealso*} environments.  These environments | 
|  | 1367 | define some additional macros to support creating reference | 
|  | 1368 | entries in a reasonable manner. | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1369 |  | 
| Fred Drake | 5802e48 | 2000-07-06 05:24:41 +0000 | [diff] [blame] | 1370 | The \env{seealso} environment is typically placed in a section | 
|  | 1371 | just before any sub-sections.  This is done to ensure that | 
|  | 1372 | reference links related to the section are not hidden in a | 
| Fred Drake | 5ed35fd | 2001-11-30 18:09:54 +0000 | [diff] [blame] | 1373 | subsection in the hypertext renditions of the documentation.  For | 
|  | 1374 | the HTML output, it is shown as a ``side bar,'' boxed off from the | 
|  | 1375 | main flow of the text.  The \env{seealso*} environment is | 
|  | 1376 | different in that it should be used when a list of references is | 
|  | 1377 | being presented as part of the primary content; it is not | 
|  | 1378 | specially set off from the text. | 
| Fred Drake | 5802e48 | 2000-07-06 05:24:41 +0000 | [diff] [blame] | 1379 |  | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1380 | \begin{envdesc}{seealso}{} | 
|  | 1381 | This environment creates a ``See also:'' heading and defines the | 
|  | 1382 | markup used to describe individual references. | 
|  | 1383 | \end{envdesc} | 
|  | 1384 |  | 
| Fred Drake | 5ed35fd | 2001-11-30 18:09:54 +0000 | [diff] [blame] | 1385 | \begin{envdesc}{seealso*}{} | 
|  | 1386 | This environment is used to create a list of references which | 
|  | 1387 | form part of the main content.  It is not given a special | 
|  | 1388 | header and is not set off from the main flow of the text.  It | 
|  | 1389 | provides the same additional markup used to describe individual | 
|  | 1390 | references. | 
|  | 1391 | \end{envdesc} | 
|  | 1392 |  | 
| Fred Drake | 4844998 | 2000-09-12 17:52:33 +0000 | [diff] [blame] | 1393 | For each of the following macros, \var{why} should be one or more | 
|  | 1394 | complete sentences, starting with a capital letter (unless it | 
|  | 1395 | starts with an identifier, which should not be modified), and | 
|  | 1396 | ending with the apropriate punctuation. | 
| Fred Drake | 5802e48 | 2000-07-06 05:24:41 +0000 | [diff] [blame] | 1397 |  | 
| Fred Drake | b7cf378 | 2000-09-12 19:58:10 +0000 | [diff] [blame] | 1398 | These macros are only defined within the content of the | 
| Fred Drake | 5ed35fd | 2001-11-30 18:09:54 +0000 | [diff] [blame] | 1399 | \env{seealso} and \env{seealso*} environments. | 
| Fred Drake | b7cf378 | 2000-09-12 19:58:10 +0000 | [diff] [blame] | 1400 |  | 
| Fred Drake | adade92 | 1999-04-22 13:05:27 +0000 | [diff] [blame] | 1401 | \begin{macrodesc}{seemodule}{\op{key}\p{name}\p{why}} | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1402 | Refer to another module.  \var{why} should be a brief | 
|  | 1403 | explanation of why the reference may be interesting.  The module | 
|  | 1404 | name is given in \var{name}, with the link key given in | 
|  | 1405 | \var{key} if necessary.  In the HTML and PDF conversions, the | 
|  | 1406 | module name will be a hyperlink to the referred-to module. | 
| Fred Drake | 64a5aaf | 2001-10-20 04:18:14 +0000 | [diff] [blame] | 1407 | \note{The module must be documented in the same | 
|  | 1408 | document (the corresponding \macro{declaremodule} is required).} | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1409 | \end{macrodesc} | 
|  | 1410 |  | 
| Fred Drake | 08c5d0c | 2000-09-11 05:22:30 +0000 | [diff] [blame] | 1411 | \begin{macrodesc}{seepep}{\p{number}\p{title}\p{why}} | 
|  | 1412 | Refer to an Python Enhancement Proposal (PEP).  \var{number} | 
|  | 1413 | should be the official number assigned by the PEP Editor, | 
|  | 1414 | \var{title} should be the human-readable title of the PEP as | 
| Fred Drake | 5802e48 | 2000-07-06 05:24:41 +0000 | [diff] [blame] | 1415 | found in the official copy of the document, and \var{why} should | 
| Fred Drake | 08c5d0c | 2000-09-11 05:22:30 +0000 | [diff] [blame] | 1416 | explain what's interesting about the PEP.  This should be used | 
|  | 1417 | to refer the reader to PEPs which specify interfaces or language | 
|  | 1418 | features relevant to the material in the annotated section of the | 
|  | 1419 | documentation. | 
|  | 1420 | \end{macrodesc} | 
|  | 1421 |  | 
|  | 1422 | \begin{macrodesc}{seerfc}{\p{number}\p{title}\p{why}} | 
|  | 1423 | Refer to an IETF Request for Comments (RFC).  Otherwise very | 
|  | 1424 | similar to \macro{seepep}.  This should be used | 
|  | 1425 | to refer the reader to PEPs which specify protocols or data | 
| Fred Drake | 5802e48 | 2000-07-06 05:24:41 +0000 | [diff] [blame] | 1426 | formats relevant to the material in the annotated section of the | 
|  | 1427 | documentation. | 
|  | 1428 | \end{macrodesc} | 
|  | 1429 |  | 
| Fred Drake | adade92 | 1999-04-22 13:05:27 +0000 | [diff] [blame] | 1430 | \begin{macrodesc}{seetext}{\p{text}} | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1431 | Add arbitrary text \var{text} to the ``See also:'' list.  This | 
|  | 1432 | can be used to refer to off-line materials or on-line materials | 
| Fred Drake | 5802e48 | 2000-07-06 05:24:41 +0000 | [diff] [blame] | 1433 | using the \macro{url} macro.  This should consist of one or more | 
|  | 1434 | complete sentences. | 
|  | 1435 | \end{macrodesc} | 
|  | 1436 |  | 
| Fred Drake | 4844998 | 2000-09-12 17:52:33 +0000 | [diff] [blame] | 1437 | \begin{macrodesc}{seetitle}{\op{url}\p{title}\p{why}} | 
|  | 1438 | Add a reference to an external document named \var{title}.  If | 
|  | 1439 | \var{url} is given, the title is made a hyperlink in the HTML | 
|  | 1440 | version of the documentation, and displayed below the title in | 
|  | 1441 | the typeset versions of the documentation. | 
|  | 1442 | \end{macrodesc} | 
|  | 1443 |  | 
| Fred Drake | 5802e48 | 2000-07-06 05:24:41 +0000 | [diff] [blame] | 1444 | \begin{macrodesc}{seeurl}{\p{url}\p{why}} | 
|  | 1445 | References to specific on-line resources should be given using | 
| Fred Drake | 5ed35fd | 2001-11-30 18:09:54 +0000 | [diff] [blame] | 1446 | the \macro{seeurl} macro if they don't have a meaningful title. | 
|  | 1447 | Online documents which have identifiable titles should be | 
|  | 1448 | referenced using the \macro{seetitle} macro, using the optional | 
|  | 1449 | parameter to that macro to provide the URL. | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1450 | \end{macrodesc} | 
|  | 1451 |  | 
|  | 1452 |  | 
|  | 1453 | \subsection{Index-generating Markup \label{indexing}} | 
|  | 1454 |  | 
|  | 1455 | Effective index generation for technical documents can be very | 
| Fred Drake | e15956b | 2000-04-03 04:51:13 +0000 | [diff] [blame] | 1456 | difficult, especially for someone familiar with the topic but not | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1457 | the creation of indexes.  Much of the difficulty arises in the | 
|  | 1458 | area of terminology: including the terms an expert would use for a | 
|  | 1459 | concept is not sufficient.  Coming up with the terms that a novice | 
| Fred Drake | 2c4e009 | 1999-03-29 14:55:55 +0000 | [diff] [blame] | 1460 | would look up is fairly difficult for an author who, typically, is | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1461 | an expert in the area she is writing on. | 
|  | 1462 |  | 
| Fred Drake | 2c4e009 | 1999-03-29 14:55:55 +0000 | [diff] [blame] | 1463 | The truly difficult aspects of index generation are not areas with | 
|  | 1464 | which the documentation tools can help.  However, ease | 
| Fred Drake | e15956b | 2000-04-03 04:51:13 +0000 | [diff] [blame] | 1465 | of producing the index once content decisions are made is within | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1466 | the scope of the tools.  Markup is provided which the processing | 
|  | 1467 | software is able to use to generate a variety of kinds of index | 
|  | 1468 | entry with minimal effort.  Additionally, many of the environments | 
| Fred Drake | 7a737df | 1999-04-23 14:41:44 +0000 | [diff] [blame] | 1469 | described in section \ref{info-units}, ``Information Units,'' will | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1470 | generate appropriate entries into the general and module indexes. | 
|  | 1471 |  | 
|  | 1472 | The following macro can be used to control the generation of index | 
| Fred Drake | adade92 | 1999-04-22 13:05:27 +0000 | [diff] [blame] | 1473 | data, and should be used in the document preamble: | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1474 |  | 
|  | 1475 | \begin{macrodesc}{makemodindex}{} | 
| Fred Drake | adade92 | 1999-04-22 13:05:27 +0000 | [diff] [blame] | 1476 | This should be used in the document preamble if a ``Module | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1477 | Index'' is desired for a document containing reference material | 
|  | 1478 | on many modules.  This causes a data file | 
| Fred Drake | d1fb779 | 1999-05-17 16:33:54 +0000 | [diff] [blame] | 1479 | \code{lib\var{jobname}.idx} to be created from the | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1480 | \macro{declaremodule} macros.  This file can be processed by the | 
|  | 1481 | \program{makeindex} program to generate a file which can be | 
|  | 1482 | \macro{input} into the document at the desired location of the | 
|  | 1483 | module index. | 
|  | 1484 | \end{macrodesc} | 
|  | 1485 |  | 
|  | 1486 | There are a number of macros that are useful for adding index | 
|  | 1487 | entries for particular concepts, many of which are specific to | 
|  | 1488 | programming languages or even Python. | 
|  | 1489 |  | 
| Fred Drake | adade92 | 1999-04-22 13:05:27 +0000 | [diff] [blame] | 1490 | \begin{macrodesc}{bifuncindex}{\p{name}} | 
| Fred Drake | ec8b905 | 1999-04-23 20:01:17 +0000 | [diff] [blame] | 1491 | Add an index entry referring to a built-in function named | 
|  | 1492 | \var{name}; parentheses should not be included after | 
| Fred Drake | 2c4e009 | 1999-03-29 14:55:55 +0000 | [diff] [blame] | 1493 | \var{name}. | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1494 | \end{macrodesc} | 
|  | 1495 |  | 
| Fred Drake | adade92 | 1999-04-22 13:05:27 +0000 | [diff] [blame] | 1496 | \begin{macrodesc}{exindex}{\p{exception}} | 
| Fred Drake | 2c4e009 | 1999-03-29 14:55:55 +0000 | [diff] [blame] | 1497 | Add a reference to an exception named \var{exception}.  The | 
| Neal Norwitz | 847207a | 2003-05-29 02:17:23 +0000 | [diff] [blame] | 1498 | exception should be class-based. | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1499 | \end{macrodesc} | 
|  | 1500 |  | 
| Fred Drake | adade92 | 1999-04-22 13:05:27 +0000 | [diff] [blame] | 1501 | \begin{macrodesc}{kwindex}{\p{keyword}} | 
| Fred Drake | 2c4e009 | 1999-03-29 14:55:55 +0000 | [diff] [blame] | 1502 | Add a reference to a language keyword (not a keyword parameter | 
|  | 1503 | in a function or method call). | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1504 | \end{macrodesc} | 
|  | 1505 |  | 
| Fred Drake | adade92 | 1999-04-22 13:05:27 +0000 | [diff] [blame] | 1506 | \begin{macrodesc}{obindex}{\p{object type}} | 
| Fred Drake | 2c4e009 | 1999-03-29 14:55:55 +0000 | [diff] [blame] | 1507 | Add an index entry for a built-in object type. | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1508 | \end{macrodesc} | 
|  | 1509 |  | 
| Fred Drake | adade92 | 1999-04-22 13:05:27 +0000 | [diff] [blame] | 1510 | \begin{macrodesc}{opindex}{\p{operator}} | 
| Fred Drake | 2c4e009 | 1999-03-29 14:55:55 +0000 | [diff] [blame] | 1511 | Add a reference to an operator, such as \samp{+}. | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1512 | \end{macrodesc} | 
|  | 1513 |  | 
| Fred Drake | adade92 | 1999-04-22 13:05:27 +0000 | [diff] [blame] | 1514 | \begin{macrodesc}{refmodindex}{\op{key}\p{module}} | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1515 | Add an index entry for module \var{module}; if \var{module} | 
|  | 1516 | contains an underscore, the optional parameter \var{key} should | 
|  | 1517 | be provided as the same string with underscores removed.  An | 
|  | 1518 | index entry ``\var{module} (module)'' will be generated.  This | 
|  | 1519 | is intended for use with non-standard modules implemented in | 
|  | 1520 | Python. | 
|  | 1521 | \end{macrodesc} | 
|  | 1522 |  | 
| Fred Drake | adade92 | 1999-04-22 13:05:27 +0000 | [diff] [blame] | 1523 | \begin{macrodesc}{refexmodindex}{\op{key}\p{module}} | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1524 | As for \macro{refmodindex}, but the index entry will be | 
|  | 1525 | ``\var{module} (extension module).''  This is intended for use | 
|  | 1526 | with non-standard modules not implemented in Python. | 
|  | 1527 | \end{macrodesc} | 
|  | 1528 |  | 
| Fred Drake | adade92 | 1999-04-22 13:05:27 +0000 | [diff] [blame] | 1529 | \begin{macrodesc}{refbimodindex}{\op{key}\p{module}} | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1530 | As for \macro{refmodindex}, but the index entry will be | 
|  | 1531 | ``\var{module} (built-in module).''  This is intended for use | 
|  | 1532 | with standard modules not implemented in Python. | 
|  | 1533 | \end{macrodesc} | 
|  | 1534 |  | 
| Fred Drake | adade92 | 1999-04-22 13:05:27 +0000 | [diff] [blame] | 1535 | \begin{macrodesc}{refstmodindex}{\op{key}\p{module}} | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1536 | As for \macro{refmodindex}, but the index entry will be | 
|  | 1537 | ``\var{module} (standard module).''  This is intended for use | 
|  | 1538 | with standard modules implemented in Python. | 
|  | 1539 | \end{macrodesc} | 
|  | 1540 |  | 
| Fred Drake | adade92 | 1999-04-22 13:05:27 +0000 | [diff] [blame] | 1541 | \begin{macrodesc}{stindex}{\p{statement}} | 
| Fred Drake | 2c4e009 | 1999-03-29 14:55:55 +0000 | [diff] [blame] | 1542 | Add an index entry for a statement type, such as \keyword{print} | 
| Fred Drake | adade92 | 1999-04-22 13:05:27 +0000 | [diff] [blame] | 1543 | or \keyword{try}/\keyword{finally}. | 
|  | 1544 |  | 
|  | 1545 | XXX Need better examples of difference from \macro{kwindex}. | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1546 | \end{macrodesc} | 
|  | 1547 |  | 
|  | 1548 |  | 
|  | 1549 | Additional macros are provided which are useful for conveniently | 
|  | 1550 | creating general index entries which should appear at many places | 
|  | 1551 | in the index by rotating a list of words.  These are simple macros | 
|  | 1552 | that simply use \macro{index} to build some number of index | 
|  | 1553 | entries.  Index entries build using these macros contain both | 
|  | 1554 | primary and secondary text. | 
|  | 1555 |  | 
| Fred Drake | adade92 | 1999-04-22 13:05:27 +0000 | [diff] [blame] | 1556 | \begin{macrodesc}{indexii}{\p{word1}\p{word2}} | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1557 | Build two index entries.  This is exactly equivalent to using | 
|  | 1558 | \code{\e index\{\var{word1}!\var{word2}\}} and | 
|  | 1559 | \code{\e index\{\var{word2}!\var{word1}\}}. | 
|  | 1560 | \end{macrodesc} | 
|  | 1561 |  | 
| Fred Drake | adade92 | 1999-04-22 13:05:27 +0000 | [diff] [blame] | 1562 | \begin{macrodesc}{indexiii}{\p{word1}\p{word2}\p{word3}} | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1563 | Build three index entries.  This is exactly equivalent to using | 
|  | 1564 | \code{\e index\{\var{word1}!\var{word2} \var{word3}\}}, | 
|  | 1565 | \code{\e index\{\var{word2}!\var{word3}, \var{word1}\}}, and | 
|  | 1566 | \code{\e index\{\var{word3}!\var{word1} \var{word2}\}}. | 
|  | 1567 | \end{macrodesc} | 
|  | 1568 |  | 
| Fred Drake | adade92 | 1999-04-22 13:05:27 +0000 | [diff] [blame] | 1569 | \begin{macrodesc}{indexiv}{\p{word1}\p{word2}\p{word3}\p{word4}} | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1570 | Build four index entries.  This is exactly equivalent to using | 
|  | 1571 | \code{\e index\{\var{word1}!\var{word2} \var{word3} \var{word4}\}}, | 
|  | 1572 | \code{\e index\{\var{word2}!\var{word3} \var{word4}, \var{word1}\}}, | 
|  | 1573 | \code{\e index\{\var{word3}!\var{word4}, \var{word1} \var{word2}\}}, | 
|  | 1574 | and | 
|  | 1575 | \code{\e index\{\var{word4}!\var{word1} \var{word2} \var{word3}\}}. | 
|  | 1576 | \end{macrodesc} | 
|  | 1577 |  | 
| Fred Drake | 432cef0 | 2001-07-06 22:34:33 +0000 | [diff] [blame] | 1578 | \subsection{Grammar Production Displays \label{grammar-displays}} | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1579 |  | 
| Fred Drake | 432cef0 | 2001-07-06 22:34:33 +0000 | [diff] [blame] | 1580 | Special markup is available for displaying the productions of a | 
|  | 1581 | formal grammar.  The markup is simple and does not attempt to | 
|  | 1582 | model all aspects of BNF (or any derived forms), but provides | 
|  | 1583 | enough to allow context-free grammars to be displayed in a way | 
|  | 1584 | that causes uses of a symbol to be rendered as hyperlinks to the | 
|  | 1585 | definition of the symbol.  There is one environment and a pair of | 
|  | 1586 | macros: | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1587 |  | 
| Fred Drake | 432cef0 | 2001-07-06 22:34:33 +0000 | [diff] [blame] | 1588 | \begin{envdesc}{productionlist}{\op{language}} | 
|  | 1589 | This environment is used to enclose a group of productions.  The | 
|  | 1590 | two macros are only defined within this environment.  If a | 
|  | 1591 | document descibes more than one language, the optional parameter | 
|  | 1592 | \var{language} should be used to distinguish productions between | 
|  | 1593 | languages.  The value of the parameter should be a short name | 
|  | 1594 | that can be used as part of a filename; colons or other | 
|  | 1595 | characters that can't be used in filename across platforms | 
|  | 1596 | should be included. | 
|  | 1597 | \end{envdesc} | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1598 |  | 
| Fred Drake | 432cef0 | 2001-07-06 22:34:33 +0000 | [diff] [blame] | 1599 | \begin{macrodesc}{production}{\p{name}\p{definition}} | 
|  | 1600 | A production rule in the grammar.  The rule defines the symbol | 
|  | 1601 | \var{name} to be \var{definition}.  \var{name} should not | 
|  | 1602 | contain any markup, and the use of hyphens in a document which | 
|  | 1603 | supports more than one grammar is undefined.  \var{definition} | 
|  | 1604 | may contain \macro{token} macros and any additional content | 
|  | 1605 | needed to describe the grammatical model of \var{symbol}.  Only | 
|  | 1606 | one \macro{production} may be used to define a symbol --- | 
|  | 1607 | multiple definitions are not allowed. | 
|  | 1608 | \end{macrodesc} | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1609 |  | 
| Fred Drake | 432cef0 | 2001-07-06 22:34:33 +0000 | [diff] [blame] | 1610 | \begin{macrodesc}{token}{\p{name}} | 
|  | 1611 | The name of a symbol defined by a \macro{production} macro, used | 
|  | 1612 | in the \var{definition} of a symbol.  Where possible, this will | 
|  | 1613 | be rendered as a hyperlink to the definition of the symbol | 
|  | 1614 | \var{name}. | 
|  | 1615 | \end{macrodesc} | 
| Fred Drake | 4293468 | 2000-04-03 15:00:28 +0000 | [diff] [blame] | 1616 |  | 
| Fred Drake | 432cef0 | 2001-07-06 22:34:33 +0000 | [diff] [blame] | 1617 | Note that the entire grammar does not need to be defined in a | 
|  | 1618 | single \env{productionlist} environment; any number of | 
|  | 1619 | groupings may be used to describe the grammar.  Every use of the | 
|  | 1620 | \macro{token} must correspond to a \macro{production}. | 
|  | 1621 |  | 
|  | 1622 | The following is an example taken from the | 
|  | 1623 | \citetitle[../ref/identifiers.html]{Python Reference Manual}: | 
|  | 1624 |  | 
|  | 1625 | \begin{verbatim} | 
|  | 1626 | \begin{productionlist} | 
|  | 1627 | \production{identifier} | 
|  | 1628 | {(\token{letter}|"_") (\token{letter} | \token{digit} | "_")*} | 
|  | 1629 | \production{letter} | 
|  | 1630 | {\token{lowercase} | \token{uppercase}} | 
|  | 1631 | \production{lowercase} | 
|  | 1632 | {"a"..."z"} | 
|  | 1633 | \production{uppercase} | 
|  | 1634 | {"A"..."Z"} | 
|  | 1635 | \production{digit} | 
|  | 1636 | {"0"..."9"} | 
|  | 1637 | \end{productionlist} | 
|  | 1638 | \end{verbatim} | 
|  | 1639 |  | 
|  | 1640 |  | 
| Fred Drake | e134158 | 2002-09-25 18:44:21 +0000 | [diff] [blame] | 1641 | \subsection{Graphical Interface Components \label{gui-markup}} | 
| Fred Drake | 432cef0 | 2001-07-06 22:34:33 +0000 | [diff] [blame] | 1642 |  | 
|  | 1643 | The components of graphical interfaces will be assigned markup, but | 
| Fred Drake | e134158 | 2002-09-25 18:44:21 +0000 | [diff] [blame] | 1644 | most of the specifics have not been determined. | 
|  | 1645 |  | 
|  | 1646 | \begin{macrodesc}{menuselection}{\p{menupath}} | 
|  | 1647 | Menu selections should be marked using a combination of | 
|  | 1648 | \macro{menuselection} and \macro{sub}.  This macro is used to mark | 
|  | 1649 | a complete sequence of menu selections, including selecting | 
|  | 1650 | submenus and choosing a specific operation, or any subsequence of | 
|  | 1651 | such a sequence.  The names of individual selections should be | 
|  | 1652 | separated by occurances of \macro{sub}. | 
|  | 1653 |  | 
|  | 1654 | For example, to mark the selection ``\menuselection{Start \sub | 
|  | 1655 | Programs}'', use this markup: | 
|  | 1656 |  | 
|  | 1657 | \begin{verbatim} | 
|  | 1658 | \menuselection{Start \sub Programs} | 
|  | 1659 | \end{verbatim} | 
|  | 1660 |  | 
|  | 1661 | When including a selection that includes some trailing indicator, | 
|  | 1662 | such as the ellipsis some operating systems use to indicate that | 
|  | 1663 | the command opens a dialog, the indicator should be omitted from | 
|  | 1664 | the selection name. | 
|  | 1665 | \end{macrodesc} | 
|  | 1666 |  | 
|  | 1667 | \begin{macrodesc}{sub}{} | 
|  | 1668 | Separator for menu selections that include multiple levels.  This | 
|  | 1669 | macro is only defined within the context of the | 
|  | 1670 | \macro{menuselection} macro. | 
|  | 1671 | \end{macrodesc} | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1672 |  | 
|  | 1673 |  | 
| Fred Drake | f1b3de8 | 2001-07-24 14:38:34 +0000 | [diff] [blame] | 1674 | \section{Processing Tools \label{tools}} | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1675 |  | 
| Fred Drake | f1b3de8 | 2001-07-24 14:38:34 +0000 | [diff] [blame] | 1676 | \subsection{External Tools \label{tools-external}} | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1677 |  | 
|  | 1678 | Many tools are needed to be able to process the Python | 
|  | 1679 | documentation if all supported formats are required.  This | 
| Fred Drake | adade92 | 1999-04-22 13:05:27 +0000 | [diff] [blame] | 1680 | section lists the tools used and when each is required.  Consult | 
|  | 1681 | the \file{Doc/README} file to see if there are specific version | 
|  | 1682 | requirements for any of these. | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1683 |  | 
|  | 1684 | \begin{description} | 
|  | 1685 | \item[\program{dvips}] | 
|  | 1686 | This program is a typical part of \TeX{} installations.  It is | 
|  | 1687 | used to generate PostScript from the ``device independent'' | 
| Fred Drake | 2c4e009 | 1999-03-29 14:55:55 +0000 | [diff] [blame] | 1688 | \file{.dvi} files.  It is needed for the conversion to | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1689 | PostScript. | 
|  | 1690 |  | 
|  | 1691 | \item[\program{emacs}] | 
|  | 1692 | Emacs is the kitchen sink of programmers' editors, and a damn | 
|  | 1693 | fine kitchen sink it is.  It also comes with some of the | 
|  | 1694 | processing needed to support the proper menu structures for | 
|  | 1695 | Texinfo documents when an info conversion is desired.  This is | 
| Fred Drake | 2c4e009 | 1999-03-29 14:55:55 +0000 | [diff] [blame] | 1696 | needed for the info conversion.  Using \program{xemacs} | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1697 | instead of FSF \program{emacs} may lead to instability in the | 
|  | 1698 | conversion, but that's because nobody seems to maintain the | 
|  | 1699 | Emacs Texinfo code in a portable manner. | 
|  | 1700 |  | 
|  | 1701 | \item[\program{latex}] | 
| Fred Drake | b5f17f2 | 2001-08-28 18:09:11 +0000 | [diff] [blame] | 1702 | \LaTeX{} is a large and extensible macro package by Leslie | 
|  | 1703 | Lamport, based on \TeX, a world-class typesetter by Donald | 
|  | 1704 | Knuth.  It is used for the conversion to PostScript, and is | 
|  | 1705 | needed for the HTML conversion as well (\LaTeX2HTML requires | 
|  | 1706 | one of the intermediate files it creates). | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1707 |  | 
|  | 1708 | \item[\program{latex2html}] | 
|  | 1709 | Probably the longest Perl script anyone ever attempted to | 
|  | 1710 | maintain.  This converts \LaTeX{} documents to HTML documents, | 
|  | 1711 | and does a pretty reasonable job.  It is required for the | 
|  | 1712 | conversions to HTML and GNU info. | 
|  | 1713 |  | 
|  | 1714 | \item[\program{lynx}] | 
|  | 1715 | This is a text-mode Web browser which includes an | 
|  | 1716 | HTML-to-plain text conversion.  This is used to convert | 
|  | 1717 | \code{howto} documents to text. | 
|  | 1718 |  | 
|  | 1719 | \item[\program{make}] | 
|  | 1720 | Just about any version should work for the standard documents, | 
|  | 1721 | but GNU \program{make} is required for the experimental | 
|  | 1722 | processes in \file{Doc/tools/sgmlconv/}, at least while | 
| Fred Drake | b5f17f2 | 2001-08-28 18:09:11 +0000 | [diff] [blame] | 1723 | they're experimental.  This is not required for running the | 
| Fred Drake | f9dc043 | 2001-08-29 02:34:10 +0000 | [diff] [blame] | 1724 | \program{mkhowto} script. | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1725 |  | 
|  | 1726 | \item[\program{makeindex}] | 
|  | 1727 | This is a standard program for converting \LaTeX{} index data | 
|  | 1728 | to a formatted index; it should be included with all \LaTeX{} | 
|  | 1729 | installations.  It is needed for the PDF and PostScript | 
|  | 1730 | conversions. | 
|  | 1731 |  | 
|  | 1732 | \item[\program{makeinfo}] | 
|  | 1733 | GNU \program{makeinfo} is used to convert Texinfo documents to | 
|  | 1734 | GNU info files.  Since Texinfo is used as an intermediate | 
|  | 1735 | format in the info conversion, this program is needed in that | 
|  | 1736 | conversion. | 
|  | 1737 |  | 
|  | 1738 | \item[\program{pdflatex}] | 
|  | 1739 | pdf\TeX{} is a relatively new variant of \TeX, and is used to | 
|  | 1740 | generate the PDF version of the manuals.  It is typically | 
|  | 1741 | installed as part of most of the large \TeX{} distributions. | 
| Fred Drake | 7a737df | 1999-04-23 14:41:44 +0000 | [diff] [blame] | 1742 | \program{pdflatex} is pdf\TeX{} using the \LaTeX{} format. | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1743 |  | 
|  | 1744 | \item[\program{perl}] | 
|  | 1745 | Perl is required for \LaTeX2HTML{} and one of the scripts used | 
|  | 1746 | to post-process \LaTeX2HTML output, as well as the | 
| Fred Drake | 2c4e009 | 1999-03-29 14:55:55 +0000 | [diff] [blame] | 1747 | HTML-to-Texinfo conversion.  This is required for | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1748 | the HTML and GNU info conversions. | 
|  | 1749 |  | 
|  | 1750 | \item[\program{python}] | 
|  | 1751 | Python is used for many of the scripts in the | 
|  | 1752 | \file{Doc/tools/} directory; it is required for all | 
|  | 1753 | conversions.  This shouldn't be a problem if you're interested | 
|  | 1754 | in writing documentation for Python! | 
|  | 1755 | \end{description} | 
|  | 1756 |  | 
|  | 1757 |  | 
| Fred Drake | f1b3de8 | 2001-07-24 14:38:34 +0000 | [diff] [blame] | 1758 | \subsection{Internal Tools \label{tools-internal}} | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1759 |  | 
|  | 1760 | This section describes the various scripts that are used to | 
|  | 1761 | implement various stages of document processing or to orchestrate | 
| Fred Drake | 2c4e009 | 1999-03-29 14:55:55 +0000 | [diff] [blame] | 1762 | entire build sequences.  Most of these tools are only useful | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1763 | in the context of building the standard documentation, but some | 
|  | 1764 | are more general. | 
|  | 1765 |  | 
|  | 1766 | \begin{description} | 
|  | 1767 | \item[\program{mkhowto}] | 
| Fred Drake | 87f768e | 1999-05-17 15:22:45 +0000 | [diff] [blame] | 1768 | This is the primary script used to format third-party | 
|  | 1769 | documents.  It contains all the logic needed to ``get it | 
|  | 1770 | right.''  The proper way to use this script is to make a | 
|  | 1771 | symbolic link to it or run it in place; the actual script file | 
|  | 1772 | must be stored as part of the documentation source tree, | 
|  | 1773 | though it may be used to format documents outside the | 
| Fred Drake | ce44498 | 2000-04-11 18:52:52 +0000 | [diff] [blame] | 1774 | tree.  Use \program{mkhowto} \longprogramopt{help} | 
| Fred Drake | d290c10 | 1999-11-09 18:03:00 +0000 | [diff] [blame] | 1775 | for a list of | 
| Fred Drake | d2a727f | 1999-05-27 21:45:54 +0000 | [diff] [blame] | 1776 | command line options. | 
| Fred Drake | 87f768e | 1999-05-17 15:22:45 +0000 | [diff] [blame] | 1777 |  | 
| Fred Drake | d1fb779 | 1999-05-17 16:33:54 +0000 | [diff] [blame] | 1778 | \program{mkhowto} can be used for both \code{howto} and | 
| Fred Drake | d80032b | 2002-09-25 21:41:22 +0000 | [diff] [blame] | 1779 | \code{manual} class documents.  It is usually a good idea to | 
|  | 1780 | always use the latest version of this tool rather than a | 
|  | 1781 | version from an older source release of Python. | 
| Fred Drake | d1fb779 | 1999-05-17 16:33:54 +0000 | [diff] [blame] | 1782 |  | 
| Fred Drake | 87f768e | 1999-05-17 15:22:45 +0000 | [diff] [blame] | 1783 | XXX  Need more here. | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1784 | \end{description} | 
|  | 1785 |  | 
|  | 1786 |  | 
| Fred Drake | eb2b833 | 2002-05-01 22:05:30 +0000 | [diff] [blame] | 1787 | \subsection{Working on Cygwin \label{cygwin}} | 
|  | 1788 |  | 
| Fred Drake | eb2b833 | 2002-05-01 22:05:30 +0000 | [diff] [blame] | 1789 | Installing the required tools under Cygwin under Cygwin can be a | 
|  | 1790 | little tedious, if only because many packages are more difficult | 
|  | 1791 | to install under Cygwin. | 
|  | 1792 |  | 
|  | 1793 | Using the Cygwin installer, make sure your Cygwin installation | 
|  | 1794 | includes Perl, Python, and the \TeX{} packages.  Perl and Python | 
|  | 1795 | are located under \menuselection{Interpreters} in the installer | 
|  | 1796 | The \TeX{} packages are located in the \menuselection{Text} | 
|  | 1797 | section; installing the tetex-beta, texmf, texmf-base, and | 
|  | 1798 | texmf-extra ensures that all the required packages are available. | 
|  | 1799 | (There may be a more minimal set, but I've not spent time trying | 
|  | 1800 | to minimize the installation.) | 
|  | 1801 |  | 
|  | 1802 | The netpbm package is used by \LaTeX2HTML, and \emph{must} be | 
|  | 1803 | installed before \LaTeX2HTML can be successfully installed, even | 
|  | 1804 | though they will never be used for most Python documentation. | 
|  | 1805 | References to download locations are located in the \ulink{netpbm | 
|  | 1806 | README}{http://netpbm.sourceforge.net/README}.  Install according | 
|  | 1807 | to the instructions. | 
|  | 1808 |  | 
|  | 1809 | \LaTeX2HTML can be installed from the source archive, but only | 
|  | 1810 | after munging one of the files in the distribution.  Edit the file | 
|  | 1811 | \file{L2hos.pm} in the top level of the unpacked distribution; | 
|  | 1812 | near the bottom of the file, change the text | 
|  | 1813 | \code{\$\textasciicircum{}O} with the text \code{'unix'}.  Proceed | 
|  | 1814 | using this command to build and install the software: | 
|  | 1815 |  | 
|  | 1816 | \begin{verbatim} | 
|  | 1817 | % configure && make install | 
|  | 1818 | \end{verbatim} | 
|  | 1819 |  | 
| Fred Drake | 77c1895 | 2002-05-02 21:10:48 +0000 | [diff] [blame] | 1820 | You should now be able to build at least the HTML, PDF, and | 
|  | 1821 | PostScript versions of the formatted documentation. | 
|  | 1822 |  | 
| Fred Drake | eb2b833 | 2002-05-01 22:05:30 +0000 | [diff] [blame] | 1823 |  | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1824 | \section{Future Directions \label{futures}} | 
|  | 1825 |  | 
|  | 1826 | The history of the Python documentation is full of changes, most of | 
|  | 1827 | which have been fairly small and evolutionary.  There has been a | 
|  | 1828 | great deal of discussion about making large changes in the markup | 
|  | 1829 | languages and tools used to process the documentation.  This section | 
|  | 1830 | deals with the nature of the changes and what appears to be the most | 
|  | 1831 | likely path of future development. | 
|  | 1832 |  | 
|  | 1833 | \subsection{Structured Documentation \label{structured}} | 
|  | 1834 |  | 
|  | 1835 | Most of the small changes to the \LaTeX{} markup have been made | 
|  | 1836 | with an eye to divorcing the markup from the presentation, making | 
|  | 1837 | both a bit more maintainable.  Over the course of 1998, a large | 
|  | 1838 | number of changes were made with exactly this in mind; previously, | 
|  | 1839 | changes had been made but in a less systematic manner and with | 
|  | 1840 | more concern for not needing to update the existing content.  The | 
|  | 1841 | result has been a highly structured and semantically loaded markup | 
|  | 1842 | language implemented in \LaTeX.  With almost no basic \TeX{} or | 
|  | 1843 | \LaTeX{} markup in use, however, the markup syntax is about the | 
|  | 1844 | only evidence of \LaTeX{} in the actual document sources. | 
|  | 1845 |  | 
|  | 1846 | One side effect of this is that while we've been able to use | 
|  | 1847 | standard ``engines'' for manipulating the documents, such as | 
|  | 1848 | \LaTeX{} and \LaTeX2HTML, most of the actual transformations have | 
| Fred Drake | 7a737df | 1999-04-23 14:41:44 +0000 | [diff] [blame] | 1849 | been created specifically for Python.  The \LaTeX{} document | 
|  | 1850 | classes and \LaTeX2HTML support are both complete implementations | 
|  | 1851 | of the specific markup designed for these documents. | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1852 |  | 
|  | 1853 | Combining highly customized markup with the somewhat esoteric | 
|  | 1854 | systems used to process the documents leads us to ask some | 
|  | 1855 | questions:  Can we do this more easily?  and, Can we do this | 
|  | 1856 | better?  After a great deal of discussion with the community, we | 
|  | 1857 | have determined that actively pursuing modern structured | 
| Fred Drake | 2c4e009 | 1999-03-29 14:55:55 +0000 | [diff] [blame] | 1858 | documentation systems is worth some investment of time. | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1859 |  | 
|  | 1860 | There appear to be two real contenders in this arena: the Standard | 
|  | 1861 | General Markup Language (SGML), and the Extensible Markup Language | 
|  | 1862 | (XML).  Both of these standards have advantages and disadvantages, | 
|  | 1863 | and many advantages are shared. | 
|  | 1864 |  | 
|  | 1865 | SGML offers advantages which may appeal most to authors, | 
|  | 1866 | especially those using ordinary text editors.  There are also | 
|  | 1867 | additional abilities to define content models.  A number of | 
| Fred Drake | 67f193f | 2001-07-09 16:04:03 +0000 | [diff] [blame] | 1868 | high-quality tools with demonstrated maturity are available, but | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1869 | most are not free; for those which are, portability issues remain | 
|  | 1870 | a problem. | 
|  | 1871 |  | 
|  | 1872 | The advantages of XML include the availability of a large number | 
|  | 1873 | of evolving tools.  Unfortunately, many of the associated | 
|  | 1874 | standards are still evolving, and the tools will have to follow | 
|  | 1875 | along.  This means that developing a robust tool set that uses | 
|  | 1876 | more than the basic XML 1.0 recommendation is not possible in the | 
|  | 1877 | short term.  The promised availability of a wide variety of | 
|  | 1878 | high-quality tools which support some of the most important | 
|  | 1879 | related standards is not immediate.  Many tools are likely to be | 
| Fred Drake | 67f193f | 2001-07-09 16:04:03 +0000 | [diff] [blame] | 1880 | free, and the portability issues of those which are, are not | 
|  | 1881 | expected to be significant. | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1882 |  | 
| Fred Drake | 67f193f | 2001-07-09 16:04:03 +0000 | [diff] [blame] | 1883 | It turns out that converting to an XML or SGML system holds | 
|  | 1884 | promise for translators as well; how much can be done to ease the | 
|  | 1885 | burden on translators remains to be seen, and may have some impact | 
|  | 1886 | on the schema and specific technologies used. | 
|  | 1887 |  | 
|  | 1888 | XXX Eventual migration to XML. | 
|  | 1889 |  | 
|  | 1890 | The documentation will be moved to XML in the future, and tools | 
|  | 1891 | are being written which will convert the documentation from the | 
|  | 1892 | current format to something close to a finished version, to the | 
|  | 1893 | extent that the desired information is already present in the | 
|  | 1894 | documentation.  Some XSLT stylesheets have been started for | 
|  | 1895 | presenting a preliminary XML version as HTML, but the results are | 
|  | 1896 | fairly rough.. | 
|  | 1897 |  | 
|  | 1898 | The timeframe for the conversion is not clear since there doesn't | 
|  | 1899 | seem to be much time available to work on this, but the appearant | 
|  | 1900 | benefits are growing more substantial at a moderately rapid pace. | 
|  | 1901 |  | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1902 |  | 
|  | 1903 | \subsection{Discussion Forums \label{discussion}} | 
|  | 1904 |  | 
|  | 1905 | Discussion of the future of the Python documentation and related | 
| Fred Drake | 7a737df | 1999-04-23 14:41:44 +0000 | [diff] [blame] | 1906 | topics takes place in the Documentation Special Interest Group, or | 
|  | 1907 | ``Doc-SIG.''  Information on the group, including mailing list | 
|  | 1908 | archives and subscription information, is available at | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1909 | \url{http://www.python.org/sigs/doc-sig/}.  The SIG is open to all | 
|  | 1910 | interested parties. | 
|  | 1911 |  | 
|  | 1912 | Comments and bug reports on the standard documents should be sent | 
|  | 1913 | to \email{python-docs@python.org}.  This may include comments | 
| Fred Drake | adade92 | 1999-04-22 13:05:27 +0000 | [diff] [blame] | 1914 | about formatting, content, grammatical and spelling errors, or | 
| Fred Drake | d1fb779 | 1999-05-17 16:33:54 +0000 | [diff] [blame] | 1915 | this document.  You can also send comments on this document | 
|  | 1916 | directly to the author at \email{fdrake@acm.org}. | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1917 |  | 
| Skip Montanaro | 176bda4cd | 2002-04-19 04:50:44 +0000 | [diff] [blame] | 1918 | \input{doc.ind} | 
|  | 1919 |  | 
| Fred Drake | acffaee | 1999-03-16 16:09:13 +0000 | [diff] [blame] | 1920 | \end{document} |