% \iffalse
%
%    tablists.dtx - tabulated list of short items.
%    (c) 2007, 2008 Olga Lapko (Lapko.O@g23.relcom.ru)
%
%    This program is provided under the terms of the
%    LaTeX Project Public License distributed from CTAN
%    archives in directory macros/latex/base/lppl.txt.
%
% \fi
%
% \iffalse
%<*driver>
\ProvidesFile{tablists.dtx}
%</driver>
%<package>\NeedsTeXFormat{LaTeX2e}[1999/12/01]
%<package>\ProvidesPackage{tablists}
%<*package>
    [2009/08/04 v0.0e (beta) Tabulated list of short items]
%</package>
%
%<*batchfile>
\begingroup

\input docstrip.tex

\keepsilent
\askforoverwritefalse

\generate{\file{tablists.sty}{\from{tablists.dtx}{package}}}

\endgroup
%</batchfile>
%
%<*driver>
\documentclass{ltxdoc}

\usepackage{ifpdf}
\ifpdf
  \usepackage{mathptmx,courier}
  \usepackage[scaled=0.90]{helvet}
  \addtolength\marginparwidth{15pt}
\fi

\usepackage{paralist}
\usepackage{makecell}
\usepackage{amsthm}
\newtheorem{theorem}{Theorem}
\usepackage{tablists}
\IfFileExists{hyperref.sty}{\usepackage{hyperref}}{}
\IfFileExists{listpen.sty}{\usepackage{listpen}}{}
\providecommand\RestoreSpaces{\bigskip}
\EnableCrossrefs
\CodelineIndex
\RecordChanges
\makeatletter
\@beginparpenalty10000
\widowpenalty10000
\clubpenalty10000
\makeatother
\providecommand*{\file}[1]{\texttt{#1}}
\providecommand*{\package}[1]{\textsf{#1}}
\providecommand*{\cls}[1]{\textsf{#1}}
\providecommand*{\env}[1]{\texttt{#1}}

\OnlyDescription
\begin{document}
  \DocInput{tablists.dtx}
  \PrintChanges
\end{document}
%</driver>
% \fi
%
% \CheckSum{493}
%
% \GetFileInfo{tablists.dtx}
%
% \DoNotIndex{\newcommand,\newenvironment}
%
%
% \title{The \textsf{tablists} package\thanks{This
%          file has version number \fileversion,
%          last revised \filedate.}}
%   \author{%
%   Olga Lapko\\
%   {\tt Lapko.O@g23.relcom.ru} }
%   \date{\filedate}
%   \maketitle
%   \begin{abstract}
% This package gives variant of environment for creating of list of short
% items in the way of tabular alignment. That could be useful for list of
% exercises in math educational literature.  It allows to build one-level
% and two-level tabulated lists.
%   \end{abstract}
%
% \tableofcontents
%
%\newpage
% \section{Building Commands}
%
% \DescribeMacro{tabenum}
% \DescribeMacro{\tabenumitem}
% \DescribeMacro{\item}
% The \env{tabenum} environment prints short items aligned in columns.
%
% Each item starts with |\tabenumitem| command.
% First example of \env{tabenum} list---please note that you may set optional
% argument in the same way as in modified environments from \package{enumerate}
% or \package{paralist} packages:
%\par\begin{small}%
%\begin{verbatim}
%\begin{tabenum}[\bfseries1)]%
%\tabenumitem
%$z=\displaystyle\frac xy$;
%\tabenumitem
%$2^x=9;$\cr
%
%\tabenumitem
%$3^{2x+3}=16 $;
%\tabenumitem
%$z=2x^2+4y^2$;\par
%\tabenumitem
%$u=\sqrt{x^2+y^2+z^2}$;
%\tabenumitem
%$v=gt+\displaystyle\frac{g}{4}t$;\\[1ex]
%\tabenumitem
%$u=2^{5x-3y+z}$;
%\tabenumitem
%$w=(v+7)^2+(u-3)^2$;
%
%
%\tabenumitem
%$5^x=\displaystyle\frac{4}{3} ;$
%\tabenumitem
%$z=(x+1)^2+y^2$;\\*
%\tabenumitem
%$2+5+8+ \ldots +(3n+2)=155$, $n\in \mathrm{N};$
%\tabenumitem
%$t=5u^2+8v^2$;
%\end{tabenum}
%\end{verbatim}
%\end{small}
% \begin{tabenum}[\bfseries1)]%
% \tabenumitem
% $z=\displaystyle\frac xy$;
% \tabenumitem
% $2^x=9;$\cr
%
% \tabenumitem
% $3^{2x+3}=4 $;
% \tabenumitem
% $z=2x^2+4y^2$;\par
% \tabenumitem
% $u=\sqrt{x^2+y^2+z^2}$;
% \tabenumitem
% $v=gt+\displaystyle\frac{g}{4}t$;\\[1ex]
% \tabenumitem
% $u=2^{5x-3y+z}$;
% \tabenumitem
% $w=(v+7)^2+(u-3)^2$;
%
%
% \tabenumitem
% $5^x=\displaystyle\frac{4}{3} ;$
% \tabenumitem
% $z=(x+1)^2+y^2$;\\*
% \tabenumitem
% $2+5+8+ \ldots +(3n+2)=155$, $n\in \mathrm{N};$
% \tabenumitem
% $t=5u^2+8v^2$;
% \end{tabenum}
%
% You may see that empty line (or |\par| command), |\\| command and |\cr|
% do the same: start a new row. The |\\| macro works like in array environment
% and allows optional argument with vertical correction.
% (Also the |\\*| command suppresses breaking between pages, see next example.)
%
% Please note that two or more |\par|'s
% |\cr|'s  or |\\|'s (and also any combination of these three commands)
% create additional empty lines.
%
% You may use the |\item|
% macro instead of |\tabenumitem| in this \env{tabenum} environments (see next examples).
%
% \DescribeMacro{\notabenumitem}
% \DescribeMacro{\noitem}
% \DescribeMacro{\skipitem}
% On the next step you can wish to do the list like before more compact. The
% |\multicolumn| does not work here correctly\footnote{
%   Also the plain \TeX's commands like \cs{omit} and \cs{span}/\cs{multispan} commands,
%   I think, need too complex code.}. At first you may use plain \TeX's
% command |\hidewidth| to hide width of widest column entry; then you may use
% other variant of |\tabenumitem|(|\item|) command---|\notabenumitem|(|\noitem|)---%^^A
% this command increases list entry, but does not create a new column;
% third command |\skipitem| allows you to skip
% one \env{tabenum} column\footnote{The \env{tabenum} column includes two columns:
% it works like \texttt{rl} columns in \env{tabular} environment. Thus, \cs{skipitem}
% equals to \texttt{\&\&} combination.}.
% Next example show usage of these three commands:
%\par\begin{small}%
%\begin{verbatim}
%\begin{tabenum}[\bfseries1)]%
%\item
%$z=\displaystyle\frac xy$;
%\noitem
%$2^x=9;$
%\item
%$3^{2x+3}=4 $.
%\item
%$z=2x^2+4y^2$;\nopagebreak
%
%\item
%$u=\sqrt{x^2+y^2+z^2}$;
%\item
%$v=gt+\displaystyle\frac{g}{4}t$,
%\item
%$u=2^{5x-3y+z}$.\cr
%\item
%$w=(v+7)^2+(u-3)^2$;
%\item
%$5^x=\displaystyle\frac{4}{3} ;$
%\item
%$z=(x+1)^2+y^2$;\\*
%\item
%$2+5+8+ \ldots +(3n+2)=155$,
%   $n\in \mathrm{N};$\hidewidth\skipitem
%\item
%$t=5u^2+8v^2$;
%\end{tabenum}
%\end{verbatim}
%\end{small}%
% \begin{tabenum}[\bfseries1)]%
% \item\label{tabenum:I:1}
% $z=\displaystyle\frac xy$;
% \noitem\label{tabenum:I:2}
% $2^x=9;$
% \item
% $3^{2x+3}=4 $.
% \item
% $z=2x^2+4y^2$;\nopagebreak
%
% \item
% $u=\sqrt{x^2+y^2+z^2}$;
% \item
% $v=gt+\displaystyle\frac{g}{4}t$,
% \item
% $u=2^{5x-3y+z}$.\cr
% \item
% $w=(v+7)^2+(u-3)^2$;
% \item
% $5^x=\displaystyle\frac{4}{3} ;$
% \item
% $z=(x+1)^2+y^2$;\\*
% \item\label{tabenum:I:11}
% $2+5+8+ \ldots +(3n+2)=155$, $n\in \mathrm{N};$\hidewidth\skipitem
% \item
% $t=5u^2+8v^2$;
% \end{tabenum}
% The items \ref{tabenum:I:1} and \ref{tabenum:I:2} were joined in one column: the item \ref{tabenum:I:2}
% used |\noitem| (|\notabenumitem|) command. The item \ref{tabenum:I:11} occupies two columns,
% so it uses the |\hidewidth| (hides item width) and |\skipitem| (skips column of next item) commands.
%
%
% \subsection{Spacing}
%
% Vertical spaces around tabulated list are equal to the list ones |\topsep+\partopsep|.
%
% Space between rows depends on the |\jot| value, like in \package{amsmath} environments
% like \env{align}, \package{gather} etc.
%
% \DescribeMacro{\tabenumsep}
% The horizontal spacing between items of list. It defined like:
% \begin{quote}
% |\renewcommand\tabenumsep{\hskip1em}|
% \end{quote}
% The |\labelsep| parameter is used after item number.
%
% \DescribeMacro{\tabenumindent}
% The |\tabenumindent| command sets left margin of \env{tabenum} environment.
% It can be defined like horizontal space/skip or text,
% for example:
% \begin{quote}
% |\renewcommand\tabenumindent{\hskip\parindent}|
% \end{quote}
% or
% \begin{quote}
% |\renewcommand\tabenumindent{Word }|
% \end{quote}
% That could be useful also
% inside, e.g., a proper list environments like \env{enumerate} or \env{itemise}
% for corrections of left margins.
%
% \subsection{The \env{tabenum} environment inside a proper list}
%
% The version 0.0e of \package{tablists} package enlarges left margin
% of \env{tabenum}, when environment appears inside proper list,
% by the value of left margin of this list. Sometimes left edges
% of \env{tabenum} labels and list labels of the same level are not aligned
% correctly (it happens when |\labelwidth| value is not equal to the natural
% width of labels). In these cases you may define the correction skip
% with the |\tabenumindent| command.
%
% Also the version 0.0e loads labels of empty items of upper/outer list
% at the left side of the first item of \env{tabenum} automatically.  It follows
% mechanism similar to building of empty items in list environment.
% (Empty items of \LaTeX\ list are consecutively stored to special box register
% and printed out at the beginning when the list text appears;
% the same happens at the beginning of \env{tabenum} environment:
% this box, if not empty, is printed at the left of first \env{tabenum} item.)
%\par\begin{small}%
%\begin{verbatim}
%\begin{enumerate}[\bfseries1)]%
%\item
%\begin{tabenum}[a)]%
%...
%\end{verbatim}%
%\end{small}%
% \begin{enumerate}[\bfseries1)]%
% \item
% \begin{tabenum}[a)]%
% \item
% {$z=\displaystyle\frac xy$};
% \noitem
% {$2^x=9;$}
% \item
% {$3^{2x+3}=4 $}.
% \item
% {$z=2x^2+4y^2$};\nopagebreak
%
% \item
% $u=\sqrt{x^2+y^2+z^2}$;
% \item
% $v=gt+\displaystyle\frac{g}{4}t$,
% \item
% $u=2^{5x-3y+z}$.\\
% \item
% $w=(v+7)^2+(u-3)^2$;
% \item
% $5^x=\displaystyle\frac{4}{3} ;$
% \item
% $z=(x+1)^2+y^2$;\cr
% \item
% $2+5+8+ \ldots +(3n+2)=155$, $n\in \mathrm{N};$\hidewidth\skipitem
% \item
% $t=5u^2+8v^2$.%
% \end{tabenum}%
% \end{enumerate}%
%\par\kern-\baselineskip
% \emph{Please note} that for the case of \env{tabenum} environment inside list,
% there is not compatibility between version 0.0e and earlier
% versions---left margin of \env{tabenum} is changed (mechanism
% of placing empty list items on one baseline using compensating vertical
% spaces could work but its calculation was changed, see also next paragraph).\smallskip
%
% \begin{small}%
% \DescribeMacro{\liststrut}
% In versions until 0.0d there was offered the |\liststrut| command in the
% cases when needed to put empty list item on the same line with first item of
% \env{tabenum}. The command raises first line of next text block at the baseline of
% previous. (Without any option it puts negative
% baselineskip. If there is a high element (any math sentence) in the first
% line of next text, it must be written in option without |$|'s,
% the height of this argument is used for compensating skips argument.)
% Since this command must take into account various vertical skips, which
% appear at the start of new item and also height of printing text,
% the adjusting of baselines does not always work correctly.\par
% \end{small}%
% \RestoreSpaces
% \subsection{The \env{subtabenum} environment: second level, variant I}
%
% \DescribeMacro{subtabenum}
% The second level of equations/exersizes list \env{subtabenum} based on \env{tabular}
% environment.
%
%\begin{small}%
%\begin{verbatim}
%\begin{tabenum}[\bfseries 1)]%
%\item
%\begin{subtabenum}[a)]%
%\item
%$z=\displaystyle\frac xy$;
%\noitem
%$2^x=9;$
%\item
%$3^{2x+3}=4 $.
%\item
%$z=2x^2+4y^2$;
%\end{subtabenum}
%
%\item
%\begin{subtabenum}[a)]%
%\item
%$u=\sqrt{x^2+y^2+z^2}$;
%\item
%...
%\end{subtabenum}
%\end{tabenum}
%\end{verbatim}%
%\end{small}%
% \begin{tabenum}[\bfseries 1)]%
% \item
% \begin{subtabenum}[a)]%
% \item
% $z=\displaystyle\frac xy$;
% \noitem
% $2^x=9;$
% \item
% $3^{2x+3}=4 $.
% \item
% $z=2x^2+4y^2$;
% \end{subtabenum}\nopagebreak
%
% \item
% \begin{subtabenum}[a)]
% \item
% $u=\sqrt{x^2+y^2+z^2}$;
% \item
% $v=gt+\gape[b]{\displaystyle\frac{g}{4}}t$,
% \item
% $u=2^{5x-3y+z}$.\\
% \item
% $w=(v+7)^2+(u-3)^2$;
% \item
% $5^x=\gape[b]{\displaystyle\frac{4}{3}} ;$
% \item
% $z=(x+1)^2+y^2$;\\
% \item
% $2+5+8+ \ldots +(3n+2)=155$, $n\in \mathrm{N};$\hidewidth\strut\skipitem
% \item
% $t=5u^2+8v^2$;
% \end{subtabenum}
% \end{tabenum}
% Please note that |\hidewidth| skip is followed by the |\strut| command inside
% \env{subtabenum} environment:
% the skips at the ``edges'' of \env{tabular} columns or before |\\| command doesn't work.
%
% \subsection{The \cs{subtabenumitem}/\cs{subitem} macros: second level, variant II}
%
% The previous example shows that columns were destroyed from one
% \env{subtabenum} environment to another. Also the rows of sublist cannot break between pages.
%
% \DescribeMacro{\subtabenumitem}
% \DescribeMacro{\subitem}
% There is another variant for two-level tabulated list. If you use second option
% in \env{tabenum} environment, you may use |\subtabenumitem|/|\subitem| commands
% for the second level\footnote{If there are not second optional argument, these commands
% work like \cs{tabenumitem}/\cs{item}.}.
%
% If you put |\subtabenumitem| (|\subitem|)  after |\tabenumitem| (|\item|), you get extra space between
% two numbers, created by |\tabenumsep| skip. The |\negtabenumsep| command
% cancels this skip: the version 0.0c included this command inside the |\tabenumitem| definition.
%\par\begin{small}\openup-1pt\enlargethispage{2\baselineskip}
%\begin{verbatim}
%\def\tabenumsep{\qquad}
%\begin{tabenum}[\bfseries 1)][a)]%
%\item
%\subitem
%$z=\displaystyle\frac xy$;
%\nosubitem
%$2^x=9;$
%\subitem
%$3^{2x+3}=4 $.
%\subitem
%$z=2x^2+4y^2$;\\
%\startnumber{4}
%\item
%\subitem
%$u=\sqrt{x^2+y^2+z^2}$;
%\subitem
%$v=gt+\displaystyle\frac{g}{4}t$,
%\subitem
%$u=2^{5x-3y+z}$.\\
%\startsubnumber{7}\subtabrow
%\subitem
%$w=(v+7)^2+(u-3)^2$;
%\subitem
%$5^x=\displaystyle\frac{4}{3} ;$
%\subitem
%$z=(x+1)^2+y^2$;\\
%\subtabrow
%\subitem
%$2+5+8+ \ldots +(3n+2)=155$, $n\in \mathrm{N};$\hidewidth\skipitem
%\subitem
%$t=5u^2+8v^2$;
%\end{tabenum}
%\end{verbatim}%
%\end{small}
% \begin{tabenum}[\bfseries 1)][a)]%
% \item
% \subitem
% $z=\displaystyle\frac xy$;
% \nosubitem
% $2^x=9;$
% \subitem
% $3^{2x+3}=4 $.
% \subitem
% $z=2x^2+4y^2$;\\
% \startnumber{4}\relax
% \item
% \subitem
% $u=\sqrt{x^2+y^2+z^2}$;
% \subitem
% $v=gt+\displaystyle\frac{g}{4}t$,
% \subitem
% $u=2^{5x-3y+z}$.\\
%\startsubnumber{7}\subtabrow
% \subitem
% $w=(v+7)^2+(u-3)^2$;
% \subitem
% $5^x=\displaystyle\frac{4}{3} ;$
% \subitem
% $z=(x+1)^2+y^2$;\\
%\subtabrow
% \subitem
% $2+5+8+ \ldots +(3n+2)=155$, $n\in \mathrm{N};$\hidewidth\skipitem
% \subitem
% $t=5u^2+8v^2$;
% \end{tabenum}
% There were used two commands |\startnumber| and |\startsubnumber| which set
% next start numbers for items of each of two levels\footnote{The \cs{startnumber}
%   command can be used inside any list
%   environment.}. The |\startnumber|
% allows you to divide \env{tabenum} environment and restart with necessary counter.
% You may still use the traditional |\setcounter{enum..}{..}| combination,
% if you know the level of your list and \env{tabenum}/\allowbreak\env{subtabenum} environments.
% For start of the new row from subitem, you need to use~\nobreak\quad1)\nobreak\enskip
% the |\skipitem| command to skip
% column, occupied by the ``parent'' label (|\tabenumitem|) and~\nobreak\quad2)\nobreak\enskip
% the |\negtabenumsep| command to undo column separation.
% These two commands abbreviated by |\subtabrow| command.
%
% \subsection{Placing the QED sign at the end of \env{tabenum} environment}
%
% When the \env{tabenum} environment is used inside \env{proof} environment (the
% \texttt{amsthm} package),
% the better way is to put QED at the end of last \env{tabenum} line. You may use
% the |\tabqedhere| command:
%
% \begin{theorem}%
% You may put the QED sign inside the \env{tabenum} environment.
% \end{theorem}%
% \begin{proof}%
% Let's put our favorite \env{tabenum} environment inside the  \env{proof} one,
% and at the end of it write the |\tabqedhere| (or |\qedhere|) command:
%\begin{verbatim}
%\begin{theorem}
% You may put the QED sign inside the \env{tabenum} environment.
%\end{theorem}
%\begin{proof}
% Let's put...
%\begin{tabenum}[\bfseries 1)][a)]%
%...
%\subitem
%$t=5u^2+8v^2$;\qedhere
%\end{tabenum}
%\end{proof}
%\end{verbatim}%
% \begin{tabenum}[\bfseries 1)][a)]%
% \item
% \subitem
% $z=\displaystyle\frac xy$;
% \nosubitem
% $2^x=9;$
% \subitem
% $3^{2x+3}=4 $.
% \subitem
% $z=2x^2+4y^2$;\\
% \startnumber{4}\relax
% \item
% \subitem
% $u=\sqrt{x^2+y^2+z^2}$;
% \subitem
% $v=gt+\displaystyle\frac{g}{4}t$,
% \subitem
% $u=2^{5x-3y+z}$.\\ \subtabrow
% \subitem
% $w=(v+7)^2+(u-3)^2$;
% \subitem
% $5^x=\displaystyle\frac{4}{3} ;$
% \subitem
% $z=(x+1)^2+y^2$;\\ \subtabrow
% \subitem
% $2+5+8+ \ldots +(3n+2)=155$, $n\in \mathrm{N};$\hidewidth\skipitem
% \subitem
% $t=5u^2+8v^2$;\qedhere
% \end{tabenum}
% \end{proof}%
%
% \subsection{Restoring of \cs{item} as command from list environments}
%
% \DescribeMacro{\restorelistitem}
% For the cases when standard lists appear inside \env{tablist}, you may
% restore original |\item| meaning.
%
% \StopEventually{}\clearpage
%
% \section{Code of package}
%
%  First goes request of \package{makecell} package.
%    \begin{macrocode}
\RequirePackage{makecell}
\@ifpackagelater{makecell}{2007/05/24 V0.1d}{}{\PackageError
    {tablists}{For a successful cooperation we need at least\MessageBreak
    version `2007/05/24 V0.1d' of package makecell,\MessageBreak
        but only version\MessageBreak
          `\csname ver@makecell.\@pkgextension\endcsname'\MessageBreak
        is available}\@eha\endinput}
