mosesdecoder/report/caption.dtx

4798 lines
167 KiB
TeX

% \iffalse meta-comment
%
% This is file `caption.dtx'.
%
% Copyright (C) 1994-2006 Axel Sommerfeldt (caption@sommerfee.de)
%
% --------------------------------------------------------------------------
%
% This work may be distributed and/or modified under the
% conditions of the LaTeX Project Public License, either version 1.3
% of this license or (at your option) any later version.
% The latest version of this license is in
% http://www.latex-project.org/lppl.txt
% and version 1.3 or later is part of all distributions of LaTeX
% version 2003/12/01 or later.
%
% This work has the LPPL maintenance status "maintained".
%
% This Current Maintainer of this work is Axel Sommerfeldt.
%
% This work consists of the files caption.ins, caption.dtx,
% caption2.dtx, and anleitung.tex and the derived files
% caption.sty, caption2.sty, caption3.sty, and manual.tex.
%
% \fi
% \CheckSum{1956}
%
% \iffalse
%<*driver>
\NeedsTeXFormat{LaTeX2e}[1994/12/01]
\documentclass{ltxdoc}
\setlength\parindent{0pt}
\setlength\parskip{\smallskipamount}
%
\newcommand\NEWfeature{\NEW{New feature}}
\newcommand\NEWdescription{\NEW{New description}}
\newcommand\NEW[2]{\hskip 1sp \marginpar{\footnotesize\sffamily\raggedleft#1\\#2}}
%
\font\manual=manfnt
\newcommand\DANGER{\hskip 1sp \marginpar{\raggedleft\textcolor{blue}{{\manual\char127}}}}
%
\ifx\pdfoutput\undefined\else
\ifcase\pdfoutput\else
\usepackage{mathptmx,courier}
\usepackage[scaled=0.90]{helvet}
\addtolength\marginparwidth{15pt}
\fi
\fi
%
%\usepackage[french,USenglish]{babel}
\usepackage{color,setspace}
%
%\usepackage{float}
\usepackage{longtable}
%\usepackage[raggedright]{sidecap}
%
\usepackage{caption}[2005/08/24]
\DeclareCaptionLabelSeparator{endash}{\space\textendash\space}
\usepackage{hyperref}
%
\DeclareCaptionFont{singlespacing}{\singlespacing}
\DeclareCaptionFont{onehalfspacing}{\onehalfspacing}
\DeclareCaptionFont{doublespacing}{\doublespacing}
\DeclareCaptionFont{red}{\color{red}}
\DeclareCaptionFont{green}{\color{green}}
\DeclareCaptionFont{blue}{\color{blue}}
%
\DeclareCaptionLabelSeparator{period-newline}{. \\}
\DeclareCaptionStyle{period-newline}[labelsep=period]{labelsep=period-newline}
\DeclareCaptionStyle{period-newline2}[labelsep=period,justification=centering]{labelsep=period-newline}
\DeclareCaptionStyle{period-newline3}[labelsep=period]{labelsep=period-newline,justification=centering}
\DeclareCaptionFormat{reverse}{#3#2#1}
\DeclareCaptionFormat{llap}{\llap{#1#2}#3\par}
\DeclareCaptionLabelFormat{fullparens}{(\bothIfFirst{#1}{ }#2)}
\DeclareCaptionLabelSeparator{fill}{\hfill}
%
\DeclareRobustCommand{\KOMAScript}{\textsf{K\kern.05em O\kern.05em%
M\kern.05em A\kern.1em-\kern.1em Script}}
%
%<+driver>\OnlyDescription
%
\begin{document}
\DocInput{caption.dtx}
\end{document}
%</driver>
% \fi
%
% \newcommand*\purerm[1]{{\upshape\mdseries\rmfamily #1}}
% \newcommand*\puresf[1]{{\upshape\mdseries\sffamily #1}}
% \newcommand*\purett[1]{{\upshape\mdseries\ttfamily #1}}
% \let\package\puresf\def\thispackage{\package{caption}}
% \let\env\purett \let\opt\purett
%
% \newcommand*\version[1]{$v#1$}
%
% \newenvironment{Options}[1]%
% {\list{}{\renewcommand{\makelabel}[1]{\texttt{##1}\hfil}%
% \settowidth{\labelwidth}{\texttt{#1\space}}%
% \setlength{\leftmargin}{\labelwidth}%
% \addtolength{\leftmargin}{\labelsep}}}%
% {\endlist}
%
% \newenvironment{Example}%
% {\ifvmode\else\unskip\par\fi
% \minipage{\linewidth}\smallskip}%
% {\smallskip\endminipage}
% \newcommand\example[3][figure]{%
% \begingroup
% \captionsetup{#2}%
% \captionof{#1}[]{#3}%
% \endgroup}
%
% \GetFileInfo{caption.sty}
% \title{Typesetting captions with the
% \thispackage\ package\thanks{This package has version number
% \fileversion, last revised \filedate.}}
% \author{Axel Sommerfeldt\\\href{mailto:caption@sommerfee.de}{\texttt{caption@sommerfee.de}}}
% \date{2006/01/12}
% \maketitle
%
% \begin{abstract}
% The \thispackage\ package provides many ways to customise the captions
% in floating environments such |figure| and |table| and cooperates with
% many other packages.\footnote{A complete re-work of the user interface
% done together with Steven D. Cochran and Frank Mittelbach has lead to
% this new enhanced version 3.0.}
% \end{abstract}
%
% \tableofcontents
%
% \newcommand\figuretext{^^A
% White sand beaches. The pink smoothness of the conch shell. A sea abundant
% with possibilities. Duty-free shops filled with Europe's finest gifts and
% perfumes. Play your favorite game of golf amidst the tropical greens on one
% of the many championship courses.}
%
% \iffalse
% --------------------------------------------------------------------------- %
% \fi
%
% \section{Introduction}
%
% Within the standard \LaTeX\ classes captions haven't received the attention
% they deserve. Simply typeset as an ordinary paragraph there is no
% remarkable visual difference from the rest of the text, like here:
%
% \example{belowskip=\abovecaptionskip}{\figuretext}
%
% There should be possibilities to change this; e.g., it would be nice if you
% can make the text of the caption a little bit smaller as the normal text,
% add an extra margin, typeset the caption label with the same font family and
% shape as your headings etc. Just like this one:
%
% \example{belowskip=\abovecaptionskip,size=small,margin=10pt,labelfont=bf,labelsep=endash}{\figuretext}
%
% With this package you can do this easily as there are many ready-to-use
% caption formatting options, but you are free to define your very own stuff, too.
%
% \iffalse
% --------------------------------------------------------------------------- %
% \fi
%
% \pagebreak[4]
% \section{Using the package}
% \label{usage}
%
% \DescribeMacro{\usepackage}
% Insert
% \begin{quote}
% |\usepackage|\oarg{options}|{caption}[|\texttt{\filedate}|]|
% \end{quote}
% into the preamble of your document, i.e.~the part of your document
% between |\documentclass| and |\begin{document}|.
% The options control how your captions will look like; e.g.,
% \begin{quote}
% |\usepackage[margin=10pt,font=small,labelfont=bf]{caption}|
% \end{quote}
% would result in captions looking like the second one in the introduction.
%
% \DescribeMacro{\captionsetup}
% For a later change of options the \thispackage\ package provides the command
% \begin{quote}
% |\captionsetup|\oarg{float type}\marg{options}
% \end{quote}
% So
% \begin{quote}
% |\usepackage[margin=10pt,font=small,labelfont=bf]{caption}|
% \end{quote}
% and
% \begin{quote}
% |\usepackage{caption}|\\
% |\captionsetup{margin=10pt,font=small,labelfont=bf}|
% \end{quote}
% are equal in their results.
%
% It's good to know that |\captionsetup| has an effect on the current
% environment only. So if you want to change some settings for the
% current |figure| or |table| only, just place the |\captionsetup| command
% inside the |figure| or |table| right before the |\caption| command.
% For example
% \begin{quote}
% |\begin{figure}|\\
% | |\ldots\\
% | \captionsetup{singlelinecheck=off}|\\
% | \caption{|\ldots|}|\\
% |\end{figure}|
% \end{quote}
% switches the single-line-check off, but only for this |figure| so all
% the other captions remain untouched.
%
% (For a description of the optional parameter \meta{float type} see
% section \ref{misc}: \textit{``Useful stuff''}.)
%
% \iffalse
% --------------------------------------------------------------------------- %
% \fi
%
% \pagebreak[3]
% \section{Options}
%
% \def\OptionLabel{RaggedRight}
% \def\UserDefined{\ldots}
% \makeatletter
% \newcommand*\Section{\@ifstar{\@Section\relax}{\@Section{section}}}
% \newcommand*\@Section[3]{#1 \ref{#2}: \textit{``#3''}}
% \makeatother
% \newcommand*\See[1]{{\small (See #1)}}
% \newcommand*\SeeUserDefined[1][]{%
% \See{\Section{declare}{Do it yourself}#1}}
%
% \iffalse
% --------------------------------------------------------------------------- %
% \fi
%
% \subsection{Formatting}
%
% \DescribeMacro{format=}
% A figure or table caption mainly consits of three parts: the caption label,
% which says if this object is a `Figure' or `Table' and what number is
% associated with it, the caption text itself, which is normally a short
% description of contents, and the caption separator which separates the text
% from the label.
%
% The \textit{caption format} determines how this information will be presented;
% it is specified with the option
% \begin{quote}
% |format=|\meta{format name}\quad ,
% \end{quote}
% having the name of the caption format as its argument.
%
% There are two standard caption formats:
% \iffalse
% \footnote{You have the option to
% define your own ones, too. See section \ref{declare}:
% \textit{``Do it yourself!''} for details.}
% \fi
%
% \begin{Options}{\OptionLabel}
% \item[plain]\NEWdescription{v3.0h}
% Typesets the captions as a normal paragraph.
% (This is the default behaviour, it
% is adapted from the standard \LaTeX\ document classes.)
%
% \item[hang]
% Indents the caption text, so it will `hang' under the first line of the text.
%
% \item[\UserDefined]
% Own formats can be defined using |\DeclareCaptionFormat|.
% \SeeUserDefined
% \end{Options}
%
% \begin{Example}
% An example: Specifying the option
% \begin{quote}
% |format=hang|
% \end{quote}
% yields captions like this:
% \example{format=hang}{\figuretext}
% \end{Example}
%
% \DescribeMacro{indention=}
% For both formats (\texttt{plain} and \texttt{hang}) you can setup an extra
% indention starting at the second line of the caption. You do this with the
% option
% \begin{quote}
% |indention=|\meta{amount}.
% \end{quote}
%
% Three examples:
%
% \begin{Example}
% \begin{quote}
% |format=plain,indention=.5cm|
% \end{quote}
% \captionsetup{aboveskip=0pt}
% \example{format=plain,indention=.5cm}{\figuretext}
% \end{Example}
%
% \begin{Example}
% \begin{quote}
% |format=hang,indention=-0.5cm|
% \end{quote}
% \captionsetup{aboveskip=0pt}
% \example{format=hang,indention=-0.5cm}{\figuretext}
% \end{Example}
%
% \pagebreak[3]
% \DescribeMacro{labelformat=}
% With the option
% \nopagebreak[3]
% \begin{quote}
% |labelformat=|\meta{label format name}
% \end{quote}
% \NEWdescription{v3.0e}
% you specify how the caption label will be typeset.
% There are three standard caption label formats:
%
% \begin{Options}{\OptionLabel}
% \item[default]
% The caption label will be typeset as specified by the document class,
% usually this means the name and the number (like \texttt{simple}).
% (This is the default behaviour.)
%
% \item[empty]
% The caption label will be empty. This option only makes sense when used
% together with other options like \texttt{labelsep=none}.
%
% \item[simple]
% The caption label will be typeset as a name and a number.
%
% \item[parens]
% The number of the caption label will be typeset in parentheses.
%
% \item[\UserDefined]
% Own label formats can be defined using |\DeclareCaptionLabelFormat|.
% \SeeUserDefined
% \end{Options}
%
% \begin{Example}
% An example: Using the options
% \begin{quote}
% |labelformat=parens,labelsep=quad|
% \end{quote}
% yields captions like this one:
% \example{labelformat=parens,labelsep=quad}{\figuretext}
% \end{Example}
%
% \DescribeMacro{labelsep=}
% With the options
% \begin{quote}
% |labelsep=|\meta{label separator name}
% \end{quote}
% you specify what caption separator will be used.
% You can choose one of the following:
%
% \begin{Options}{\OptionLabel}
% \item[none]
% There is no caption separator. This option only makes sense when used
% together with other options like \texttt{labelformat=empty}.
%
% \item[colon]
% The caption label and text will be separated by a colon and a space.
% (This is the default one.)
%
% \item[period]
% The caption label and text will be separated by a period and a space.
%
% \item[space]
% The caption label and text will be separated by a single space.
%
% \item[quad]
% The caption label and text will be separated by a |\quad|.
%
% \item[newline]
% The caption label and text will be separated by a line break (|\\|).
%
% \item[endash]\NEWfeature{v3.0h}
% The caption label and text will be separated by an en-dash,
% surrounded by spaces (| -- |).
%
% \item[\UserDefined]
% Own separators can be defined using |\DeclareCaptionLabelSeparator|.
% \SeeUserDefined
% \end{Options}
%
% Three examples:
% \begin{Example}
% \begin{quote}
% |labelsep=period|
% \end{quote}
% \captionsetup{aboveskip=0pt}
% \example{labelsep=period}{\figuretext}
% \end{Example}
%
% \begin{Example}
% \begin{quote}
% |labelsep=newline,singlelinecheck=false|
% \end{quote}
% \captionsetup{aboveskip=0pt}
% \example{labelsep=newline,singlelinecheck=false}{\figuretext}
% \end{Example}
%
% \begin{Example}
% \begin{quote}
% |labelsep=endash|
% \end{quote}
% \captionsetup{aboveskip=0pt}
% \example{labelsep=endash}{\figuretext}
% \end{Example}
%
% \iffalse
% --------------------------------------------------------------------------- %
% \fi
%
% \subsection{Justification}
% \label{justification}
%
% \DescribeMacro{justification=}
% As addition to the caption format you could also specify a
% \emph{caption justification}; it is specified with the option
% \begin{quote}
% |justification=|\meta{justification name}\quad.
% \end{quote}
%
% You can choose one of the following:
%
% \begin{Options}{\OptionLabel}
% \item[justified]
% Typesets the caption as a normal paragraph. (This is the default.)
%
% \item[centering]
% Each line of the caption will be centered.
%
% \iffalse
% \item[Centering]
% Each line of the caption will be centered, too.
% But this time the command |\Centering| of the \package{ragged2e} package
% will be used to achieve this. This difference is that this time the word
% breaking algorithm of \TeX\ will work inside the caption.
% \fi
%
% \item[centerlast]
% The last line of each paragraph of the caption text will be centered.
%
% \item[centerfirst]
% Only the first line of the caption will be centered.
%
% \item[raggedright]
% Each line of the caption will be moved to the left margin.
%
% \iffalse
% \item[RaggedRight]
% Each line of the caption will be moved to the left margin using
% the command |\RaggedRight| from the \package{ragged2e} package.
% \fi
% \item[RaggedRight]
% Each line of the caption will be moved to the left margin, too.
% But this time the command |\RaggedRight| of the \package{ragged2e} package
% will be used to achieve this. This difference is that this time the word
% breaking algorithm of \TeX\ will work inside the caption.
%
% \item[raggedleft]
% Each line of the caption will be moved to the right margin.
%
% \iffalse
% \item[RaggedLeft]
% Each line of the caption will be moved to the right margin using
% the command |\RaggedLeft| from the \package{ragged2e} package.
% \fi
%
% \item[\UserDefined]
% Own justifications can be defined using |\DeclareCaptionJustification|.
% \SeeUserDefined
% \end{Options}
%
% Two examples:
% \begin{Example}
% \begin{quote}
% |justification=centerlast|
% \end{quote}
% \captionsetup{aboveskip=0pt}
% \example{justification=centerlast}{\figuretext}
% \end{Example}
%
% \begin{Example}
% \begin{quote}
% |format=hang,justification=raggedright|
% \end{quote}
% \captionsetup{aboveskip=0pt}
% \example{format=hang,justification=raggedright}{\figuretext}
% \end{Example}
%
% \begin{Example}
% \begin{quote}
% |labelsep=newline,justification=centering|
% \end{quote}
% \captionsetup{aboveskip=0pt}
% \example{belowskip=\abovecaptionskip,labelsep=newline,justification=centering}{\figuretext}
% \end{Example}
%
% \DescribeMacro{singlelinecheck=}
% The standard \LaTeX\ document classes (|article|, |report|, and |book|)
% automatically center a caption if it fits in one single line:
%
% \example{belowskip=\abovecaptionskip}{A short caption.}
%
% \DANGER
% The \thispackage\ package adapts this behaviour and therefore usually
% ignores the justification you have set with |justification=| in such case.
% But you can switch this special treatment of such short captions off
% with the option
% \begin{quote}
% |singlelinecheck=|\meta{bool}\quad.
% \end{quote}
% Using |false|, |no|, |off| or |0| for \meta{bool} you switch off the
% extra centering:
% \begin{quote}
% |singlelinecheck=false|
% \end{quote}
% Doing so the above short caption would look like
%
% \begingroup
% \captionsetup{type=figure}
% \ContinuedFloat
% \endgroup
% \example{belowskip=\abovecaptionskip,singlelinecheck=false}{A short caption.}
%
% Using |true|, |yes|, |on| or |1| for \meta{bool} you switch on the
% extra centering again. (The default is on.)
%
% \iffalse
% --------------------------------------------------------------------------- %
% \fi
%
% \subsection{Fonts}
% \label{fonts}
%
% \DescribeMacro{font=}
% \DescribeMacro{labelfont=}
% \DescribeMacro{textfont=}
% There are three font options which affects different parts of the caption:
% One affecting the whole caption (|font|), one which only affects the caption
% label and separator (|labelfont|) and at last one which only affects the
% caption text (|testfont|).
% You set them up using the options
% \begin{quote}\begin{tabular}{@{}r@{}ll}
% |font=| & \marg{font options} & ,\\
% |labelfont=| & \marg{font options} & and\\
% |textfont=| & \marg{font options} & .\\
% \end{tabular}\end{quote}
%
% And these are the available font options:
%
% \begin{Options}{\OptionLabel}
% \item[scriptsize] {\scriptsize Very small size}
% \item[footnotesize] {\footnotesize The size usually used for footnotes}
% \item[small] {\small Small size}
% \item[normalsize] {\normalsize Normal size}
% \item[large] {\large Large size}
% \item[Large] {\Large Even larger size}
%
% \item[up] {\upshape Upright shape}
% \item[it] {\itshape Italic shape}
% \item[sl] {\slshape Slanted shape}
% \item[sc] {\scshape Small Caps shape}
%
% \item[md] {\mdseries Medium series}
% \item[bf] {\bfseries Bold series}
%
% \item[rm] {\rmfamily Roman family}
% \item[sf] {\sffamily Sans Serif family}
% \item[tt] {\ttfamily Typewriter family}
%
% \item[\UserDefined]
% Own font options can be defined using |\DeclareCaptionFont|.
% \SeeUserDefined
% \end{Options}
%
% If you use only one of these options you can omit the braces;
% e.g., the options
% \iffalse
% \begin{quote}
% \fi
% |font={small}|
% \iffalse
% \end{quote}
% \fi
% and
% \iffalse
% \begin{quote}
% \fi
% |font=small|
% \iffalse
% \end{quote}
% \fi
% yield the same result.
%
% Two examples:
% \begin{Example}
% \begin{quote}
% |font={small,it},labelfont=bf|
% \end{quote}
% \captionsetup{aboveskip=0pt}
% \example{font={small,it},labelfont=bf}{\figuretext}
% \end{Example}
%
% \begin{Example}
% \begin{quote}
% |font=small,labelfont=bf,textfont=it|
% \end{quote}
% \captionsetup{aboveskip=0pt}
% \example{font=small,labelfont=bf,textfont=it}{\figuretext}
% \end{Example}
%
% \iffalse
% --------------------------------------------------------------------------- %
% \fi
%
% \subsection{Margins and further paragraph options}
% \label{margins}
%
% \DescribeMacro{margin=}
% \DescribeMacro{width=}
% For all captions you can specify \emph{either} an extra margin \emph{or}
% a fixed width. You do this using the options
% \begin{quote}\begin{tabular}{@{}r@{}ll}
% |margin=| & \meta{amount} & \emph{or}\\
% |width=| & \meta{amount} & \\
% \end{tabular}\end{quote}
% Nevertheless what option you use, the left and right margin will be the
% same.
%
% Two examples illustrating this:
% \begin{Example}
% \begin{quote}
% |margin=10pt|
% \end{quote}
% \captionsetup{aboveskip=0pt}
% \example{margin=10pt}{\figuretext}
% \end{Example}
%
% \begin{Example}
% \begin{quote}
% |width=.75\textwidth|
% \end{quote}
% \captionsetup{aboveskip=0pt}
% \example{width=.75\textwidth}{\figuretext}
% \end{Example}
%
% \DescribeMacro{parskip=}
% This option is useful for captions containing more than one paragraph.
% If specifies the extra vertical space inserted between them:
% \begin{quote}
% |parskip=|\meta{amount}
% \end{quote}
% One example:
% \begin{Example}
% \begin{quote}
% |margin=10pt,parskip=5pt|
% \end{quote}
% \captionsetup{aboveskip=0pt}
% \example{margin=10pt,parskip=5pt}{
% First paragraph of the caption. This one contains some test, just to
% show how these options affect the layout of the caption.
%
% Second paragraph of the caption. This one contains some text, too, to
% show how these options affect the layout of the caption.}
% \end{Example}
%
% \DescribeMacro{hangindent=}
% The option
% \begin{quote}
% |hangindent=|\meta{amount}
% \end{quote}
% is for setting up a hanging indention starting from the second line of each
% paragraph. If the caption contains just a single paragraph, using this option
% leads to the same result as the option |indention=| you already know about.
% But if the caption contains multiple paragraphs you will notice the difference:
%
% \begin{Example}
% \begin{quote}
% |format=hang,indention=-.5cm|
% \end{quote}
% \captionsetup{aboveskip=0pt}
% \example{format=hang,indention=-.5cm}{
% First paragraph of the caption. This one contains some test, just to
% show how these options affect the layout of the caption.
%
% Second paragraph of the caption. This one contains some text, too, to
% show how these options affect the layout of the caption.}
% \end{Example}
%
% \begin{Example}
% \begin{quote}
% |format=hang,hangindent=-.5cm|
% \end{quote}
% \captionsetup{aboveskip=0pt}
% \example{format=hang,hangindent=-.5cm}{
% First paragraph of the caption. This one contains some test, just to
% show how these options affect the layout of the caption.
%
% Second paragraph of the caption. This one contains some text, too, to
% show how these options affect the layout of the caption.}
% \end{Example}
%
% \iffalse
% --------------------------------------------------------------------------- %
% \fi
%
% \subsection{Styles}
% \label{style}
%
% \DescribeMacro{style=}
% A suitable combination of caption options is called \emph{caption style}.
% You can compare them more or less to page styles which you set up with
% |\pagestyle|: The caption style provides all settings for a whole caption layout.
%
% You switch to an already defined caption style with the option
% \begin{quote}
% |style=|\meta{style name}\quad.
% \end{quote}
% The \thispackage\ package usually defines only the style |default| which
% puts all options you already know about to the default ones.
% This means that specifying the option
% \begin{quote}
% |style=default|
% \end{quote}
% has the same effect as specifying all these options:
% \begin{quote}
% |format=default,labelformat=default,labelsep=default,|\\
% |justification=default,font=default,labelfont=default,|\\
% |textfont=default,margin=0pt,indention=0pt,parindent=0pt|\\
% |hangindent=0pt,singlelinecheck=true|
% \end{quote}
%
% Own caption styles can be defined using |\DeclareCaptionStyle|.
% \SeeUserDefined
%
% \iffalse
% --------------------------------------------------------------------------- %
% \fi
%
% \subsection{Skips}
%
% \DescribeMacro{aboveskip=}
% \DescribeMacro{belowskip=}
% The spaces above and below the caption are controlled by the skips
% |\abovecaptionskip| and |\belowcaptionskip|. The standard \LaTeX\ document
% classes |article|, |report| and |book| set |\abovecaptionskip| to |10pt|
% and |\belowcaptionskip| to |0pt|.
%
% \pagebreak[3]
% Both skips can be changed with the command |\setlength|, but you can
% use these options, too:
% \nopagebreak[3]
% \begin{quote}\begin{tabular}{@{}r@{}ll}
% |aboveskip=| & \meta{amount} & and\\
% |belowskip=| & \meta{amount} & .\\
% \end{tabular}\end{quote}
%
% \DescribeMacro{position=}
% Using |\abovecaptionskip| and |\belowcaptionskip| has a major design flaw:
% If the caption is typeset \emph{above} (and not \emph{below}) the figure
% or table they are not set up very useful at default, because there will be
% some extra space above the caption but no space between the caption and the
% figure or table itself. (Remember: |\belowcaptionskip| is usually set to |0pt|.)
%
% Please compare the spacing in these small tables:
% \begin{Example}
% \begin{minipage}[c]{.5\linewidth}
% \iffalse
% \captionsetup{aboveskip=0pt}%
% \fi
% \captionof{table}{A table}
% \centering\begin{tabular}{ll}
% A & B \\
% C & D \\
% \end{tabular}
% \end{minipage}
% \begin{minipage}[c]{.5\linewidth}
% \centering\begin{tabular}{ll}
% A & B \\
% C & D \\
% \end{tabular}
% \captionof{table}{A table}
% \end{minipage}
% \end{Example}
%
% But you can fix this by using the option |position=|: It specifies how the
% spacing above and below the caption will be used:
% \begin{quote}
% |position=top|\quad(or |position=above|)
% \end{quote}
% tells the \thispackage\ package to use the spacing useful for caption
% \emph{above} the figure or table and
% \begin{quote}
% |position=bottom|\quad(or |position=below|)
% \end{quote}
% tells the \thispackage\ package to use the spacing useful for captions
% \emph{below} the figure or table. (The last one is the default setting
% except for |longtable|s.)
%
% So adding an extra |\captionsetup{position=top}| to the left example
% table gives you proper spacing around both captions:
% \begin{Example}
% \begin{minipage}[c]{.5\linewidth}
% \captionsetup{position=top}
% \captionof{table}{A table}
% \centering\begin{tabular}{ll}
% A & B \\
% C & D \\
% \end{tabular}
% \end{minipage}
% \begin{minipage}[c]{.5\linewidth}
% \centering\begin{tabular}{ll}
% A & B \\
% C & D \\
% \end{tabular}
% \captionof{table}{A table}
% \end{minipage}
% \end{Example}
%
% (Technically speaking |\abovecaptionskip| and |\belowcaptionskip| will
% be swapped if you specify the option |position=top|, so in both cases
% |\abovecaptionskip| will be used between the caption and the figure or
% table itself.)
%
% \DescribeMacro{tableposition=}
% This option is especially useful when used together with the optional
% argument of the |\captionsetup| command.
% \See{\Section{misc}{Useful stuff} for details}\par
% E.g.,
% \begin{quote}
% |\captionsetup[table]{position=top}|
% \end{quote}
% causes all captions within tables to be treated as captions \emph{above}
% the table (regarding spacing around it).
% \NEWfeature{v3.0a}
% Because this is a very common setting the \thispackage\ package offers
% an abbreviating option for the use with |\usepackage|:
% \begin{quote}
% |\usepackage[|\ldots|,tableposition=top]{caption}|
% \end{quote}
% is equivalent to
% \begin{quote}
% |\usepackage[|\ldots|]{caption}|\\
% |\captionsetup[table]{position=top}|
% \end{quote}
%
% \iffalse
% --------------------------------------------------------------------------- %
% \fi
%
% \pagebreak[3]
% \section{Useful stuff}
% \label{misc}
%
% \DescribeMacro{\caption}
% The command
% \nopagebreak[3]
% \begin{quote}
% |\caption|\oarg{lst\_entry}\marg{heading}
% \end{quote}
% \nopagebreak[3]
% typesets the caption inside a floating environment like |figure| or |table|.
% Well, you already know this, but what is new is the fact then when you leave
% the argument \meta{lst\_entry} empty, no entry in the list of figures or
% tables will be made; e.g.,
% \begin{quote}
% |\caption[]{A figure without entry in the list of figures.}|
% \end{quote}
%
% \DescribeMacro{\caption*}
% The \package{longtable} package defines the command |\caption*| which
% typesets the caption without label and without entry in the list of tables.
% An example:
% \begin{quote}
% |\begin{longtable}{cc}|\\
% | \caption*{A table}\\|\\
% | A & B \\|\\
% | C & D \\|\\
% |\end{longtable}|
% \end{quote}
% looks like
% \begin{longtable}{cc}
% \caption*{A table}\\
% A & B \\
% C & D \\
% \end{longtable}
%
% This package does it, too, so you can use this command now within every
% floating environment like |figure| or |table|, like here:
% \begin{quote}
% |\begin{table}|\\
% | \caption*{A table}|\\
% | \begin{tabular}{cc}|\\
% | A & B \\|\\
% | C & D \\|\\
% | \end{tabular}|\\
% |\end{table}|
% \end{quote}
%
% \DescribeMacro{\captionof}
% \DescribeMacro{\captionof*}
% Sometimes you want to typeset a caption \emph{outside} a floating environment,
% putting a figure within a |minipage| for instance. For this purpose the
% \thispackage\ package offers the command
% \begin{quote}
% |\captionof|\marg{float type}\oarg{lst\_entry}\marg{heading}\quad.
% \end{quote}
% Note that the first argument, the \meta{float type}, is mandatory here, because
% the |\captionof| command needs to know which name to put into the caption label
% (e.g. ``Figure'' or ``Table'') and in which list to put the contents entry.
% An example:
% \begin{quote}
% |\captionof{figure}{A figure}|\\
% |\captionof{table}{A table}|
% \end{quote}
% typesets captions like this:
% \begin{Example}
% \captionof{figure}{A figure}
% \captionsetup{belowskip=\abovecaptionskip}
% \captionof{table}{A table}
% \end{Example}
%
% The star variant |\captionof*| has the same behaviour as the |\caption*| command:
% it typesets the caption without label and without entry to the list of figures
% or tables.
%
% Please use both |\captionof| and |\captionof*| only \emph{inside} environments
% (like |minipage| or |\parbox|), otherwise a page break can appear between content
% and caption. Furthermore some strange effects could occur (e.g., wrong spacing
% around captions).
%
% \DescribeMacro{\ContinuedFloat}
% Sometimes you want to split figures or tables without giving them
% their own reference number. This is what the command
% \begin{quote}
% |\ContinuedFloat|
% \end{quote}
% is for; it should be used as first command inside the floating environment.
% It prevents the increment of the relevant counter so a figure or table
% with a |\ContinuedFloat| in it gets the same reference number as the figure
% or table before.
%
% An example:
% \begin{quote}
% |\begin{table}|\\
% |\caption{A table}|\\
% \ldots\\
% |\end{table}|\\
% \ldots\\
% |\begin{table}\ContinuedFloat|\\
% |\caption{A table (cont.)}|\\
% \ldots\\
% |\end{table}|
% \end{quote}
% gives the following result:
% \begin{Example}
% \makeatletter\def\@captype{table}\makeatother
% \caption[]{A table}
% \centerline{\ldots}
% \ContinuedFloat
% \captionsetup{aboveskip=0pt}
% \caption[]{A table (cont.)}
% \end{Example}
%
% \DescribeMacro{\captionsetup}
% We already know the |\captionsetup| command (see \Section{usage}
% {Using the package}), but this time we get enlighten about
% the optional argument \meta{float type}.
%
% Remember, the syntax of this command is
% \begin{quote}
% |\captionsetup|\oarg{float type}\marg{options}\quad.
% \end{quote}
%
% If a \meta{float type} gets specified, all the \meta{options} don't
% change anything at this time. Instead they only get marked for a later use,
% when a caption inside of a floating environment of the particular type
% \meta{float type} gets typeset.
% For example
% \begin{quote}
% |\captionsetup[figure]|\marg{options}
% \end{quote}
% forces captions within a |figure| environment to use the given \meta{options}.
%
% Here comes an example to illustrate this:
% \begin{quote}
% |\captionsetup{font=small}|\\
% |\captionsetup[figure]{labelfont=bf}|
% \end{quote}
% gives captions like this:
% \begin{Example}
% \captionsetup{font=small}
% \captionsetup[figure]{labelfont=bf}
% \captionof{figure}[]{A figure}
% \captionsetup{belowskip=\abovecaptionskip}
% \captionof{table}[]{A table}
% \end{Example}
%
% As you see the command |\captionsetup[figure]{labelfont=bf}| only changed
% the font of the figure caption labels, not touching all other ones.
%
% \DescribeMacro{\clearcaptionsetup}
% If you want to get rid of these parameters marked for an automatic use within
% a particular environment you can use the command
% \begin{quote}
% |\clearcaptionsetup|\marg{Typ}\quad.
% \end{quote}
%
% For example |\clearcaptionsetup{figure}| would clear the extra handling in the
% example above:
% \begin{Example}
% \captionsetup{font=small}
% \captionof{figure}[]{A figure}
% \captionsetup{belowskip=\abovecaptionskip}
% \captionof{table}[]{A table}
% \end{Example}
%
% As \meta{float type} you can usually give one of these only two:
% |figure| and |table|.
% But as we will see later that some \LaTeX\ packages exist (like the
% \package{float}, \package{longtable}, and \package{sidecap} package
% for example) who can define additional floating enviroments and these two
% commands can also be used with them.
%
% \iffalse
% --------------------------------------------------------------------------- %
% \fi
%
% \pagebreak[3]
% \section{Do it yourself!}
% \label{declare}
%
% A family of commands is provided to allow users to define their own formats.
% This enables information on separators, justification, fonts, and styles to
% be associated with a name and kept in one place
% (these commands need to appear in the document preamble,
% this is the part between |\documentclass| and |\begin{document}|).
%
% \pagebreak[2]
% \DescribeMacro{\DeclareCaptionFormat}
% You can define your own caption formats using the command
% \begin{quote}
% |\DeclareCaptionFormat|\marg{name}\marg{code using \#1, \#2 and \#3}\quad.
% \end{quote}
% At usage the system replaces \#1 with the caption label, \#2 with the
% separator and \#3 with the text. So the standard format |plain| is defined
% inside |caption.sty| as
% \begin{quote}
% |\DeclareCaptionFormat{plain}{#1#2#3\par}|
% \end{quote}
%
% \DescribeMacro{\DeclareCaptionLabelFormat}
% Likewise you can define your own caption label formats:
% \begin{quote}
% |\DeclareCaptionLabelFormat|\marg{name}\marg{code using \#1 and \#2}
% \end{quote}
% At usage \#1 gets replaced with the name (e.g. ``figure'') and \#2
% gets replaced with the reference number (e.g. ``12'').
%
% \DescribeMacro{\bothIfFirst}
% \DescribeMacro{\bothIfSecond}
% When you define your own caption label formats and use the \package{subfig}
% package\cite{subfig}, too, you must take care of empty caption label names.
% For this purpose the commands
% \begin{quote}
% |\bothIfFirst|\marg{first arg}\marg{second arg}\quad and\\
% |\bothIfSecond|\marg{first arg}\marg{second arg}
% \end{quote}
% are offered. |\bothIfFirst| tests if the first argument exists (means: is
% not empty), |\bothIfSecond| tests if the second argument exists. If it is
% so both arguments get typeset, otherwise none of them.
%
% For example the standard label format |simple| isn't defined as
% \begin{quote}
% |\DeclareCaptionLabelFormat{simple}{#1 #2}|\quad,
% \end{quote}
% because this could cause an extra space if \#1 is empty. Instead |simple|
% is defined as
% \begin{quote}
% |\DeclareCaptionLabelFormat{simple}{\bothIfFirst{#1}{ }#2}|\quad,
% \end{quote}
% causing the space to appear only if the label name is present.
%
% \pagebreak[3]
% \DescribeMacro{\DeclareCaptionLabelSeparator}
% You can define your own caption label separators with
% \nopagebreak[3]
% \begin{quote}
% |\DeclareCaptionLabelSeparator|\marg{name}\marg{code}\quad.
% \end{quote}
% \nopagebreak[3]
% Again an easy example taken from |caption.sty| itself:
% \nopagebreak[3]
% \begin{quote}
% |\DeclareCaptionLabelSeparator{colon}{: }|
% \end{quote}
% \pagebreak[3]
%
% \DescribeMacro{\DeclareCaptionJustification}
% You can define your own caption justifications with
% \begin{quote}
% |\DeclareCaptionJustification|\marg{name}\marg{code}\quad.
% \end{quote}
% The \meta{code} simply gets typeset just before the caption.
% E.g.~using the justification |raggedright|, which is defined as
% \begin{quote}
% |\DeclareCaptionJustification{raggedright}{\raggedright}|\quad,
% \end{quote}
% yields captions with all lines moved to the left margin.
%
% \DescribeMacro{\DeclareCaptionFont}
% You can define your own caption fonts with
% \begin{quote}
% |\DeclareCaptionFont|\marg{name}\marg{code}\quad.
% \end{quote}
% For example this package defines the options |small| and |bf| as
% \begin{quote}
% |\DeclareCaptionFont{small}{\small}|\quad and\\
% |\DeclareCaptionFont{bf}{\bfseries}|\quad.
% \end{quote}
% The line spacing could be customized using the \package{setspace} package,
% for example:\NEWdescription{v3.0h}
% regeln:
% \begin{quote}
% |\usepackage{setspace}|\\
% |\DeclareCaptionFont{singlespacing}{\singlespacing}|\\
% |\DeclareCaptionFont{onehalfspacing}{\onehalfspacing}|\\
% |\DeclareCaptionFont{doublespacing}{\doublespacing}|\\
% |\captionsetup{font={onehalfspacing,small},labelfont=bf}|
% \end{quote}
% \example{font={onehalfspacing,small},labelfont=bf,singlelinecheck=off}\figuretext
% An example which brings color into life:
% \begin{quote}
% |\usepackage{color}|\\
% |\DeclareCaptionFont{red}{\color{red}}|\\
% |\DeclareCaptionFont{green}{\color{green}}|\\
% |\DeclareCaptionFont{blue}{\color{blue}}|\\
% |\captionsetup{labelfont=blue,textfont=green}|
% \end{quote}
% \example{labelfont=blue,textfont=green,singlelinecheck=off}\figuretext
%
% \DescribeMacro{\DeclareCaptionStyle}
% The best one comes at last: You can define your own caption styles with
% \begin{quote}
% |\DeclareCaptionStyle|\marg{name}\oarg{additional options}\marg{options}
% \end{quote}
% Remember, caption styles are just a collection of suitable options, saved
% under a given name. You can wake up these options at any time with the
% option |style=|\meta{style name}.
%
% All caption styles are based on the default set of options. (See \Section
% {style}{Styles} for a complete list.) So you only need
% to specify options which are different to them.
%
% If you specify \meta{additional options} they get used in addition when
% the caption fits into a single line and this check was not disabled with
% the option |singlelinecheck=off|.
%
% Again a very easy example taken from |caption.sty|:
% \begin{quote}
% |\DeclareCaptionStyle{default}[justification=centering]{}|
% \end{quote}
%
% \iffalse
% --------------------------------------------------------------------------- %
% \fi
%
% \subsection{Examples}
%
% If you would like to have a colon \emph{and} a line break as caption
% separator you could define it this way:
% \begin{quote}
% |\DeclareCaptionLabelSeparator{period-newline}{. \\}|
% \end{quote}
% Selecting this separator with |\captionsetup{labelsep=period-newline}| you
% get captions like this:
% \begin{Example}
% \captionsetup{labelsep=period-newline,labelfont=bf,margin=10pt}
% \captionsetup{aboveskip=0pt,type=figure}
% \caption[]{\figuretext}
% \end{Example}
%
% For short captions---which fit into one single line---this separator
% may not be satisfying, even when the automatically centering process
% is switched off (with |singlelinecheck=off|):
% \begin{Example}
% \captionsetup{labelsep=period-newline,labelfont=bf,margin=10pt,singlelinecheck=0}
% \captionsetup{aboveskip=0pt,type=figure}
% \caption[]{A figure.}
% \end{Example}
%
% An own caption style which selects another caption separator automatically
% puts this right:
% \begin{quote}
% |\DeclareCaptionStyle{period-newline}%|\\
% | [labelsep=period]{labelsep=period-newline}|
% \end{quote}
% \begin{Example}
% \captionsetup{style=period-newline,labelfont=bf,margin=10pt}
% \captionsetup{aboveskip=0pt,type=figure}
% \ContinuedFloat
% \caption[]{A figure.}
% \end{Example}
% If you would like to keep the centering of these captions an appropriate
% definition is
% \begin{quote}
% |\DeclareCaptionStyle{period-newline}%|\\
% | [labelsep=period,justification=centering]%|\\
% | {labelsep=period-newline}|
% \end{quote}
% Using this definition short captions look like
% \begin{Example}
% \captionsetup{style=period-newline2,labelfont=bf,margin=10pt}
% \captionsetup{aboveskip=0pt,type=figure}
% \ContinuedFloat
% \caption[]{A figure.}
% \end{Example}
% while long ones still have a line break after the caption label.
%
% Slightly changed, you also get centered captions if they are longer than one line:
% \begin{quote}
% |\DeclareCaptionStyle{period-newline}%|\\
% | [labelsep=period]%|\\
% | {labelsep=period-newline,justification=centering}|
% \end{quote}
% \begin{Example}
% \captionsetup{style=period-newline3,labelfont=bf,margin=10pt}
% \captionsetup{aboveskip=0pt,type=figure}
% \caption[]{\figuretext}
% \end{Example}
%
% \bigskip\pagebreak[3]
% Another example: You want captions to look like this:
% \begin{Example}
% \captionsetup{format=reverse,labelformat=fullparens,labelsep=fill,font=small,labelfont=it}
% \captionsetup{aboveskip=0pt}
% \captionof{figure}[]{\figuretext}
% \end{Example}
% \pagebreak[2]
% You could do it this way:
% \nopagebreak[3]
% {\leftmargini=10pt
% \begin{quote}
% |\DeclareCaptionFormat{reverse}{#3#2#1}|\\
% |\DeclareCaptionLabelFormat{fullparens}{(\bothIfFirst{#1}{ }#2)}|\\
% |\DeclareCaptionLabelSeparator{fill}{\hfill}|\\
% |\captionsetup{format=reverse,labelformat=fullparens,|\\
% | labelsep=fill,font=small,labelfont=it}|
% \end{quote}}
%
% \bigskip\pagebreak[3]
% Another example: The caption text should go into the left margin; a possible
% solution would be:
% {\leftmargini=10pt
% \begin{quote}
% |\DeclareCaptionFormat{llap}{\llap{#1#2}#3\par}|\\
% |\captionsetup{format=llap,labelsep=quad,singlelinecheck=no}|
% \end{quote}}
% As a result you would get captions like this:
% \begin{Example}
% \captionsetup{format=llap,singlelinecheck=no,labelsep=quad}
% \captionsetup{aboveskip=0pt}
% \captionof{figure}[]{\figuretext}
% \end{Example}
%
% \iffalse
% --------------------------------------------------------------------------- %
% \fi
%
% \pagebreak[3]
% \section{Using non-standard document classes}
%
% \NEWdescription{v3.0d}
% The \thispackage\ package was developed using the standard document classes
% |article|, |report| and |book|.
%
% If you would like to use the \thispackage\ package with the
% \KOMAScript\ classes or with the \package{memoir} class, you have to take
% into consideration that all the possibilities for customization of the
% captions the \KOMAScript\ classes or \package{memoir} class have
% to offer will get lost. (And they have a lot of possibilites to offer!)
% So class options like |tablecaptionabove| and commands like |\captionabove|,
% |\captionbelow|, |\captionformat|, |\figureformat|, |\tableformat|,
% |\setcapindent|, |\setcaphanging|, |\captionstyle| etc.\ will not work
% anymore. So make a wise decision!
%
% Using the \thispackage\ package together with document classes not mentioned
% so far is not recommended at the moment -- unwanted layout changes,
% side effects or failures could occur. (But future versions of the
% \thispackage\ package will contain adaptations for more document classes!
%
% \iffalse
% --------------------------------------------------------------------------- %
% \fi
%
% \section{Using other packages}
% \label{packages}
%
% The \thispackage\ package contains special adaptations to other packages who
% handle with captions, too, so the captions always should look like you
% have specified them to look like.
%
% These are the packages the \thispackage\ package is adapted to:
%
% \begin{tabular}{ll}
% |float| & Gives you the possibility to define new floating environments\\
% |hypcap| & Adjusting \package{hyperref} anchors of captions\\
% |listings| & Typesets source code listings\\
% |longtable| & Typesets tables spanned over multiple pages\\
% |rotating| & Supports rotated figures and tables\\
% |sidecap| & Offers captions \emph{beside} figures or tables\\
% |supertabular| & Typesets tables spanned over multiple pages\\
% \end{tabular}
%
% \NEWfeature{v3.0b}
% If you use one of the above packages together with the {\thispackage} package
% you get the additional possibility to set up captions with
% \begin{quote}|\captionsetup|\oarg{environment}\marg{options}\quad.\end{quote}
% These options will apply for captions inside these environments automatically.
% For example
% \begin{quote}|\captionsetup[lstlisting]{labelfont=bf}|\end{quote}
% forces captions inside the |lstlisting| environment to have bold labels.
% (Please note that this do not work with the |sideways| environments offered by
% the \package{rotating} package.)
%
% If a certain support is not desired you can switch it off using the
% \thispackage\ package option
% \begin{quote}
% |\usepackage[|\ldots|,|\meta{package}|=no]{caption}|\quad.
% \end{quote}
% For example specifying the option |float=no| means you don't like the
% \thispackage\ package to support the \package{float} package.
% (Note: You can specify these options only within the |\usepackage| command,
% especially \emph{not} at a later time with |\captionsetup|.)
%
% For further information about the supported packages please take a look
% at the documentation belonging to it or buy yourself
% The \LaTeX\ Companion\cite{companion}.
%
% \iffalse
% --------------------------------------------------------------------------- %
% \fi
%
% \subsection{The \package{float} package}
% \label{float}
%
% A very useful feature is provided by the \package{float} package\cite{float}:
% It offers the float placement specifier |H| which is much more restrictive
% than the specifier |h| offered by \LaTeX. While the latter one is only a
% recommendation to \LaTeX\ to set the float ``here'', the |H| forces the
% float to appear exactly at the spot where it occurs in your input file
% and nowhere else.
%
% Furthermore it offers different styles for floating environments, these
% styles are |plain|, |plaintop|, |ruled|, and |boxed|.
% You can link one of these styles to either new floating environments or
% to one of the existing environments |figure| and |table|.
%
% If you are using the \thispackage\ package together with the \package{float}
% package this caption style called |ruled| gets defined automatically:
% \begin{quote}
% |\DeclareCaptionStyle{ruled}{labelfont=bf,labelsep=space}|
% \end{quote}
% This style represents the caption layout in |ruled| styled floats.
% For you as an end user this means that captions within |ruled| floats will
% always look like this, nevertheless what generic caption options do you
% specify:
%
% \ifx\floatstyle\undefined
%
% \begin{Example}
% \hrule height.8pt depth0pt \kern2pt
% \vbox{\strut{\bfseries Program 7.1}
% The first program. This hasn't got anything to do with the package
% but is included as an example. Note the \texttt{ruled} float style.}
% \kern2pt\hrule\kern2pt
% \begin{verbatim}
% #include <stdio.h>
%
% int main(int argc, char **argv)
% {
% for (int i = 0; i < argc; ++i)
% printf("argv[%d] = %s\n", i, argv[i]);
% return 0;
% }
% \end{verbatim}
% \kern2pt\hrule\relax
% \end{Example}
%
% \else
%
% \floatstyle{ruled}
% \newfloat{Program}{tbp}{lop}[section]
% \floatname{Program}{Program}
%
% \begin{Program}[H]
% \begin{verbatim}
% #include <stdio.h>
%
% int main(int argc, char **argv)
% {
% for (int i = 0; i < argc; ++i)
% printf("argv[%d] = %s\n", i, argv[i]);
% return 0;
% }
% \end{verbatim}
% \caption{The first program. This hasn't got anything to do with the package
% but is included as an example. Note the \texttt{ruled} float style.}
% \end{Program}
%
% \fi
%
% If you want a different layout for |ruled| captions you have to define
% your own one using the command
% \begin{quote}
% |\DeclareCaptionStyle{ruled}|\marg{options}\quad.
% \end{quote}
%
% This mechanism also works with all other float styles. If you want a special
% caption layout for |plain| or |boxed| floats for example you can simply define
% a suitable caption style with the same name as the float style.
%
% \textbf{Note:} For successful cooperation you need the float package
% version 1.3 or newer.
%
% \iffalse
% --------------------------------------------------------------------------- %
% \fi
%
% \subsection{The \package{listings} package}
% \label{listings}
%
% \NEWdescription{v3.0b}
% The \package{listings} package\cite{listings} is a source code printer for \LaTeX.
% You can typeset stand alone files as well as listings with an environment
% similar to \texttt{verbatim} as well as you can print code snippets using
% a command similar to |\verb|.
% Many parameters control the output and if your preferred programming
% language isn't already supported, you can make your own definition.
%
% \textbf{Note:} For successful cooperation you need the listings package
% version 1.2 or higher. You'll get an error message when using an
% older version!
%
% \iffalse
% --------------------------------------------------------------------------- %
% \fi
%
% \subsection{The \package{longtable} package}
% \label{longtable}
%
% The \package{longtable} package\cite{longtable} offers the environment
% |longtable| which behaves similar to the |tabular| environment, but
% the table itself can span multiple pages.
%
% \textbf{Note:} For successful cooperation you need the longtable package
% version 3.15 or newer.
%
% \iffalse
% --------------------------------------------------------------------------- %
% \fi
%
% \subsection{The \package{rotating} package}
% \label{rotating}
%
% The \package{rotating} package\cite{rotating} offers the floating
% environments \texttt{sideways\-figure} and \texttt{sideways\-table}
% which are just like normal figures and tables but rotated by 90 degree.
% Furthermore they always use a full page on their own.
%
% \iffalse
% --------------------------------------------------------------------------- %
% \fi
%
% \subsection{The \package{sidecap} package}
% \label{sidecap}
%
% \NEWdescription{v3.0b}
% The \package{sidecap} package\cite{sidecap} offers the floating
% environments |SCfigure| and |SCtable| which are like normal figures
% and tables but the caption will be put \emph{beside} the contents.
%
% The \package{sidecap} package offers it's own options for justification.
% If set, they will override the one specified with the caption option
% |justification=| for captions beside their contents.
%
% \DescribeMacro{listof=}
% Using the \package{sidecap} package you will probably notice that
% suppressing the entry in the list of figures or tables with
% |\caption[]{|\ldots|}| won't work inside these environments.
% This is caused by the implementation design of the \package{sidecap}
% package, but you can use |\captionsetup{listof=false}| inside the
% figure or table as an alternative here.
%
% \ifx\SCfigure\undefined
%
% \begin{Example}
% \newsavebox\scbox
% \begin{lrbox}{\scbox}
% \setlength{\unitlength}{.75cm}
% \setlength{\fboxsep}{0pt}
% \fbox{\begin{picture}(4,4)
% \put(1,3){\circle{1}}
% \put(3,3){\circle{1}}
% \put(2,2){\circle{1}}
% \put(1,1){\circle{1}}
% \put(3,1){\circle{1}}
% \end{picture}}
% \end{lrbox}
% \newlength\scboxwidth
% \setlength\scboxwidth{\wd\scbox}
% \makebox[\linewidth][c]{
% \parbox[b]{\scboxwidth}{\unhbox\scbox}
% \hspace\marginparsep
% \parbox[b]{1.5\scboxwidth}{
% \captionsetup{justification=RaggedRight,labelfont=bf}
% \captionof{figure}[]{A small example with the caption beside the figure.}
% }
% }
% \end{Example}
%
% \else
%
% \captionsetup{labelfont=bf}
% \begin{SCfigure}[1.5][!ht]
% \setlength{\unitlength}{.75cm}
% \setlength{\fboxsep}{0pt}
% \fbox{\begin{picture}(4,4)
% \put(1,3){\circle{1}}
% \put(3,3){\circle{1}}
% \put(2,2){\circle{1}}
% \put(1,1){\circle{1}}
% \put(3,1){\circle{1}}
% \end{picture}}
% \iffalse
% \captionsetup{labelfont=bf}
% \fi
% \caption[]{A small example with the caption beside the figure.}
% \end{SCfigure}
% \captionsetup{labelfont=default}
%
% \fi
%
% \iffalse
% --------------------------------------------------------------------------- %
% \fi
%
% \subsection{The \package{supertabular} package}
% \label{supertabular}
%
% The \package{supertabular} package\cite{supertabular} offers the environment
% |supertabular| which is quite similar to the |longtable| environment provided
% by the \package{longtable} package. Both offers the typesetting of tables
% which can span multiple pages. For a detailed discussion about the
% differences between these powerful packages please take a look at
% The \LaTeX\ Companion\cite{companion}.
%
% \iffalse
% --------------------------------------------------------------------------- %
% \fi
%
% \subsection{Known incompatibilities}
%
% \NEWdescription{v3.0b}
% Using the \thispackage\ package together with one of the following packages
% is not recommended; usually this would cause unwanted side effects or even
% errors:
% \begin{quote}
% \package{ccaption}, \package{ftcap}, \package{hvfloat}, and
% \package{nonfloat}
% \end{quote}
%
% \iffalse
% --------------------------------------------------------------------------- %
% \fi
%
% \section{Compatibility to older versions}
% \label{compatibility}
%
% \subsection{The \thispackage\ package version $1.x$}
%
% This version of the \thispackage\ package still supports the old options
% and commands provided by the version $1.x$ of this package. So there
% shouldn't occur any problems compiling old documents, but please don't mix
% old options and commands with the new ones. This isn't supported and can
% yield to ugly side effects.
%
% Here comes a short oversight of the obsolete options and commands and how
% they have been replaced within this version of the \thispackage\ package:
%
% {\small\begin{longtable}{ll}
% \thispackage\ \version{1.x} & \thispackage\ \version{3.x}\\
% \hline
% \endhead
% |normal| & |format=plain|\\
% |hang| & |format=hang|\\
% |isu| & |format=hang|\\
% |center| & |justification=centering|\\
% |centerlast| & |justification=centerlast|\\
% \iffalse
% |anne| & |justification=centerlast|\\
% \fi
% |nooneline| & |singlelinecheck=off|\\
% |scriptsize| & |font=scriptsize|\\
% |footnotesize| & |font=footnotesize|\\
% |small| & |font=small|\\
% |normalsize| & |font=normalsize|\\
% |large| & |font=large|\\
% |Large| & |font=Large|\\
% |up| & |labelfont=up|\\
% |it| & |labelfont=it|\\
% |sl| & |labelfont=sl|\\
% |sc| & |labelfont=sc|\\
% |md| & |labelfont=md|\\
% |bf| & |labelfont=bf|\\
% |rm| & |labelfont=rm|\\
% |sf| & |labelfont=sf|\\
% |tt| & |labelfont=tt|\\
% \end{longtable}}
%
% Beside the options for setting up the desired font there were also
% the commands |\captionsize| resp.~|\captionfont| and |\captionlabelfont|
% who could be redefined with |\renewcommand| and allowed an alternate and
% more flexible way to change the font used for captions.
% This mechanism was replaced by the commands
% \begin{minipage}\linewidth\begin{quote}
% |\DeclareCaptionFont{|\ldots|}{|\ldots|}|\qquad and\\
% |\captionsetup{font=|\ldots|,labelfont=|\ldots|}|\qquad.
% \end{quote}\SeeUserDefined\strut\end{minipage}
%
% Setting the margin for captions was done in \version{1.x} with
% \begin{quote}
% |\setlength{\captionmargin}{|\ldots|}|\quad.
% \end{quote}
% This was replaced by
% \begin{quote}
% |\captionsetup{margin=|\ldots|}|\qquad.
% \end{quote}
% \See{\Section{margins}{Margins and further paragraph options}}
%
% For example the old-style code
% \begin{quote}
% |\usepackage[hang,bf]{caption}|\\
% |\renewcommand\captionfont{\small\sffamily}|\\
% |\setlength\captionmargin{10pt}|
% \end{quote}
% should now be written as
% \begin{quote}
% |\usepackage[format=hang,labelfont=bf,font={small,sf},|\\
% | margin=10pt]{caption}|
% \end{quote}
% or
% \begin{quote}
% |\usepackage{caption}|\\
% |\captionsetup{format=hang,labelfont=bf,font={small,sf},|\\
% | margin=10pt}|\qquad.
% \end{quote}
%
% The quite exotic option |ruled| who allowed a partial usage of
% the caption settings for |ruled| floats defined with the
% \package{float} package will be emulated by this version of the
% caption package, too.
% But using this option is not recommended anymore since this
% version of the \thispackage\ package offers a more flexible way
% for changing the captions of these floating environments:
% \begin{quote}
% |\DeclareCaptionStyle{ruled}{|\ldots|}|
% \end{quote}
% resp.
% \begin{quote}
% |\captionsetup[ruled]{|\ldots|}|\qquad.
% \end{quote}
% \SeeUserDefined[, \Section*{misc}{Useful stuff}, and
% \Section*{float}{The \package{float} package}]
%
% \subsection{The \package{caption2} package version $2.x$}
%
% Although they do very similar stuff the packages \package{caption} and
% its experimental and now obsolete variant \package{caption2} have a
% very different implementation design.
% Therefore a full compatibility could not be offered.
% For that reason you will still find a file called |caption2.sty| in
% this package distribution, so old documents using the \package{caption2}
% package will still compile fine.
%
% Newly created documents should use the actual version of the
% \thispackage\ package instead. In most cases it's sufficient to replace
% the command
% \begin{quote}
% |\usepackage[...]{caption2}|
% \end{quote}
% by
% \begin{quote}
% |\usepackage[...]{caption}|\qquad.
% \end{quote}
% But some options and commands will not be emulated, so you can get
% error messages afterwards. This section will help you removing
% these errors. If you have problems migrating from \package{caption2}
% to \package{caption} please don't hesitate to send me an e-mail.
%
% In addition to the obsolete options shown in the last section
% these ones will be emulated, too:
%
% {\small\begin{longtable}{ll}
% \package{caption2} \version{2.x} & \thispackage\ \version{3.x}\\
% \hline
% \endhead
% |flushleft| & |justification=raggedright|\\
% |flushright| & |justification=raggedleft|\\
% |oneline| & |singlelinecheck=on|\\
% \end{longtable}}
%
% Setting the margin for captions was done in \version{2.x} with
% \begin{quote}\leavevmode\hbox{%
% |\setcaptionmargin{|\ldots|}| resp.
% |\setcaptionwidth{|\ldots|}|\quad.
% }\end{quote}
% This was replaced by
% \begin{quote}\leavevmode\hbox{%
% |\captionsetup{margin=|\ldots|}| resp.
% |\captionsetup{width=|\ldots|}|\quad.
% }\end{quote}
% \See{\Section{margins}{Margins and further paragraph options}}
%
% The so-called single-line-check was controlled by the commands
% |\oneline|\-|captions|\-|false| (for switching the check off) and
% |\oneline|\-|captions|\-|true| (for switching the check on).
% This was replaced by
% |\captionsetup{|\discretionary{}{}{}|singlelinecheck=|\discretionary{}{}{}|off}|
% resp.
% |\captionsetup{|\discretionary{}{}{}|singlelinecheck=|\discretionary{}{}{}|on}|.
% \See{\Section{justification}{Justification}}
%
% The commands
% \begin{quote}
% |\captionstyle|, |\captionlabeldelim|, |\captionlabelsep|,\\
% |\captionindent|, |\captionlabelfalse|, |\defcaptionstyle|,\\
% |\newcaptionstyle|, and |\renewcaptionstyle|
% \end{quote}
% do not have a simple replacement and therefore will not be emulated
% by this version of the \thispackage\ package. (So using them will
% yield to error messages.) Rewriting such code is not always easy and
% straight-ahead, but by conscientious reading of this manual you should
% find appropriate options and commands instead.
%
% \iffalse
% ... (some examples)
% \fi
%
% The \version{2.x} option |ignoreLTcapwidth| do not have a replacement, too.
% But in most cases you could simply drop using that option because
% in this version of the \thispackage\ package the value of |\LTcapwidth|
% will be ignored anyway (unless you set it to a different value than the
% default one).
% \See{\Section{longtable}{The \package{longtable} package}}
%
% \iffalse
% --------------------------------------------------------------------------- %
% \fi
%
% \pagebreak[3]
% \section{Further reading}
%
% I recommend the following documents for further reading:
%
% \begin{itemize}
% \item
% The \TeX\ FAQ - Frequently asked questions about \TeX\ and \LaTeX :
% \begin{quote}\url{http://faq.tug.org/}\end{quote}
%
% \item
% A French FAQ can be found at
% \begin{quote}\url{http://www.grappa.univ-lille3.fr/FAQ-LaTeX/}\end{quote}
%
% \item
% \textsf{epslatex} from Keith Reckdahl contains many tips around
% including graphics in \LaTeXe\ documents.
% You will find this document in the directory
% \begin{quote}\url{ftp://ftp.ctan.org/pub/tex/info/epslatex/}\end{quote}
% \end{itemize}
%
% \iffalse
% --------------------------------------------------------------------------- %
% \fi
%
% \section{Thanks}
%
% I would like to thank Katja Melzner,
% Steven D. Cochran, Frank Mittelbach,
% David Carlisle, Carsten Hinz, Olga Lapko, and Keith Reckdahl.
% Thanks a lot for all your help, ideas, patience, spirit, and support!
%
% Also I would like to thank
% Harald Harders,
% Peter L\"offler,
% Peng Yu,
% Alexander Zimmermann,
% Matthias Pospiech,
% J\"urgen Wieferink,
% Christoph Bartoschek,
% Uwe St\"ohr,
% Ralf Stubner,
% Geoff Vallis,
% Florian Keiler,
% J\"urgen G\"obel,
% and
% Uwe Siart
% who all helped to make this package a better one.
%
% \iffalse
% --------------------------------------------------------------------------- %
% \fi
%
% \StopEventually{\begin{thebibliography}{9}
% \bibitem{companion}
% Frank Mittelbach and Michel Goossens:
% \newblock {\em The {\LaTeX} Companion (2nd.~Ed.)},
% \newblock Addison-Wesley, 2004.
%
% \bibitem{float}
% Anselm Lingnau:
% \emph{An Improved Environment for Floats},
% 2001/11/08
%
% \bibitem{floatrow}
% Olga Lapko:
% \emph{The floatrow package documentation},
% 2005/05/22
%
% \bibitem{hyperref}
% Sebastian Rahtz:
% \emph{Hypertext marks in \LaTeX},
% 2003/11/30
%
% \bibitem{hypcap}
% Heiko Oberdiek:
% \emph{The hypcap package -- Adjusting anchors of captions}
% 2001/08/27
%
% \bibitem{listings}
% Carsten Heinz:
% \emph{The Listings Package},
% 2004/02/13
%
% \bibitem{longtable}
% David Carlisle:
% \emph{The longtable package},
% 2000/10/22
%
% \bibitem{rotating}
% Sebastian Rahtz and Leonor Barroca:
% \emph{A style option for rotated objects in \LaTeX},
% 1997/09/26
%
% \bibitem{sidecap}
% Rolf Niepraschk und Hubert G\"a\ss lein:
% \emph{The sidecap package},
% 2003/06/06
%
% \bibitem{subfig}
% Steven D. Cochran:
% \emph{The subfig package},
% 2005/07/05
%
% \bibitem{supertabular}
% Johannes Braams und Theo Jurriens:
% \emph{The supertabular environment},
% 2002/07/19
%
% \bibitem{Anne}
% Anne Br\"uggemann-Klein:
% \emph{Einf\"uhrung in die Dokumentverarbeitung},
% B.G. Teubner, Stuttgart, 1989
% \end{thebibliography}}
%
% \iffalse
% --------------------------------------------------------------------------- %
% \fi
%
% \DoNotIndex{\\,\_,\ ,\@@par}
% \DoNotIndex{\@classoptionslist,\@currext,\@currname}
% \DoNotIndex{\@ehc,\@ehd,\@empty,\@expandtwoargs}
% \DoNotIndex{\@for,\@firstofone,\@firstoftwo}
% \DoNotIndex{\@gobble,\@gobblefour,\@gobbletwo,\@hangfrom}
% \DoNotIndex{\@ifnextchar,\@ifstar,\@ifundefined,\@latex@error}
% \DoNotIndex{\@namedef,\@nameuse}
% \DoNotIndex{\@onlypreamble,\@parboxrestore,\@plus,\@ptionlist}
% \DoNotIndex{\@removeelement,\@restorepar,\@secondoftwo,\@setpar}
% \DoNotIndex{\@tempa,\@tempboxa,\@tempdima,\@tempdimb,\@tempdimc,\@tempb,\@tempc}
% \DoNotIndex{\@undefined,\@unprocessedoptions,\@unusedoptionlist}
% \DoNotIndex{\p@,\z@}
% \DoNotIndex{\active,\addtocounter,\addtolength,\advance}
% \DoNotIndex{\baselineskip,\begin,\begingroup,\bfseries,\box}
% \DoNotIndex{\catcode,\centering,\changes,\csname,\def,\divide,\do,\downarrow}
% \DoNotIndex{\edef,\else,\empty,\end,\endcsname,\endgraf,\endgroup,\expandafter}
% \DoNotIndex{\fi,\footnotesize,\global}
% \DoNotIndex{\hangindent,\hbox,\hfil,\hsize,\hskip,\hspace,\hss}
% \DoNotIndex{\ifcase,\ifdim,\ifnum,\ifodd,\ifvoid,\ifvmode}
% \DoNotIndex{\ifx,\ignorespaces,\itshape}
% \DoNotIndex{\Large,\large,\leavevmode,\leftmargini,\leftskip,\let,\linewidth}
% \DoNotIndex{\llap,\long,\m@ne,\margin,\mdseries,\message}
% \DoNotIndex{\newcommand,\newdimen,\newlength,\newline,\newif,\newsavebox}
% \DoNotIndex{\next,\nobreak,\nobreakspace,\noexpand,\noindent,\numberline}
% \DoNotIndex{\normalsize,\or,\par,\parbox,\parfillskip}
% \DoNotIndex{\parindent,\parskip,\prevdepth,\protect,\protected@edef,\providecommand}
% \DoNotIndex{\quad}
% \DoNotIndex{\raggedleft,\raggedright,\relax,\renewcommand,\RequirePackage}
% \DoNotIndex{\rightskip,\rmfamily}
% \DoNotIndex{\sbox,\scriptsize,\scshape,\setbox,\setlength,\sffamily,\slshape}
% \DoNotIndex{\small,\string,\space,\strut}
% \DoNotIndex{\textheight,\the,\toks@,\typeout,\ttfamily}
% \DoNotIndex{\unvbox,\uparrow,\upshape,\usebox,\usepackage}
% \DoNotIndex{\value,\vbox,\vsize,\vskip,\wd,\width,\z@skip}
% \DoNotIndex{\AtBeginDocument,\AtEndOfPackage,\CurrentOption,\DeclareOption}
% \DoNotIndex{\ExecuteOptions,\GenericWarning,\IfFileExists,\InputIfFileExists}
% \DoNotIndex{\NeedsTeXFormat,\MessageBreak}
% \DoNotIndex{\PackageError,\PackageInfo,\PackageWarning,\PackageWarningNoLine}
% \DoNotIndex{\ProcessOptions,\ProvidesPackage}
%
% \iffalse
% --------------------------------------------------------------------------- %
% \fi
%
% \clearpage
% \setlength{\parskip}{0pt plus 1pt}
%
% \section{The Implementation}
%
% \changes{v1.0}{1994/10/27}{First release}
% \changes{v1.1}{1994/11/03}{New captiontype \cs{centerlast}}
% \changes{v1.2}{1994/11/28}{Support of the \package{float} package}
% \changes{v1.3}{1995/01/09}{Support of \cs{captionlabelfont} in subcaptions}
% \changes{v1.4}{1995/01/30}{New option \cs{nooneline}}
% \changes{v1.4b}{1995/04/05}{Bugfix release}
% \changes{v3.0}{2003/12/20}{Rewritten; many new commands and features}
% \changes{v3.0d}{2004/11/28}{Split into two packages: \package{caption} \& \package{caption3}}
%
% The \package{caption} package consists of two parts -- the kernel
% (|caption3.sty|) and the main package (|caption.sty|).
%
% The kernel provides all the user commands and internal macros which are
% necessary for typesetting captions and setting parameters regarding these.
% While the standard \LaTeX\ document classes provides an internal command
% called |\@makecaption| and no options to control its behavior (except the
% vertical skips above and below the caption itself), we provide similar
% commands called |\caption@make| and |\caption@@make|, but with a lot of
% options which can be selected with |\captionsetup|.
% Loading the kernel part do not change the output of a \LaTeX\ document
% -- it just provides functionality which can be used by \LaTeXe\ packages
% which typesets captions, like the \package{caption} package or the
% \package{subfig} package.
%
% The \package{caption} package itself redefines the \LaTeX\ commands
% |\caption|, |\@caption|, and |\@makecaption| and maps the latter one to
% |\caption@@make|, giving the user the possibility to control the captions of
% the floating environments |figure| and |table|. Furthermore it does similar
% to the caption stuff coming from other packages (like the \package{longtable}
% or \package{supertabular} package):
% Mapping the appropriate internal commands (like |\LT@makecaption| or
% |\ST@caption|) to the ones offered by the \package{caption} kernel.
% So you can think of the \package{caption} package as a layer package, it
% simply provides adaptation layers between the caption stuff coming from
% \LaTeXe\ itself or a \LaTeXe\ package and the caption stuff offered by the
% \package{caption} kernel.
%
% \iffalse
% --------------------------------------------------------------------------- %
% \fi
%
% \subsection{Kernel}
% \iffalse
%<*kernel>
% \fi
%
% \subsubsection*{Identification}
%
% \begin{macrocode}
\NeedsTeXFormat{LaTeX2e}[1994/12/01]
\ProvidesPackage{caption3}[2006/03/16 v3.0j caption3 kernel (AR)]
%<+debug>\PackageWarning{caption3}{DEBUG VERSION}
% \end{macrocode}
%
% \subsubsection*{Generic helpers}
%
% \begin{macro}{\@nameundef}
% This is the opposite to |\@namedef| which is offered by the \LaTeX\ kernel.
% We use it to remove the definition of some commands and keyval options after
% |\begin{document}| (to save \TeX\ memory) and to remove caption options defined
% with |\captionsetup|\oarg{type}.
% \begin{macrocode}
\providecommand*\@nameundef[1]{%
\expandafter\let\csname #1\endcsname\@undefined}
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\l@addto@macro}
% The \LaTeXe\ kernel offers the internal helper macro |\g@addto@macro| which
% globally adds commands to any existising macro, like in |\AtBeginDocument|.
% This is the same but it works local, not global.
% \begin{macrocode}
\providecommand\l@addto@macro[2]{%
\begingroup
\toks@\expandafter{#1#2}%
\edef\@tempa{\endgroup\def\noexpand#1{\the\toks@}}%
\@tempa}
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\bothIfFirst}
% \begin{macro}{\bothIfSecond}
% |\bothIfFirst| tests if the first argument is not empty, |\bothIfSecond|
% tests if the second argument is not empty. If yes both arguments get
% typeset, otherwise none of them.
% \begin{macrocode}
\def\bothIfFirst#1#2{%
\protected@edef\caption@tempa{#1}%
\ifx\caption@tempa\@empty\else
#1#2%
\fi}
% \end{macrocode}
% \begin{macrocode}
\def\bothIfSecond#1#2{%
\protected@edef\caption@tempa{#2}%
\ifx\caption@tempa\@empty\else
#1#2%
\fi}
% \end{macrocode}
% \end{macro}
% \end{macro}
%
% \begin{macro}{\caption@ifinlist}
% This helper macro checks if the first argument is in the comma separated
% list which is offered as second argument. So for example
% \begin{quote}
% |\caption@ifinlist{frank}{axel,frank,steven}{yes}{no}|
% \end{quote}
% would expand to |yes|.
% \begin{macrocode}
\def\caption@ifinlist#1#2{%
\let\next\@secondoftwo
\edef\caption@tempa{#1}%
\@for\caption@tempb:={#2}\do{%
\ifx\caption@tempa\caption@tempb
\let\next\@firstoftwo
\fi}%
\next}
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\caption@setbool}
% \begin{macro}{\caption@ifbool}
% \begin{macro}{\caption@undefbool}
% For setting and testing boolean options we offer these three helper macros:
% \begin{quote}
% |\caption@setbool|\marg{name}\marg{value}\\
% | |(with |value = false/true/no/yes/off/on/0/1|)\\
% |\caption@ifbool|\marg{name}\marg{if-clause}\marg{else-clause}\\
% |\caption@undefbool|\marg{name}
% \end{quote}
% \begin{macrocode}
\def\caption@setbool#1#2{%
\caption@ifinlist{#2}{1,true,yes,on}{%
\expandafter\let\csname caption@if#1\endcsname\@firstoftwo
}{\caption@ifinlist{#2}{0,false,no,off}{%
\expandafter\let\csname caption@if#1\endcsname\@secondoftwo
}{%
\PackageError{caption}{Undefined boolean value `#2'}{\caption@eh}%
}}}
% \end{macrocode}
% \begin{macrocode}
\def\caption@ifbool#1{\@nameuse{caption@if#1}}
% \end{macrocode}
% \begin{macrocode}
\def\caption@undefbool#1{\@nameundef{caption@if#1}}
% \end{macrocode}
% \end{macro}
% \end{macro}
% \end{macro}
%
% \subsubsection*{Using the keyval package}
%
% We need the \package{keyval} package for option handling, so we load it here.
% \begin{macrocode}
\RequirePackage{keyval}[1997/11/10]
% \end{macrocode}
%
% \begin{macro}{\undefine@key}
% This helper macro is the opposite of |\define@key|, it removes a keyval
% definition.
% \begin{macrocode}
\providecommand*\undefine@key[2]{%
\@nameundef{KV@#1@#2}\@nameundef{KV@#1@#2@default}}
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\DeclareCaptionOption}
% |\DeclareCaptionOption|\marg{option}\marg{code}\\
% |\DeclareCaptionOption*|\marg{option}\marg{code}\par
% We declare our options using these commands (instead of using
% |\DeclareOption| offered by \LaTeXe), so the keyval package is used.
% The starred form makes the option available during the lifetime of the
% current package only, so they can be used with |\usepackage|, but
% \emph{not} with |\captionsetup| later on.
% \begin{macrocode}
\newcommand\DeclareCaptionOption{%
\@ifstar{\caption@declareoption\AtEndOfPackage}%
{\caption@declareoption\@gobble}}
\newcommand*\caption@declareoption[2]{%
#1{\undefine@key{caption}{#2}}\define@key{caption}{#2}}
\@onlypreamble\DeclareCaptionOption
\@onlypreamble\caption@declareoption
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\captionsetup}
% \changes{v3.0a}{2004/01/17}{Bugfix: Missing \% added}
% |\captionsetup|\oarg{type}\marg{keyval-list of options}\par
% If the optional argument `type' is specified, we simply save or append
% the option list, otherwise we `execute' it with |\setkeys|.
% \begin{macrocode}
\newcommand\captionsetup{\@ifnextchar[\caption@setuptype\caption@setup}
\newcommand\caption@typ@{caption@typ@} % This saves 74 words of TeX memory
\def\caption@setuptype[#1]#2{%
\@ifundefined{\caption@typ@#1}%
{\@namedef{\caption@typ@#1}{#2}}%
{\expandafter\l@addto@macro\csname\caption@typ@#1\endcsname{,#2}}}
\newcommand\caption@setup{\caption@setkeys{caption}}
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\caption@setkeys}
% \changes{v3.0i}{2006/01/03}{\cs{caption@setkeys} introduced}
% This one simply calls |\setkeys| but lets error messages refer to
% the \package{caption} package instead of the \package{keyval} package.
% \begin{macrocode}
\newcommand*\caption@setkeys[2]{%
\let\caption@KV@errx\KV@errx
\let\caption@KV@err\KV@err
\def\KV@errx##1{\PackageError\caption@package{##1}\@ehc}%
\let\KV@err\KV@errx
\setkeys{#1}{#2}%
\let\KV@errx\caption@KV@errx
\let\KV@err\caption@KV@err}
\newcommand\caption@package{caption}
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\caption@settype}
% \changes{v3.0i}{2006/01/03}{Optional argument added}
% \changes{v3.0j}{2006/01/26}{Revised}
% |\caption@settype|\oarg{package}\marg{type}\par
% Caption options which have been saved with |\captionsetup|\oarg{type} can
% be executed using this command.
% (It simply executes the saved option list, if there is any.)
% \begin{macrocode}
\newcommand\caption@settype{%
\@ifnextchar[\caption@@settype{\caption@@settype[caption]}}
\def\caption@@settype[#1]#2{%
\@ifundefined{\caption@typ@#2}{}{%
\def\caption@package{#1}%
\caption@esetup{\csname\caption@typ@#2\endcsname}%
\def\caption@package{caption}}}
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\caption@esetup}
% |\caption@esetup|\marg{keyval-list of options}\par
% To execute a keyval-list of options saved within a macro we
% need this special version of |\caption@setup| which expands the
% argument first.
% \begin{macrocode}
\newcommand*\caption@esetup[1]{%
\edef\caption@tempa{\noexpand\caption@setup{#1}}%
\caption@tempa}
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\clearcaptionsetup}
% |\clearcaptionsetup|\marg{type}\par
% This removes the saved option list associated with \meta{type}.
% \begin{macrocode}
\newcommand*\clearcaptionsetup[1]{\@nameundef{\caption@typ@#1}}
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\showcaptionsetup}
% \changes{v3.0e}{2005/05/03}{Optimized for memory usage}
% |\showcaptionsetup|\oarg{package}\marg{type}\par
% This comes for debugging issues: It shows the saved option list which
% is associated with \meta{type}.
% \begin{macrocode}
\newcommand*\showcaptionsetup[2][\@firstofone]{%
\GenericWarning{}{%
#1 Caption Info: KV list on `#2'\MessageBreak
#1 Caption Data: (%
\@ifundefined{\caption@typ@#2}{%
% empty -- print nothing
}{%
\@nameuse{\caption@typ@#2}%
}%
)}}
% \end{macrocode}
% \end{macro}
%
% \subsubsection*{Errors}
%
% \begin{macro}{\caption@eh}
% At the moment we only offer this simple error message as generic helper
% for the user.
% \begin{macrocode}
\newcommand\caption@eh{%
If you do not understand this error, please take a closer look\MessageBreak
at the documentation of the `caption' package.\MessageBreak
\@ehc}
% \end{macrocode}
% \end{macro}
%
% \subsubsection*{Margin resp. width}
%
% \begin{macro}{\captionmargin}
% \begin{macro}{\captionmarginx}
% \begin{macro}{\captionwidth}
% |\captionmargin| and |\captionwidth| contain the extra margin
% resp. the total width used for captions. Please never set these values in
% a direct way, they are just accessible in user documents to provide
% compatibility to |caption.sty| \version{1.x}.\par
% Note that we can only set one value at a time, `margin' \emph{or} `width'.
% If |\captionwidth| is not zero we will take this value afterwards,
% otherwise |\captionmargin| and |\captionmarginx|.
% \begin{macrocode}
\newdimen\captionmargin
\newdimen\captionmarginx
\newdimen\captionwidth
% \end{macrocode}
% \end{macro}
% \end{macro}
% \end{macro}
%
% \begin{macrocode}
\DeclareCaptionOption{margin}{\setcaptionmargin{#1}}
\DeclareCaptionOption{width}{\setcaptionwidth{#1}}
% \end{macrocode}
%
% \begin{macro}{\setcaptionmargin}
% |\setcaptionmargin|\marg{amount}
% \changes{v3.0h}{2005/10/24}{Renamed from \cs{caption@setmargin} to \cs{setcaptionmargin}}
% \changes{v3.0h}{2005/10/24}{\cs{setcaptionmargin} enhanced so it can take left+right margin}
% |\setcaptionmargin|\marg{amount}\par
% Please never use this in user documents, it's just there to
% provide compatibility to |caption2.sty| \version{2.x}.
% \begin{macrocode}
\newcommand*\setcaptionmargin[1]{%
\captionwidth\z@
\caption@@setmargin#1,#1,\@nil\@@}
\def\caption@@setmargin#1,#2,#3\@@{%
\setlength\captionmargin{#1}%
\setlength\captionmarginx{#2}%
\advance\captionmarginx by -\captionmargin}
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\setcaptionwidth}
% |\setcaptionwidth|\marg{amount}
% \changes{v3.0h}{2005/10/24}{Renamed from \cs{caption@setwidth} to \cs{setcaptionwidth}}
% |\setcaptionwidth|\marg{amount}\par
% Please never use this in user documents, it's just there to
% provide compatibility to |caption2.sty| \version{2.x}.
% \begin{macrocode}
\newcommand\setcaptionwidth{%
\setlength\captionwidth}
% \end{macrocode}
% \end{macro}
%
% \subsubsection*{Indentions}
% \begin{macro}{\captionindent}
% \begin{macro}{\captionparindent}
% \begin{macro}{\captionhangindent}
% These are the indentions we support.
% \begin{macrocode}
\newdimen\captionindent
\newdimen\captionparindent
\newdimen\captionhangindent
% \end{macrocode}
% \end{macro}
% \end{macro}
% \end{macro}
%
% \changes{v3.0b}{2004/05/16}{Defaults added for options \opt{parindent=} and \opt{hangindent=}}
% \changes{v3.0h}{2005/08/22}{Option \opt{parskip=}: \cs{AtBeginCaption} replaced by \cs{caption@@par}}
% \changes{v3.0h}{2005/08/22}{Undocumented defaults for \opt{parindent=}, \opt{hangindent=},
% and \opt{parskip=} removed}
% \begin{macrocode}
\DeclareCaptionOption{indent}[\leftmargini]{\setlength\captionindent{#1}}% obsolete!
\DeclareCaptionOption{indention}[\leftmargini]{\setlength\captionindent{#1}}
\DeclareCaptionOption{hangindent}{\setlength\captionhangindent{#1}}
\DeclareCaptionOption{parindent}{\setlength\captionparindent{#1}}
\DeclareCaptionOption{parskip}{\l@addto@macro\caption@@par{\setlength\parskip{#1}}}
% \end{macrocode}
%
% \subsubsection*{Styles}
%
% \begin{macro}{\DeclareCaptionStyle}
% \changes{v3.0a}{2004/01/17}{Pass through argument \#3 so extra spaces between arguments do make any harm}
% |\DeclareCaptionStyle|\marg{name}\oarg{single-line-list-of-KV}\marg{list-of-KV}
% \begin{macrocode}
\newcommand*\DeclareCaptionStyle[1]{%
\@ifnextchar[{\caption@declarestyle{#1}}{\caption@declarestyle{#1}[]}}
\def\caption@declarestyle#1[#2]#3{%
\global\@namedef{caption@sls@#1}{#2}%
\global\@namedef{caption@sty@#1}{#3}}
\@onlypreamble\DeclareCaptionStyle
\@onlypreamble\caption@declarestyle
% \end{macrocode}
% \end{macro}
%
% \begin{macrocode}
\DeclareCaptionOption{style}{\caption@setstyle{#1}}
% \end{macrocode}
%
% \begin{macro}{\caption@setstyle}
% \changes{v3.0f}{2005/06/01}{Starred variant added}
% |\caption@setstyle|\marg{name}\\
% |\caption@setstyle*|\marg{name}\par
% Selecting a caption style means saving the additional
% \meta{single-line-list-of-KV} (this will be done by |\caption@sls|),
% resetting the caption options to the default ones (this will be done using
% |\caption@setdefault|) and executing the \meta{list-of-KV} options
% (this will be done using |\caption@esetup|).\par
% The starred version will give no error message if the given style is not
% defined.
% \begin{macrocode}
\newcommand\caption@setstyle{%
\@ifstar{\caption@@setstyle\@gobble}{\caption@@setstyle\@firstofone}}
\newcommand*\caption@@setstyle[2]{%
\@ifundefined{caption@sty@#2}%
{#1{\PackageError{caption}{Undefined caption style `#2'}{\caption@eh}}}%
{\expandafter\let\expandafter\caption@sls\csname caption@sls@#2\endcsname
\caption@setdefault\caption@esetup{\csname caption@sty@#2\endcsname}}}
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\caption@setdefault}
% This resets (nearly) all caption options to the default ones.
% \emph{Note that this does not touch the skips and the positioning!}
% \begin{macrocode}
\newcommand\caption@setdefault{\captionsetup{%
format=default,labelformat=default,labelsep=default,%
justification=default,font=default,labelfont=default,textfont=default,%
margin=0pt,indent=0pt,parindent=0pt,hangindent=0pt,%
singlelinecheck=1,strut=1}}
% \end{macrocode}
% \end{macro}
%
% \changes{v3.0d}{2005/02/12}{\opt{indent=0pt} added to caption style \opt{default}}
% Currently there is only one pre-defined style, called `default'.
% It's a perfect match to the behaviour of |\@makecaption| offered by the
% standard \LaTeX\ document classes:
% If the caption fits in one single line, it is typeset centered.
%
% \begin{macrocode}
\DeclareCaptionStyle{default}[indent=0pt,justification=centering]{}
% \end{macrocode}
%
% \subsubsection*{Formats}
%
% \begin{macro}{\DeclareCaptionFormat}
% \changes{v3.0a}{2004/01/17}{Pass through argument \#3 so extra spaces between arguments do make any harm}
% \changes{v3.0d}{2005/02/09}{Starred variant added}
% |\DeclareCaptionFormat|\marg{name}\marg{code with \#1, \#2, and \#3}\\
% |\DeclareCaptionFormat*|\marg{name}\marg{code with \#1, \#2, and \#3}\par
% The starred form causes the code being typeset in vertical (instead of
% horizontal) mode, but does not support the |indention=| option.
% \begin{macrocode}
\newcommand\DeclareCaptionFormat{%
\@ifstar{\caption@declareformat\@gobble}%
{\caption@declareformat\@firstofone}}
\newcommand\caption@declareformat[3]{%
\global\expandafter\let\csname caption@ifh@#2\endcsname#1%
\global\long\@namedef{caption@fmt@#2}##1##2##3{#3}}
\@onlypreamble\DeclareCaptionFormat
\@onlypreamble\caption@declareformat
% \end{macrocode}
% \end{macro}
%
% \begin{macrocode}
\DeclareCaptionOption{format}{\caption@setformat{#1}}
% \end{macrocode}
%
% \begin{macro}{\caption@setformat}
% |\caption@setformat|\marg{name}\par
% Selecting a caption format simply means saving the code (in |\caption@fmt|)
% and if the code should be used in horizontal or vertical mode (|\caption@ifh|).
% \begin{macrocode}
\newcommand*\caption@setformat[1]{%
\@ifundefined{caption@fmt@#1}%
{\PackageError{caption}{Undefined caption format `#1'}{\caption@eh}}%
{\expandafter\let\expandafter\caption@ifh\csname caption@ifh@#1\endcsname
\expandafter\let\expandafter\caption@fmt\csname caption@fmt@#1\endcsname}}
% \end{macrocode}
% \end{macro}
%
% \changes{v3.0a}{2004/01/23}{Caption format \opt{default} renamed to \opt{normal}}
% \changes{v3.0f}{2005/05/12}{Caption format \opt{normal} renamed to \opt{@normal}}
% \changes{v3.0h}{2005/08/25}{Caption format \opt{@normal} renamed to \opt{plain} and documented}
% There are two pre-defined formats, called `plain' and `hang'.
%
% \begin{macrocode}
\DeclareCaptionFormat{plain}{#1#2#3\par}
\DeclareCaptionFormat{hang}{%
\@hangfrom{#1#2}%
\advance\captionparindent\hangindent
\advance\captionhangindent\hangindent
\caption@@par
#3\par}
% \end{macrocode}
%
% \changes{v3.0a}{2004/01/23}{Caption format \opt{default} linked to \opt{normal}}
% \changes{v3.0e}{2005/04/28}{Bugfix 05-04-28: Missing \cs{caption@ifh@default} added}
% `default' usually maps to `plain'.
%
% \begin{macrocode}
\def\caption@fmt@default{\caption@fmt@plain}
\def\caption@ifh@default{\caption@ifh@plain}
% \end{macrocode}
%
% \subsubsection*{Label formats}
%
% \begin{macro}{\DeclareCaptionLabelFormat}
% \changes{v3.0a}{2004/01/17}{Pass through argument \#2 so extra spaces between arguments do make any harm}
% |\DeclareCaptionLabelFormat|\marg{name}\marg{code with \#1 and \#2}
% \begin{macrocode}
\newcommand*\DeclareCaptionLabelFormat[2]{%
\global\@namedef{caption@lfmt@#1}##1##2{#2}}
\@onlypreamble\DeclareCaptionLabelFormat
% \end{macrocode}
% \end{macro}
%
% \begin{macrocode}
\DeclareCaptionOption{labelformat}{\caption@setlabelformat{#1}}
% \end{macrocode}
%
% \begin{macro}{\caption@setlabelformat}
% |\caption@setlabelformat|\marg{name}\par
% Selecting a caption label format simply means saving the code (in |\caption@lfmt|).
% \begin{macrocode}
\newcommand*\caption@setlabelformat[1]{%
\@ifundefined{caption@lfmt@#1}%
{\PackageError{caption}{Undefined caption label format `#1'}{\caption@eh}}%
{\expandafter\let\expandafter\caption@lfmt\csname caption@lfmt@#1\endcsname}}
% \end{macrocode}
% \end{macro}
%
% There are three pre-defined label formats, called `empty', `simple', and `parens'.
%
% \begin{macrocode}
\DeclareCaptionLabelFormat{empty}{}
\DeclareCaptionLabelFormat{simple}{\bothIfFirst{#1}{\nobreakspace}#2}
\DeclareCaptionLabelFormat{parens}{\bothIfFirst{#1}{\nobreakspace}(#2)}
% \end{macrocode}
%
% `default' usually maps to `simple'.
%
% \begin{macrocode}
\def\caption@lfmt@default{\caption@lfmt@simple}
% \end{macrocode}
%
% \subsubsection*{Label separators}
%
% \begin{macro}{\DeclareCaptionLabelSeparator}
% \changes{v3.0a}{2004/01/17}{Pass through argument \#2 so extra spaces between arguments do make any harm}
% \changes{v3.0h}{2005/08/25}{Starred variant added}
% |\DeclareCaptionLabelSeparator|\marg{name}\marg{code}\\
% |\DeclareCaptionLabelSeparator*|\marg{name}\marg{code}\par
% The starred form causes the label separator to be typeset \emph{without} using |\captionlabelfont|.
% \begin{macrocode}
\newcommand\DeclareCaptionLabelSeparator{%
\@ifstar{\caption@declarelabelseparator\@gobble}%
{\caption@declarelabelseparator\@firstofone}}
\newcommand\caption@declarelabelseparator[3]{%
\global\expandafter\let\csname caption@iflf@#2\endcsname#1%
\global\long\@namedef{caption@lsep@#2}{#3}}
\@onlypreamble\DeclareCaptionLabelSeparator
\@onlypreamble\caption@declarelabelseparator
% \end{macrocode}
% \end{macro}
%
% \begin{macrocode}
\DeclareCaptionOption{labelsep}{\caption@setlabelseparator{#1}}
\DeclareCaptionOption{labelseparator}{\caption@setlabelseparator{#1}}
% \end{macrocode}
%
% \begin{macro}{\caption@setlabelseparator}
% |\caption@setlabelseparator|\marg{name}\par
% Selecting a caption label separator simply means saving the code (in |\caption@lsep|).
% \begin{macrocode}
\newcommand*\caption@setlabelseparator[1]{%
\@ifundefined{caption@lsep@#1}%
{\PackageError{caption}{Undefined caption label separator `#1'}{\caption@eh}}%
{\expandafter\let\expandafter\caption@iflf\csname caption@iflf@#1\endcsname
\expandafter\let\expandafter\caption@lsep\csname caption@lsep@#1\endcsname}}
% \end{macrocode}
% \end{macro}
%
% \changes{v3.0f}{2005/06/11}{Bugfix 05-03-23: Caption label separator \opt{newline} implementation
% changed from \cs{newline} to \cs{\textbackslash}}
% \changes{v3.0h}{2005/08/24}{Caption label separator \opt{endash} added}
% There are seven pre-defined label separators, called `none', `colon', `period', `space',
% `quad', `newline', and `endash'.
%
% \begin{macrocode}
\DeclareCaptionLabelSeparator{none}{}
\DeclareCaptionLabelSeparator{colon}{: }
\DeclareCaptionLabelSeparator{period}{. }
\DeclareCaptionLabelSeparator{space}{ }
\DeclareCaptionLabelSeparator*{quad}{\quad}
\DeclareCaptionLabelSeparator*{newline}{\\}
\DeclareCaptionLabelSeparator*{endash}{\space\textendash\space}
% \end{macrocode}
%
% `default' usually maps to `colon'.
%
% \begin{macrocode}
\def\caption@lsep@default{\caption@lsep@colon}
\def\caption@iflf@default{\caption@iflf@colon}
% \end{macrocode}
%
% \subsubsection*{Justifications}
%
% \begin{macro}{\DeclareCaptionJustification}
% \changes{v3.0a}{2004/01/17}{Pass through argument \#2 so extra spaces between arguments do make any harm}
% |\DeclareCaptionJustification|\marg{name}\marg{code}
% \begin{macrocode}
\newcommand*\DeclareCaptionJustification[2]{%
\global\@namedef{caption@hj@#1}{#2}}
%\newcommand\DeclareCaptionJustification{\DeclareCaptionFont}
\@onlypreamble\DeclareCaptionJustification
% \end{macrocode}
% \end{macro}
%
% \begin{macrocode}
\DeclareCaptionOption{justification}{\caption@setjustification{#1}}
% \end{macrocode}
%
% \begin{macro}{\caption@setjustification}
% |\caption@setjustification|\marg{name}\par
% Selecting a caption justification simply means saving the code (in |\caption@hj|).
% \begin{macrocode}
\newcommand*\caption@setjustification[1]{%
\@ifundefined{caption@hj@#1}%
{\PackageError{caption}{Undefined caption justification `#1'}{\caption@eh}}%
{\expandafter\let\expandafter\caption@hj\csname caption@hj@#1\endcsname}}
%\newcommand\caption@setjustification{\caption@setfont{@hj}}
% \end{macrocode}
% \end{macro}
%
% These are the pre-defined justification code snippets.
%
% \begin{macrocode}
\DeclareCaptionJustification{justified}{}
\DeclareCaptionJustification{centering}{\centering}
\DeclareCaptionJustification{centerfirst}{\caption@centerfirst}
\DeclareCaptionJustification{centerlast}{\caption@centerlast}
\DeclareCaptionJustification{raggedleft}{\raggedleft}
\DeclareCaptionJustification{raggedright}{\raggedright}
% \end{macrocode}
%
% `default' usually maps to `justified'.
%
% \begin{macrocode}
\def\caption@hj@default{\caption@hj@justified}
% \end{macrocode}
%
% \begin{macro}{\caption@centerfirst}
% \begin{macro}{\caption@centerlast}
% Please blame Frank Mittelbach for |\caption@centerfirst| and
% Anne Br\"uggemann-Klein\cite{Anne} for |\caption@centerlast| |:-)|
% \begin{macrocode}
\newcommand\caption@centerfirst{%
\edef\caption@normaladjust{%
\leftskip\the\leftskip
\rightskip\the\rightskip
\parfillskip\the\parfillskip\relax}%
\leftskip\z@\@plus -1fil%
\rightskip\z@\@plus 1fil%
\parfillskip\z@skip
\noindent\hskip\z@\@plus 2fil%
\@setpar{\@@par\@restorepar\caption@normaladjust}}
\newcommand\caption@centerlast{%
\leftskip\z@\@plus 1fil%
\rightskip\z@\@plus -1fil%
\parfillskip\z@\@plus 2fil\relax}
% \end{macrocode}
% \end{macro}
% \end{macro}
%
% \changes{v3.0b}{2004/05/16}{Improved \package{ragged2e} package support}
% We also support the upper-case commands offered by the \package{ragged2e}
% package.
% Note that these just map to their lower-case variants if the
% \package{ragged2e} package is not available.
% \begin{macrocode}
\DeclareCaptionJustification{Centering}{%
\caption@ragged\Centering\centering}
\DeclareCaptionJustification{RaggedLeft}{%
\caption@ragged\RaggedLeft\raggedleft}
\DeclareCaptionJustification{RaggedRight}{%
\caption@ragged\RaggedRight\raggedright}
% \end{macrocode}
%
% \begin{macro}{\caption@ragged}
% |\caption@ragged| will be basically defined as\par
% |\AtBeginDocument{\IfFileExists{ragged2e.sty}%|\\
% | {\RequirePackage{ragged2e}\let\caption@ragged\@firstoftwo}%|\\
% | {\let\caption@ragged\@secondoftwo}}|\par
% but with an additional warning if the ragged2e package is not avail.
% (This warning will be typeout only one time per option, that's why
% we need the |caption\string#1| stuff.)
% \begin{macrocode}
\newcommand*\caption@ragged[2]{%
\@ifundefined{caption\string#1}{%
\PackageWarning{caption}{%
Cannot locate the `ragged2e' package, therefore\MessageBreak
substituting \string#2 for \string#1\MessageBreak}%
\global\@namedef{caption\string#1}}{}%
#2}
% \end{macrocode}
% \begin{macrocode}
\AtBeginDocument{\IfFileExists{ragged2e.sty}{%
\RequirePackage{ragged2e}\let\caption@ragged\@firstoftwo}{}}
% \end{macrocode}
% \end{macro}
%
% \subsubsection*{Fonts}
%
% \begin{macro}{\DeclareCaptionFont}
% \changes{v3.0a}{2004/01/22}{Bugfix: Multi token arguments are allowed now}
% |\DeclareCaptionFont|\marg{name}\marg{code}
% \begin{macrocode}
\newcommand\DeclareCaptionFont[2]{%
\define@key{caption@fnt}{#1}[]{\g@addto@macro\caption@tempa{#2}}}
\@onlypreamble\DeclareCaptionFont
% \end{macrocode}
% \end{macro}
%
% \begin{macrocode}
\DeclareCaptionOption{font}{\caption@setfont{font}{#1}}
\DeclareCaptionOption{labelfont}{\caption@setfont{labelfont}{#1}}
\DeclareCaptionOption{textfont}{\caption@setfont{textfont}{#1}}
% \end{macrocode}
%
% \begin{macro}{\caption@setfont}
% |\caption@setfont|\marg{name}\marg{keyval-list of names}\par
% Selecting a caption font means saving all the code snippets
% (in |\caption#1|).
% Because we use |\setkeys| recursive here we need to do this inside an
% extra group and collect all the code snippets in |\caption@tempa| first.
% \begin{macrocode}
\newcommand*\caption@setfont[2]{%
\let\caption@tempa\@empty
\begingroup
% \define@key{caption@fnt}{default}[]{%
% \global\expandafter\let\expandafter\caption@tempa
% \csname caption#1@default\endcsname}%
\caption@setkeys{caption@fnt}{#2}%
\endgroup
\expandafter\let\csname caption#1\endcsname\caption@tempa}
% \end{macrocode}
% \end{macro}
%
% \begin{macrocode}
\DeclareCaptionFont{default}{}
% \end{macrocode}
%
% These are the pre-defined font code snippets.
%
% \begin{macrocode}
\DeclareCaptionFont{scriptsize}{\scriptsize}
\DeclareCaptionFont{footnotesize}{\footnotesize}
\DeclareCaptionFont{small}{\small}
\DeclareCaptionFont{normalsize}{\normalsize}
\DeclareCaptionFont{large}{\large}
\DeclareCaptionFont{Large}{\Large}
% \end{macrocode}
%
% \begin{macrocode}
\DeclareCaptionFont{up}{\upshape}
\DeclareCaptionFont{it}{\itshape}
\DeclareCaptionFont{sl}{\slshape}
\DeclareCaptionFont{sc}{\scshape}
\DeclareCaptionFont{md}{\mdseries}
\DeclareCaptionFont{bf}{\bfseries}
\DeclareCaptionFont{rm}{\rmfamily}
\DeclareCaptionFont{sf}{\sffamily}
\DeclareCaptionFont{tt}{\ttfamily}
% \end{macrocode}
%
% \begin{macro}{\captionsize}
% \changes{v3.0a}{2004/01/23}{Implementation changed from \cs{captionfont} to \cs{@empty}}
% \changes{v3.0c}{2004/07/16}{Use \cs{providecommand} instead of \cs{newcommand} in respect of the memoir class}
% The old versions \version{1.x} of the \package{caption} package offered this
% command to setup the font size used for captions. We still do
% so old documents will work fine.
% \begin{macrocode}
\providecommand\captionsize{}
% \end{macrocode}
% \end{macro}
%
% \changes{v3.0a}{2004/01/23}{Option \opt{size=} now sets \cs{captionsize} instead of \cs{captionfont}}
% \begin{macrocode}
\DeclareCaptionOption{size}{\caption@setfont{size}{#1}}
% \end{macrocode}
%
% \subsubsection*{Vertical spaces before and after captions}
%
% \begin{macro}{\abovecaptionskip}
% \begin{macro}{\belowcaptionskip}
% Usually these skips are defined within the document class, but some
% document classes don't do so.
% \begin{macrocode}
\@ifundefined{abovecaptionskip}{%
\newlength\abovecaptionskip\setlength\abovecaptionskip{10\p@}}{}
\@ifundefined{belowcaptionskip}{%
\newlength\belowcaptionskip\setlength\belowcaptionskip{0\p@}}{}
% \end{macrocode}
% \end{macro}
% \end{macro}
%
% \changes{v3.0d}{2005/02/12}{Option \opt{skip=} added}
% \begin{macrocode}
\DeclareCaptionOption{aboveskip}{\setlength\abovecaptionskip{#1}}
\DeclareCaptionOption{belowskip}{\setlength\belowcaptionskip{#1}}
\DeclareCaptionOption{skip}{\setlength\abovecaptionskip{#1}}
% \end{macrocode}
%
% \subsubsection*{Positioning}
%
% These macros handle the right position of the caption.
% Note that the position is actually \emph{not} controlled by the
% \package{caption} kernel options, but by the user (or a specific package
% like the \package{float} package) instead.
% The user can put the |\caption| command wherever he likes! So this stuff
% is only to give us a \emph{hint} where to put the right skips, the user
% usually has to take care for himself that this hint actually matches the
% right position.
% The user can also try out the experimental setting |position=auto| which
% means that the \package{caption} package should try to guess the actual
% position of the caption for himself. (But in many cases, for example in
% |longtable|s, this is doomed to fail, so it's not documented in the
% user part of the documentation.)
%
% \begin{macrocode}
\DeclareCaptionOption{position}{\caption@setposition{#1}}
% \end{macrocode}
%
% \begin{macro}{\caption@setposition}
% \changes{v3.0a}{2004/01/22}{Now the positions \opt{t}, \opt{above}, \opt{b},
% \opt{below}, and \opt{a} are allowed, too}
% \changes{v3.0d}{2004/08/10}{Usage of \cs{caption@defaultpos} added}
% |\caption@setposition|\marg{position}\par
% Selecting the caption position means that we put |\caption@position| to
% the right value. \emph{Please do \textbf{not} use the internal macro
% \cs{caption@position} in your own package or document, but use the wrapper
% macro \cs{caption@iftop} instead.}
% \begin{macrocode}
\newcommand*\caption@setposition[1]{%
\caption@ifinlist{#1}{d,default}{%
\def\caption@position{\caption@defaultpos}%
}{\caption@ifinlist{#1}{t,top,above}{%
\let\caption@position\@firstoftwo
}{\caption@ifinlist{#1}{b,bottom,below}{%
\let\caption@position\@secondoftwo
}{\caption@ifinlist{#1}{a,auto}{%
\let\caption@position\@undefined
}{%
\PackageError{caption}{Undefined caption position `#1'}{\caption@eh}%
}}}}}
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\caption@defaultpos}
% The default `position' is usually `bottom', this means that the (larger)
% skip will be typeset above the caption.
% This correspondents to the |\@makecaption| implementation in the standard
% \LaTeX\ document classes.
% \begin{macrocode}
%\caption@setdefaultpos{b}% default = bottom
\let\caption@defaultpos\@secondoftwo
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\caption@iftop}
% \changes{v3.0a}{2004/01/23}{Split into \cs{caption@iftop} \& \cs{caption@fixposition}}
% \changes{v3.0d}{2005/02/12}{Adapted to \cs{caption@defaultpos}}
% |\caption@iftop|\marg{true-code}\marg{false-code}\par
% (If the |position=| is set to |auto| we assume a |bottom| position.)
% \begin{macrocode}
\newcommand\caption@iftop{%
\ifx\caption@position\@undefined
\expandafter\@secondoftwo
\else
\expandafter\caption@position
\fi}
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\caption@fixposition}
% \changes{v3.0b}{2004/05/16}{Split into \cs{caption@fixposition} & \cs{caption@autoposition}}
% |\caption@fixposition|\par
% This macro checks if the `position' is set to `auto'.
% If yes, |\caption@autoposition| will be called to
% set |\caption@position| to a proper value we can actually use.
% \begin{macrocode}
\newcommand\caption@fixposition{%
\ifx\caption@position\@undefined
\caption@autoposition
\fi}
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\caption@autoposition}
% \changes{v3.0a}{2004/01/23}{\cs{ifvmode} added}
% |\caption@autoposition|\par
% We guess the actual position of the caption by checking |\prevdepth|.
% \begin{macrocode}
\newcommand\caption@autoposition{%
\ifvmode
%<+debug> \edef\caption@tempa{\the\prevdepth}%
%<+debug> \PackageInfo{caption}{\protect\prevdepth=\caption@tempa}%
% \caption@setposition{\ifdim\prevdepth>-\p@ b\else t\fi}%
\ifdim\prevdepth>-\p@
\let\caption@position\@secondoftwo
\else
\let\caption@position\@firstoftwo
\fi
\else
%<+debug> \PackageInfo{caption}{no \protect\prevdepth}%
% \caption@setposition{b}%
\let\caption@position\@secondoftwo
\fi}
% \end{macrocode}
% \end{macro}
%
% \subsubsection*{Hooks}
%
% \begin{macro}{\AtBeginCaption}
% \begin{macro}{\AtEndCaption}
% |\AtBeginCaption| \marg{code}\\
% |\AtEndCaption| \marg{code}\par
% These hooks can be used analogous to |\AtBeginDocument| and |\AtEndDocument|.
% \begin{macrocode}
\newcommand\caption@beginhook{}
\newcommand\caption@endhook{}
\newcommand\AtBeginCaption{\l@addto@macro\caption@beginhook}
\newcommand\AtEndCaption{\l@addto@macro\caption@endhook}
% \end{macrocode}
% \end{macro}
% \end{macro}
%
% \subsubsection*{Miscellaneous options}
%
% \changes{v3.0b}{2004/05/16}{Option \opt{listof=} added}
% \changes{v3.0d}{2005/02/12}{Option \opt{strut=} added}
% \begin{macrocode}
\DeclareCaptionOption{listof}{\caption@setbool{lof}{#1}}
\DeclareCaptionOption{singlelinecheck}{\caption@setbool{slc}{#1}}
\DeclareCaptionOption{strut}{\caption@setbool{strut}{#1}}
% \end{macrocode}
%
% \subsubsection*{Debug options}
% {\small Please note that these options are usually not available.}
%
% \begin{macrocode}
%<+debug>\DeclareCaptionOption{showposition}{\caption@setbool{showpos}{#1}}
%<+debug>\captionsetup{showposition=0}
% \end{macrocode}
%
% \subsubsection*{Initialization of parameters}
%
% \begin{macrocode}
\captionsetup{style=default,position=default,listof=1}
% \end{macrocode}
%
% \begin{macro}{\ifcaption@star}
% If the starred form of |\caption| is used, this will be set to |true|.
% (It will be reset to |false| at the end of |\caption@@make|.)
% \begin{macrocode}
\newif\ifcaption@star
% \end{macrocode}
% \end{macro}
%
% \subsubsection*{Typesetting the caption}
%
% \begin{macro}{\caption@make}
% |\caption@make|\marg{float name}\marg{ref.\ number}\marg{text}
% \begin{macrocode}
\newcommand\caption@make[2]{%
\caption@@make{\caption@lfmt{#1}{#2}}}
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\caption@@make}
% \changes{v3.0b}{2004/05/16}{Bugfix 04-05-05: \cs{ifdim}\cs{captionindent=}\cs{z@} added}
% \changes{v3.0d}{2005/02/12}{Bugfix 04-10-26: Use \cs{@tempdima} instead of \cs{captionmargin} resp. \cs{captionwidth};
% check for \cs{z@} added}
% \changes{v3.0d}{2005/02/12}{Bugfix: \cs{hskip}\cs{captionmargin} to the end of caption added}
% \changes{v3.0d}{2005/02/12}{Bugfix: \cs{strut} moved from here to \cs{caption@@@make}}
% \changes{v3.0d}{2005/02/12}{Single-line-check moved up so it can affect margins now}
% \changes{v3.0d}{2005/02/09}{Improvement: \cs{caption@ifh} added}
% \changes{v3.0d}{2005/02/09}{Bugfix: \cs{leavevmode} added}
% \changes{v3.0h}{2005/08/24}{Uses \cs{sbox} instead of \cs{setbox} in single-line-check}
% \changes{v3.0i}{2005/12/04}{Uses \cs{caption@slc}}
% \changes{v3.0i}{2006/01/11}{Bugfix: \cs{caption@calcmargin} inside single-line-check replaced by \cs{relax}}
% \changes{v3.0i}{2006/01/11}{Bugfix: \cs{caption@startbox} will always be typeset in horizontal mode}
% |\caption@@make|\marg{caption label}\marg{caption text}
% \begin{macrocode}
\newcommand\caption@@make[2]{%
\begingroup
\caption@beginhook
\caption@calcmargin
% \end{macrocode}
%
% Special single-line treatment (option |singlelinecheck=|)
%
% \begin{macrocode}
\caption@ifslc{\ifx\caption@sls\@empty\else
\caption@slc{#1}{#2}\captionwidth\relax
\fi}{}%
% \end{macrocode}
%
% Typeset the left margin (option |margin=|)
%
% \begin{macrocode}
\@tempdima\captionmargin
\caption@ifh{\advance\@tempdima by \captionindent}%
\hskip\@tempdima
% \end{macrocode}
%
% We actually use a |\vbox| of width |\captionwidth - \captionindent|
% to typeset the caption
% (Note: |\captionindent| is \emph{not} supported if the caption format
% was defined with |\DeclareCaptionFormat*|.)
%
% \begin{macrocode}
\@tempdima\captionwidth
\caption@ifh{\advance\@tempdima by -\captionindent}%
\caption@startbox\@tempdima
% \end{macrocode}
%
% Typeset the indention (option |indention=|)
%
% \begin{macrocode}
\caption@ifh{%
% \ifdim\captionindent=\z@
% \leavevmode
% \else
\hskip-\captionindent}%
% \fi}%
% \end{macrocode}
%
% Typeset the caption itself
%
% \begin{macrocode}
\caption@@@make{#1}{#2}%
% \end{macrocode}
%
% \begin{macrocode}
\caption@endbox
% \end{macrocode}
%
% Typeset the right margin (option |margin=|)
%
% \begin{macrocode}
\@tempdima\captionmargin
\advance\@tempdima by \captionmarginx
\hskip\@tempdima
% \end{macrocode}
%
% \begin{macrocode}
\caption@endhook
\endgroup
% \end{macrocode}
%
% \begin{macrocode}
\global\caption@starfalse}
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\caption@calcmargin}
% Calculate |\captionmargin| \& |\captionwidth|, so both contain valid
% values.
% \changes{v3.0h}{2005/10/24}{Internal: \cs{ifcaption@width} replaced by \cs{ifdim}\cs{captionwidth=}\cs{z@}}
% \changes{v3.0i}{2006/01/12}{Improvement: Takes care of list environment now}
% \begin{macrocode}
\newcommand\caption@calcmargin{%
% \end{macrocode}
% \emph{Note:} Inside a |list| environment |\linewidth| do not contain
% the proper value, because |\@caption| calls |\@parboxrestore| which
% resets |\linewidth| to |\hsize|. Therefore we have to calculate the
% proper line width on our own in this case.
% \begin{macrocode}
\@tempdima\hsize
\ifnum\@listdepth>0\relax
\advance\@tempdima by -\leftmargin
\advance\@tempdima by -\rightmargin
\fi
% \end{macrocode}
% \begin{macrocode}
\ifdim\captionwidth=\z@
\captionwidth\@tempdima
\advance\captionwidth by -2\captionmargin
\advance\captionwidth by -\captionmarginx
\else
\captionmargin\@tempdima
\advance\captionmargin by -\captionwidth
\divide\captionmargin by 2
\captionmarginx\z@
\fi
% \end{macrocode}
% \begin{macrocode}
%<+debug> \PackageInfo{caption}{%
%<+debug> \protect\hsize=\the\hsize,
%<+debug> \protect\margin=\the\captionmargin,
%<+debug> \protect\marginx=\the\captionmarginx,
%<+debug> \protect\width=\the\captionwidth}%
% \end{macrocode}
% \begin{macrocode}
}
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\caption@slc}
% This one does the single-line-check.
% \begin{macrocode}
\newcommand\caption@slc[4]{%
\caption@startslc
\sbox\@tempboxa{\caption@@@make{#1}{#2}}%
\ifdim\wd\@tempboxa >#3%
\caption@endslc
\else
\caption@endslc
\caption@esetup\caption@sls
#4%
\fi}
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\caption@startslc}
% \changes{v3.0b}{2004/05/16}{Bugfix: Redefinition of \cs{label} \& \cs{@footnotetext} added}
% \changes{v3.0b}{2004/05/16}{Redefine \cs{stepcounter} instead of \cs{footnote(mark)}}
% \changes{v3.0d}{2005/02/12}{\cs{let}\cs{caption@hj}\cs{relax} added}
% \changes{v3.0h}{2005/07/09}{Support of \package{endnotes} package added}
% Re-define anything which would disturb the single-line-check.
% \begin{macrocode}
\newcommand\caption@startslc{%
\begingroup
\let\label\@gobble
\let\@footnotetext\@gobble\let\@endnotetext\@gobble
\def\stepcounter##1{\advance\csname c@##1\endcsname\@ne\relax}%
\let\caption@hj\relax}
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\caption@endslc}
% This ends the single-line-check.
% \begin{macrocode}
\newcommand\caption@endslc{%
\endgroup}
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\caption@startbox}
% \begin{macro}{\caption@endbox}
% These macros start and end the box which surrounds the caption paragraph.
% \begin{macrocode}
\newcommand*\caption@startbox[1]{\vbox\bgroup\hsize#1}%
%\newcommand*\caption@startbox[1]{\vbox\bgroup\setlength\hsize{#1}\@parboxrestore}%
\newcommand*\caption@endbox{\egroup}
%\newcommand*\caption@endbox{\@finalstrut\strutbox\@@par\egroup}
% \end{macrocode}
% \end{macro}
% \end{macro}
%
% \begin{macro}{\caption@@@make}
% \changes{v3.0b}{2004/05/16}{Bugfix 04-05-06: \cs{allowhyphens} added}
% \changes{v3.0d}{2005/02/12}{Bugfix 04-12-16: Use some kind of \cs{@startstrut}\cs{strutbox} instead of \cs{strut}}
% \changes{v3.0d}{2005/02/12}{Bugfix 05-01-23: \cs{@finalstrut}\cs{strutbox} added}
% \changes{v3.0e}{2005/05/05}{Use \cs{caption@ifempty}; \cs{let}\cs{caption@ifstrut}\cs{@secondoftwo} added}
% \changes{v3.0e}{2005/05/05}{Bugfix: Handling of \cs{ifcaption@star} changed}
% \changes{v3.0h}{2005/08/24}{Check for empty label added}
% \changes{v3.0h}{2005/08/25}{\cs{caption@iflf} added}
% |\caption@@@make|\marg{caption label}\marg{caption text}\par
% This one finally typesets the caption paragraph, without margin and indention.
% \begin{macrocode}
\newcommand\caption@@@make[2]{%
% \end{macrocode}
%
% If the label is empty, we use no caption label separator.
%
% \begin{macrocode}
\sbox\@tempboxa{#1}%
\ifdim\wd\@tempboxa=\z@
\let\caption@lsep\relax
\fi
% \end{macrocode}
%
% If the text is empty, we use no caption label separator, too.\par
% \emph{Note:} Unfortunately this only works under certain circumstances.
% Therefore an additional check inside |\@caption| will be introduced
% in the upcoming version \version{3.1} of the caption package.
%
% \begin{macrocode}
\caption@ifempty{#2}{%
\let\caption@lsep\relax
% \let\caption@ifstrut\@secondoftwo
}%
% \end{macrocode}
%
% Take care that |\captionparindent| and |\captionhangindent| will be used
% to typeset the paragraph.
%
% \begin{macrocode}
\@setpar{\@@par\caption@@par}\caption@@par
% \end{macrocode}
%
% Finally the caption will be typeset.
%
% \begin{macrocode}
\caption@hj\captionsize\captionfont\caption@fmt
{\ifcaption@star\else{\captionlabelfont#1}\fi}%
{\ifcaption@star\else{\caption@iflf\captionlabelfont\caption@lsep}\fi}%
{{\captiontextfont
\caption@ifstrut{\vrule\@height\ht\strutbox\@width\z@}{}%
\nobreak\hskip\z@skip
#2%
% \caption@ifstrut{\vrule\@height\z@\@depth\dp\strutbox\@width\z@}{}%
\caption@ifstrut{\@finalstrut\strutbox}{}%
\par}}}
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\caption@ifempty}
% \changes{v3.0e}{2005/05/05}{This macro added}
% |\caption@ifempty|\marg{text}\marg{if-clause}\par
% This one tests if the \meta{text} is actually empty.\par
% \emph{Note:} This will be done without expanding the text, therefore this
% is far away from being bullet-proof.
% \begin{macrocode}
\newcommand\caption@ifempty[1]{%
\def\caption@tempa{#1}%
\def\caption@tempb{\ignorespaces}%
\ifx\caption@tempa\caption@tempb
\let\caption@tempa\@empty
\fi
\ifx\caption@tempa\@empty
\expandafter\@firstofone
\else
\expandafter\@gobble
\fi}
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\caption@@par}
% \changes{v3.0h}{2005/08/22}{Made this definition global}
% |\caption@@par|\par
% This command will be executed with every |\par| inside the caption.
% \begin{macrocode}
\newcommand*\caption@@par{%
\parindent\captionparindent\hangindent\captionhangindent}%
% \end{macrocode}
% \end{macro}
%
% \iffalse
%</kernel>
% \fi
%
% \iffalse
% --------------------------------------------------------------------------- %
% \fi
%
% \subsection{Main package}
% \iffalse
%<*package>
% \fi
%
% \subsubsection*{Identification}
%
% \begin{macrocode}
\NeedsTeXFormat{LaTeX2e}[1994/12/01]
\ProvidesPackage{caption}[2006/03/21 v3.0j Customising captions (AR)]
%<+debug>\PackageWarning{caption}{DEBUG VERSION}
% \end{macrocode}
%
% \subsubsection*{Loading the caption kernel}
%
% \begin{macrocode}
\RequirePackage{caption3}[2006/01/12] % needs v3.0i or newer
% \end{macrocode}
%
% \subsubsection*{Option for configuration files}
%
% \begin{macrocode}
\DeclareCaptionOption{config}[caption]{%
\InputIfFileExists{#1.cfg}{\typeout{*** Local configuration file
#1.cfg used ***}}%
{\PackageWarning{caption}{Configuration
file #1.cfg not found}}}
% \end{macrocode}
%
% \subsubsection*{Options for |figure| and |table|}
%
% \changes{v3.0a}{2004/01/09}{Options \opt{figureposition} and \opt{tableposition} added}
% \begin{macrocode}
\DeclareCaptionOption*{figureposition}{\captionsetup[figure]{position=#1}}
\DeclareCaptionOption*{tableposition}{\captionsetup[table]{position=#1}}
% \end{macrocode}
%
% \subsubsection*{caption \version{1.x} compatibility options}
%
% \begin{macrocode}
\DeclareCaptionOption*{normal}[]{\caption@setformat{normal}}
\DeclareCaptionOption*{isu}[]{\caption@setformat{hang}}
\DeclareCaptionOption*{hang}[]{\caption@setformat{hang}}
\DeclareCaptionOption*{center}[]{\caption@setjustification{centering}}
\DeclareCaptionOption*{anne}[]{\caption@setjustification{centerlast}}
\DeclareCaptionOption*{centerlast}[]{\caption@setjustification{centerlast}}
% \end{macrocode}
%
% \begin{macrocode}
\DeclareCaptionOption*{scriptsize}[]{\def\captionfont{\scriptsize}}
\DeclareCaptionOption*{footnotesize}[]{\def\captionfont{\footnotesize}}
\DeclareCaptionOption*{small}[]{\def\captionfont{\small}}
\DeclareCaptionOption*{normalsize}[]{\def\captionfont{\normalsize}}
\DeclareCaptionOption*{large}[]{\def\captionfont{\large}}
\DeclareCaptionOption*{Large}[]{\def\captionfont{\Large}}
% \end{macrocode}
%
% \begin{macrocode}
\DeclareCaptionOption*{up}[]{\l@addto@macro\captionlabelfont\upshape}
\DeclareCaptionOption*{it}[]{\l@addto@macro\captionlabelfont\itshape}
\DeclareCaptionOption*{sl}[]{\l@addto@macro\captionlabelfont\slshape}
\DeclareCaptionOption*{sc}[]{\l@addto@macro\captionlabelfont\scshape}
\DeclareCaptionOption*{md}[]{\l@addto@macro\captionlabelfont\mdseries}
\DeclareCaptionOption*{bf}[]{\l@addto@macro\captionlabelfont\bfseries}
\DeclareCaptionOption*{rm}[]{\l@addto@macro\captionlabelfont\rmfamily}
\DeclareCaptionOption*{sf}[]{\l@addto@macro\captionlabelfont\sffamily}
\DeclareCaptionOption*{tt}[]{\l@addto@macro\captionlabelfont\ttfamily}
% \end{macrocode}
%
% \begin{macrocode}
\DeclareCaptionOption*{nooneline}[]{\caption@setbool{slc}{0}}
% \end{macrocode}
%
% \begin{macrocode}
\caption@setbool{ruled}{0}
\DeclareCaptionOption*{ruled}[]{\caption@setbool{ruled}{1}}
% \end{macrocode}
%
% \subsubsection*{Some caption2 \version{2.x} compatibility options}
% \changes{v3.0h}{2005/07/08}{caption2 \version{2.x} compatibility options added}
%
% \begin{macrocode}
\DeclareCaptionOption*{flushleft}[]{\caption@setjustification{raggedright}}
\DeclareCaptionOption*{flushright}[]{\caption@setjustification{raggedleft}}
\DeclareCaptionOption*{oneline}[]{\caption@setbool{slc}{1}}
\DeclareCaptionOption*{ignoreLTcapwidth}[]{}
% \end{macrocode}
%
% \subsubsection*{Some \KOMAScript\ compatibility stuff}
% \changes{v3.0h}{2005/08/22}{\KOMAScript\ compatibility options added}
% \changes{v3.0i}{2005/11/17}{\KOMAScript\ compatibility commands added}
%
% \begin{macrocode}
\@ifundefined{scr@caption}{}{%
% \end{macrocode}
%
% \begin{macrocode}
\DeclareCaptionOption*{onelinecaption}[]{\onelinecaptionstrue}
\DeclareCaptionOption*{noonelinecaption}[]{\onelinecaptionsfalse}
\DeclareCaptionOption*{tablecaptionabove}[]{\captionsetup[table]{position=t}}
\DeclareCaptionOption*{tablecaptionbelow}[]{\captionsetup[table]{position=b}}
% \end{macrocode}
%
% \begin{macro}{\onelinecaptionsfalse}
% \begin{macro}{\onelinecaptionstrue}
% \begin{macrocode}
\def\onelinecaptionstrue{\caption@setbool{slc}{1}}
\def\onelinecaptionsfalse{\caption@setbool{slc}{0}}
% \end{macrocode}
% \end{macro}
% \end{macro}
%
% \begin{macro}{\captionabove}
% \begin{macro}{\captionbelow}
% \changes{v3.0j}{2006/03/21}{Bugfix 06-03-21: \cs{let}\cs{caption@setposition}\cs{@gobble} added}
% Original code:
% \begin{verbatim}
% \newcommand{\captionabove}{\@captionabovetrue\scr@caption}
% \newcommand{\captionbelow}{\@captionabovefalse\scr@caption}
% \end{verbatim}
% \begin{macrocode}
\def\captionabove{%
\caption@setposition{t}\let\caption@setposition\@gobble
\scr@caption}
\def\captionbelow{%
\caption@setposition{b}\let\caption@setposition\@gobble
\scr@caption}
% \end{macrocode}
% \end{macro}
% \end{macro}
%
% \iffalse % Not very useful...
% \begin{macro}{\setcapindent}
% \begin{macrocode}
% \def\setcapindent{\@ifstar{\@@setcapindent}{\@setcapindent}}
% \def\@setcapindent#1{%
% \caption@setformat{plain}\setlength\captionindent{#1}}
% \def\@@setcapindent#1{%
% \PackageError{caption}{\string\setcapindent* is not supported yet}{\caption@eh}}
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\setcaphanging}
% \begin{macrocode}
% \def\setcaphanging{%
% \caption@setformat{hang}\setlength\captionindent\@z}
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\setcapwidth}
% \begin{macrocode}
% \renewcommand*\setcapwidth[2][]{%
% \PackageWarning{caption}{%
% Ignoring optional argument of \string\setcapwidth!\MessageBreak
% You're using package caption.\MessageBreak}%
% \setcaptionwidth{#2}}
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\setcapmargin}
% \begin{macrocode}
% \renewcommand*\setcapmargin{\@ifstar\@setcapmargin\@@setcapmargin}
% \renewcommand*\@setcapmargin[2][\@tempdimb]{%
% \setlength\@tempdimb{#2}%
% \setlength\@tempdima{#1}%
% \setcaptionmargin{\@tempdima,\@tempdimb}}
% \renewcommand*\@@setcapmargin[2][\@tempdimb]{%
% \PackageError{caption}{\string\setcapmargin* is not supported yet}{\caption@eh}}
% \end{macrocode}
% \end{macro}
% \fi
%
% \begin{macrocode}
}
% \end{macrocode}
%
% \subsubsection*{Generic package support}
%
% \begin{macro}{\caption@declarepackage}
% |\caption@declarepackage|\marg{package name}\par
% Each single package support can be switched on or off by using the
% appropriate option. By default all of them are enabled.
% \begin{macrocode}
\newcommand*\caption@declarepackage[1]{%
\caption@setbool{pkt@#1}{1}%
\DeclareCaptionOption*{#1}{\caption@setbool{pkt@#1}{##1}}}
\AtEndOfPackage{\let\caption@declarepackage\@undefined}
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\caption@ifpackage}
% \changes{v3.0f}{2005/05/29}{3rd argument \meta{code} added, so no extra check is needed}
% |\caption@ifpackage|\marg{package name}\marg{package macro}\marg{code}\par
% If a certain package support is requested the appropriate code will
% be used. `Requested' means that the option belonging to it is set to
% |true| and the macro called \meta{package macro} is defined.
% (If \meta{package macro} is not yet defined we use |\AtBeginDocument|
% here, so the package could be loaded after this package, too.)
% \begin{macrocode}
\newcommand\caption@ifpackage[3]{%
% \end{macrocode}
% \begin{macrocode}
%<+debug> \edef\caption@tempa{%
%<+debug> \caption@ifbool{pkt@#1}%
%<+debug> {\@ifundefined{#2}{AtBeginDocument}{firstofone}}%
%<+debug> {gobble}}%
%<+debug> \PackageInfo{caption}{#1 = \caption@ifbool{pkt@#1}{1}{0} %
%<+debug> (\@ifundefined{#2}{not }{}loaded -> \caption@tempa)}%
% \end{macrocode}
% \begin{macrocode}
\caption@ifbool{pkt@#1}{%
\@ifundefined{#2}%
{\let\caption@tempa\AtBeginDocument}%
{\let\caption@tempa\@firstofone}%
}{%
\let\caption@tempa\@gobble
}%
\caption@tempa{\@ifundefined{#2}{}{#3}}%
% \end{macrocode}
%
% \begin{macrocode}
\caption@undefbool{pkt@#1}}
\AtEndOfPackage{\let\caption@ifpackage\@undefined}
% \end{macrocode}
% \end{macro}
%
% You can also switch the caption support off using the package option
% |caption=false|.
% This may look strange, but there are certain circumstances where this could
% be useful.
% Such a situation might be the usage of the \package{subfig} package without
% disturbing the main caption code of the document class.\par
% \emph{Note: This mechanism is obsolete now, it has been superseeded by the
% \package{subfig} package option {\rm|caption=false|} which causes that only the
% caption kernel \package{caption3} is loaded.}
%
% \begin{macrocode}
\caption@declarepackage{caption}
% \end{macrocode}
%
% These are the packages we support:
%
% \begin{macrocode}
\caption@declarepackage{float}
\caption@declarepackage{floatrow}
\caption@declarepackage{hyperref}
\caption@declarepackage{hypcap}
\caption@declarepackage{listings}
\caption@declarepackage{longtable}
\caption@declarepackage{picins}
\caption@declarepackage{rotating}
\caption@declarepackage{sidecap}
\caption@declarepackage{supertabular}
% \end{macrocode}
%
% \begin{macro}{\ProcessOptionsWithKV}
% \changes{v3.0a}{2004/01/23}{Bugfix, see \purett{news:400D360C.9678329F@gmx.net} for details}
% \changes{v3.0i}{2006/01/03}{Improvement, uses \cs{caption@setkeys} instead of \cs{setkeys}}
% \changes{v3.0j}{2006/02/23}{Bugfix, now processes only those global options which have a default value}
% We process our options using the keyval package, so we use this one
% instead of |\ProcessOptions| offered by \LaTeXe.
% (This code was taken from the \package{hyperref} package.)
% \begin{macrocode}
\def\ProcessOptionsWithKV#1{%
\let\@tempc\relax
% \end{macrocode}
%
% \begin{macrocode}
\let\caption@tempa\@empty
\@for\CurrentOption:=\@classoptionslist\do{%
\@ifundefined{KV@#1@\CurrentOption}{%
}{%
\@ifundefined{KV@#1@\CurrentOption @default}{%
\PackageInfo{#1}{Global option `\CurrentOption' ignored}%
}{%
\PackageInfo{#1}{Global option `\CurrentOption' processed}%
\edef\caption@tempa{\caption@tempa,\CurrentOption,}%
\@expandtwoargs\@removeelement\CurrentOption
\@unusedoptionlist\@unusedoptionlist
}%
}%
}%
\edef\caption@tempa{%
\noexpand\caption@setkeys{#1}{%
\caption@tempa\@ptionlist{\@currname.\@currext}%
}%
}%
\caption@tempa
% \end{macrocode}
%
% \begin{macrocode}
\let\CurrentOption\@empty
\AtEndOfPackage{\let\@unprocessedoptions\relax}}
% \end{macrocode}
% \end{macro}
%
% \begin{macrocode}
\ProcessOptionsWithKV{caption}
% \end{macrocode}
%
% If the option |caption=false| was given we stop processing this file
% immediately.
% \begin{macrocode}
\caption@ifbool{pkt@caption}{}{\endinput}
\caption@undefbool{pkt@caption}
% \end{macrocode}
%
% \subsubsection*{Useful stuff}
%
% \begin{macro}{\captionof}
% |\captionof|(|*|)\marg{type}\oarg{lst\_entry}\marg{heading}
% \begin{macrocode}
\def\captionof{\@ifstar{\caption@of{\caption*}}{\caption@of\caption}}
\newcommand*\caption@of[2]{\def\@captype{#2}#1}
% \end{macrocode}
% \end{macro}
%
% Note: Like |\captionof| the option |type=| should only be used inside a
% group or environment and does not check if the argument is a valid
% floating environment or not.
%
% \changes{v3.0d}{2005/11/28}{Option \opt{type=} added}
% \begin{macrocode}
\DeclareCaptionOption{type}{\def\@captype{#1}}
% \end{macrocode}
%
% \begin{macro}{\ContinuedFloat}
% \changes{v3.0f}{2005/06/11}{Call of \cs{caption@ContinuedFloat} added}
% \changes{v3.0i}{2005/11/12}{Optional argument and call of \cs{caption@@ContinuedFloat} added}
% |\ContinuedFloat|\oarg{type}\par
% This mainly decreases the appropriate counter by $-1$.
% \begin{macrocode}
\providecommand\ContinuedFloat{%
\@ifnextchar[%]
\@ContinuedFloat
{\ifx\@captype\@undefined
\@latex@error{\noexpand\ContinuedFloat outside float}\@ehd
\else
\@ContinuedFloat[\@captype]%
\fi}}
\def\@ContinuedFloat[#1]{%
\addtocounter{#1}\m@ne
\caption@ContinuedFloat{#1}%
\caption@@ContinuedFloat{#1}}
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\caption@ContinuedFloat}
% \begin{macro}{\caption@resetContinuedFloat}
% |\caption@ContinuedFloat|\marg{type}\par
% |\caption@resetContinuedFloat|\marg{type}\par
% The first one will be called inside |\ContinuedFloat|, the second one
% inside |\caption|. Usually they do nothing but this changes if the
% \package{hyperref} package is loaded. (See \package{hyperref} package
% support for details.)
% \begin{macrocode}
\let\caption@ContinuedFloat\@gobble
\let\caption@resetContinuedFloat\@gobble
% \end{macrocode}
% \end{macro}
% \end{macro}
%
% \begin{macro}{\caption@@ContinuedFloat}
% This hook is for foreign packages which link themself into |\ContinuedFloat|,
% for example the \package{subfig} package\cite{subfig}.
% \begin{macrocode}
\providecommand*\caption@@ContinuedFloat[1]{}
% \end{macrocode}
% \end{macro}
%
% \subsubsection*{Internal helpers}
%
% \begin{macro}{\caption@begin}
% \changes{v3.0a}{2004/01/23}{\cs{caption@settype} changed by \cs{caption@setfloattype}}
% \changes{v3.0e}{2005/04/12}{Check for default label format added}
% \changes{v3.0f}{2005/06/11}{Call of \cs{caption@resetContinuedFloat} added}
% Our handling of |\caption| will always be surrounded by
% |\caption@begin| (or |\caption@beginex|) and |\caption@end|.\par
% |\caption@begin|\marg{type} performs these tasks:
% \begin{itemize}
% \item Call |\caption@resetContinuedFloat| (see above)
% and start a new group
% \item Execute the options set with |\captionsetup|\oarg{type}
% \item Define |\fnum@|\meta{type} if the caption label format is set
% to non-default
% \item Override the |position=| setting, if necessary
% (for example if set to |auto| or used inside a |supertabular|)
% \end{itemize}
% \begin{macrocode}
\newcommand*\caption@begin[1]{%
\caption@resetContinuedFloat{#1}%
\begingroup
% \end{macrocode}
% \begin{macrocode}
\caption@setfloattype{#1}%
% \end{macrocode}
%
% \begin{macrocode}
\ifx\caption@lfmt\caption@lfmt@default\else
\@namedef{fnum@#1}{%
\caption@lfmt{\caption@floatname{#1}}{\@nameuse{the#1}}}%
\fi
% \end{macrocode}
%
% \begin{macrocode}
\caption@fixposition
\global\let\caption@fixedposition\caption@position}
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\caption@beginex}
% \changes{v3.0b}{2004/05/16}{Support of \opt{listof=} added}
% \changes{v3.0h}{2005/09/16}{Bugfix: Made this macro and \cs{addcontentsline} \cs{long}}
% |\caption@beginex|\marg{type}\marg{list entry}\\
% performs the same tasks as |\caption@begin| and additionally:
% Redefine |\addcontentsline| if no list-of entry is requested, that
% means either the argument \meta{list entry} is empty or |listof=| was
% set to |false|.
% \begin{macrocode}
\newcommand\caption@beginex[2]{%
\caption@begin{#1}%
% \end{macrocode}
%
% \begin{macrocode}
\caption@iflof%
{\def\caption@tempa{#2}}%
{\let\caption@tempa\@empty}%
\ifx\caption@tempa\@empty
\long\def\addcontentsline##1##2##3{}%
\fi}
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\caption@end}
% |\caption@end| closes the group.
% \begin{macrocode}
\newcommand*\caption@end{%
\endgroup
% \end{macrocode}
%
% \begin{macrocode}
\let\caption@position\caption@fixedposition}
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\caption@setfloattype}
% \changes{v3.0a}{2004/01/23}{This macro added}
% |\caption@setfloattype|\marg{type}\\
% sets up the right float type within |\@caption|, |\LT@makecaption| etc.
% Usually this is equivalent to |\caption@settype| but I made it an own macro so
% I can extend it later on, for example if the \package{float} or
% \package{sidecap} package is loaded.
% \begin{macrocode}
\let\caption@setfloattype\caption@settype
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\caption@letfloattype}
% \changes{v3.0b}{2004/05/16}{This macro added}
% \changes{v3.0e}{2005/05/05}{Argument \meta{extra code} added}
% |\caption@letfloattype|\marg{type}\marg{extra code}\\
% redefines |\caption@setfloattype| so it does not only
% |\caption@settype|\marg{type} but two additional tasks:
% Executing extra code given as second argument and
% execute options with |\caption@settype{#1}| afterwards.\par
% You can find an example of its usage in the \package{longtable}
% support, where this macro is called so
% |\captionsetup[longtable]{|\ldots|}| can be used to setup options
% for longtables which have a higher priority than the options which
% have been setup with |\captionsetup[table]{|\ldots|}| or
% |\setlength\LTcapwidth{|\ldots|}|.
% \begin{macrocode}
\newcommand*\caption@letfloattype[2]{%
\def\caption@setfloattype##1{%
\caption@settype{##1}#2\caption@settype{#1}}}
% \end{macrocode}
% \end{macro}
%
% \changes{v3.0a}{2004/01/23}{Internal hooks \cs{caption@@begin} \& \cs{caption@@end} added}
% \changes{v3.0h}{2005/10/06}{Internal hooks \cs{caption@@begin} \& \cs{caption@@end} removed}
%
% \begin{macro}{\caption@floatname}
% |\caption@floatname|\marg{type}\par
% Usually all float names (which partly build the caption label)
% follow the same naming convention. But some packages (for example
% the \package{float} package) do not, so we use this wrapper macro which
% can be changed later on.
% \begin{macrocode}
\newcommand*\caption@floatname[1]{\@nameuse{#1name}}
% \end{macrocode}
% \end{macro}
%
% \subsubsection*{Caption support}
%
% \iffalse\begin{quote}
% \small\emph{Note:}
% Our aim is patching the existing |\caption| code so changes done by other
% packages will not get lost. We do similar in our \package{float},
% \package{hyperref}, and \package{hypcap} support so get the disadvantage
% of having ugly code with some negative side-effects, like the non-working
% |\caption{}| feature when the \package{french(le)} or \package{hyperref}
% package is loaded.
% \end{quote}\fi
%
% Some packages (like the \package{hyperref} package for example) redefines
% |\caption| and |\@caption|, too, but without chaining to their previous
% definitions. So we have to use |\AtBeginDocument| here, so we can make sure
% our definition don't get lost.
%
% \begin{macrocode}
\AtBeginDocument{%
% \end{macrocode}
%
% We only patch |\caption| and |\@caption| if the \package{captcont} package
% (which brings it's own definition of |\caption*|) is not used.
% It does not make much sense using the actual version of the \package{caption}
% package with the \package{captcont} package, but this was different in the
% old (\version{1.x}) days so we take care to be backward compatible.
%
% \begin{macrocode}
\@ifundefined{cc@caption}{%
% \end{macrocode}
%
% \begin{macro}{\caption}
% \iffalse\changes{v3.0}{2003/07/18}{Bugfix: \cs{global} added, so this works with sidecap}\fi
% \changes{v3.0f}{2005/05/22}{Bugfix: \cs{ContinuedFloat} added}
% \changes{v3.0f}{2005/06/13}{Support of \cs{caption*[]} removed}
% Here comes our definition of |\caption| and |\caption*|.
% (We set |\caption@startrue| globally so it works with the \package{sidecap} package, too.)
% \begin{macrocode}
\let\caption@old\caption
\def\caption{\caption@caption\caption@old}%
\def\caption@caption#1{%
\@ifstar{\ContinuedFloat\global\caption@startrue#1[]}{#1}}%
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\@caption}
% Our definition of |\@caption| simply calls the old definition,
% nested by |\caption@beginex| and |\caption@end|.
% \begin{macrocode}
\let\caption@@old\@caption
\long\def\@caption#1[#2]#3{%
\caption@beginex{#1}{#2}%
\caption@@old{#1}[{#2}]{#3}%
\caption@end}%
% \end{macrocode}
% \end{macro}
%
% \begin{macrocode}
}{%
% \end{macrocode}
%
% \changes{v3.0c}{2004/07/16}{Bugfix 04-07-15: \package{captcont} support fixed}
% Minimum \package{captcont} package support:\\
% We define |\caption@caption| here so it's there but does not make any harm.
%
% \begin{macrocode}
\PackageInfo{caption}{captcont package v2.0 detected}%
\def\caption@caption#1{#1}%
}%
}
% \end{macrocode}
%
% \begin{macro}{\@makecaption}
% |\@makecaption|\marg{label}\marg{text}\par
% The original code (from |latex/base/classes.dtx|):
% \begin{verbatim}
% \long\def\@makecaption#1#2{%
% \vskip\abovecaptionskip
% \sbox\@tempboxa{#1: #2}%
% \ifdim \wd\@tempboxa >\hsize
% #1: #2\par
% \else
% \global \@minipagefalse
% \hb@xt@\hsize{\hfil\box\@tempboxa\hfil}%
% \fi
% \vskip\belowcaptionskip}
% \end{verbatim}
% We do basically the same, but take care of the |position=| setting
% and use |\caption@@make| from the \package{caption} kernel to actually
% typeset the caption.
% \begin{macrocode}
\renewcommand\@makecaption[2]{%
\caption@iftop{\vskip\belowcaptionskip}{\vskip\abovecaptionskip}%
% \end{macrocode}
% \begin{macrocode}
%<+debug> \caption@ifbool{showpos}{%
%<+debug> \llap{$\caption@iftop\downarrow\uparrow$ }}{}%
% \end{macrocode}
% \begin{macrocode}
\caption@@make{#1}{#2}%
% \end{macrocode}
%
% \begin{macrocode}
\caption@iftop{\vskip\abovecaptionskip}{\vskip\belowcaptionskip}}
% \end{macrocode}
% \end{macro}
%
% \subsubsection*{\package{\KOMAScript} classes support}
% \changes{v3.0a}{2004/01/18}{Minimum adaptation to \KOMAScript\ added}
% \changes{v3.0h}{2005/08/22}{\cs{PackageInfo} added to \KOMAScript\ support}
%
% \begin{macrocode}
\AtBeginDocument{\@ifundefined{scr@caption}{}{%
\PackageInfo{caption}{KOMA-Script class detected}%
% \end{macrocode}
%
% \begin{macro}{\scr@caption}
% We update the definition of |\scr@caption| so it actually reflects
% our definition of |\caption|.
% \begin{macrocode}
\let\scr@caption\caption
% \end{macrocode}
% \end{macro}
%
% \begin{macrocode}
}}
% \end{macrocode}
%
% \subsubsection*{french(le) package support}
% \changes{v3.0h}{2005/10/03}{Minimum adaptation to \package{french(le)} added}
%
% \begin{macrocode}
\AtBeginDocument{\@ifundefined{f@ffrench}{}{%
\PackageInfo{caption}{french(le) package detected}%
% \end{macrocode}
%
% If |\GOfrench| is defined as |\relax| all the re-definitions regarding
% captions have already been done, so we can do our patches immediately.
% Otherwise we must add our stuff to |\GOfrench|.
%
% \begin{macrocode}
\@ifundefined{GOfrench}%
{\let\caption@tempa\@firstofone}%
{\def\caption@tempa{\g@addto@macro\GOfrench}}%
\caption@tempa{%
% \end{macrocode}
%
% \begin{macro}{\@cnORI}
% We update the definition of |\@cnORI| so it actually reflects
% our definition of |\caption|.
% \begin{macrocode}
\let\@cnORI\caption
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\@tablescaption}
% The \package{french(le)} package sets |\caption| to |\@tablescaption| at
% |\begin{table}| for special a treatment of footnotes.
% Therefore we have to patch |\@tablescaption| so |\caption*| will work
% inside the |table| environment.
% \begin{macrocode}
\let\caption@tablescaption\@tablescaption
\def\@tablescaption{\caption@caption\caption@tablescaption}%
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\f@ffrench}
% \begin{macro}{\f@tfrench}
% |\f@ffrench| and |\f@tfrench| reflect |\fnum@figure| and |\fnum@table|
% when used in french mode. These contain additional code which typesets
% the caption separator |\captionseparator| instead of the usual colon.
% Because this breaks with our |\@makecaption| code we have to remove
% this additional code here.
% \begin{macrocode}
\let\@eatDP\@undefined
\let\caption@tempa\@empty
\ifx\f@ffrench\fnum@figure
\l@addto@macro\caption@tempa{\let\fnum@figure\f@ffrench}%
\fi
\ifx\f@tfrench\fnum@table
\l@addto@macro\caption@tempa{\let\fnum@table\f@tfrench}%
\fi
\def\f@ffrench{\ifx\listoffigures\relax\else\figurename~\thefigure\fi}%
\def\f@tfrench{\ifx\listoftables\relax\else\tablename~\thetable\fi}%
\caption@tempa
% \end{macrocode}
% \end{macro}
% \end{macro}
%
% \begin{macrocode}
}}}
% \end{macrocode}
%
% \subsubsection*{\package{float} package support}
% \changes{v3.0f}{2005/05/31}{\package{float} package support rewritten and improved}
% \iffalse
% (This is a more straight-ahead implementation, but it only works with v1.3
% now, so v1.2 is no longer supported. The old code including documentation
% can be found in caption-30f-050530.zip)
% \fi
%
% The \package{float} package usually do not use the \LaTeX\ kernel command
% |\@caption| to typeset the caption but |\float@caption| instead.
% (|\@caption| will only be used if the float is re-styled with
% |\restylefloat*|.)
%
% The main two things |\float@caption| is doing different are:
% \begin{itemize}
% \item The caption will be typeset inside a savebox called |\@floatcapt| so
% it can be placed above or below the float contents afterwards.
% \item |\@makecaption| will not be used to finally typeset the caption.
% Instead |\@fs@capt| will be used which definition is part of the float
% style.
% (Note that |\@fs@capt| will not typeset any vertical space above or below
% the caption; instead this space will be typeset by the float style code
% itself.)
% \end{itemize}
%
% So our main goal is to re-define |\float@caption| so our macro
% |\caption@@make| will be used instead of |\@fs@capt|.
%
% To allow different caption styles for different float styles we will also
% determine the current float style (e.g. `ruled') at run time and select
% a caption style (and additional settings) with the same name, if defined.
%
% \begin{macro}{\caption@setfloatposition}
% First of all we provide a macro which converts |\@fs@iftopcapt| (which
% is part of a float style and controls where the caption will be typeset,
% above or below the float contents) to our |position=| setting. Since the
% spacing above and below the caption will be done by the float style and
% \emph{not} by us this sounds quite useless. But in fact it isn't, since some
% packages based on the \package{caption} package (like the \package{subfig}
% package) could have an interest for this information and therefore use the
% |\caption@iftop| macro we provide in our kernel. Furthermore we need this
% information for ourself in |\captionof| which uses |\@makecaption| to
% finally typeset the caption with skips.
% \begin{macrocode}
\def\caption@setfloatposition{%
\caption@setposition{\@fs@iftopcapt t\else b\fi}}
% \end{macrocode}
% \end{macro}
%
% \begin{macrocode}
\caption@ifpackage{float}{@float@setevery}{%
\PackageInfo{caption}{float package v1.3 (or newer) detected}%
% \end{macrocode}
%
% Since |\float@caption| puts the float contents into a savebox we need
% a special version of |\captionof| which `unfolds' this box afterwards,
% so the caption actually gets typeset. Furthermore we have to typeset
% the spacing above and below the caption for ourself, since this space is
% not part of the box.
%
% Please note that this version of |\captionof| only works \emph{outside}
% floating environments defined with the float package, so for example
% a |\captionof{Program}| used within a `standard' |figure| or a
% |minipage| will work fine, but not within a re-styled |figure| or
% an |Example| environment defined with |\newfloat|.
% (We don't check for this so you'll get wired errors if you try to do so!)
%
% \begin{macro}{\caption@of@float}
% Usually no special action is necessary, so we define |\caption@of@float|
% to |\@gobble|. We will redefine it later on to |\@firstofone| to activate
% the code which `unfolds' the savebox.
% \begin{macrocode}
\let\caption@of@float\@gobble
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\caption@of}
% If the float is defined by the float package (which means |\fst@|\meta{type}
% is defined) we activate the special treatment for such captions typeset
% with |\captionof|. Furthermore we `execute' this float style, so
% |\@fs@iftopcapt| is set to its proper value.
% \begin{macrocode}
\renewcommand*\caption@of[2]{%
\@ifundefined{fst@#2}{}{%
\let\caption@of@float\@firstofone
\@nameuse{fst@#2}\@float@setevery{#2}}%
\def\@captype{#2}#1}%
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\float@caption}
% \changes{v3.0h}{2005/08/23}{Bugfix 05-08-12: \cs{captionof} sets hyperref anchor now}
% Our version of |\float@caption| nearly looks like our version of |\@caption|.
% The main differences are that |\@fs@capt| will be replaced by our |\caption@@make|
% and that the savebox called |\@floatcapt| will be unfolded if requested by
% |\captionof|. (see above)
% \begin{macrocode}
\let\caption@@float\float@caption
\long\def\float@caption#1[#2]#3{%
\caption@beginex{#1}{#2}%
\let\@fs@capt\caption@@make
\caption@@float{#1}[{#2}]{#3}%
% \end{macrocode}
%
% \begin{macrocode}
\caption@of@float{%
% \end{macrocode}
% If the \package{hyperref} package is loaded, we need to set the appropriate
% anchor for ourself. To do so without adding extra vertical space we need
% to save (and restore) |\prevdepth| and switch off the interline skip.
% \begin{macrocode}
\@ifundefined{hyper@@anchor}{}{%
\begingroup
\@tempdima\prevdepth
\nointerlineskip
\let\leavevmode\relax
\hyper@@anchor\@currentHref\relax
\prevdepth\@tempdima
\endgroup}%
% \end{macrocode}
%
% \begin{macrocode}
\def\caption@@make##1##2{\unvbox\@floatcapt}%
\@makecaption{}{}}%
% \end{macrocode}
%
% \begin{macrocode}
\caption@end}%
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\@float@setevery}
% |\@float@setevery|\marg{float type} is provided by the \package{float} package;
% it's called every time a floating environment defined with |\newfloat| or
% |\restylefloat| begins.
% We use this hook to do some adaptations and to setup the proper caption style
% (if defined) and additional settings declared with
% |\captionsetup|\oarg{float style}.
% \begin{macrocode}
\let\caption@float@setevery\@float@setevery
\def\@float@setevery#1{%
\caption@float@setevery{#1}%
% \end{macrocode}
%
% \LaTeX{} and most packages use |\|\meta{type}|name|
% to provide a macro for the float name -- for example the command
% |\figurename| will usually contain the name of the floating environment
% |figure|:
% \begin{quote}
% |\newcommand\figurename{Figure}|
% \end{quote}
%
% But the \package{float} package don't follow this naming convention,
% it uses |\fname@|\meta{type} instead. So we have to adapt
% |\caption@floatname| here, so our captions will be still ok.
%
% \begin{macrocode}
\def\caption@floatname##1{\@nameuse{fname@#1}}%
% \end{macrocode}
%
% Both |\newfloat| and |\restylefloat| save the \emph{actual} definition of
% |\@caption| or |\float@caption| in |\@float@c@|\meta{captype} with |\let|
% (instead of using |\def|), so redefinitions of |\@caption| (and of course
% our redefinition of |\float@caption|) will never been used if the
% |\newfloat| or |\restylefloat| command takes place in front of the
% redefinitions provided by the \package{caption} or other packages like the
% \package{hyperref} package.
%
% So here we determine if the user has used |\restylefloat| or
% |\restylefloat*| and bring |\@float@c@|\meta{captype} up-to-date.
% This is quite easy: If |\@float@c@|\meta{captype} is the same as the
% original or our own definition of |\float@caption|, the user has used
% |\restylefloat| (and |\float@caption| should be used), otherwise
% we assume he has used |\restylefloat*| (and |\@caption| should be used).
% (This test will fail if some other package re-defines |\float@caption|,
% too, so we have to assume that we are the only one.)
%
% \begin{macrocode}
\expandafter\let\expandafter\caption@tempa\csname @float@c@#1\endcsname
\ifx\caption@tempa\float@caption
\else\ifx\caption@tempa\@caption
\else\ifx\caption@tempa\caption@@float
%<+debug> \PackageInfo{caption}{\protect\@float@c@#1\space := \protect\float@caption}%
\expandafter\let\csname @float@c@#1\endcsname\float@caption
\else
%<+debug> \PackageInfo{caption}{\protect\@float@c@#1\space := \protect\@caption}%
\expandafter\let\csname @float@c@#1\endcsname\@caption
\fi\fi\fi
% \end{macrocode}
%
% If the floating environment is defined with |\newfloat| or |\restylefloat|
% (and \emph{not} with |\restylefloat*|), |\@float@c@|\meta{type}
% will now be identical to |\float@caption|.
%
% \begin{macrocode}
\expandafter\ifx\csname @float@c@#1\endcsname\float@caption
% \end{macrocode}
%
% First of all we set the caption position to it's proper value.
% (See above definition of |\caption@setfloatposition|)
%
% \begin{macrocode}
\caption@setfloatposition
% \end{macrocode}
%
% Now we'll have to determine the current float style.
% This is not so easy because the only hint provided by the \package{float}
% package is the macro |\fst@|\meta{float type} which points to the macro
% which represents the float style.
% So for example after
% \begin{quote}
% |\floatstyle{ruled}|\\
% |\newfloat{Program}{tbp}{lop}|
% \end{quote}
% |\fst@Program| will be defined as
% \begin{quote}
% |\def\fst@Program{\fs@ruled}|\quad.
% \end{quote}
%
% So here is what we do: We copy |\fst@|\meta{float type} to |\caption@fst| and
% make it a string so we can gobble the first four tokens (= |\fs@|), so only the
% the name of the float style is left.
%
% \begin{macrocode}
\expandafter\let\expandafter\caption@fst\csname fst@#1\endcsname
\edef\caption@fst{\noexpand\string\expandafter\noexpand\caption@fst}%
\edef\caption@fst{\noexpand\@gobblefour\caption@fst}%
% \edef\caption@fst{\caption@fst}%
% \end{macrocode}
%
% |\caption@fst| now contains the float style (e.g. `ruled')
% so we can use it to set the corresponding style (if defined) and additional options.
%
% \begin{macrocode}
\caption@setstyle*\caption@fst
\caption@settype\caption@fst
% \end{macrocode}
%
% \begin{macrocode}
\fi}%
% \end{macrocode}
% \end{macro}
%
% \changes{v3.0f}{2005/06/26}{Skips of \env{plaintop} and \env{boxed} floats corrected}
%
% \begin{macro}{\fs@plaintop}
% \begin{macro}{\fs@boxed}
% The float styles |plaintop| and |boxed| don't use our skip which can be set
% with |skip=| : |plaintop| uses |\belowcaptionskip| instead of
% |\abovecaptionskip|, and |boxed| uses a fixed space of |2pt|.
% So we patch the according float style macros here to change this.
% \begin{macrocode}
\g@addto@macro\fs@plaintop{\def\@fs@mid{\vspace\abovecaptionskip\relax}}%
\g@addto@macro\fs@boxed{\def\@fs@mid{\kern\abovecaptionskip\relax}}%
% \end{macrocode}
% \end{macro}
% \end{macro}
%
% \begin{macrocode}
}
% \end{macrocode}
%
% The skip between `boxed' floats and their caption defaults to |2pt|.
%
% \begin{macrocode}
\captionsetup[boxed]{skip=2pt}
% \end{macrocode}
%
% \changes{v3.0f}{2005/05/26}{\opt{strut=0} added to caption style \opt{ruled}}
% \changes{v3.0f}{2005/05/27}{Option \opt{ruled} fixed}
% To emulate the `ruled' definition of |\@fs@capt| we provide a caption style
% `ruled' with appropriate options. But if the package option |ruled| was
% specified, we setup some caption parameters to emulate the behaviour
% of the \package{caption} package \version{1.x} option |ruled| instead:
% The current caption settings will be used, but without margin and without
% `single-line-check'.
% \begin{macrocode}
\caption@ifbool{ruled}{%
\captionsetup[ruled]{margin=0pt,singlelinecheck=0}%
}{%
\DeclareCaptionStyle{ruled}{labelfont=bf,labelsep=space,strut=0}%
}
\caption@undefbool{ruled}
% \end{macrocode}
%
% \subsubsection*{\package{floatrow} package support}
% \changes{v3.0f}{2005/06/01}{Support of the \package{floatrow} package added}
%
% The \package{floatrow} package is adapted for usage with the
% \package{caption} package. So the main work has already been done,
% there are only two little things we have to take care about:
%
% \begin{macrocode}
\caption@ifpackage{floatrow}{flrow@setlist}{%
\PackageInfo{caption}{floatrow package v0.1f (or newer) detected}%
% \end{macrocode}
%
% \begin{macro}{\caption@of}
% Captions typeset with |\captionof| should have the correct layout,
% so we have to `activate' this layout here with |\flrow@setlist|.
% \par{\small (Please note that this version of |\captionof| has the same
% restrictions than the |\captionof| offered for floating environments
% defined with the \package{float} package, see above.)}
% \begin{macrocode}
\renewcommand*\caption@of[2]{%
\def\@captype{#2}\flrow@setlist{{#2}}#1}%
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\caption@floatname}
% The \package{floatrow} package follows the same naming convention
% as the \package{float} package; so we have to adapt |\caption@floatname|
% here, too.
% \begin{macrocode}
\renewcommand*\caption@floatname[1]{%
\@nameuse{\@ifundefined{fname@#1}{#1name}{fname@#1}}}%
% \end{macrocode}
% \end{macro}
%
% \begin{macrocode}
}
% \end{macrocode}
%
% \subsubsection*{\package{hyperref} package support}
% \changes{v3.0f}{2005/06/11}{Support of the \package{hyperref} package added}
%
% When the \package{hyperref} package is used we have the problem
% that the usage of |\ContinuedFloat| will create duplicate
% hyperlinks -- both |\@currentHlabel| and |\@currentHref| will be the same
% for the main float and the continued ones. So we have to make sure
% unique labels and references will be created each time. We do this
% by extending |\theHfigure| and |\theHtable|, so for continued floats
% the scheme
% \begin{quote}\meta{type}|.|\meta{type \#}|.|\meta{continue \#}\end{quote}
% will be used instead of
% \begin{quote}\meta{type}|.|\meta{type \#}\quad\quad.\end{quote}
% \par{\small(This implementation follows an idea from Steven Douglas Cochran.)}
% \par{\small Note: This does not help if |\Hy@naturalnamestrue| is set.}
%
% \begin{macrocode}
\caption@ifpackage{hyperref}{theHfigure}{%
\PackageInfo{caption}{hyperref package v6.74m (or newer) detected}%
% \end{macrocode}
%
% \begin{macro}{\caption@ContinuedFloat}
% \changes{v3.0g}{2005/06/28}{Bugfix: \cs{newcounter} replaced by \cs{newcount}}
% If |\theH|\meta{type} is defined, we extend it with |.|\meta{continue \#}.
% Furthermore we set |\caption@resetContinuedFloat| to |\@gobble| so the
% continuation counter will not be reset to zero inside |\caption|.
% \begin{macrocode}
\def\caption@ContinuedFloat#1{%
\@ifundefined{theH#1}{}{%
\@ifundefined{CF@#1}{%
\expandafter\newcount\csname CF@#1\endcsname
\caption@resetContinuedFloat{#1}}{}%
\global\advance\csname CF@#1\endcsname\@ne\relax
\expandafter\l@addto@macro\csname theH#1\endcsname{%
.\expandafter\@arabic\csname CF@#1\endcsname}%
\let\caption@resetContinuedFloat\@gobble
}}%
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\caption@resetContinuedFloat}
% If a continuation counter is defined, we reset it.
% \begin{macrocode}
\def\caption@resetContinuedFloat#1{%
\@ifundefined{CF@#1}{}{\global\csname CF@#1\endcsname\z@\relax}}%
% \end{macrocode}
% \end{macro}
%
% \begin{macrocode}
}
% \end{macrocode}
%
% \subsubsection*{\package{hypcap} package support}
% \changes{v3.0f}{2005/06/22}{Support of the \package{hypcap} package added}
%
% When the \package{hypcap} package is used the following problems occur:
% \begin{enumerate}
% \item The \package{hypcap} package uses |\capstart|, |\hc@caption|, and
% |\hc@@caption| instead of |\caption| and |\@caption|.
% So we have to patch these macros, too.
% \item |\caption| will be saved to |\hc@org@caption| when the
% \package{hypcap} package is loaded.
% We have to change this so our definition of |\caption| will always be
% used.
% \item Both, |\capstart| and |\hc@@caption|, call |\hyper@makecurrent|.
% But since we offer |\ContinuedFloat| the float counters could have changed
% between these both calls! So we fix this by saving the \package{hyperref}
% reference (= |\@currentHref|) in |\capstart| and restoring it later on in
% |\hc@@caption|.
% \par{\small (This also fixes the problem that \package{hypcap} does not
% work if |\Hy@hypertexnamesfalse| is set. This come in handy; we set
% it locally to avoid duplicated \package{hyperref} labels which could
% occur if |\ContinuedFloat| will be used.)}
% \item |\capstart| will call |\H@refstepcounter| to increase the float
% number. This collides with a following|\ContinuedFloat|, too, so we have
% to move this call from here to |\caption|. (Since we set
% |\Hy@hypertexnamesfalse| we can do this without problems.)
% \end{enumerate}
%
% \begin{macrocode}
\caption@ifpackage{hypcap}{hc@caption}{%
\PackageInfo{caption}{hypcap package v1.0 (or newer) detected}%
% \end{macrocode}
%
% \begin{macro}{\capstart}
% Here comes our version of |\capstart|:
% \begin{macrocode}
\let\caption@capstart\capstart
\def\capstart{%
% \end{macrocode}
% First of all we update |\hc@org@caption| to correct the problem that the
% \package{hypcap} package has saved an older definition of |\caption|.
% \begin{macrocode}
\let\hc@org@caption\caption
% \end{macrocode}
% Since we don't know the float counter yet (it could be changed with
% |\ContinuedFloat| afterwards!) we make sure |\H@refstepcounter| will
% not be used and |\Hy@hypertexnamesfalse| is set, so unique
% \package{hyperref} labels will be generated by the original
% definition of |\capstart|.
% Afterwards we save the reference which was generated by
% |\hyper@makecurrent|.
% \begin{macrocode}
\begingroup
\let\H@refstepcounter\@gobble
\Hy@hypertexnamesfalse
\caption@capstart
\global\let\caption@currentHref\@currentHref
\endgroup
% \end{macrocode}
%
% The \package{hypcap} package restores the previous definition of |\caption|
% inside |\hc@@caption|. But since we will call this inside a group later on
% (making this restauration non-working), we have to make this for ourself
% inside |\caption|.
% (This would not be necessary if \package{hypcap} would do this inside
% |\hc@caption| instead of |\hc@@caption|.)\par
% Additionally we increase the float counter here (since we have suppressed this
% in |\capstart|) and use |\caption@caption| here, so |\caption*| will work as
% expected.
% \begin{macrocode}
\def\caption{%
\let\caption\hc@org@caption
\H@refstepcounter\@captype
\caption@caption\hc@caption}}%
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\hc@@caption}
% Here comes our version of |\hc@@caption|:
% \begin{macrocode}
\let\caption@hc@@caption\hc@@caption
\long\def\hc@@caption#1[#2]#3{%
\caption@beginex{#1}{#2}%
% \end{macrocode}
%
% Beside the usual |\caption@begin| and |\caption@end| stuff (to support local
% options etc.) we make sure our saved \package{hyperref} reference will be
% used.
% \begin{macrocode}
\let\caption@hyper@makecurrent\hyper@makecurrent
\def\hyper@makecurrent\@captype{%
\let\hyper@makecurrent\caption@hyper@makecurrent
\global\let\@currentHref\caption@currentHref}%
% \end{macrocode}
%
% \begin{macrocode}
\caption@hc@@caption{#1}[{#2}]{#3}%
\caption@end}%
% \end{macrocode}
% \end{macro}
%
% \begin{macrocode}
}
% \end{macrocode}
%
% \subsubsection*{\package{listings} package support}
% \changes{v3.0b}{2004/05/16}{Support of the \package{listings} package added}
%
% \begin{macrocode}
\caption@ifpackage{listings}{lst@MakeCaption}{%
\PackageInfo{caption}{listings package v1.2 (or newer) detected}%
% \end{macrocode}
%
% \begin{macro}{\lst@MakeCaption}
% To support the \package{listings} package we need to redefine
% |\lst@MakeCaption| so the original stuff is nested with
% |\caption@begin| and |\caption@end|.
% \begin{macrocode}
\let\caption@lst@MakeCaption\lst@MakeCaption
\def\lst@MakeCaption#1{%
% \end{macrocode}
%
% If the |position=| is set to |auto|, we take over the |captionpos=| setting
% from the \package{listings} package.
% Note that we won't do this otherwise, so \package{listings} settings like
% |abovecaptionskip=0pt,belowcaptionskip=10pt,captionpos=t| will \emph{not}
% cause different outputs with or without the \package{caption} package loaded.
% \begin{macrocode}
\def\caption@autoposition{\caption@setposition{#1}}%
% \end{macrocode}
%
% \begin{macrocode}
\caption@begin{lstlisting}%
\caption@lst@MakeCaption{#1}%
\caption@end}%
% \end{macrocode}
% \end{macro}
%
% \begin{macrocode}
}
% \end{macrocode}
%
% \subsubsection*{\package{longtable} package support}
%
% \begin{macrocode}
\caption@ifpackage{longtable}{LT@makecaption}{%
\PackageInfo{caption}{longtable package v3.15 (or newer) detected}%
% \end{macrocode}
%
% \begin{macro}{\LT@makecaption}
% \changes{v3.0d}{2004/08/10}{Bugfix 04-08-04: \cs{abovecaptionskip} \& \cs{belowcaptionskip} will be used now}
% \changes{v3.0e}{2005/05/05}{Bugfix: \cs{captionsetup[longtable]} overrides \cs{LTcapwidth} now}
% \changes{v3.0h}{2005/10/07}{\cs{caption@LT@make} introduced}
% |\LT@makecaption|\marg{cmd}\marg{label}\marg{text}\par
% Original code:
% \begin{verbatim}
% \def\LT@makecaption#1#2#3{%
% \LT@mcol\LT@cols c{\hbox to\z@{\hss\parbox[t]\LTcapwidth{%
% % Based on article class "\@makecaption", "#1" is "\@gobble" in star
% % form, and "\@firstofone" otherwise.
% \sbox\@tempboxa{#1{#2: }#3}%
% \ifdim\wd\@tempboxa>\hsize
% #1{#2: }#3%
% \else
% \hbox to\hsize{\hfil\box\@tempboxa\hfil}%
% \fi
% \endgraf\vskip\baselineskip}%
% \hss}}}
% \end{verbatim}
%
% \begin{macrocode}
\def\LT@makecaption#1#2#3{%
\caption@LT@make{%
% \end{macrocode}
%
% We set |\ifcaption@star| according the 1st argument.
% \begin{macrocode}
\caption@startrue#1\caption@starfalse
% \end{macrocode}
%
% If |\LTcapwidth| is not set to its default value |4in| we assume
% that it shall overwrite our own setting.
% (But |\captionsetup[longtable]{width=|\ldots|}| will overwrite |\LTcapwidth|.)
% \begin{macrocode}
\caption@letfloattype{longtable}{%
\ifdim\LTcapwidth=4in \else
\setcaptionwidth\LTcapwidth
\fi}%
% \end{macrocode}
%
% The default |position=| setting for longtables is |top|.
% (This emulates the standard behaviour of the \package{longtable} package
% which has no skip above the caption but a skip below it.)
% \begin{macrocode}
% \caption@setdefaultpos{t}%
\let\caption@defaultpos\@firstoftwo
% \end{macrocode}
%
% |position=auto| is a bad idea for longtables, but we do our very best.
% This works quite well for captions inside the longtable contents, but
% not for captions inside the longtable (end)foot.
% \begin{macrocode}
\def\caption@autoposition{%
\caption@setposition{\ifcase\LT@rows t\else b\fi}}%
% \end{macrocode}
%
% \begin{macrocode}
\caption@begin{table}%
% \end{macrocode}
%
% The following skip has the purpose to correct the height of the
% |\parbox[t]|. Usually it's the height of the very first line, but
% because of our extra skips (|\abovecaptionskip| and |\belowcaptionskip|)
% it's always |0pt|.
% (A different idea would be typesetting the first skip outside the longtable
% column with |\noalign{\vskip|\ldots|}|, but this means we have to move
% |\caption@begin| to some other place because it does not work in tabular
% mode\ldots)
% \begin{macrocode}
\vskip-\ht\strutbox
% \end{macrocode}
%
% This should look familiar. We do our skips and use |\caption@@make| to
% typeset the caption itself.
% \begin{macrocode}
\caption@iftop{\vskip\belowcaptionskip}{\vskip\abovecaptionskip}%
\caption@@make{#2}{#3}\endgraf
\caption@iftop{\vskip\abovecaptionskip}{\vskip\belowcaptionskip}%
\caption@end}}%
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\caption@LT@make}
% Typesets the caption as centered |\multicolumn|\ldots
% \begin{macrocode}
\newcommand\caption@LT@make[1]{%
\LT@mcol\LT@cols c{\hbox to\z@{\hss\parbox[t]\hsize{#1}\hss}}}%
% \end{macrocode}
% \end{macro}
%
% \begin{macrocode}
}
% \end{macrocode}
%
% \subsubsection*{\package{picins} package support}
% \changes{v3.0j}{2006/01/26}{Support of the \package{picins} package added}
%
% \begin{macrocode}
\caption@ifpackage{picins}{piccaption}{%
\PackageInfo{caption}{picins package v3.0 (or newer) detected}%
% \end{macrocode}
%
% \begin{macro}{\piccaption}
% Original code:
% \begin{verbatim}
% \def\piccaption{\@ifnextchar [{\@piccaption}{\@piccaption[]}}
% \end{verbatim}
% \begin{macrocode}
\def\piccaption{\@dblarg\@piccaption}
% \def\piccaption{\caption@caption{\@dblarg\@piccaption}}
% \end{macrocode}
% \end{macro}
%
% {\itshape TODO: Make |\piccaption[]{|\ldots|}| and |\piccaption{}| work}
%
% \begin{macrocode}
}
% \end{macrocode}
%
% \subsubsection*{\package{rotating} package support}
%
% \begin{macrocode}
\caption@ifpackage{rotating}{@rotcaption}{%
\PackageInfo{caption}{rotating package v2.0 (or newer) detected}%
% \end{macrocode}
%
% \begin{macro}{\rotcaption}
% \changes{v3.0c}{2004/07/16}{Bugfix: Check for \cs{caption@caption} removed}
% \changes{v3.0i}{2005/12/07}{Rewritten, works with \package{hyperref} now}
% Make |\rotcaption*| work.
% \begin{macrocode}
\def\rotcaption{\let\@makecaption\@makerotcaption\caption}%
% \let\@rotcaption\@undefined
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\rotcaptionof}
% \changes{v3.0i}{2005/12/07}{New}
% Make |\rotcaptionof(*)| work.
% \begin{macrocode}
\def\rotcaptionof{\@ifstar{\caption@of{\rotcaption*}}{\caption@of\rotcaption}}%
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\@makerotcaption}
% \changes{v3.0i}{2005/12/06}{Rewritten, should finally work proper now}
% Original (bugfixed) code:
% \begin{verbatim}
% \long\def\@makerotcaption#1#2{%
% \setbox\@tempboxa\hbox{#1: #2}%
% \ifdim \wd\@tempboxa > .8\vsize
% \rotatebox{90}{%
% \begin{minipage}{.8\textheight}#1: #2\end{minipage}%
% }%\par % <== \par removed (AR)
% \else%
% \rotatebox{90}{\box\@tempboxa}%
% \fi
% \nobreak\hspace{12pt}% <== \nobreak added (AR)
% }
% \end{verbatim}
% Our version emulates this behaviour, but if |width=| is set,
% the rotated caption is always typeset as |minipage|.
% (Note that |margin=| is not supported here.)
% \begin{macrocode}
\long\def\@makerotcaption#1#2{%
% \end{macrocode}
%
% \begin{macrocode}
\ifdim\captionwidth=\z@
\setcaptionwidth{.8\textheight}%
\caption@slc{#1}{#2}{.8\vsize}{%
\let\caption@makerot\caption@@make
\setcaptionmargin\z@
% \setlength\captionindent\z@
% \def\caption@startbox##1{\hbox\bgroup\hsize=.8\textheight}%
% \def\caption@endbox{\egroup}%
% (not needed because \rotatebox uses an \hbox anyway)
\let\caption@startbox\@gobble
\let\caption@endbox\relax}%
\caption@setbool{slc}{0}% been there, done that
\fi
% \end{macrocode}
%
% \begin{macrocode}
\rotatebox{90}{\caption@makerot{#1}{#2}}%
\nobreak\hspace{12pt}}%
% \end{macrocode}
%
% \begin{macrocode}
\newcommand\caption@makerot[2]{%
\begin{minipage}\captionwidth\caption@@make{#1}{#2}\end{minipage}}%
% \end{macrocode}
% \end{macro}
%
% \begin{macrocode}
}
% \end{macrocode}
%
% \subsubsection*{\package{sidecap} package support}
%
% \begin{macrocode}
\caption@ifpackage{sidecap}{endSC@FLOAT}{%
\PackageInfo{caption}{sidecap package v1.4d (or newer) detected}%
% \end{macrocode}
%
% \begin{macro}{\SC@caption}
% \changes{v3.0d}{2004/11/28}{Bugfix: Definition of \cs{@captype} added}
% \changes{v3.0e}{2005/05/05}{Bugfix: Empty captions are handled correctly now}
% \changes{v3.0e}{2005/05/05}{Priority of options fixed}
% \changes{v3.0h}{2005/10/03}{Bugfix: Always use \cs{AtBeginDocument} to set \cs{SC@caption}}
% First of all, we let sidecap use an actual definition of |\caption|.\\
% (This is only required for version 1.5d of the sidecap package.)
% \begin{macrocode}
\@ifundefined{caption@caption}%
{\let\caption@tempa\AtBeginDocument}%
{\let\caption@tempa\@firstofone}%
\caption@tempa{\let\SC@caption=\caption}%
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\SC@zfloat}
% \changes{v3.0b}{2004/05/16}{Local definition of \cs{captionsetup} added}
% \changes{v3.0c}{2004/07/16}{Bugfix 04-07-15: Check for \cs{caption@caption} removed}
% This macro will be called at the start of the environment, here is a good
% opportunity to do some adaptations to |\caption| and |\captionsetup|.
% \begin{macrocode}
\let\caption@SC@zfloat\SC@zfloat
\def\SC@zfloat#1#2#3[#4]{%
% \end{macrocode}
%
% Note: |#2| is either |figure| or |table| and will be stored to |\SC@captype|
% by the original version of |\SC@zfloat|.
% \begin{macrocode}
\caption@SC@zfloat{#1}{#2}{#3}[#4]%
% \end{macrocode}
%
% Since the sidecap package uses our |\caption| code outside the
% floating environment the regular |\captionsetup| will not work.
% So we need a special version here which saves the given argument list
% which will be executed later on.
% \begin{macrocode}
\global\let\SC@CAPsetup\@empty
\def\captionsetup##1{\g@addto@macro\SC@CAPsetup{,##1}}%
% \end{macrocode}
%
% Make |\caption*| work.
% \begin{macrocode}
\let\caption@old\caption
% \def\caption{\renewcommand\captionsetup[1]{}\caption@caption\caption@old}%
\def\caption{\caption@caption\caption@old}%
}%
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\endSC@FLOAT}
% \changes{v3.0i}{2006/01/12}{\cs{@listdepth}\cs{z@} added}
% This macro will be called at the end of the environment, here we need to
% setup our stuff before the \package{sidecap} package actually typesets
% its caption.
% \begin{macrocode}
\let\caption@endSC@FLOAT\endSC@FLOAT
\def\endSC@FLOAT{%
% \end{macrocode}
%
% Note that |\@captype| isn't defined so far, this will be done inside
% the original definition of |\endSC@FLOAT|.
% But we define |\@captype| already here to make |\captionsetup| work
% with |\@captype|-based options (like |type=|).
% \begin{macrocode}
\let\@captype\SC@captype
% \end{macrocode}
%
% Here we execute the options set with |\captionsetup| inside this environment.
% \begin{macrocode}
\caption@esetup\SC@CAPsetup
% \end{macrocode}
%
% Before we can typeset the caption we need to set the margin to zero
% because any extra margin would only be disturbing here.\par
% (We don't need to take care about the caption position because
% the sidecap package set both |\abovecaptionskip| and |\belowcaptionskip|
% to a skip of zero anyway.)\par
% Furthermore |\SC@justify| will override the caption justification, if set.
% The usage of |\SC@justify| differs from version to version of the
% \package{sidecap} package:\par
% \begin{tabular}{ll}
% Version 1.4: & |\SC@justify| is not defined\\
% Version 1.5: & |\SC@justify| is |\relax| when not set\\
% Version 1.6: & |\SC@justify| is |\@empty| when not set\\
% \end{tabular}
% \begin{macrocode}
\caption@letfloattype{SC\@captype}{%
\@listdepth\z@
\setcaptionmargin\z@
\@ifundefined{SC@justify}{}{%
\ifx\SC@justify\@empty\else
\let\caption@hj\SC@justify
\let\SC@justify\@empty
\fi}}%
% \end{macrocode}
%
% We adapt |\caption@ifempty| so |\caption{}| will work within these
% environments, too.
% \begin{macrocode}
\long\def\caption@ifempty##1{%
\ifx\SC@CAPtext\@empty
\expandafter\@firstofone
\else
\expandafter\@gobble
\fi}%
% \end{macrocode}
%
% \iffalse % Does not work anyway...
% Furthermore we adapt |\caption@ifnocontentsline| so |\caption[]{|\ldots|}|
% will work within these environments, too.
% \begin{macrocode}
% \long\def\caption@ifnocontentsline##1{%
% \ifx\SC@OPTCAPtext\@empty
% \expandafter\@firstofone
% \else
% \expandafter\@gobble
% \fi}%
% \end{macrocode}
% \fi
%
% Finally we call the original definition of |\endSC@FLOAT| which will
% call our version of |\caption| to typeset the caption.
% \begin{macrocode}
\caption@endSC@FLOAT}%
% \end{macrocode}
% \end{macro}
%
% \begin{macrocode}
}
% \end{macrocode}
%
% \subsubsection*{\package{supertabular} package support}
%
% \begin{macro}{\caption@setSTposition}
% The |position=| setting will be overwritten by the
% \package{supertabular} package: If |\topcaption| is used,
% the position will be |top| automatically, |bottom| otherwise.
% \begin{macrocode}
\def\caption@setSTposition{%
\caption@setposition{\if@topcaption t\else b\fi}}
% \end{macrocode}
% \end{macro}
%
% \begin{macrocode}
\caption@ifpackage{supertabular}{ST@caption}{%
\PackageInfo{caption}{supertabular package detected}%
% \end{macrocode}
%
% \begin{macro}{\tablecaption}
% \changes{v3.0e}{2005/05/05}{Made \cs{topcaption*} and \cs{bottomcaption*} work}
% Make |\topcaption*| and |\bottomcaption*| work.
% \begin{macrocode}
\let\caption@tablecaption\tablecaption
\def\tablecaption{\caption@caption\caption@tablecaption}%
% \end{macrocode}
% \end{macro}
%
% \begin{macro}{\ST@caption}
% \changes{v3.0a}{2004/01/23}{Bugfix: Missing \cs{par} added}
% Original code:
% \begin{verbatim}
% \long\def\ST@caption#1[#2]#3{\par%
% \addcontentsline{\csname ext@#1\endcsname}{#1}%
% {\protect\numberline{%
% \csname the#1\endcsname}{\ignorespaces #2}}
% \begingroup
% \@parboxrestore
% \normalsize
% \if@topcaption \vskip -10\p@ \fi
% \@makecaption{\csname fnum@#1\endcsname}{\ignorespaces #3}\par
% \if@topcaption \vskip 10\p@ \fi
% \endgroup}
% \end{verbatim}
% \begin{macrocode}
\let\caption@ST\ST@caption
\long\def\ST@caption#1[#2]#3{\par%
\caption@letfloattype{supertabular}{}%
\let\caption@fixposition\caption@setSTposition
\caption@beginex{#1}{#2}%
\addcontentsline{\csname ext@#1\endcsname}{#1}%
{\protect\numberline{%
\csname the#1\endcsname}{\ignorespaces #2}}%
\@parboxrestore
\normalsize
\@makecaption{\csname fnum@#1\endcsname}{\ignorespaces #3}\par
\caption@end}%
% \end{macrocode}
% \end{macro}
%
% \begin{macrocode}
}
% \end{macrocode}
%
% \iffalse
%</package>
% \fi
%
% \clearpage
% \Finale
%
\endinput