LATEX-L Archives

Mailing list for the LaTeX3 project

LATEX-L@LISTSERV.UNI-HEIDELBERG.DE

Options: Use Classic View

Use Monospaced Font
Show Text Part by Default
Condense Mail Headers

Topic: [<< First] [< Prev] [Next >] [Last >>]

Print Reply
Sender: Mailing list for the LaTeX3 project <[log in to unmask]>
From: Javier Bezos <[log in to unmask]>
Date: Mon, 20 Dec 1999 13:49:45 +0100
Reply-To: Mailing list for the LaTeX3 project <[log in to unmask]>
Parts/Attachments: text/plain (164 lines)
(Message in three parts, because LaTeX-L rejects long
messages)

Below there are two enclosed files corresponding to titletoc with
templates added, and a trial file. The main goal is to show a
different approach to TOC attributes and how entries could be
grouped in a single paragraph. I'm currently working in some
improvements and many bugs remain to be fixed, but it
provides a mock-up of the main ideas. I have not finished yet
partial tocs and hence I removed the code from the sent files;
the processcontents is just a copy of the code by James Kilfiger.

The attributes of standard toc entries (JB1) are:

pre-action:  Code to be executed before the entry,
post-action: Code to be executed after the entry,
decls: declarations (usually paragraph format ones),
left-margin: the left margin related to the entry text (*not*
  the label),
right-margin: the right margin related to the entry text,
right-adjust: a correction for leaders (the leader chars
   are not centered in the enclosing box, but aligned to
   right), this parametes adjusts the entry text so that
   its right margin and the leaders are algned,
label-format: It should include code for making the label hangs,
label-width:
title-format: self-explanatories
title-format-nolabel: if present, overrides the title format
  in unlabeled entries,
page-format: It should include code for making the page hangs,
leaders-text:
leaders-width: self-explanatories

The attributes of "paragraphed" toc entries (JB2) are:

pre-action: Only that of the very first grouped entry is executed,
decls:
left-margin:
right-margin:
label-format:
title-format:
title-format-nolabel:
page-format: As before, except that neither the label nor the page
   hang,
punct-sep: Default separator,
punct-end: Ending puntuation, only that of the very last grouped entry
  is executed.        =f0 [.]        \COpunct@end,
punct-sup: Separator when the following entry is one level above
  (eg, subsection section)
punct-sup-sup: Id. two levels above (eg subsubsection section)
punct-sub: Id. one level below (eg, section subsection)

Since the right-margin is usually set for all of entries, the
command \contentsmargin[correction]{right} is provided. The
default values for the corresponding attributes are taken
from a couple of internal macros set by it.

\bye \bye
Javier

ps. As I'm gettting more and more involved in an Omega project,
I'm not sure if I can continue with this discussion. I will try it,
anyway.

===========================   xtitlesec.sty begins
\ProvidesPackage{xtitletoc}
\RequirePackage{xparse}
\RequirePackage{template}

% The following tags are used:
% ttl@  : the generic one, shared with titlesec
% ttle@ : ending puntuation for block format
% ttll@ : section level
% ttlx@ : file extension

\newif\ifttl@numsec
\newif\ifttl@fromblock

\providecommand\titleline{%
  \@ifnextchar[{\ttl@line}{\ttl@line[s]}}

\def\ttl@line[#1]#2{%
  \vskip\topskip
  \hrule \@height \z@
  \nobreak
  \vskip-\topskip
  \begingroup
    \parindent\z@
    \everypar{}%
    \leftskip\z@
    \rightskip\z@
    \@makebox[\hsize][#1]{\ttl@makeline{#2}}%
    \par
  \endgroup
  \hrule height \z@
  \nobreak}

% Fillers:

\providecommand\titlerule{\@ifstar{\ttl@row}{\ttl@rule}}

\let\ttl@leaders\xleaders

\def\ttl@row{\@ifnextchar[{\ttl@row@i}{\ttl@row@i[\wd\z@]}}
\def\ttl@row@i[#1]#2{%
  \ifvmode\expandafter\titleline\fi
  {\sbox\z@{#2}%
   \hspace{-#1}%
   \hskip\wd\z@
   \ttl@leaders\hb@xt@#1{\hss\box\z@}%
   \hfill\kern\z@}}

\def\ttl@rule{\@ifnextchar[{\ttl@rule@i}{\ttl@rule@i[.4pt]}}
\def\ttl@rule@i[#1]{%
  \ifvmode\expandafter\titleline\fi
  {\leaders\hrule height #1\hfill\kern\z@}}

\providecommand\filright{%
  \gdef\es@filleft##1{\hskip##1}%
  \gdef\es@filright##1{\hfill}%
  \let\\\@centercr
  \advance\rightskip\z@ \@plus 1fil\relax}
\providecommand\filleft{%
  \gdef\es@filleft##1{\hfill}%
  \gdef\es@filright##1{\hskip##1}%
  \let\\\@centercr
  \advance\leftskip\z@ \@plus 1fil
  \parfillskip\z@}
\providecommand\filcenter{\filleft\filright
  \gdef\es@filleft##1{\hfill}}
\providecommand\fillast{%
  \gdef\es@filleft##1{\hfill}%
  \gdef\es@filright##1{\hfill}%
  \let\\\@centercr
  \filleft\advance\rightskip\z@ \@plus -1fil
  \parfillskip\z@ \@plus 2fil\relax}

% User interface
% ~~~~~~~~~~~~~~
% Tools:

\DeclareOption{dotinlabels}{\def\[log in to unmask]
\DeclareOption{nodotinlabels}{\let\ttl@idot\@empty}

\DeclareOption{leftlabels}{%
  \renewcommand\numberline[1]{\hb@xt@\@tempdima{#1\ttl@idot\hfil}}%
  \newcommand\contentslabel[2][\thecontentslabel\ttl@idot]{%
    \hspace*{-#2}\hb@xt@#2{#1\hfil}}}

\DeclareOption{rightlabels}{%
  \renewcommand\numberline[1]{\hb@xt@\@tempdima{\hss#1\ttl@idot\enspace}}%
  \let\contentslabel\relax
  \newcommand\contentslabel[2][\thecontentslabel\ttl@idot\enspace]{%
    \hspace*{-#2}\hb@xt@#2{\hfil#1}}}

\newcommand\contentspage[1][\thecontentspage]{%
  \hb@xt@\@pnumwidth{\hfil#1}%
  \hspace*{-\@pnumwidth}}

\newcommand\contentspush[1]{%
  \sbox\z@{#1}%
  \advance\leftskip\wd\z@
  \leavevmode\llap{\box\z@}}

ATOM RSS1 RSS2