%    \end{macrocode}
%
% The horizontal separation space between items/columns.
%    \begin{macrocode}
\newcommand\tabenumsep{\hskip1em}
\newcommand\negtabenumsep{%
    \settowidth\@tempdima{\tabenumsep}\hspace*{-\@tempdima}}
%    \end{macrocode}
%
% \begin{macro}{\tabenumitem}
% \begin{macro}{\subtabenumitem}
% Definition of aligned items of `tabular'ed list
%    \begin{macrocode}
\newcommand\tabenumitem{\ifvoid\@labels\else\llap{\box\@labels\hspace{-\@totalleftmargin}}\fi
    &\@ifnextchar[%
    {\TeXr@@tabenumitem{&}}%
    {\TeXr@tabenumitem{&}{\@enumctr}\setcounter{\@subenumctr}\z@}}
%    \end{macrocode}
% The macro for second level of tabulated items.
%    \begin{macrocode}
\newcommand\subtabenumitem{\ifnum\value{\@subenumctr}=\z@\negtabenumsep
    \let\negtabenumsep\relax\fi&
    \@ifnextchar[%]
      {\TeXr@@tabenumitem{&}}%
      {\TeXr@tabenumitem{&}{\@subenumctr}}}
%    \end{macrocode}
% The macros for list and optional numeration. For a successful usage of |\label|--|\ref| mechanism
% the |\refstepcounter| contains were divided in two parts: the |\stepcounter| command was placed in the
% first column, before printing of label, on the second column was placed mechanism of creation
% labels.
% \changes{0.0b}{2007/09/07}{The \cmd{\refstepcounter} command divided into two parts to allow
%       labels for tabular items.}
%    \begin{macrocode}
\newcommand\TeXr@tabenumitem[2]{%
    \stepcounter{#2}{\@nameuse{label#2}}#1
    \protected@edef
      \@currentlabel{\csname p@#2\endcsname\csname the#2\endcsname}}
\@ifdefinable\TeXr@@tabenumitem{}
\def\TeXr@@tabenumitem#1[#2]{{#2}#1}
%    \end{macrocode}
% \end{macro}%
% \end{macro}%
%
% \begin{macro}{\notabenumitem}
% \begin{macro}{\nosubtabenumitem}
% Definition of not aligned items with emulation of spaces around.
% The starred form of |\notabenumitem| skips space before number.
%    \begin{macrocode}
\newcommand\notabenumitem{\@ifstar
    {\TeXr@notabenumitem{\@enumctr}}%
    {\tabenumsep\TeXr@notabenumitem{\@enumctr}}}
%    \end{macrocode}
% The macro for second level of tabulated items.
%    \begin{macrocode}
\newcommand\nosubtabenumitem{\@ifstar
    {\TeXr@notabenumitem{\@subenumctr}}%
    {\tabenumsep\TeXr@notabenumitem{\@subenumctr}}}
\newcommand\TeXr@notabenumitem[1]{\@ifnextchar[%]
    {\TeXr@@tabenumitem{\hskip\labelsep}}%
    {\TeXr@tabenumitem{\hskip\labelsep}{#1}}}
%    \end{macrocode}
% \end{macro}%
% \end{macro}%
%
% \begin{macro}{\skipitem}
% Command allows to skip column of items in tabulated list.
% One item column occupies two tabular ones and needs |&&| for skipping
%    \begin{macrocode}
\newcommand\skipitem[1][1]{\count@=#1\multiply\count@2\advance\count@\@ne
    \eline{\count@}}
%    \end{macrocode}
% \end{macro}%
%
% \begin{macro}{\subtabrow}
% Command allows to skip column of items in tabulated list.
% One item column occupies two tabular ones and needs |&&| for skipping
%    \begin{macrocode}
\newcommand\subtabrow{\skipitem\negtabenumsep}
%    \end{macrocode}
% \end{macro}%
%
% \begin{macro}{\tabenumindent}
% If this command empty there is no any indentation. To set necessary indentation
% you may define this command as any text or horizontal skip.
%    \begin{macrocode}
\newcommand\tabenumindent{}
%    \end{macrocode}
% \end{macro}%
%
% \begin{environment}{tabenum}
% \begin{environment}{rtabenum}
% Start of definition of tabulated lists themselves---\env{tabenum}
% and \env{rtabenum}.
% They allow usage of optional argument in the same way as in
% \env{enumerate} environment from \package{paralist} package.
% The second definition, \env{rtabenum}, replaces |\Alph|/|\alph|
% numeration for \texttt{A}/texttt{a} entries by Russian
% |\Asbuk|/|\asbuk| numeration.
%    \begin{macrocode}
\newenvironment{rtabenum}{\let\Alph\Asbuk\let\alph\asbuk
    \tabenum}{\endtabenum}
%    \end{macrocode}
%
% These environments use mechanism of optional argument from |\@enumlabel@|
% command.
%    \begin{macrocode}
\newcommand\tabenum{\@ifnextchar[{\TeXr@tabenum@}{\TeXr@tabenum@[]}}
\@ifdefinable\TeXr@tabenum@{}
\def\TeXr@tabenum@[#1]{\@ifnextchar[%]
    {\TeXr@tabenum@@[#1]}{\TeXr@tabenum@@[#1][]}}
%    \end{macrocode}
%
% These environments allow two options for item numeration and subitem numeration.
%    \begin{macrocode}
\@ifdefinable\TeXr@tabenum@@{}
\long\def\TeXr@tabenum@@[#1][#2]{\par
    \addpenalty\@beginparpenalty
%    \end{macrocode}
% Vertical spaces around \env{tabenum}  similar to spaces in list environments.
% The space above reduced by |\jot| to make it equal to the space below.
%    \begin{macrocode}
    \@topsepadd\topsep\advance\@topsepadd\partopsep
    \advance\@topsepadd-\jot
    \ifdim\@topsepadd<\z@\@topsepadd=\z@\fi
    \if@nobreak\vspace{-\jot}\else\addvspace\@topsepadd\fi
%    \end{macrocode}
% Interline spacing enlarged by |\jot| as in \package{amsmath}'s environments like
% \env{align} etc.
%    \begin{macrocode}
    \openup\jot
%    \end{macrocode}
% Check for list depth and settings for first level.
% If it exceeded, the error message pops out.
%    \begin{macrocode}
    \ifnum\@enumdepth>\thr@@
      \@toodeep
    \else
      \advance\@enumdepth\@ne
      \edef\@enumctr{enum\romannumeral\the\@enumdepth}%
      \setcounter{\@enumctr}\z@
      \let\item\tabenumitem\let\noitem\notabenumitem
%    \end{macrocode}
% Check for list depth and settings for second level.
% If it exceeded, one level used.
%    \begin{macrocode}
      \ifnum\@enumdepth>\thr@@
        \PackageWarning{tablists}{tablist has one level}{}%
        \let\subitem\tabenumitem\let\nosubitem\notabenumitem
      \else
        \let\subitem\subtabenumitem\let\nosubitem\nosubtabenumitem
        \advance\@enumdepth\@ne
        \edef\@subenumctr{enum\romannumeral\the\@enumdepth}%
        \setcounter{\@subenumctr}\z@
      \fi
    \fi
%    \end{macrocode}
% Checks for first option. If option is absent used default enumerating.
%    \begin{macrocode}
    \def\tempa{#1}\ifx\tempa\empty\else
      \TeXr@enumlabel@{#1}{\@enumctr}\fi
%    \end{macrocode}
% Checks for second option. If option is absent used default enumerating.
%    \begin{macrocode}
    \def\tempa{#2}\ifx\tempa\empty\else
      \TeXr@enumlabel@{#2}{\@subenumctr}\fi
    \@TeXr@tabenum
    }
%    \end{macrocode}
% There building macro for item/subitem labels.
%    \begin{macrocode}
\newcommand\TeXr@enumlabel@[2]{%
    \@tempcnta0
    \TeXr@lab{}\def\TeXr@label{\TeXr@label@{#2}}%
    \expandafter\TeXr@loop\@gobble{}#1\@@@
    \ifnum\@tempcnta=1\else
      \PackageWarning{tablists}{Incorrect label; no or multiple
        counters.\MessageBreak The label is: \@gobble#1}%
    \fi
    \expandafter\edef\csname label#2\endcsname{\the\TeXr@lab}%
    \expandafter\let\csname the#2\endcsname\TeXr@the%
}
%    \end{macrocode}
%
% For column alignment is used |\halign| command of plain \TeX.
% In this case \env{tabenum}/\env{rtabenum} environments can run through a few pages.
%    \begin{macrocode}
\newcommand{\@TeXr@tabenum}{\begingroup
    \let\\\TeXr@arraycr\TeXr@tlist@arrayjot\let\par=\cr
    \settowidth\@tempdima{\tabenumindent}\gdef\tabenumindent{}%
    \settowidth\@tempdimb{\tabenumsep}%
    \ifnum\@listdepth>\z@\advance\@tempdima\@totalleftmargin\fi
    \let\qedhere\tabqedhere
    \halign\bgroup
    \strut##\hskip\@tempdima
        \hskip-\@tempdimb&&\hskip\@tempdimb\hfil##\hskip\labelsep
        &##\hfil\cr}
%    \end{macrocode}
%
% Finish of \env{tabenum} environment.
%    \begin{macrocode}
\def\endtabenum{\crcr\egroup\endgroup\par
    \addpenalty\@endparpenalty
    \advance\@topsepadd\jot
    \addvspace\@topsepadd}
%    \end{macrocode}
% \end{environment}%
% \end{environment}%
%
% \begin{environment}{subtabenum}
% \begin{environment}{rsubtabenum}
% The tabulated list of second level. This list uses a real \env{tabular}
% environment. In this case it is placed in one page. This list as its
% parent environment use optional argument in the way of \package{paralist}'s
% \env{enumerate}.
%    \begin{macrocode}
\newcommand\subtabenum[1][]{\TeXr@tlist@arrayjot
    \setcounter{\@subenumctr}\z@
    \def\tempa{#1}\ifx\tempa\empty\else
      \TeXr@enumlabel@{#1}{\@subenumctr}\fi
    \let\item\subtabenumitem\let\noitem\nosubtabenumitem
    \let\tabenumitem\subtabenumitem\let\notabenumitem\nosubtabenumitem
    \let\subitem\subtabenumitem\let\nosubitem\nosubtabenumitem
    \@TeXr@subtabenum
    }
\newcommand{\@TeXr@subtabenum}{\let\negtabenumsep\relax
    \hbox{\ifnum0=`}\fi
    \begin{tabular}[t]{@{\tabenumindent}l@{}
                        *{12}{r@{\hskip\labelsep}l@{\tabenumsep}}@{}}%
    }
