Blame doc/pdf/sphinxmanual.cls

Packit Service 99d1c0
%
Packit Service 99d1c0
% sphinxmanual.cls for Sphinx (http://sphinx-doc.org/)
Packit Service 99d1c0
%
Packit Service 99d1c0
Packit Service 99d1c0
\NeedsTeXFormat{LaTeX2e}[1995/12/01]
Packit Service 99d1c0
\ProvidesClass{sphinxmanual}[2017/03/26 v1.6 Document class (Sphinx manual)]
Packit Service 99d1c0
Packit Service 99d1c0
% chapters starting at odd pages (overridden by 'openany' document option)
Packit Service 99d1c0
\PassOptionsToClass{openright}{\sphinxdocclass}
Packit Service 99d1c0
Packit Service 99d1c0
% 'oneside' option overriding the 'twoside' default
Packit Service 99d1c0
\newif\if@oneside
Packit Service 99d1c0
\DeclareOption{oneside}{\@onesidetrue}
Packit Service 99d1c0
% Pass remaining document options to the parent class.
Packit Service 99d1c0
\DeclareOption*{\PassOptionsToClass{\CurrentOption}{\sphinxdocclass}}
Packit Service 99d1c0
\ProcessOptions\relax
Packit Service 99d1c0
Packit Service 99d1c0
% Defaults two-side document
Packit Service 99d1c0
\if@oneside
Packit Service 99d1c0
% nothing to do (oneside is the default)
Packit Service 99d1c0
\else
Packit Service 99d1c0
\PassOptionsToClass{twoside}{\sphinxdocclass}
Packit Service 99d1c0
\fi
Packit Service 99d1c0
Packit Service 99d1c0
\LoadClass{\sphinxdocclass}
Packit Service 99d1c0
Packit Service 99d1c0
% Set some sane defaults for section numbering depth and TOC depth.  You can
Packit Service 99d1c0
% reset these counters in your preamble.
Packit Service 99d1c0
%
Packit Service 99d1c0
\setcounter{secnumdepth}{2}
Packit Service 99d1c0
\setcounter{tocdepth}{1}
Packit Service 99d1c0
Packit Service 99d1c0
% Change the title page to look a bit better, and fit in with the fncychap
Packit Service 99d1c0
% ``Bjarne'' style a bit better.
Packit Service 99d1c0
%
Packit Service 99d1c0
\renewcommand{\maketitle}{%
Packit Service 99d1c0
  \let\spx@tempa\relax
Packit Service 99d1c0
  \ifHy@pageanchor\def\spx@tempa{\Hy@pageanchortrue}\fi
Packit Service 99d1c0
  \hypersetup{pageanchor=false}% avoid duplicate destination warnings
Packit Service 99d1c0
  \begin{titlepage}%
Packit Service 99d1c0
    \let\footnotesize\small
Packit Service 99d1c0
    \let\footnoterule\relax
Packit Service 99d1c0
    \noindent\rule{\textwidth}{1pt}\par
Packit Service 99d1c0
      \begingroup % for PDF information dictionary
Packit Service 99d1c0
       \def\endgraf{ }\def\and{\& }%
Packit Service 99d1c0
       \pdfstringdefDisableCommands{\def\\{, }}% overwrite hyperref setup
Packit Service 99d1c0
       \hypersetup{pdfauthor={\@author}, pdftitle={\@title}}%
Packit Service 99d1c0
      \endgroup
Packit Service 99d1c0
    \begin{flushright}%
Packit Service 99d1c0
      \sphinxlogo
Packit Service 99d1c0
      \py@HeaderFamily
Packit Service 99d1c0
      {\Huge \@title \par}
Packit Service 99d1c0
      {\itshape\LARGE \py@release\releaseinfo \par}
Packit Service 99d1c0
      \vfill
Packit Service 99d1c0
      {\LARGE
Packit Service 99d1c0
        \begin{tabular}[t]{c}
Packit Service 99d1c0
          \@author
Packit Service 99d1c0
        \end{tabular}
Packit Service 99d1c0
        \par}
Packit Service 99d1c0
      \vfill\vfill
Packit Service 99d1c0
      {\large
Packit Service 99d1c0
       \@date \par
Packit Service 99d1c0
       \vfill
Packit Service 99d1c0
       \py@authoraddress \par
Packit Service 99d1c0
      }%
Packit Service 99d1c0
    \end{flushright}%\par
Packit Service 99d1c0
    \@thanks
Packit Service 99d1c0
  \end{titlepage}%
Packit Service 99d1c0
  \setcounter{footnote}{0}%
Packit Service 99d1c0
  \let\thanks\relax\let\maketitle\relax
Packit Service 99d1c0
  %\gdef\@thanks{}\gdef\@author{}\gdef\@title{}
Packit Service 99d1c0
  \if@openright\cleardoublepage\else\clearpage\fi
Packit Service 99d1c0
  \spx@tempa
Packit Service 99d1c0
}
Packit Service 99d1c0
Packit Service 99d1c0
\newcommand{\sphinxtableofcontents}{%
Packit Service 99d1c0
  \pagenumbering{roman}%
Packit Service 99d1c0
  \pagestyle{plain}%
Packit Service 99d1c0
  \begingroup
Packit Service 99d1c0
    \parskip \z@skip
Packit Service 99d1c0
    \tableofcontents
Packit Service 99d1c0
  \endgroup
Packit Service 99d1c0
  % before resetting page counter, let's do the right thing.
Packit Service 99d1c0
  \if@openright\cleardoublepage\else\clearpage\fi
Packit Service 99d1c0
  \pagenumbering{arabic}%
Packit Service 99d1c0
  \ifdefined\fancyhf\pagestyle{normal}\fi
Packit Service 99d1c0
}
Packit Service 99d1c0
Packit Service 99d1c0
% This is needed to get the width of the section # area wide enough in the
Packit Service 99d1c0
% library reference.  Doing it here keeps it the same for all the manuals.
Packit Service 99d1c0
%
Packit Service 99d1c0
\renewcommand*\l@section{\@dottedtocline{1}{1.5em}{2.6em}}
Packit Service 99d1c0
\renewcommand*\l@subsection{\@dottedtocline{2}{4.1em}{3.5em}}
Packit Service 99d1c0
Packit Service 99d1c0
% Fix the bibliography environment to add an entry to the Table of
Packit Service 99d1c0
% Contents.
Packit Service 99d1c0
% For a report document class this environment is a chapter.
Packit Service 99d1c0
%
Packit Service 99d1c0
\newenvironment{sphinxthebibliography}[1]{%
Packit Service 99d1c0
  \if@openright\cleardoublepage\else\clearpage\fi
Packit Service 99d1c0
  % \phantomsection % not needed here since TeXLive 2010's hyperref
Packit Service 99d1c0
  \begin{thebibliography}{1}%
Packit Service 99d1c0
  \addcontentsline{toc}{chapter}{\bibname}}{\end{thebibliography}}
Packit Service 99d1c0
Packit Service 99d1c0
% Same for the indices.
Packit Service 99d1c0
% The memoir class already does this, so we don't duplicate it in that case.
Packit Service 99d1c0
%
Packit Service 99d1c0
\@ifclassloaded{memoir}
Packit Service 99d1c0
 {\newenvironment{sphinxtheindex}{\begin{theindex}}{\end{theindex}}}
Packit Service 99d1c0
 {\newenvironment{sphinxtheindex}{%
Packit Service 99d1c0
    \if@openright\cleardoublepage\else\clearpage\fi
Packit Service 99d1c0
    \phantomsection % needed as no chapter, section, ... created
Packit Service 99d1c0
    \begin{theindex}%
Packit Service 99d1c0
    \addcontentsline{toc}{chapter}{\indexname}}{\end{theindex}}}