% \iffalse meta-comment % % Copyright (C) 2001-2021 by Wybo Dekker % % This work may be distributed and/or modified under the % conditions of the LaTeX Project Public License (LPPL), either % version 1.3c of this license or (at your option) any later % version. The latest version of this license is in the file: % % http://www.latex-project.org/lppl.txt % % This work consists of the self-extracting file ctable.dtx % Installation: see the readme section below. % %<*internal> \iffalse % %<*readme> # ctable key | description ---:|:--- ctable | package for flexible key/value driven typesetting of floats version | 1.32 date | 2025/07/10 author | Wybo Dekker email | wybodekker@me.com license | Released under the LaTeX Project Public License v1.3c or later ## Short description: ctable.sty provides commands to easily typeset centered or left or right aligned table and (multiple-)figure floats, with footnotes. Instead of an environment, a command with 4 arguments is used; the first is optional and is used for key,value pairs generating variations on the defaults and offering a route for future extensions. # Installation: This is a self-extracting file. Install as follows: 1. Run "tex ctable.dtx" 2. Run "sh make.sh" 3. Run "make install" to install in the local tree (needs sudo rights), or Run "make inst" to install in your own tree. 4. Run "make clean" to remove most intermediate files, or Run "make Clean" to keep the dtx file and CTAN zip only. 5. Run "make zip" to create a zip file for CTAN 6. Try "make help" % %<*make> uudecode etc.uue tar xf etc.taz make make help % %<*etc> begin-base64 644 etc.taz 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 mn8mDx0dHdE/VVh+in4mLYWhgzPtP4rUH15adwAR/ef+JACm/8STkui/bUvx T2UAEq8/SrhoXeys7T7bV59/8326bGZo4/TXWhN7u79PEnvr/9IP/CdYABcX E1PjPyf5jxv7r/vzr8P6c/T/zoE/LH8S0/1v8/SfL6DPNUsmE1fL//rN9mcH B3tHZ4AGQBOgBRCD+Xfsqeic/h16I95PL0jpnP7kB0CTl5z0z6UGaGsDSIwA vL4AbWtaT12Aru6fM/hc/buo8SdsxoZ/GiIjOieif3j9FyH+UIgAnzo+YcLR 1MnFxvlf/F4axMRUpJ9E2z8dwB9L/tGQkpDr2JH7/FcNTn9VkP/RQvxPJsC/ LgnM32D+Jw8/k8bB0ubPWf8DM/4k898j/vxslJQT0fzHKQBkBaVFP6eiGrzk /wkgrRPg81aa0Fk6OZMDZARV/qzauBj+r+4a+X/iTEv71cXS1BlA/s+NP3tM 8v9iGOB/PnQc/3e0Mv/69vv/vOb/jP/1/z/s7J+Tv/WfkYWd/XP65/8fZgam /6f+/98xIhTkxOFgsP9kFpykhIjS5/Pp8zcJ9WeRLSP+T2JAO0hoOgEBwSL/ +QHPbvi+AQHhoXuqaDgrGbp9Irv9Xwh09nD4xGkHZ2MgIPfVlCxJO1Nux9BD HVHaAJMfeF77GZCbQNrd/sA4mx/dW1PUB8pqKWP331WkWic4TRh27QOTX5f8 Xh/9nsf8Pqb8Nj6epvbee8WPCbmsKYtzm5rnftfErbbHnd86WeXV1MS5l8dx bnpVdLY/j13OiebeZLCv6Hbp4Up56W8RlGTk+TwpJD2i3ztZCbOnezbybTxq Gx+Mel7d3k/5Xq0m3nW9nhve9rQfw/OJ8U57j+rLLzQkpVwRo74e3q/HPfvF /Hrc8utgfCaw32+u0fDlv/SG+W2vjzhJ4Nb5sPecV/Pbhbtj0WfD9u19/lCS F+PUnhDHjzz0Og52RZa/WtiZ5uPrzBNv0c2tGb+Yzn23+o8+7ZdXcj4o11dO R6P9tTic3+/Cb9gWb8bdfmD82Xm1Ln6H4Py7ql0lT05a/HyLSwN2r52I9pPt ZVfBdc13NZcyP/fTnOnVHnj3uyS1Hh8v7/xMH2274vY/uqb5356QQq9uhXa4 yzpz3xJgtqBftEM/qC6mfUlX3GYWa7Zuyc17yQddgmvYKXwF52AeL1wvPR7l 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 VfmOQ6/jLCo/wNmsez3h+cwzH9Ic8B67y+9dPsls6Yu04xTvOXn0tZ5GXNFG r/ABm+D55PBJl+68kNYyl1khm0OaKo8qG9oQ7fHeox67faeUVbXIkZwZ3NNK QboXly/NinJ+WPXM24yu0+9r3PryVFXCk75zZ3tiGG+DaRR7j4VkWXOKRoSr pp1xjYGBxa8vi8j7zZ85nTl+bLOv96UTG19snr28wXQLsMH5Zrhjz1k34UCM nIRoJXL6UMKFivgVcedPvSbxMi8rqObXLD6pxNngVeG4qivM7ey1IW8no6m7 BgYfza8rCpVeKrWsmx43eHV6use1l5olTMO4Sv/TMvlllPkvMjta1WrTT7Zr SQesu1wVnZxyt06iumc7rnCguV7Cu2VG5oZWf7yloWtZh17dylPHeRna2br3 tHwSGzUOZN2wVOp8SVzjsSnggcHyqVwjBa+S7q1dxlUpTzMPdE2fZa9d92Dl 0aJ8yiRre5eDXUsZMtLW7ztTuUcsnDsXuygsaOVd99hkTZgnXWh5u/HE/jsP yoIHZZTWdzq9j7oVeT0zsvrQ+0MZq2oO1YPO+ttfV9cIcZ+ov5V1F69Qa9xy q9jGBl15Y/rcfMeMipl667GJy9uXrCObNS1BezeHPb1Dw85rGdjs2KnghJt9 D7Oua/uiZN8jQ3L2km1FlIX2qXsRHct4wc/YhTGN2fjcLNJ0k+K4hErT9YPu DWdyr8zSjHh0XHW1Gcs6wrr0TUbi1YYfhLfncYcRlvPSblaRIxvFxXSwB9MP oiG1cY9/mk39wWNSSVDc/tNM97jyrA4XG4r9jynPU1ufvO0Kzp+x5b1YuZpz m4Y6/hfS65S2Z6tBLZftWwyhsk23S3PiXwwjah2Plh9967swtTVhh53o9bIs Jy9qbUGbVPn2fTH35y5VOx62KMOluCf+9SHSoHmgf1NqDskqR8sqcvjmeAXT /0AwQQbIJv5vz8Fv5BnhcH/U/kPh8YaC9h8Ob2iIxWD57T8UBg23/8YDaioG fhSagR+BRUaqAa5kEPCnUEEW4AdS6SEAgQkCYCibSSCyQRLgz6QHAWwoiz6J HQqw6BwmEdSHSnmQQRoQRucARDKBFgACBFoYQPfn52SNVqcL2UhACIHGBth0 IBAEGaNHR0pAx6HiUE00EDoNlAP6VlIJRJCfKQig0AQnHT0fdI0UFsAiMikM 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 GDBgwJhg/AsrDGKFABgBAA== ==== % %<*internal> \fi \def\nameofplainTeX{plain} \ifx\fmtname\nameofplainTeX \def\Extract#1#2#3{\generate{\file{#1.#2}{\from{\jobname.dtx}{#3}}}} \else \def\Extract#1#2#3{} \expandafter\begingroup \fi % %<*install> \input docstrip.tex \keepsilent \askforoverwritefalse \Extract{\jobname}{sty}{package} % %\endbatchfile %<*internal> \nopreamble\nopostamble \catcode9=12 \Extract{README}{md}{readme} \Extract{etc}{uue}{etc} \Extract{make}{sh}{make} \ifx\fmtname\nameofplainTeX \expandafter\endbatchfile \else \expandafter\endgroup \fi % % \fi % % \iffalse %<*driver> \ProvidesFile{ctable.dtx} % %\NeedsTeXFormat{LaTeX2e}[2021/11/15] %\ProvidesPackage{ctable} %<*package> [2025/07/10 v1.32 package for flexible key/value driven typesetting of floats] % %<*driver> \documentclass{ltxdoc} \usepackage{paralist}\setdefaultleftmargin{1em}{1em}{1em}{1em}{1em}{1em} \usepackage[a4paper,margin=20mm,left=50mm,nohead]{geometry} \usepackage[numbered]{hypdoc} \usepackage{longtable} \usepackage{\jobname} \usepackage{fontspec} \usepackage[final]{microtype} \setmainfont{TeX Gyre TermesX} \usepackage{tocloft} \setlength\cftparskip{.5ex} \setlength\cftbeforesecskip{.5ex} \setlength\cftaftertoctitleskip{1ex} \graphicspath{{./doc/}} \definecolor{vbgreen}{rgb}{0,.6,0} \definecolor{B}{rgb}{0.77, 0.90, 0.96} \definecolor{Y}{rgb}{1,1,.878} \def\REF#1{\href{http://www.ctan.org/pkg/#1}{\texttt{#1}}} \def\isarg#1{\hskip-1em=\texttt{\textsl{#1}}\\} \def\oarg#1{\hskip-1em\texttt{[\textsl{#1}]}} \def\marg#1{\hskip-1em\texttt{\{\textsl{#1}\}}} \def\arg#1{\texttt{\{\textsl{#1}\}}} \marginparwidth25mm \parindent0pt\parskip1ex \let\DescribeKey\DescribeEnv \newcommand{\ROW}[3]{\parskip0pt% \colorbox{#1}{% \parbox{.98\hsize}{% \rule{0pt}{1.5ex}\\% \parbox{.57\hsize}{\includegraphics{#2}}% \parbox{.43\hsize}{\centering{\includegraphics{#3}}}% \\\rule{0pt}{1.5ex}% }% }\par% } \EnableCrossrefs \CodelineIndex \hypersetup{ pdftitle = ctable package for flexible key/value driven typesetting of floats pdfauthor = Wybo Dekker, pdfsubject = {Typesetting centered, right, and left aligned table and figure floats, with many configuration options}, pdfkeywords = { table floats, figure floats, key=value options, footnotes, booktabs, tabularx, threeparttable }, bookmarksopen, colorlinks } \begin{document} \DocInput{\jobname.dtx} \end{document} % % \fi % % \GetFileInfo{\jobname.dtx} % \DoNotIndex{ % \,\\,\@ifclassloaded,\@ifpackageloaded,\@rot@twosidefalse,\@rot@twosidetrue, % \@textsuperscript,\addlinespace,\addtocounter,\AtBeginDocument,\begin, % \begingroup,\def,\define@key,\definecolor,\edef,\else,\empty,\end,\endgroup, % \endinput,\expandonce,\fboxrule,\fboxsep,\fcolorbox,\fi,\hbox,\hsize, % \if@twoside,\ifdim,\ifpdf,\ifx,\label,\left,\let,\long,\makeatletter, % \makeatother,\MessageBreak,\NC@find@X,\newbox,\newcolumntype,\newcommand, % \newdimen,\newif,\noexpand,\normalfont,\PackageError,\PackageWarningNoLine, % \parindent,\pos,\raggedleft,\raggedright,\relax,\RequirePackage,\rot@LR, % \sbox,\strut,\textit,\textsuperscript,\undefined,\usebox,\vskip,\wd} % % \title{\textsf{ctable} --- package for flexible key/value driven typesetting of floats} % \date{\large\fileversion\quad\filedate} % \author{Wybo Dekker\thanks{Email: wybodekker@me.com}} % \maketitle % \begin{abstract}\noindent % The \texttt{ctable} package provides a \texttt{ctable} % command for the typesetting of table and figure floats. You will % not need to type the usual nested begin...end sequences, as % \texttt{ctable} is a command, not an environment. \texttt{ctable} % has only 4 arguments, but the optional first one may hold many % \textsl{key=value} pairs and makes \texttt{ctable} very flexible % and extensible. It uses Simon Fear's \REF{booktabs} package for % better vertical spacing around horizontal rules and it provides % facilities for making table footnotes. % \end{abstract} % \tableofcontents % % \section{Purpose} The |ctable| package lets you easily typeset captioned % table and figure floats with optional footnotes. Both caption and % footnotes will normally be forced within the width of the table. % % If the width of the table is specified, then \REF{tabularx} will be used % to typeset it, and one or more |X| column specifiers should be specified. % Otherwise tabular will be used. % % This package defines the commands \cs{ctable}, \cs{tnote} and % \cs{tmark}, and four \cs{tabularnewline} generating % commands. The latter generate reasonable amounts of whitespace % around horizontal rules and are also useful for tabulars % outside this package. % % Since the |ctable| package imports the \REF{array} and \REF{booktabs} % packages, all commands from those packages are available as well. % % Note that, in line with the comments that Simon Fear made % describing his \REF{booktabs} package, vertical rules for column % separation can be produced with \cs{ctable}, but no provisions are % made to have them make contact with horizontal rules. % % \section{Usage} % \DescribeMacro{\ctable}\oarg{key=value,...}\arg{coldefs}\arg{foottable}\arg{rows}\\ % typesets the \textsl{rows} in a table float with column specifiers % \textsl{coldefs} like in the |tabularx| environment. \textsl{foottable} % consists of zero or more instances of the \cs{tnote} command described % in section \ref{other}. The table properties are specified with % \textsl{key=value} pairs described in section \ref{options}. % % \DescribeMacro{\setupctable}\marg{key=value....}\\ % sets \cs{ctable} defaults, either in the preamble or in the body. % \section{Options}\label{options} % Options are given as key=value pairs, separated by comma's. % Extra comma's, including any behind the last pair, don't hurt. % Arguments to option should be put between braces if they contain % comma's or equals signs. % Currently the following option keys have been defined: % % \DescribeKey{bgopacity}\isarg{...} % Sets the opacity of the table's background color, where 1 is 100\% opaque % (the default), and 0 is completely transparent. One application is with % watermarking: most watermarking packages print their watermark on the % background. |ctable|'s background color, which is opaque by default, may % make the watermark (partially) invisible. You can avoid this by setting % the |bgopacity| option to a value lower than 1. Note that this works only % in PDF mode, a warning is issued otherwise.\\ % Note: there are two limitations to transparency setting: % \begin{compactenum} % \item it works only in PDF mode: so it works in pdflatex and lualatex, % but is disabled in xelatex. % \item it disables transparency features in the tikz package; therefore, % ctable checks if the tikz package is loaded and if so, disables its own % transparency with a warning. That helps only if you load tikz % \textit{before} ctable. % \end{compactenum} % % \DescribeKey{botcap} % put the caption at the bottom of the float instead of on top of it. % See also: |topcap|, |sidecap|. % % \DescribeKey{caption}\isarg{...} % table caption; the braces are needed only if your caption contains a % comma or an equals sign. % % \DescribeKey{cap}\isarg{...} % for a short caption to go to the \cs{listoftables}. Without the |cap| % option, the full caption will go into the \cs{listoftables}. If |cap| is % given an empty value, \textsl{and you have loaded the |caption| package}, % no entry in the \cs{listoftables} will be made. This may be useful, for % example, with the |continued| option. % % \DescribeKey{captionskip}\isarg{...} % moves the caption relative to the table; the default is |0ex|, which puts % captions at their default \LaTeX\ positions. For the standard \LaTeX\ % classes this means that a top caption's baseline at % |1ex| above the top rule position of the table and a bottom caption's % baseline at |4ex| below the bottom rule position. These dimensions may be % different for other classes or when other packages are included. The % |memoir| class and the |caption| package, for example, both typeset % captions differently, and the combination of both even differs from each % alone.\footnote{I did some measurements on the whitespace between the % caption and the top of the table with and without using the caption % package and/or the memoir class: standard LaTeX: 1ex; memoir: % 2.32ex; caption: 2.69ex; both memoir and caption: 2.68ex. For the % distances between bottom caption baselines and the table bottom I found, % respectively: 3.90ex, 3.41ex, 3.72ex and 3.74ex } Keep in mind that when % you use the |caption| package in the |memoir| class, |memoir|'s caption % commands are suspended and |caption|'s commands must be used. % % \DescribeKey{captionsleft} This option is defined for % \cs{setupctable} only, and it is effective only where the |sideways| option % is used. After |\setupctable{captionsleft}| all tables typeset with the % |sideways| option will have their captions at the left. % % \DescribeKey{captionsright} This option is defined for % \cs{setupctable} only, and it is effective only where the |sideways| option % is used. After |\setupctable{captionsright}| all tables typeset with the % |sideways| option will have their captions at the right. % % \DescribeKey{captionsinside} % This option is defined for \cs{setupctable} only, it is the default, and it is effective % only where the |sideways| option is used. After % |\setupctable{captionsinside}| all tables typeset with the |sideways| % option will have their captions at the left in one-sided documents. In % twosided documents, captions will be on the left for odd-numbered pages % and on the right for even-numbered pages. This is the default. % % \DescribeKey{center} % center the table in the available text width; this is the default. % See also: |left|, |right|. % % \DescribeKey{continued}\isarg{...} % if used, the table will be numbered the same as the previous table. If % used without an argument, the caption will be suffixed with ` % (continued)', if used with an argument, the suffix will be the argument. % % \DescribeKey{doinside}\isarg{...} % command to be run inside, just before the tabular or tabularx % environment. You can use this, for example, for the adjustment of the % font size with \cs{small}. % % \DescribeKey{figure} % produce a figure float instead of a table float. See also: |table|. % % \DescribeKey{footerwidth}\isarg{...} % Footnotes are typeset within the width of the table. When you use the % |mincapwidth| option, presumably because the table is very narrow, footnotes % are given the same width as the caption. With small footnotes this may not % be what you want; this option can be used to give the footnotes their own width. % Without an argument, they will be typeset within the width of the table. % % \DescribeKey{framebg}\isarg{r g b} % set the background color of the frame (the color inside the frame) to the % given triplet of \textsl{rgb}-values. The values should be numbers % between 0 and 1. The default is |1 1 1| (white). % % % \DescribeKey{framefg}\isarg{r g b} % set the foreground color of the frame (the rule color) to the given % triplet of \textsl{rgb}-values. The values should be numbers between 0 % and 1. The default is |0 0 0| (black). % % % \DescribeKey{framerule}\isarg{...} % draw a frame around the table with the given rule thickness. The default % is |0pt|, so that no frame will be seen. % % % \DescribeKey{framesep}\isarg{...} % set the distance between the frame and the table to the given dimension. % The default is |0pt|. % % % \DescribeKey{label}\isarg{...} % labels the float with \cs{label}. % % \DescribeKey{left} % left align the table in the available text width. See also: |center|, |right|. % % \DescribeKey{maxwidth}\isarg{...} % like the \textsl{width} option, but any |X| column specifiers will be % replaced with |l| if the resulting table width would thus stay within the % specified maximum width. This is especially useful where the \LaTeX\ % source is generated by a script. % % \DescribeKey{mincapwidth}\isarg{...} % sets the minimum width of the float. Without this option, the width is % set to that of the tabular, and the caption and footnotes are typeset % within that width. This may be a problem with very narrow tables; % |mincapwidth| can then be used to give the float a minimum width. The % tabular will be centered in it. If you don't want the footnotes to be affected % see the |footerwidth| option. % % \DescribeKey{nonotespar} % typeset footnotes in a table; this is the default. See also: |notespar|. % % \DescribeKey{nosideways} % undo the sideways option. See also: |sideways|. % % \DescribeKey{nostar} % use the un-starred versions of the |table| and |figure| environments; % this is the default % % \DescribeKey{nosuper} % in the footnote table, typeset footnote markers on the line, instead of % superscripted. % % \DescribeKey{notespar} % typeset footnotes in a paragraph instead of in a table. % % \DescribeKey{pos}\isarg{...} % float position, default: |tbp|. % % \DescribeKey{right} % right align the table in the available text width. % % \DescribeKey{sidecap} % put the caption at the side of the float. Currently, this works only if % you have loaded the |memoir| class, otherwise an error message is % generated. The parameters for the caption, such as its vertical % positioning, width and more, must be set with the appropriate |memoir| % commands. See also: |botcap|, |topcap|. % % \DescribeKey{sideways} % rotate table or figure by 90 degrees anticlockwise and put it on a % separate page. With the twoside option for the standard \LaTeX\ document % classes, rotation will be -90 on even pages, unless the options % |captionleft| or |captionsright| are used. If you use this option, the % |pos| option is not allowed. See also: |nosideways|, |captionsinside|. % % \DescribeKey{star} % use the starred versions of the |table| and |figure| environments, which % place the float over two columns when the |twocolumn| option or the % \cs{twocolumn} command is active. See also: |nostar|. % % \DescribeKey{super} % in the footnote table, typeset footnote markers as superscripts; this is % the default. See also: |nosuper|. % % \DescribeKey{table} % produce a table float (this is the default). See also: |figure|. % % \DescribeKey{topcap} % put the caption top of the float; this is the default. See also: |botcap|, |sidecap|. % % \DescribeKey{width}\isarg{...} % \REF{tabularx} will be used to typeset the table at the specified % width\,---\,one or more |X| column specifiers must be provided. % % \section{The width and maxwidth options} % When \LaTeX-sources containing tables are generated automatically by a % script, it is often not known in advance what the maximum size of an % |l|~column will be. A good solution for this is to use an |X|~specifier, % typesetting the table at the text width with the \REF{tabularx} package. % However, this will result in too much white space in cases where the % column contains small texts only. This problem can be solved by using % the maxwidth option instead of the width option. The |X|~specifiers will % then be replaced with |l| as long as the width of the resulting table % stays with the specified maximum width. % % \section{Tables wider than the text width} % When you make a table wider than \cs{textwidth}, it will extend in the right margin. % If it is a large table, occupying a whole page, you can use the geometry package % and surround your ctable call with |\newgeometry{width=...,margin=...}| and \cs{restoregeometry}. % However, both geometry commands imply \cs{clearpage}, so your table will appear on an otherwise % empty page. % % Alternatively, you can center the table on the paper, extending in both margins, by using the % option |doinside=\hspace*{}| with an appropriate negative |dimen>|. % % \section{Setting option defaults: setupctable} % Every call of \cs{ctable} resets the options to their defaults before evaluating the % first (optional) argument. So if you make two ctables: |\ctable[left,...| and % |\ctable[...|, the first will be left-aligned on the page, but the second, lacking % the |left| option, will be centered, because that is the default. If you want all % your tables left-aligned, it's more practical to change the default by calling % \DescribeMacro{\setupctable} % |\setupctable{left}|, either in the preamble or somewhere in the body. In latter % case only tables following the call will have their defaults changed. \par % \cs{setupctable} can set the defaults for all options except (of course) |caption|, % |cap|, and |label|. Actually, the initial option defaults are set by % calling \cs{setupctable} as follows: % \begin{verbatim} % \setupctable{ % captionskip=0pt, framerule=0pt, nostar, % center, framesep=0pt, pos=tbp, % continued=(continued), maxwidth=0pt, super, % doinside={}, mincapwidth=0pt, table, % framebg=1 1 1, nonotespar, topcap, % framefg=0 0 0, nosideways, width=0pt % } % \end{verbatim} % \section{Other commands}\label{other} % \DescribeMacro{\tnote}\oarg{label}\arg{footnote text}\\ % places {\footnotesize\textsuperscript{\normalfont\textit{label}}\,footnote text} % under the table. % This command can only be used in \cs{ctable}'s third argument, that % is: the foottable argument described above. % The label is optional, the default label is a single $a$. For more % detailed control, you can also replace this command with something % like |labeltext&footnotetext\NN|. % The footnotes are placed under the table, without a rule. % You therefore probably will want to use the \cs{LL} (last line) % command if you use footnotes. % \par % \DescribeMacro{\tmark}\oarg{label} % places the superscripted label in the table. It is equivalent with |$^{label}$|. % The label is optional, the default label is a single $a$. % \cs{tmark} may be used in captions, but only \textit{without} an argument. % \par % The newline generating commands are a combination of % \cs{tabularnewline} and zero or one of \REF{booktabs} \cs{toprule}, % \cs{midrule} or \cs{bottomrule}. These combinations have been made, and % short names have been defined, because source texts for complex % tables often become very crowded: % \par % \DescribeMacro{\NN} Normal Newline, generates just a normal new line. % An optional dimen parameter inserts extra vertical space under the % line. Is an alias for \cs{tabularnewline} % \par % \DescribeMacro{\FL} First Line, generates a new line and a thick % rule with some extra space under it. % An optional dimen parameter sets the line width; the default is 0.08em. % Is an alias for \cs{toprule} % \par % \DescribeMacro{\ML} Middle Line: generates a new line and a thin % rule with some extra space over and under it. % An optional dimen parameter sets the line width; the default is 0.05em. % Is an alias for |\tabularnewline\midrule| % \par % \DescribeMacro{\LL} Last Line: generates a new line and a thick % rule with some extra space over it. % An optional dimen parameter sets the line width; the default is 0.08em. % Is an alias for |\tabularnewline\bottomrule| % \par % These macros can be used outside \cs{ctable} constructs, that is: % in tabulars, longtables, et cetera. % \par % Finally, for completeness, here are some of \REF{booktabs}' commands % that may be useful: % \par % \DescribeMacro{\toprule} |\toprule[]| % where || is the optional thinkness of the rule. % \par % \DescribeMacro{\midrule} |\midrule[]|. % \par % \DescribeMacro{\bottomrule} |\bottomrule[]|. % \par % \DescribeMacro{\cmidrule} |\cmidrule[](){a-b}| % where || can be |r|, |l|, or |rl| % and the rule is drawn over columns |a| through |b|. % \par % \DescribeMacro{\morecmidrules} \cs{morecmidrules} % must be used to separate two successive cmidrules. % \par % \DescribeMacro{\addlinespace} |\addlinespace[]| % inserts extra space between rows. % \par % \DescribeMacro{\specialrule} % |\specialrule{}{}{}|. % \par % See the \REF{booktabs} documentation for details. % \newpage % \section{Examples} % Table~\ref{nowidth} is an example taken from the related package % \REF{threeparttable} by Donald Arseneau, with an extra footnote. % It was typeset with: % \color{vbgreen} % \begin{verbatim} % \ctable[ % cap = The Skewing Angles, % caption = The Skewing Angles ($\beta$) for % $\fam0 Mu(H)+X_2$ and $\fam0 Mu(H)+HX$~\tmark, % label = nowidth, % pos = h % ]{rlcc}{ % \tnote{for the abstraction reaction, % $\fam0 Mu+HX \rightarrow MuH+X$.} % \tnote[b]{1 degree${} = \pi/180$ radians.} % \tnote[c]{this is a particularly long note, showing that % footnotes are set in raggedright mode as we don't like % hyphenation in table footnotes.} % }{ \FL % & & $\fam0 H(Mu)+F_2$ & $\fam0 H(Mu)+Cl_2$ \ML % &$\beta$(H) & $80.9^\circ$\tmark[b] & $83.2^\circ$ \NN % &$\beta$(Mu) & $86.7^\circ$ & $87.7^\circ$ \LL % } % \end{verbatim} % \color{black} % \ctable[ % cap = The Skewing Angles, % caption = The Skewing Angles ($\beta$) for % $\fam0 Mu(H)+X_2$ and $\fam0 Mu(H)+HX$~\tmark, % label = nowidth, % pos = h % ]{rlcc}{ % \tnote{for the abstraction reaction, % $\fam0 Mu+HX \rightarrow MuH+X$.} % \tnote[b]{1 degree${} = \pi/180$ radians.} % \tnote[c]{this is a particularly long note, showing that % footnotes are set in raggedright mode as we don't like % hyphenation in table footnotes.} % }{ \FL % & & $\fam0 H(Mu)+F_2$ & $\fam0 H(Mu)+Cl_2$ \ML % &$\beta$(H) & $80.9^\circ$\tmark[b] & $83.2^\circ$ \NN % &$\beta$(Mu) & $86.7^\circ$ & $87.7^\circ$ \LL % } % Table~\ref{width} is an example with a width specification, % taken from the \REF{tabularx} documentation, with the vertical rules % removed. % By using the trimming parameters of the \REF{booktabs} \cs{cmidrule} % command, some of the horizontal splitting was regained. % The |left| option left aligns the table. It was typeset with: % \color{vbgreen} % \begin{verbatim} % \ctable[ % caption = Example with a specified width of 100mm, % label = width, % width = 100mm, % pos = ht, % left % ]{c>{\raggedright}Xc>{\raggedright}X}{ % \tnote{footnotes are placed under the table} % }{ \FL % \multicolumn{4}{c}{Example using tabularx} \ML % \multicolumn{2}{c}{Multicolumn entry!} & THREE & FOUR \NN % \cmidrule(r){1-2}\cmidrule(rl){3-3}\cmidrule(l){4-4} % one& % The width of this column depends on the width of the table.\tmark & % three& % Column four will act in the same way as column two, with the same width.\LL % } % \end{verbatim} % \color{black} % \ctable[ % caption = Example with a specified width of 100mm, % label = width, % width = 100mm, % pos = ht, % left % ]{c>{\raggedright}Xc>{\raggedright}X}{ % \tnote{footnotes are placed under the table} % }{ \FL % \multicolumn{4}{c}{Example using tabularx} \ML % \multicolumn{2}{c}{Multicolumn entry!} & THREE & FOUR \NN % \cmidrule(r){1-2}\cmidrule(rl){3-3}\cmidrule(l){4-4} % one& % The width of this column depends on the width of the % table.\tmark & % three& % Column four will act in the same way as % column two, with the same width. \LL % } % % Figures, even single ones, are always put in tabular cells. This is not % particularly handy for single pictures, but it eases the construction of % arrays of pictures, including sub-captions, delineation, and spacing. For a % small example, which also shows how you can simplify the construction of % figure arrays, see subsection~\ref{figureexample} on % page~\pageref{figureexample}. % % \section{Option examples} % In the following, small examples will be shown illustrating the effect of % options. In the left column the relevant part of the source is shown, in the % right column you see the result. In most cases you see a standard example on a % light yellow background, followed by one or more variations on a light blue % background. Where necessary, the example will show boxes to indicate the page % and the text body. % % \subsection{\ttfamily\bfseries center, left, right} % These options align the float in the page; the default is |center|: % \medskip\\ % \ROW{Y}{s02k}{02k} % \ROW{B}{s02l}{02l} % \ROW{B}{s02m}{02m} % % \subsection{\ttfamily\bfseries super, nosuper} % Footnote markers in |ctable| are typeset superscripted by default. Use the % |nosuper| option to place them on the base line: % \medskip\\ % \ROW{Y}{s07a}{07a} % \ROW{B}{s07b}{07b} % % \subsection{\ttfamily\bfseries notespar, nonotespar} % By default, footnotes in |ctable| are typeset in a table, one line per note. % This corresponds with the |nonotespar| option.You can also typeset them in a paragraph, % one after the other, by using the |notespar| option: % \medskip\\ % \ROW{Y}{s12a}{12a} % \ROW{B}{s12b}{12b} % % \subsection{\ttfamily\bfseries continued} % The |continued| option suffixes the caption with ` (continued)', and lowers the table % number by one, so that it obtains the same number as the previous table. % This option can be given an argument to replace the default suffix: % \medskip\\ % \ROW{Y}{s13a}{13a} % \ROW{B}{s13b}{13b} % \ROW{B}{s13c}{13c} % % \subsection{\ttfamily\bfseries mincapwidth} % |ctable| forces caption and footnotes to stay within the width of the table. % Sometimes, however, tables are so narrow, that this is not really what you want. % In such cases, use the |mincapwidth| option to give caption and footnotes some % extra room: % \medskip\\ % \ROW{Y}{s05a}{05a} % \ROW{B}{s05b}{05b} % \medskip % You can set |mincapwidth| to a large value, say \cs{hsize}, if you want a one-line % caption. Note, however, that this may influence the horizontal positioning of % the table: values larger than \cs{hsize} will move a centered table out of the % center, a value of \cs{hsize} will prevent the |left| and |right| options to do % their work, because the table is already captured between the left and right % margins. When footnotes are small, you may wish to undo the effect of the % |mincapwidth| option on them: % \medskip\\ % \ROW{B}{s05c}{05c} % \medskip % % \subsection{\ttfamily\bfseries maxwidth} % When \LaTeX-sources containing tables are generated automatically by a % script, it is often not known in advance what the maximum size of an |l| % column will be. A good solution for this is to use an |X| specifier, % typesetting the table at the text width with the \REF{tabularx} package. % However, this will result in too much white space in cases where the % column contains small texts only. This problem can be solved by using % the maxwidth option instead of the width option. The |X| specifiers will % then be replaced with |l| as long as the width of the resulting table % stays with the specified maximum width. % \medskip\\ % \ROW{Y}{s06a}{06a} % \ROW{B}{s06b}{06b} % % \subsection{\ttfamily\bfseries framerule} % The following examples show the use of frames and backgrounds. Every table % is typeset by |ctable| with a frame around it, but the frame is, by default, % drawn with a zero width line, and is therefore invisible. You can make it % visible by either changing the linewidth to a positive value or by giving it a % background color, which will be used to fill the frame. % % Here is a simple table without a frame, followed by one with a red, |1pt| thick % frame: % \medskip\\ % \ROW{Y}{s08a}{08a} % \ROW{B}{s08b}{08b} % \medskip % As you see, the frame fits closely to the first (\cs{FL}) and last (\cs{LL}) table % lines. This can be a reason to either remove those lines, or to introduce some % whitespace between the frame and the table with the |framesep| option: % \medskip\\ % \ROW{B}{s09b}{09b} % \medskip % And finally, we could also frame the table by giving it a, say, yellow backgound % instead of a red frame line, or even do both: % \medskip\\ % \ROW{Y}{s10a}{10a} % \ROW{B}{s10b}{10b} % % \newpage % \subsection{\ttfamily\bfseries captionskip} % The distance between a top caption and the table is \texttt{2ex}, % but it can be varied with \texttt{captionskip}: % \medskip\\ % \ROW{Y}{s03a}{03a} % \ROW{B}{s03b}{03b} % \medskip % This works for bottom caption, too: % \medskip\\ % \ROW{Y}{s04a}{04a} % \ROW{B}{s04b}{04b} % % \subsection{\ttfamily\bfseries figure, botcap}\label{figureexample} % By default, |ctable| generates a table float, but with the |figure| option, a % figure float is generated instead. The caption stays on top, so if you are % accustomed to have bottom caption for your figures, you will probably also need % the |botcap| option: % \medskip\\ % \ROW{Y}{s01a}{01a} % \ROW{B}{s01b}{01b} % % \newpage % \subsection{\ttfamily\bfseries doinside} % The argument of doinside is supposed to be a command to be run inside, % just before the tabular or tabularx environment. You can use this, for % example, for the adjustment of the font size with \cs{small}: % \medskip\\ % \ROW{Y}{s14a}{14a} % Put your descriptive text here % \StopEventually{^^A % \newpage % \section{History} % \begin{longtable}{@{}p{8mm}p{127mm}@{}} % v1.00 & 2000-06-01\\ % & - first release.\\ % v1.01 & 2001-03-17\\ % & - making use of booktabs package\\ % v1.02 & 2002-06-24\\ % & - using keyval to reduce args to 4\\ % v1.03 & 2002-07-16\\ % & - many syntactic corrections, thanks to Johannes Braams\\ % v1.04 & 2003-08-11\\ % & - caption, if empty, will not be typeset\\ % & - rotate option added\\ % & - star option added to use table* and figure*\\ % & - environments\\ % v1.05 & 2003-10-03\\ % & - maxwidth option added\\ % v1.06 & 2004-03-20\\ % & - left, right and center options added\\ % & - frame{sep,rule,fg,bg} options added\\ % & - error in width-setting corrected\\ % v1.06a& 2004-04-01\\ % & - made setting fboxsep and fboxrule only temporary\\ % & - removed superfluous space after tabulars\\ % v1.06b& 2004-06-19\\ % & - added several \% at eol to remove superfluous whitespace occurring sometimes\\ % v1.07 & 2005-08-09\\ % & - added option sideways, option rotate now obsolete\\ % & - added option captionskip\\ % v1.08 & 2006-04-10\\ % & - standardized file setup following dtxtut.pdf\\ % & - mincapwidth option added\\ % & - moved newdimen definition outside ctable macro\\ % v1.09 & 2007-03-04\\ % & - added option nosuper\\ % & - corrected incorrect positioning when table is wider than mincapwidth\\ % v1.10 & 2007-08-17\\ % & - footnote markers now stay superscript with nosuper\\ % & - documentation: added many examples for the options\\ % & - corrected some unwanted white space in captions\\ % & - caption package included to correct booktabs errors in caption position\\ % & - captionskip option redefined: 0pt value now corresponds to LaTeX default\\ % v1.11 & 2007-09-07\\ % & - added some percent signs at EOL to prevent whitespace\\ % & - removed xspace usage - caused overfull badness\\ % v1.12 & 2008-04-12\\ % & option notespar added\\ % v1.13 & 2008-05-01\\ % & - cap option with empty argument will not be inserted in lot/lof\\ % & - added option continued, for continuation tables\\ % v1.14 & 2009-09-15\\ % & - nosuper propagation to later tables prohibited\\ % & - added option doinside\\ % & - use of (obsolete) carom.sty for docs discontinued\\ % & - empty labels not created\\ % & - newcolumntype warnings removed\\ % & - caption package not needed anymore\\ % v1.15 & 2009-09-17\\ % & - removed whitespace before tables\\ % & - corrected marginpars in the documentation\\ % v1.16 & 2010-06-26\\ % & - option cap={} did not suppress lot/lof entry\\ % & - notespar option now generates fully justified notes\\ % v1.17 & 2010-10-30\\ % & - doinside option propagated in subsequent ctable calls\\ % v1.18 & - 2011-04-15\\ % & - added setupctable for option defaults\\ % & - added complement for several options (topcap, nosideways, et cetera)\\ % v1.19 & 2011-05-01\\ % & - sideways option did not work anymore; corrected\\ % v1.20 & 2011-08-24\\ % & - added options captionsleft, captionsright, captionsinside\\ % v1.21 & 2011-09-05\\ % & - better documentation for sideways, captionsleft/right/inside options\\ % v1.22 & 2012-05-25\\ % & - allow empty lines in last (tabular) argument\\ % & - corrected error from hyperref's nameref calls (thanks Marco Daniel!)\\ % v1.23 & 2012-05-28\\ % & - footerwidth option added\\ % v1.24 & - 2013-04-28\\ % & - require xcolor instead of color\\ % & - added option bgopacity\\ % & - added option sidecap (for memoir only)\\ % v1.25 & 2013-05-24\\ % & - url's to CTAN corrected\\ % v1.26 & 2013-06-15\\ % & - footerwidth option was inactive when notespar option was active\\ % v1.27 & - 2013-12-19\\ % & - label option did not work with side caption\\ % & - disable transparency with warning if tikz package loaded\\ % v1.28 & 2014-02-20\\ % & - added percent characters at EOLs causing whitespace\\ % v1.29 & 2014-04-20\\ % & - reorganized inst script\\ % v1.30 & 2015-08-29\\ % & - tikz' transparency got broken when tikz loaded after ctable\\ % & - removed overfull hboxes from documentation\\ % v1.31 & 2015-10-03\\ % & - documentation: comments about tmark in captions\\ % & - documentation: more info about caption skips\\ % & - use expandonce from etoolbox\\ % & - use AtBeginDocument, not AtEndPreamble from etoolbox (problems with tikz)\\ % v1.32 & 2025-07-10\\ % & - help argument missing in PackageError calls\\ % & - simutaneous use of pos and sideways options incorrectly tested\\ % & - now contained in 1 self-extracting file\\ % \end{longtable} % \newpage % \PrintIndex % } % \section{Implementation} % \subsection{Initialization} % \begin{macrocode} %<*package> \RequirePackage{ifpdf,etoolbox,xcolor,xkeyval,array,tabularx,booktabs,rotating} % \end{macrocode} % The transparency package works only in pdf mode, and if the tikz package is not loaded; % otherwise define a dummy \cs{transparent} and issue a warning. % \begin{macrocode} \ifpdf \@ifpackageloaded{tikz}{ \PackageWarningNoLine{ctable}{ Transparency disabled: incompatible with tikz package } \def\transparent#1{} }{ \RequirePackage{transparent} } \else \PackageWarningNoLine{ctable}{\MessageBreak Transparency disabled: pdfTeX is not running in PDF mode } \def\transparent#1{} \fi % \end{macrocode} % We need to know if the user has loaded tikz after ctable. If so, we have % loaded the transparent package already, which then will disturb the tikz % definitions, so we must quit with an error message. % Some warnings depend on whether the caption package is loaded or not. % Here a flag is set to remember that. % \begin{macrocode} \newif\if@CTcaptionloaded \AtBeginDocument{ \makeatletter \@ifpackageloaded{tikz}{ \@ifpackageloaded{transparent}{ \PackageError{ctable}{You must load ctable after tikz}{} } }{} \@ifpackageloaded{caption}{\@CTcaptionloadedtrue}{\@CTcaptionloadedfalse} \makeatother } \def\NN{\tabularnewline} \def\FL{\toprule} \def\ML{\NN\midrule} \def\LL{\NN\bottomrule} \def\@dfltCTfgcolor#1 #2 #3={\definecolor{@dfltCTframefg}{rgb}{#1,#2,#3}} \def\@dfltCTbgcolor#1 #2 #3={\definecolor{@dfltCTframebg}{rgb}{#1,#2,#3}} \def\@CTfgcolor#1 #2 #3={% \definecolor{@CTframefg}{rgb}{#1,#2,#3} \def\@CTfgactual{@CTframefg}} \def\@CTbgcolor#1 #2 #3={% \definecolor{@CTframebg}{rgb}{#1,#2,#3} \def\@CTbgactual{@CTframebg}} \def\@CTtextsuperscript#1{% \ifx\@CTsuper\@CTtrue\@textsuperscript{#1}\else{\footnotesize#1}\fi } % \end{macrocode} % define a true and a false value % \begin{macrocode} \def\@CTtrue{1} \def\@CTfalse{0} % \end{macrocode} % normally we do nothing special inside the float, but that can be changed with the doinside option % \begin{macrocode} \def\@CTdoinside{\relax} % \end{macrocode} % Need three booleans to remember: % if we use tabularx, % if we are running in the memoir class, % \begin{macrocode} \newif\if@CTusex \newif\if@CTinmemoir \@ifclassloaded{memoir}{\@CTinmemoirtrue}{\@CTinmemoirfalse} % \end{macrocode} % Need lots of dimens and their defaults % \begin{macrocode} \newdimen\@CTframesep \newdimen\@dfltCTframesep \newdimen\@CTframerule \newdimen\@dfltCTframerule \newdimen\@CTwidth \newdimen\@dfltCTwidth \newdimen\@CTcaptionskip \newdimen\@dfltCTcaptionskip \newdimen\@CTmaxwidth \newdimen\@dfltCTmaxwidth \newdimen\@CTmincapwidth \newdimen\@dfltCTmincapwidth \newdimen\@CTfooterwidth \newdimen\@dfltCTfooterwidth \newdimen\@CTw % the final width \newdimen\@CTfloatwidth \newdimen\@CToldsep \newdimen\@CToldrule % \end{macrocode} % Allocate box registers so that we can determine the widths of the % tables % \begin{macrocode} \newbox\CT@t % tabular saved and measured here % \end{macrocode} % Option setting commands from keyval. The table position (here, top, % bottom, page) gets a special treatment, since \LaTeX\ does not expand % commands there. So instead of putting things like \texttt{tbp} in a % command like |\@CTbegin| we put % |\begin{table}[tbp]| in it. % \begin{macrocode} \define@key{suCT}{bgopacity}{\def\@dfltCTbgopacity{#1}} \define@key{suCT}{botcap}[]{\let\@dfltCTbotcap\@CTtrue} \define@key{suCT}{captionsinside}[]{\def\rot@LR{-1} \if@twoside\@rot@twosidetrue \else\@rot@twosidefalse\fi} \define@key{suCT}{captionsleft}[]{\@rot@twosidefalse\def\rot@LR{-1}} \define@key{suCT}{captionsright}[]{\@rot@twosidefalse\def\rot@LR{0}} \define@key{suCT}{captionskip}{\@dfltCTcaptionskip=#1} \define@key{suCT}{center}[]{\let\@dfltCTalign\centering} \define@key{suCT}{continued}{\def\@dflttextcontinued{#1}} \define@key{suCT}{doinside}{\def\@dfltCTdoinside{#1}} \define@key{suCT}{figure}[]{\def\@dfltCTtaborfig{figure}} \define@key{suCT}{framebg}{\@dfltCTbgcolor#1=} \define@key{suCT}{framefg}{\@dfltCTfgcolor#1=} \define@key{suCT}{framerule}{\@dfltCTframerule=#1} \define@key{suCT}{framesep}{\@dfltCTframesep=#1} \define@key{suCT}{left}[]{\let\@dfltCTalign\raggedright} \define@key{suCT}{maxwidth}{\@dfltCTmaxwidth=#1} \define@key{suCT}{mincapwidth}{\@dfltCTmincapwidth=#1} \define@key{suCT}{footerwidth}[-1pt]{\@dfltCTfooterwidth=#1} \define@key{suCT}{nonotespar}[]{\let\@dfltCTnotespar\@CTfalse} \define@key{suCT}{nosideways}[]{\let\@dfltCTsideways\empty} \define@key{suCT}{nostar}[]{\def\@dfltCTstarred{}} \define@key{suCT}{nosuper}[]{\let\@dfltCTsuper\@CTfalse} \define@key{suCT}{notespar}[]{\let\@dfltCTnotespar\@CTtrue} \define@key{suCT}{pos}{\def\@dfltCTpos{#1}} \define@key{suCT}{right}[]{\let\@dfltCTalign\raggedleft} \define@key{suCT}{sideways}[]{\def\@dfltCTsideways{sideways}} \define@key{suCT}{star}[]{\def\@dfltCTstarred{*}} \define@key{suCT}{super}[]{\let\@dfltCTsuper\@CTtrue} \define@key{suCT}{table}[]{\def\@dfltCTtaborfig{table}} \define@key{suCT}{topcap}[]{\let\@dfltCTbotcap\@CTfalse} \define@key{suCT}{width}{\@dfltCTwidth=#1} \newcommand{\setupctable}[1]{\setkeys{suCT}{#1}} \setupctable{ bgopacity=1, captionskip=0pt, center, continued=(continued), doinside={}, footerwidth=0pt, framebg=1 1 1, framefg=0 0 0, framerule=0pt, framesep=0pt, maxwidth=0pt, mincapwidth=0pt, nonotespar, nosideways, nostar, super, table, topcap, width=0pt, } \define@key{CT}{bgopacity}{\def\@CTbgopacity{#1}} \define@key{CT}{botcap}[]{\let\@CTbotcap\@CTtrue} \define@key{CT}{captionskip}{\@CTcaptionskip=#1} \define@key{CT}{caption}{\def\@CTcaption{#1}} \define@key{CT}{cap}{\def\@CTcap{#1}} \define@key{CT}{center}[]{\let\@CTalign\centering} \define@key{CT}{continued}[\@dflttextcontinued]{\def\@CTcontinued{#1}} \define@key{CT}{doinside}{\def\@CTdoinside{#1}} \define@key{CT}{figure}[]{\def\@CTtaborfig{figure}} \define@key{CT}{framebg}{\@CTbgcolor#1=} \define@key{CT}{framefg}{\@CTfgcolor#1=} \define@key{CT}{framerule}{\@CTframerule=#1} \define@key{CT}{framesep}{\@CTframesep=#1} \define@key{CT}{label}{\def\@CTlabel{#1}} \define@key{CT}{left}[]{\let\@CTalign\raggedright} \define@key{CT}{maxwidth}{\@CTmaxwidth=#1} \define@key{CT}{mincapwidth}{\@CTmincapwidth=#1} \define@key{CT}{footerwidth}[-1pt]{\@CTfooterwidth=#1} \define@key{CT}{nonotespar}[]{\let\@CTnotespar\@CTfalse} \define@key{CT}{nosideways}[]{\let\@CTsideways\empty} \define@key{CT}{nostar}[]{\def\@CTstarred{}} \define@key{CT}{nosuper}[]{\let\@CTsuper\@CTfalse} \define@key{CT}{notespar}[]{\let\@CTnotespar\@CTtrue} \define@key{CT}{pos}{\def\@CTpos{#1}\def\@CTbegin{\@CTbeg[#1]}} \define@key{CT}{right}[]{\let\@CTalign\raggedleft} \define@key{CT}{sidecap}[]{\let\@CTbotcap\undefined} \define@key{CT}{sideways}[]{\def\@CTsideways{sideways}} \define@key{CT}{star}[]{\def\@CTstarred{*}} \define@key{CT}{super}[]{\let\@CTsuper\@CTtrue} \define@key{CT}{table}[]{\def\@CTtaborfig{table}} \define@key{CT}{topcap}[]{\let\@CTbotcap\@CTfalse} \define@key{CT}{width}{\@CTwidth=#1} % \end{macrocode} % A caption will only be generated if the \textsl{caption} option was used, with a % non-empty value. If so, it goes in the lot/lof, unless the \textsl{cap} option % specified a different (probably shorter) value for it. A \textsl{cap} option with % an empty value inhibits a tof/lof entry. % The \cs{expandonce} trick below is from Marco Daniel. % It expands the arguments of \cs{caption} % so that the hyperref command \cs{nameref} works OK. % See http://tex.stackexchange.com/questions/57396/ % Note that, in captions, |tmark| may only be used without its optional argument. % \begin{macrocode} \def\@CTCaption{ \ifx\@CTcaption\empty\else \def\@CTcaptionarg{\ifx\@CTlabel\empty\else\label{\@CTlabel}\fi \@CTcaption\ \@CTcontinued\strut} \begingroup \ifx\@CTcap\empty \edef\x{\endgroup\noexpand\caption[]{\expandonce\@CTcaptionarg}} \else \edef\x{\endgroup\noexpand\caption[\expandonce\@CTcap]% {\expandonce\@CTcaptionarg}} \fi \x \fi } % \end{macrocode} % Need to redefine X columntype, but the array package would generate a warning. % So first set the type to be redefined to \cs{undefined} to suppress the warning. % Save the standard X type once in the new type Y % \begin{macrocode} \newcolumntype{Y}{X} \def\@CTXcolumntype#1{% \let\NC@find@X\undefined \newcolumntype{X}{#1}% } \long\def\@CTframe#1#2#3{% \@CToldsep\fboxsep\fboxsep\@CTframesep% \@CToldrule\fboxrule\fboxrule\@CTframerule% \transparent{\@CTbgopacity}% \fcolorbox{#1}{#2}{\fboxsep\@CToldsep\fboxrule\@CToldrule\transparent{1}#3}% } \newcommand{\tnote}[2][a]{% \ifx\@CTnotespar\@CTtrue% \@CTtextsuperscript{\normalfont\textit{#1}}\,#2 \else% \hbox{\@CTtextsuperscript{\normalfont\textit{#1}}}\NN \fi } \newcommand{\tmark}[1][a]{% \hbox{\textsuperscript{\normalfont\textit{#1}}}} \newdimen\@CTcurftwidth \newcommand{\ctable}[4][]{% \let\@CTtaborfig \@dfltCTtaborfig \let\@CTalign \@dfltCTalign \let\@CTsideways \@dfltCTsideways \let\@CTcontinued \empty \let\@CTpos \@dfltCTpos \let\@CTcaption \empty \let\@CTcap \undefined \let\@CTlabel \empty \let\@CTbotcap \@dfltCTbotcap \let\@CTstarred \@dfltCTstarred \let\@CTsuper \@dfltCTsuper \let\@CTnotespar \@dfltCTnotespar \let\@CTdoinside \@dfltCTdoinside \let\@CTbgopacity \@dfltCTbgopacity \@CTframerule \@dfltCTframerule \@CTcaptionskip \@dfltCTcaptionskip \@CTframesep \@dfltCTframesep \@CTwidth \@dfltCTwidth \@CTmaxwidth \@dfltCTmaxwidth \@CTmincapwidth \@dfltCTmincapwidth \@CTfooterwidth \@dfltCTfooterwidth \def\@CTfgactual {@dfltCTframefg}% \def\@CTbgactual {@dfltCTframebg}% \def\@CTbeg {\begin{\@CTsideways\@CTtaborfig\@CTstarred}}% \def\@CTbegin {\@CTbeg}% \def\@CTend {\end{\@CTsideways\@CTtaborfig\@CTstarred}}% \setkeys{CT}{#1}% % \end{macrocode} % Make the short caption equal to the caption if it has not been defined % \begin{macrocode} \ifx\@CTcap\undefined\let\@CTcap\@CTcaption\fi % \end{macrocode} % Issue a warning if the short caption is empty and the caption package is not loaded % \begin{macrocode} \ifx\@CTcap\empty \if@CTcaptionloaded\else \PackageWarningNoLine{ctable} {\MessageBreak An empty cap= option prevents lot/loc entry only \MessageBreak if the caption package is loaded! } \fi \fi % \end{macrocode} % Currently, the sidecap option can only be used from within the memoir class; % here we test if memoir is loaded: % \begin{macrocode} \if@CTinmemoir\else \ifx\@CTbotcap\undefined \PackageError{ctable}% {sidecap option not available here}% {\MessageBreak You can, currently, use the sidecap option only with \MessageBreak memoir documents. Use topcap or botcap only. } \fi \fi % \end{macrocode} % It makes no sense to use \textsl{width} together with \textsl{maxwidth} or % \textsl{pos} together with \textsl{sideways} % \begin{macrocode} \ifdim\@CTwidth=0pt\else \ifdim\@CTmaxwidth=0pt\else \PackageError{ctable} {width and maxwidth options are mutually exclusive} {\MessageBreak You may not use the width and maxwidth options together. \MessageBreak Use either width or maxwidth. } \fi \fi \ifx\@CTpos\undefined\else \ifx\@CTsideways\empty\else \PackageError{ctable} {pos and sideways options are mutually exclusive} {\MessageBreak You may not use the pos and sideways options together. \MessageBreak Rotated tables and figures appear on a separate page. } \fi \fi % \end{macrocode} % It makes no sense to label a captionless table, because the label can't % be placed, leaving the user wondering why references to the table get a ?? % \begin{macrocode} \ifx\@CTcaption\empty \ifx\@CTlabel\empty\else \PackageError{ctable} {label option used in captionless table} {\MessageBreak You may not label a captionless table. \MessageBreak Such a label can't be referenced. } \fi \fi % \end{macrocode} % save the table contents in a box, so we can determine its width, % initially, save the table typeset with the tabular environment: % \begin{macrocode} \sbox\CT@t{% \@CTXcolumntype{l}% temporarily make type X = l \@CTframe{\@CTfgactual}{\@CTbgactual}{% \@CTdoinside \begin{tabular}{#2} #4% \end{tabular}% }% }% % \end{macrocode} % then look if we'll need the tabularx environment: % \begin{macrocode} \@CTusexfalse \ifdim\@CTmaxwidth=0pt \ifdim\@CTwidth=0pt \else \@CTusextrue \fi \else \ifdim\wd\CT@t>\@CTmaxwidth \@CTusextrue \fi \fi % % if so, replace tabular with tabularx: % \if@CTusex \sbox\CT@t{% \@CTXcolumntype{Y}% restore X \@CTframe{\@CTfgactual}{\@CTbgactual}{% \@CTdoinside \begin{tabularx}{\ifdim\@CTwidth>0pt\@CTwidth\else\@CTmaxwidth\fi}{#2} #4% \end{tabularx}% }% }% \fi % \end{macrocode} % the |CT@t| box now contains the table as we want to typeset it; % determine its width: % \begin{macrocode} \@CTw=\wd\CT@t % \end{macrocode} % Now find the width of the float, |\@CTfloatwidth|; everything in it will % be centered within that width. % Normally we'll use the width of the table, |\@CTw|, but if the % mincapwidth, |\@CTmincapwidth| was set wider than the table, that will be used: % \begin{macrocode} \@CTfloatwidth=\ifdim\@CTmincapwidth>\@CTw \@CTmincapwidth \else \@CTw \fi % \end{macrocode} % |\@CTbegin| is now defined as something like |\begin{table}[tbp]|. % \begin{macrocode} \@CTbegin \ifx\@CTcontinued\empty\else\addtocounter{\@CTtaborfig}{-1}\fi \@CTalign \begin{minipage}{\@CTfloatwidth}\parindent0pt \ifx\@CTbotcap\@CTfalse\@CTCaption\vskip\@CTcaptionskip\fi \ifx\@CTbotcap\undefined% \begin{sidecaption}[\@CTcap]{\@CTcaption}[\@CTlabel] \fi \centering{\usebox\CT@t}% insert the tabular \def\@CTfootnotes{#3}% \ifx#3\empty\else{% append footnotes, if any % \end{macrocode} % Footnotes: if the |footerwidth| is 0pt (the default), typeset the footer as % wide as the caption (which may be wider than the table because of the % |mincapwidth| option); if it is -1pt (because |footerwidth| was set without an argument) % make it as wide as the table; otherwise, give it the width set by the % |footerwidth| option. % \begin{macrocode} \@CTcurftwidth=\ifdim\@CTfooterwidth=-1pt\@CTw\else \ifdim\@CTfooterwidth=0pt\hsize\else \@CTfooterwidth\fi\fi \footnotesize \ifx\@CTnotespar\@CTtrue% \\[.2ex] \begin{minipage}{\@CTcurftwidth}% #3% \end{minipage}% \else% \\ \begin{tabularx}{\@CTcurftwidth}{r@{\,}>{\raggedright}X} #3% \end{tabularx}% \fi } \fi \ifx\@CTbotcap\undefined\end{sidecaption}\fi \ifx\@CTbotcap\@CTtrue\vskip\@CTcaptionskip\@CTCaption\fi \end{minipage} \@CTend } \endinput % % \end{macrocode} %\Finale