\def\endsubtabenum{\end{tabular}%
    \ifnum0=`{\fi}\gdef\tabenumindent{}}
%    \end{macrocode}
%
% Russified environment with |\Asbuk|/|\asbuk| counters instead of
% |\Alph|/|\alph|.
%    \begin{macrocode}
\newenvironment{rsubtabenum}{\let\Alph\Asbuk\let\alph\asbuk%
   \subtabenum}{\endsubtabenum}
%    \end{macrocode}
% \end{environment}%
% \end{environment}%
%
% \begin{macro}{\arrayjot}
% The redefinition of |\\| command inside tabular to enlarge interline spacing
% by |\jot| value---to create analogous spacing to parent, \env{tabenum}, environment.
%    \begin{macrocode}
\@ifdefinable\TeXr@rixarraycr{}
\let\TeXr@rixarraycr\TeXr@xarraycr
\newcommand\TeXr@Xarraycr{\@ifnextchar[%]
     \TeXr@Xargarraycr {\@argarraycr[\jot]}}
\@ifdefinable\TeXr@Xargarraycr{}
\def\TeXr@Xargarraycr[#1]{\@tempdima\jot\advance\@tempdima#1%
                      \@argarraycr[\@tempdima]}
\@ifdefinable\TeXr@arrayjot{}
\def\TeXr@arrayjot   [#1]{\let\@xarraycr\TeXr@Xarraycr\jot#1}
\def\noarrayjot{\let\@xarraycr\TeXr@rixarraycr}
\newcommand\TeXr@tlist@arrayjot {\@ifnextchar[%]
    \TeXr@arrayjot{\TeXr@arrayjot[\jot]}}
\AtBeginDocument{\let\arrayjot\TeXr@tlist@arrayjot}
\def\TeXr@arraycr{%
  \relax\iffalse{\fi\ifnum 0=`}\fi
  \@ifstar{\vadjust{\penalty\@M}\@xarraycr}\@xarraycr}
