summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--Doc/myformat.perl690
-rw-r--r--Doc/myformat.sty648
2 files changed, 0 insertions, 1338 deletions
diff --git a/Doc/myformat.perl b/Doc/myformat.perl
deleted file mode 100644
index 2e64be27..0000000
--- a/Doc/myformat.perl
+++ /dev/null
@@ -1,690 +0,0 @@
-# myformat.perl by Guido van Rossum <guido@cwi.nl> 25 Jan 1994 -*- perl -*-
-#
-# Extension to LaTeX2HTML for documents using myformat.sty.
-# Subroutines of the form do_cmd_<name> here define translations
-# for LaTeX commands \<name> defined in the corresponding .sty file.
-#
-# XXX Not complete: \indexii etc.; \funcitem etc.
-
-package main;
-
-# words typeset in a special way (not in HTML though)
-
-sub do_cmd_ABC{ join('', 'ABC', @_[0]); }
-sub do_cmd_UNIX{ join('', 'Unix', @_[0]); }
-sub do_cmd_ASCII{ join('', 'ASCII', @_[0]); }
-sub do_cmd_POSIX{ join('', 'POSIX', @_[0]); }
-sub do_cmd_C{ join('', 'C', @_[0]); }
-sub do_cmd_Cpp{ join('', 'C++', @_[0]); }
-sub do_cmd_EOF{ join('', 'EOF', @_[0]); }
-sub do_cmd_NULL{ join('', '<tt>NULL</tt>', @_[0]); }
-
-sub do_cmd_e{ local($_) = @_; '&#92;' . $_; }
-
-$AUTHOR_ADDRESS = '';
-$PYTHON_VERSION = '';
-
-sub do_cmd_version{ $PYTHON_VERSION . @_[0]; }
-sub do_cmd_release{
- local($_) = @_;
- s/$any_next_pair_pr_rx//;
- $PYTHON_VERSION = "$2";
- $_;
-}
-
-sub do_cmd_authoraddress{
- local($_) = @_;
- s/$any_next_pair_pr_rx//;
- $AUTHOR_ADDRESS = "$2";
- $_;
-}
-
-sub do_cmd_hackscore{
- local($_) = @_;
- s/$any_next_pair_pr_rx/_/;
- $_;
-}
-
-sub do_cmd_optional{
- local($_) = @_;
- s/$any_next_pair_pr_rx/<\/var><big>\[<\/big><var>\2<\/var><big>\]<\/big><var>/;
- $_;
-}
-
-sub do_cmd_varvars{
- local($_) = @_;
- s/$any_next_pair_pr_rx/<var>\2<\/var>/;
- $_;
-}
-
-# texinfo-like formatting commands: \code{...} etc.
-
-sub do_cmd_code{
- local($_) = @_;
- s/$any_next_pair_pr_rx/<tt>\2<\/tt>/;
- $_;
-}
-
-sub do_cmd_sectcode{ &do_cmd_code(@_); }
-sub do_cmd_module{ &do_cmd_code(@_); }
-sub do_cmd_keyword{ &do_cmd_code(@_); }
-sub do_cmd_exception{ &do_cmd_code(@_); }
-sub do_cmd_class{ &do_cmd_code(@_); }
-sub do_cmd_function{ &do_cmd_code(@_); }
-sub do_cmd_constant{ &do_cmd_code(@_); }
-sub do_cmd_member{ &do_cmd_code(@_); }
-sub do_cmd_method{ &do_cmd_code(@_); }
-sub do_cmd_email{ &do_cmd_code(@_); }
-sub do_cmd_program{ &do_cmd_code(@_); }
-sub do_cmd_cfunction{ &do_cmd_code(@_); }
-sub do_cmd_cdata{ &do_cmd_code(@_); }
-sub do_cmd_ctype{ &do_cmd_code(@_); }
-
-sub do_cmd_email{
- local($_) = @_;
- s/$any_next_pair_pr_rx/<tt><font face=sans-serif>\2<\/font><\/tt>/;
- $_;
-}
-
-sub do_cmd_url{
- # use the URL as both text and hyperlink
- local($_) = @_;
- s/$any_next_pair_pr_rx//;
- local($url) = $2;
- $url =~ s/~/&#126;/g;
- "<tt><font face=sans-serif><a href=\"$url\">$url</a></font></tt>" . $_;
-}
-
-sub do_cmd_manpage{
- # two parameters: \manpage{name}{section}
- local($_) = @_;
- local($any_next_pair_pr_rx3) = "$OP(\\d+)$CP([\\s\\S]*)$OP\\3$CP";
- s/$next_pair_pr_rx$any_next_pair_pr_rx3/<em>\2<\/em>(\4)/;
- $_;
-}
-
-sub do_cmd_rfc{
- local($_) = @_;
- s/$next_pair_pr_rx//;
- local($br_id,$rfcnumber) = ($1, $2);
-
- # Save the reference
- local($nstr) = &gen_index_id("RFC!RFC $rfcnumber", '');
- $index{$nstr} .= &make_half_href("$CURRENT_FILE#$br_id");
- "<a name=\"$br_id\">RFC $rfcnumber<\/a>" .$_;
-}
-
-sub do_cmd_kbd{
- local($_) = @_;
- s/$any_next_pair_pr_rx/<kbd>\2<\/kbd>/;
- $_;
-}
-
-sub do_cmd_key{
- local($_) = @_;
- s/$any_next_pair_pr_rx/<tt>\2<\/tt>/;
- $_;
-}
-
-sub do_cmd_var{
- local($_) = @_;
- s/$any_next_pair_pr_rx/<em>\2<\/em>/;
- $_;
-}
-
-sub do_cmd_dfn{
- local($_) = @_;
- s/$any_next_pair_pr_rx/<i><dfn>\2<\/dfn><\/i>/;
- $_;
-}
-
-sub do_cmd_emph{
- local($_) = @_;
- s/$any_next_pair_pr_rx/<em>\2<\/em>/;
- $_;
-}
-
-sub do_cmd_strong{
- local($_) = @_;
- s/$any_next_pair_pr_rx/<b>\2<\/b>/;
- $_;
-}
-
-sub do_cmd_deprecated{
- # two parameters: \deprecated{version}{whattodo}
- local($_) = @_;
- local($any_next_pair_pr_rx3) = "$OP(\\d+)$CP([\\s\\S]*)$OP\\3$CP";
- local($release,$action) = ($2, $4);
- s/$next_pair_pr_rx$any_next_pair_pr_rx3//;
- "<b>Deprecated since release $release.</b>"
- . "\n$action<p>"
- . $_;
-}
-
-# file and samp are at the end of this file since they screw up fontlock.
-
-# index commands
-
-$INDEX_SUBITEM = "";
-
-sub get_indexsubitem{
- $INDEX_SUBITEM ? " $INDEX_SUBITEM" : '';
-}
-
-sub do_cmd_setindexsubitem{
- local($_) = @_;
- s/$any_next_pair_pr_rx//;
- $INDEX_SUBITEM = $2;
- $_;
-}
-if (defined &process_commands_wrap_deferred) {
- &process_commands_wrap_deferred("setindexsubitem \# {}\n");
-}
-
-sub do_cmd_indexii{
- local($_) = @_;
- s/$next_pair_pr_rx//o;
- local($br_id1, $str1) = ($1, $2);
- s/$next_pair_pr_rx//o;
- local($br_id2, $str2) = ($1, $2);
- join('', &make_index_entry($br_id1, "$str1 $str2"),
- &make_index_entry($br_id2, "$str2, $str1"), $_);
-}
-
-sub do_cmd_indexiii{
- local($_) = @_;
- s/$next_pair_pr_rx//o;
- local($br_id1, $str1) = ($1, $2);
- s/$next_pair_pr_rx//o;
- local($br_id2, $str2) = ($1, $2);
- s/$next_pair_pr_rx//o;
- local($br_id3, $str3) = ($1, $2);
- join('', &make_index_entry($br_id1, "$str1 $str2 $str3"),
- &make_index_entry($br_id2, "$str2 $str3, $str1"),
- &make_index_entry($br_id3, "$str3, $str1 $str2"),
- $_);
-}
-
-sub do_cmd_indexiv{
- local($_) = @_;
- s/$next_pair_pr_rx//o;
- local($br_id1, $str1) = ($1, $2);
- s/$next_pair_pr_rx//o;
- local($br_id2, $str2) = ($1, $2);
- s/$next_pair_pr_rx//o;
- local($br_id3, $str3) = ($1, $2);
- s/$next_pair_pr_rx//o;
- local($br_id4, $str4) = ($1, $2);
- join('', &make_index_entry($br_id1, "$str1 $str2 $str3 $str4"),
- &make_index_entry($br_id2, "$str2 $str3 $str4, $str1"),
- &make_index_entry($br_id3, "$str3 $str4, $str1 $str2"),
- &make_index_entry($br_id4, "$str4, $str1 $str2 $str3"),
- $_);
-}
-
-sub do_cmd_ttindex{ &do_cmd_index(@_); }
-
-sub my_typed_index_helper{
- local($word, $_) = @_;
- s/$next_pair_pr_rx//o;
- local($br_id, $str) = ($1, $2);
- join('', &make_index_entry($br_id, "$str $word"),
- &make_index_entry($br_id, "$word, $str"), $_);
-}
-
-sub do_cmd_stindex{ &my_typed_index_helper('statement', @_); }
-sub do_cmd_opindex{ &my_typed_index_helper('operator', @_); }
-sub do_cmd_exindex{ &my_typed_index_helper('exception', @_); }
-sub do_cmd_obindex{ &my_typed_index_helper('object', @_); }
-
-sub my_parword_index_helper{
- local($word, $_) = @_;
- s/$next_pair_pr_rx//o;
- local($br_id, $str) = ($1, $2);
- &make_index_entry($br_id, "$str ($word)") . $_;
-}
-
-
-# Set this to true to strip out the <tt>...</tt> from index entries;
-# this is analogous to using the second definition of \idxcode{} from
-# myformat.sty.
-#
-# It is used from &make_mod_index_entry() and &make_str_index_entry().
-#
-$STRIP_INDEX_TT = 0;
-
-sub make_mod_index_entry{
- local($br_id,$str,$define) = @_;
- local($halfref) = &make_half_href("$CURRENT_FILE#$br_id");
- # If TITLE is not yet available (i.e the \index command is in the title
- # of the current section), use $ref_before.
- $TITLE = $ref_before unless $TITLE;
- # Save the reference
- if ($define eq "DEF") {
- local($nstr,$garbage) = split / /, $str, 2;
- $Modules{$nstr} .= $halfref;
- }
- $str = &gen_index_id($str, $define);
- if ($STRIP_INDEX_TT) {
- $str =~ s/<tt>(.*)<\/tt>/\1/;
- }
- $index{$str} .= $halfref;
- "<a name=\"$br_id\">$anchor_invisible_mark<\/a>";
-}
-
-sub my_module_index_helper{
- local($word, $_) = @_;
- s/$next_pair_pr_rx[\n]*//o;
- local($br_id, $str) = ($1, $2);
- local($section_tag) = join('', @curr_sec_id);
- $word = "$word " if $word;
- &make_mod_index_entry("SECTION$section_tag",
- "<tt>$str</tt> (${word}module)", 'DEF');
- $_;
-}
-
-sub ref_module_index_helper{
- local($word, $_) = @_;
- s/$next_pair_pr_rx//o;
- local($br_id, $str) = ($1, $2);
- $word = "$word " if $word;
- &make_mod_index_entry($br_id, "<tt>$str</tt> (${word}module)", 'REF') . $_;
-}
-
-sub do_cmd_bifuncindex{ &my_parword_index_helper('built-in function', @_); }
-sub do_cmd_modindex{ &my_module_index_helper('', @_); }
-sub do_cmd_bimodindex{ &my_module_index_helper('built-in', @_); }
-sub do_cmd_exmodindex{ &my_module_index_helper('extension', @_); }
-sub do_cmd_stmodindex{ &my_module_index_helper('standard', @_); }
-
-# these should be adjusted a bit....
-sub do_cmd_refmodindex{ &ref_module_index_helper('', @_); }
-sub do_cmd_refbimodindex{ &ref_module_index_helper('built-in', @_); }
-sub do_cmd_refexmodindex{ &ref_module_index_helper('extension', @_); }
-sub do_cmd_refstmodindex{ &ref_module_index_helper('standard', @_); }
-
-sub do_cmd_nodename{ &do_cmd_label(@_); }
-
-sub init_myformat{
- # XXX need some way for this to be called after &initialise; ???
- $anchor_mark = '';
- $icons{'anchor_mark'} = '';
- # <<2>>...<<2>>
- $any_next_pair_rx3 = "$O(\\d+)$C([\\s\\S]*)$O\\3$C";
- $any_next_pair_rx5 = "$O(\\d+)$C([\\s\\S]*)$O\\5$C";
- $any_next_pair_rx7 = "$O(\\d+)$C([\\s\\S]*)$O\\7$C";
- $any_next_pair_rx9 = "$O(\\d+)$C([\\s\\S]*)$O\\9$C";
- # <#2#>...<#2#>
- $any_next_pair_pr_rx_3 = "$OP(\\d+)$CP([\\s\\S]*)$OP\\3$CP";
- $any_next_pair_pr_rx_5 = "$OP(\\d+)$CP([\\s\\S]*)$OP\\5$CP";
- $any_next_pair_pr_rx_7 = "$OP(\\d+)$CP([\\s\\S]*)$OP\\7$CP";
- $any_next_pair_pr_rx_9 = "$OP(\\d+)$CP([\\s\\S]*)$OP\\9$CP";
-}
-
-&init_myformat;
-
-# similar to make_index_entry(), but includes the string in the result
-# instead of the dummy filler.
-#
-sub make_str_index_entry{
- local($br_id,$str) = @_;
- # If TITLE is not yet available (i.e the \index command is in the title
- # of the current section), use $ref_before.
- $TITLE = $ref_before unless $TITLE;
- # Save the reference
- local($nstr) = &gen_index_id($str, '');
- if ($STRIP_INDEX_TT) {
- $nstr =~ s/<tt>(.*)<\/tt>/\1/;
- }
- $index{$nstr} .= &make_half_href("$CURRENT_FILE#$br_id");
- "<a name=\"$br_id\">$str<\/a>";
-}
-
-# Changed from the stock version to indent {verbatim} sections,
-# and make them smaller, to better match the LaTeX version:
-
-# (Used with LaTeX2HTML 96.1*)
-sub replace_verbatim {
- # Modifies $_
- local($prefix,$suffix) = ("\n<p><dl><dd><pre><font size=-1>\n",
- "</font></pre></dl>");
- s/$verbatim_mark(verbatim)(\d+)/$prefix$verbatim{$2}$suffix/go;
- s/$verbatim_mark(rawhtml)(\d+)/$verbatim{$2}/ego; # Raw HTML
-}
-
-# (Used with LaTeX2HTML 98.1)
-sub replace_verbatim_hook{
- # Modifies $_
- local($prefix,$suffix) = ("\n<p><dl><dd><font size=-1>",
- "</font></dl>");
- s/$math_verbatim_rx/&put_comment("MATH: ".$verbatim{$1})/eg;
- s/$verbatim_mark(\w*[vV]erbatim\*?)(\d+)\#/$prefix$verbatim{$2}$suffix/go;
- # Raw HTML, but replacements may have protected characters
- s/$verbatim_mark(rawhtml)(\d+)#/&unprotect_raw_html($verbatim{$2})/eg;
- s/$verbatim_mark$keepcomments(\d+)#/$verbatim{$2}/ego; # Raw TeX
- s/$unfinished_mark$keepcomments(\d+)#/$verbatim{$2}/ego; # Raw TeX
-}
-
-sub do_env_cfuncdesc{
- local($_) = @_;
- local($return_type,$function_name,$arg_list,$idx) = ('', '', '', '');
- local($cfuncdesc_rx) =
- "$next_pair_rx$any_next_pair_rx3$any_next_pair_rx5";
- if (/$cfuncdesc_rx/o) {
- $return_type = "$2";
- $function_name = "$4";
- $arg_list = "$6";
- $idx = &make_str_index_entry($3,
- "<tt>$function_name</tt>" . &get_indexsubitem);
- $idx =~ s/ \(.*\)//;
- }
- "<dl><dt>$return_type <b>$idx</b>"
- . "(<var>$arg_list</var>)\n<dd>$'\n</dl>"
-}
-
-sub do_env_ctypedesc{
- local($_) = @_;
- local($type_name) = ('');
- local($cfuncdesc_rx) = "$next_pair_rx";
- if (/$cfuncdesc_rx/o) {
- $type_name = "$2";
- $idx = &make_str_index_entry($1,
- "<tt>$type_name</tt>" . &get_indexsubitem);
- $idx =~ s/ \(.*\)//;
- }
- "<dl><dt><b>$idx</b>\n<dd>$'\n</dl>"
-}
-
-sub do_env_cvardesc{
- local($_) = @_;
- local($var_type,$var_name,$idx) = ('', '', '');
- local($cfuncdesc_rx) = "$next_pair_rx$any_next_pair_rx3";
- if (/$cfuncdesc_rx/o) {
- $var_type = "$2";
- $var_name = "$4";
- $idx = &make_str_index_entry($3,
- "<tt>$var_name</tt>" . &get_indexsubitem);
- $idx =~ s/ \(.*\)//;
- }
- "<dl><dt>$var_type <b>$idx</b>\n"
- . "<dd>$'\n</dl>";
-}
-
-sub do_env_funcdesc{
- local($_) = @_;
- local($function_name,$arg_list,$idx) = ('', '', '');
- local($funcdesc_rx) = "$next_pair_rx$any_next_pair_rx3";
- if (/$funcdesc_rx/o) {
- $function_name = "$2";
- $arg_list = "$4";
- $idx = &make_str_index_entry($3,
- "<tt>$function_name</tt>" . &get_indexsubitem);
- $idx =~ s/ \(.*\)//;
- }
- "<dl><dt><b>$idx</b> (<var>$arg_list</var>)\n<dd>$'\n</dl>";
-}
-
-sub do_env_funcdescni{
- local($_) = @_;
- local($function_name,$arg_list,$idx) = ('', '', '');
- local($funcdesc_rx) = "$next_pair_rx$any_next_pair_rx3";
- if (/$funcdesc_rx/o) {
- $function_name = "$2";
- $arg_list = "$4";
- if ($STRIP_INDEX_TT) {
- $idx = $function_name; }
- else {
- $idx = "<tt>$function_name</tt>"; }
- }
- "<dl><dt><b>$idx</b> (<var>$arg_list</var>)\n<dd>$'\n</dl>";
-}
-
-sub do_cmd_funcline{
- local($_) = @_;
- local($funcdesc_rx) = "$next_pair_pr_rx$OP(\\d+)$CP([\\s\\S]*)$OP\\3$CP";
-
- s/$funcdesc_rx//o;
- local($br_id, $function_name, $arg_list) = ($3, $2, $4);
- local($idx) = &make_str_index_entry($br_id, "<tt>$function_name</tt>");
-
- "<dt><b>$idx</b> (<var>$arg_list</var>)\n<dd>" . $_;
-}
-
-# Change this flag to index the opcode entries. I don't think it's very
-# useful to index them, since they're only presented to describe the dis
-# module.
-#
-$INDEX_OPCODES = 0;
-
-sub do_env_opcodedesc{
- local($_) = @_;
- local($opcode_name,$arg_list,$stuff,$idx) = ('', '', '', '');
- local($opcodedesc_rx) = "$next_pair_rx$any_next_pair_rx3";
- if (/$opcodedesc_rx/o) {
- $opcode_name = "$2";
- $arg_list = "$4";
- if ($INDEX_OPCODES) {
- $idx = &make_str_index_entry($3,
- "<tt>$opcode_name</tt> (byte code instruction)");
- $idx =~ s/ \(byte code instruction\)//;
- }
- else {
- $idx = "<tt>$opcode_name</tt>";
- }
- }
- $stuff = "<dl><dt><b>$idx</b>";
- if ($arg_list) {
- $stuff .= "&nbsp;&nbsp;&nbsp;&nbsp;<var>$arg_list</var>";
- }
- $stuff . "\n<dd>$'\n</dl>";
-}
-
-sub do_env_datadesc{
- local($_) = @_;
- local($idx) = '';
- if (/$next_pair_rx/o) {
- $idx = &make_str_index_entry($1, "<tt>$2</tt>" . &get_indexsubitem);
- $idx =~ s/ \(.*\)//;
- }
- "<dl><dt><b>$idx</b>\n<dd>$'\n</dl>"
-}
-
-sub do_env_datadescni{
- local($_) = @_;
- local($idx) = '';
- if (/$next_pair_rx/o) {
- if ($STRING_INDEX_TT) {
- $idx = "$2"; }
- else {
- $idx = "<tt>$2</tt>"; }
- }
- "<dl><dt><b>$idx</b>\n<dd>$'\n</dl>"
-}
-
-sub do_cmd_dataline{
- local($_) = @_;
-
- s/$next_pair_pr_rx//o;
- local($br_id, $data_name) = ($1, $2);
- local($idx) = &make_str_index_entry($br_id, "<tt>$data_name</tt>"
- . &get_indexsubitem);
- $idx =~ s/ \(.*\)//;
-
- "<dt><b>$idx</b>\n<dd>" . $_;
-}
-
-sub do_env_excdesc{ &do_env_datadesc(@_); }
-sub do_env_classdesc{ &do_env_funcdesc(@_); }
-sub do_env_fulllineitems{ &do_env_itemize(@_); }
-
-
-@col_aligns = ("<td>", "<td>", "<td>");
-
-sub setup_column_alignments{
- local($_) = @_;
- local($j1,$a1,$a2,$a3,$j4) = split(/[|]/,$_);
- local($th1,$th2,$th3) = ('<th>', '<th>', '<th>');
- $col_aligns[0] = (($a1 eq "c") ? "<td align=center>" : "<td>");
- $col_aligns[1] = (($a2 eq "c") ? "<td align=center>" : "<td>");
- $col_aligns[2] = (($a3 eq "c") ? "<td align=center>" : "<td>");
- # return the aligned header start tags; only used for \begin{tableiii?}
- $th1 = (($a1 eq "l") ? "<th align=left>"
- : ($a1 eq "r" ? "<th align=right>" : "<th>"));
- $th2 = (($a2 eq "l") ? "<th align=left>"
- : ($a2 eq "r" ? "<th align=right>" : "<th>"));
- $th3 = (($a3 eq "l") ? "<th align=left>"
- : ($a3 eq "r" ? "<th align=right>" : "<th>"));
- ($th1, $th2, $th3);
-}
-
-sub do_env_tableii{
- local($_) = @_;
- local($font,$h1,$h2) = ('', '', '');
- local($tableiii_rx) =
- "$next_pair_rx$any_next_pair_rx3$any_next_pair_rx5$any_next_pair_rx7";
- if (/$tableiii_rx/o) {
- $font = $4;
- $h1 = $6;
- $h2 = $8;
- }
- local($th1,$th2,$th3) = &setup_column_alignments($2);
- $globals{"lineifont"} = $font;
- "<table border align=center>"
- . "\n <tr>$th1<b>$h1</b></th>"
- . "\n $th2<b>$h2</b></th>$'"
- . "\n</table>";
-}
-
-sub do_cmd_lineii{
- local($_) = @_;
- s/$next_pair_pr_rx//o;
- local($c1) = $2;
- s/$next_pair_pr_rx//o;
- local($c2) = $2;
- local($font) = $globals{"lineifont"};
- local($c1align, $c2align) = @col_aligns[0,1];
- "<tr>$c1align<$font>$c1</$font></td>\n"
- . " $c2align$c2</td>$'";
-}
-
-sub do_env_tableiii{
- local($_) = @_;
- local($font,$h1,$h2,$h3) = ('', '', '', '');
-
- local($tableiii_rx) =
- "$next_pair_rx$any_next_pair_rx3$any_next_pair_rx5$any_next_pair_rx7"
- . "$any_next_pair_rx9";
- if (/$tableiii_rx/o) {
- $font = $4;
- $h1 = $6;
- $h2 = $8;
- $h3 = $10;
- }
- local($th1,$th2,$th3) = &setup_column_alignments($2);
- $globals{"lineifont"} = $font;
- "<table border align=center>"
- . "\n <tr>$th1<b>$h1</b></th>"
- . "\n $th2<b>$h2</b></th>"
- . "\n $th3<b>$h3</b></th>$'"
- . "\n</table>";
-}
-
-sub do_cmd_lineiii{
- local($_) = @_;
- s/$next_pair_pr_rx//o;
- local($c1) = $2;
- s/$next_pair_pr_rx//o;
- local($c2) = $2;
- s/$next_pair_pr_rx//o;
- local($c3) = $2;
- local($font) = $globals{"lineifont"};
- local($c1align, $c2align, $c3align) = @col_aligns;
- "<tr>$c1align<$font>$c1</$font></td>\n"
- . " $c2align$c2</td>\n"
- . " $c3align$c3</td>$'";
-}
-
-sub do_env_seealso{
- "<p><b>See Also:</b></p>\n" . @_[0];
-}
-
-sub do_cmd_seemodule{
- # Insert the right magic to jump to the module definition. This should
- # work most of the time, at least for repeat builds....
- local($_) = @_;
- local($any_next_pair_pr_rx3) = "$OP(\\d+)$CP([\\s\\S]*)$OP\\3$CP";
- s/$next_pair_pr_rx$any_next_pair_pr_rx3//;
- local($module,$text,$node,$key) = ($2, $4, '', "module$2");
- $key =~ s/_//g;
- # XXX somewhat bogus computation of $node
-# $node = $external_labels{$key} unless
-# ($node = $ref_files{$key});
- $node = $key;
- "<p>Module <tt><b><a href=\"$node#$key\">$module</a></b></tt>"
- . "&nbsp;&nbsp;&nbsp;($text)</p>"
- . $_;
-}
-
-sub do_cmd_seetext{
- "<p>" . @_[0];
-}
-
-
-sub do_cmd_maketitle {
- local($_) = @_;
- local($the_title) = '';
- if ($t_title) {
- $the_title .= "<h1 align=\"center\">$t_title</h1>";
- } else { &write_warnings("\nThis document has no title."); }
- if ($t_author) {
- if ($t_authorURL) {
- local($href) = &translate_commands($t_authorURL);
- $href = &make_named_href('author', $href, "<strong>${t_author}</strong>");
- $the_title .= "\n<p align=\"center\">$href</p>";
- } else {
- $the_title .= "\n<p align=\"center\"><strong>$t_author</strong></p>";
- }
- } else { &write_warnings("\nThere is no author for this document."); }
- if ($t_institute) {
- $the_title .= "\n<p align=\"center\"><small>$t_institute</small></p>";}
- if ($AUTHOR_ADDRESS) {
- $the_title .= "\n<p align=\"center\"><small>$AUTHOR_ADDRESS";
- $the_title .= "</small></p>";}
- if ($t_affil) {
- $the_title .= "\n<p align=\"center\"><i>$t_affil</i></p>";}
- if ($t_date) {
- $the_title .= "\n<p align=\"center\"><strong>$t_date</strong>";
- if ($PYTHON_VERSION) {
- $the_title .= "<br><strong>Release $PYTHON_VERSION</strong>";}
- $the_title .= "</p>"
- }
- if ($t_address) {
- $the_title .= "<br>\n<p align=\"left\"><small>$t_address</small></p>";
- } else { $the_title .= "\n<p align=\"left\">"}
- if ($t_email) {
- $the_title .= "\n<p align=\"left\"><small>$t_email</small></p>";
- } else { $the_title .= "</p>" }
- $the_title . "<p><hr>\n" . $_ ;
-}
-
-
-# These are located down here since they screw up fontlock.
-
-sub do_cmd_file{
- # This uses a weird HTML construct to adjust the font to be
- # reasonable match that used in the printed form as much as
- # possible. The expected behavior is that a browser that doesn't
- # understand "<font face=...>" markup will use courier (or whatever
- # the font is for <tt>).
- local($_) = @_;
- s/$any_next_pair_pr_rx/`<tt><font face=sans-serif>\2<\/font><\/tt>'/;
- $_;
-}
-
-sub do_cmd_samp{
- local($_) = @_;
- s/$any_next_pair_pr_rx/`<samp>\2<\/samp>'/;
- $_;
-}
-
-1; # This must be the last line
diff --git a/Doc/myformat.sty b/Doc/myformat.sty
deleted file mode 100644
index f613e24..0000000
--- a/Doc/myformat.sty
+++ /dev/null
@@ -1,648 +0,0 @@
-%
-% myformat.sty for the Python doc [works only with with Latex2e]
-%
-
-\NeedsTeXFormat{LaTeX2e}[1995/12/01]
-\ProvidesPackage{myformat}
- [1998/01/11
- LaTeX package (Python manual markup)]
-
-% Optional packages:
-%
-% If processing of these documents fails at your TeX installation,
-% these may be commented out (independently) to make things work.
-% These are both supplied with the current version of the teTeX
-% distribution.
-%
-% The "fancyhdr" package makes nicer page footers reasonable to
-% implement, and is used to put the chapter and section information in
-% the footers.
-%
-% The "times" package makes the default font the PostScript Times
-% font, which makes for smaller PostScript and a font that more people
-% like.
-%
-% The "fncychap" package is used to get the nice chapter headers. The
-% .sty file is distributed with Python, so you should not need to disable
-% it. You'd also end up with a mixed page style; uglier than stock LaTeX!
-%
-\RequirePackage{fancyhdr}\typeout{Using fancier footers than usual.}
-\RequirePackage{times}\typeout{Using times fonts instead of Computer Modern.}
-\RequirePackage[Bjarne]{fncychap}\typeout{Using nice chapter headings.}
-
-
-% for PDF output, use maximal compression
-\@ifundefined{pdfannotlink}{
- \let\LinkColor=\relax
- \let\NormalColor=\relax
-}{%
- \input{pdfcolor}
- \let\LinkColor=\NavyBlue
- \let\NormalColor=\Black
- \pdfcompresslevel=9
- \let\OldContentsline=\contentsline
- \renewcommand{\contentsline}[3]{%
- \OldContentsline{#1}{%
- \pdfannotlink attr{/Border [0 0 0]} goto name{page.#3}%
- \LinkColor#2\NormalColor%
- \pdfendlink%
- }{#3}%
- }
- \let\OldLabel=\label
- \renewcommand{\label}[1]{%
- \OldLabel{#1}%
- {\pdfdest name{label.#1} fit}%
- }
- % This stuff adds a page.# destination to every PDF page, where # has
- % the same formatting as the displayed page number. This doesn't really
- % help with the frontmatter, but does fine with the body.
- %
- % This is *heavily* based on the hyperref package.
- %
- \def\@begindvi{%
- \unvbox \@begindvibox
- \@hyperfixhead
- \global\let \@begindvi \@hyperfixhead
- }
- \def\hyperpageanchor{%
- \hyper@anchorstart{page.\thepage}\hyper@anchorend
- }
- \let\HYPERPAGEANCHOR\hyperpageanchor
- \def\@hyperfixhead{%
- \let\H@old@thehead\@thehead
- \gdef\@foo{\pdfdest name{page.\thepage} fit}%
- \expandafter\ifx\expandafter\@empty\H@old@thehead
- \def\H@old@thehead{\hfil}\fi
- \def\@thehead{\@foo\relax\H@old@thehead}%
- }
-}
-
-% Increase printable page size (copied from fullpage.sty)
-\topmargin 0pt
-\advance \topmargin by -\headheight
-\advance \topmargin by -\headsep
-
-% attempt to work a little better for A4 users
-\@ifundefined{paperheight}{
- \textheight 9in
-}{
- \textheight \paperheight
- \advance\textheight by -2in
-}
-
-\oddsidemargin 0pt
-\evensidemargin \oddsidemargin
-\marginparwidth 0.5in
-
-\@ifundefined{paperwidth}{
- \textwidth 6.5in
-}{
- \textwidth \paperwidth
- \advance\textwidth by -2in
-}
-
-
-% Style parameters and macros used by most documents here
-\raggedbottom
-\sloppy
-\parindent = 0mm
-\parskip = 2mm
-\hbadness = 5000 % don't print trivial gripes
-
-\pagestyle{empty} % start this way; change for
-\pagenumbering{roman} % ToC & chapters
-\setcounter{secnumdepth}{1}
-
-% Use this to set the font family for headers and other decor:
-\newcommand{\HeaderFamily}{\sffamily}
-
-% Redefine the 'normal' header/footer style when using "fancyhdr" package:
-\@ifundefined{fancyhf}{}{
- % Use \pagestyle{normal} as the primary pagestyle for text.
- \fancypagestyle{normal}{
- \fancyhf{}
- \fancyfoot[LE,RO]{{\HeaderFamily\thepage}}
- \fancyfoot[LO]{{\HeaderFamily\nouppercase{\rightmark}}}
- \fancyfoot[RE]{{\HeaderFamily\nouppercase{\leftmark}}}
- \renewcommand{\headrulewidth}{0pt}
- \renewcommand{\footrulewidth}{0.4pt}
- }
- % Update the plain style so we get the page number & footer line,
- % but not a chapter or section title. This is to keep the first
- % page of a chapter and the blank page between chapters `clean.'
- \fancypagestyle{plain}{
- \fancyhf{}
- \fancyfoot[LE,RO]{{\HeaderFamily\thepage}}
- \renewcommand{\headrulewidth}{0pt}
- \renewcommand{\footrulewidth}{0.4pt}
- }
- % Redefine \cleardoublepage so that the blank page between chapters
- % gets the plain style and not the fancy style. This is described
- % in the documentation for the fancyhdr package by Piet von Oostrum.
- \renewcommand{\cleardoublepage}{
- \clearpage\if@openright \ifodd\c@page\else
- \hbox{}
- \thispagestyle{plain}
- \newpage
- \if@twocolumn\hbox{}\newpage\fi\fi\fi}
-}
-
-% old code font selections:
-\let\codefont=\tt
-\let\sectcodefont=\tt
-
-% (Haven't found a new one that gets <, >, and _ right without being
-% monospaced.)
-
-
-% This sets up the {verbatim} environment to be indented and a minipage,
-% and to have all the other mostly nice properties that we want for
-% code samples.
-
-% Variable used by begin code command
-\newlength{\codewidth}
-
-\newcommand{\examplevspace}{2mm}
-\newcommand{\exampleindent}{1cm}
-
-\let\OldVerbatim=\verbatim
-\let\OldEndVerbatim=\endverbatim
-\renewcommand{\verbatim}{%
- \begingroup%
- \setlength{\parindent}\exampleindent%
- % Calculate the text width for the minipage:
- \setlength{\codewidth}{\linewidth}%
- \addtolength{\codewidth}{-\parindent}%
- %
- \par%
- \vspace\examplevspace%
- \indent%
- \begin{minipage}[t]{\codewidth}%
- \small%
- \OldVerbatim%
-}
-\renewcommand{\endverbatim}{%
- \OldEndVerbatim%
- \end{minipage}%
- \endgroup%
-}
-
-% Augment the sectioning commands used to get our own font family in place:
-\renewcommand{\section}{\@startsection {section}{1}{\z@}%
- {-3.5ex \@plus -1ex \@minus -.2ex}%
- {2.3ex \@plus.2ex}%
- {\reset@font\Large\HeaderFamily}}
-\renewcommand{\subsection}{\@startsection{subsection}{2}{\z@}%
- {-3.25ex\@plus -1ex \@minus -.2ex}%
- {1.5ex \@plus .2ex}%
- {\reset@font\large\HeaderFamily}}
-\renewcommand{\subsubsection}{\@startsection{subsubsection}{3}{\z@}%
- {-3.25ex\@plus -1ex \@minus -.2ex}%
- {1.5ex \@plus .2ex}%
- {\reset@font\normalsize\HeaderFamily}}
-\renewcommand{\paragraph}{\@startsection{paragraph}{4}{\z@}%
- {3.25ex \@plus1ex \@minus.2ex}%
- {-1em}%
- {\reset@font\normalsize\HeaderFamily}}
-\renewcommand{\subparagraph}{\@startsection{subparagraph}{5}{\parindent}%
- {3.25ex \@plus1ex \@minus .2ex}%
- {-1em}%
- {\reset@font\normalsize\HeaderFamily}}
-
-
-% Underscore hack (only act like subscript operator if in math mode)
-%
-% The following is due to Mark Wooding (the old version didn't work with
-% Latex 2e.
-
-\DeclareRobustCommand\hackscore{%
- \ifmmode_\else\textunderscore\fi%
-}
-\begingroup
-\catcode`\_\active
-\def\next{%
- \AtBeginDocument{\catcode`\_\active\def_{\hackscore{}}}%
-}
-\expandafter\endgroup\next
-
-%
-% This is the old hack, which didn't work with 2e.
-% You should not need this since the rest of the documentation is now
-% LaTeX2e-only.
-%
-%\def\_{\ifnum\fam=\ttfamily \char'137\else{\tt\char'137}\fi}
-%\catcode`\_=12
-%\catcode`\_=\active\def_{\ifnum\fam=\ttfamily \char'137 \else{\tt\char'137}\fi}
-
-
-
-%% Lots of index-entry generation support.
-
-% Command to wrap around stuff that refers to function / module /
-% attribute names in the index. Default behavior: like \code{}. To
-% just keep the index entries in the roman font, uncomment the second
-% definition to use instead; it matches O'Reilly style more.
-%
-\newcommand{\idxcode}[1]{\codefont{#1}}
-%\renewcommand{\idxcode}[1]{#1}
-
-% Command to generate two index entries (using subentries)
-\newcommand{\indexii}[2]{\index{#1!#2}\index{#2!#1}}
-
-% And three entries (using only one level of subentries)
-\newcommand{\indexiii}[3]{\index{#1!#2 #3}\index{#2!#3, #1}\index{#3!#1 #2}}
-
-% And four (again, using only one level of subentries)
-\newcommand{\indexiv}[4]{
-\index{#1!#2 #3 #4}
-\index{#2!#3 #4, #1}
-\index{#3!#4, #1 #2}
-\index{#4!#1 #2 #3}
-}
-
-% Command to generate a reference to a function, statement, keyword,
-% operator.
-\newcommand{\stindex}[1]{\indexii{statement}{#1@{\idxcode{#1}}}}
-\newcommand{\opindex}[1]{\indexii{operator}{#1@{\idxcode{#1}}}}
-\newcommand{\exindex}[1]{\indexii{exception}{#1@{\idxcode{#1}}}}
-\newcommand{\obindex}[1]{\indexii{object}{#1}}
-\newcommand{\bifuncindex}[1]{\index{#1@{\idxcode{#1()}} (built-in function)}}
-
-% Add an index entry for a module
-\newcommand{\refmodule}[2]{\index{#1@{\idxcode{#1}} (#2module)}}
-\newcommand{\refmodindex}[1]{\refmodule{#1}{}}
-\newcommand{\refbimodindex}[1]{\refmodule{#1}{built-in }}
-\newcommand{\refexmodindex}[1]{\refmodule{#1}{extension }}
-\newcommand{\refstmodindex}[1]{\refmodule{#1}{standard }}
-
-% support for the module index
-\newwrite\modindexfile
-\openout\modindexfile=mod\jobname.idx
-
-% Add the defining entry for a module
-\newcommand{\defmodindex}[2]{%
- \index{#1@{\idxcode{#1}} (#2module)|textbf}%
- \setindexsubitem{(in module #1)}%
- \write\modindexfile{#1 \thepage}}
-
-% built-in & Python modules in the main distribution
-\newcommand{\bimodindex}[1]{\defmodindex{#1}{built-in }}
-\newcommand{\stmodindex}[1]{\defmodindex{#1}{standard }}
-
-% Python & extension modules outside the main distribution
-\newcommand{\modindex}[1]{\defmodindex{#1}{}}
-\newcommand{\exmodindex}[1]{\defmodindex{#1}{extension }}
-
-% Additional string for an index entry
-\newcommand{\index@subitem}{}
-\newcommand{\setindexsubitem}[1]{\renewcommand{\index@subitem}{#1}}
-\newcommand{\ttindex}[1]{\index{#1@{\idxcode{#1}} \index@subitem}}
-
-
-% {fulllineitems} is used in one place in libregex.tex, but is really for
-% internal use in this file.
-%
-\newenvironment{fulllineitems}{
- \begin{list}{}{\labelwidth \leftmargin \labelsep 0pt
- \rightmargin 0pt \topsep -\parskip \partopsep \parskip
- \itemsep -\parsep
- \let\makelabel=\itemnewline}
-}{\end{list}}
-
-
-% cfuncdesc should be called as
-% \begin{cfuncdesc}{type}{name}{arglist}
-% ... description ...
-% \end{cfuncdesc}
-\newenvironment{cfuncdesc}[3]{%
- \begin{fulllineitems}%
- \item[\code{#1 \bfcode{#2}(\varvars{#3})}]%
- \index{#2@{\idxcode{#2()}}}%
-}{\end{fulllineitems}}
-
-\newenvironment{cvardesc}[2]{%
- \begin{fulllineitems}%
- \item[\code{#1 \bfcode{#2}}]%
- \index{#2@{\idxcode{#2}}}%
-}{\end{fulllineitems}}
-
-\newenvironment{ctypedesc}[1]{%
- \begin{fulllineitems}%
- \item[\bfcode{#1}]\ttindex{#1}
-}{\end{fulllineitems}}
-
-\newcommand{\funcline}[2]{\funclineni{#1}{#2}\ttindex{#1()}}
-\newenvironment{funcdesc}[2]{%
- \begin{fulllineitems}%
- \funcline{#1}{#2}%
-}{\end{fulllineitems}}
-
-\newcommand{\optional}[1]{%
- {\textnormal{\Large[}}{#1}\hspace{0.5mm}{\textnormal{\Large]}}}
-
-% similar to {funcdesc}, but doesn't add to the index
-\newcommand{\funclineni}[2]{\item[\code{\bfcode{#1}(\varvars{#2})}]}
-\newenvironment{funcdescni}[2]{%
- \begin{fulllineitems}%
- \funclineni{#1}{#2}%
-}{\end{fulllineitems}}
-
-\newenvironment{classdesc}[2]{%
- \begin{fulllineitems}%
- \item[\code{\bfcode{#1}(\varvars{#2})}]%
- \ttindex{#1}%
- \def\baseclasses##1{}%
-}{\end{fulllineitems}}
-
-\newenvironment{excdesc}[1]{%
- \begin{fulllineitems}%
- \item[\bfcode{#1}]\ttindex{#1}%
-}{\end{fulllineitems}}
-
-\newcommand{\dataline}[1]{\datalineni{#1}\ttindex{#1}}
-\newenvironment{datadesc}[1]{%
- \begin{fulllineitems}%
- \dataline{#1}%
-}{\end{fulllineitems}}
-
-% similar to {datadesc}, but doesn't add to the index
-\newcommand{\datalineni}[1]{\item[\bfcode{#1}]}
-\newenvironment{datadescni}[1]{%
- \begin{fulllineitems}%
- \datalineni{#1}%
-}{\end{fulllineitems}}
-
-\newenvironment{opcodedesc}[2]{%
- \begin{fulllineitems}%
- \item[\bfcode{#1}\quad\var{#2}]%
-}{\end{fulllineitems}}
-
-
-\let\nodename=\label
-
-% For these commands, use \command{} to get the typography right, not
-% {\command}. This works better with the texinfo translation.
-\newcommand{\ABC}{{\sc abc}}
-\newcommand{\UNIX}{{\sc Unix}}
-\newcommand{\POSIX}{POSIX}
-\newcommand{\ASCII}{{\sc ascii}}
-\newcommand{\Cpp}{C\protect\raisebox{.18ex}{++}}
-\newcommand{\C}{C}
-\newcommand{\EOF}{{\sc eof}}
-\newcommand{\NULL}{\code{NULL}}
-
-% code is the most difficult one...
-\newcommand{\code}[1]{{\@vobeyspaces\@noligs\def\{{\char`\{}\def\}{\char`\}}\def\~{\char`\~}\def\^{\char`\^}\def\e{\char`\\}\def\${\char`\$}\def\#{\char`\#}\def\&{\char`\&}\def\%{\char`\%}%
-\mbox{\codefont{#1}}}}
-
-\newcommand{\bfcode}[1]{\code{\bfseries#1}} % bold-faced code font
-\newcommand{\kbd}[1]{\mbox{\tt #1}}
-\newcommand{\key}[1]{\mbox{\tt #1}}
-\newcommand{\samp}[1]{\mbox{`\code{#1}'}}
-% This weird definition of \var{} allows it to always appear in roman
-% italics, and won't get funky in code fragments when we play around
-% with fonts.
-\newcommand{\var}[1]{\mbox{\normalsize\textrm{\textit{#1\/}}}}
-\renewcommand{\emph}[1]{{\em #1\/}}
-\newcommand{\dfn}[1]{\emph{#1}}
-\newcommand{\strong}[1]{{\bf #1}}
-% let's experiment with a new font:
-\newcommand{\file}[1]{\mbox{`\small\textsf{#1}'}}
-
-% Use this def/redef approach for \url{} since hyperref defined this already,
-% but only if we actually used hyperref:
-\@ifundefined{pdfannotlink}{%
- \newcommand{\pythonurl}[1]{\mbox{\small\textsf{#1}}}%
-}{
- \newcommand{\pythonurl}[1]{{%
- \pdfannotlink attr{/Border [0 0 0]} user{/S /URI /URI (#1)}%
- \LinkColor% color of the link text
- \mbox{\small\textsf{#1}}%
- \NormalColor% Turn it back off; these are declarative
- \pdfendlink}% and don't appear bound to the current
- }% formatting "box".
-}
-\let\url=\pythonurl
-\newcommand{\email}[1]{\mbox{\small\textsf{#1}}}
-
-\newcommand{\varvars}[1]{{\def\,{\/{\char`\,}}\var{#1}}}
-
-\newif\iftexi\texifalse
-\newif\iflatex\latextrue
-
-% These should be used for all references to identifiers which are
-% used to refer to instances of specific language constructs. See the
-% names for specific semantic assignments.
-%
-% For now, don't do anything really fancy with them; just use them as
-% logical markup. This might change in the future.
-%
-\let\module=\code
-\let\keyword=\code
-\let\exception=\code
-\let\class=\code
-\let\function=\code
-\let\member=\code
-\let\method=\code
-
-\let\cfunction=\code
-\let\ctype=\code
-\let\cdata=\code
-
-% constants defined in Python modules or C headers, not language constants:
-\let\constant=\code
-
-\newcommand{\manpage}[2]{{\emph{#1}(#2)}}
-\newcommand{\rfc}[1]{RFC #1\index{RFC!RFC #1}}
-\newcommand{\program}[1]{\strong{#1}}
-
-
-% Deprecation stuff.
-% Should be extended to allow an index / list of deprecated stuff. But
-% there's a lot of stuff that needs to be done to make that automatable.
-%
-% First parameter is the release number that deprecates the feature, the
-% second is the action the should be taken by users of the feature.
-%
-% Example:
-%
-% \deprecated {1.5.1}
-% {Use \method{frobnicate()} instead.}
-%
-\newcommand{\deprecated}[2]{%
- \strong{Deprecated since release #1.} #2\par}
-
-
-\newenvironment{tableii}[4]{%
- \begin{center}%
- \def\lineii##1##2{\csname#2\endcsname{##1}&##2\\}%
- \begin{tabular}{#1}\hline \strong{#3}&\strong{#4} \\ \hline%
-}{%
- \hline%
- \end{tabular}%
- \end{center}%
-}
-
-\newenvironment{tableiii}[5]{%
- \begin{center}%
- \def\lineiii##1##2##3{\csname#2\endcsname{##1}&##2&##3\\}%
- \begin{tabular}{#1}\hline \strong{#3}&\strong{#4}&\strong{#5} \\ \hline%
-}{%
- \hline%
- \end{tabular}%
- \end{center}%
-}
-
-\newcommand{\itemnewline}[1]{%
- \@tempdima\linewidth%
- \advance\@tempdima \leftmargin\makebox[\@tempdima][l]{#1}%
-}
-
-\newcommand{\sectcode}[1]{{\sectcodefont{#1}}}
-
-% Cross-referencing (AMK)
-% Sample usage:
-% \begin{seealso}
-% \seemodule{rand}{Uniform random number generator}; % Module xref
-% \seetext{\emph{Encyclopedia Britannica}}. % Ref to a book
-% \end{seealso}
-
-\newenvironment{seealso}[0]{
- \strong{See Also:}\par
- % These should only be defined within the {seealso} environment:
- \def\seemodule##1##2{\ref{module-##1}:\quad Module \module{##1}\quad (##2)}
- \def\seetext##1{\par{##1}}
-}{\par}
-
-
-% Fix the theindex environment to add an entry to the Table of
-% Contents; this is much nicer than just having to jump to the end of
-% the book and flip around, especially with multiple indexes.
-%
-\let\OldTheindex=\theindex
-\renewcommand{\theindex}{
- \cleardoublepage
- \OldTheindex
- \addcontentsline{toc}{chapter}{\indexname}
-}
-
-% Use a similar trick to catch the end of the {abstract} environment,
-% but here make sure the abstract is followed by a blank page if the
-% 'openright' option is used.
-%
-\let\OldEndAbstract=\endabstract
-\renewcommand{\endabstract}{
- \if@openright
- \ifodd\value{page}
- \typeout{Adding blank page after the abstract.}
- \vfil\pagebreak
- \fi
- \fi
- \OldEndAbstract
-}
-
-% This wraps the \tableofcontents macro with all the magic to get the
-% spacing right and have the right number of pages if the 'openright'
-% option has been used. This eliminates a fair amount of crud in the
-% individual document files.
-%
-\let\OldTableofcontents=\tableofcontents
-\renewcommand{\tableofcontents}[0]{%
- \setcounter{page}{1}%
- \pagebreak%
- \pagestyle{plain}%
- {%
- \parskip = 0mm%
- \OldTableofcontents%
- \if@openright%
- \ifodd\value{page}%
- \typeout{Adding blank page after the table of contents.}%
- \pagebreak\hspace{0pt}%
- \fi%
- \fi%
- }%
- \cleardoublepage%
- \pagenumbering{arabic}%
- \@ifundefined{fancyhf}{}{\pagestyle{normal}}%
-}
-
-% Allow the release number to be specified independently of the
-% \date{}. This allows the date to reflect the document's date and
-% release to specify the Python release that is documented.
-%
-\newcommand{\@release}{}
-\newcommand{\version}{}
-\newcommand{\releasename}{Release}
-\newcommand{\release}[1]{%
- \renewcommand{\@release}{\releasename\space\version}%
- \renewcommand{\version}{#1}}
-
-% Allow specification of the author's address separately from the
-% author's name. This can be used to format them differently, which
-% is a good thing.
-%
-\newcommand{\@authoraddress}{}
-\newcommand{\authoraddress}[1]{\renewcommand{\@authoraddress}{#1}}
-
-% Change the title page to look a bit better, and fit in with the
-% fncychap ``Bjarne'' style a bit better.
-%
-\renewcommand{\maketitle}{%
- \begin{titlepage}%
- \let\footnotesize\small
- \let\footnoterule\relax
- \@ifundefined{ChTitleVar}{}{%
- \mghrulefill{\RW}}%
- \@ifundefined{pdfinfo}{}{
- \pdfinfo
- author {\@author}
- title {\@title}
- }
- \begin{flushright}%
- {\rm\Huge\HeaderFamily \@title \par}%
- {\em\LARGE\HeaderFamily \@release \par}
- \vfill
- {\LARGE\HeaderFamily \@author \par}
- \vfill\vfill
- {\large
- \@date \par
- \vskip 3em
- \@authoraddress \par
- }%
- \end{flushright}%\par
- \@thanks
- \end{titlepage}%
- \setcounter{footnote}{0}%
- \let\thanks\relax\let\maketitle\relax
- \gdef\@thanks{}\gdef\@author{}\gdef\@title{}
-}
-
-% This sets up the fancy chapter headings that make the documents look
-% at least a little better than the usual LaTeX output.
-%
-\@ifundefined{ChTitleVar}{}{
- \ChNameVar{\raggedleft\normalsize\HeaderFamily}
- \ChNumVar{\raggedleft \bfseries\Large\HeaderFamily}
- \ChTitleVar{\raggedleft \rm\Huge\HeaderFamily}
- % This creates chapter heads without the leading \vspace*{}:
- \def\@makechapterhead#1{%
- {\parindent \z@ \raggedright \normalfont
- \ifnum \c@secnumdepth >\m@ne
- \DOCH
- \fi
- \interlinepenalty\@M
- \DOTI{#1}
- }
- }
- \typeout{Using fancy chapter headings.}
-}
-
-% Tell TeX about pathological hyphenation cases:
-\hyphenation{Base-HTTP-Re-quest-Hand-ler}
-
-% Don't use this at this time.
-% Should probably do a little more, and will get moved around as the
-% document classes get defined.
-\newenvironment{howto}{
- \chapter{\@title}
-}{}