%    \end{macrocode}
% \end{macro}
%
% \begin{macro}{\startnumber}
% The variant of |\setcounter{enum..}{..}| sentence.
% This command sets start number of current list (you must put this command
% inside of list or \env{tabenum} environment).
% The |\setcounter{enum..}{..}| sentence needs previous number,
% but  |\startnumber| needs a real start number of a list.
%    \begin{macrocode}
\newcommand\startnumber[1]{\count@#1\advance\count@-1%
    \global\expandafter\csname c@\@enumctr\endcsname\count@}
\newcommand\startsubnumber[1]{\count@#1\advance\count@-1%
    \global\expandafter\csname c@\@subenumctr\endcsname\count@}
%    \end{macrocode}
% \end{macro}
%
% \begin{macro}{\liststrut}
% For the cases of \env{tablist} appears just after empty
% \env{enumerate} (or analogous) list entry.
% This command inserts negative |\baselineskip| and put start of
% `tabular'ed  list on the baseline of list number.
%
% Optional argument allows to align baselines in the case of high
% elements in first line of \env{tablist}. In the version 0.0e the calculation
% of compensating space was changed.
%    \begin{macrocode}
\newcommand\liststrut[1][]{\def\tempa{#1}\ifx\tempa\empty
    \strut\@tempskipa\z@
  \else\settoheight\@tempdima{{$#1$}}\vrule height\@tempdima depth\dp\strutbox width\z@
     \advance\@tempdima-\ht\strutbox
     \ifdim\@tempdima>\lineskip\advance\@tempdima\lineskip\fi
     \@tempskipa\@tempdima
  \fi
  \advance\@tempskipa\baselineskip
%  \advance\@tempskipa-\@outerparskip
  \par\nobreak\vskip-\parskip
%  \advance\@tempskipa\lastskip
   \nobreak\kern-\@tempskipa\@nobreaktrue}
%    \end{macrocode}
% \end{macro}
%
% \begin{macro}{\tabqedhere}
% Places the QED sign at the end of \env{tabenum} line inside the \env{proof} environment.
%    \begin{macrocode}
\newcommand\tabqedhere{\cr
  \noalign{\@par\@tempdima\prevdepth
    \kern-\@tempdima\kern-\baselineskip\kern\lineskip
    {\strut\popQED}\@par\kern\@tempdima}}
%    \end{macrocode}
% \end{macro}
%
% \begin{macro}{\restorelistitem}
% For the cases when standard lists appear inside \env{tablist}.
%    \begin{macrocode}
\let\TeXr@orilistitem\item
\newcommand\restorelistitem{\let\item\TeXr@orilistitem}
%    \end{macrocode}
% \end{macro}
%
% \Finale
\endinput
%%
%% End of file tablists.dtx