% -*- coding: utf-8; time-stamp-format: "%02d-%02m-%:y at %02H:%02M:%02S %Z" ; time-stamp-active: nil -*- % N.B.: this dtx file does NOT use \DocInput. It does NOT prefix the user % manual part with percent characters. %<*none> \def\etocdtxtimestamp {Time-stamp: <29-10-2023 at 10:31:05 CET>}% % %<*!readme> %% %% Package: etoc %% Version: 1.2d %% License: LPPL 1.3c %% Copyright (C) 2012-2023 Jean-Francois Burnol %% % %<*none> \def\etocpkgdate {2023/10/29} \def\etocdocdate {2023/10/29} \def\etocpkgversion {1.2d} \def\etocpkgdescription {Completely customisable TOCs (JFB)} %% Formerly this etoc.dtx also included source for a German translation %% etoc-DE.pdf. But all additions since April 2015 had been only in English. %% Since 1.09f of 2022/08/30 etoc-DE.pdf is not produced anymore and the %% existing translated sections have been removed from this etoc.dtx. % Definition of \etocLicense % -------------------------- \begingroup \long\def\firstofone #1{#1}\catcode1=14\catcode2=0 \catcode`\%=12\catcode`\_=12\endlinechar13\catcode13=13 ^^A \catcode32=13\catcode`\\=12^^Brelax^^A ^^Bfirstofone{^^Bendgroup^^Bdef^^BetocLicense^^A {% Package: etoc % Version: 1.2d % License: LPPL 1.3c % Copyright (C) 2012-2023 Jean-Francois Burnol % % This Work may be distributed and/or modified under the % conditions of the LaTeX Project Public License, in its % version 1.3c. This version of this license is in % http://www.latex-project.org/lppl/lppl-1-3c.txt % and 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 2005/12/01 or later. % % The Author of this Work is: % Jean-Francois Burnol % % This Work consists of the main source file etoc.dtx and the derived % files etoc.sty, etoc.tex, etoc.pdf, etoc.dvi, README.md. % % Running etex (or latex or pdflatex) on etoc.dtx extracts etoc.sty, % etoc.tex and README.md. See README.md for further instructions. }}% \bgroup\catcode2 0 \catcode`\\ 12 ^^Biffalse % %<*readme> Source: etoc.dtx (1.2d) Author: Jean-Francois Burnol Info: Completely customisable TOCs License: LPPL 1.3c Copyright (C) 2012-2023 Jean-Francois Burnol. ABSTRACT ======== With `etoc` loaded, `\tableofcontents` can be used multiple times and an added command `\localtableofcontents` allows to typeset "local" tables of contents, i.e. having their scope limited to the last sectioning command encountered. No auxiliary file is used additionally to the standard `.toc` file. Release 1.2 provides **experimental** additions `\locallistoffigures` and `\locallistoftables` which also use only the `.toc` file. Such local TOCs or "Lists Of" typically need to adopt a "display style" (i.e. the way the title is rendered, whether it should add itself an entry in the `.toc` file, ...) somewhat distinct from the global TOC. The release 1.2 default adapts automatically the titles of local TOCs to their depths in the sectioning hierarchy. Should the need arise to customize such "display style", full control is allowed by package commands. Regarding how the individual "contents lines" are handled, here again complete control is given to the user to define from the ground-up how to use the *name*, *number*, and *page number* for each entry, according to their "levels" (i.e. part, chapter, section, subsection, ...). As this requires some LaTeX fluency, many examples which can serve as starting points are attached to the PDF documentation as extractible files. Loading `etoc` per itself modifies nothing to "contents lines" rendering from the class default or changes from other packages. But full usage of the package allows spectacular effects such as displaying TOCs as trees or mind maps. INSTALLATION ============ For manual installation do `etex etoc.dtx` to extract files then move `etoc.sty` to a place where TeX can find it. etoc.sty -> TDS:tex/latex/etoc/etoc.sty etoc.dtx -> TDS:source/latex/etoc/etoc.dtx etoc.pdf -> TDS:doc/latex/etoc/etoc.pdf README.md -> TDS:doc/latex/etoc/README.md To produce `etoc.pdf` run pdflatex on the extracted file `etoc.tex` sufficiently many times (`latexmk -pdf etoc` is recommended). LICENSE ======= This Work may be distributed and/or modified under the conditions of the LaTeX Project Public License, in its version 1.3c. This version of this license is in > and the latest version of this license is in > and version 1.3 or later is part of all distributions of LaTeX version 2005/12/01 or later. The Author of this Work is Jean-Francois Burnol This Work consists of the main source file etoc.dtx and the derived files etoc.sty, etoc.tex, etoc.pdf, etoc.dvi. RECENT CHANGES ============== - `1.2d 2023/10/29` fix crash (since `1.2`) in presence of `\usepackage[nottoc]{tocbibind}`. Thanks to François Jonca for report. - `1.2c 2023/10/28` compatibility hotfix with `hyperref v7.01c`. Thanks to Denis Bitouzé for report. - `1.2b 2023/07/01` fixes a regression from `1.2` regarding concomitant usage of the package with `tocloft`. Some documentation improvements, in particular discussion of compatibility with `microtype`. - `1.2a 2023/05/01` lifts the requirement added at `1.1a` of a LaTeX kernel from 2020-10-01 or later, and also the requirement added at `1.2` of availability of the `\expanded` engine primitive. It also adds a `deeplevels` option. - `1.2 2023/03/01` completes the core internal refactoring from `1.1a-d` and adds **experimental** `\locallistoffigures` and `\locallistoftables`. It lets `\localtableofcontents` by default auto-select a heading style adapted to its location inside the document hierarchy, and adds options to control whether local TOCs and Lists Of add an entry corresponding to their heading in the `.toc` file. Compatibility with `tocbibind` package, too. - `1.1a 2023/01/14` up to `1.1d` are mainly about refactoring core legacy code. In part, this is to prepare for future changes relative to how hyperref and the LaTeX kernel will interact in the future. % %<*tex>------------------------------------------------------------------------- %% To produce the documentation etoc.pdf with source code included: %% latexmk -pdf etoc.tex %% (or sufficiently many times pdflatex etoc.tex) %% For customizations see comments and classe options below. \tracinglostchars3 \chardef\Withdvipdfmx 0 % replace 0 by 1 for using latex+dvipdfmx \chardef\NoSourceCode 0 % replace 0 by 1 for the doc *without* the source code \NeedsTeXFormat{LaTeX2e} \ProvidesFile {etoc.tex}[Driver for etoc documentation]% \PassOptionsToClass {a4paper,fontsize=10pt,twoside}{scrartcl} \PassOptionsToPackage {ngerman,english}{babel} \input etoc.dtx %%% Local Variables: %%% mode: latex %%% End: %------------------------------------------------------------------------- %<*none>------------------------------------------------------------------------ ^^Bfi^^Begroup % \chardef\noetex 0 \ifx\numexpr\undefined\chardef\noetex 1 \fi \ifnum\noetex=1 \chardef\extractfiles 0 % extract files, then stop \else \ifx\ProvidesFile\undefined \chardef\extractfiles 0 % etex etc.. on etoc.dtx, only file extraction. \else % latex/pdflatex on etoc.tex or on etoc.dtx \ifx\Withdvipdfmx\undefined % latex/pdflatex run is on etoc.dtx \chardef\extractfiles 1 % 1 = extract files and typeset manual, 2 = only typeset \chardef\Withdvipdfmx 0 % 0 = pdflatex or latex+dvips, 1 = dvipdfmx \chardef\NoSourceCode 1 % 0 = include source code, 1 = do not \NeedsTeXFormat {LaTeX2e}% \PassOptionsToClass {a4paper,fontsize=10pt,twoside}{scrartcl}% \PassOptionsToPackage {ngerman,english}{babel}% \else % latex run is on etoc.tex \chardef\extractfiles 2 % do not extract files, only typeset \fi \ProvidesFile{etoc.dtx}% [etoc source and documentation (\etocdtxtimestamp)]% \fi \fi \ifnum\extractfiles<2 % extract files \def\MessageDeFin{\newlinechar10 \let\Msg\message \Msg{********************************************************************^^J}% \Msg{*^^J}% \Msg{* To finish the installation you have to move the following^^J}% \Msg{* file into a directory searched by TeX:^^J}% \Msg{*^^J}% \Msg{*\space\space\space\space etoc.sty^^J}% \Msg{*^^J}% \Msg{* To produce the documentation with source code included execute^^J}% \Msg{* latexmk -pdf etoc.tex^^J}% \Msg{*^^J}% \Msg{* Happy TeXing!^^J}% \Msg{*^^J}% \Msg{********************************************************************^^J}% }% \begingroup \input docstrip.tex \askforoverwritefalse \generate{\nopreamble\nopostamble \file{README.md}{\from{etoc.dtx}{readme}}% \usepostamble\defaultpostamble \file{etoc.tex}{\from{etoc.dtx}{tex}}% \usepreamble\defaultpreamble \file{etoc.sty}{\from{etoc.dtx}{package}}}% \endgroup \fi % end of file extraction (from etex/latex/pdflatex run on etoc.dtx) \ifnum\noetex=1 % warning for README.md \expandafter\def\expandafter\MessageDeFin\expandafter {\MessageDeFin \Msg{* warning: to get correct utf-8 encoded README.md ^^J}% \Msg{* do etex etoc.dtx and not as here tex etoc.dtx ^^J}% \Msg{********************************************************************^^J}}% \fi \ifnum\extractfiles=0 % tex/etex/xetex/etc on etoc.dtx, files extracted, stop \MessageDeFin\expandafter\end \fi % From this point on, run is necessarily with e-TeX. % Check if \MessageDeFin got defined, if yes put it at end of run. \ifdefined\MessageDeFin\AtEndDocument{\MessageDeFin}\fi %------------------------------------------------------------------------------- % START OF USER MANUAL TEX SOURCE \documentclass{scrartcl} \makeatletter %%% START OF CUSTOM doc.sty LOADING (May 21, 2022 in xint.dtx) %%% (August 26, 2022 here, comments trimmed) % % For some legacy reason (because I started like this and it % worked to my satisfaction) I had used scrdoc.cls all those % years, without in fact needing most of its features. % % It loads ltxdoc class, from which again I need very little. On % testing May 20, 2022 the upcoming LaTeX 2022-06-01 I had some % problems with ltxdoc not having suitable interface for rolling % back to doc=V2. % % ... % % Thus it turns out I need very little of doc.sty, and almost % nothing of ltxdoc.cls and scrdoc.cls. % % (maybe provisory, try to see if usage of cross-hyperlinking % as in sourcexint.pdf makes sense here for rendering of % implementation part - loading time of etoc.pdf in viewer % in increased, though. 2022/08/26) % % Let's load the doc=V2 version to avoid having to work around % hypdoc loading interfering with my use of hyperref. \ifdefined\IfFormatAtLeastTF \IfFormatAtLeastTF{2022/06/01}% {% \IfFileExists{doc-2021-06-01.sty}% {\usepackage{doc}[=v2]}% % Why on earth do I lose my time doing this? {\GenericError {(etoc build doc)\@spaces}% {etoc build error: % Your LaTeX installation seems to be broken, format is\MessageBreak 2022-06-01 or later but `doc' package in its `v2' version\MessageBreak seems to not be available. \space Will try with `doc' but if\MessageBreak its `v3' is used there will be an option clash error\MessageBreak regarding hyperref.}% {}% {Please make sure `doc' package matches your LaTeX format.}% \usepackage{doc}% }% }% {\usepackage{doc}}% \else \usepackage{doc} \fi %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % MACROS OF doc.sty WILL BE HACKED (2022/06/06) FOR THE IMPLEMENTATION PART % % First we want to turn CodelineNo into a real LaTeX counter % This will spare defining an extra counter for the hyperlinks with \hyperref \begingroup\let\newcount\@gobble\@definecounter{CodelineNo}\endgroup % Let's now reenact the doc.sty default for \theCodeLineNo \def\theCodelineNo{\reset@font\scriptsize\arabic{CodelineNo}} % But as we will reset CodelineNo at each style file we need some unique id \def\theHCodelineNo{\the\value{section}.\the\value{CodelineNo}} % This is all for now. % The further hacks are to be found after the \StopEventually (i.e. a few % thousands lines down from here if you don't have access to the private % sources, which is probably the case if you are not the author). %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % As explained above I was formerly using scrdoc hence ltxdoc indirectly. % Let's emulate here the little I appear to need from ltxdoc.cls and % srcdoc.cls. % \AtBeginDocument{\MakeShortVerb{\|}} \DeclareFontShape{OT1}{cmtt}{bx}{n}{<-> ssub * cmtt/m/n}{} \DeclareFontFamily{OMS}{cmtt}{\skewchar\font 48} % '60 \DeclareFontShape{OMS}{cmtt}{m}{n}{<-> ssub * cmsy/m/n}{} \DeclareFontShape{OMS}{cmtt}{bx}{n}{<-> ssub * cmsy/b/n}{} \DeclareFontShape{OT1}{cmss}{m}{it}{<->ssub*cmss/m/sl}{} \ifnum\NoSourceCode=1 \OnlyDescription \fi \CodelineNumbered \EnableCrossrefs % but this will be hacked % \setcounter{StandardModuleDepth}{1} % we don't use this mechanism currently \def\cmd#1{\cs{\expandafter\cmd@to@cs\string#1}} \def\cmd@to@cs#1#2{\char\number`#2\relax} % Here I am loading doc=v2 but formerly I was using ltxdoc via scrdoc % which I dropped at release 1.4l (2022-05-29) and without much % thinking I had kept this. \DeclareRobustCommand\cs[1]{\texttt{\bslash#1}} % As I may have the * active, or macro names with _ or ^, I should % add \detokenize. But see below for a redefinition anyhow. % % More urgent is that I am also using hyperref and this definition gives wrong % bookmarks if \cs is used in section titles. As I had very very few usags of % \cs in the whole of xint.dtx, it took me a while to realize the problem % here. Turns out that doc=v3 by default loads hypdoc which includes this % configuation for hyperref compatibility: \AtBeginDocument{% \pdfstringdefDisableCommands{\def\cs#1{\textbackslash\detokenize{#1}}}% }% % As I have not loaded hyperref yet I must delay it to AtBeginDocument. \providecommand\marg[1]{% {\ttfamily\char`\{}\meta{#1}{\ttfamily\char`\}}} \providecommand\oarg[1]{% {\ttfamily[}\meta{#1}{\ttfamily]}} \providecommand\parg[1]{% {\ttfamily(}\meta{#1}{\ttfamily)}} % \@addtoreset{CodelineNo}{part}% No need for this here % \def\partname{File}% \partname is "fixed" somewhere further down anyhow % No need for this, anyhow I don't build the indices % \gdef\codeline@wrindex#1{\if@filesw % \begingroup % \let\protect\noexpand % \immediate\write\@indexfile % {\string\indexentry{#1}% % {\filesep\number\c@CodelineNo}}% % \endgroup\fi} % \let\filesep\@empty % There is very little we seem to need from the scrdoc extras: page geometry % is set by geometry package and a4paper option from xint.tex file. So it % seems I only need the hologo loading: \usepackage{hologo} \DeclareRobustCommand*{\eTeX}{\hologo{eTeX}}% \DeclareRobustCommand*{\LuaTeX}{\hologo{LuaTeX}}% % \makeatother %%% end of ltxdoc+srcdoc emulation from June 2022 xint.dtx, %%% copied over almost verbatim to etoc.dtx on 2022/08/26. %%% See after \StopEventually for doc.sty hacks. \makeatletter % pour maintenir les % en début de ligne dans les blocs verbatim \let\original@check@percent\check@percent \let\check@percent\relax \makeatother % We got sensible result with attachfile or attachfile2 % only with pdflatex. So this is remnant of earlier % times when etoc.pdf was produced via latex+dvipdfmx \usepackage{ifpdf} \ifpdf\chardef\Withdvipdfmx 0 \fi \makeatletter \ifnum\Withdvipdfmx=1 \@for\@tempa:=hyperref,bookmark,graphicx,xcolor,pict2e\do {\PassOptionsToPackage{dvipdfmx}\@tempa} % \PassOptionsToPackage{dvipdfm}{geometry} \PassOptionsToPackage{bookmarks=true}{hyperref} \PassOptionsToPackage{dvipdfmx-outline-open}{hyperref} \PassOptionsToPackage{dvipdfmx-outline-open}{bookmark} % \def\pgfsysdriver{pgfsys-dvipdfm.def} \else \PassOptionsToPackage{bookmarks=true}{hyperref} \fi \makeatother \usepackage[T1]{fontenc} \usepackage[hscale=0.66,vscale=0.75]{geometry} % Some problems with headers \pagestyle{headings} % \sectionmark uses \markboth in twoside but % with an empty right mark! As a result if a section starts % on an odd page, it does not appear in the header mark. % Perhaps there was a subsection of 3 lines on that page % and it is the subsection which decides what is in the header. % Some custom \sectionmark to get headers more to my taste. % But it is hard to find algorithm giving satisfaction in all cases. \makeatletter \renewcommand *{\sectionmark }[1]{% % Que c'est pénible cette syntaxe \markboth/\markright de LaTeX ! % Pourquoi est-ce que \markright n'a pas été définie comme #1#2-> truc avec #2 ?? \if@twoside \expandafter \markboth \else \expandafter\expandafter\expandafter \markright\expandafter \@firstoftwo \fi {\MakeMarkcase {\Ifnumbered {section}{\sectionmarkformat }{}#1}}% {\MakeMarkcase {\Ifnumbered {section}{\sectionmarkformat }{}#1}}% } % Par ailleurs je vais remplacer \firstmark par \botmark dans \rightmark % dont la définition par défaut est : % \rightmark: % macro:->\expandafter \@rightmark \firstmark \@empty \@empty \renewcommand*\rightmark{\expandafter\@rightmark\botmark \@empty\@empty} % Au passage l'output de latexdef à un : supplémentaire bizarre % $ latexdef botmark % % \botmark: % \botmark: % % Néanmoins pour les \part il ne faut clairement pas utiliser \botmark % Tous mes \part sont après un \clearpage explicite % Je crois que le plus simple est encore de faire ceci: \def\ps@mypartheadings{% \ps@headings \let\@evenhead\@empty \let\@oddhead\@empty } % peut-être serait-ce mieux de mettre le \thispagestyle après mon \clearpage, % explicitement dans la source \def\part{\thispagestyle{mypartheadings}\scr@startpart {part}} \makeatother % pour les environnements verbatim % uniformisé finalement, avec quelques exceptions, pour dtx du 3 déc 2013 %\def\MacroFont{\ttfamily\small\hyphenchar\font45 \baselineskip11pt\relax} % Je supprime le small finalement 2023/02/28 mais passe en 10pt \def\MacroFont{\ttfamily\hyphenchar\font45\relax\setstretch{1}} %---- % better \verb pour doc. % 12 octobre 2013, importé de xint.dtx % je rajoute pour { afin que truc{machin puisse avoir hyphénation % retire \leavemmode, pas nécessaire pour emploi ici % NOTE 9 mars 2015. J'ai depuis une version plus aboutie dans xint.dtx % mais je laisse ici tel quel. \def\MicroFont{\ttfamily\hyphenchar\font45 } % modif de \do@noligs: \char`#1} --> \char`#1 } \makeatletter \def\do@noligs #1% {% \catcode `#1\active \begingroup \lccode `\~=`#1\relax \lowercase {\endgroup \def ~{\kern \z@ \char `#1 }}% }% \def\dobackslash {% \catcode92 \active \begingroup \lccode `\~=92\relax \lowercase {\endgroup \def ~{\kern \z@ \char 92 }}% }% \def\dobraces {% \catcode123 \active \begingroup \lccode `\~=123\relax \lowercase {\endgroup \def ~{\hskip \z@\@plus.1pt\@minus.1pt \char 123 }}% \catcode125 \active \begingroup \lccode `\~=125\relax \lowercase {\endgroup \def ~{\char 125 \hskip \z@\@plus.1pt\@minus.1pt }}% }% \def\verb {% \relax \ifmmode\hbox\else\leavevmode\null\fi \bgroup \MicroFont \let\do\do@noligs \verbatim@nolig@list \let\do\@makeother \dospecials \catcode32 10 \dobackslash \dobraces \makestarlowast \@jfverb }% \def\@jfverb #1{\catcode`#1\active \lccode`\~`#1\lowercase{\def~{\egroup\unskip}}}% % (\unskip ajouté le 14 octobre) % \lowast est défini plus loin \begingroup \lccode`\~=`\* \lowercase{% \endgroup \def\makestarlowast {\catcode`\*\active\let~\lowast}}% \makeatother % %%%% FONT CONFIGURATION \usepackage{txfonts} % (2013) rescale the monospace font to 92% and allow hyphenation % (2023) fix the missing rescaling of bold series of txttt \DeclareFontFamily{T1}{txtt}{\hyphenchar\font 45\relax} %\DeclareFontFamily{T1}{txtt}{\hyphenchar\font -1\relax} \DeclareFontShape{T1}{txtt}{m}{n}{ %medium <->s*[.96] t1xtt% }{} \DeclareFontShape{T1}{txtt}{m}{sc}{ %cap & small cap <->s*[.96] t1xttsc% }{} \DeclareFontShape{T1}{txtt}{m}{sl}{ %slanted <->s*[.96] t1xttsl% }{} \DeclareFontShape{T1}{txtt}{m}{it}{ %italic <->ssub * txtt/m/sl% }{} \DeclareFontShape{T1}{txtt}{m}{ui}{ %unslanted italic <->ssub * txtt/m/sl% }{} % ---- /added here missing scale factor 2023 \DeclareFontShape{T1}{txtt}{bx}{n}{ %bold extended <->s*[.96] t1xbtt% }{} % The above s*[.96] added 2023/01/18, next two untested \DeclareFontShape{T1}{txtt}{bx}{sc}{ %bold extended cap & small cap <->s*[.96] t1xbttsc% }{} \DeclareFontShape{T1}{txtt}{bx}{sl}{ %bold extended slanted <->s*[.96] t1xbttsl% }{} % ---- /end of 2023 fix \DeclareFontShape{T1}{txtt}{bx}{it}{ %bold extended italic <->ssub * txtt/bx/sl% }{} \DeclareFontShape{T1}{txtt}{bx}{ui}{ %bold extended unslanted italic <->ssub * txtt/bx/sl% }{} \DeclareFontShape{T1}{txtt}{b}{n}{ %bold <->ssub * txtt/bx/n% }{} \DeclareFontShape{T1}{txtt}{b}{sc}{ %bold cap & small cap <->ssub * txtt/bx/sc% }{} \DeclareFontShape{T1}{txtt}{b}{sl}{ %bold slanted <->ssub * txtt/bx/sl% }{} \DeclareFontShape{T1}{txtt}{b}{it}{ %bold italic <->ssub * txtt/bx/it% }{} \DeclareFontShape{T1}{txtt}{b}{ui}{ %bold unslanted italic <->ssub * txtt/bx/ui% }{} % (2023) also rescale the txss sans serif (Helvetica) \DeclareFontFamily{T1}{txss}{} \DeclareFontShape{T1}{txss}{m}{n}{ %medium <->s * [0.89]t1xss% }{} \DeclareFontShape{T1}{txss}{m}{sc}{ %cap & small cap <->s * [0.89]t1xsssc% }{} \DeclareFontShape{T1}{txss}{m}{sl}{ %slanted <->s * [0.89]t1xsssl% }{} \DeclareFontShape{T1}{txss}{m}{it}{ %italic <->ssub * txss/m/sl% }{} \DeclareFontShape{T1}{txss}{m}{ui}{ %unslanted italic <->ssub * txss/m/sl% }{} \DeclareFontShape{T1}{txss}{bx}{n}{ %bold extended <->s * [0.89]t1xbss% }{} \DeclareFontShape{T1}{txss}{bx}{sc}{ %bold extended cap & small cap <->s * [0.89]t1xbsssc% }{} \DeclareFontShape{T1}{txss}{bx}{sl}{ %bold extended slanted <->s * [0.89]t1xbsssl% }{} \DeclareFontShape{T1}{txss}{bx}{it}{ %bold extended italic <->ssub * txss/bx/sl% }{} \DeclareFontShape{T1}{txss}{bx}{ui}{ %bold extended unslanted italic <->ssub * txss/bx/sl% }{} \DeclareFontShape{T1}{txss}{b}{n}{ %bold <->ssub * txss/bx/n% }{} \DeclareFontShape{T1}{txss}{b}{sc}{ %bold cap & small cap <->ssub * txss/bx/sc% }{} \DeclareFontShape{T1}{txss}{b}{sl}{ %bold slanted <->ssub * txss/bx/sl% }{} \DeclareFontShape{T1}{txss}{b}{it}{ %bold italic <->ssub * txss/bx/it% }{} \DeclareFontShape{T1}{txss}{b}{ui}{ %bold unslanted italic <->ssub * txss/bx/ui% }{} % % Use the Bitter typeface for the romanfamily \usepackage[scale=0.87]{bitter} \AtBeginDocument{% \renewcommand{\familydefault}{\sfdefault}% \rmfamily } \usepackage{xspace} % added svgnames 2022/08/26 on occasion of transfer from xint colouring scheme \usepackage[dvipsnames,svgnames]{xcolor} \usepackage{graphicx} \usepackage[inline]{enumitem} \usepackage{array} \usepackage{longtable} \definecolor{joli}{RGB}{225,95,0} \definecolor{JOLI}{RGB}{225,95,0} \definecolor{BLUE}{RGB}{0,0,255} \colorlet{niceone}{green!35!blue!75} \colorlet{optioncolor}{Maroon} % These colours mostly used only after stopeventually \definecolor{etocnamecolor}{RGB}{228,57,0} \colorlet{verbcolor}{Maroon} \colorlet{privatecommentcolor}{cyan} \colorlet{macrocodecommentcolor}{gray} \colorlet{macrocodenewmacrocolor}{verbcolor} \colorlet{macrocodelinktouserdoccolor}{etocnamecolor}% and bold face \colorlet{macrocodelinktosectioncolor}{DarkBlue}% and bold face \colorlet{macrocodelinktocodelinecolor}{Blue} \colorlet{macrocodenoncscolor}{Green} \usepackage {babel} % ngerman and english options have been passed to babel \AtBeginDocument {% % this may be obsolete as I don't use scrdoc or ltxdoc classes anymore \renewcommand\partname{Part}% \addto\captionsenglish {\renewcommand\partname{Part}} } \usepackage{tikz} \usetikzlibrary{trees} % added for "cyclic" grow function 2013/03/02 \usepackage{forest}[2015/05/04] % switched from tikz-qtree to forest 2013/09/09 % No problem with hyperlinks then, contrarily to tikz-qtree. % 12 mars 2015, pour 1.08a, see http://tex.stackexchange.com/a/232584/4686 \usetikzlibrary{mindmap} % Vendredi 13 mars 2015 à 18:10:40 % POUR LA TOC DE TITLE PAGE \usepackage{eso-pic} \usepackage{picture} \usepackage{ragged2e} % setspace usage added February 2023... (to accompany change of document font) % It must be loaded before hyperref \usepackage{setspace} \usepackage{hyperref}% I had used [pdfencoding=pdfdoc] until 1.09f \hypersetup{% linktoc=all,% %%linktoc=none,% STRESS TEST OF 1.1a %% bookmarksdepth=3,% (not needeed anymore now, 1.07g) breaklinks=true,% colorlinks,% linkcolor=RoyalBlue,% Orchid urlcolor=OliveGreen,% pdfauthor={Jean-François Burnol},% on peut y aller maintenant avec ç en 2022... pdftitle={The etoc package},% pdfsubject={Tables of contents with LaTeX},% pdfkeywords={LaTeX, table of contents},% pdfstartview=FitH,% %%pdfpagemode=UseOutlines,% commented-out for 1.09h } % added usage of package bookmark 2013/10/10 \usepackage{bookmark} \usepackage{varioref} % Vendredi 16 septembre 2016 % pour rendre accessibles les exemples % Fait package filecontentsdef le Samedi 17. \usepackage{filecontentsdef} %\ifnum\Withdvipdfmx=1 %% Attempts to use attachfile2 for latex+dvipdfmx fail: %% %% - 2016: (I did not record which version of attachfile2 was used) %% (this \the\value comment presumably refers to how I was using %% \attachfile at that time) %% %% I have an issue that with \thesubsection or \the\value{section} in code %% snippet filename, the file is not correctly attached, it appears in the %% pdf interface but with a wrong filename and one can not obtain the file %% from the pdf (tested on Acrobat Reader 11 Vendredi 16 septembre 2016). %% %% - 2023 (January, 1.2, with 2019/11/26 v2.11): %% %% I had to comment-out the mimetype, created and modified key settings. %% Then latex run passed but dvipdfmx complained with a dozen of %% dvipdfmx:warning: Object @atfi_obj_67 used, but not defined. Replaced by null. %% The Adobe Reader (same as in 2016...) Attachment panel lists a dozen of %% Inconnu in section 39 %% lines clearly matching the dvipdfmx warnings. %% %% The panel of Comments does display the list. From there or from the %% Attachment panels one can recover the snippets. The «etocsnippet» name %% is displayed in a strange greyed-out rendering, and one has to guess that %% CTRL-click gives access to the file. (not different from pdflatex route) %% %% I also tried with attachfile2.dtx from github at commit 660cea7 of May %% 19, 2022, and the same problem with the Attachment panel was there. Only %% difference I saw with attachfile2 from TL2022 was the ordering in the %% Attachment panel (with TL2022 attachfile2, the «Inconnu» lines were all %% grouped together). %% %% So I can still not go via latex+dvipdfmx in 2023. But the size reduction %% which is motivation for dvipdfmx was modest in this renewed testing, %% roughly 740Kb vs 840Kb with pdflatex. %% % \usepackage[dvipdfmx]{attachfile2} %% MEMO: I use \widthof in Linked list of the main package commands in %% a \makebox, since August 30, 2022, for 1.09f release. %% This requires calc, which is loaded only by attachfile among %% used packages; and calc is not loaded by attachfile2. % \usepackage{calc} %\else \usepackage{attachfile}% no op with dvipdfmx %\fi % \def\CEST{+02'00'}\def\CET{+01'00'} \def\ExtractDateStamp #1<#2-#3-#4 at #5:#6:#7 #8>% {D:#4#3#2#5#6#7\csname#8\endcsname} \edef\DateForSamples {\expandafter\ExtractDateStamp\etocdtxtimestamp} \attachfilesetup{%icon=Paperclip,% attention Paperclip pas PaperClip !! mimetype=application/x-tex, %appearance=false, % These comments and next are from November 19, 2022 % author={Jean-François Burnol}, % author={\pdfescapestring{Jean-François Burnol}}, % TODO: resolve this at some point in my future life author={Jean-Francois Burnol}, % doing this has fixed the date shown in Acrobat annotation panel % but now some strange seemingly unrelated date is printed in % the "Comment panel" created=\DateForSamples, modified=\DateForSamples, % allright this one next sets the dates shown in the "Comment Panel", % whereas the above two (or only modified) impacts the panel of % annotations on the left in my (very old) Adobe Reader. Not yet % tested with evince date=\DateForSamples }% \colorlet{etocsnippet}{blue} \newcommand\marginattach{% \noindent Depending on the PDF viewer\normalmarginpar % syntaxe pénible n'y-a-t-il pas un moyen plus commode % j'hésite à tester \value{page} \marginpar [% left {\hfill \textattachfile[description={in section \the\value{section}}]% {etocsnippet-\snippetno.tex}% {\textcolor{etocsnippet}{etocsnippet-\snippetno.tex}}% }% ]% {% right \textattachfile[description={in section \the\value{section}}]% {etocsnippet-\snippetno.tex}% {\textcolor{etocsnippet}{etocsnippet-\snippetno.tex}}% \hfill }% \stepcounter{snippet}, a click (or CTRL-click) on the filename in the margin may allow to extract it. Or check if an ``attachments'' or ``comments'' panel is available. } % Sadly, on non-attachement supporting viewers such as Skim.app, % the filename is not even searchable : entering "etocsnippet" % in the PDF viewer search form does not find the margin texts. % But I did not want to add to the filename the section number, % or perhaps even the page number (which could have been perilous % and I did not want to have to test and experiment, as I have % done enough for today with these code snippets). % In Acrobat the description field gives rise to some "tooltip" % display on hover, which displays the description field. \newcounter{snippet}%[section] \stepcounter{snippet} \makeatletter \newcommand\snippetno{% \ifnum\value{snippet}<10 0\fi\the\value{snippet}% %%% emulating former manual mark-up (with reset at each section) but I drop this %%% \ifnum\value{snippet}>0 -\@Alph{\numexpr\value{snippet}+\@ne\relax}\fi } \makeatother \usepackage{colorframed}% fix color issues with framed.sty (JFB 2022) \colorlet{shadecolor}{gray!10} \usepackage{centeredline}% custom macro now in public package \usepackage{xinttools}% for easier construction of the doubly hyperlinked cs names \usepackage{etoc} % (loads multicol) % There is clearly a bug of \singlespacing to do this \vskip\baselineskip. % What then if one goes from double to onehalf spacing? no such adjustment % in \onehalfspacing? Not coherent. And caused me a lost of half an hour % to first spot the problem (with "inline" TOCs first), then understand % that it originated into the setspace.sty commands, then waste time % canceling the hook locally and finally do this after going into checking % setspace.sty. \def\etocbeforetitlehook{\setstretch{1}} % for etoc's own default line styles. <1.08b had \partname by default but this % does not work well with babel+frenchb hence the default is now simply Part. % Here we can use \partname as we do (did) the documentation for English or German. % Careful with the customization of \partname done by scrdoc class! (obsolete remark) \renewcommand{\etocpartname}{\partname} % see the \AtBeginDocument with \addto\captionsngerman etc... %-------- % 10 octobre 2013: \AtBeginDocument{\addtocontents{toc}{\protect\hypersetup{hidelinks}}} %-------- % add-ons for the new section `surprising uses of etoc' (2013/01/24) % use of \the\value rather than \arabic due to paranoia in 2023. \newcounter{visibletoc} \renewcommand{\etocaftertitlehook} {\stepcounter{visibletoc}% \phantomsection \etoctoccontentsline{visibletoc}{\the\value{visibletoc}}} % at 1.2a \etocthemaxlevel for test of build with deeplevels option \etocsetlevel{visibletoc}{\etocthemaxlevel} %-------- % Statistics on sections and subsections in a part \thispartstats: % 2 mars 2013 % cette version utilise des box, plutôt que des macros. % mais on ne peut plus alors changer de police etc... % 11 octobre 2013, je retire les \color{teal}. \newsavebox\firstnamei \newsavebox\firstnumberi \newsavebox\lastnamei \newsavebox\lastnumberi \newsavebox\firstnameii \newsavebox\firstnumberii \newsavebox\lastnameii \newsavebox\lastnumberii \newcounter{mycounti} \newcounter{mycountii} \newcommand*{\thispartstatsauxi}{} \newcommand*{\thispartstatsauxii}{} \newcommand*{\oldtocdepth}{} \newcommand*{\thispartstats}{% \setcounter{mycounti}{0}% \setcounter{mycountii}{0}% \def\thispartstatsauxi{% \sbox{\firstnamei}{\footnotesize\etocname}% \sbox{\firstnumberi}{\footnotesize\etocnumber}% \def\thispartstatsauxi{}}% \def\thispartstatsauxii{% \sbox{\firstnameii}{\footnotesize\etocname}% \sbox{\firstnumberii}{\footnotesize\etocnumber}% \def\thispartstatsauxii{}}% \begingroup \etocsetstyle{subsection} {} {} {\thispartstatsauxii \stepcounter{mycountii}% \sbox{\lastnameii}{\footnotesize\etocname}% \sbox{\lastnumberii}{\footnotesize\etocnumber}} {} \etocsetstyle{section} {} {} {\thispartstatsauxi \stepcounter{mycounti}% \sbox{\lastnamei}{\footnotesize\etocname}% \sbox{\lastnumberi}{\footnotesize\etocnumber}} {{\footnotesize\itshape Here are some statistics for this part: it contains \arabic{mycounti} section\ifnum\value{mycounti}>1 s\fi{} and \ifnum\value{mycountii}>1 \arabic{mycountii} \else no \fi subsection\ifnum\value{mycountii}>1 s\fi. The name of the first section is ``\unhbox\firstnamei{}'' and the corresponding number is ``\unhbox\firstnumberi''. The name of the last section is ``\unhbox\lastnamei{}'' and its number is ``\unhbox\lastnumberi''. \ifnum\value{mycountii}>0 The name of the first subsection is ``\unhbox\firstnameii{}'' and the corresponding number is ``\unhbox\firstnumberii''. The name of the last subsection is ``\unhbox\lastnameii{}'' and its number is ``\unhbox\lastnumberii''.\fi \par}} \etocinline % october 10, 2013. \etocsetnexttocdepth {2}% \etocsettocstyle {\pdfbookmark[1]{Statistics}{\thepart.STATS}}{} \localtableofcontents \endgroup } %-------- % add-ons pour les TOC comme TikZ mind map, tree ou molécules % hyperlinks to source code... added November 20, 2022 % works in sync with macrocode hacks explained after \StopEventually % which were added in August 2022 % imported/adapted from code originally added to xint.dtx % FINALLY, after many hesitations and great suffering with \marginpar % I decide to simply divide the name into two parts and use two % distinct hyperlinks, so as to not render the reading to painful. % use a slightly different colour for second half? % MEMO: we can change \ttfamily as hyperref uses a scope limiting group. % Modified 2023/03/20 to devote the left two-thirds to linking to the user manual. \makeatletter % for \on@line \DeclareRobustCommand\csb[1]{% \edef\nbforuser{\the\numexpr2*\xintLength{#1}/3}% \ifcsname r@#1\endcsname \hyperref[#1]{\ttfamily\hyphenchar\font45 \char`\\ \xintKeepUnbraced{\nbforuser}{#1}}% \ifcsname r@etocmacro-#1\endcsname \hyperref[etocmacro-#1]{\ttfamily\hyphenchar\font45 \xintTrim{\nbforuser}{#1}}% \else % for .toc suffixed macros \ifcsname r@etocmacro-\xintTrimUnbraced{-4}{#1}\endcsname \hyperref[etocmacro-\xintTrimUnbraced{-4}{#1}]{\ttfamily\hyphenchar\font45 \xintTrim{\nbforuser}{#1}}% \else % 2023/02/27 also catch non existing destinations in source code {\fboxsep-\fboxrule\color{Orchid}% \fbox{\ttfamily\hyphenchar\font45 \xintTrim{\nbforuser}{#1}#1}% }% \ifcsname r@etocname\endcsname \expanded{\noexpand\AtEndDocument {\noexpand\PackageError{etoc}{Pas de référence dans le code à #1\on@line}% {Corriger!} }% }% \fi % \hyperref[#1]{\ttfamily\hyphenchar\font45 \xintTrim{\nbforuser}{#1}}% \fi \fi \else % 1.1a, updated 2023/01/22 1.2 {\fboxsep-\fboxrule\color{Orchid}% \fbox{\ttfamily\hyphenchar\font45 \char`\\ #1}% }% % make second run of compilation raise an error if macro name has been % misspelled so target (in the documentation) does not exist ; but this will % trigger error first time the documentation is added, one has to make % one compilation after adding the label and before continuing doc edits % 2023/01/22 1.2 \ifcsname r@etocname\endcsname \expanded{\noexpand\AtEndDocument {\noexpand\PackageError{etoc}{Pas de référence à #1\on@line}% {Corriger!} }% }% \fi \fi } \makeatother \DeclareRobustCommand\csa [1] {{\ttfamily\hyphenchar\font45 \char`\\ #1}} \newcommand\cshyp[1]{\texorpdfstring{\csa{#1}}{\textbackslash #1}} \newcommand\csbhyp[1]{\texorpdfstring{\csa{#1}}{\textbackslash #1}} \newcommand\etoc{% \texorpdfstring{{\color{joli}\ttfamily\bfseries etoc}}{etoc}\xspace} \newcommand\toc{\csb{tableofcontents}\xspace} \newcommand\localtoc{\csb{localtableofcontents}\xspace} \newcommand\invisiblelocaltoc{\csb{invisiblelocaltableofcontents}\xspace} \newcommand\localtocwrdp{\csb{localtableofcontentswithrelativedepth}\xspace} \newcommand\lowast{\raisebox{-.25\height}{*}} \newcommand\starit[1]{\csa{#1\lowast}} \newcommand\staritb[1]{\csb{#1}\lowast} % 2023/01/23, mais pas la peine de s'embêter avec robust et texorpdfstring \newcommand\etocrelease[1]{\hyperlink{v#1}{\texttt{#1}}} \DeclareRobustCommand\ctanpkg[1] {\texorpdfstring{\href{https://ctan.org/pkg/#1}{#1}}{#1}} \hyphenation{ table-of-con-tents local-table-of-con-tents local-table-of-con-tents-with-rel-a-tive-depth etoc-local-list-of-ta-bles-hook etoc-local-list-of-fig-ures-hook local-list-of-fig-ures local-list-of-ta-bles % toc-depth sec-num-depth con-tents-line % etoc-stan-dard-lines etoc-de-fault-lines etoc-toc-lines etoc-set-style etoc-name etoc-page etoc-skip-first-pre-fix etoc-num-ber etoc-if-first etoc-x-if-first etoc-if-num-bered etoc-x-if-num-bered etoc-if-was-empty etoc-x-if-was-empty etoc-checks-empti-ness etoc-no-toc-if-no-toc etoc-the-name etoc-the-num-ber etoc-the-page etoc-link etoc-the-linked-name etoc-the-linked-num-ber etoc-the-linked-page etoc-the-link etoc-set-level etoc-set-toc-depth etoc-set-next-toc-depth etoc-set-toc-depth etoc-obey-toc-toc-depth etoc-ig-nore-toc-depth etoc-depth-tag etoc-set-tag-depth etoc-obey-depth-tags etoc-ig-nore-depth-tags etoc-toc-con-tents-line etoc-set-local-top etoc-stan-dard-dis-playstyle etoc-ar-ti-cle-style etoc-book-style etoc-set-toc-style etoc-mul-ti-col-style etoc-mul-ti-col etoc-lo-cal-mul-ti-col etoc-toc-style etoc-toc-style-with-marks etoc-toc-style-with-marks-nouc etoc-ruled-style etoc-ruled etoc-lo-cal-ruled etoc-framed-style etoc-framed etoc-lo-cal-framed etoc-in-line etoc-af-ter-ti-tle-hook etoc-af-ter-con-tents-hook etoc-af-ter-toc-hook etoc-skip-first-pre-fix etoc-only-on-first % etoc-font-mi-nus-two etoc-font-mi-nus-one etoc-font-zero etoc-font-one etoc-font-two etoc-font-three etoc-sep-mi-nus-two etoc-sep-mi-nus-one etoc-sep-zero etoc-sep-one etoc-sep-two etoc-sep-three etoc-mi-nus-two-left-mar-gin etoc-mi-nus-two-right-mar-gin etoc-mi-nus-one-left-mar-gin etoc-mi-nus-one-right-mar-gin etoc-base-line-spread-mi-nus-two etoc-base-line-spread-mi-nus-one etoc-base-line-spread-zero etoc-base-line-spread-one etoc-base-line-spread-two etoc-base-line-spread-three etoc-toc-line-lead-ers etoc-ab-brev-page-name etoc-part-name etoc-book-name etoc-above-toc-skip etoc-be-low-toc-skip etoc-column-sep etoc-mul-ti-col-sep etoc-mul-ti-col-pre-tol-er-ance etoc-mul-ti-col-tol-er-ance etoc-de-fault-nb-col etoc-in-ner-top-sep etoc-top-rule etoc-top-rule-col-or-cmd etoc-in-ner-left-sep etoc-in-ner-right-sep etoc-in-ner-bot-tom-sep etoc-left-rule etoc-right-rule etoc-bot-tom-rule etoc-left-rule-col-or-cmd etoc-right-rule-col-or-cmd etoc-bot-tom-rule-col-or-cmd etoc-bkg-col-or-cmd etoc-framed-mp-hook etoc-keep-orig-i-nal-table-of-con-tents etoc-im-me-di-ate-set-toc-dep-th etoc-im-me-di-ate-depth-tag etoc-im-me-di-ate-toc-con-tents-line etoc-im-me-di-ate-set-local-top % next-toc-with-tags } % no more \frenchspacing since 2022/08/26 % for illustration only. Not to be recommended in general. \setcounter{secnumdepth}{4} % Usage of microtype added for 1.2 release; now that for some time % due to the business of attachfile I am tied with pdflatex. \ifnum\Withdvipdfmx=1 \else % should I check for xetex/luatex ? \usepackage[nopatch=toc]{microtype} \AtBeginDocument{\addtocontents{toc}{\protect\microtypesetup{protrusion=false}}} \fi \def\etocoption#1{{\color{optioncolor}\bfseries\texttt{#1}}} \begin{document} % \normalsize % change rien à un parindent un peu grand si 4 \parindent 3\fontcharwd\font`x\relax \marginparsep 6bp \thispagestyle{empty} \bookmark[named=FirstPage,level=1]{Title page} % depth tags for title page toc \etocsettagdepth {preamble} {part} \etocsettagdepth {overview} {section} \etocsettagdepth {styling} {section} \etocsettagdepth {control} {section} \etocsettagdepth {examples} {section} \etocsettagdepth {advanced} {section} \etocsettagdepth {etocandworld}{part} \etocsettagdepth {code} {section} % pour les TOC à la TikZ \newtoks\treetok \newtoks\parttok \newtoks\sectiontok \newtoks\subsectiontok \newtoks\subsubsectiontok \newtoks\tmptok \newcommand*\appendtotok[2]{% #1=toks variable, #2=macro, expands once #2 #1\expandafter\expandafter\expandafter{\expandafter\the\expandafter #1#2}} % 12 et 13 mars 2015 pour la mind map de title page % pour les Mindmap avec branch color \def\appendpart #1#2#3{% \edef\tmpstuff {\the#1 child [branch color = #3]{\the#2}}% #1\expandafter {\tmpstuff }% } % for 1.09f mind map on title page \def\prependpart #1#2#3{% \edef\tmpstuff {child [branch color = #3]{\the#2} \the#1}% #1\expandafter {\tmpstuff }% } % TOC MIND MAP ON TITLE PAGE \newcount\tikznumberofcurrentgrandchild % copied originally from http://tex.stackexchange.com/a/232914 % % \newcount\tikzdeltaofcurrentgrandchild % not needed at 1.2 % 1.2 causes quite a few adjustments as the parts have been modified, there % are now only 8 of them, and it is not same number of sections too. % As I don't read TikZ well, I had some trouble, but I take this opportunity % to clean up some complications from recent layouts which handled some % sections to lie on circular arcs, as exception to the general rectangular % rule. This was because not everything could fit, but I could find % satisfactorily layout this time, simply inhibiting via depth tags a few % sections. \def\tikzmycustomgrowth {% \pgftransformreset \ifnum\tikztreelevel=1 \pgftransformrotate{(\pgfkeysvalueof{/tikz/sibling angle}) * (\tikznumberofcurrentchild-2)}% \pgftransformxshift{\the\tikzleveldistance}% \fi \ifnum\tikztreelevel=2 \pgfmathsetmacro\tikzoffsetofcurrentchild{% (\tikzsiblingdistance)*(\tikznumberofcurrentgrandchild) }% \ifdim\tikzoffsetofcurrentchild pt<\tikzlevelheight \pgftransformxshift{\tikzlevelwidth/2} \pgftransformyshift{-\tikzlevelheight/2+\tikzoffsetofcurrentchild} \else \pgfmathsetmacro\tikzoffsetofcurrentchild{\tikzoffsetofcurrentchild-\tikzlevelheight}% \ifdim\tikzoffsetofcurrentchild pt<\tikzlevelwidth \pgftransformxshift{\tikzlevelwidth/2-\tikzoffsetofcurrentchild} \pgftransformyshift{\tikzlevelheight/2} \else \pgfmathsetmacro\tikzoffsetofcurrentchild{\tikzoffsetofcurrentchild-\tikzlevelwidth}% \ifdim\tikzoffsetofcurrentchild pt<\tikzlevelheight \pgftransformxshift{-\tikzlevelwidth/2} \pgftransformyshift{\tikzlevelheight/2-\tikzoffsetofcurrentchild} \else \pgfmathsetmacro\tikzoffsetofcurrentchild{\tikzoffsetofcurrentchild-\tikzlevelheight}% \ifdim\tikzoffsetofcurrentchild pt<\tikzlevelwidth \pgftransformxshift{-\tikzlevelwidth/2+\tikzoffsetofcurrentchild} \pgftransformyshift{-\tikzlevelheight/2} \else \pgfmathsetmacro\tikzoffsetofcurrentchild{\tikzoffsetofcurrentchild-\tikzlevelwidth}% \pgftransformxshift{\tikzlevelwidth/2} \pgftransformyshift{-\tikzlevelheight/2+\tikzoffsetofcurrentchild} \fi\fi\fi\fi \pgftransformrotate {\pgfkeysvalueof{/tikz/sibling angle} * \tikznumberofcurrentgrandchild}% \global\advance\tikznumberofcurrentgrandchild by1 \fi } % % % version circulaire utilisée avec les versions 1.08a--1.09e du manuel. % \def\tikzmycustomgrowth {% % \pgftransformreset % \ifnum\tikztreelevel=1 % \pgftransformrotate {126+(\pgfkeysvalueof{/tikz/sibling angle})*(\tikznumberofcurrentchild-1)}% % \fi % \ifnum\tikztreelevel=2 % \pgftransformrotate {(\pgfkeysvalueof{/tikz/sibling angle})*(2+\tikznumberofcurrentgrandchild)}% % \global\advance\tikznumberofcurrentgrandchild by 1 % \fi % \pgftransformxshift {\the\tikzleveldistance}% % } \newcounter{partco} % 1,2,3,4,5,... -> 1,2,3,1,2,3,1,2,3 \def\pseudomodthree #1{\numexpr #1 + 3 - 3*((#1+1)/3)\relax} \newbox\TitlePageMindmapTOC \etocsetstyle{part} {\etocskipfirstprefix} {\ifcase\pseudomodthree{\value{partco}}% \or \appendpart\treetok\parttok {Dandelion!50}% first (was teal!60 until 1.09f) \or \appendpart\treetok\parttok {teal!40}% second (was yellow!80 until 1.2) \else\appendpart\treetok\parttok {green!40}% third \fi } {\stepcounter{partco}% \edef\treenode{node {\noexpand\textbf{\etocifnumbered{\unexpanded\expandafter{\etocthelinkednumber}.}{} \unexpanded\expandafter{\etocthelinkedname}}}}% \parttok\expandafter{\treenode}} {% 1.09f used \prependpart for the last... reverted at 1.2, % better to append, avoids overlaps by rays of some balls \ifcase\pseudomodthree{\value{partco}}% \or \appendpart\treetok\parttok {Dandelion!50}% first \or \appendpart\treetok\parttok {teal!40}% second \else\appendpart\treetok\parttok {green!40}% third \fi } \etocsetstyle{section} {} {} {% define the section node \edef\childnode{child {node % The Bitter font does not have bold italic % Adding \baselineskip setting, and \endgraf to activate because \par causes % ! Paragraph ended before \tikz@collect@child@code was complete. % There must be some way to configure the TikZ node but I don't have % the time to go into its documentation. {\baselineskip10pt\noexpand\itshape%\noexpand\bfseries \unexpanded\expandafter{\etocthelinkedname}\hfil\break p. \unexpanded\expandafter{\etocthelinkedpage}\noexpand\endgraf }% }% }% \appendtotok\parttok\childnode } {} % title page toc % 1.09f used a prepend for last part so we needed to delay % the insertion of the root node to after the treetok had % been finished. % 1.2 uses append always so we can initialize here \treetok{\node [root concept]{\normalfont{The \etoc package}\par {\normalsize\textsc {Jean-François Burnol}\par \ttfamily jfbu (at) free (dot) fr}\par {\normalsize Package version:\par \hyperref[changelog]{\etocpkgversion{} (\etocpkgdate )}\par}}% } \etocsettocstyle {\setcounter{partco}{0}} {\global\treetok\expandafter{\the\treetok;}} \etocsetnexttocdepth{section} % fill in the \treetok \etocinline \tableofcontents\label{toc:mindmaptitlepage} % For debugging % \newwrite\TOCasTree % \immediate\openout\TOCasTree=\jobname.toctree % \immediate\write\TOCasTree{\the\treetok}% % \immediate\closeout\TOCasTree \tikzset {branch color/.style={concept color=#1!white, every child/.append style={concept color=#1!white!30!white, opacity=0.3, text opacity=1}, }, % ajout pour versions depuis 1.08g level width/.store in=\tikzlevelwidth, level height/.store in=\tikzlevelheight, }% \global\setbox\TitlePageMindmapTOC\hbox {% \resizebox{\dimexpr\paperwidth-1cm\relax}!{ \begin{tikzpicture}[mindmap, text width=2cm, align = flush center, % pour 1.09 je reviens à version circulaire simplifiée % pour 1.09f je reviens à version rectangulaire growth function=\tikzmycustomgrowth, nodes={concept}, % trying cyan I get some surprising brutal color change % much more visible than with orange concept color=yellow!50,% orange!60 until 1.2 % root concept/.append style={font=\huge, text width = 6cm}, root concept/.append style={font=\Large, text width = 5cm}, % level 1/.append style={level distance=7cm, sibling level 1/.append style={level distance=6cm, sibling angle=360/8},% 8 parties % level 1 concept/.append style={font=\Large, text width = 3cm}, % ancienne version circulaire % level 2/.append style={level distance=12.5cm, sibling angle=360/39},% % pour version rectangulaire, par tâtonnements: % réactivée pour 1.09f (étonnamment, juste quelques petits ajustements, mais ça % a tout de même pris pas mal de temps...) level 2/.append style={level width=21cm, level height=30cm, sibling distance=2.12cm,% à ajuster manuellement % 1.09f pour essayer certaines parties en % circulaire; plus besoin pout 1.2 % level distance=10cm,% distance depuis le centre ! % sibling angle=12,% à ajuster manuellement }, level 2 concept/.append style={text width=2cm}, ] \the\treetok \end{tikzpicture}% }% }% end of \hbox % On l'envoie au shipout \AddToShipoutPictureFG*{\put(.5\paperwidth,.5\paperheight) {\makebox(0,0){\box\TitlePageMindmapTOC}}} % trigger first page \noindent\null\par\vskip-5cm\hbox{\hypertarget{FRONTPAGE}{}}\vskip5cm % % for standard TOC % \etocstandardlines % \etocclasstocstyle % \tableofcontents % reset toc global to class default and line styles to etoc default \etocdefaultlines \etocclasstocstyle \clearpage \etocdepthtag.toc {preamble} %---- % MAIN TOC % made invisible at 1.2 \invisibletableofcontents \label{toc:main} \part*{\etoc} \addcontentsline{toc}{part}{\etoc (read this first)} \onehalfspacing \begin{shaded}\small % lien pour pour les "attachment annotations" % https://helpx.adobe.com/acrobat/using/comments.html % % Memo: https://english.stackexchange.com/questions/42370/is-two-thirds-plural % Yes and no. Yes, when you're talking about multiples of fractions eg. two % thirds they are plural. But when you're talking about a portion of a single % item, that item is singular. % 1). One third of the pizza was eaten. (part of one pizza was eaten) % Two thirds of the pizza was eaten. (part of one pizza was eaten) % The subject is pizza - singular. If you have one third of a pizza, and I have % one third of that same pizza we have two thirds (plural) of one pizza % (singular). % Of course this changes when the subject becomes plural: % One third of two pizzas were eaten. (part of two pizzas were eaten) % 2). One third of the visitors were men. (multiple visitors were men) % Two thirds of the visitors were men. (multiple visitors were men) % The subject in this case - men - is plural. % % Cependant j'ai un doute à cause de «the first» qui en française se traduirait % par un pluriel «les premiers deux-tiers» et ensuite on aurait envie de mettre % un pluriel; mais de toute la Grammaire n'a pas de Logique ! Tout le monde le % sait ! % The command names throughout the user documentation which are displayed {\textcolor{RoyalBlue}{with this colour}} are doubly hyperlinked: the first two-thirds of the command name hyperlinks to the user documentation, and the remaining third part hyperlinks to the source code. You can try it out now: \csb{localtableofcontents}. But read this first: if you get lost inside the source code, clicking on control sequences displayed {\textcolor{macrocodelinktouserdoccolor}{with this colour}} brings you back to the part of the user manual discussing that specific command. \ifnum\NoSourceCode=1 (but this PDF does not include the source code) \fi \end{shaded} \section*{Abstract} %\renewcommand\abstractname{} %\begin{abstract} \begingroup \leftskip1cm \rightskip1cm With \etoc loaded, \csb{tableofcontents} can be used multiple times and an added command \csb{localtableofcontents} allows to typeset ``local'' tables of contents, i.e. having their scope limited to the last sectioning command encountered. No auxiliary file is used additionally to the standard \texttt{.toc} file. Release \etocrelease{1.2} provides EXPERIMENTAL additions \csb{locallistoffigures} and \csb{locallistoftables} which also use only the \texttt{.toc} file. Such local TOCs or ``Lists Of'' typically need to adopt a ``display style'' (i.e. the way the title is rendered, whether it should add itself an entry in the \texttt{.toc} file, ...) somewhat distinct from the global TOC. The release \etocrelease{1.2} default adapts automatically the titles of local TOCs to their depths in the sectioning hierarchy. Should the need arise to customize such ``display style'', full control is allowed by package commands. Regarding how the individual ``contents lines'' are handled, here again complete control is given to the user to define from the ground-up how to use the \emph{name}, \emph{number}, and \emph{page number} for each entry, according to their ``levels'' (i.e. part, chapter, section, subsection, ...). As this requires some \LaTeX{} fluency, many examples which can serve as starting points are attached to the PDF documentation as extractible files. Loading \etoc per itself modifies nothing to ``contents lines'' rendering from the class default or changes from other packages. But full usage of the package allows spectacular effects such as displaying TOCs as trees or mind maps. %\end{abstract} \endgroup %\clearpage \setstretch{1} \section*{License} \addcontentsline{toc}{section}{License} \begingroup \ttfamily \hyphenchar\font -1 \parindent0pt \obeyspaces\obeylines % \etocLicense\endgroup \onehalfspacing \clearpage \onehalfspacing \etocignoredepthtags \etocsettocdepth {subsubsection} \etocdepthtag.toc{overview} \part{Overview}\label{part:overview} \thispartstats \etocdefaultlines \etocsettocstyle{}{} \localtableofcontents \label{toc:overview} \section[\csbhyp{(local)\-tableofcontents}]{The \csbhyp{tableofcontents}, \csbhyp{localtableofcontents} and other main package commands} \begin{description} \item [\csb{tableofcontents}] can be used arbitrarily many times in the document, \item [\csb{localtableofcontents}] produces tables of contents which are limited in scope by the nearest preceding sectioning command,% % \footnote{After adding a \localtoc in-between existing ones, the first compilation will typeset at its location a pre-existing next one; only at second compilation will the contents match the location. Hence often a third compilation is needed for document to stabilize. And if the ``to toc'' mechanism is active (see the discussion of \csb{etocsetup} option \etocoption{localtoctotoc} and similar options), only on second compilation is a new entry made in the \texttt{.toc} file so three compilations is always a minimum. If one starts compilations from a given source, and no auxiliary files, the first compilation prepares the |.toc| file, the second typesets the main and local TOCs, possibly changing page numbers due to added contents, and only at the third compilation will things perhaps stabilize, and this third step is surely needed in case of \etocoption{localtoctotoc}. \ctanpkg{latexmk} is highly recommended.} \item [\csb{etocsettocstyle}\marg{before\_toc}\marg{after\_toc}] defines (from the ground up, completely) the TOC titles, or more generally everything either before or after the actual TOC contents, \item [\csb{etocsetstyle}\marg{levelname}% \marg{start}\marg{prefix}\marg{contents}\marg{finish}] defines (completely, from the ground up) arbitrarily the way the \csa{contentsline} entries in the |.toc| file are rendered, depending on their first argument, which is a `level name' such as |part|, |chapter|, |section|, |subsection|, \dots It is possible to create new levels or re-assign the numerical level of a named one via \csb{etocsetlevel}\marg{levelname}\marg{number}, thus opening the way for sophisticated (ab)-uses of the data stored in the |.toc| file. \item [\csb{etocname}, \csb{etocnumber}, \csb{etocpage}] are free to use arbitrarily in the \csb{etocsetstyle} \marg{prefix} and \marg{contents} arguments for a given contents line level name, they stand for what will be extracted by \etoc from the actual data which is stored in the |.toc| file and is a bit entangled there (for the first two). \end{description} %% \vskip-\baselineskip\vskip0pt % sigh LaTeX spaces ! Throughout this documentation ``layout'', ``display'', ``TOC style'' always are synonyms and refer roughly to how the TOC title is typeset. And ``line styles'' refer to how each individual entry in the TOC will be rendered according to its ``level''. Whenever ``TOC style'' is mentioned it is for the title related things, else the documentation will say ``line styles''. \csb{etocsetstyle} is for line styles and it requires \LaTeX{} fluency. It is however absolutely not required to use it: by default \etoc does not intervene at all into the rendering of the contents lines. For example, one can use packages such as \ctanpkg{tocloft} to customize these contents lines as wished. \csb{etocsettocstyle} is for styling the titles (and all things related to material before and after the actual TOC contents). It was originally conceived mainly for being used after the main document TOC (assuming it comes first). By default \etoc renders the main TOC as specified by the class it knows about. But for example in a |book|-class document, one does not want to use a chapter-like heading for a local TOC in a section. Hence the need for \csb{etocsettocstyle}. But if used in the preamble it will apply to the main TOC too (if it comes first in the document body), hence its usage has to be delayed or stored into some command, else one has to insert branches in the original definition to query the kind of TOC it is applied to. With \etocrelease{1.2} some utilities facilitate using \csb{etocsettocstyle} only once in the preamble and branch according to whether it is handling a main document TOC or a local one. But the macro was really initially conceived to be used for local TOCs once the main TOC was typeset (commands are provided to restore the default configuration in time for a main TOC at end of document). There is no command to customize the titles only for local TOCs from the preamble. With \etocrelease{1.2} an effort has been made to make using \csb{etocsettocstyle} for local TOCs purely an option: by default the package adopts a style for local headings which takes into account the local top level. This corresponds to the command \csb{etocetoclocaltocstyle}, which is emitted by default by the package. Furthermore \etocrelease{1.2} detects \ctanpkg{tocbibind}% % \footnote{Support for \ctanpkg{tocloft} customization of contents lines was already in place for many years; the compatibility with \ctanpkg{tocbibind} was added only at \etocrelease{1.2} and required to update the \ctanpkg{tocloft} related code.} % and executes a compatilibity layer so that this package can be used with hopefully the same result as in the main document classes. Package options \etocoption{maintoctotoc}, \etocoption{localtoctotoc}, \etocoption{localloftotoc} and \etocoption{locallottotoc} trigger ``to toc'' mechanisms even without \ctanpkg{tocbibind} if desired, directly at \etoc level. The starred variants of the table of contents and ``list of'' commands will ignore the status of these options, as in the \ctanpkg{memoir} class. \section[\csbhyp{locallistof\-(figures\textbar\-tables)}]{The \protect\etocrelease{1.2} \csbhyp{locallistoffigures} and \csbhyp{locallistoftables} commands} \label{locallistoffigures} \label{locallistoftables} \label{etocsetup} The major novelty with \etocrelease{1.2} is the addition of \csb{locallistoffigures} and \csb{locallistoftables}. \begin{framed} The following major problem is known with the current implementation: \csb{locallistoffigures} and \csb{locallistoftables} actually list the figures, respectively the tables, say in a given \csa{section} which are \textbf{TYPESET THEREIN}, which is not necessarily the same figures, tables, which in the \LaTeX{} source are located \textbf{``WITHIN'' THAT SECTION}. Recall that \LaTeX{} does not have a structured representation of the document (despite what many people like to think), so there is no pre-existing official way from inside a table to know in which section or subsection it is defined. And figures and tables are \emph{floating}. If a figure, for example, floats to next page, and the section were it was \emph{defined} is followed on the initial page by another one, then a \csb{locallistoffigures} in the first section will NOT see the figure which has drifted to next page! That floating figure will be listed by a \csb{locallistoffigures} in the NEXT section! Now, if all sections are equipped with \csb{locallistoffigures} this current ``feature'' of \etoc means that all figures will be accounted for and one will be able to see in which section they physically reside after typesetting! Which is nice but perhaps counter intuitive. The source of this problem is well-understood by package author but addressing the issue is delayed probably for some months, by lack of time and ressources; or may remain a permanent ``feature'' as the author does not intend to hack in any way into code for floats, or even captions. Here is a non-\etoc file you can play with and which illustrates the mechanism: \begin{verbatim} \documentclass{article} \begin{document} \tableofcontents % the table of contents will show the "table" entry % as belonging to **second** section \section{first} \begin{table}[p] some tabular \makeatletter % add some entry in the toc file, like a subsection would do \write\@auxout{\string \@writefile {toc} {\protect \contentsline {subsection}{table}{\thepage }{}}} \caption{table} \end{table} \section{second} \end{document} \end{verbatim} \end{framed} \begin{itemize} \item This is experimental code and the user interface as well as the output may change. \item It is mandatory to load \etoc with option \etocoption{lof} for \csb{locallistoffigures} and \etocoption{lot} for \csb{locallistoftables}. \item \etoc does not interfere whatsoever with \csa{listoffigures} and \csa{listoftables}, and can not customize them in any way. \item \etoc still uses no additional auxiliary file, it uses only the |.toc| file. \item This is experimental code and the user interface as well as the output may change. \item The new command \csb{etocsetup} allows to configure at any location in the preamble or in the document body the boolean options \etocoption{maintoctotoc}, \etocoption{localtoctotoc}, \etocoption{localloftotoc}, \etocoption{locallottotoc}, and \etocoption{ouroboros} which can also be issued as package options. The first four default to |false|, except with the \ctanpkg{memoir} class, in which case they are set to |true|, or when \ctanpkg{tocbibind} is detected, in which case they are set to |true| depending on the setting of the \ctanpkg{tocbibind} options. \item The \etocoption{ouroboros} option defaults to |true|. When set to |false|, local TOCs which have been added to the |.toc| file due to \etocoption{localtoctotoc} will \emph{not} list themselves (they will still list entries from local TOCs at deeper levels in their scope, and the ``lists of'' at their same level, and are listed in the main TOC, the only thing is that they don't show themselves in themselves).% % \footnote{It is complex to try to anticipate all scenarii, but in general, it is expected this behavior may cause the |.toc| file to need more time to stabilize when a new local TOC is added in the midst of a document having already a bunch of them.} % The default is that they \emph{do} list themselves, hence the name \etocoption{ouroboros}. It has no impact on the main TOCs, use their starred variant to inhibit the self-display, but then why have issued \etocoption{maintoctotoc} in the first place? \item An effort has been made to facilitate as much as possible customization by the user, i.e. via commands without |@| letter. However this documentation will only list their names with very brief comments at the appropriate place and the reader is expected to check in the source code to understand better what they are for. \item This is experimental code and the user interface as well as the output may change. \item For example, the actual figure entries or table entries use by default the code from the main LOF or LOT; but one may prefer to render them in a way taking into account the local ``list of'' scope: for example in a section, perhaps use the same style as subsections. This is possible and is explained briefly later. \item Although the default ``\etoc'' choices for local titles should be hopefully satisfactory in most cases, it is also possible to tell \etoc to try to use emulation from the document class via the command \csb{etocclasstocstyle}. An effort has been made to obtain something which works at one level deeper than the ones under \csa{part}. For example with \ctanpkg{KOMA-script}, we use the option |leveldown|. However this will not really work for deeper local ``lists of''.% % \footnote{And with \ctanpkg{KOMA-script} at version \texttt{3.30} or later the fact that unnumbered sections reset the subsection counter will cause bad problems in a \texttt{scrbook} document if a TOC, local to a \csa{subsection} uses a title which is un unnumbered section!} % But for some document using local ``lists of'' only for chapters or for sections in classes without chapters, this \csb{etocclasstocstyle} may be appropriate as it may allow the user to use the class interface for advanced control of the marks or other details. \item The \etoc document class agnostic default, from \csb{etocetoclocaltocstyle} which is automatically issued at package loading time, is completely customizable. \item This is experimental code and the user interface as well as the output may change. \item If using for example all three of \csb{localtableofcontents}, \csb{locallistoffigures} and \csb{locallistoftables}, in the same location after a division heading, and if the ``to toc'' related options either from \etoc or from \ctanpkg{tocbibind} are used, then \csb{localtableofcontents} must be the first one in order to be able to list the other two (and itself). It can not see the ``lists of'' coming before itself at the same division level. \item Regarding the TOC title style, \etoc knows the standard classes, the \ctanpkg{KOMA-script} main classes and the \ctanpkg{memoir} class. In an unknown class it will use the code from the |article| class emulation. For the local TOCs and local ``lists of'' it uses as with the known classes its own class-independent code from \csb{etocetoclocaltocstyle}. \item One can tell \etoc to not replace the original \csa{tableofcontents} via \csb{etockeeporiginaltableofcontents} (it will still be possible to use \csb{etoctableofcontents}), but the non-etoc \csa{tableofcontents} is usable only if document does not use \csb{locallistoffigures} or \csb{locallistoftables} as the latter two insert entries for figures, resp.\@ tables, in the main |.toc| file and only \etoc's \csb{tableofcontents} knows to ignore them. \item This is experimental code and the user interface as well as the output may change. \end{itemize} \section{The \csbhyp{etocsettocstyle} command} \label{etocsettocstyleintro} This is a command with two mandatory arguments: \centeredline{\csb{etocsettocstyle}\marg{before\_toc}\marg{after\_toc}} The \marg{before\_toc} part is responsible for typesetting the heading, for example it can be something like \starit{section}|{\contentsname}|. Here is an example of input: \begin{verbatim} \etocsettocstyle {\section*{Local table of contents}}% {}% don't do anything special after the toc contents \end{verbatim} Once issued it will have an impact on all next usages of \localtoc (or \toc) until it is used again (or some related command). Generally speaking the \marg{before\_toc} part should leave \TeX{} in ``vertical mode'': the line styles (either from the standard classes or the package default ones) all expect to get started in `vertical mode'. For more documentation of this and related commands see first \autoref{sec:compatoverview} then \autoref{sec:tocstyle} for the more detailed pre-\etocrelease{1.2} documentation. Only daring people will continue reading documentation as it now starts telling how to truly activate \etoc power. \section{The \csbhyp{etocsetstyle} command} \label{etocsetstyleintro} A distinction must be made between the \emph{line styles}, \emph{i.e.} the way the name, number and page numbers (aka \etoc-provided \csb{etocname}, \csb{etocnumber}, and \csb{etocpage}) are used at each level, and the \emph{toc display style} (for lack of a better name) which tells how the title should be set, whether an entry in the |.toc| file should be made, whether the contents should be typeset with multiple columns, etc... the latter is governed by the command \csb{etocsettocstyle} (and related commands) which has already been mentioned, and the former by the command \csb{etocsetstyle} with is the core of \etoc functionality. It has five mandatory arguments. % \centeredline {\csb{etocsetstyle}\color{blue}\marg{levelname}% \marg{start}\marg{prefix}\marg{contents}\marg{finish}} % The first one is the name of the sectional unit: a priori known names are |book|, |part|, |chapter|, |section|, |subsection|, |subsubsection|, |paragraph|, and |subparagraph|. Any other name can be declared and assigned to a (numeric) level via the \csb{etocsetlevel} command.% % \footnote{\etoc issues automatically \csb{etocsetlevel}\texttt{\string{appendix\string}\string{0\string}} (or wit h |1| if the document has no \csa{chapter} command), since \etocrelease{1.2}. Formerly this was done only with class \ctanpkg{memoir}.} The four other arguments of \csb{etocsetstyle} specify: 1) \emph{what to do when this level is first encountered, down from a more general one,} then 2) \& 3) (two arguments, a `prefix' and a `contents') \emph{how to use for this level the \csb{etocname}, \csb{etocnumber} and \csb{etocpage} parsed data,} and 4) \emph{the last argument is the code to execute when a division unit of higher importance than the defined level style is encountered.} Notice that this means that virtually \etoc manages a kind of tree-like substratum which is abstracted from the `flat' structure of the |.toc| data. You should now read \autoref{sec:linestyles} for the detailed documentation. \section{No auxiliary file is used beyond the TOC file} \label{sec:compatoverview} An important characteristic of \etoc is that it is allows many different TOCs in the same document, \emph{using only one} |.toc| \emph{file}! \begingroup \setcounter{mycounti}{0}% \etocinline \etocsetlevel{part}{1} \etocsetlevel{chapter}{1} \etocsetlevel{visibletoc}{0} \etocsetstyle{visibletoc} {} {\stepcounter{mycounti}} {} {} \etocsettocstyle{}{} \etocsetnexttocdepth{0} \tableofcontents The present documentation contains \arabic{mycounti} visible tables of contents (and a few invisible ones) and uses only one |.toc| file!% % \footnote{and the counting itself has been achieved by a table of contents which was inserted in this paragraph! See \autoref{sec:tocoftocs}.} \endgroup However, each \localtoc or \toc command will trigger the execution of the \emph{full contents} from the |.toc| file. The effect of \localtoc as well as the enforcement of the line styles as defined via \csb{etocsetstyle} are achieved via suitable redefinition of the \csa{contentsline} \LaTeX{} macro. But everything else present in the |.toc| file will be executed, as it is not possible for \etoc to control in any way what is present in the |.toc| file beyond \csa{contentsline} entries. So one should think twice before adding manually extra commands to the |.toc| file. See \autoref{sec:addingtotoc} for further discussion. \section{Compatibility mode}\label{subs:compat} \label{etoctoclines} \label{etocstandardlines} \label{etocclasstocstyle} \label{etocetoclocaltocstyle} \label{etocusertocstyle} \label{etoclocallistoffigureshook} \label{etoclocallistoftableshook} \etoc starts in a ``compatibility mode'', which means that it does not at all interfere with how the commands from the |.toc| file get executed as long as it has not been told explicitly to do so.% % \footnote{\label{fn:compat}for the ``toc display style'', by this we mean the aspects independant from the contents of the \texttt{.toc} file, \etoc checks if it knows the class, and then uses emulation code which was added manually to its source, and if not it defaults to the |article| class layout. No automated way to recover the global toc display for arbitrary document classes is implemented. But \etoc will detect if \ctanpkg{tocloft} has customized the TOC title.} This ``compatibility mode'' stops for matters of the ``toc display style'' as soon as \csb{etocsettocstyle} is made use of, and for matters of the ``toc line styles'' as soon as \csb{etocsetstyle} is used for \emph{any} level (part, chapter, section, ...). Levels not receiving explicit configurations will use some pre-defined defaults which are in \etoc source code. \begin{description} \item[\csb{etocclasstocstyle}] sets the `main toc layout' to be as without |\usepackage{|\etoc\unskip|}|. Local TOCs will also obey the document class style but with an attempt to use a heading one level down. This tries to adapt to being in the top level below \csa{part} (i.e. in a \csa{chapter} or \csa{section}) but is not adapted to deeper local TOCs. At \etocrelease{1.2}, previously existing \csa{etocstandarddisplaystyle} was made into a deprecated synonym to this (the version from earlier releases made no attempt to adapt the style of the local TOCs to the level where it is located). \item [\csb{etocetoclocaltocstyle}] (package default) Activates a heading style for local tables of contents (and ``lists of'') which tries to adapt automatically to the surrounding level. It thus by-passes the configuration done by \csb{etocsettocstyle} which will then apply only to the main TOC. Using again \csb{etocsettocstyle} de-activates this behavior. \item [\csb{etocusertocstyle}] means to obey the \csb{etocsettocstyle} configuration as previously in place, not only for the main TOC but also for local ones. If \csb{etocsettocstyle} has never been used, this means that we return to the situation from \csb{etocclasstocstyle}. \item [\csb{etocstandardlines}] (package default) Sets the `content lines' to be as without |\usepackage{|\etoc\unskip|}|. \item [\csb{etoctoclines}] sets the `content lines' to match the last encountered \csb{etocsetstyle} specs. \item [\csb{etocdefaultlines}] sets the `content lines' to use \etoc pre-defined ones. The denomination is a bit confusing as `default' here means that these line styles are the ones defined by default, but not used by default\dots{} perhaps \csa{etocfallbacklines} would have been a better name. Please be aware that by design the |paragraph| and |subparagraph| linestyles are configured by \csb{etocdefaultlines} to display nothing at all. \end{description} Naturally \csb{etocsettocstyle} and \csb{etocsetstyle} can be used arbitrarily many times in the document body (or already in the preamble but there one can not typeset a TOC; however one can prepare commands which will be activated later from inside the document body). And they obey the scope-limiting effect of \LaTeX{} environments. For an illustration of using \etoc in compatibility mode see \autoref{sec:testingcompat}. And see \autoref{sec:anothercompat} for some ways to let the line styles use the code from the document class but with some custom changes. During expansion of \csb{locallistoffigures} or \csb{locallistoftables}, the macros \csb{etoclocallistoffigureshook} resp.\@ \csb{etoclocallistoftableshook} are executed right before typesetting the entries. Their default definitions (refer to source code for more info): \begin{verbatim} \def\etoclocallistoffigureshook{\etocstandardlines}% \def\etoclocallistoftableshook {\etocstandardlines}% \end{verbatim} means compatibility mode, i.e.\@ the macros \csa{l@figure} and \csa{l@table} will be the ones involved, as if we were in the global \csa{listoffigures} or \csa{listoftables}. If you redefine these ``hook''-macros to do nothing, the figure/table entries will use the style as appropriate for entries at numerical level one deeper than the ``local top'': i.e. in a section they will be typeset as if being subsections. If you have both \csb{locallistoffigures} and a \localtoc, this may align better vertically than the \LaTeX{} line style from the global ``Lists Of''. Note that ``hook'' is used here in a very naive meaning of some macro which is pre-located somewhere and that one can redefine to obtains various effects. \section{A list of the commands added at \texorpdfstring{\protect\etocrelease{1.2}}{1.2}} \label{etocstoretocstyleinto} \label{etocstorelinestylesinto} \label{etocstorethislinestyleinto} \label{etocifislocal} \label{etocifislocaltoc} \label{etocifislocallof} \label{etocifislocallot} %%\label{etocsettocstyle} \label{etocifmaintoctotoc} \label{etociflocaltoctotoc} \label{etociflocalloftotoc} \label{etociflocallottotoc} \label{etocifisstarred} \label{etoclevel} \label{etocthelevel} %%\label{etocthemaxlevel} \label{etocifunknownlevelTF} \label{etocdivisionnameatlevel} \label{etoclocalheadtotoc} \label{etocglobalheadtotoc} \label{etocetoclocaltocmaketitle} %%\label{etocetoclocaltocstyle} \label{localcontentsname} \label{locallistfigurename} \label{locallisttablename} \label{etocetoclistoffiguresmaketitle} \label{etocetoclistoftablesmaketitle} \label{etocclasslocaltocmaketitle} \label{etocclasslocallofmaketitle} \label{etocclasslocallotmaketitle} \label{etocclassmaintocaddtotoc} \label{etocclasslocaltocaddtotoc} \label{etocclasslocallofaddtotoc} \label{etocclasslocallotaddtotoc} \begin{shaded}\footnotesize %\setstretch{1} One pre-existing command has been modified: \csa{etocstandarddisplaystyle} which is now deprecated and replaced by \csb{etocetoclocaltocstyle}. The former behavior was to set also local TOCs to apply the style from the main TOC, which basically never works really well. As explained already one can use \csb{etocclasstocstyle} to try to get for top local TOCs a suitable behavior, for example in the case of \ctanpkg{KOMA-script} classes, a behavior using their |leveldown| option. But this will not be satisfactory for deeper local TOCs or ``lists of''. \end{shaded} \DeleteShortVerb\| First there is \csb{etocsetup}: \begin{description} \item [\csb{etocsetup}\marg{key[=true|false],...}] has already been mentioned earlier. It is usable with \etocoption{maintoctotoc}, \etocoption{localtoctotoc}, \etocoption{localloftotoc}, \etocoption{locallottotoc}, and \etocoption{ouroboros}, everywhere in the document after the package loading. \end{description} \MakeShortVerb\| Then some utilities relative to the \csb{etocsetlevel} command: \begin{itemize} \item \csb{etoclevel}\marg{levelname} expands to a numeric quantity giving the level of a given string argument. For example \csb{etoclevel}|{section}| will usually produce a \TeX{} number denotation of value one. It is provided for matters of programming, as its output format is suitable for usage in \csa{ifnum} test. For typesetting, it should be prefixed by the \TeX{} primitive \csa{number}. \item \csb{etocthelevel}\marg{levelname} expands to a explicit digits (possibly prefixed by a minus sign), i.e.\@ it is equivalent to |\number|\csb{etoclevel}\marg{levelname} and is provided as a convenience. (added at \etocrelease{1.2a}) \item \csb{etocthemaxlevel} expands to either |12| or |6| (default) depending on whether the \etocoption{deeplevels} option was used or not. See the documentation of \csb{etocsetlevel} for more. (added at \etocrelease{1.2a}) \item \csb{etocifunknownlevelTF}\marg{levelname}\marg{True}\marg{False} is a conditional to test if a level name has been declared to \etoc. \end{itemize} Then two utilities to help store and restore toc line styles: \begin{description} \item [\csb{etocstorelinestylesinto}\marg{control\_sequence}] This is a command with one mandatory argument which must be a control sequence such as \csa{foo}. The macro \csa{foo} is then overwritten with no check if it exists already. Its effect is to store inside \csa{foo} the current toc line styles configuration, for all levels at once. Then inserting \csa{foo} in the document will restore all line styles to the state they were in at time of usage of \csb{etocstorelinestylesinto}. \item [\csb{etocstorethislinestyleinto}\marg{name or number}\marg{control\_sequence}] Same principle but now \csa{foo} will store the line style for the specified level only. This argumant can be numerical or a name. And thus executing \csa{foo} will then have the same effect as re-doing the \csb{etocsetstyle} for that level. \end{description} The more numerous additions are relative to usage of \csb{etocsettocstyle}, i.e.\@ customizing the ``display'' style. This mainly means matters relative to the title of the local TOCs or Lists Of, inclusive of whether they should add an entry into the |.toc| file matching their titles. Indeed, please be aware that as soon as you use \csb{etocsettocstyle} you will have to handle yourself the support for such behavior. Of course, as you also control the options, you don't have to use the provided command layer which tests the status of these options, but it is provided anyway as public interface. Indeed all of this is done via commands with no |@| letter in their names, and the package itself uses this public interface in its implementation of the default behavior, adjusted to the document class. The documentation here is brief, check for more the source code to which the listed commands are hyperlinked (from the last third of their names). Some of these commands are defined via batch processing done in loops in the code, and the hyperlinks only point to some initial dummy definitions, which were added only to provide such link targets, and one has to read the code further to discover the actual definitions. \begin{itemize} \item \csb{etocifislocal}, \csb{etocifislocaltoc}, \csb{etocifislocallof}, \csb{etocifislocallot} can be used from inside the \csb{etocsettocstyle} first or second argument to select either one of the \marg{True} and \marg{False} branches. \item \csb{etocifmaintoctotoc}, \csb{etociflocaltoctotoc}, \csb{etociflocalloftotoc}, \csb{etociflocallottotoc}, are conditionals matching the options and selecting one of the \marg{True} or \marg{False} branches. \item \csb{etocifisstarred}\marg{True}\marg{False} says from inside the \csb{etocsettocstyle} arguments if the toc or `list of' command was in starred form. The \csb{etocetoclocaltocstyle} and \csb{etocclasstocstyle} have been configured so that when a |*| follows a \toc or \localtoc or local ``lists of'', its ``to toc'' behavior (if active from \ctanpkg{tocbibind} or \etoc own options) is canceled. They use \csb{etocifisstarred} to this effect. \item \csb{etoclocalheadtotoc}\marg{levelname}\marg{text} is a synonym for \centeredline{\csa{addcontentsline}|{toc}|\marg{@levelname}\marg{text}} % Pay attention to automatically added |@| character.% % \footnote{Without this syntax, it would not be possible to have all three of \localtoc, \csb{locallistoffigures} and \csb{locallistoftables} one after the other following a given document heading, due to deep internals of the local TOC \etoc mechanism. Notice that these internal details are susceptible to change with no advance notice and the actual implementation of \csb{etoclocalheadtotoc} may change.} Use this for example in the second argument of \csb{etoclocalmulticol}.% % \footnote{There is currently no analog of \csb{etoclocalmulticol} and similar commands which would be related to \csb{locallistoffigures} or \csb{locallistoftables} as \csb{etoclocalmulticol} is to \localtoc.} \item \csb{etocglobalheadtotoc}\marg{levelname}\marg{text} is a synonym for \centeredline{\csa{addcontentsline}|{toc}|\marg{levelname}\marg{text}} % We have so many commands we can define another useless one\dots{} for aesthetic reasons of coherent names\dots{} \item \csb{etocdivisionnameatlevel}\marg{number} is an expandable construct which starts from a numerical level from |-2| to |5| and produces one of |book|, |part|, ..., up to |subparagraph| as per the built-in \LaTeX\ (and standard classes) default assignments (and \ctanpkg{memoir} for |book|). Under option \etocoption{deeplevels} the numerical level can go up to |11| but as there is no standard default for documents with extra sectioning commands (e.g. is it using \csa{subsubsubparagraph}? or \csa{subsubsubsection}? or some \csa{subivsection}?), the user has probably to copy and redo with changes the package definition of \csb{etocdivisionnameatlevel} in that case. \item \csb{etocetoclocaltocmaketitle} is the command used by \csb{etocetoclocaltocstyle} which typesets a local ``list of'' title using an un-numbered sectioning appropriate to its scope. See the source code for how it looks. \item \csb{etocetoclistoffiguresmaketitle} and \csb{etocetoclistoftablesmaketitle} are similar, see the source code. \item \csb{localcontentsname}, \csb{locallistfigurename}, \csb{locallisttablename} are self-explanatory. \item \csb{etocclasslocaltocmaketitle}, \csb{etocclasslocallofmaketitle}, \csb{etocclasslocallotmaketitle}, \csb{etocclassmaintocaddtotoc}, \csb{etocclasslocaltocaddtotoc}, \csb{etocclasslocallofaddtotoc}, \csb{etocclasslocallotaddtotoc}, well again see source code. \end{itemize} Finally there is a command to help store/restore a given display style configuration. \begin{description} \item [\csb{etocstoretocstyleinto}\marg{control\_sequence}] This is a command with one mandatory argument which must be a control sequence such as \csa{foo}. The macro \csa{foo} is then overwritten with no check if it exists already. Its effect is to store inside \csa{foo} the data configured by the last \csb{etocsettocstyle}. Then inserting \csa{foo} in the document will restore the saved toc style.% % \footnote{It is impossible to store the style used by the \csb{etocetoclocaltocstyle} for local TOCs. Only the one for main TOCs, which was configured by last usage of \csb{etocsettocstyle} is saved in \csa{foo}. After \csa{foo} is executed, one needs to again issue \csb{etocetoclocaltocstyle} if one wants the latter to be active.} \end{description} % {\footnotesize (clearing this page as next display must be on one page % only)\par} % \clearpage \section{A partial list of the package commands} %\enlargethispage{2\baselineskip} %\vskip-\baselineskip\vskip0pt %\parshape 1 -1.5cm \dimexpr\linewidth+3cm\relax %\begin{minipage}{\dimexpr\linewidth+3cm\relax} \begin{multicols}{2}\parindent0pt\relax\setstretch{1}% \csb{etocbeforetitlehook}\par \csb{etocaftertitlehook}\par \csb{etocaftercontentshook}\par \csb{etocaftertochook}\par \csb{etocsettocstyle}\par \csb{etocclasstocstyle}\par \csb{etocetoclocaltocstyle}\par \csb{etocmulticol}\par \csb{etocframed}\par \csb{etocruled}\par \csb{etocsettocdepth}\par \csb{etocsettocdepth.toc}\par \csb{etocsetnexttocdepth}\par \csb{etocdepthtag.toc}\par \csb{etocsettagdepth}\par \csb{etocobeydepthtags}\par \csb{etocdefaultlines}\par \csb{etocstandardlines}\par \csb{etoctoclines}\par \csb{etocsetlevel}\par\columnbreak \flushright \csb{etocsetstyle}\par \csb{etocskipfirstprefix}\par \csb{etocifnumbered}\par \csb{etociffirst}\par \csb{etoclink}\par \csb{etocthelink}\par \csb{etocname}\par \csb{etocnumber}\par \csb{etocpage}\par \csb{etocthename}\par \csb{etocthenumber}\par \csb{etocthepage}\par \csb{etocthelinkedname}\par \csb{etocthelinkednumber}\par \csb{etocthelinkedpage}\par % \csb{etocdisplay}\par % \csb{etocframedstyle}\par % \csb{etocignoredepthtags}\par % \csb{etocignoretoctocdepth}\par % \csb{etocimmediatedepthtag.toc}\par % \csb{etocimmediatesettocdepth.toc}\par % \csb{etocimmediatetoccontentsline}\par % \csb{etocinline}\par % \csb{etoclocalframed}\par % \csb{etoclocalmulticol}\par % \csb{etoclocalruled}\par % \csb{etocmulticolstyle}\par % \csb{etocobeytoctocdepth}\par % \csb{etocruledstyle}\par % \csb{etoctoccontentsline}\par %\flushright \csb{localtableofcontents}\par \mbox{}\llap{\csb{localtableofcontentswithrelativedepth}}\par \csb{locallistoffigures}\par \csb{locallistoftables}\par \csb{tableofcontents}\par %\vspace{5\baselineskip}\hrule height 0pt \end{multicols} %\end{minipage}\par {\footnotesize\setstretch{1} The above is not an exhaustive list of all the package user commands. For example, it does not include most of those added at \etocrelease{1.2} and which were listed in the previous section.\par } \clearpage \etocdepthtag.toc {styling} \part{The \etoc styling commands} \label{part:styling} \thispartstats \etocsetstyle{section} {\begin{enumerate}[leftmargin=.75cm, label=\etocifnumbered {{\fboxrule1pt\fcolorbox{green}{white}{\etocnumber}}}{}]} {\normalsize\bfseries\rmfamily\item} {\etocname{} (page \etocpage)} {\end{enumerate}} \etocsetstyle{subsection} {\begin{enumerate}[leftmargin=0cm, label=\etocnumber]} {\normalfont \item} {\etocname{} (p.~\etocpage)} {\end{enumerate}} \etocsetstyle{subsubsection} {\par\nobreak\begingroup\normalfont\footnotesize\itshape\etocskipfirstprefix} {\allowbreak\,--\,} {\etocname} {.\hfil\par\endgroup\pagebreak[3]} % 27 janvier 2013 22:30 % je définis les macros (non protégées) % \etocthename, \etocthenumber, \etocthepage \etocruledstyle[1]{\etocfontminusone\color{green}% \fboxrule1pt\fboxsep1ex \framebox[\linewidth] {\normalcolor\hss Contents of \autoref{part:styling}\hss}} \localtableofcontents \label{toc:part:styling} The two main commands \csb{etocsettocstyle} and \csb{etocsetstyle} can be used anywhere in the document. Typically one will render the main global TOC in one style and local tables of contents in another. So the commands to style the local tables of contents will be executed after the main \toc (if it is first in document) either by direct injection in the document source, or encapsulated in user commands defined in the preamble. All commands obey the scope limiting effect induced by \LaTeX{} environments or the core \TeX |\begingroup/\endgroup| (or braces |{...}|) constructs. \section{The \csbhyp{etocsettocstyle} and related commands} \label{sec:tocstyle} \begingroup \etocsettocstyle{}{} \etocstandardlines \microtypesetup{protrusion=false} \DeclareTOCStyleEntry[numwidth=3em,indent=0em]{tocline}{subsection} \DeclareTOCStyleEntry[numwidth=3.5em,indent=3em]{tocline}{subsubsection} \localtableofcontents \label{toc:tocstyle} \endgroup \subsection{The \csbhyp{etocsettocstyle} command} \label{etocsettocstyle} The basics are explained in \autoref{etocsettocstyleintro}. Recall that the syntax is \centeredline{\csb{etocsettocstyle}\marg{before\_toc}\marg{after\_toc}} and here is a typical example of use: \begin{verbatim} \etocsettocstyle {\section*{Local table of contents}}% {}% don't do anything special after the toc contents \end{verbatim} The first argument to \csb{etocsettocstyle} can also contain instructions to mark the page headings. Or it could check to see if two-column mode is on, and switch to one-column style, and the \meta{after\_toc} part would then reenact the two-column mode. The commands to be described next \csb{etocmulticolstyle}, \csb{etocruledstyle}, and \csb{etocframedstyle} all call \csb{etocsettocstyle} as a lower-level routine, to initiate a \texttt{multi\-cols} environment in \marg{before\_toc} and close it in \marg{after\_toc}. \subsubsection{The \csbhyp{etocarticlestyle}, \csbhyp{etocbookstyle}, and others commands} \label{etocarticlestyle} \label{etocarticlestylenomarks} \label{etocbookstyle} \label{etocbookstylenomarks} \label{etocreportstyle} \label{etocreportstylenomarks} These are the commands used internally by \etoc in compatibility mode depending on the document class. For example \csb{etocarticlestyle} instructs \etoc to use |\section*{\contentsname}| (with marks on the page) and \csb{etocbookstyle} says to use |\chapter*{\contentsname}|. It can prove useful to issue \csb{etocarticlestyle} for a \csa{localtableofcontents} inside a chapter, in |book| class and compatibility mode for the global TOC display style. Here is the current list: \begin{itemize}[nosep] \item \csb{etocarticlestyle} \item \csb{etocarticlestylenomarks} \item \csb{etocreportstyle} \item \csb{etocreportstylenomarks} \item \csb{etocbookstyle} \item \csb{etocbookstylenomarks} \item \csb{etocmemoirstyle} \item \csb{etocscrartclstyle} \item \csb{etocscrreprtstyle} \item \csb{etocscrbookstyle} \end{itemize} The command \csb{etocclasstocstyle} will adapt to the document class. One can not use the \ctanpkg{KOMA-script} related commands or the \ctanpkg{memoir} one in standard classes. \subsubsection{The \csbhyp{etocinline} and \csbhyp{etocdisplay} commands} \label{etocinline} \label{etocnopar} \label{etocdisplay} With \csb{etocinline}, or its synonym |\etocnopar|, the \localtoc command and its variants do \emph{not} first issue a |\par| to close the previous paragraph. Hence, the table of contents can be printed in an inline style; or, if used only for preparing some token list or macro, it will leave nothing in the token stream on execution. Issue \csb{etocdisplay} to return to the default situation that \localtoc and variants issue a |\par| to switch to vertical mode before typesetting the TOC title and contents. Here is an example of an \emph{inline} table of contents, which has only subsections and uses the |itemize*| environment from \ctanpkg{enumitem} for them. The code used is \begin{verbatim} And the output is: \begingroup \etocglobaldefs \etocsetstyle {subsection} {\begin{itemize*}[itemjoin={{; }}, itemjoin*={{, and }}]} {} {\item [{\bfseries\etocnumber.}] \etocname\ (\emph{p. \etocpage })} {\end{itemize*}.}% \etocsetnexttocdepth {subsection}% \etocsettocstyle {a clone of a local table of contents, originally defined in \autoref{sec:tocstyle}, but here rendered completely differently via an inline \ctanpkg{enumitem} list: }{}% \etocinline\tableofcontents \ref{toc:tocstyle} \endgroup \end{verbatim} (observe that on executing the above there is no extra space after the colon beyond what is intended, and the current paragraph is simply continued) And the output is: \begingroup \etocglobaldefs \etocsetstyle {subsection} {\begin{itemize*}[itemjoin={{; }}, itemjoin*={{, and }}]} {} {\item [{\bfseries\etocnumber.}] \etocname\ (\emph{p. \etocpage })} {\end{itemize*}.}% \etocsetnexttocdepth {subsection}% \etocsettocstyle {a clone of a local table of contents, originally defined in \autoref{sec:tocstyle}, but here rendered completely differently via an inline \ctanpkg{enumitem} list: }{}% \etocinline\tableofcontents \ref{toc:tocstyle} \endgroup It was needed to use \csb{etocglobaldefs} because the \csa{item} command, as modified by \ctanpkg{enumitem} closes a group, hence the meaning of \csb{etocname}, \csb{etocnumber} and \csb{etocpage} would have been lost after it. A more impressive example of an inline table of contents (containing the full contents of this document, which subsections rendered as page footnotes...) is to be found in \autoref{sec:crazy}. \subsection{The \csbhyp{etocmulticolstyle}, \csbhyp{etocmulticol}, and \csbhyp{etoclocalmulticol} commands} \label{etocmulticolstyle} \label{etocmulticol} \label{etoclocalmulticol} This is a command with one optional and one mandatory argument: \centeredline{\csb{etocmulticolstyle}\oarg{number\_of\_columns}\marg{heading}} The \meta{number\_of\_columns} can go from 1 to 10 (it defaults to 2; if its value is 1, naturally no |multicols| environment is then created). The \meta{heading} will typically be some `vertical' material like: \meta{heading} = |\section*|\marg{title} but one may also have horizontal material like |\fbox{Hello World}| (\etoc adds automatically a |\par| at the end of this ``heading'' argument to \csb{etocmulticolstyle}). Here is an example: \begin{verbatim} \etocmulticolstyle{\noindent\bfseries\Large \leaders\hrule height1pt\hfill \MakeUppercase{Table of Contents}} \localtableofcontents \end{verbatim} After \csb{etocmulticolstyle} all future \csa{tableofcontents} will use the specified style until modified by renewed usage of \csb{etocsettocstyle} or variants. A shortcut combining the style specification and the table of contents and not impacting the styles of later TOCs is:% % \centeredline{\csb{etoclocalmulticol}\oarg{number\_of\_columns}\marg{heading}} % So the above example can be also obtained using: \begin{verbatim} \etoclocalmulticol{\noindent\bfseries\Large \leaders\hrule height1pt\hfill \MakeUppercase{Table of Contents}} \end{verbatim} % It has the advantage that the TOC styling as specified applies only to this sole local TOC. And there is also \csb{etocmulticol}\oarg{number\_of\_columns}\marg{heading} for global TOC. \subsection{The \csbhyp{etoctocstyle} command} \label{etoctocstyle} \centeredline{\csb{etoctocstyle}\oarg{kind}\marg{number\_of\_columns}\marg{title}% } % is the exact equivalent of doing % \centeredline{% \csb{etocmulticolstyle}|[|{\itshape number\_of\_columns}|]|% |{\kind*{|\itshape title\upshape|}}|} % where |kind| is one of |chapter|, |section|, . . . and defaults to |chapter| or |section| depending on the document class. As explained above one still has to issue \localtoc to typeset the TOC. And the styling, if not enclosed in a scope-limiting group or environment, applies to subsequent local TOCs. \subsubsection{The \csbhyp{etoctocstylewithmarks} command} \label{etoctocstylewithmarks} \label{etoctocstylewithmarksnouc} \centeredline{\csb{etoctocstylewithmarks}\oarg{kind}% \marg{number\_of\_columns}\marg{title}\marg{mark}% } % is the exact equivalent of doing % \centeredline {\csb{etocmulticolstyle}|[|{\itshape number\_of\_columns}|]|% |{\kind*{|\itshape title \ttfamily\upshape\string\markboth% |{\MakeUppercase{|{\rmfamily\itshape mark}|}}}}|} % where |kind| is one of |chapter|, |section|, ... The actual display of the marks depends on the settings of the page style. There is variant \csb{etoctocstylewithmarksnouc} which does not uppercase. \paragraph{Do we really want paragraph entries in the TOC?} \paragraph{really?} \subsection{The \csbhyp{etocruledstyle}, \csbhyp{etocruled} and \csbhyp{etoclocalruled} commands} \label{etocruledstyle} \label{etocruled} \label{etoclocalruled} The general format of \csb{etocruledstyle} is: % \centeredline{\csb{etocruledstyle}% \oarg{number of columns}\marg{title of the toc}% }% \noindent The title is horizontal material (the |LR| mode of \emph{\LaTeX{}, a document preparation system}): if it does not fit on one line it should be put in a \csa{parbox} of a given width. The green frame for the heading of the table of contents at the \hyperref[toc:part:styling]{the start of this part} was obtained with: \begin{verbatim} \etocruledstyle[1]{\etocfontminusone\color{green}% \fboxrule1pt\fboxsep1ex \framebox[\linewidth] {\normalcolor\hss Contents of this part\hss}} \localtableofcontents \end{verbatim} As a shortcut to set the style with \csb{etocruledstyle} and then issue a \localtoc, all inside a group so that future table of contents will not be affected, there is: % \centeredline{\csb{etoclocalruled}\oarg{number\_of\_columns}\marg{title}} % And there is also \csb{etocruled} for the global TOC. \subsection{The \csbhyp{etocframedstyle}, \csbhyp{etocframed}, and \csbhyp{etoclocalframed} commands} \label{etocframedstyle} \label{etocframed} \label{etoclocalframed} Same mechanism: % \centeredline{\csb{etocframedstyle}\oarg{number\_of\_columns}\marg{title}} % and the accompanying shortcut: % \centeredline{\csb{etoclocalframed}\oarg{number\_of\_columns}\marg{title}} % The shortcut is used if one does not want to modify the style of the next TOCs (the other way is to put the whole thing inside braces or a |\begingroup...\endgroup|; there is also \csb{etocframed} for a global table of contents). The entire table of contents is framed. The title itself is not framed: if one wants a frame one should set it up inside the \meta{title} argument to \csb{etocframedstyle} or \csb{etocframed}. The colors for the background and for the components (top, left, right, bottom) of the border are specified via suitable |\renewcommand|'s (see \autoref{ssec:customdisplay}). A |minipage| is used, hence the produced table of contents isn't compatible with a page break. For allowing page breaks, use of the commands of \ctanpkg{mdframed} or \ctanpkg{tcolorbox} in the arguments of \csb{etocsettocstyle} is recommended. Examples in this document are on pages \pageref{toc:d}, \pageref{toc:floating}, \pageref{toc:b}, and \pageref{toc:clone}. \subsection{Customizing the pre-defined toc display styles} \label{ssec:customdisplay} \label{etocabovetocskip} \label{etocbelowtocskip} \label{etoccolumnsep} \label{etocmulticolsep} \label{etocmulticolpretolerance} \label{etocmulticoltolerance} \label{etocdefaultnbcol} %\label{etocinnertopsep}% déjà défini \label{etoctoprule} \label{etoctoprulecolorcmd} \label{etocinnerleftsep} \label{etocinnerrightsep} \label{etocinnerbottomsep} \label{etocleftrule} \label{etocrightrule} \label{etocbottomrule} \label{etocleftrulecolorcmd} \label{etocrightrulecolorcmd} \label{etocbottomrulecolorcmd} \label{etocbkgcolorcmd} \label{etocframedmphook} We list the relevant macros, what they do should be legible from their names. Note that dimensions are stored in macros so are modifed using \csa{renewcommand}'s and not \csa{setlength}'s. And color related commands are not color definitions, they execute \csa{color}, and their effect gets canceled by re-defining them to do \csa{relax} or \csa{empty}. \begin{verbatim} \newcommand*\etocabovetocskip{3.5ex plus 1ex minus .2ex} \newcommand*\etocbelowtocskip{3.5ex plus 1ex minus .2ex} \newcommand*\etoccolumnsep{2em} \newcommand*\etocmulticolsep{0ex} \newcommand*\etocmulticolpretolerance{-1} \newcommand*\etocmulticoltolerance{200} \newcommand*\etocdefaultnbcol{2} \newcommand*\etocinnertopsep{2ex} \newcommand*\etoctoprule{\hrule} \newcommand*\etoctoprulecolorcmd{\relax} % for the framed style only: \newcommand*\etocinnerleftsep{2em} \newcommand*\etocinnerrightsep{2em} \newcommand*\etocinnerbottomsep{3.5ex} \newcommand*\etocleftrule{\vrule} \newcommand*\etocrightrule{\vrule} \newcommand*\etocbottomrule{\hrule} \newcommand*\etocleftrulecolorcmd{\relax} \newcommand*\etocrightrulecolorcmd{\relax} \newcommand*\etocbottomrulecolorcmd{\relax} \newcommand*\etocbkgcolorcmd{\relax} % hooks \newcommand\etocframedmphook{\relax} \end{verbatim} The \csa{etocframedmphook} is positioned immediately after the beginning of a minipage environment where the contents of the framed TOC are typeset. The \csa{...colorcmd} commands are initially set to expand to \csa{relax} (hence do not require package |color| or |xcolor| to be loaded). If one has modified a command such as \csa{etocbkgcolorcmd} to expand to a color command and wants to reset it to do nothing, one \emph{must} use |\renewcommand{\etocbkgcolorcmd}{\relax}| and not \csa{let}\csa{etocbkgcolorcmd}\csa{relax}. Regarding the dimensions of the top rule they can be specified in |ex|'s or |em|'s as in this example: \centeredline{|\renewcommand{\etoctoprule}{\hrule height 1ex}|} The package code is done in such a manner that it is the font size in instance at the end of typesetting the title argument to \csb{etocruled} or \csb{etocframed} which will be used for the meaning of the `1ex'. Of course also the other rule commands can have their dimensions in font relative units, but their values are decided on the basis of the font in effect just before the table of contents. The top and bottom rules do not have to be rules and can be horizontal \emph{leaders} (of a specified height) in the general \TeX{} sense. However the left and right rules are not used as (horizontal) leaders but as objects of a given specified width. Note that \emph{only} the Plain \TeX{} syntax for rules is accepted here. \subsection{Headings, titles, \csbhyp{etocoldpar}, \csbhyp{etocinnertopsep}} \label{etocinnertopsep} \label{etocoldpar} For \csb{etocmulticolstyle} the mandatory \meta{heading} argument can be either vertical mode material like |\section*{\emph{Table of Contents}}| or horizontal mode material like in the simple |\etocmulticolstyle{Hello World}|. No explicit |\par| or empty line can be inserted in the mandatory argument of \csb{etocmulticolstyle}, but \etoc provides \csb{etocoldpar} as a substitute: it does |\let\etocoldpar\par| before the |multicols| environment and inserts this |\etocoldpar|\footnote{this command \csb{etocoldpar} (= working \csa{par} in the argument to \csb{etocmulticolstyle}) is not related to the switch \csb{etocinline} whose purpose is to tell \etoc not to do a \csa{par} before the table of contents.} at the end of the heading, then does a vertical skip of value \csb{etocinnertopsep}. The command \csb{etocoldpar} can also be used explicitely if needed in the mandatory argument to \csb{etocmulticolstyle} (it is not allowed to insert an empty line in this argument). On the other hand the commands \csb{etocruledstyle} and \csb{etocframedstyle} expect an argument ``in LR mode'' (to use the terminology from \emph{LaTeX, a document preparation system}). This means that multiline titles are only possible if enclosing them inside something like a \csa{parbox}. An important dimension used by all three of \csb{etocmulticolstyle}, \csb{etocruledstyle} and \csb{etocframedstyle} is \csb{etocinnertopsep}. It gives the amount of separation between the heading and the start of the contents. Its default value is |2ex| and it is changed with |\renewcommand*{\etocinnertopsep}|\marg{new\_value}, not with |\setlength|. \section{Starred variants and hooks} \label{tableofcontents*} \label{localtableofcontents*} \label{etocbeforetitlehook} \label{etocaftertitlehook} \label{etocaftercontentshook} \label{etocaftertochook} The \toc, \localtoc, \csb{etocmulticol}, and all their cousins have starred variants (the star must be before the other arguments). The non-starred variants execute the \csb{etocaftertitlehook}, whose default definition is to do nothing. The starred variants do not execute this hook. For example, imagine you are using |book| class and want \localtoc to use a section-like title, but unnumbered. Assuming the main \toc comes first in the document, you can insert this after it: \begin{verbatim} \etocarticlestyle \renewcommand{\etocaftertitlehook}{\addcontentsline{toc}{section}{\contentsname}} \end{verbatim} This configures the way \localtoc will behave (or \toc) from now on in the document. The first line tells essentially to use |\section*{\contentsname}|, and the second line says to insert the title in the |.toc| file itself (thus to be displayed by the main table of contents). Notice that \ctanpkg{hyperref} package will then automatically create suitable anchor and one should \emph{not} use explicitly \cs{phantomsection} here (it would let the anchor be located below not above the title). % problème avec \xspace With this set-up issuing \localtoc\unskip|*| will ignore the \csb{etocaftertitlehook} hence not send the local toc title to the |.toc| file. This mimics the \ctanpkg{memoir} class behavior, and can also be used with it. For more on \ctanpkg{memoir} class with \etoc, see \autoref{ssec:memoir}. There are further hook macros: \csb{etocaftercontentshook}, \csb{etocbeforetitlehook} and \csb{etocaftertochook} which are initially defined to do nothing and can be used for some special effects. They are executed whether or not the table of contents command was starred. For example, the present document executed \begin{verbatim} \renewcommand{\etocbeforetitlehook}{\setstretch{1}} \end{verbatim} as it is globally using the \ctanpkg{setspace} command \csa{onehalfspacing}. Not using \csa{singlespacing} in the hook as it does a systematic vertical skip of one baseline, which is unwanted in our usage. \begin{framed} In recent years, the \LaTeX{} kernel has added a general ``hook'' mechanism with a user interface of the type |\AddToHook{...}{...}|. The \etoc macros with `hook' ending their names are much simpler things which are supposed to be manipulated only via \csa{renewcommand} or \csa{def} direct overwrites. In future, and to the extent the author has time for that addition, with its costly documentation updates collaterals, and thoughts about backward compatibility, \etoc should arguably tap into the general tools provided by recent \LaTeX{} kernels. \end{framed} \section{The \csbhyp{etocsetstyle} and related commands} \label{sec:linestyles} \label{etocsetstyle} \label{etocname} \label{etocpage} \begingroup \etocsettocstyle{}{} %\setuptoc{toc}{noprotrusion}% pas d'effet mais c'est normal car ce n'est pas % % KOMA mais etoc qui fait le style global \microtypesetup{protrusion=false} \DeclareTOCStyleEntry[numwidth=3.2em,indent=0em]{tocline}{subsection} \etocstandardlines \localtableofcontents \label{toc:linestyles} \endgroup Let us explain how \etoc was used to produce the table of contents displayed at the beginning of this \autoref{part:styling}. This is a local table of contents, and we used the command \localtoc. The line styles were (essentially) obtained in the following manner:% \footnote{the present document has {\ttfamily\string\renewcommand\string{% \string\familydefault\string}\string{\string\sfdefault\string}} in its preamble, hence \csa{normalfont} switches to the |sans| typeface; so in the section line-style, I wrote \csa{rmfamily} instead.} \begingroup\small \begin{filecontentshere}{etocsnippet-\snippetno.tex} \etocsetstyle{section} {\begin{enumerate}} {\normalsize\bfseries\rmfamily\item} {\etocname{} (page \etocpage)} {\end{enumerate}} \etocsetstyle{subsection} {\begin{enumerate}} {\normalfont\item} {\etocname{} (p.~\etocpage)} {\end{enumerate}} \etocsetstyle{subsubsection} {\par\nobreak\begingroup\normalfont \footnotesize\itshape\etocskipfirstprefix} {\allowbreak\,--\,} {\etocname} {.\hfil\par\endgroup\pagebreak[3]} \end{filecontentshere} \endgroup % Note 2023/02/22: pour une raison que je ne vais pas chercher à comprendre % le etocsnippet-01 était mis du mauvais côté (dans la marge intérieure, pas % extérieure) lorsque ce \marginattach était avant le \endgroup \marginattach These provisory style definitions rely on the automatic numbering generated by the |enumerate| environments but it is much better to use the further command \csb{etocnumber} inside the item label, which gives the real thing. The improved definitions will thus be explained later. With this style, one would have to be imaginative to design something then for paragraph and subparagraph entries! perhaps as superscripts? Well, usually one does not need paragraphs and subparagraphs numbered and listed in the TOC, so our putative user here chose a design where no provision is made for them and added the definitive: \begin{verbatim} \etocsetstyle{paragraph}{}{}{}{} \etocsetstyle{subparagraph}{}{}{}{} \end{verbatim} This is also the situation with the default package line styles! Each \csb{etocsetstyle} command has five mandatory arguments: % \centeredline{\csb{etocsetstyle}\color{blue}\marg{levelname}\marg{start}\marg{prefix}\marg{contents}\marg{finish}} % The initially recognized \meta{levelname}'s are the sectioning levels of the standard document classes: from \emph{part} (or \emph{book} which is used by the \ctanpkg{memoir} class) down to \emph{subparagraph}. The \meta{start} code is executed when a toc entry of that level is encountered and the previous one was at a higher level. The \meta{finish} code is executed when one again encounters a higher level toc entry. In the meantime all entries for that level are typeset by executing first the \meta{prefix} code and then the \meta{contents} code. The (robust) commands \csb{etocname}, \csb{etocnumber} and \csb{etocpage} are provided for use inside the \meta{prefix} and \meta{contents} parts of the \csb{etocsetstyle} specification. They represent of course, the name, number, and page number of the corresponding toc entry. If package \ctanpkg{hyperref} is active in the document and has added hyperlinks to the TOC data, then these links are kept in the commands \csb{etocname}, \csb{etocnumber} and \csb{etocpage} (this last one will have a link only if \ctanpkg{hyperref} was passed either option \emph{linktoc=all} or option \emph{linktoc=page}.)% % \footnote{As expected, in case of \emph{linktoc=page}, only \csb{etocpage} is an hyperlink, not \csb{etocname} nor \csb{etocnumber}. See \csb{etoclink} on how to create hyperlinks with the entry target.} % In accordance with the \ctanpkg{hyperref} native behavior, no link gets incorporated into \csb{etocpage} if the page number is empty. \subsection{The \csbhyp{etocskipfirstprefix} and \csbhyp{etociffirst} commands} \label{etocskipfirstprefix} \label{etociffirst} \label{etocxiffirst} The chosen |subsubsection| style made use of the command \csb{etocskipfirstprefix}, which instructs \etoc to \emph{not} use for the first item the specified \meta{prefix} code. The command \csb{etociffirst}\marg{YES CODE}\marg{NO CODE} is a more flexible way to customize the \meta{prefix} (and \meta{contents}) specifications. It executes the \meta{YES CODE} branch if this is the first unit at that level (inside a lower level) and the \meta{NO CODE} if not. This is a robust command which survives to expansion (for example in an |enumitem| label). The variant \csb{etocxiffirst} does the same, but is expandable. \subsection{The \csbhyp{etocnumber} command} \label{etocnumber} So far, our specifications would use the numbering generated by the |enumerate| environments, but of course we generally want the actual numbers as found in the |.toc| file. This is available via the \csb{etocnumber} command. To get the labels in the |enumerate| list to use it we can proceed with the syntax {\ttfamily label=\char32} from the package |enumitem|: \begin{verbatim} \etocsetstyle{section} {\begin{enumerate}[label=\etocnumber]} {\normalsize\bfseries\rmfamily\item} {\etocname{} (page \etocpage)} {\end{enumerate}} \end{verbatim} Rather than just \csb{etocnumber} we then used something like |\fbox{\etocnumber}|. Note that \csb{etocnumber} is a robust command which explains why it can be used inside the label specification without needing an added |\protect|. \subsection{The \csbhyp{etocifnumbered} switch} \label{etocifnumbered} \label{etocxifnumbered} The \csa{fbox} would give an unaesthetic result in the case of an unnumbered section (which ended up in the table of contents via an \csa{addcontentsline} command).\footnote{as seen we use \csa{fcolorbox} rather than \csa{fbox}. Due to some redefinition made by package |xcolor|, had we used \csa{fbox} (and not used \ctanpkg{hyperref}) we would have needed \csa{protect}\csa{fbox}.} The \csb{etocifnumbered}\marg{A}\marg{B} command executes \meta{A} if the number exists, and \meta{B} if not. So we use it in the code which was finally chosen for the |section| level: \begin{verbatim} \etocsetstyle{section} {\begin{enumerate}[leftmargin=.75cm, label=\etocifnumbered {{\fboxrule1pt\fcolorbox{green}{white}{\etocnumber}}}{}]} {\normalsize\bfseries\rmfamily\item} {\etocname{} (page \etocpage)} {\end{enumerate}} \etocsetstyle{subsection} {\begin{enumerate}[leftmargin=0cm, label=\etocnumber]} {\normalfont \item} {\etocname{} (p.~\etocpage)} {\end{enumerate}} \end{verbatim} If we had changed only the |section| level, and not the |subsection| level, an error on compilation would have occurred because the package style for subsections expects to start `in vertical mode'. An additional \csa{par} token in the \meta{contents} part of the |section| level would have fixed this: |{...(page \etocpage)\par}|. The command \csb{etocifnumbered} is robust; \csb{etocxifnumbered} has the same effect but is expandable. \subsection{The \csbhyp{etocthename}, \csbhyp{etocthenumber}, and \csbhyp{etocthepage} commands} \label{etocthename} \label{etocthenumber} \label{etocthepage} It is sometimes desirable to have access to the name, number and page number without the hyperref link data: something similar to the starred variant of the \csa{ref} command, when package \ctanpkg{hyperref} is used. For example one may wish to use the unit or page number in some kind of numeric context, or change its formatting. This is provided by \csb{etocthename}, \csb{etocthenumber}, and \csb{etocthepage}. These commands are not ``robust'', in fact it is expected they will be often submitted to one expansion step so that their contents can easily be recovered and stored perhaps for delayed usage. \subsection{The \csbhyp{etoclink} command} \label{etoclink} The command \csb{etoclink}\marg{text} can be used in the line style specifications in a manner analogous to \csb{etocname}, \csb{etocnumber} and \csb{etocpage}. It creates a link (if \ctanpkg{hyperref} is present% % \footnote{Prior to \etocrelease{1.1a}, no such link was added if the \texttt{.toc} file entry was encountered with \ctanpkg{hyperref}'s option \texttt{linktoc} set to \texttt{none}.}) % whose target is the corresponding document unit and whose name is the given \meta{text} mandatory argument. Hence |\etoclink{\etocthename}| is under default conditions of \ctanpkg{hyperref} like the original \csb{etocname}, because the latter is already hyperlinked. Under \emph{linktoc=page} context |\etoclink{\etocthename}| adds the hyperlink which is missing from \csb{etocname}. Similarly under the default \ctanpkg{hyperref} condition (i.e.\@ \emph{linktoc=section}) \csb{etocpage} is not an hyperlink, but one can use |\etoclink{\etocthepage}|. The command \csb{etoclink} is robust. % Since |etoc 1.08j| it contains the link % destination in an already expanded form, so for example can be used even after % a |&| in a tabular construction, if \csb{etocglobaldefs} was issued. \makeatletter\scr@activate@xsection{1}\makeatother % [] goes to head but {} to toc % What would really be useful is an option for the length of {} to be measured % and opt for [] only if does not fit on one header line \subsection[The \csbhyp{etocthelinkedname} et al.\protect\@{} commands] {The \csbhyp{etocthelinkedname}, \csbhyp{etocthelinkednumber}, \csbhyp{etocthelinkedpage} and \csbhyp{etocthelink} commands} \label{etocthelinkedname} \label{etocthelinkednumber} \label{etocthelinkedpage} \label{etocthelink} \makeatletter\scr@activate@xsection{0}\makeatother The meanings of these commands can be stored for delayed usage. For example this is done in the \hyperref[tocastree]{examples with trees}. There has been a \textbf{breaking change} at \etocrelease{1.1a}. Here is the behavior \emph{prior} to this release: \begin{itemize}[noitemsep] \item \csb{etocthelinkedname} and \csb{etocthelinkednumber} were hyperlinks only if \ctanpkg{hyperref} was configured via |linktoc=all| or |linktoc=section| (the default), \item \csb{etocthelinkedpage} was an hyperlink only if \ctanpkg{hyperref} was configured via |linktoc=all| or |linktoc=page| and the page number was not empty. \end{itemize} This behavior was coherent with the commands \csb{etocname}, \csb{etocnumber}, and \csb{etocpage} being the robust variants of \csb{etocthelinkedname}, \csb{etocthelinkednumber}, and \csb{etocthelinkedpage}. At \etocrelease{1.1a} it was decided that the commands should match their denominations.% % \footnote{To tell the whole truth, the author in refactoring the code completely at \etocrelease{1.1a} was tricked by the names and forgot to read the old documentation so the new behavior was implemented and it was decided to keep the change.} % So they are now \emph{always} hyperlinks independently of |linktoc| \ctanpkg{hyperref} option (\csb{etocthelinkedpage} has no hyperlink if the page number is empty, to match \ctanpkg{hyperref} behavior): \begin{itemize}[noitemsep] \item \csb{etocthelinkedname} and \csb{etocthelinkednumber} and \csb{etocthelinkedpage} are always (in presence of \ctanpkg{hyperref}) hyperlinks (for \csb{etocthelinkedpage} the page number must not be empty). \end{itemize} A further command is provided: \csb{etocthelink}, which wraps% % \footnote{Prior to \etocrelease{1.1a}, there was a link added only if \ctanpkg{hyperref} option \texttt{linktoc} was not \texttt{none}.} % an hyperlink around its argument: |\etocthelink|\marg{foo} hyperlinks an arbitrary text \meta{foo} to the target sectioning unit in the document. The command \csb{etoclink} is its robust variant. \subsection{The \csbhyp{etocsetlevel} command} \label{etocsetlevel} \label{etocthemaxlevel} One can inform \etoc of a level to associate to a given sectioning command with \csb{etocsetlevel}. For example: \begin{verbatim} \etocsetlevel{cell}{0} \etocsetlevel{molecule}{1} \etocsetlevel{atom}{2} \etocsetlevel{nucleus}{3} \end{verbatim} In compatibility mode, it will be assumed that the commands |\l@cell|, |\l@molecule|, ..., have been defined somewhere either by the user or a class: doing only |\etocsetlevel| is not enough for the corresponding level to work out-of-the-box in compatibility mode. However, if table of contents are never using compatibility mode, then all that matters is that the various line styles have been set. If, for example |section| is at level |1|, then there is no need to do some \csb{etocsetstyle}|{molecule}{..}{..}{..}{..}| after \csb{etocsetlevel}|{molecule}{1}| if \csb{etocsetstyle}|{section}{..}{..}{..}{..}| has already been done (and it has been done by the package itself in its definition of its own line styles). The accepted levels (but see the frame below) run from |-1| to |6| inclusive (also |-2| with class \ctanpkg{memoir}). Anything else is mapped to |6|, which is a dummy level, never displayed. The package does: \begin{verbatim} \etocsetlevel{book}{-2}% (only with class memoir) \etocsetlevel{part}{-1} \etocsetlevel{chapter}{0} \etocsetlevel{appendix}{0}% or 1 if document has no \chapter \etocsetlevel{section}{1} \etocsetlevel{subsection}{2} \etocsetlevel{subsubsection}{3} \etocsetlevel{paragraph}{4} \etocsetlevel{subparagraph}{5} \end{verbatim} \etoc own custom styles are activated by \csb{etocdefaultlines}. \begin{framed} Boolean option \etocoption{deeplevels} added at \etocrelease{1.2a} has the effect of replacing \texttt{6} by \texttt{12} as the maximal numerical level (which, as has been said above, is never displayed). The value |6| (default) or |12| (if \etocoption{deeplevels} is set to true) is held by \csb{etocthemaxlevel}. With \etocoption{deeplevels} option one can for example do: \begin{verbatim} \etocsetlevel{subsubsubsection}{4} \etocsetlevel{subsubsubsubsection}{5} \etocsetlevel{subsubsubsubsubsection}{6} \etocsetlevel{paragraph}{7} \etocsetlevel{subparagraph}{8} \end{verbatim} but it is up to user to actually define \LaTeX{} commands such as \csa{subsubsubsection}, and also to provide, if \etoc is left in ``compatibility mode'', the suitable \csa{l@subsubsubsection} et al. needed for TOC rendering. If you use \csb{etocsetstyle} (even only for one level name) though, which quits ``compatiblity mode'', it is not \csa{l@subsubsubsection} which needs definition, but \csb{etocsetstyle}|{subsubsubsection}{..}{..}{..}{..}| which has to have been used. \end{framed} The numerical level assignments can be modified at anytime. See \autoref{part:surprising} for various applications of this technique. \subsection{Using \texttt{enumerate} or \texttt{itemize} environments for line styles} The code for the line styles of the \localtoc of this part was already reproduced in \autoref{sec:linestyles}. It is very simple and uses \texttt{enumerate} environments for sections and subsections, then an ``inline'' paragraph style for subsubsection titles. Actually, the very first version of \etoc from 2012 was originally motivated by the aim to do exactly this kind of things, which necessitates to be aware of when for example after a series of subsections, a section line appears in the |.toc| file.% % \footnote{At the source code level, the legacy method dating back to the origins in 2012 was replaced by a completely new one at release \etocrelease{1.2}.} % Indeed, this should trigger the emission of an |\end{enumerate}|. With the \marg{start} and \marg{finish} arguments of \csb{etocsetstyle}, \etoc provides an easy systematic interface to accomplish this kind of task. But there are some limitations to the use of list environments for typesetting TOCs. One of them is intrinsic to the scope limitations created by the groups associated to the environments: the |.toc| file may contain, besides the information to be typeset in the TOCs, some other commands, such as language changing commands from \ctanpkg{babel}, and some such commands do not expect to see their scope limited in this way by the presence of an environment (which will not be visible in the |.toc| file itself but enacted dynamically by the user-specified line styles). The built-in ``default line styles'' provided with \etoc (see \autoref{sec:custom}) do not make use of environments. Actually, in this user manual, only the \hyperref[toc:part:styling]{table of contents} at the start of this \autoref{part:styling}, the \autoref{toc:allsubsections} (which is a TOC!) and examples from \autoref{etocthelink} have their line styles expressed in terms of \texttt{enumerate} or \texttt{itemize} environments. \subsection{The\csbhyp{etocglobaldefs} and \csbhyp{etoclocaldefs} commands} \label{etocglobaldefs} \label{etoclocaldefs} In \LaTeX{} the meaning of a command defined via |\newcommand\foo{...}| inside an environment (or group) vanishes from \TeX's memory on exit from this environment (or group). At times however it is needed to make definitions with global scope, for this \TeX{} has the primitive prefix |\global|. By default \etoc's definitions of \csb{etocname} etc... are local. This causes problems in certain contexts such as TOC as tables (\autoref{sec:tocastable}, \autoref{ssec:tocastableold}) and also with |enumitem| \emph{inline} variants of its standard environments, because the command |\item| then closes a group (see \autoref{etocthelink}). After \csb{etocglobaldefs} has been issued, the \csb{etocname}, \csb{etocnumber} and \csb{etocpage} will be defined during execution of \toc and \localtoc with global scope. For normal use this is not necessary. It does not hurt either to activate it systematically. To return to the default, which lets \etoc only define them locally to the context in place where the \csa{contentsline} is encountered, execute \csb{etoclocaldefs}. Both \csb{etocglobaldefs} and \csb{etoclocaldefs} have an effect only locally to the environment or group where they are used. \section{The \etoc fall-back line styles} \label{sec:custom} \etocdefaultlines \renewcommand{\etoctoprule}{\hrule height2pt depth0pt} \renewcommand{\etoctoprulecolorcmd}{\color{red}} \etocruledstyle{\normalfont\normalsize\rmfamily\fboxrule1pt\color{red}% \fbox{\parbox{.8\linewidth}{\centering\normalcolor This is a table of contents for the (few) subsections of this section. It carries the label |toc:c|}}} \localtableofcontents \label{toc:c} \subsection{A demo of a TOC using \csbhyp{etocdefaultlines}} \label{etocdefaultlines} These line styles were written at an early stage in the development of the package; although the next section explains how to customize the font choicess or vertical spaces, etc\dots, used by these line styles, most other changes would require copying them from the sources and modify them directly. Admittedly they have been written at a rather scary low-\TeX{} level, and will not serve as a very friendly starting point. Activating their use is done via \csb{etocdefaultlines}, or \csb{etoctoclines} if the line styles have not been modified with \csb{etocsetstyle}. Sections and sub-sections are printed in essentially the same manner, except that the leading for sub-sections is a bit smaller (with document classes lacking a \csa{chapter} command, the sections are printed in bold typeface; this is the case in the present document). Sub-sub-sections are printed inline, in one paragraph, with no numbers or page numbers. This style was designed and tested with documents having lots of sub-sub-sections, and should be used on a two-column layout: it provides (only in that situation with many sub-sub-sections) a more compact presentation than what is achieved by the \LaTeX{} default.\footnote{and there will never be a Part or Chapter entry alone at the bottom of a column or page (except if it has no sub-unit).} On the other hand, used with a one-column layout, and with few sub-sub-sections, the style is a bit more spread out vertically than the \LaTeX{} default, sub-sections are not visually much different from sections (especially for document classes with a \csa{chapter} command), so the result is less hierarchical in appearance than in the \LaTeX{} default. Let us typeset the global table of contents of the present document as if it had been done with a class having the \csa{chapter} command: we will print sections as chapters, and subsections as sections. We use \csb{etocsetlevel} for that, and also we need to change the font style of ``sections'' (which in truth are our subsections) to use not the bold but the medium series; we modify the \csb{etocfontone} command for that. Also we use dot leaders which are less spread out than in the package default. \begin{filecontentshere}{etocsnippet-\snippetno.tex} \etocruledstyle[2]{\normalfont\normalsize\rmfamily\itshape \fbox{\parbox{.6\linewidth}{ \leftskip 0pt plus .5fil \rightskip 0pt plus -.5fil \parfillskip 0pt plus 1fil This is the global table of contents on two columns, using \etoc default line styles, but with sections as chapters, and subsections as sections. }}} \etocdefaultlines \etocsetnexttocdepth{1} \begingroup \etocsetlevel{section}{0} \etocsetlevel{subsection}{1} \renewcommand*{\etocfontone}{\normalfont \normalsize} \renewcommand*{\etoctoclineleaders} {\hbox{\normalfont\normalsize\hbox to 1ex {\hss.\hss}}} \sloppy \tableofcontents \endgroup \end{filecontentshere} \marginattach \filecontentsexec\filecontentsheremacro \subsection{Customizing the \etoc pre-defined line styles} \label{etocfontminustwo} \label{etocfontminusone} \label{etocfontzero} \label{etocfontone} \label{etocfonttwo} \label{etocfontthree} \label{etocsepminustwo} \label{etocsepminusone} \label{etocsepzero} \label{etocsepone} \label{etocseptwo} \label{etocsepthree} \label{etocminustwoleftmargin} \label{etocminustworightmargin} \label{etocminusoneleftmargin} \label{etocminusonerightmargin} \label{etocbaselinespreadminustwo} \label{etocbaselinespreadminusone} \label{etocbaselinespreadzero} \label{etocbaselinespreadone} \label{etocbaselinespreadtwo} \label{etocbaselinespreadthree} \label{etoctoclineleaders} \label{etocabbrevpagename} \label{etocpartname} \label{etocbookname} We will simply list the relevant commands as defined in the package. Customizing them goes through suitable \csa{renewcommand}s: \begin{verbatim} \newcommand*\etocfontminustwo{\normalfont \LARGE \bfseries} \newcommand*\etocfontminusone{\normalfont \large \bfseries} \newcommand*\etocfontzero{\normalfont \large \bfseries} \newcommand*\etocfontone{\normalfont \normalsize \bfseries} % (in classes with chapter, \etocfontone does not do \bfseries) \newcommand*\etocfonttwo{\normalfont \normalsize} \newcommand*\etocfontthree{\normalfont \footnotesize} \newcommand*\etocsepminustwo{4ex plus .5ex minus .5ex} \newcommand*\etocsepminusone{4ex plus .5ex minus .5ex} \newcommand*\etocsepzero{2.5ex plus .4ex minus .4ex} \newcommand*\etocsepone{1.5ex plus .3ex minus .3ex} \newcommand*\etocseptwo{.5ex plus .1ex minus .1ex} \newcommand*\etocsepthree{.25ex plus .05ex minus .05ex} \newcommand*\etocminustwoleftmargin{1.5em plus 0.5fil} \newcommand*\etocminustworightmargin{1.5em plus -0.5fil} \newcommand*\etocminusoneleftmargin{1em} \newcommand*\etocminusonerightmargin{1em} \newcommand*\etocbaselinespreadminustwo{1} \newcommand*\etocbaselinespreadminusone{1} \newcommand*\etocbaselinespreadzero{1} \newcommand*\etocbaselinespreadone{1} \newcommand*\etocbaselinespreadtwo{1} \newcommand*\etocbaselinespreadthree{.9} \newcommand*\etoctoclineleaders {\hbox{\normalfont\normalsize\hbox to 2ex {\hss.\hss}}} \newcommand*\etocabbrevpagename{p.~} % initial of "page" \newcommand*\etocpartname{Part} % prior to 1.08b, was \partname % but this didn't make sense e.g. with babel+frenchb whose \frenchpartname % takes into account the value of the part counter. \newcommand*\etocbookname{Book} % to be modified according to language \end{verbatim} No customizing of the standard line styles is possible from within \etoc. As already explained, when \csb{etocstandardlines} has been issued, the package just makes itself very discrete and acts only at the global level, and the TOC entries are (hopefully) formatted as would have happened in the absence of \etoc.\footnote{with the \ctanpkg{KOMA-script} classes, we noticed that \csb{etocclasstocstyle} was apparently needed for the KOMA options |toc=left| to be active at the level of the line entries.} The \csb{etocstandardlines} compatibility mode will work also with sectioning commands made known to \etoc via \csb{etocsetlevel}, under the condition of course that these sectioning commands are accompanied with all the relevant definitions for typesetting toc entries in the \LaTeX{} default manner (existence of the macros \csa{l@something} . . .). Using the command \csb{etocsetstyle}, be it in the preamble or in the body of the document, has the secondary effect of switching off the compatibility mode. \section{Summary of the main styling commands} \subsection{Setting up local styles} \hbox{\color{green}\fboxrule1pt\fboxsep1em \setbox0\hbox{\csb{etocthename}, \csb{etocthenumber}, \csb{etocthepage}, \csb{etoclink}\marg{linkname}}% \framebox[\linewidth][c] {\vbox{\hsize\wd0\normalcolor\noindent \csb{etocsetstyle}\marg{levelname}% \marg{start}\marg{prefix}\marg{contents}\marg{finish}\\ \csb{etocname}, \csb{etocnumber}, \csb{etocpage}, \csb{etocifnumbered}\marg{A}\marg{B}\\ \csb{etocthename}, \csb{etocthenumber}, \csb{etocthepage}, \csb{etoclink}\marg{linkname} }}} \subsection{Setting up toc display styles} \medskip \hbox{\color{green}\fboxrule1pt\fboxsep1em \setbox0\hbox{\csb{etoctocstylewithmarksnouc}\oarg{kind}% \marg{number\_of\_columns}\marg{title}\marg{mark}}% \framebox[\linewidth][c] {\vbox{\hsize\wd0 \normalcolor\noindent \csb{etocmulticolstyle}\oarg{number\_of\_columns}\marg{heading}\\ \csb{etoctocstyle}\oarg{kind}\marg{number\_of\_columns}\marg{title}\\ \csb{etoctocstylewithmarks}\oarg{kind}\marg{number\_of\_columns}% \marg{title}\marg{mark}\\ \csb{etoctocstylewithmarksnouc}\oarg{kind}\marg{number\_of\_columns}% \marg{title}\marg{mark}\\ \csb{etocruledstyle}\oarg{number\_of\_columns}\marg{title}\\ \csb{etocframedstyle}\oarg{number\_of\_columns}\marg{title}\\ \csb{etocsettocstyle}\marg{before\_toc}\marg{after\_toc}}}} \subsection{Displaying tables of contents} \medskip \hbox{\color{green}\fboxrule1pt\fboxsep1em \setbox0\hbox{\csb{etocname}, \csb{etocnumber}, \csb{etocpage}, \csb{etocifnumbered}\marg{A}\marg{B}}% \framebox[\linewidth][c] {\vbox{\hsize\wd0\normalcolor\noindent \toc\\ \localtoc\\ \csb{etocmulticol}\oarg{number\_of\_columns}\marg{heading}\\ \csb{etoclocalmulticol}\oarg{number\_of\_columns}\marg{heading}\\ \csb{etocruled}\oarg{number\_of\_columns}\marg{title}\\ \csb{etoclocalruled}\oarg{number\_of\_columns}\marg{title}\\ \csb{etocframed}\oarg{number\_of\_columns}\marg{title}\\ \csb{etoclocalframed}\oarg{number\_of\_columns}\marg{title}\\ \hbox{}{\itshape\ttfamily\ \ \ \ and their starred variants} }}} \subsection{Labels and references} \label{ssec:labelref} The commands (starred or not) to actually display the table of contents can be followed with optional labels or references:\par \medskip \hbox{\color{green}\fboxrule1pt\fboxsep1em \setbox0\hbox{\csb{etocname}, \csb{etocnumber}, \csb{etocpage}, \csb{etocifnumbered}\marg{A}\marg{B}}% \framebox[\linewidth][c] {\vbox{\hsize\wd0\normalcolor\noindent \toc \csa{label}|\{toc:here\}|\\ \toc \csa{ref}|\{toc:far\}| \\ \toc \csa{label}|\{toc:here\}| \csa{ref}|\{toc:far\}| \\ \localtoc \csa{label}|\{toc:here\}|\\ \localtoc \csa{ref}|\{toc:far\}| \\ \localtoc \csa{label}|\{toc:here\}| \csa{ref}|\{toc:far\}| \\ \hbox{}{\itshape\ttfamily\ \ \ \ similarly with\ }% \csb{etocmulticol}{\itshape\ttfamily\ etc . . . } }}} \medskip \localtoc \csa{ref}|{toc:far}| acts the same as \toc \csa{ref}|{toc:far}|. % <--- car à 1.2 cela permet d'éviter une page quasi vide... When re-displaying another toc, only its contents are transferred: both the line styles and the toc display style are the ones currently defined, not the ones from the cloned toc. \clearpage \etocdepthtag.toc {control} \part{Control of contents} \label{part:control} \thispartstats \etocsettocstyle{}{}% maybe I should use \etocclasstocstyle here ? % but then I probably need some extra KOMA stuff to % counteract the setspace effet \begingroup \microtypesetup{protrusion=false} \DeclareTOCStyleEntry[numwidth=2em,indent=0pt]{tocline}{section} \DeclareTOCStyleEntry[numwidth=2.5em,indent=2em]{tocline}{subsection} \DeclareTOCStyleEntry[numwidth=3em,indent=4.5em]{tocline}{subsubsection} \etocstandardlines \localtableofcontents \endgroup \section[The \csbhyp{tableofcontents} et al. commands]{The \csbhyp{tableofcontents}, \csbhyp{localtableofcontents} and \csbhyp{localtableofcontentswithrelativedepths} commands} \label{tableofcontents} \label{etoctableofcontents} \label{localtableofcontents} \label{localtableofcontentswithrelativedepth} \label{etockeeporiginaltableofcontents} \begin{description} \item[\toc] can be used arbitrarily many times in the document. Styling either globally the TOC or its individual entries is customizable at any time in the document. \csb{etoctableofcontents} is a synonym to \etoc's \toc. The \toc command reverts to its non-\etoc definition if \csa{etockeeporiginaltableofcontents} is issued after loading the package. % \footnote{% This was added to fix a compatiblity issue with \ctanpkg{listings}'s \texttt{\string\lstlistoflistings}, as it needs the \texttt{\string\tableofcontents} macro to keep its original meaning.} \item[\localtoc] will print local tables of contents: \emph{i.e.} all sections and sub-units inside a given chapter, or all subsubsections and lower inside a given subsection, etc... (see also \csb{etocsetnexttocdepth}).% % \footnote{As is explained in \autoref{sec:labeling} the syntax allows to create somewhere a local table of contents and to display it at some other location either before or after its origin.}% \textsuperscript{,}% \footnote{As is explained in \autoref{sec:tocdepth} \etoc allows at anytime to locally redefine the numeric levels associated to named ones, which brings great flexibility to achieve special effects, all done using only a single auxiliary file, the standard |.toc| file.} % \item[\localtocwrdp\marg{number}] % \mbox{}\footnote{Thanks to Tony \textsc{Roberts} for feature request.} % can be used to override the document or current tocdepth setting (see \autoref{sec:tocdepth} for a discussion of tocdepth) to become relative to where the local TOC originates. For example, assuming the default numeric level assignments to standard sectioning units \begin{verbatim} \section{This is a section} \localtableofcontentswithrelativedepth{+2} \end{verbatim} will create a local table of contents taking into account the subsections and subsubsections inside this section, independently of what is the value of the |tocdepth| counter at this position in the document. If the numeric argument had been |3|, the local TOC would have displayed also paragraphs. If the section had been a chapter, and again for a relative tocdepth of |2|, the taken into account levels would have been sections and subsections. \end{description} \section{Labeling and reusing elsewhere} \label{sec:labeling} \label{invisiblelocaltableofcontents} \etoc allows to typeset at some location a local table of contents which is defined elsewhere. For this, two simple steps: \begin{enumerate} \item insert \localtoc at the distant place, and follow it by some |\label{foo}|. \item insert \toc|\ref{foo}| (or \localtoc|\ref{foo}|, it does the same) at the place where you want this distant table of contents to appear. \item in step \textbf{1}, if you use \invisiblelocaltoc in place of \localtoc, there will be no typesetting at its place of definition. \end{enumerate} At the place of use of \toc|\ref{foo}|, the layout and looks is entirely configurable locally. It may be completely different from how the same contents are rendered elsewhere by another \toc|\ref{foo}| or by the original label-decorated \localtoc|\label{foo}|. The current value of the |tocdepth| counter is obeyed. As an example the table of contents corresponding to \autoref{part:styling} has been cloned here in a \hyperref[toc:d]{float} which appears \vpageref{toc:d}. \begin{filecontentsdef}{etocsnippet-\snippetno.tex}{\foo} \begin{figure}[ht!] \centering \begingroup % this is a KOMA-script specific customization \DeclareTOCStyleEntry[numwidth=2em,indent=0pt]{tocline}{section} \DeclareTOCStyleEntry[numwidth=3.2em,indent=2em]{tocline}{subsection} \etocstandardlines % <-- use the defaults from the document class \renewcommand{\etocbkgcolorcmd}{\color{green!5}} \renewcommand{\etocbelowtocskip}{0pt\relax} \fboxsep1ex \etocframedstyle [1]{\fbox{\makebox[.5\linewidth]{\etocfontminusone I am from \hyperref[toc:part:styling]{far away}}}} \etocsetnexttocdepth{subsection} \tableofcontents \label{toc:d} \ref{toc:part:styling} \endgroup \end{figure} \end{filecontentsdef} \filecontentsexec\foo We used this: \filecontentsprintviascan\foo \marginattach In the above example, not only did we use |\ref{toc:part:styling}| to print here the distant (local) table of contents which has been labeled |toc:part:styling| but we added a (possibly confusing) |\label{toc:d}|. This is done for the down-to-earth reason of being able to use, as we did in the previous paragraph, |\vpageref{toc:d}|. But if one wants to clone again the original local table of contents, one must reference its original label: \toc|\ref{toc:part:styling}|.% % \footnote{Why does this author always give complicated examples rather than down-to-earth ones?} % This original local table of contents is to be found \vpageref{toc:part:styling}. \section[\csbhyp{etocsetlevel}]{A powerful functionality of \etoc: the re-assignment of levels with \csbhyp{etocsetlevel}} \label{sec:tocdepth} The intrinsic levels manipulated by \etoc are numeric: from |-2| (which corresponds to |book| in the \ctanpkg{memoir} class) down (from the big to the small) to |5| (|subparagraph|). But the assignment of a numeric level to a given name can be modified at any time with the command \csb{etocsetlevel}\marg{level\_name}\marg{number}. In conjunction with the use of the \LaTeX{} |tocdepth| counter, this has powerful applications: \meta{level\_name} does not have to coincide with an actual document sectioning command, and \etoc can be used to print arbitrary ``lists of things'', using no other auxiliary file than the |.toc| file. This is explained further in \autoref{part:surprising}. \begin{framed} It is often said that in the standard classes, the sectioning level of |\part| is |0| in the classes not having a |\chapter| command, and |-1| in classes having a |\chapter| command. This is \emph{correct} for what regards the \emph{automatic numbering}, as is governed by the value of the |secnumdepth| counter; but it is \emph{wrong} for what regards the effect of the |tocdepth| counter: setting the |tocdepth| to |-1| in the |article| class just before |\tableofcontents| does \emph{not} prevent Parts from appearing in the Table of Contents. One has to set it to |-2| for that, whether in the |article| or in the |book| class. The canonical levels, a priori known to \etoc, are those of relevance to the \textbf{|tocdepth|} counter in the standard classes and are recapitulated in this table: \centeredline{ \fbox{\begin{tabular}{rc} (\ctanpkg{memoir} class) book&-2\\ part&-1\\ chapter&0 \\ section&1\\ subsection&2 \\ subsubsection&3 \\ paragraph&4 \\ subparagraph& 5 \end{tabular}}} \smallskip With \etoc, the user can easily print a local table of contents inside a given subsection, where subsubsections will be printed in the style of sections, paragraphs in the style of subsections, and subparagraphs in the style of subsubsections, if so desired. One can also decide to set everything to be at the level |6| (never displayed by \etoc), except for example paragraphs, promoted to be at level |1|, and then one obtains a nice table of contents of all the paragraphs from the document! (|tocdepth| at least |1|)\footnotemark \end{framed} \footnotetext{and one should naturally not print this TOC of paragraphs in compatibility mode, which would insist on inserting a gigantic left margin.} \section{The \csbhyp{etocsettocdepth} and \csbhyp{etocsetnexttocdepth} commands} \label{etocsettocdepth} \label{etocsetnexttocdepth} \label{invisibletableofcontents} The |tocdepth| counter has no bearing on what gets written to the |.toc| file; its action is only on the actual typesetting of the table of contents.\footnote{In the standard classes (at least), it also influences the \csa{listoftables} and \csa{listoffigures}, via \csa{@dottedtocline}.} In the standard classes there is only one |\tableofcontents| possible, whereas with \etoc, arbitrarily many are allowed, so one may change |tocdepth| to the appropriate value (which decides the finest sectioning level displayed) again and again each time a table of contents needs to be typeset. \etoc provides \csb {etocsettocdepth}\marg{level} whose mandatory argument is either numeric (from |-3| to |5|) or a division name such as |subsection| or |subsubsection| or any name previously declared to \etoc with \csb{etocsetlevel} (the keywords |all| and |none| are recognized, although not corresponding to a document division). This does the appropriate |\setcounter{tocdepth}{numeric_level}|. As is explained in the next subsection, |tocdepth| is used by \ctanpkg{hyperref}, and one must take steps to prevent its changes from influencing the bookmarks, too. So, \etoc has \csb {etocsetnexttocdepth}\marg{level} whose influence ceases immediately after the next table of contents. The package defines \csb{invisibletableofcontents} essentially as \centeredline{\csb{etocsetnexttocdepth}|{none}|\csb{tableofcontents}} The simplest organization is probably to have after |\begin{document}| and before the first |\tableofcontents| a single instance of the \csb{etocsettocdepth} command, with argument the deepest level (or most commonly used deepest level) among the tables of contents of the document, and to use locally, where needed, \csb{etocsetnexttocdepth} before |\tableofcontents| or |\localtableofcontents|. \begin{framed} It is possible to use \csb{etocsettocdepth} inside the first argument of \csb{etocsettocstyle} (possibly in conjunction with checking the \csb{etoclocaltop} value, \emph{which however will be up-to-date there only if \csb{etocchecksemptiness} was executed}). There is no worry then about possible impact on hyperref bookmarks later on, because \etoc always resets the |tocdepth| counter after typesetting a TOC to the value it had before it. % Since \etocrelease{1.09} The macro \csb{etocsetnexttocdepth} works also if located in first argument of \csb{etocsettocstyle}, but there is no reason to use it there as \csb{etocsettocdepth} has no durable effet on the |tocdepth| counter if executed there. Check \csb{localtableofcontentswithrelativedepth} for a simpler way to control the depth of local tables of contents. This has the advantage of working reliably whether or not the \csb{etocchecksemptiness} is used. \end{framed} \subsection{The hyperref option \emph{bookmarksdepth}} \label{ssec:bookmarksdepth} When modifying the counter |tocdepth| for the purposes of multiple uses of \toc or \localtoc, one should be aware that package \ctanpkg{hyperref} by default takes into account the \emph{current} value of the |tocdepth| counter to decide whether the |pdf| file will contain a bookmark corresponding to sectioning commands encountered in the source file. Thus, one typically needs to reset |tocdepth| to its previous value after having temporarily modified it for a given table of contents. Or, there is the \emph{bookmarksdepth=n} option of package \ctanpkg{hyperref}, with \emph{n} the desired document bookmarks maximal depth, which can be numeric or the name of a level known to \ctanpkg{hyperref}. This documentation previously passed |bookmarksdepth=3| as option to \ctanpkg{hyperref}, so even if |tocdepth| was left to |1| by inadvertance after printing a certain table of contents this did not modify the bookmark tree of the |pdf| file. Now that \csb{etocsetnexttocdepth} has been added to the package, we have used it systematically and there was no need for |bookmarksdepth=3| anymore. \section[The \csbhyp{etocsettocdepth.toc} command]{The \csbhyp{etocsettocdepth.toc} and \csbhyp{etocimmediatesettocdepth.toc} and commands} \label{etocsettocdepth.toc} \label{etocimmediatesettocdepth.toc} This command \csb{etocsettocdepth.toc} implements some functionality of \ctanpkg{tocvsec2}% % \footnote{I thank Denis \textsc{Bitouzé} for drawing my attention to the incompatibility of this package with \etoc.}, % a package which however was incompatible with \etoc (it can still be used for its |secnumdepth|-related commands, but its |toc|-related activities will get canceled by \etoc) and more-or-less designed for a single table of contents. The action of \csb{etocsettocdepth.toc} is totally different than the one of \csb{etocsettocdepth}. Rather than modifying the |tocdepth| counter immediately, it adds a line to the |.toc| file which, when executed inside a table of contents will enact this change. The command \csb{etocsettocdepth.toc}, like \csb{etocsettocdepth}, accepts both numeric and named arguments. In the case of a named argument, the actual numeric value to be used is not yet decided at the time the |.toc| file is created; it will be the value currently specified for the named level at the time each table of contents (not having done |\etocignoretoctocdepth|) is typeset. The |tocdepth| counter will never be set to a value finer than its initial value at the start of the table of contents: so adding commands \csb{etocsettocdepth.toc} in the document is a way to \emph{restrict} locally the depth of the table of contents. For example to prevent inclusion in the tables of contents of the sub-sub-sections of a given chapter. This {\fbox{gets executed in ALL tables of contents.}} Also \csb{etocimmediatesettocdepth.toc} is provided. For explanations, refer to the discussion of \csb{etocimmediatedepthtag.toc} in the next section. \subsection{The \csbhyp{etocobeytoctocdepth} and \csbhyp{etocignoretoctocdepth} commands} \label{etocobeytoctocdepth} \label{etocignoretoctocdepth} So \csb{etocignoretoctocdepth} is provided to cancel the \csb{etocsettocdepth.toc} mechanism when needed; and \csb{etocobeytoctocdepth} will re-activate it. The package does initially \csb{etocobeytoctocdepth}. \section[The \csbhyp{etocdepthtag.toc} and \csbhyp{etocsettagdepth} commands]{The \csbhyp{etocdepthtag.toc}, \csbhyp{etocimmediatedepthtag.toc} and \csbhyp{etocsettagdepth} commands} \label{etocdepthtag.toc} \label{etocimmediatedepthtag.toc} \label{etocsettagdepth} \label{sec:depthtags} % Release \etocrelease{1.07h} has a The command \csb{etocdepthtag.toc} allows to control dynamically the which contents end up included in the displayed TOCs (this documentation also decribed formerly a way using \csb{etocsettocdepth.toc} with some dummy level name, which got then set via \csb{etocsetlevel} according to what was locally needed, but it was too hacky and I am not sure if it was understandable). It is used as \csb{etocdepthtag.toc}\marg{tag\_name}, where the \meta{tag\_name} is anything, and this will put the tag in the |.toc| file. When typesetting a TOC, one issues a series of commands \csb{etocsettagdepth}\marg{tag\_name}\marg{level} where the \meta{level} may be either numeric (from |-3| to |5|) or the name of a division unit known to \etoc, or |none| or |all|. The effect of the tag inside the |.toc| file will then be to set the |tocdepth| counter to the desired value, in real time (this can not get finer than the initial value of |tocdepth| at the start of the TOC). The added flexibility is thus that \csb{etocsetlevel} has not been used in a kind of hacky way, that one may use named level depths, and the keywords |none| and |all|. As usual, once the tag depths have been set, they remain in effect until getting redefined or seeing their scope expire via the closing of a group or of a surrounding environment. For an example, see \autoref{sec:tocwithdepthtags}. When using \csb{etocdepthtag.toc} in combination with \LaTeX's |\include|, data may not end up in the |.toc| file in the correct order. For example in this situation: \begin{verbatim} \clearpage % or anything ending up causing its presence here right before % the \etocdepthtag.toc \etocdepthtag.toc{sometag} \include{some file containing sections} \end{verbatim} The tag will end up in the |.toc| file \emph{after} all section headings from the included file. The cause is that \LaTeX\ inserts immediately in the main auxiliary file a command to input the auxiliary file of the included file (which in turn, contains instructions to add data to the |.toc| file). But \csb{etocdepthtag.toc} does not internally use such immediateness, as it uses the same interface as |\section| and alike commands when they want to write extra data to the |.toc| file. So% % \footnote{Thanks to Norman \textsc{Ramsey} who reported this problem, together with a fix, in July\dots 2016. Sorry for long delay before updating \etoc six years later\dots} % % \etocrelease{1.09f} adds there is \csb{etocimmediatedepthtag.toc} which will force the tag to be written immediately to the |.toc| file (well, rather immediately to the |.aux| file, so before the inclusion of the auxiliary file of the included file). One should not use this variant systematically. For example if your document looks like: \begin{verbatim} \clearpage \section{bbbb} Some text \etocdepthtag.toc{sometag} \etocimmediatedepthtag.toc{someimmediatetag} \section{cccc} Some text \end{document} \end{verbatim} then the |someimmediatetag| will end up being inserted in |.toc| file \emph{before} the |bbbb| section. This is because \LaTeX's |\section| uses a \emph{delayed} write, not an \emph{immediate} one. And \csb{etocdepthtag.toc} wisely uses a \emph{delayed} write. As it seems very hard programmatically to identify automatically if the \emph{immediate} variant of \csb{etocdepthtag.toc} should be used, the package provides two separate commands and it is up to user to make the correct choice. \subsection{The \csbhyp{etocobeydepthtags} and \csbhyp{etocignoredepthtags} commands} \label{etocobeydepthtags} \label{etocignoredepthtags} After \csb{etocignoredepthtags}, the |.toc| depth tags are ignored (but \csb{etocdepthtag.toc} still works). The package does initially \csb{etocobeydepthtags} which makes \etoc react to the found tags in the |.toc| file. \section{Adding commands to the \texorpdfstring{\texttt{.toc}}{.toc} file} \label{sec:addingtotoc} We described above \csb{etocsettocdepth.toc} and \csb{etocdepthtag.toc} which both insert commands inside the |.toc| file. An even more general mechanism of adding ``action tags'' to the |.toc| file could be envisioned, but this would just be a wrapper for direct use of |\addtocontents{toc}{\something}|. One should be cautious when adding in this way things to the |.toc| file. For example, inserting \csa{addtocontents}|{toc}{\string\clearpage}| just before a \csa{part} to fix the problem when some part entry (in the table of contents) is isolated at the bottom of one page, will cause problems with multiple TOCs: this \csa{clearpage} will be executed by \etoc each time a \toc or \localtoc command is encountered! The more prudent thing is to do rather: {\csa{addtocontents}|{toc}{\string\myclearpage}|,} to have a |\let\myclearpage\relax| at the top level of the document and to use where needed something like: \begin{verbatim} \let\myclearpage\clearpage \tableofcontents \let\myclearpage\relax \end{verbatim} The \ctanpkg{memoir} class has the command \csa{settocdepth} which writes a \csa{changetoc\-depth} command inside the |.toc| file. This will impact the typesetting by \etoc of \emph{all} tables of contents, with (possibly) unexpected results: imagine the document has \csa{settocdepth}|{chapter}| at some point to avoid having the sections from subsequent chapters be listed in the main table of contents. Then a local table of contents in one of these chapters will print a title but will be without any entry. As the \ctanpkg{memoir} class by itself allows multiple\toc these issues already arise there, independently of \etoc, see page 170 of the \ctanpkg{memoir} manual. For this specific issue, the commands \csb{etocsettocdepth.toc}, \csb{etocignoretoctocdepth} and \csb{etocobeytoctocdepth} are the way to go; or their variants \csb{etocdepthtag.toc} and \csb{etocsettagdepth}. As an aside, any |\setcounter{tocdepth}{n}| command added directly to the |.toc| file will see its effect % (since release \etocrelease{1.07g}) cease when the end of a table of contents is reached, as \etoc executes a |\setcounter{tocdepth}{previous_value}| there, to reste the \texttt{tocdepth} counter to the value it had on entering the table of contents. \subsection{The hyperref option \emph{hidelinks}}\label{ssec:hidelinks} The colored links (and also the rectangle links) are a bit annoying when used in tables of contents, especially when the document uses \etoc and has plenty of them! One may wish for having colored links, \emph{except} for those within table of contents! Indeed, why would things in TOCs need to be either framed in rectangles or colored, when the user \emph{already expects them to be links}? I use the following trick: either in the preamble using |\AtBeginDocument|, or right after |\begin{document}|, I have the command \centeredline{|\addtocontents{toc}{\protect\hypersetup{hidelinks}}|} \begin{framed} All TOCs typeset by \etoc have their contents done within a group (as if enclosed in an environment). So the command \csa{hypersetup}|{hidelinks}| will be executed by \emph{each} TOC, but its effect will be limited to that TOC. \end{framed} I found out experimentally that the option |hidelinks| could indeed be set many times with |\hypersetup| (this is not the case of all \ctanpkg{hyperref} options). \subsection{Disabling protrusion in all TOCs} \label{ssec:disableprotrusion} If using \ctanpkg{microtype} it looks like a generally advisable counsel to disable protrusion in particular for all TOCs (see however \autoref{ssec:microtype} for further information if you don't want to do that). To achieve this simply add % \centeredline{|\addtocontents{toc}{\protect\microtypesetup{protrusion=false}}|} % immediately after |\begin{document}| (or use |\AtBeginDocument|). We ended up doing this for the present document after checking for a few of our TOCs that it improved their looks. As \etoc always encloses the typesetting of tables of contents inside scope limiting groups, the effect will be limited to tables of contents only. Notice that adding the above command to an existing document will have an effect only on second compilation. \section[The \csbhyp{etocsetlocaltop.toc} command] {The \csbhyp{etocsetlocaltop.toc} and \csbhyp{etocimmediatesetlocaltop.toc} commands} \label{etocsetlocaltop.toc} \label{etocimmediatesetlocaltop.toc} It is important to understand that \csb{localtableofcontents} works entirely from data \emph{in the |.toc| file}. If the document, say with |article| class, contains starred sectioning commands, which are not accompanied by suitable \csa{addcontentsline}, then these units are completely transparent to \csb{localtableofcontents}: \begin{itemize} \item If \localtoc is issued before |\section*{Foo}|, say locally to a |\section|, then the local TOC will include not only the |subsection|s between the |\section| and the |\section*{Foo}| but also those following, and it will stop only at encountering a later |\section| or |\part| from the document's body. \item If the command is issued right after |\section*{Foo}| and the later was itself subsequent to a (numbered) |\subsection|, then \etoc will think it must display a TOC local to the \emph{subsection}. \end{itemize} % Since release \etocrelease{1.08k}, \etoc provides the one-argument There is the command \csb{etocsetlocaltop.toc} to insert into the |.toc| file a kind of ``ghost'' of a given sectioning unit. Here is an example: \begin{verbatim} \part*{Extra unnumbered part} \etocsetlocaltop.toc{part} \localtableofcontents \end{verbatim} So with no |\part| heading inserted into the table of contents via an |\addcontentsline|, still \localtoc will know it is local to a part. In this example the local contents will be delimited by the next numbered |\part|, or |\part*| with |\addcontentsline|, or also by a later, second, |\etocsetlocaltop.toc{part}|. As a (counter)-example consider this document: \begin{verbatim} \documentclass{article} \usepackage{etoc} \begin{document} \tableofcontents \part*{A} \etocsetlocaltop.toc{part} \localtableofcontents \section{I} \section{II} \part*{B} \section{III} \part*{C} \section{IV} \end{document} \end{verbatim} It uses only |\part*|. Thanks to the \csb{etocsetlocaltop.toc} the \localtoc knows it should report only sections. But the other |\part*| are invisible to it as nothing is recorded in the |.toc| file. So the local table of contents in this example will list \emph{all} sections not only |I| and |II|. To fix thix one may e.g.\@ insert another |\etocsetlocaltop.toc{part}|, this time after |\part*{B}| (or make this a numbered part, or use |\addcontentsline| for it). The above document amended with added |\etocsetlocaltop.toc{part}| after each unnumbered part will thus have its main TOC without any |Part| heading, but each |\part| can show a correct \localtoc. The simpler approach would be to use |\addcontentsline| with each unnumbered |\part| so that it ends up in the |.toc| file, but \etoc is keen on allowing the most diverse point of views. It should be stressed that the various |\etocsetlocaltop.toc|\marg{sect. unit} do impact the global \toc: they really act like actual sectioning units, except for not inducing any typesetting. In usual document classes, this would appear to mean that they are completely transparent to the global \toc. Not the case with \etoc, which adds a virtual assembly of levels: the |.toc| data originating in |\etocsetlocaltop.toc|\marg{sect. unit} will trigger the execution of the \marg{finish} parts of the line styles of finer sectioning units encountered before (either in the global \toc or in an active \localtoc); and it triggers the \marg{start} parts of the line styles of finer units encountered after it (again in the global \toc, but also in any \localtoc which is already activated at a coarser lever). Depending on how the toc line styles are configured this may translate into some visual effect; for example with the \etoc own line styles the \marg{start} and \marg{finish} mostly insert penalties or vertical spaces. It is a matter of debate if this is good design; a variant serving purely to influence boundaries of local table of contents with no collateral effects could be provided. And the name of the macro was perhaps not so well chosen as it suggests it acts as would such an hypothetical variant. In absence of feature requests we leave the matter standing for now.% % Usage of \csb{etocsetlocaltop.toc} interacts with \csb{etocchecksemptiness} in the expected way: it modifies (as explained above) the selection made by \csb{localtableofcontents}, hence the decision whether this local TOC will end up empty or not. There is also \csb{etocimmediatesetlocaltop.toc}. This may be useful in some very special circumstances involving |\include|. For related discussion see the documentation of \csb{etocimmediatedepthtag.toc}. \section{The \csbhyp{etoclocaltop} command} \label{etoclocaltop} Within either the TOC style (\csb{etocsettocstyle}) or the local title styles (\csb{etocsetstyle}), the control sequence \csb{etoclocaltop} is made equivalent for the duration of \csb{localtableofcontents} to a numeric (self-delimiting) denotation of the current top level. Thus: it will in numeric contexts (|\ifnum|, |\ifcase|, ...) represent zero for a local TOC corresponding to chapter, or one if in a section, or two if in a subsection, etc..., assuming of course here that the default levels are obeyed (see \autoref{sec:tocdepth}). %\begin{framed} \csb{etoclocaltop} from inside the TOC heading (first argument of \csb{etocsettocstyle}) has the correct value \emph{only under \csb{etocchecksemptiness} regime}. Special circumstances correspond to some special values: \begin{description}[nolistsep] \item[|-3|] (|-\thr@@|)\newline signals that \etoc considers the local TOC to be ``unknown''; this happens at the last local TOC, for the first \LaTeX\ run after adding a new \localtoc to the document. In doubt, \etoc assumes the TOC will prove non empty, hence it prints (independently of whether the check for emptiness was activated or not) the heading as specified by \csb{etocsettocstyle}. Thus, check if \csb{etoclocaltop} gives |-3| as a a \meta{number} to detect that situation from within the first argument of \csb{etocsettocstyle}, if desired. \item[|-1000|](|-\@m|)\newline is in case of a \localtoc being considered ``known'' (although it may still refer to the data in the |.toc| file from the previous run) but without the check for emptiness having been executed. \item[|-10000|](|-\@M|)\newline is the value when accessed from the title of a global TOCs. \end{description} %\end{framed} %\begin{framed} When executed from within a local table of contents \textbf{line styles} (\csb{etocsetstyle}), \csb{etoclocaltop} always will hold the correct value, whether or not the emptiness check was executed. For a global table of contents however, it will always keep the value |-3|. %\end{framed} Attention! \cs{etoclocaltop} is only to be queried not set. \section{Checking TOCs for emptiness} \subsection{The \csbhyp{etocchecksemptiness} command} \label{etocchecksemptiness} \label{etocdoesnotcheckemptiness} The user needs to issue \csb{etocchecksemptiness} to tell \etoc to check whether local tables of contents are empty and in case of emptiness to print nothing at all.\footnote{Thanks to Paul Gaborit who asked for such a feature.} This can be useful to authors of \LaTeX{} classes who for example wish to have a |\chapter| command doing systematically a \localtoc, or for people producing files via automatic conversions and some of those might have sectioning commands and others not. «Emptiness» means that no \csa{contentsline} command would get executed within the scope of the local table of contents --- empty line styles by themselves do not make the TOC empty. \etoc always executes the \csb{etocaftertochook} command; and the test for emptiness itself executes everything else found in the |.toc| file. See \autoref{sec:addingtotoc} in this context. \begin{enumerate} \item the \csb{etocifwasempty} command discussed below can be used from inside \csb{etocaftertochook}, and even from inside \csb{etocbeforetitlehook}. \item there is also \csb{etocdoesnotcheckemptiness}.% % (since \etocrelease{1.08i}.) \end{enumerate} The suppression of the heading (more precisely of the toc display style elements) may be effective only for the final \LaTeX{} runs. For example in the situation of a \toc|\ref{foo}| where the label |foo| is not yet recognized, the heading (but not the contents) is printed and the TOC is declared non-empty. Or, if one adds a \localtoc to a document, on the next run, the test for emptiness will in fact apply to the next one, and the last local TOC of the document will have its contents temporarily unknown to \etoc, hence will be declared non empty, and the heading will be printed. For a finalized document compiled with initially no auxiliary files, the first \LaTeX{} run will declare all local TOCs non empty and print for each of them a heading (and no contents naturally). The second \LaTeX{} run will then correctly decide which local TOC is empty or not. \subsection{The \csbhyp{etocnotocifnotoc} command} \label{etocnotocifnotoc} The user can then extend the emptiness-checking to the global TOCs with \csb{etocnotocifnotoc}. May I respectfully give the advice then to rather do none of |\usepackage{etoc}| nor \toc ? |;-)|. Well, there is always the case of batch conversions of documents having or not sectioning units. \subsection{The \csbhyp{etocifwasempty} command} \label{etocifwasempty} \label{etocxifwasempty} The command \csb{etocifwasempty}\marg{YES}\marg{NO} executes \meta{YES} if the previous TOC was found to be empty and \meta{NO} if its was not so. This may serve to act appropriately after a truly empty TOC. If \csb{etocchecksemptiness} has not been issued, this conditional always executes the \meta{NO} branch. This command is robust, and \csb{etocxifwasempty} is its expandable version. \fbox{Do not forget the second argument: at least an empty pair of braces |{}| must be present.} This conditional may wrongly say that the local TOC is empty or not empty until \LaTeX{} compilations stabilize. But if it says that a local TOC is empty, this does mean that \etoc considered the just encountered local table of contents to be empty (for that run) and thus printed nothing (not even a |\par|). \clearpage \etocdepthtag.toc {examples} \part{Examples}\label{part:examples} \thispartstats %% (pas de sous-section) \etocdefaultlines \etocsettocstyle {}{} \localtableofcontents To understand all code snippets in detail, one will need to have first browsed through \autoref{sec:linestyles} and \autoref{sec:tocstyle}. \section{A first example} \label{sec:firstexample} This section is called ``a first example'' due to legacy reasons of the various defects of this documentation... Let us present a ``first example'' (sort of) of specification for line styles: \begin{filecontentsdef}{etocsnippet-\snippetno.tex}{\foo} \begingroup\parindent 0pt \parfillskip 0pt \leftskip 0cm \rightskip 1cm \etocsetstyle {section} {} {\leavevmode\leftskip 0cm\relax} {\bfseries\normalsize\makebox[.5cm][l]{\etocnumber.}% \etocname\nobreak\hfill\nobreak \rlap{\makebox[1cm][r]{\mdseries\etocpage}}\par} {} \etocsetstyle {subsection} {} {\leavevmode\leftskip .5cm\relax } {\mdseries\normalsize\makebox[1cm][l]{\etocnumber}% \etocname\nobreak\hfill\nobreak \rlap{\makebox[1cm][r]{\etocpage}}\par} {} \etocsetstyle {subsubsection} {} {\leavevmode\leftskip 1.5cm\relax } {\mdseries\normalsize\makebox[1cm][l]{\etocnumber}% \etocname\nobreak\hfill\nobreak \rlap{\makebox[1cm][r]{\etocpage}}\par} {} \etocruledstyle[1]{\bfseries \Large My first \etoc: TOC of \autoref{part:overview} (\nameref{part:overview})} \tableofcontents \ref{toc:overview} \endgroup \end{filecontentsdef} \begin{verbatim} \begingroup\parindent 0pt \parfillskip 0pt \leftskip 0cm \rightskip 1cm \etocsetstyle {section} {} {\leavevmode\leftskip 0cm\relax} {\bfseries\normalsize\makebox[.5cm][l]{\etocnumber.}% \etocname\nobreak\hfill\nobreak \rlap{\makebox[1cm][r]{\mdseries\etocpage}}\par} {} \etocruledstyle[1]{\bfseries \Large My first \etoc: TOC of \autoref{part:overview} (\nameref{part:overview})} \tableofcontents \ref{toc:overview} \endgroup \end{verbatim} In the above verbatim there is a mysterious \centeredline{|\ref{toc:overview}|} which will be commented upon later. But let use first see what this code produces (of course its output depends on the contents of the present document, as applies to all other examples in this documentation). \filecontentsexec\foo This author always complicates things, so the above example had one additional twist I now have to explain. The mysterious % \centeredline{|\tableofcontents \ref{toc:overview}|} % means that the contents which are displayed are those of a local table of contents located somewhere else and labeled there via a % \centeredline{|\label{toc:overview}|} % Turns out that this was done via a \localtoc located at the start of \autoref{part:overview}, here is how the code looked like overthere: \begin{verbatim} \part{Overview} \etocdefaultlines \etocsettocstyle{}{} \localtableofcontents \label{toc:overview} \end{verbatim} For more explanations refer to \autoref{sec:labeling}. Notice in particular that there is no relation whatsoever between the line styles used for the original \localtoc and those applying here to the cloned one. Actually the original one could even have been made invisible via usage of \invisiblelocaltoc! Regarding the line styles, we could have used those defined by \etoc, which are activated via \csb{etocdefaultlines}, or the default document class styles which are activated by \csb{etocstandardlines}, but we were a bit more ambitious here and wanted to design our own. The technique is a simple one: each heading is in its own paragraph, which may extend on multiple lines; it is responsible for setting its own |\leftskip|. Here is again the code used (now displayed more fully). Notice that we defined styles for sections, subsections, and subsubsections, but actually that \autoref{part:overview} only has sections! \filecontentsprintviascan\foo \marginattach The two commands used are \csb{etocsetstyle} for specifying the line styles, and \csb{etocruledstyle} for the TOC global style. The |\rightskip| is shared by all, and creates space where the page numbers get printed. For an elaboration of this technique see the next \autoref{sec:secondexample} as well as \autoref{sec:tocwithdepthtags} which provides a TOC with parts and paragraphs. Both allow multi-line headings and employ a technique for putting page numbers in the right margin which was inspired from what \LaTeX2e's |\@dottedtocline| macro does. \section{A second example} \label{sec:secondexample} This second example: \begin{enumerate} \item illustrates displaying subsections of a given section ``horizontally'' in one single paragraph, \item does a selection of contents via the technique of \emph{depth tags}, described in \autoref{sec:depthtags}. \end{enumerate} Again the qualities of the author innovative pedagogy skills are well illustrated by the simplicity of the example. \begin{filecontentsdef}{etocsnippet-\snippetno.tex}{\foo} \begingroup \newcommand*{\DotsAndPage} {\nobreak\leaders\hbox{\bfseries\normalsize\hbox to .75ex {\hss.\hss}}% \hfill\nobreak \makebox[\rightskip][r]{\bfseries\normalsize\etocpage}\par} \etocsetstyle {part} {\parindent 0pt \nobreak \etocskipfirstprefix} {\pagebreak[3]\bigskip} {\large\rmfamily\bfseries\centering %\scshape \etocifnumbered{Part \etocnumber{} -- }{}\etocname\par} {} \etocsetstyle {section} {\leftskip 0pt \rightskip .75cm \parfillskip-\rightskip \nobreak\medskip \etocskipfirstprefix} {\leftskip 0pt \rightskip .75cm \parfillskip-\rightskip \pagebreak[1]\smallskip} {\normalsize\rmfamily\bfseries %\scshape \etocnumber. \etocname\DotsAndPage } {\parfillskip 0pt plus 1fil\relax } \etocsetstyle {subsection} {\leftskip1cm\rightskip .75cm \parfillskip 0pt plus 1fil\relax \nobreak\smallskip} {} {\footnotesize\sffamily\mdseries\itshape \etocname{} (\etocnumber, p. \etocpage). } {\par\medskip} \etocsettagdepth {preamble} {none} \etocsettagdepth {overview} {none} \etocsettagdepth {styling} {subsection} \etocsettagdepth {control} {none} \etocsettagdepth {examples} {none} \etocsettagdepth {advanced} {none} \etocsettagdepth {etocandworld}{subsection} \etocsettagdepth {code} {none} \etocsettocstyle {\centering\LARGE\textsc{\contentsname}\par\nobreak\medskip}{} \etocsetnexttocdepth {all} % but depth tags will control the actual contents \etocobeydepthtags % this is default anyhow, but may have been turned off \tableofcontents \endgroup \end{filecontentsdef} \filecontentsexec\foo \medskip The code looks like this. For more explanations relative to depth tags, and especially how they were incorporated into the present document, see also \autoref{sec:tocwithdepthtags}. \filecontentsprintviascan\foo \marginattach One last remark: the code above uses \csb{etocsetstyle} only for parts, sections and subsections. Non-styled levels would be displayed using fall-back defaults which are incorporated into the package code. Those fall-back defaults for |paragraph| and |subparagraph| display nothing at all (deliberately). So even if the |tocdepth| counter setting allowed it, and even if we had used % \centeredline{|\etocsettagdepth {code}{paragraph}|} % (as that \autoref{part:code} does contain \csa{paragraph}'s), no paragraph entry would have been displayed here. \section{A Beautiful Thesis example} Here is a relatively simple example of use of the package functionalities. Let us set up some line styles. We choose a style for sections and sub-sections which would be suitable for, respectively, sections and sub-sections in an average length memoir. The line style specifications have some redundancy for clarity, and do not care about what to do at possible page breaks. Also, they do not worry about potential multi-column use. \begin{filecontentsdef}{etocsnippet-\snippetno.tex}{\foo} \begingroup % we start a group to keep the style changes local \newlength{\tocleftmargin} \setlength{\tocleftmargin}{4cm} \newlength{\tocrightmargin} \setlength{\tocrightmargin}{1cm} \etocsetstyle{section} % will pretend to be a Chapter {\addvspace{1ex}\parfillskip0pt \leftskip\tocleftmargin % (already done in title) \rightskip\the\tocrightmargin plus 1fil \parindent0pt\color{cyan}} % (already done) {\bfseries\LARGE\upshape\addvspace{1ex}\leavevmode} {\llap{Chapter\hspace{.5em}{\etocnumber}\hspace{.75cm}}\etocname \nobreak\hfill\kern1em\makebox[-\tocrightmargin][l]{\makebox[0pt]{\etocpage}}\par} {} \etocsetstyle{subsection} % will pretend to be a Section {} {\mdseries\large\addvspace{.5ex}\leavevmode} {\llap{\etocnumber\hspace{.75cm}}\textit{\etocname}% \hfill\makebox[-\tocrightmargin][l]{\makebox[0pt]{\etocpage}}\par} {} \def\tmptitle{My Beautiful Thesis} \etocsettocstyle{\color{cyan}\parindent0pt \leftskip\tocleftmargin \leavevmode\leaders\hrule height 1pt\hfill\ \huge\textit{\tmptitle}\par}{\bigskip} \tableofcontents \ref{toc:overview} \endgroup \end{filecontentsdef} \filecontentsexec\foo \filecontentsprintviascan\foo \marginattach \section{Testing the compatibility mode}\label{sec:testingcompat} As a further example we now print the local table of contents of \autoref{sec:tocstyle}. First we will test the compatibility mode.\footnote{the present document uses the \ctanpkg{scrartcl} class, and we check here that the \etoc compatibility mode does respect the customizing done via the class commands.} The original is the local table of contents of \autoref{sec:tocstyle}, to which we allocated the label |toc:tocstyle|. \begin{verbatim} \begingroup % to keep in particular toc=left with local effect \KOMAoptions{toc=left} \etocclasstocstyle % necessary for the display to obey toc=left \etocstandardlines % use the document class built-in TOC line styles \tableofcontents \ref{toc:tocstyle} \endgroup \end{verbatim} \begingroup \KOMAoptions{toc=left} \etocclasstocstyle \etocstandardlines \tableofcontents \ref{toc:tocstyle} \endgroup \section{Another compatibility mode} \label{sec:anothercompat} As explained in \autoref{subs:compat}, the commands \csb{etocstandardlines} and \csb{etocetoclocaltocstyle} tell \etoc to, essentially, act as an observer. And it starts in this state initially. The document class layout for the table of contents is then perfectly obeyed (well, hopefully). There is no way \emph{if remaining in this compatibility mode} to customize this standard layout (change fonts, margins, vertical spacings, etc...) from within the package. For customizing \emph{while remaining in the compatibility mode}, use some package dedicated to this task; because \etoc either is (temporarily perhaps) in compatibility mode with no customization on its part possible, or the user has specified the layout in \csb{etocsetstyle} commands (and \csb{etocsettocstyle}) and is supposedly in complete control. Well, there is actually an alternative. It is possible to use the \csb{etocsetstyle} commands to recreate an artificial compatibility mode, in order to achieve effects like the following, all things being otherwise equal to the document class defaults: \begin{enumerate}[noitemsep] \item get the \ctanpkg{hyperref} link to encapsulate only the names, but not the numbers of each entry of the table of contents, \item use the document class style for chapters and sections, but modify it only for subsections, \item do either of the above only for some portions of the table of contents. \end{enumerate} One only needs to use within the arguments of \csb{etocsetstyle} the \LaTeX{} standard \csa{l@chapter}, \csa{l@section}, etc... re-constituting their arguments using \csb{etocname}, \csb{etocnumber}, \csb{etocpage} as one wishes. Here is an example. Include in the preamble: \begin{filecontentshere}{etocsnippet-\snippetno.tex} \makeatletter \newcommand{\MyLocalTOC}[1][section]{% \begingroup \etocsetstyle{section}{}{} {\l@section{\numberline{\etocnumber}\etocname}{\etocpage}}{}% \etocsetstyle{subsection}{}{} {\l@subsection{\numberline{\etocnumber}\etocname}{\etocpage}}{}% \etocsetstyle{subsubsection}{}{} {\l@subsubsection{\numberline{\etocnumber}\etocname}{\etocpage}}{}% % etc... if further sectioning units are needed % (i.e. not excluded by tocdepth and actually there in document) % Here #1 defaults to section, meaning this is appropriate % for local TOC in a chapter \etocsettocstyle{\@nameuse{#1}*{Local contents}} {} % \localtableofcontents \endgroup} \makeatother \end{filecontentshere} \marginattach Then use \csa{MyLocalTOC} in the document body. It is prepared for being local to a \csa{chapter}'s as it typesets the heading of the TOC by default as un unnumbered section.% % \footnote{Parts are handled somewhat differently according to whether one uses the standard or other classes; please check the source of these classes for what is to emulate here.} One can add to the above arbitrary text formatting commands, for example one can replace |\etocpage| in the code above by |\textcolor{blue}{\etocpage}|. Only pay attention to using |\makeatletter/\makeatother| as we are handling \LaTeX{} macros with the dangerous sign |@| in their names. To give another example, one sees in \texttt{article.cls} the following definition: \begin{verbatim} \newcommand*\l@subsection{\@dottedtocline{2}{1.5em}{2.3em}} \end{verbatim} The first argument is the level, the second the indent, and the third the numwidth (see the \ctanpkg{tocloft} documentation). So if we issue in a document using the \texttt{article} class: \begin{verbatim} \makeatletter \etocsetstyle{subsection} {] {} {\@dottedtocline{2}{1.5em}{2.3em}{\numberline{etocnumber}\etocname}{\etocpage}} {} \makeatother \end{verbatim} we then basically reconstitute the default rendering. Here is more careful code: \begin{verbatim} \makeatletter \etocsetstyle{subsection} {] {} {\@dottedtocline{2}{1.5em}{2.3em}{\etocifnumbered{\numberline{etocnumber}}{}% \etocname}{\etocpage}} {} \makeatother \end{verbatim} Hence one can very easily without any (additional...) package modify the hard-coded indent |1.5em| and numwidth |2.3em|. But in general one has to do this in a synchronized way also for subsubsections, and for sections. The definition of |\l@section| in the \texttt{article} class source is a bit more complex. Nevertheless this technique is probably the fastest (but see the example at start of \autoref{sec:linestyles}) to get going with \etoc even if one is primarily interested only in its \localtoc, as typesetting local tables of contents exactly as global tables of contents is not ideal. For example for a local TOC in a section, it looks appropriate to modify the above into \begin{verbatim} \makeatletter \etocsetstyle{subsection} {] {} {\@dottedtocline{2}{0}{2.3em}{\etocifnumbered{\numberline{etocnumber}}{}% \etocname}{\etocpage}} {} \makeatother \end{verbatim} to cancel the indentation. One will have to keep the indents and numwidths in sync with similar changes to other line styles, if \csa{contentsline}'s of various levels are to be executed. % % The number and the name of each entry are each separately an \ctanpkg{hyperref} links, as is always the case with \etoc, when not in compatibility mode. Replacing \csb{etocnumber} with \csb{etocthenumber} will give a TOC where the numbers are not links anymore, but the names still are. Or one may decide to use \csb{etocthename} and keep an hyperlinked number with \csb{etocnumber}. For a more sophisticated example see \autoref{sec:anothercompatadvanced}. \begin{shaded}\footnotesize\itshape \textcolor{red}{Attention Please!} The \LaTeX{} kernel is moving towards adding \emph{tagging} to the PDF, in a way mostly automated and transparent to user. \etoc will in due time accompany that evolution but this may mean that it will use for its own the hooks that \LaTeX{} will place for example in \emph{\csa{@dottedtocline}}. So, if the user explicitly also requires usage of \emph{\csa{@dottedtocline}}, this \emph{may} mean that some tagging code would be executed twice, possibly causing some havoc. My remark is \emph{purely hypothetical}, as a.t.t.o.w.\@ (2023/02/22) I have only started looking in the matter, and the \LaTeX{} and \ctanpkg{hyperref} TOC related changes have started being visible to developers only a few days ago. It may be however, that activating tagging could mean that the simple-minded recycling techniques described in this section will not work. I guess \etoc will always have the possibility to let the user specify that \etoc should not take care itself of the tagging (which it has to do in general, because the \LaTeX{} hooks are located in places such as \emph{\csa{@dottedtocline}} which \etoc does not execute, except if asked to do so as in the example above), so perhaps the techniques here will still work but require some \emph{\csa{etocnotagging}} or some \emph{noetoctagging} option to the \localtoc or \toc commands.\par \end{shaded} \section{Emulating the book class}\label{sec:thirdexample} As explained in \autoref{subs:compat}: without explicit use of an \csb{etocsetstyle} command the package will leave to the document class the hand regarding the ``toc line styles''. It is sometimes asked by users (for example those using \etoc for its \csb{localtableofcontents}) how to stay close to but not completely identical with the design implemented by the standard classes, such as |book|. I can recommend package \ctanpkg{tocloft} for this, as it is compatible with \etoc (see \autoref{subs:tocloft}) and thus \etoc will obey the \ctanpkg{tocloft} customizations (as long as no use has been made of \csb{etocsetstyle}). It is also possible to modify only the style for, say, sections and leave the parts, chapters, subsections as in the document class, via the technique from \autoref{sec:anothercompat}. But for complete control, here is a translation of the |book| class code into \etoc lingua. It is then easy to modify the relevant lengths or adjust the used fonts. I thank \textsc{Denis Bitouzé} for prompting me to include this in the \etoc manual, as it resulted from some conversation we had about this. The code is not 100\% faithful to the |book| class, and particularly its rendering of (multi-line) non-numbered units differs (... I think, as I copied pasted as is the code from where I had stored it and did not do much thinking about it again). Some proficiency in low-level \TeX\ and \LaTeX\ macros is needed to understand what the code says, but for modifying fonts or some lengths such in-depth understanding is not needed. With some extra code one can \emph{automatically adjust the widths} assigned to typesetting sectioning numbers in order to prevent overflows, even with for example \MakeUppercase{\romannumeral 38}; but this is a more advanced feature which I have moved to \autoref{sec:thirdexampleextra}. First we set up some lengths. I use macro registers, not real \LaTeX\ lengths. When using |em|'s however, this means that one must pay attention to when the actual dimension assignment is made, as this will then depend upon the current font settings. In the code below, at the location where the \csa{TOCnumwidthB} and \csa{TOCnumwidthC} will be used, the |1em| from their specification will be matched to the normal medium series font, not the bold font; this is deliberate so that one can compare more readily with the other dimensions; besides, with the \csa{TOCcomputenumwidths} from \autoref{sec:thirdexampleextra} these macros will actually hold a dimension using |pt| as dimensional unit. \begin{filecontentshere}{etocsnippet-\snippetno.tex} % it will be easy to globally shift the TOC horizontally if needed \def\TOCleftmargin {0pt} \def\TOCrightmargin {2.55em}% like LaTeX's \@tocrmarg % this is for dotted leaders \newbox\TOCleaderbox \def\TOCleaderboxwidth {0.7777em}% about like what standard classes do % vertical spacing \def\TOCverysmallvskip {0pt plus .2pt} \def\TOCmedvskip {1em plus 1pt} \def\TOCbigvskip {2.25em plus 1pt} % the ``numwidths'' for typesetting the numbering of division units. % I don't recall exactly how (and for which fonts) these figures were chosen. % They quickly prove too small if using Roman numerals (as do too the book % class defaults even though they are a bit larger). \def\TOCnumwidthB {1.5em} % chapter \def\TOCnumwidthC {2.278em}% section, I think default is 2.3em \def\TOCnumwidthD {3.056em}% analog in standard class is 3.2em \def\TOCnumwidthE {3.833em}% analog in standard class is 4.1em \def\TOCnumwidthF {4.611em}% analog in standard class is 5em \def\TOCnumwidthG {5.389em}% analog in standard class is 6em % The code for the ``global toc style''. \newcommand*\TOCglobalstyle {% \etocsettocstyle {\if@twocolumn \@restonecoltrue \onecolumn \else \@restonecolfalse \fi \parindent\z@ \leftskip\z@skip \rightskip \z@skip \setbox\TOCleaderbox\hbox to \TOCleaderboxwidth{\hss.\hss}% \chapter *{\noindent\kern\TOCleftmargin\relax % uses "pt"... \contentsname \@mkboth {\MakeUppercase \contentsname}{\MakeUppercase \contentsname}}% \rightskip \TOCrightmargin\relax \parfillskip -\rightskip % or a smaller value if desired \leftskip \TOCleftmargin \relax } {\if@restonecol \twocolumn \fi\cleardoublepage}% % \etocsetstyle{part} {} {\addpenalty {-\@highpenalty}% \addvspace \TOCbigvskip \leavevmode {\large \bfseries % use a group to limit font change \interlinepenalty\@M \etocifnumbered{\etocnumber\hspace{1em}}{}% \etocname \nobreak\hfil\makebox[-\parfillskip][r]{\etocpage}}\par \nobreak } {} {}% % \etocsetstyle{chapter} {\advance\leftskip\TOCnumwidthB\relax} {\addpenalty {-\@highpenalty }% \vskip \TOCmedvskip\relax \leavevmode {\interlinepenalty\@M \etocifnumbered {\llap{\makebox[\TOCnumwidthB][l]{\bfseries\etocnumber}}} {\advance\leftskip-\TOCnumwidthB\relax}% \bfseries\etocname \nobreak\hfil\makebox[-\parfillskip][r]{\etocpage}\par }% \penalty \@highpenalty } {} {\advance\leftskip-\TOCnumwidthB\relax}% % \TOCsetlinestyle {section} {\TOCnumwidthC}% \TOCsetlinestyle {subsection} {\TOCnumwidthD}% \TOCsetlinestyle {subsubsection}{\TOCnumwidthE}% \TOCsetlinestyle {paragraph} {\TOCnumwidthF}% \TOCsetlinestyle {subparagraph} {\TOCnumwidthG}% }% end of \TOCglobalstyle %The common code for line styles is abstracted into a macro: \newcommand\TOCsetlinestyle [2]{% #1= unit, #2= numwidth as macro \etocsetstyle{#1} {\advance\leftskip#2\relax} {\vskip \TOCverysmallvskip\relax \leavevmode {\interlinepenalty\@M \etocifnumbered {\llap{\makebox[#2][l]{\etocnumber}}}{\advance\leftskip-#2\relax}% \etocname \nobreak\leaders \copy\TOCleaderbox \hfil\makebox[-\parfillskip][r]{\etocpage}% \par }% } {} {\advance\leftskip-#2\relax}% } \makeatother \end{filecontentshere} \marginattach Nota Bene: the code deliberately handles the non-numbered sectioning units differently from what the standard document classes \texttt{article}, \texttt{report}, \texttt{book} do, particularly regarding the alignment of multi-line headings. The whole thing was encapsulated in \csa{TOCglobalstyle}, because we also want a \csa{TOClocalstyle} for local tables of contents which typically will want to use |\section*| rather than |\chapter*| and not insert page marks in the headers. The \csa{TOClocalstyle} is to be issued once, after the main document TOC, or rather before using \localtoc. If one wants a full TOC at end of document one will naturally have to issue again \csa{TOCglobalstyle} there. \begin{filecontentshere}{etocsnippet-\snippetno.tex} \makeatletter \newcommand*\TOClocalstyle {% \etocsettocstyle {\if@twocolumn \@restonecoltrue \onecolumn \else \@restonecolfalse \fi \setbox\TOCleaderbox\hbox to \TOCleaderboxwidth{\hss.\hss}% \parindent\z@ \dimen@ 2.25em % for left indenting \section *{\kern\dimen@ % use of \dimen@ works here by sheer luck \contentsname % un-comment this if marks are wanted: %\@mkboth {\MakeUppercase \contentsname}{\MakeUppercase \contentsname}% }% end of \section \parskip \z@skip \vspace{-1.25\baselineskip}% somewhat ad hoc \leftskip 2.25em \rightskip 4.5em \advance\rightskip-\TOCrightmargin\relax \leavevmode\leaders\hrule\@height\p@\hfill\kern\z@\par \rightskip 4.5em \parfillskip -\TOCrightmargin\relax } {\nobreak\vskip-.5\baselineskip \leavevmode\leaders\hrule\@height\p@\hfill\kern\z@\par \bigskip \if@restonecol \twocolumn \fi }% % \etocsetstyle{section} {\advance\leftskip\TOCnumwidthC\relax} {\addpenalty \@secpenalty \etociffirst{}{\addvspace{\TOCmedvskip}}% \leavevmode {\interlinepenalty\@M \bfseries\etocifnumbered {\llap{\makebox[\TOCnumwidthC][l]{\etocnumber}}} {\advance\leftskip-\TOCnumwidthC}% \etocname\nobreak\hfil\makebox[-\parfillskip][r]{\etocpage}\par }% \penalty \@highpenalty } {} {\advance\leftskip-\TOCnumwidthC\relax}% % the rest is identical with code for global tocs: \TOCsetlinestyle {subsection} {\TOCnumwidthD}% \TOCsetlinestyle {subsubsection}{\TOCnumwidthE}% \TOCsetlinestyle {paragraph} {\TOCnumwidthF}% \TOCsetlinestyle {subparagraph} {\TOCnumwidthG}% }% end of \TOClocalstyle \makeatother \end{filecontentshere} \marginattach As mentioned previously, this handles non-numbered (multi-line) sectioning units somewhat differently from what happens in the standard document classes. For some reason this code has some hard-coded |2.25em| and |4.5em| which were not abstracted into macros or lengths. The code inserts horizontal rules above and below the TOC contents in a non-separable by pagebreak way. See \autoref{sec:thirdexampleextra} for more. \section{A framed display} We now opt for a ``framed'' style, using the package default line styles and some colors added (it has been put in a float which appears \vpageref{toc:b}). \begin{filecontentshere}{etocsnippet-\snippetno.tex} \etocdefaultlines \begingroup \renewcommand{\etoccolumnsep}{2em} \renewcommand{\etocinnerleftsep}{1.5em} \renewcommand{\etocinnerrightsep}{1.5em} % specify a background color for the toc contents \renewcommand{\etocbkgcolorcmd}{\color{yellow!10}} % set up the top and bottom rules \renewcommand{\etoctoprule}{\hrule height 1pt} \renewcommand{\etoctoprulecolorcmd}{\color{red!25}} \renewcommand{\etocbottomrule}{\hrule height 1pt} \renewcommand{\etocbottomrulecolorcmd}{\color{red!25}} % set up the left and right rules \renewcommand{\etocleftrule}{\vrule width 5pt} \renewcommand{\etocrightrule}{\vrule width 5pt} \renewcommand{\etocleftrulecolorcmd}{\color{red!25}} \renewcommand{\etocrightrulecolorcmd}{\color{red!25}} % use \fcolorbox to set up a colored frame for the title \fboxrule1pt \renewcommand{\etocbelowtocskip}{0pt\relax} \etocframedstyle {\normalsize\rmfamily\itshape \fcolorbox{red}{white}{\parbox{.8\linewidth}{\centering This is a table of contents \`a la \etoc, but for the subsections and subsubsections of \autoref{sec:tocstyle}. As it is put in a frame, it has to be small enough to fit on one page. It has the label |toc:b|.}}} \begin{figure}[ht!] \centering \tableofcontents \label{toc:b} \ref{toc:tocstyle} \end{figure} \endgroup \end{filecontentshere} \marginattach \filecontentsexec\filecontentsheremacro \section{Another TOC with background color}\label{ssec:again} Let us now try out some more sophisticated line styles. The display will use the \csb{etocframedstyle} package command, which requires that the produced table of contents fits on a single page. We wrap it up in a \hyperref[toc:floating]{figure environment} showing up \vpageref{toc:floating}. This design uses the \etoc `framed' style with a background color. The frame borders have been set to have the same color as the one serving as background for the entire thing. It would be advantageous to use rather inside \csb{etocsettocstyle} commands from a package like |tcolorbox| as this allows sophisticated breakable boxes (with |TikZ/pgf| for decoration.) The details of the line styles used here are a bit involved, they were written by the author at some early stage of this documentation and have only been slightly revised to use more \LaTeX-commands and less \TeX-primitives. Similar code is used also for \hyperref[toc:clone]{this other toc}. \begin{filecontentshere}{etocsnippet-\snippetno.tex} \begin{figure}[htbp!]\centering \colorlet{subsecnum}{black} \colorlet{secbackground}{green!30} \colorlet{tocbackground}{red!20!green!20} \renewcommand{\etocbkgcolorcmd}{\color{tocbackground}} \renewcommand{\etocleftrulecolorcmd}{\color{tocbackground}} \renewcommand{\etocrightrulecolorcmd}{\color{tocbackground}} \renewcommand{\etocbottomrulecolorcmd}{\color{tocbackground}} \renewcommand{\etoctoprulecolorcmd}{\color{tocbackground}} \renewcommand{\etocleftrule}{\vrule width 3cm} \renewcommand{\etocrightrule}{\vrule width 1cm} \renewcommand{\etocbottomrule}{\hrule height 12pt} \renewcommand{\etoctoprule}{\hrule height 12pt} \renewcommand{\etocinnertopsep}{0pt} \renewcommand{\etocinnerbottomsep}{0pt} \renewcommand{\etocinnerleftsep}{0pt} \renewcommand{\etocinnerrightsep}{0pt} \newcommand\shiftedwhiterule[2]{% \hbox to \linewidth{\color{white}% \hskip#1\leaders\vrule height1pt\hfil}\nointerlineskip \vskip#2} \etocsetstyle{subsubsection} {\etocskipfirstprefix} {\shiftedwhiterule{\leftskip}{6pt}} {\sffamily\footnotesize \leftskip2.3cm\hangindent1cm\rightskip.5cm\relax \makebox[1cm][l]{\color{subsecnum}\etocnumber}% \color{black}\etocname \nobreak\leaders\hbox to.2cm{\hss.}\hfill \rlap{\makebox[.5cm][r]{\etocpage\hspace{.1cm}}}\par \nointerlineskip\vskip3pt} {} \etocsetstyle{subsection} {\etocskipfirstprefix} {\shiftedwhiterule{1.5cm}{6pt}} {\sffamily\small \leftskip1.5cm\hangindent.8cm\rightskip.5cm\relax \makebox[.75cm][l]{\color{subsecnum}\etocnumber}% \color{black}\etocname \nobreak\leaders\hbox to.2cm{\hss.}\hfill \rlap{\makebox[.5cm][r]{\etocpage\hspace{.1cm}}}\par \nointerlineskip\vskip3pt} {} \newcommand{\coloredstuff}[2]{% \leftskip0pt\rightskip0pt\parskip0pt \fboxsep0pt % \colorbox uses \fboxsep also when no frame! \noindent\colorbox{secbackground} {\parbox{\linewidth}{% \vskip5pt {\noindent\color{#1}#2\par}\nointerlineskip \vskip3pt}}% \par\nointerlineskip} \etocsetstyle{section} {\coloredstuff{blue}{\hfil \bfseries\large Contents of Part One\hfil}} {\vskip3pt\sffamily\small} {\coloredstuff{blue} {\leftskip1.5cm\rightskip.5cm\parfillskip-\rightskip \makebox[0pt][r]{\makebox[.5cm][l]{\etocnumber}}% \etocname\nobreak\hfill\makebox[.5cm][r]{\etocpage\hspace{.1cm}}}% \vskip6pt} {} \etocframedstyle[1]{} \tableofcontents \label{toc:floating} \ref{toc:part:styling} \vspace{-\baselineskip} \centeredline{|\tableofcontents \ref{toc:part:styling}| (\emph{cf.} \hyperref[toc:clone]{this other toc})} \end{figure} \end{filecontentshere} \marginattach \filecontentsexec\filecontentsheremacro The table of contents produced by this code appears on \vpageref{toc:floating}. \section{A (crazy) inline display} \label{sec:crazy} Let us construct some crazy inline display of the table of contents of this entire document. We will typeset the subsections as footnotes... This kind of style is suitable for a hyperlinked document, probably not for print! (although I like it, but my personal tastes in many matters do not seem to be widely shared). %%%% Note: 27 april 2014 %%%% except for a miraculous situation depending from the quantity of previous %%%% material this TOC will have links extending accross pagebreaks, which %%%% dvipdfmx does not know how to handle completely. Apart from that the output %%%% is ok, thus no need to try seriously to avoid them. \begin{filecontentsdef}{etocsnippet-\snippetno.tex}{\foo} \begingroup \newsavebox{\forsubsections} \etocsetstyle{part}{\upshape. \etocskipfirstprefix} {. \upshape} {\bfseries\etocname:~~} {} \etocsetstyle{section}{\itshape\etocskipfirstprefix} {, } {\mdseries\etocname} {} \etocsetstyle{subsection} {\begin{lrbox}{\forsubsections}\footnotesize\upshape\etocskipfirstprefix} {; } {\etocname} {.\end{lrbox}\footnote{\unhbox\forsubsections}} \etocsetstyle{subsubsection} { (\itshape\etocskipfirstprefix} {, } {\etocname} {\/\upshape)} \etocsettocstyle{Here is the inline table of contents. }{.\par} \tableofcontents \label{toc:crazyinline} \endgroup \end{filecontentsdef} \filecontentsexec\foo The code used: \filecontentsprintviascan\foo \marginattach \section{One more example of colored TOC layout} \label{ssec:tocclone} The command \csb{etocframedstyle} puts the title on the top rule in a centered position. This is not very convenient for this example so we included the title as part of the \meta{start} code at section level, to get it \emph{inside} the frame. \begin{filecontentshere}{etocsnippet-\snippetno.tex} \begingroup \definecolor{subsecnum}{RGB}{13,151,225} \definecolor{secbackground}{RGB}{0,177,235} \definecolor{tocbackground}{RGB}{212,237,252} \renewcommand{\etocbkgcolorcmd}{\color{tocbackground}} \renewcommand{\etocleftrulecolorcmd}{\color{tocbackground}} \renewcommand{\etocrightrulecolorcmd}{\color{tocbackground}} \renewcommand{\etocbottomrulecolorcmd}{\color{tocbackground}} \renewcommand{\etoctoprulecolorcmd}{\color{tocbackground}} \renewcommand{\etocleftrule}{\vrule width 1cm} \renewcommand{\etocrightrule}{\vrule width .5cm} \renewcommand{\etocbottomrule}{\hrule height 12pt} \renewcommand{\etoctoprule}{\hrule height 12pt} \renewcommand{\etocinnertopsep}{0pt} \renewcommand{\etocinnerbottomsep}{0pt} \renewcommand{\etocinnerleftsep}{0pt} \renewcommand{\etocinnerrightsep}{0pt} \newcommand\shiftedwhiterule[2]{% \hbox to \linewidth{\color{white}% \hskip#1\leaders\vrule height1pt\hfil}\nointerlineskip\vskip#2} \etocsetstyle{subsubsection}{\etocskipfirstprefix} {\shiftedwhiterule{\leftskip}{6pt}} {\sffamily\footnotesize \leftskip2.5cm\hangindent1cm\rightskip1cm\noindent \hbox to 1cm{\color{subsecnum}\etocnumber\hss}% \color{black}\etocname\leaders\hbox to .2cm{\hss.}\hfill \rlap{\hbox to 1cm{\hss\etocpage\hskip.2cm}}\par \nointerlineskip\vskip3pt} {} \etocsetstyle{subsection}{\etocskipfirstprefix} {\shiftedwhiterule{1.5cm}{6pt}} {\sffamily\small \leftskip1.5cm\hangindent1cm\rightskip1cm\noindent \hbox to 1cm{\color{subsecnum}\etocnumber\hss}% \color{black}\etocname\leaders\hbox to .2cm{\hss.}\hfill \rlap{\hbox to 1cm{\hss\etocpage\hskip.2cm}}\par \nointerlineskip\vskip6pt} {} \newcommand{\coloredstuff}[2]{% \leftskip0pt\rightskip0pt\parskip0pt \fboxsep0pt % \colorbox uses \fboxsep also when no frame! \noindent\colorbox{secbackground} {\parbox{\linewidth}{% \vskip5pt {\noindent\color{#1}#2\par}\nointerlineskip \vskip3pt}}% \par\nointerlineskip} \etocsetstyle{section} {\coloredstuff{white} {\hfil \hyperref[toc:b]{\bfseries\large I am a twin of that other TOC (click me!)}\hfil}} {\vskip3pt\sffamily\small} {\coloredstuff{white} {\leftskip1.5cm\rightskip.5cm\parfillskip-\rightskip \makebox[0pt][r]{\makebox[.5cm][r]{\etocnumber\hspace{.2cm}}}% \etocname\hfill\makebox[.5cm][r]{\etocpage\hspace{.2cm}}}% \vskip6pt } {} \etocframedstyle[1]{} \tableofcontents \label{toc:clone} \ref{toc:tocstyle} \endgroup \end{filecontentshere} \marginattach \filecontentsexec\filecontentsheremacro % 1.07l on the occasion of traduction into German documentation % APRIL 26, 2014 Improvement in the section style for better placement of % page number when the section name is more than one line long. Use of % \makebox rather than \hbox, to be more LaTeX like. The TOC has been put in a \hyperref[toc:clone]{float} which appears \vpageref{toc:clone}. The coding is a bit involved\footnote{and reveals the author's preference for the \TeX{} syntax...} as it does not use any additional package. Also, it was written at some early stage and I have not revised it since. A better solution would be to use some package to set up a background color possibly extending accross pages, as the framed style (which we used to get this background color) can only deal with material short enough to fit on one page. % 1.2 doc: commenté out to avoid a new page % ah non finalement car cause TOC as a tree d'être sur page impaire, % ce qui est moins bien à cause des overlap. Regarding colors, generally speaking all color commands inside \etoc are initially defined to do nothing, and the choice to use or not colors is left to the user. \clearpage \etocdepthtag.toc {advanced} \part{Advanced examples} \label{part:surprising} \thispartstats %% (pas de sous-section) \etocdefaultlines \etocsettocstyle {}{} \localtableofcontents \section{The TOC of TOCs} \label{sec:tocoftocs} \begingroup % \endgroup just after the \tableofcontents command \etocinline \etocsetlevel{part}{1} \etocsetlevel{visibletoc}{0} \etocsetstyle{visibletoc} {\etocskipfirstprefix} {, } {{\color{niceone}\etocname}} {} \etocsettocstyle{}{} \etocsetnexttocdepth{visibletoc} Here is the numbered and linked list of all tables of contents which are displayed within this document:\footnote{The TOCs put in floats may change the order: the numbers are listed in the order the TOCs are typeset in the document; but the numbering itself is from the order of the TOCs in the \emph{source} of this document... } \tableofcontents \endgroup. And to obtain it here we just wrote:\par\smallskip {\leftskip1cm\rightskip2cm \ttfamily\small\baselineskip11pt \noindent Here is the numbered and linked list of all tables of contents which are displayed within this document:~\string\tableofcontents.\par} The preparatory work was the following. First, we defined a counter |visibletoc| whose vocation is to get incremented at each displayed toc. \etoc has its own private counter but it counts all TOCs, even those not displayed because the |tocdepth| value was |-2| or |-3|. We could have added manually |\refstepcounter{visibletoc}| and |\label| commands at all suitable locations in the document source, and we would then have used here |\ref| commands, but this imposes heavy manual editing of the source. There is a much better way: there is a hook \csb{etocaftertitlehook} and we told it to increment the |visibletoc| counter and to write a line to the |.toc| file, in a manner analogous to what sectioning commands such as |chapter|, |section|, or |subsection| do. As \etoc increments its own private counter even before typesetting the title of a table of contents, this provides (most of the time) a better link destination than any counter manipulated from inside \csb{etocaftertitlehook} (for which the link would target the area just after the title). So, rather than including |\refstepcounter{visibletoc}| inside \csb{etocaftertitlehook}, we just put there |\stepcounter{visibletoc}| followed by the command \csb{etoctoccontentsline}|{visibletoc}{\thevisibletoc}|. This \etoc command \csb{etoctoccontentsline}\marg{level\_name}\marg{name} has the same effect as: \centeredline{| ||\addcontentsline{toc}|\marg{level\_name}\marg{name}} but its usefulness is to circumvent\footnote{using \csa{addtocontents} rather than \csa{addcontentsline}} the patching for automatic creation of bookmarks done to \csa{addcontentsline} by the \ctanpkg{hyperref} package, as pdf bookmarks don't make much sense here (and would elicit a complaint of \ctanpkg{hyperref} that the bookmark level is `unknown').\footnote{% The package provides a starred variant \staritb{etoctoccontentsline}, which does allow the creation of bookmarks and has a third mandatory argument which is the Level to be used by these bookmarks; depending on the context the starred as well as the non-starred variants may be profitably preceded by \csa{phantomsection}.} Finally, the preamble of the document did \csb{etocsetlevel}|{visibletoc}{6}|. The level |6| (or anything with a higher number) is ignored, even if |tocdepth| has value |10| for example; this is independently of whether \etoc uses the document class default line styles or its own line styles, or the ones defined by the user with the \csb{etocsetstyle} command. So there is no need to worry that something could go wrong. \emph{The example actually uses \csb{etocthemaxlevel}, see the \etocrelease{1.2a} change log entry.} Then, only here we have set \csb{etocsetlevel}|{visibletoc}{0}|. And to display only this kind of entries we assign temporarily to |part| and |chapter| level |1| (or anything higher than zero) and set |tocdepth| to the value |0|. We also did% % \centeredline{\csb{etocsetstyle}\{visibletoc\}\{\csb{etocskipfirstprefix}\}% \{, \}\{\string\etocname\}\{\}} % which defines an inline display with the comma (plus space) as separator. Finally, as \etoc issues |\par| automatically by default just before typesetting a table of contents, we used the command \csb{etocinline} (also known as \cs{etocnopar}) which turns off this behavior. Here are the implementation details: \begingroup \begin{filecontentshere}{etocsnippet-\snippetno.tex} < in the preamble > \newcounter{visibletoc} \renewcommand{\etocaftertitlehook} {\stepcounter{visibletoc}\etoctoccontentsline{visibletoc}{\thevisibletoc}} \etocsetlevel{visibletoc}{\etocthemaxlevel} \begin{document} < document body > \subsection{Surprising uses of etoc} \begingroup \etocinline \etocsetlevel{part}{1} % \etocsetlevel{chapter}{1} % (no chapters in scrartcl class) \etocsetlevel{visibletoc}{0} \etocsetstyle{visibletoc} {\etocskipfirstprefix}{, }{{\color{niceone}\etocname}}{} \etocsettocstyle{}{} % don't set any title, rules or frame or multicol! \etocsetnexttocdepth{visibletoc} % display only the `visibletoc' entries from .toc Here is the numbered and linked list of all tables of contents which are displayed within this document: \tableofcontents. \endgroup \end{filecontentshere} \marginattach \endgroup After |\etocsetstyle{visibletoc}{..}{..}{..}{..}|, all future TOCs (not in compatibility mode) will use the defined style for level |0| (which is normally the level for chapters). To keep these changes strictly local the simplest manner is to put everything inside a group. The \autoref{subsec:interverting} gives another use of the shuffling of levels. \section[Arbitrary ``Lists Of...'', \csbhyp{etoctoccontentsline}]{% Arbitrary ``Lists Of...'', \csbhyp{etoctoccontentsline} and \csbhyp{etocimmediatetoccontentsline}} \label{etoctoccontentsline} \label{etocimmediatetoccontentsline} This idea of interverting the levels is very powerful and allows to let \etoc display lists of arbitrary things contained in the document. All of that still using nothing else than the |.toc| file! Example: imagine a document with dozens of exercises, perhaps defined as |\newtheorem{exercise}{}[section]|. Let us explain how to instruct \etoc to display an hyperlinked list of all these exercises. For this we put in the preamble: (but see \etocrelease{1.2a} change log entry) \begin{verbatim} \newtheorem{exerci}{}[section] % the exercice number will be recoverable via \etocname: v--here--v \newcommand*{\exercisetotoc}{\etoctoccontentsline{exercise}{\theexerci}} \newenvironment{exercise}{\begin{exerci}\exercisetotoc}{\end{exerci}} \etocsetlevel{exercise}{6} \end{verbatim} In this way, \csb{etocname} will give the exercise number (but \csb{etocnumber} will be empty). Had we used instead \begin{verbatim} \newcommand*{\exercisetotoc} {\etoctoccontentsline{exercise}{\protect\numberline{\theexerci}}} \end{verbatim} the exercise number would then have been available via \csb{etocnumber}, and \csb{etocname} would have been empty. It doesn't matter which one of the two methods is used. The \etoc command \csb{etoctoccontentsline}|{..}{..}| is provided as a substitute to \csa{addcon\-tentsline}|{toc}{..}{..}|: this is to avoid the patching which is done by \ctanpkg{hyperref} to \csa{addcontentsline} in its process of creation of bookmarks. If one wants to authorize \ctanpkg{hyperref} to create bookmarks at a specific level \meta{n}, one can use (here with \meta{n}$=$|2|) the starred variant \starit{etoctoccontentsline} which has an additional argument: \begin{verbatim} \newcommand{\exercisetotoc}{\etoctoccontentsline*{exercise}{\theexerci}{2}} \end{verbatim} The counter |exerci| is already incremented by the |exerci| theorem environment, and provides the correct destination for the link added by package \ctanpkg{hyperref}. The command \csa{exercisetotoc} adds for each exercise a line to the |.toc| file, corresponding to a fictitious document unit with name `|exercise|'. A four-column list, including the sections, can then be typeset with the following code: \begin{filecontentshere}{etocsnippet-\snippetno.tex} \etocsetnexttocdepth{2} % sections are at level 1 and will show up \begingroup \etocsetlevel{exercise}{2} % but: \etocsetlevel{chapter}{3} % no chapters \etocsetlevel{subsection}{3} % no subsections \etocsetlevel{part}{3} % no parts \etocsetstyle{exercise}{}{} % \etocname = exercise number {\noindent\etocname\strut\leaders\etoctoclineleaders\hfill\etocpage\par} {\pagebreak[2]\vskip\baselineskip} \etocsetstyle{section}{}{} {\noindent\strut{\bfseries\large\etocnumber\hskip.5em\etocname}\par \nopagebreak[3]}{} \etocruledstyle[4]{\Large\bfseries List of the exercises} \setlength{\columnseprule}{.4pt} \tableofcontents \endgroup \end{filecontentshere} \marginattach A related command \csb{etocimmediatetoccontentsline} (and its starred version) is also provided. For discussion and the meaning of ``immediate'', refer to the analogous case of \csb{etocimmediatedepthtag.toc}. \section{The TOC as a tree}\label{tocastree} Using \ctanpkg{tikz} and the package \ctanpkg{forest} we shall display the table of contents of \autoref{part:styling} as a tree. The technique is to use the \etoc modified command \toc not for typesetting, but to prepare a macro, or rather here a \csa{toks} variable, with all the instructions to be executed later. \textsc{Leslie Lamport}'s book has no mention whatsoever of such token lists registers, and \LaTeX{} gives the impression to not really expect the general user to ever hear about them (or delimited macros); this whole section and the next are thus for advanced users. Putting the \csb{etocnumber} and \csb{etocname} commands in \csa{treetok} would be of no use: to which number or name would they then refer to, in a delayed execution? We need to store, not the macro names, but the macro contents. And also we wish to maintain the correct \ctanpkg{hyperref} hyperlinks. The commands \csb{etocname}, etc\dots, are robust, it is easier to work with \csb{etocthelinkednumber}, \csb{etocthelinkedname}, and \csb{etocthelinkedpage} which contain the same information in an easier accessible form.% % \normalmarginpar\marginpar{\footnotesize\rmfamily\itshape\RaggedRight At \etocrelease{1.1a} the commands \csa{etocthelinkedname}, etc\dots, are always providing an hyperlink, so it is not true that \csb{etocname}, etc\dots, are always simply their robust variants.} For this |forest| tree we have designed very special \etoc styles for sections and subsections. They use a token list register called |\treetok| and a macro |\appendtotok| whose r\^ole is to append to a given token list variable the contents of a macro given as second argument. All this will happen in reaction to a |\tableofcontents| command, but \emph{nothing} has yet been printed in the process.\footnote{There is always a \csa{par}, which here is not a problem, but can be suppressed if need be via the command \csb{etocinline} or its synonym \csb{etocnopar}.} This is the later job of a |forest| environment which will be given the contents of |\treetok|. \let\appendtotok\relax \begin{filecontentsdef}{etocsnippet-\snippetno.tex}{\foo} % \newtoks\treetok % put this (uncommented) preferably in the preamble % \newtoks\tmptok % (idem) \begingroup \newcommand*\appendtotok[2]{% #1=toks variable, #2=macro, expands once #2 #1\expandafter\expandafter\expandafter {\expandafter\the\expandafter #1#2}} \newcommand*\PrepareSectionNode{% \tmptok {\centering\bfseries}% \appendtotok\tmptok\etocthelinkedname \edef\foresttreenode{ [{\noexpand\parbox{2cm}{\the\tmptok}}}% } \newcommand*{\PrepareSubsectionNode}{% \tmptok {\raggedright}% \appendtotok\tmptok\etocthelinkedname \edef\foresttreenode{ [{\noexpand\parbox{6cm}{\the\tmptok}}}% } \etocsetstyle{section} {\etocskipfirstprefix} {\appendtotok\treetok{ ]}} {\PrepareSectionNode \appendtotok\treetok\foresttreenode} {\appendtotok\treetok{ ]}} \etocsetstyle{subsection} {\etocskipfirstprefix} {\appendtotok\treetok{ ]}} {\PrepareSubsectionNode \appendtotok\treetok\foresttreenode} {\appendtotok\treetok{ ]}} \etocsettocstyle {\treetok{[{\hyperref[part:styling]{The \etoc styling commands}}}} {\global\appendtotok\treetok{ ]}} % forest does not like @\the\treetok if \treetok is empty. On first latex % run, this will be the case because the TOC style defined above will not % have been executed, as the label {toc:overview} does not refer to a valid % TOC yet. So we must give a safe default value to \treetok \treetok{[{run latex again}]} \begin{figure}[htbp!] \centering \etocsetnexttocdepth{subsection} \tableofcontents \label{toc:forest}\ref{toc:part:styling} \hypersetup{hidelinks}% \bracketset{action character=@} % manual adjustments to fit the printed page % \kern-1cm \noindent\kern-3cm \begin{forest} for tree={anchor=center,child anchor=west, grow'=east,draw,thick, edge={draw,thick,dashed,color=teal}}, where={level()==1}{circle,thick,fill=blue!5, before computing xy={l=6cm}}{}, where={level()==2}{fill=red!5, before computing xy={l=6cm}}{}, rectangle, thick, fill=cyan!5, inner sep=6pt, @\the\treetok \end{forest} \end{figure} \endgroup \end{filecontentsdef} \filecontentsexec\foo The resulting tree has been put in a \hyperref[toc:forest]{float}, which appears \vpageref[above]{toc:forest}. Here is the code used for its production: \filecontentsprintviascan\foo \marginattach Why |\hypersetup{hidelinks}|? as explained in \autoref{ssec:hidelinks}, I prefer the links in TOCs not to be colorized, nor framed, so this document inserts a command %\csa{hypersetup}\texttt{\{hidelinks\}} % ok pour hyphénation %\csa{hypersetup}|{hidelinks}| % pas ok |\hypersetup{hidelinks}| % ok maintenant 12 octobre 2013 in the |.toc| file. But at the time the |\treetok| contents are unpacked the |\hyperlink| commands originating in |\etocthelinkedname|, etc\dots{} will be executed in the normal environment for links (which, in this document, is to colorize them). Rather than having \etoc's code try to guess what the current ``style'' for links is (a concept not really provided by \ctanpkg{hyperref} it seems) and store it in |\etocthelinkedname|, etc\dots, I opted for the simpler solution to leave it up to the user to recreate whatever conditions are desired. So here it is necessary to re-issue |\hypersetup{hidelinks}| in the |figure| environment. There are some other examples in this documentation where |\tableofcontents| is used to prepare material for later typesetting: \begin{itemize} \item printing the statistics at the start of each Part (see \autoref{ssec:statistics}) is done using save boxes (so the problem of the appearance of the links does not arise then). \item typesetting of the TOC as a table without benefiting from \csb{etocglobaldefs} (see \autoref{ssec:tocastableold}). \item and the examples in the next section. \end{itemize} \section{The TOC as a molecule}\label{sec:molecule} It is also possible to construct a TOC tree obeying the TikZ syntax for trees: but this is a more complicated task for the \etoc line styles for reasons related to the way braces are handled by \TeX{} (they need, when filling up the token list to be always balanced at each step, else complicated tricks must be employed.) The simplest strategy is to allocate a token list (or use a macro) for each level used: we may need a \csa{parttok}, a \csa{chaptertok}, a \csa{sectiontok} and a \csa{subsectiontok}, to help in the task of filling up the total \csa{treetok}. As we are interested here in the table of contents of this (or another) document part, only a \csa{sectiontok} and a \csa{subsectiontok} will be needed. \let\appendtotok\relax \let\treenode\relax \let\appendchildtree\relax \let\preparetreenode\relax \begin{filecontentshere}{etocsnippet-\snippetno.tex} % \newtoks\treetok % put this (uncommented) preferably in the preamble % \newtoks\subsectiontok % \newtoks\subsubsectiontok % Attention: this code has been prepared only for subsections % and subsubsections. \newcommand*{\treenode}{}% only to make sure our \edef's do not overwrite % an existing command % expands 2nd argument (macro) and appends it to 1st argument (toks) \newcommand*\appendtotok[2]{% #1=toks variable, #2=macro, expands once #2 #1\expandafter\expandafter\expandafter {\expandafter\the\expandafter #1#2}} % appends 2nd argument contents (toks) as child of first argument (toks) \newcommand*{\appendchildtree}[2]{% token list t1 becomes: t1 child {t2} \edef\tmp{\the#1 child {\the#2}}% #1\expandafter{\tmp}% } % prepare the (hyperlinked) number in the "node (number)" shape \newcommand*{\preparetreenode}{% \tmptok\expandafter{\etocthelinkednumber}% expanded once (needed) \edef\treenode{node {\the\tmptok}}% } \etocsetstyle{subsection} {\etocskipfirstprefix} {\appendchildtree\treetok\subsectiontok} {\preparetreenode \subsectiontok\expandafter{\treenode}} {\appendchildtree\treetok\subsectiontok} \etocsetstyle{subsubsection} {\etocskipfirstprefix} {\appendchildtree\subsectiontok\subsubsectiontok} {\preparetreenode \subsubsectiontok\expandafter{\treenode}} {\appendchildtree\subsectiontok\subsubsectiontok} \etocsettocstyle {\treetok{\node {\hyperref[sec:linestyles]{Line styles}}}} {\global\appendtotok\treetok{ ;}} \centeredline{% from package centeredline (limits scope of \hypersetup) \etocsetnexttocdepth{subsubsection} \etocinline\tableofcontents \label{toc:molecule} \ref{toc:tocstyle} \hypersetup{hidelinks}% \begin{tikzpicture} [grow cyclic, level 1/.style={level distance=4cm,sibling angle=72}, level 2/.style={level distance=2cm,sibling angle=60}, every node/.style={ball color=red,circle,text=SkyBlue}, edge from parent path={[dashed,very thick,color=cyan] (\tikzparentnode) --(\tikzchildnode)}] \the\treetok \end{tikzpicture}% } \end{filecontentshere} \marginattach \filecontentsexec\filecontentsheremacro The |\tableofcontents| command is executed prior to the |tikzpicture| environment which will actually typeset it via insertion of the accumulated data in the \csa{toks} register \csa{treetok}. This \hyperref[toc:molecule]{TikZ TOC} is fully hyperlinked, like the previous \hyperref[toc:forest]{Forest TOC}. % Mercredi 01 mars 2023 à 23:27:29 % arrrrrrgggghhh % desperate attempt to avoid an annoying varioref "may loop" error. % at last minute, arose from a suppression of a paragraph a few % dozen pages earlier. % [76] % ! Package varioref Error: \vref or \vpageref at page boundary 65-66 (may loop). % See the varioref package documentation for explanation. % Type H for immediate help. % ... % % l.6114 appears \vpageref{toc:mindmap} % mais ça n'a pas suffit. Bon 10 minutes de perdues je vais déplacer la ligne. \enlargethispage{3\baselineskip} Another example: \etocsettocstyle {\treetok{\node {\autoref{sec:tocstyle}}}} {\global\appendtotok\treetok{ ;}} \etocsetnexttocdepth {subsubsection} \tableofcontents \ref{toc:tocstyle} \centeredline{% \hypersetup{hidelinks} \begin{tikzpicture} [grow cyclic, level 1/.style={level distance=2.5cm,sibling angle=60}, level 2/.style={level distance=1cm,sibling angle=45}, every node/.style={ball color=red!50,circle,text=black}, edge from parent path={[very thick,color=cyan] (\tikzparentnode) --(\tikzchildnode)}] \the\treetok \end{tikzpicture} }% % The above is the fully hyperlinked table of contents of \autoref{sec:tocstyle}. \section{The TOC as a TikZ mind map} \label{sec:mindmap} This is in the same spirit as the ``molecule'' example. The use of the \eTeX{} primitive \csa{unexpanded} will simplify the code.% % \let\partnode\relax \let\childnode\relax \let\appendtotok\relax \let\appendchildtree\relax \expandafter\let\csname c@partco\endcsname\relax \begin{filecontentsdef}{etocsnippet-\snippetno.tex}{\foo} % \newtoks\treetok % done in preamble % \newtoks\parttok \newcommand*\partnode {} % check with \newcommand we will not overwrite something \newcommand*\childnode {} \newcommand*\tmprotate {} % (idem) \newcommand*\tmpoption {} % \newcommand*\tmpstuff {} % \newcommand*\appendtotok[2]{% #1=toks variable, #2=macro, expands once #2 #1\expandafter\expandafter\expandafter{\expandafter\the\expandafter #1#2}} \newcommand*{\appendchildtree}[3]{% % this is to construct "t1 child [#3]{t2}" from #1=t1 and #2=t2 % t1 and t2 are two toks variable (not macros) % #3 = for example teal!60 \edef\tmpstuff {\the#1 child [#3]{\the#2}}% #1\expandafter {\tmpstuff }% } \newcounter{partco} % 1,2,3,4,5,... -> 1,2,3,1,2,3,1,2,3 \def\pseudomodthree #1{\numexpr #1 + 3 - 3*((#1+1)/3)\relax} \etocsetstyle{part} {\etocskipfirstprefix} % This updates the global tree with the data from the previous % part and all its children sections. Moved here because for some parts the % sections are not displayed due to depth tags. {\ifnum\value{partco}=3 \appendchildtree\treetok\parttok {branch color= green!50,level distance=10cm}% \else \ifcase\pseudomodthree{\value{partco}}% \or \appendchildtree\treetok\parttok {branch color= teal!30}% first \or \appendchildtree\treetok\parttok {branch color= yellow!80}% second \else\appendchildtree\treetok\parttok {branch color= green!50}% third and next ... \fi\fi } {\stepcounter{partco}% % customize manually some TikZ set-up (should be done inside the TikZ thing I guess) \def\tmpoption {}% \def\tmprotate {}% first %\ifnum\value{partco}=5 \def\tmprotate {[counterclockwise from =-40]}\fi %\ifnum\value{partco}=8 \def\tmprotate {[counterclockwise from =-50]}\fi % define the part node \edef\partnode{node \tmpoption {\unexpanded\expandafter{\etocthelinkednumber}. \unexpanded\expandafter{\etocthelinkedname}}\tmprotate }% % this is a starting point which will be filled it by the section children \parttok\expandafter{\partnode}} {\ifcase\pseudomodthree{\value{partco}}% \or \appendchildtree\treetok\parttok {branch color= teal!60}% first \or \appendchildtree\treetok\parttok {branch color= yellow!80}% second \else\appendchildtree\treetok\parttok {branch color= green!50}% third and next ... \fi } \etocsetstyle{section} {} {} {% define the section node \edef\childnode{child {node {\unexpanded\expandafter{\etocthelinkednumber} \unexpanded\expandafter{\etocthelinkedname}}}}% % append it to the current \parttok \appendtotok\parttok\childnode } {} \etocsettocstyle {\setcounter{partco}{0}% \treetok{\node [root concept]{\textbf{The \etoc documentation}}}} {\global\appendtotok\treetok{ ;}} % The \global above is mandatory because etoc always typesets TOC inside a group \etocsetnexttocdepth{section} % use of depth tags to cut out sections for most parts, the sections % are too numerous to fit well with the circular growth \etocsettagdepth {preamble} {part} \etocsettagdepth {overview} {part} \etocsettagdepth {styling} {part} \etocsettagdepth {control} {part} \etocsettagdepth {examples} {part} \etocsettagdepth {advanced} {part} \etocsettagdepth {etocandworld}{part} \etocsettagdepth {code} {section} \tikzset{ branch color/.style={ concept color=#1!white, every child/.append style={concept color=#1!white!30!white, font=\normalsize}, } }% \begin{figure}[htbp!] \etocobeydepthtags % obey the depth tags restrictions (which is default anyhow) \tableofcontents\label{toc:mindmap}% \centeredline{\resizebox{.85\paperwidth}{!}% {\begin{tikzpicture}[mindmap, grow cyclic, text width=2cm, align=flush center, nodes={concept}, concept color=orange!60, root concept/.append style={text width=4cm, font=\Large}, level 1/.append style={level distance=5cm,sibling angle=45, text width=3cm}, level 2/.append style={level distance=7cm,sibling angle=30, text width=3cm}, level 1 concept/.append style={font=\normalsize}, ] \the\treetok \end{tikzpicture}}} \end{figure} \end{filecontentsdef} \filecontentsexec\foo It is difficult to get everything to fit on one page. However \csa{resizebox} comes to the rescue. And it preserves hyperlinks. Nevertheless for this example I excluded some sections from the display, using the technique of the \etoc \hyperref[etocdepthtag.toc]{depth tags}. % The fully hyperlinked TOC % appears \vpageref{toc:mindmap}. \filecontentsprintviascan\foo \marginattach The fully hyperlinked TOC appears \vpageref{toc:mindmap}. An interesting alternative is to use \etoc rather to convert the entire TOC into a TikZ tree (perhaps excluding some parts) and print it out to a file from which it can be recovered and manipulated directly by the author of the document. Things written to the |.log| file get broken into lines. Here is a technique to get non-broken output. Once the \csa{treetok} has been computed by \etoc (as in the \hyperref[toc:molecule]{molecule} example, or the current example), this demo will write it out to file with extension |.toctree|: \begin{verbatim} \newwrite\TOCasTree \immediate\openout\TOCasTree=\jobname.toctree \immediate\write\TOCasTree{\the\treetok}% \end{verbatim} \section{The TOC as a (long) table} \label{sec:tocastable} % With release \etocrelease{1.08} it is easier to typeset a TOC as a table. It is possible to open a \texttt{tabular} (or \texttt{longtable}) in the title part of the TOC (first argument to \csb{etocsettocstyle}) and then close it after the contents (second argument to \csb{etocsettocstyle}), and specify in the line styles how to use the tabulation |&| and tabular end of row |\\|. But there are some conditions and a few caveats: \begin{enumerate} \item it is \textbf{mandatory} to issue \csb{etocglobaldefs} for \etoc's definitions of \csb{etocname} et al. to have global scope, i.e. not be extinguished on encountering a |&|, \item it is impossible to start one of the \meta{start}, \meta{prefix}, \meta{contents} or \meta{finish} specification with a sole |\hline|, \emph{i.e.} one not preceded by a |\\|, % (it is however possible to put % |\\| at the end of \meta{prefix} and the |\hline| at the start of % \meta{contents}). \item as is explained next, it is recommended to put the |\\| at the start of the \meta{prefix} or \meta{contents} specifications in order to close the \emph{previous} row, rather that at the end with the idea to close the \emph{current} row; and when the TOC is a partial one (a \csa{localtableofcontents}) this is (in almost all situations) mandatory. \end{enumerate} Here is an example of a TOC as a |longtable|. Yes this is only \emph{one} table! The code follows. \begin{filecontentsdef}{etocsnippet-\snippetno.tex}{\foo} \begingroup \etocglobaldefs % necessary for \etocname etc... to survive & \makeatletter % hack into longtable \hline to avoid annoying (here) stray lines at top \def\LT@@hline{% \ifx\@let@token\hline \global\let\@gtempa\@gobble \global\let\@gtempb\@firstofone %%% ADDED \gdef\LT@sep{\penalty-\@medpenalty\vskip\doublerulesep}% \else \global\let\@gtempa\@empty \global\let\@gtempb\@gobble %%% ADDED \gdef\LT@sep{\penalty-\@lowpenalty\vskip-\arrayrulewidth}% \fi \ifnum0=`{\fi}% \multispan\LT@cols \unskip\leaders\hrule\@height\arrayrulewidth\hfill\cr \@gtempb{% %%% ADDED \noalign{\LT@sep}% \multispan\LT@cols \unskip\leaders\hrule\@height\arrayrulewidth\hfill\cr \noalign{\penalty\@M}% }% %%% ADDED \@gtempa} \makeatother % observe the locations of the \\ \etocsetstyle{part} {} {} {\\\hline\multicolumn{3}{c}{\bfseries\vrule height6ex depth3ex width0pt \makebox[0pt]{\etocifnumbered{\etocnumber. }{}\etocname}}} {} \etocsetstyle{section} {} {\etociffirst{\\\hline}{\\}} {\etocnumber&\etocname &\etocpage } {} \etocsetstyle{subsection} {} {\\} {&\makebox[1cm][c]{\etocnumber}% \parbox[t]{\dimexpr6cm-\tabcolsep\relax}{\sloppy\itshape\etocname\strut}% &\itshape\etocpage } {} \etocsettocstyle {\hypersetup{hidelinks}% \begin{longtable}{|>{\bfseries}c|p{7cm}|r|} \hline \multicolumn{3}{|c|}{\Large\bfseries\strut\strut TABLE OF CONTENTS}% } {\\\hline\end{longtable}} \etocsetnexttocdepth {subsection} \tableofcontents \endgroup \end{filecontentsdef} \filecontentsexec\foo \filecontentsprintviascan\foo \marginattach Examining the code above the reader will wonder why the |\\| are always given first in \meta{prefix+contents} and not, as is more intuitive, rather last. In some favorable cases (but almost never for local tables of contents) one may indeed construct TOC-as-tables with the |\\| located at the end of the style specifications. The problem in the previous example was with the positioning of the |\hline|'s. Due to technical aspects of how \TeX{} constructs alignments any definition or assignment done after an |\\| starts a new row, and thus makes |\hline| an illegal token (this shows as a |misplaced \noalign| error.) Not only does \etoc have to do such definitions to construct \csb{etocname} etc..., it is furthermore the case that some packages put things in the |.toc| file and as a result there is never any guarantee that between two \csa{contentsline} there will not be such a token like |\relax| which in the contexts of alignments forces \TeX{} to start a cell and thus makes it impossible then to insert an |\hline|. The safest way is thus to start with an |\\| each line style specification in order to close the \emph{previous} table row. We had a little problem with the fact that we wanted parts not only to have a rule above them (easy, they do |\\\hline|) but also below them: after each part there is a section, and it is these sections which are used to insert the missing |\hline| (this is done with the help of the \csb{etociffirst} conditional). Last technical note: because we put the |\\\hline| inside the branches, there was no need to employ the expandable variants \csb{etocxiffirst} and \csb{etocxifnumbered}. For the hardliner's old way see \autoref{ssec:tocastableold}. Here is also a much simpler example. It is a local table of contents. \begin{filecontentsdef}{etocsnippet-\snippetno.tex}{\foo} \begin{center} \etocsetstyle{section} {} {\etociffirst{\\\hline\hline}{\\\hline}} {\etocname & \etocnumber & \etocpage } {} \etocsettocstyle {\hypersetup{hidelinks}\begin{tabular}{|>{\RaggedRight}p{4.5cm}|c|c|}\hline \multicolumn{1}{|c|}{\bfseries Section title}& \bfseries number& \bfseries page} {\\\hline\end{tabular}} \etocglobaldefs % MANDATORY !! \etocsetnexttocdepth{1} \tableofcontents\ref{toc:overview} \end{center} \end{filecontentsdef} \filecontentsexec\foo \filecontentsprintviascan\foo \marginattach \section{A TOC self-adjusting widths for its typesetting} \label{sec:thirdexampleextra} This is a continuation of \autoref{sec:thirdexample}. The goal is to adjust automatically the ``numwidths'' used for typesetting the unit numbers in the (local) tables of contents. \begin{filecontentshere}{etocsnippet-\snippetno.tex} \makeatletter \newcommand*\TOCcompute@numwidths [2]{% #1=empty/"local", #2=minimal indent \begingroup \def\TOCnumwidthB {0pt}% \def\TOCnumwidthC {0pt}% \def\TOCnumwidthD {0pt}% \def\TOCnumwidthE {0pt}% \def\TOCnumwidthF {0pt}% \def\TOCnumwidthG {0pt}% \etocsetstyle{part}{}{}{}{}% \etocsetstyle{chapter}{} {\setbox0\hbox{\bfseries\etocthenumber\kern#2}} {\ifdim\wd0>\TOCnumwidthB\edef\TOCnumwidthB{\the\wd0}\fi}{}% \etocsetstyle{section}{} {\setbox0\hbox{\bfseries\etocthenumber\kern#2}} {\ifdim\wd0>\TOCnumwidthC\edef\TOCnumwidthC{\the\wd0}\fi}{}% \etocsetstyle{subsection}{} {\setbox0\hbox{\etocthenumber\kern#2}} {\ifdim\wd0>\TOCnumwidthD\edef\TOCnumwidthD{\the\wd0}\fi}{}% \etocsetstyle{subsubsection}{} {\setbox0\hbox{\etocthenumber\kern#2}} {\ifdim\wd0>\TOCnumwidthE\edef\TOCnumwidthE{\the\wd0}\fi}{}% \etocsetstyle{paragraph}{} {\setbox0\hbox{\etocthenumber\kern#2}} {\ifdim\wd0>\TOCnumwidthF\edef\TOCnumwidthF{\the\wd0}\fi}{}% \etocsetstyle{subparagraph}{} {\setbox0\hbox{\etocthenumber\kern#2}} {\ifdim\wd0>\TOCnumwidthG\edef\TOCnumwidthG{\the\wd0}\fi}{}% % \etocsettocstyle {} {\global\let\TOCnumwidthB\TOCnumwidthB \global\let\TOCnumwidthC\TOCnumwidthC \global\let\TOCnumwidthD\TOCnumwidthD \global\let\TOCnumwidthE\TOCnumwidthE \global\let\TOCnumwidthF\TOCnumwidthF \global\let\TOCnumwidthG\TOCnumwidthG }% make the found maximal widths have global scope \etocnopar \csname #1tableofcontents\endcsname \typeout{Next TOCs will use \TOCnumwidthB\space for chapter number width}% \typeout{Next TOCs will use \TOCnumwidthC\space for section number width}% \typeout{Next TOCs will use \TOCnumwidthD\space for subsection number width}% \typeout{Next TOCs will use \TOCnumwidthE\space for subsubsection number width}% \typeout{Next TOCs will use \TOCnumwidthF\space for paragraph number width}% \typeout{Next TOCs will use \TOCnumwidthG\space for subparagraph number width}% \endgroup % matches \begingroup at start of definition }% \newcommand*\TOCcomputenumwidths [1][0.5em]{% \TOCcompute@numwidths {}{#1}% }% \newcommand*\TOCcomputelocalnumwidths [1][0.5em]{% \TOCcompute@numwidths {local}{#1}% }% \makeatother \end{filecontentshere} \marginattach The optional parameter to \csa{TOCcomputenumwidths} specifies the minimal indent. In case nothing is numbered you may wish a higher value than |0.5em|. For each local table of contents to have its own width computations, the macro \csa{TOCcomputelocalnumwidths} is provided. As the code makes global assignments, either use (once) \csa{TOCcomputenumwidths} or do \csa{TOCcomputelocalnumwidths} for each local table of contents. \begin{verbatim} \TOCcomputelocalnumwidths % may use optional argument to replace 0.5em \localtableofcontents \end{verbatim} Notes: \begin{enumerate}[nosep] \item naturally these are only suggestions. For example one could put everything in single macros \csa{TOCtoc} and \csa{TOClocaltoc} to simultaneously compute the numwidths and then typeset the (local) table of contents. \item if you want to adjust the |tocdepth| recall from \autoref{ssec:bookmarksdepth} that it influences \ctanpkg{hyperref} hence you may need to use a group |\begingroup...\endgroup|. Or, one can use \csb{etocsetnexttocdepth}\marg{level} but (with the code as here) this must then be issued twice, once for \csa{TOCcomputelocalnumwidths}, once for \csa{localtableofcontents}. \item the bold font serves above for both chapter and section numwidth computations, but the code from \autoref{sec:thirdexample} uses |\bfseries| only in local TOCs. Thus the \csa{TOCcomputenumwidth} will set the parameter \csa{TOCnumwidthC} to a value slightly larger than needed in the main TOC. Hence the section style in \csa{TOCcompute@numwidths} should possibly insert the |\bfseries| in the box only after testing for the optional parameter |local|. \end{enumerate} \section{Interverting the levels} \label{subsec:interverting} Let us display and count all subsections occurring in this document (see \autoref{part:surprising} for other uses of this technique): \begin{verbatim} \etocsetnexttocdepth{2} \begingroup \etocsetlevel{part}{3} \etocsetlevel{section}{3} \etocsetstyle{subsection} {\small\begin{enumerate}[itemsep=0pt,label=,leftmargin=0pt]} {\normalfont\bfseries\item} {\roman{enumi}. \mdseries\etocname{} (\etocnumber, p.~\etocpage)} {\end{enumerate}} \renewcommand{\etoccolumnsep}{2.75em} \renewcommand{\columnseprule}{1pt} \etocmulticol[3]{\subsection{All subsections of this document}} \endgroup \end{verbatim} \etocsetnexttocdepth{2} \begingroup \etocdefaultlines \etocclasstocstyle \etocsetlevel{book}{3} \etocsetlevel{part}{3} \etocsetlevel{chapter}{3} \etocsetlevel{section}{3} \etocsetstyle{subsection}{\small \begin{enumerate}[itemsep=0pt,label=,leftmargin=0pt]} {\normalfont\bfseries\item} {\roman{enumi}. \mdseries\etocname{} (\etocnumber, p.~\etocpage)} {\end{enumerate}} \renewcommand{\etoccolumnsep}{2.75em} \renewcommand{\columnseprule}{1pt} %%\etocmarkbothnouc{List of all subsections} %% le mark (\markright) est fait par \subsection \etocmulticol[3]{\subsection{All subsections of this document}\label{toc:allsubsections}} \endgroup \section{Displaying statistics}\label{ssec:statistics} Each part of this document starts with a paragraph telling how many sections and subsections it has. Well, each one of this paragraph is a table of contents! We designed a macro \csa{thispartstats} to do that. It uses ``storage'' boxes to keep the information about the first and last section or subsection. Using boxes is the simplest manner to encapsulate the \ctanpkg{hyperref} link for later use (whether there is one or none). However, one cannot modify then the font or the color. % (using the % \TeX{} primitive \csa{setbox} rather than the \LaTeX{} \csa{sbox} would % allow to change the color of the un-boxed saved box) If such a need arises, one must switch from using boxes to using macros, and store the \ctanpkg{hyperref} data for later use as was done in the code presented in \autoref{sec:molecule}. We present also this second method. But first, the code of \csa{thispartstats}:\par \begin{filecontentshere}{etocsnippet-\snippetno.tex} \newsavebox\firstnamei \newsavebox\firstnumberi \newsavebox\lastnamei \newsavebox\lastnumberi \newsavebox\firstnameii \newsavebox\firstnumberii \newsavebox\lastnameii \newsavebox\lastnumberii \newcounter{mycounti} \newcounter{mycountii} \newcommand*{\thispartstatsauxi}{} \newcommand*{\thispartstatsauxii}{} \newcommand*{\oldtocdepth}{} \newcommand*{\thispartstats}{% \setcounter{mycounti}{0}% \setcounter{mycountii}{0}% \def\thispartstatsauxi{% \sbox{\firstnamei}{\footnotesize\etocname}% \sbox{\firstnumberi}{\footnotesize\etocnumber}% \def\thispartstatsauxi{}}% \def\thispartstatsauxii{% \sbox{\firstnameii}{\footnotesize\etocname}% \sbox{\firstnumberii}{\footnotesize\etocnumber}% \def\thispartstatsauxii{}}% \begingroup \etocsetstyle{subsection} {} {} {\thispartstatsauxii \stepcounter{mycountii}% \sbox{\lastnameii}{\footnotesize\etocname}% \sbox{\lastnumberii}{\footnotesize\etocnumber}} {}% \etocsetstyle{section} {} {} {\thispartstatsauxi \stepcounter{mycounti}% \sbox{\lastnamei}{\footnotesize\etocname}% \sbox{\lastnumberi}{\footnotesize\etocnumber}} {{\footnotesize\itshape Here are some statistics for this part: it contains \arabic{mycounti} section\ifnum\value{mycounti}>1 s\fi{} and \arabic{mycountii} subsection\ifnum\value{mycountii}>1 s\fi. The name of the first section is \unhbox\firstnamei{} and the corresponding number is \unhbox\firstnumberi. The name of the last section is \unhbox\lastnamei{} and its number is \unhbox\lastnumberi. The name of the first subsection is \unhbox\firstnameii{} and the corresponding number is \unhbox\firstnumberii. The name of the last subsection is \unhbox\lastnameii{} and its number is \unhbox\lastnumberii.\par}}% \etocinline % cancels the automatic \par automatically before the TOC \etocsettocstyle {}{} \etocsetnexttocdepth{2}% \localtableofcontents % to be used at the top level of a Part. \endgroup } \end{filecontentshere} \marginattach And now, the variant with macros rather than boxes (this variant as it stands here is for using within a section). \begin{filecontentshere}{etocsnippet-\snippetno.tex} \makeatletter \newcommand*\firstsubname {} \newcommand*\lastsubname {} \newcommand*\firstsubnumber {} \newcommand*\lastsubnumber {} \newcommand*\thisspecialstatsaux{} \newcommand*{\thisspecialstats}{% \setcounter{mycounti}{0}% \def\thisspecialstatsaux{% \let\firstsubname\etocthelinkedname \let\firstsubnumber\etocthelinkednumber \def\thisspecialstatsaux{}} \begingroup \etocsetstyle{subsection} {} {} {\thisspecialstatsaux \stepcounter{mycounti}% \let\lastsubname\etocthelinkedname \let\lastsubnumber\etocthelinkednumber } {Here are some statistics for this section. It contains \arabic{mycounti} subsections. The name of its first is \emph{\firstsubname{}} and the corresponding number is {\firstsubnumber}. The name of the last subsection is \emph{\lastsubname{}} and its number is {\lastsubnumber}.}% \etocsettocstyle {}{} \etocinline \etocsetnexttocdepth {1}% \localtableofcontents % to be used within a section \endgroup } \makeatother \end{filecontentshere} \marginattach \section{Using depth tags} \label{sec:tocwithdepthtags} \etoc provides via the concept of \emph{depth tags} the possibility to decide that, for example, a table of contents will display sections and subsections in a given chapter or part, but only sections, or nothing at all, for the other chapters (or parts) included in the given table of contents. You will find more explanations at \autoref{sec:depthtags} For this the user adds to the source usage in the document body of \csb{etocdepthtag.toc} commands, located right before the |\part|, or |\chapter|, or whatever division headings whose control is desired, for example % \centeredline{|\etocdepthtag.toc{specialchapter}|} % and then when using \toc or \localtoc, user will add some command such as % \centeredline{|\etocsettagdepth{specialchapter}{section}|} % which will have the effect that only sections but no subsections of that chapter get displayed in that (possibly local, here to a Part) table of contents. Actually, one also has to add a depth tag at end of the desired scope of first one, something such as % \centeredline{|\etocdepthtag.toc{endofspecialchapter}|} % and one will then issue % \centeredline{|\etocsettagdepth{endofspecialchapter}{all}|} % to left further chapters again include in the so-configured table of contents all of their sub-units (as limited by current |tocdepth|). The simplest way thus is, if one decides to add a depth tag for one part or chapter to also add depth tags to all other parts, respectively chapters, and configure them appropriately. Think of this as a way to add \emph{inside} the |.toc| file some changes to the |tocdepth| counter, except that those changes are dynamically configurable, and also the whole thing can be ignored if \csb{etocignoredepthtags} is used. As an example, one can imagine a document with various Parts, each part displaying a table of contents of the \emph{complete} document, but which shows regarding other parts only their title and no finer division, whereas for the Part where it is located it will show all levels allowed by |tocdepth|. This is a variant of a ``local'' table of contents, which does display things external to the Part where it is located, but in a more limited way than regarding that Part itself. The commands \csb{etocobeydepthtags} (which is default behavior) and \csb{etocignoredepthtags} can be used to control which TOC obey depth tags. If generally they should not, issue once \csb{etocignoredepthtags} in preamble, and then use \csb{etocobeydepthtags} for specific TOCs, either inside a scope-limiting group, or re-issue \csb{etocignoredepthtags} after each such (local or not) table of contents. Here is a demonstration using the contents of this documentation. We want a TOC which will have a heading for each |\part|, with two Parts being handle especially: the \autoref{part:control} will show all its divisions down to subsubsection (if present) and the \autoref{part:code} will even show paragraphs (turns out that this document used there some |\paragraph| mark-up). To achieve this we added various \csb{etocdepthtag.toc} commands inside the source of this document prior to each |\part| command. It only remains now to set appropriately the depth of each such depth tag, which will be done like this: \begin{verbatim} \etocsettagdepth {preamble} {part} \etocsettagdepth {overview} {part} \etocsettagdepth {styling} {part} \etocsettagdepth {control} {subsubsection} \etocsettagdepth {examples} {part} \etocsettagdepth {advanced} {part} \etocsettagdepth {etocandworld}{part} \etocsettagdepth {code} {paragraph} \end{verbatim} As said, we want here to display even paragraph entries in a specific part. The standard document class paragraph TOC line styles give too much vertical spacing in this context. So we cook up our own, quickly designed, line styles, a bit like what we did for \autoref{sec:firstexample}, but with a way (see the command |\EndParWithPageNumberInMarginAndLeaders|) to put page numbers on the right which is more like the method used by \LaTeX2e's |\@dottedtocline|; headings occupying more than one line will now wrap in a way achieving some hanging indentation relative to the entry number (but there is no such long heading in this example). \begin{filecontentsdef}{etocsnippet-\snippetno.tex}{\foo} \etocsetnexttocdepth {all} \begingroup \parindent 0pt \leftskip 0cm \rightskip .75cm \parfillskip -\rightskip \newcommand*{\EndParWithPageNumberInMargin} {\nobreak\hfill % I initially added \etocnoprotrusion after \etocpage, but % finally switched to using monospace font for page number, % and it seems to have deactivated the protrusion anyhow. \makebox[0.75cm][r]{\mdseries\normalsize\ttfamily\etocpage}% \par} \renewcommand*\etoctoclineleaders {\hbox{\normalfont\normalsize\hbox to .75ex {\hss.\hss}}} \newcommand*{\EndParWithPageNumberInMarginAndLeaders} {\nobreak\leaders\etoctoclineleaders\hfill \makebox[0.75cm][r]{\mdseries\normalsize\ttfamily\etocpage}% \par } \etocsetstyle {part} {} {\leavevmode\leftskip 1cm\relax} {\bfseries\large\llap{\makebox[1cm][r]{\etocnumber\ \ }}% \etocname\EndParWithPageNumberInMargin\smallskip} {} \etocsetstyle {section} {} {\leavevmode\leftskip 1.75cm\relax} {\bfseries\normalsize\llap{\makebox[.75cm][l]{\etocnumber}}% \etocname\EndParWithPageNumberInMarginAndLeaders} {} \etocsetstyle {subsection} {} {\leavevmode\leftskip 2.75cm\relax } {\mdseries\normalsize\llap{\makebox[1cm][l]{\etocnumber}}% \etocname\EndParWithPageNumberInMarginAndLeaders} {} \etocsetstyle {subsubsection} {} {\leavevmode\leftskip 4cm\relax } {\mdseries\normalsize\llap{\makebox[1.25cm][l]{\etocnumber}}% \etocname\EndParWithPageNumberInMarginAndLeaders} {} \etocsetstyle {paragraph} {} {\leavevmode\leftskip 5.5cm\relax } {\mdseries\normalsize\llap{\makebox[1.5cm][l]{\etocnumber}}% \etocname\EndParWithPageNumberInMarginAndLeaders} {} \etocsettagdepth {preamble} {part} \etocsettagdepth {overview} {part} \etocsettagdepth {styling} {part} \etocsettagdepth {control} {subsubsection} \etocsettagdepth {examples} {part} \etocsettagdepth {advanced} {part} \etocsettagdepth {etocandworld}{part} \etocsettagdepth {code} {paragraph} \renewcommand\etoctoprule {\hrule height 3pt\relax } \renewcommand\etoctoprulecolorcmd {\color{blue}} \renewcommand\etocaftercontentshook {\medskip\begingroup \color{blue}\hrule height 3pt \endgroup } \etocruledstyle [1]{\Large\bfseries \fbox{\makebox[8cm]{A TOC using depth tags}}} \sloppy \etocobeydepthtags % let's not forget to activate this (default anyhow) \tableofcontents \endgroup \end{filecontentsdef} \filecontentsexec\foo \filecontentsprintviascan\foo \marginattach \section{Sections styling subsections} \label{sec:anothercompatadvanced} Here is a subtler example where one only marginally modifies the sections (adding color to the number, removing the \ctanpkg{hyperref} link, changing the color for one specific section) but let them decide almost one by one of the style which will be followed by their subsections. Furthermore one configures some sections to decide they will not display subsections at all or only count how many there are! % modified for 1.2 doc to make the argument optional and update number % of exceptional section \begin{filecontentshere}{etocsnippet-\snippetno.tex} \makeatletter \newcommand*{\MyQuasiStandardTOC}[2][]{% % #1 is an optional "\ref{somelabeltoanothertoc}" % #2 is the number of some exceptional section \begingroup \etocsetstyle{section} {} {\etociffirst{% Suppress display of subsections for the first section! \etocsetlevel{subsection}{\etocthemaxlevel}} {\etocsetlevel{subsection}{2}}% \ifnum\etocthenumber=#2 % Handle especially section number #2 ! \etocsetstyle{subsection} {\def\foo{}\par\nopagebreak\begingroup \leftskip2em \rightskip\@tocrmarg \parfillskip \@flushglue \parindent 0pt \normalfont\normalsize\rmfamily\itshape \etocskipfirstprefix} {\allowbreak\,--\,} {\edef\foo{\the\numexpr\foo+1}\etocname\ \textup{(\etocnumber)}} {.\par \upshape My AI counted circa \foo\space subsections, was it right?\par\endgroup}% \else \ifnum\etocthenumber>#2 % Only count subsections in those sections ! \etocsetstyle{subsection} {\def\foo{}}% {\edef\foo{\the\numexpr\foo+1}}% {}% {\leftskip2em \emph{There are \foo\space subsections here, but I will need payment to display them.}\par}% \else \etocsetstyle{subsection} {}% {}% {\l@subsection{\numberline{\etocnumber}\etocname}{\etocpage}}% {}% \fi \fi }% {% Display in a special color the number of the special section! \l@section{\numberline{{\ifnum\etocthenumber=#2 \color{red}\else\color{cyan}\fi\etocthenumber}}% \etociffirst{\etocname\space (SUBSECTIONS SKIPPED)}{\etocname}} {\etocpage}}% {}% \etocclasstocstyle % will use the ambient document class % special KOMA-script customization as this document uses scrartcl % and we need to enlarge numwidth for some subsections \DeclareTOCStyleEntry[numwidth=2em,indent=0pt]{tocline}{section} \DeclareTOCStyleEntry[numwidth=2.5em,indent=2em]{tocline}{subsection} \etocsetnexttocdepth {subsection}% \tableofcontents #1 \endgroup } \makeatother \end{filecontentshere} \marginattach \filecontentsexec\filecontentsheremacro The optional argument stands for a suitable |\ref|, see \autoref{sec:labeling}. Here is what \begin{verbatim} \MyQuasiStandardTOC[\ref{toc:part:styling}]{11}% treat especially section 11 \end{verbatim} gives: \MyQuasiStandardTOC[\ref{toc:part:styling}]{11}% \vskip.5\baselineskip The page heading (on the page where this TOC appears) may have been modified as is expected from usage of \csb{etocclasstocstyle} in the code. Sections are printed exactly as in the default, \emph{except} that a special section number is displayed especially and that its subsections are then displayed inline! And other sections may only count subsections or ignore them altogether! Note: for this code to work the macro \csa{thesection} \emph{must} not have been modified from its default which produces simply arabic digits. In other terms it must be usable as \TeX{} number denotation. Typically this would fail if we were handling subsections as their number in the |.toc| file will be typically something like |3.7| which does not work in a \TeX{} integer-only context. But it is possible to use a counter and configure the line styles to increment it, and use its value. \section{The TOC as a (long) table (alternative)} \label{ssec:tocastableold} Due to, among other things, the fact that alignment cells create and close groups, and that by default definitions of \csb{etocname}, \csb{etocnumber}, \csb{etocpage} made by \etoc are local, it was not easy to typeset a TOC as table with \etoc, prior to release to the addition of \csb{etocglobaldefs} at \etocrelease{1.08}. Not only \csb{etocname} etc... caused a problem, but also the basic redefinition of \csa{contentsline} was made by \etoc only after the first argument to \csb{etocsettocstyle} had been executed, hence if this argument were to open a tabular, the \etoc redefinition of \csa{contentsline} would be done in the first cell of the first row and get lost thereafter. Thus one had to resort to the technique explained in \autoref{tocastree} of using the execution of \csa{tableofcontents} as a way to store data which was then displayed later. For the record, here is how the TOC from \autoref{sec:tocastable} was coded in the old days.% % \footnote{At release \etocrelease{1.09f} the design anb contents of the TOC from \autoref{sec:tocastable} were modified; the code here, if executed, which will not, reproduces the former looks.} % We don't have here the problems with the positioning of |\hline|'s we face with the newer method; on the other hand we must manipulate token registers which are not familiar to most \LaTeX{} users (macros could be used, but would be more cumbersome, except perhaps if using the \eTeX{} \csa{unexpanded}). The method here is the most powerful because it filters out of the |.toc| file only the data we want (the other things are not ignored, they are executed but hopefully do not create havoc; typically they are language changing instructions, etc...), and we are less susceptible to fall potential victims of various external macros inserted in the |.toc| file by other packages. Note: rather than |\toks| registers it would be easier here to use \eTeX{} \csa{unexpanded} primitive. See for example \autoref{sec:mindmap}. \let\appendtotok\relax \let\PreparePart\relax \let\PrepareSection\relax \let\PrepareSubsection\relax \begin{filecontentshere}{etocsnippet-\snippetno.tex} \newtoks\toctabletok \newcommand*\appendtotok[2]{% #1=toks variable, #2=macro, expands once #2 #1\expandafter\expandafter\expandafter {\expandafter\the\expandafter #1#2}} \newcommand*\PreparePart{% \toks0 \expandafter{\etocthelinkednumber}% \toks2 \expandafter{\etocthelinkedname}% \toks4 \expandafter{\etocthelinkedpage}% \edef\toctablepiece {\noexpand\hline \noexpand\strut\the\toks0 &\noexpand\bfseries\the\toks2 &\the\toks4 \noexpand\\\noexpand\hline}% } \newcommand*\PrepareSection{% \toks0 \expandafter{\etocthelinkednumber}% \toks2 \expandafter{\etocthelinkedname}% \toks4 \expandafter{\etocthelinkedpage}% \edef\toctablepiece {\the\toks0 &\the\toks2 &\the\toks4 \noexpand\\}% } % \newcommand*{\PrepareSubsection}{% \toks0 \expandafter{\etocthelinkednumber}% \toks2 \expandafter{\expandafter\itshape\etocthelinkedname\strut}% \toks4 \expandafter{\expandafter\itshape\etocthelinkedpage}% \edef\toctablepiece{&\noexpand\makebox[1cm][c]{\the\toks0}% \noexpand\parbox[t]{\dimexpr6cm-\tabcolsep\relax} {\noexpand\sloppy\the\toks2}% &\the\toks4 \noexpand\\}% } \begingroup \etocsetstyle{part}{}{}{\PreparePart \appendtotok\toctabletok\toctablepiece}{} \etocsetstyle{section}{}{}{\PrepareSection \appendtotok\toctabletok\toctablepiece}{} \etocsetstyle{subsection}{}{}{\PrepareSubsection\appendtotok\toctabletok\toctablepiece}{} \etocsettocstyle {\toctabletok{\hypersetup{hidelinks}% \begin{longtable}{|>{\bfseries}c|p{7cm}|r|}\hline \multicolumn{3}{|c|}{\Large\bfseries\strut TABLE OF CONTENTS}% \\\hline\hline}} {\global\toctabletok\expandafter{\the\toctabletok\hline\end{longtable}}} \etocsettocdepth {subsection} \tableofcontents \the\toctabletok \endgroup \end{filecontentshere} \marginattach \clearpage \etocdepthtag.toc {etocandworld} \part{\etoc and the world} \etocsettocstyle{}{} \etocdefaultlines % etoc own default \localtableofcontents \section{Constraints on the \texttt{.toc} file constitution} The contents of the |.toc| file (if it already exists) are read into memory by \etoc once, at the time of |\begin{document}|.% % \footnote{% Versions earlier than \etocrelease{1.07m} read the |.toc| file at the time of \csa{usepackage\{etoc\}}. Thanks to Denis Bitouzé who signaled a Babel related problem, which turned out to be caused by this.} The |.toc| file remains available to other packages for read operations until the location of the first table of contents at which time a write stream is opened by \etoc and from that point the file is erased until its contents are again written to the disk by \LaTeX{} at the end of the compilation. Don't use |\if stuff \tableofcontents\fi|, but: \centeredline{|\if stuff \expandafter\tableofcontents\fi|} Also a |\else| immediately following \csa{tableofcontents} or \csa{localtableofcontents} requires a previous \csa{expandafter}. \etoc can not really cohabit with packages modifying the \csa{tableofcontents} command: some sort of truce can be achieved if \etoc is loaded last, hence is the winner. \begin{framed} Do not modify the |\tableofcontents| command like this: \centeredline{|\let\oldtableofcontents\tableofcontents|} \centeredline{|\renewcommand\tableofcontents{\oldtableofcontents foo}|} as this will make the |\label/\ref| mechanism impossible. Rather, redefine \csb{etocaftertochook} \centeredline{|\renewcommand\etocaftertochook{foo}|} and there is also \csb{etocaftercontentshook} which is executed a bit earlier\footnotemark{} just before the closing part of the toc display style (and thus still within a group.) Prepending is less of a problem (and anyhow there is also \csb{etocbeforetitlehook} available to the user). Under certain circumstances \etoc imposes its views on \csa{tableofcontents} at the time of |\begin{document}|. You may thus have to use \csa{AtBeginDocument} to delay your (necessarily ugly and non-recommendable) patches. Patching after |\begin{document}| is naturally possible but I feel almost a rebel to mention this to \LaTeX{} users! \end{framed} \footnotetext{Contrarily to \csb{etocaftertochook}, \csb{etocaftercontentshook} is not executed if the |tocdepth| did not allow the printing of the TOC.} \etoc \textbf{requires} the |.toc| file to use the \csa{contentsline} macro. It \textbf{can not} work if there is no |.toc| file or if the |.toc| file does not use the \csa{contentsline} macro or if the \csa{contentsline} macro second argument mixes number and name in a manner unexpected by \etoc.% % \footnote{Prior to \etocrelease{1.1a}, \etoc required the \csa{contentsline} macro expansion to invoke \csa{l@section} et al. It now does not expand \csa{contentsline} hence is immune to whatever would happen during this expansion, and does not use nor modify the \csa{l@section} et al.\@ macros.} \section{Compatibility with document classes} \etoc has mainly been tested with the |article| and |book| standard classes. Some compatibility layer with the \ctanpkg{KOMA-script} and \ctanpkg{memoir} classes was added at \etocrelease{1.05} of |2012/12/01|.% % \footnote{That this is still in the doc on \texttt{2023/02/22} shows the frequency of \etoc syncing with upstream changes... but let me reassure the reader there has been indeed some occasional, although admittedly rare, internal updates in the more than ten years elapsed since.} % A compatibility layer is required for what this document designates as the ``global display style'': \etoc tries to emulate the default behaviour of the document class when \csb{etocsettocstyle} has not been used, so that it is still in ``compatibility mode''. There does not seem to be an easy way to extract this in an automated manner dynamically, so it is basically some manual work which the author initiated in 2012 and which got sporadically updated since. \subsection{Compatibility with the \ctanpkg{KOMA-script} classes} \label{etocscrartclstyle} \label{etocscrbookstyle} \label{etocscrreprtstyle} Not really tested... well, tested by this document with its dozens of \etoc TOCs and which uses \ctanpkg{scrartcl}! The package code contains \begin{verbatim} \@ifclassloaded{scrartcl} {\renewcommand*\etocclasstocstyle{\etocscrartclstyle}}{} \end{verbatim} with \cs{etocscrartclstyle} trying to emulate the global display style of the \cs{tableofcontents} within the class \ctanpkg{scrartcl}. Thus \etoc is ready for basic usage in compatibility mode. See further \autoref{ssec:tocbasic}. \subsection{Compatibility with the \ctanpkg{memoir} class} \label{ssec:memoir} \label{etocmemoirtoctotocfmt} \label{etocmemoirstyle} Release \etocrelease{1.07l} has also improved the compatibility with the \ctanpkg{memoir} class: its |appendix| level has been made known to \etoc. It is at the same level as |chapter|, thus the chapter line style should possibly do a test for some user defined boolean whose activation may be added to the |.toc| file at the suitable location via |\addtocontents{toc}{..}|, if one needs to distinguish the two kinds of divisions. The \ctanpkg{memoir} mechanism relative to \toc versus \toc|*| is obeyed automatically, and applies with \localtoc too. With release \etocrelease{1.2} some issues which were previously described here when the ``to toc'' feature of \ctanpkg{memoir} was left acting on local TOCs have been resolved, as an after-effect of the support for \etocoption{localtoctotoc} etc..., see \csb{etocsetup}. \subsection{Compatibility with \ctanpkg{beamer}} For the reasons mentioned already regarding the constraints on the |.toc| file constitution, \etoc is incompatible with the \ctanpkg{beamer} class. However, if \ctanpkg{beamer} is used in an article mode, i.e., with the article class in conjunction with the \ctanpkg{beamerarticle} package, then \etoc should work. \section{Compatibility with other packages} \subsection{Compatibility with \ctanpkg{babel}} \begin{framed} One must load \etoc \emph{after} \ctanpkg{babel}. This is in order for \ctanpkg{babel}'s shorthands to be active at the time when \etoc loads the |.toc| file. \end{framed} \subsection{Compatibility with \ctanpkg{hyperref}} Please inform the author in case of issues: \etoc was from the start designed to be |100%| compatible with package \ctanpkg{hyperref}. \begin{framed} Releases of \etoc prior to \etocrelease{1.2c} copied over some legacy internals of \ctanpkg{hyperref} which got removed there at release |v7.01c| of |2023-10-21|, and this caused \etoc to stop displaying tables of contents. You must use at least \etocrelease{1.2c} to avoid that mishap. \end{framed} The macros \csb{etocname}, \csb{etocnumber}, and \csb{etocpage} contain the \ctanpkg{hyperref} links, if present (note that the \emph{linktoc=all} option of \ctanpkg{hyperref} tells it to put a link also in the page number corresponding to a given toc entry). For example, the tables of contents of the present document are all fully linked. It doesn't matter whether \etoc or \ctanpkg{hyperref} is loaded first. \subsection{Compatibility with \ctanpkg{microtype}} \label{ssec:microtype} \label{etocnoprotrusion} (this doc added at \etocrelease{1.2b}) \ctanpkg{microtype} patches the \LaTeX{} \csa{numberline} command (which is used in |.toc| file) to execute \csa{leftprotrusion}. The reason \ctanpkg{microtype} does this patch to \csa{numberline} is that the default \LaTeX{} contents line styles do some \csa{hskip} which inhibit left protrusion of the (explicit digits or letters of the) argument of \csa{numberline}, which is the first typeset material on the contents line. Some other contexts than a previous \csa{hskip} inhibit left protrusion, in particular a non-zero paragraph indentation. One could imagine that \etoc user only has to add \csa{leftprotrusion} if so desired at start of the defined line styles. But usage of the \csa{leftprotrusion} command is delicate, it must be followed with an explicit character or with a very limited set of \LaTeX{} commands. In particular, and imagining here that the defined line style starts a paragraph with \csb{etocnumber}, and that this paragraph is indented so that automatic left protrusion does not apply, an attempt to force reactivation of left protrusion via: % \centeredline{|\leftprotrusion\etocnumber|} % fails. One has to resort to use: % \centeredline{|\expandafter\leftprotrusion\etocthenumber|} % This would not work with \csb{etocthelinkednumber}, so to get the protruding number to also be hyperlinked one has to use % \centeredline{|\etoclink{\expandafter\leftprotrusion\etocthenumber}|} The package does not provide yet (nor is it planned in near future in absence of user requests) extra support such as an option to insert internally \csa{leftprotrusion} \emph{inside} \csb{etocnumber} which would avoid such gymnastics. But the user can easily add a definition such as % \centeredline{|\newcommand\leftprotrudingetocnumber{\etoclink{\expandafter\leftprotrusion\etocthenumber}}|} % to the preamble, and use the defined wrapper or a variant built upon \csb{etocthename} in custom \csb{etocsetstyle} line style definitions. If on the contrary you want to avoid left protrusion, it is coherent to load \ctanpkg{microtype} this way: % \centeredline{|\usepackage[nopatch=toc]{microtype}|} % This avoids the \csa{leftprotrusion} addition done by \ctanpkg{microtype} to \csa{numberline}; but this is of relevance only if you use \etoc in compatibility mode, because user-defined \etoc line styles will not execute \csa{numberline} except if explicitly added to the line style, and even if they do, as explained above something such as % \centeredline{|\numberline{\etocnumber}|} % will inject a \csa{leftprotrusion} which will remain without effect. \etoc provides since \etocrelease{1.2b} a macro \csb{etocnoprotrusion} which is a copy of the \LaTeX{} \csa{noprotrusion} command available since its |2018/12/01| release, and is used since by \LaTeX{} default TOC code with page numbers. You can use this if a style definition, perhaps modeled on the standard \LaTeX{} layout from \csa{@dottedtocline}, also locates \csb{etocpage} at right margin preceded on the line by some dot leaders. Indeed protrusion may cause an extra dot, compared to other lines, which is really ugly visually. Use \csa{noprotrusion} in the style after \csb{etocpage} (or whatever is at end of the line style contents) if you can assume that \LaTeX{} is recent enough, or use \csb{etocnoprotrusion} which will work with all \LaTeX{} versions, even old ones. You may also consider turning protrusion off completely for tables of contents. For this, see \autoref{ssec:disableprotrusion}. Notice that some problem with page number alignment look like protrusion-related ones but may simply be caused by the fact that the font used does not assign the same width to all digits, and the line style pushes these digits to the right end of the line (to confirm this in case of suspicion, temporarily make package \ctanpkg{microtype} inactive or remove it from your document). If for example \texttt{20} is, in the used font, wider than \texttt{27}, the latter will look shifted a bit to the right compared to the former. Centering the page number in a fixed width box (itself flushed-right to end of line) is one solution, but it may not be to everyone's taste due to single-digit page number; in that case the line style code could make a test on the page number (or its width, if it is not assumed it is purely numerical) and make appropriate decisions. I will leave the matter to your \LaTeX{} coding skills. Using a font with tabular lining figures fixes such problem. \subsection{Compatibility with \ctanpkg{multicol}} \etoc loads the package \ctanpkg{multicol}. \subsection{Compatibility with \ctanpkg{tableof}} It is possible to use simultaneously \etoc and \ctanpkg{tableof}. Release \etocrelease{1.08} of \etoc requires at least version |1.4a| of \ctanpkg{tableof}. If \csb{etocglobaldefs} is put in the preamble, this must be after the loading of package \ctanpkg{tableof}. {\color{niceone}\ctanpkg{tableof}} command \csa{nexttocwithtags} should work as expected. \ctanpkg{tableof} commands \csa{tableof}, \csa{tablenotof}, ... will typeset the (a priori global) table of contents according to the document class defaults, obeying the \etoc depth tags; as explained in the \ctanpkg{tableof} documentation they do not typeset a TOC title. They should \emph{not} be used in case \csb{etocglobaldefs} was issued before, except if its scope has been terminated since then, or \csb{etoclocaldefs} has cancelled its influence. \subsection{Compatibility with \ctanpkg{tocbasic}} \label{ssec:tocbasic} (doc last updated for \etocrelease{1.2}) This has only been tested to the extent of production of this PDF file (which does have dozens of TOCs, among them a few in compatibility mode). I noticed that some things required the global display style to also be set to compatiblity mode for some \ctanpkg{KOMA-script} user interface to produce the desired effect. As an example, the local table of contents of \autoref{sec:testingcompat} uses |\KOMAoptions{toc=left}| and \csb{etocstandardlines} but it had to use also \csb{etocclasstocstyle}: \begin{verbatim} \begingroup % to keep in particular toc=left with local effect \KOMAoptions{toc=left} \etocclasstocstyle % necessary for the display to obey toc=left \etocstandardlines \tableofcontents \ref{toc:tocstyle} \endgroup \end{verbatim} On the other hand I could use some other interface without having to activate the compatibility for the global display style. See \hyperref[toc:d]{the example} from \autoref{sec:labeling} or the one from the \autoref{part:control} which uses \begin{verbatim} \begingroup \etocsettocstyle{}{} \DeclareTOCStyleEntry[numwidth=2em,indent=0pt]{tocline}{section} \DeclareTOCStyleEntry[numwidth=2.5em,indent=2em]{tocline}{subsection} \DeclareTOCStyleEntry[numwidth=3em,indent=4.5em]{tocline}{subsubsection} \etocstandardlines \localtableofcontents \endgroup \end{verbatim} and demonstrates that this interface works also when not using the compatibility mode from \csb{etocclasstocstyle}. Of course, here the display style is a bit plain... but the \hyperref[toc:d]{example} of \autoref{sec:labeling} less so; it uses about the same TOCStyleEntry lines as above with some more width for the numbers of subsections. \subsection{Compatibility with \ctanpkg{tocloft}}\label{subs:tocloft} Steps are taken to prevent the redefinition of |\tableofcontents| done by \ctanpkg{tocloft} at |\begin{document}|. % As long as \etoc is left in compatibility mode the customization done by \ctanpkg{tocloft} will be obeyed, for both the line styles and the TOC title. One may still benefit from the \emph{depth tags} management by \etoc, from its |\localtableofcontents|, from its |\label+\ref| mechanism. One may use |\etocsetstyle| to define via \etoc the layout for one TOC and then use rather \ctanpkg{tocloft} for another one, if |\tableofcontents| follows \csb{etocstandardlines} and \csb{etocclasstocstyle}. In this compatibility mode \csb{etocsetlevel}\marg{division unit}|{|\csb{etocthemaxlevel}|}| will render invisible the chosen division level, but exchanging levels is otherwise not possible. \begin{framed} One should load \etoc \emph{after} \ctanpkg{tocloft}. A warning is issued if otherwise, because if \etoc is loaded before it will realize that at the time of |\begin{document}| and trick \ctanpkg{tocloft} into believing having been loaded with the |titles| option. Some bugs with \etocrelease{1.2} and \etocrelease{1.2a} were fixed at \etocrelease{1.2b}. \end{framed} It is possible to modify midway in the document the macros \csa{l@section}, \csa{l@subsection} ... but the effect will be seen only in table of contents typeset by \etoc in compatibility mode (and of course after those customizations). It will have no effect on true \etoc TOCs. \subsection{Compatibility with \ctanpkg{tocbibind}}\label{subs:tocbibind} Added at \etocrelease{1.2} (but with a bug fixed only at \etocrelease{1.2d}). See also \csb{etocsetup} for a discussion of the package options which are all related to this (they will achieve the \ctanpkg{tocbibind} ``to toc'' features without requiring the package). Thanks to Denis Bitouzé for feature request. \subsection{Compatibility with \ctanpkg{tocvsec2}} \etoc used to be incompatible with package \ctanpkg{tocvsec2}; it now cohabits, sort of, as it deactivates \ctanpkg{tocvsec2}'s modification of |\tableofcontents| and also cancels its other |toc|-related macros, but reimplements partially their functionality with \csb{etocsettocdepth.toc}. By the way, at least two latex runs are necessary for new uses of this command in a document to have an effect in tables of contents. \section{\TeX nical matters} The \csb{etocname}, \csb{etocnumber}, \csb{etocpage} commands are protected against premature expansion. They are hyperlinks if package \ctanpkg{hyperref} is loaded and depending on its option |linktoc| value; under the default |linktoc=section|, only name and number are hyperlinked, not the page number. On the other hand \csb{etocthename}, \csb{etocthenumber}, \csb{etocthepage} are \emph{not} protected against expansion. And neither are \csb{etocthelinkedname}, \csb{etocthelinkednumber}, \csb{etocthelinkedpage}. They were modified at \etocrelease{1.1a} and now are always hyperlinks (except for the latter if the page number is empty), if \ctanpkg{hyperref} is present, independently of |linktoc| status. The commands \csb{etoclink} and \csb{etocifnumbered} are also protected against premature expansion. Also \csb{etociffirst} and \csb{etoctoccontentsline}. Commands such as \csb{etocsetstyle}, \csb{etocsetlevel}, \csb{etocsettocstyle}, \csb{etocmulticolstyle}, \csb{etocruledstyle}, \csb{etocframedstyle} obey \LaTeX{}'s groups. All TOCs are typeset inside groups. When a \localtoc is inserted by the user in the document, a line containing an \etoc inner command and an identification number is added to the |.toc| file on first subsequent compilation. The correct local table of contents will be displayed only on the second compilation. %%% de-\section this for matters of avoiding too cramped mindmap TOC %%%\section{Errors and catastrophes} After using \csb{etocsetstyle} for one level, the remaining uncustomized levels use the \etoc default styles (those which are activated by \csb{etocdefaultlines}). One has to make sure that \textbf{all levels} needed for the next table of contents are mutually compatible: in particular the \etoc default line styles expect each to be started in ``vertical mode''. When using multiple \toc commands in a document, one should beware from adding typesetting instructions directly in the |.toc| file, as they will be executed by \etoc for \textbf{all TOCs}: even for a \localtoc it doesn't matter if that instruction seems to concern material outside of its scope, it will get executed nevertheless. If absolutely necessary to add extra commands to the |.toc| file, make it in such a way that they can be activated or deactivated easily from the document source, e.g.\@ via some booleans. As is usual with toc and labels, after each change, one has to run latex a certain number of times to let the produced document get its final appearance (at least twice).\par \clearpage \etocdepthtag.toc {code} \normalmarginpar\marginparwidth72bp \part{The code} \label{part:code} % return to single spacing \setstretch{1} \etocdefaultlines \etocsettocstyle{}{} \localtableofcontents % IL FAUT METTRE AVANT \section{Timestamps} SINON FOUTU % (non plus maintenant puisque j'utilise \botmark pas \firstmark % dans le \rightmark) % Que c'est pénible cette syntaxe \markboth/\markright de LaTeX ! % Pourquoi est-ce que \markright n'a pas été définie comme #1#2-> truc avec #2 ?? \makeatletter \if@twoside \renewcommand *{\sectionmark }[1]{% \markboth {\unexpanded{\ifodd\value{page}(\hyperref[imp]{implementation}, \hyperlink{FRONTPAGE}{user manual front page})\hfill\fi \hyperref[changelog]{\thesection. Change history}% \ifodd\value{page}\else\hfill(\hyperref[imp]{implementation}, \hyperlink{FRONTPAGE}{user manual front page})\fi}}% {\unexpanded{\ifodd\value{page}(\hyperref[imp]{implementation}, \hyperlink{FRONTPAGE}{user manual front page})\hfill\fi \hyperref[changelog]{\thesection. Change history}% \ifodd\value{page}\else\hfill(\hyperref[imp]{implementation}, \hyperlink{FRONTPAGE}{user manual front page})\fi}}% } \else\error % faudrait cependant que je réfléchisse à quoi faire exactement en oneside % mais comme ceci ne peut arriver que si quelqu'un customise etoc.tex % ce qui n'arrivera JAMAIS, je laisse tomber \renewcommand *{\sectionmark }[1]{% \markright {\unexpanded{\ifodd\value{page}(\hyperref[imp]{implementation}, \hyperlink{FRONTPAGE}{user manual front page})\hfill\fi \hyperref[changelog]{\thesection. Change history}% \ifodd\value{page}\else\hfill(\hyperref[imp]{implementation}, \hyperlink{FRONTPAGE}{user manual front page})\fi}}% } \fi \makeatother \section{Timestamp} This is the documentation as of \texttt{\etocdocdate}, printed from the source file with the time stamp \texttt{\etocdtxtimestamp}. The package version is \texttt{\etocpkgversion}, of \texttt{\etocpkgdate}. \catcode1 13 \begingroup \renewcommand\lowast{{\normalsize\raisebox{-.4\height}{*}}} \small \section{Change history}\label{changelog} \setlength{\columnsep}{\etoccolumnsep} \makeatletter % 27 avril 2014 un petit hack pour hyphénation (éventuelle) en allemand % j'ai déjà ~ qui sera de catcode 0, cependant il faudrait aussi les accolades, % donc finalement pour aller vite, je rends le + actif. Je modifie aussi le test % fait par \jfverbaspace (n'ayant pas commenté mon code, j'ai dû réfléchir pour % me rappeler à peu près ce que c'était censé faire). \def\jfverbatim{\@beginparpenalty \predisplaypenalty \parindent \z@ \parfillskip \@flushglue \parskip \tw@\p@ plus 1fil\relax \let \do \@makeother \dospecials \makestarlowast \catcode`$ \active \begingroup\lccode`~`$ \lowercase{\endgroup\def~[##1]{\foreignlanguage{ngerman}{##1}}}% \catcode`^ \active \begingroup\lccode`~`^ \lowercase{\endgroup\def~{\nopagebreak}}% ajouté 2014/04/28, oblige à un peu % plus de mark-up cependant \catcode`\~\z@ \footnotesize\normalfont\baselineskip10pt\relax % \def\v{\vskip\baselineskip v}% ajouté 2015/05/09; faudra trouver mieux. % 2022/08/30, I remove all "v"'s from version numbers. % 2023/01/25, creating hypertargets \begingroup\lccode`~32 \lowercase{\endgroup \def\1##1~{\vskip\baselineskip\hypertarget{v1##1}{1##1}~}}% % 2022/08/26, stop using \frenchspacing % \frenchspacing % 2023/01/14 \def\2##1.{\ctanpkg{##1}}% % 2022/08/26. I realized that rendering was broken, and finally identified % the bad commit to be in LaTeX 2022/06/01 release. Its \obeyspaces not only % makes the ascii32 \active but it also redefines it! Solution could be to % actually use \obeyedspace in the definition of active space about 20 lines % below but this would tie to LaTeX 2022/06/01 or later for building etoc.pdf \catcode`\ \active % was \obeyspaces \jf@xverbatim } \begingroup \catcode `|=0 \catcode `[= 1 \catcode`]=2 \catcode `\{=12 \catcode `\}=12 \catcode`\\=12 |long|gdef|jf@xverbatim#1\end{jfverbatim}[#1|end[jfverbatim]] |endgroup \def\endjfverbatim{} \newdimen\jfverbadim \makeatother \begin{multicols}{2} % un \raggedcolumns ne fonctionne pas vraiment pour faire de l'alignement % de grid à cause du \parskip \makeatletter \everypar{\leftskip\jfverbadim\bgroup \def\par{\egroup\jfverbadim\z@\@@par}% \def\jfverbaspace#1{\if\@sptoken\string#1\unskip\else\ \fi#1}} % % see 2022/08/26 above note \begingroup\obeyspaces\def\x{\endgroup% \def {\ifvmode\advance\jfverbadim.5em\relax\else\expandafter\jfverbaspace\fi}}\x \makeatother \vskip-\baselineskip \begin{jfverbatim} ~1.2d [2023/10/29]^ Fix crash (present since 1.2) if used with \usepackage[nottoc]{tocbibind} (the faulty code was avoided if also tocloft was used by document). Thanks to François Jonca for report. ~1.2c [2023/10/28]^ Compatibility hotfix with hyperref v7.01c; etoc had copied over a now unneeded internal hyperref test, and since v7.01c the result was that etoc produced empty tables of contents. Thanks to Denis Bitouzé for report. ~1.2b [2023/07/01]^ bugfix: a refactoring at 1.2 accidentally removed a needed \AtBeginDocument and as a result the tocloft redefinition of \tableofcontents was not undone, if etoc got loaded after tocloft, as is advised by the documentation. Thanks to user691586 for report. Add section documenting compatibility aspects with usage of package microtype. Add \etocnoprotrusion an alias to LaTeX 2018/12/01 \noprotrusion and use it after \etocpage inside the package built-in fallback section and subsection toc line styles. Fix some of the documentation (in particular the sections "A first example" and "A second example") as some of its highly pedagogical comments had lost sync with other changes. Don't hesitate getting in touch with the author to obtain further improvements. ~1.2a [2023/05/01]^ The requirements (added respectively at 1.1a and 1.2) of a LaTeX kernel at least as recent as 2020-10-01 and of availability of \expanded engine primitive have been lifted. Due to lack of time and ressources, etoc is not retro-tested on old LaTeX installations, though. Boolean option `deeplevels' extends the maximal allowed numerical level from 6 to 12. Adapted from a patch courtesy of Matthew Trescott. See https://github.com/doxygen/doxygen/pull/9936 for context. Using this option does not change anything to tocdepth and secnumdepth LaTeX counters, nor does it do any of the needed extras to let a sectioning level be known to LaTeX (if etoc is used in "compatibility mode", the suitable \l@ macros must have been declared to LaTeX for TOC rendering). Whether or not using etoc in compatibility mode (i.e. whether or not using \etocsetstyle{}{...}{...}{...}{...}), recall that all new levels must be declared to etoc at least once via \etocsetlevel{}{}. The macro \etocthemaxlevel expands accordingly to either 6 (default) or 12 (if option `deeplevels'). So \etocsetlevel{foo}{\etocthemaxlevel} should now be used in place of \etocsetlevel{foo}{6} when one wants to make foo entries invisible in a document context which may have used, or not, the `deeplevels' option. The auto-selection-of-heading-by-local-tocs from 1.2 uses a macro \etocdivisionnameatlevel which will need most probably user adaptation with `deeplevels', as etoc can not know what are the standard names chosen by user, and how many deep levels were actually added. So it opted to the choices done by the Doxygen project. Check the etoc source code for this macro and redefine it appropriately. Note though that this only matters if your documents has local TOCs located under division units at least as deep as subsubsection. Fix a 1.2 bug: using `six' as first argument of `\etocsetlevel' caused an internal control sequence to be redefined, with various strange potential aftereffects. ~1.2 [2023/03/01]^ \locallistoffigures and \locallistoftables. MAKE SURE TO READ THE FRAMED TEXT IN THE DOCUMENTATION AT START OF SECTION 2 WHICH DESCRIBES THESE NEW COMMANDS. It is for time being required to pass options `lof', resp. `lot' at package loading time to activate these features. Whether or not these features are enabled, etoc interferes in absolutely no way with \listoffigures and \listoftables and their respective auxiliary files. Boolean options (and utility \etocsetup) `maintoctotoc', `localtoctotoc', `localloftotoc', `locallottotoc', and `ouroboros'. For above reasons, no `mainloftotoc' or `mainlottotoc'. With `ouroboros=false` local TOCs whose heading has been added to the `.toc' file due to `localtoctotoc` will show deeper ones and the local `lists of' from their own level, but not themselves. Compatibility layer with `tocbibind'. Thanks to Denis Bitouzé for feature request many years ago. Sorry for the delay! New feature (and breaking change): local tables of contents in the default package configuration auto-adapt their titles to use the appropriate unnumbered division heading (for example a \subsection* if inside a \section). Formerly, it was intended one would use \etocsettocstyle (or higher level commands), else local TOCs were rendered using the same emulation of the document class as for the main TOC. One can still require this document class emulation but then etoc tries at least to adapt to the division unit one level below \part (i.e. \chapter or \section). E.g., for KOMA-script the option `leveldown' is used. But this is not appropriate for deeper levels in general. Ultimate control of toc titling can still be achieved via \etocsettocstyle. Many commands have been added to ease its usage. It is also possible to customize the default behavior without \etocsettocstyle. Details of the user interface and produced output from these novel commands and options are susceptible to change. Use at own risk. Bugfix: the emptiness check could fail for \localtableofcontentswithrelativedepth as it ignored tocdepth changes originating from inside the .toc file, contrarily to the actual typesetting (and behavior with other local tocs) Bugfix: the \tableofcontents\ref{foo} syntax caused a ``Missing number'' after \vpageref{foo} from package varioref in certain circumstances due to \r@foo having then acquired a value with an unexpected non-numerical first chunk. Breaking change: the \etocsavedsectiontocline et al. macros which raised a deprecation warning since 1.1a now use an error message. \expanded primitive is required. [reverted at 1.2a] ~1.1d (not released, part of 1.2)^ Complete internal refactoring of the legacy core code behind the concept of ``start'' and ``finish'' parts for line styles. \etocifunknownlevelTF and \etoclevel abstract away some internals and may be useful for class or package authors. \etocsetlevel filters out forbidden keywords `all', `none' and others. Its second argument can be an expression. \etocsetstyle checks and warns appropriately if the level is unknown to etoc or has a non-accepted numerical value. Extensive refactoring of the documentation. ~1.1c [2023/01/20]^ Fix a brace removal bug in the construction of \etocname. It remained without visible effects in documents using hyperref and default settings, thanks to the hyperlink wrapper, but e.g. \section{{\color{blue}Blue}} in a document not using hyperref, and not using etoc only in "compatibility mode", could cause a color leak in the table of contents. With the KOMA-script numberline toc feature, unnumbered entries in TOCs typeset via etoc user-defined or package provided line styles but using compatibility mode for the global display style were (knowingly) considered to be numbered with an empty number. They are now considered by \etocifnumbered to be not numbered and the empty \etocnumber will carry no hyperlink. Fix a 1.1a regression in the context of KOMA-script unnumbered TOC entries: \etocthelinkedname could lose its hyperlink. Continue internal trimming of old code branches which became un-needed after the 1.1a refactoring. Add relatively decent code comments to accompany the 1.1a-c refactoring. Update warning messages to use more consistently LaTeX's templates. ~1.1b [2023/01/15]^ Documentation fix, 1.1a forgot to mention the following change: \etocthelinkedname, \etocthelinkednumber, \etocthelinkedpage are now always hyperlinks independently of linktoc status. ~1.1a [2023/01/14]^ This version brings no new functionality, despite the number bump. It implements a complete rewrite of old legacy core internals. Formerly, etoc waited for ~2hyperref. (if present) to have added hyperlinks via its patch to LaTeX's \contentsline. etoc examined the arguments of \l@section and other commands to extract hyperlinking information, if any. With this release etoc decides earlier according to ~2hyperref. linktoc status whether section names and page numbers should be hyperlinked, and adds links itself via \hyperlink. etoc is thus now immune to the details of how ~2hyperref. patches the \contentsline command, which is not executed anymore. Overall, the code is greatly simplified. \etoclink now wraps its argument in an hyperlink even if ~2hyperref. is configured via linktoc=none. Formerly no hyperlink was added then. Deprecation of \etocsavedsectiontocline and similarly named commands. They are not needed as \l@section et al. are with this release left unmodified during the table of contents typesetting. ~LaTeX kernel from 2020-10-01 or later is required (to allow assuming the \contentsline entries in the TOC file always have four arguments). [reverted at 1.2a] ~1.09i [2022/11/21]^ Fix bug showing when a document uses both \etocchecksemptiness and \etocsetlocaltop.toc: the start and finish parts of some levels were executed possibly causing extra printed output. More hyperlinking in the implementation part of the documentation. ~1.09h [2022/11/20]^ Documentation improvements. In particular, attached code snippets are now visible via their filenames in the page margins. Also, command names are doubly hyperlinked: first half links to the devoted part of the user manual, second half links to the implementation part. ~1.09g [2022/11/17]^ Compatibility hotfix with recent hyperref 7.00u of 2022-11-13. Thanks to Denis Bitouzé for signaling the breakage to the author. ~1.09f [2022/08/30]^ No more shipping of a German translation of the documentation, as it was last updated in April 2015. (etoc.pdf) User level commands hyperlink from their code source definitions to their descriptions in the documentation part. Macros used in the code source hyperlink to where they first got defined there. Wrap the \etocpartname (from etoc's package provided toc line style) together with the part number in a potential common hyperlink. Try to sync the emulation of the global display style with KOMA-script v3.37 (in particular regarding the noparskipfake KOMA toc feature). Improve documentation of some aspects under memoir class. Remove the \nonumberline token, even though empty, from the meaning of \etocthename (KOMA-script classes). Add \etocimmediatedepthtag.toc to work around problems related to \include (see user doc). Thanks to Norman Ramsey who reported the problem and proposed a work-around in July 2016. Apologies for the somewhat longish delay in incorporating it... Also add \etocimmediatesettocdepth.toc. Also add \etocimmediatetoccontentsline and its starred variant. Also add \etocimmediatesetlocaltop.toc. Fix an obscure bug (see source code comments) in the \etocsetlocaltop.toc mechanism. ~1.09e [2021/09/23]^ Needed (if etoc is used without hyperref) updates to internal macros to prepare for the upcoming LaTeX November 2021 change to \contentsline. Related updates to the user macro \etoctoccontentsline. ~1.09d [2021/07/13]^ Some minor synching with tableof 1.4c. Add \etockeeporiginaltableofcontents to provide a work-around to a compatibility issue with listings's \lstlistoflistings, which abuses \tableofcontents for doing something unrelated to the actual contents. Thanks to Denis Bitouzé for report. Usage: \usepackage{etoc}\etockeeporiginal-tableofcontents, then however you must employ \etoctableofcontents, not \tableofcontents. ~1.09c [2020/05/15]^ Syncs with KOMA-script deprecation of \iftocfeature. ~1.09b [2019/11/17]^~par~nobreak~vskip-~parskip~vskip-~baselineskip ~1.09a ^ Sync with memoir v3.7i which has a better location of the TOC hyperref anchor. The \etocaftertitlehook can now freely be used also with memoir class (formerly its usage in case of memoir class was preempted by etoc itself). For more details refer to the section "Compatibility with the memoir class". ~1.09 [2019/03/09]^ New features: \etoclocaltop, \localtableofcontentswithrelativedepth. Thanks to Tony Roberts for feature request. Note to hackers: internal control sequence \Etoc@localtop is gone. etoc now requires e-TeX (\numexpr, \unless). ~1.08p [2018/07/04]^ Fixed bug surfacing in case of linktoc=page option of hyperref. Thanks to Denis Bitouzé for report. Cf:~\ https://github.com/ho-tex/hyperref/issues/65~\ https://github.com/dbitouze/yathesis/issues/61 ~1.08o [2018/06/15]^ Fixed bug showing up if an unnumbered TOC entry starts with a brace, and document uses hyperref. Caused by a typo in a macro name at previous release. ~1.08n [2018/02/23]^ Refactoring of core macros detecting \numberline and its variants. ~1.08m [2018/02/07]^ Fix to 1.08k's introduced incompatibility with KOMA-script and tocbasic's \nonumberline. ~1.08l [2017/10/23]^ Workaround an issue with Emacs/AUCTeX wrongly reporting about actually non-existent LaTeX errors, which was triggered by some strings written (indirectly) to log file by etoc under some circumstances. ~1.08k [2017/09/28]^ Adds \etocsetlocaltop.toc. See corresponding manual section for details. Adds \etocsavedparttocline, \etocsavedchaptertocline, \etocsavedsectiontocline, ... They can be used in the context of the technique explained in section "Another compatibility mode". Formerly, etoc redefined for the duration of the TOC the memoir macro \chapternumberline and its likes to have same meaning as \numberline (of course, not when executed in compatibility mode), for the sake of extraction of \etocnumber. New method detects presence of any \numberline macro without any change to originals; they can thus be used as is when applying the approach of "Another compatibility mode" section from manual. ~1.08j [2017/09/21]^ Since 1.08a-2015/03/13 \etocname, \etocnumber, \etocpage contain, if hyperref is present and configured for using hyperlinks in the TOC, the link destination in already expanded form. This means one can use them even if the style closes a group (for example from a & in a tabular), if \etocglobaldefs was issued; also one can save their meaning for delayed usage (with for example \LetLtxMacro as they are robust). But for some legacy reason \etoclink, contrarily to \etocthelink, was handled differently. Now, \etoclink also contains the link destination in already expanded form, and can thus be used even if the line style issues a &, as long as \etocglobaldefs is issued. Also, bugs dating back to the early days of the package, but surfacing only under relatively rare conditions such as usage of hyperref with its option "linktoc=page" got fixed. ~1.08i [2016/09/29]^ This fixes an issue dating back to 1.08e-2015/04/17: under \etocchecksemptiness regime, some circumstances (such as adding to an already compiled document a \localtableofcontents before the main \tableofcontents) created an "Undefined control sequence \Etoc@localtop" error. Thanks to Denis Bitouzé for reporting the problem. On this occasion, \etocdoesnotcheckemptiness has been added to unset the flag. A rather more exotic issue was fixed: the emptiness check for local tocs could get confused if the tocdepth counter was varying in some specific ways from inside the toc file. After adding to a document a \localtableofcontents, two LaTeX passes are needed for etoc to get a chance to print the correct local contents. Formerly, etoc issued a Warning on the first pass; it now also induces LaTeX into announcing "There were undefined references", as this is nearer to the end of the log file and console output. ~1.08h [2016/09/25]^ New functioning of \etocsetnexttocdepth: the tocdepth counter is modified only at the time of the table of contents, not before. This fixes an issue which arose when \etocsetnexttocdepth was used multiple times with no intervening table of contents. Thanks to Denis Bitouzé for reporting the problem. The PDF documentation includes about 25 LaTeX code snippets also as file attachment annotations, additionally to their verbatim typesetting. The ordering of the documentation contents has been slightly re-organized. A previous documentation-only update on 2016/09/09 added a new section with the (approximate) translation into etoc lingua of the book class toc style, for easy customizability. ~1.08g [2015/08/29]^ Downgraded to a mere info message the etoc-issued warning (relative to \settocdepth/\maxtocdepth) under class memoir. ~1.08f [2015/04/28]^ Minor changes to the documentation. \etocsetlevel more economical. ~1.08e [2015/04/17]^ The command \etocchecksemptiness tells etoc to not print, from that point on, the headings of the local tables of contents if they have empty contents. This is mainly for class authors who might want to have their \section or \chapter automatically do a \localtableofcontents. Could prove also useful for batch conversions of documents. Thanks to Paul Gaborit who asked for such a feature. The command \etocnotocifnotoc extends this behaviour to global TOCs: indeed why should documents with no sectioning units take this as an excuse not to use package etoc ? The command \etocifwasempty{yes}{no} can be used for suitable extra action. A \tableofcontents\ref{foo} now expects foo to be a label to a _local_ TOC. The use with foo a label to a _global_ TOC is not supported anymore as it had no utility and made the code more complex. The syntax \localtableofcontents\ref{foo} is now accepted as a synonym to the earlier syntax \tableofcontents\ref{foo}. ~1.08d [2015/04/09]^ Translation into German of the additions made to the documentation for the 1.08x series of releases. Thanks to Christine Römer! ~1.08c [2015/03/30]^ - removed a few unneeded \long from the code. - removed use of \arabic at one location of the code, as it may get redefined by some language modules for babel or polyglossia. ~1.08b [2015/03/18]^ Bug fixes: - extra space token removed from `\localtableofcontents` (showed only for inline TOCs.) - \etocpartname (a macro used by the package own default line styles) was defined to be \partname, but this is not compatible at least with babel+french context. Now simply expands to Part. - some problems fixed in the German documentation. - [2015/03/28] some more problems fixed in the documentation. Added mention of \etocarticlestyle and \etocbookstyle. ~1.08a [2015/03/13]^ \etocname, \etocnumber and \etocpage are now the robust variants of \etocthelinkedname, \etocthelinkednumber and \etocthelinkedpage. This should arguably have been done since the addition of the latter to etoc with 1.07f [2013/03/07]. The earlier robust commands \etocname etc... contained the hyperlink destination only in an unexpanded form. The documentation has a brand new title page and a new section The TOC as a TikZ mind map both illustrating further uses of etoc to display tables of contents as trees in an automatic manner. ~1.08 [2015/03/10]^ \etocskipfirstprefix may now appear anywhere in the part of a level style. New commands \etociffirst, \etocxiffirst, \etocxifnumbered, \etocglobaldefs and \etoclocaldefs. It is now possible to issue line style specifications directly with & and \\ tokens, in order to typeset a TOC as a tabular or longtable with the opening for example in the first argument of \etocsettocstyle and the closing in its second argument. It is mandatory for such uses to issue \etocglobaldefs which tells etoc to proceed globally for certain definitions. This is also useful in the context of the inline environments of package enumitem. On this occasion, various old parts of the code have been improved. ~1.07n [2015/03/05]^ No more use of \toks@ when etoc constructs \etocthelinkedname etc... Thus \toks@ can be put in the line styles in order to accumulate information. Only useful if it is certain nothing else will change \toks@ either. In the documentation: list of main commands now in alphabetic order. ~1.07m [2015/01/23]^ Reading of .toc file is delayed to \begin{document} to account for possible Babel active characters used therein. Thanks to Denis Bitouzé who reported a Babel related problem. Improved global toc display emulation under KOMA-script classes. New command \etocbeforetitlehook. New command \etocdisplay. ~1.07l [doc of 2014/04/29]^ Added to the documentation an example of use of \etocthelinkedname together with an enumitem inline itemize* environment; moved main TOC to immediately after the title, and license to the first pages. Incorporation of the translation into German done on the initiative of $[Christine Römer] by $[Felix Baral-Weber, Jenny Rothkrämer-Vogt, Daniel Büttner, Claudia Dahl, Christian Otto and Christine Römer (FSU Jena).] My grateful thanks to all! ~vskip~baselineskip1.07l [2014/04/22]^ Fixes a bug with the 1.07k compatibility layer with tocloft which had broken the 1.07k (sic) compatibility with memoir (yes, memoir class 1.07k testing had been done before adding the tocloft thing to the source code . . . ). Also, etoc when detecting tocvsec2 now checks if this is under the memoir class, as then nothing special needs to be done to rescue \tableofcontents, contrarily to the situation with the native tocvsec2. ~1.07k [2014/03/06]^ Compatibility with package tocloft; and improved compatibility with class memoir. Novel TOC example in Overview. ~1.07j [2013/12/03]^ Some issues with the documentation formatting (now two-sided) have been addressed, and a novel documentation section ``Typesetting the TOC as a table'' has been added. Very minor code change (\Etoc@readtoc). ~1.07i [2013/10/21]^ Changes to the \etocmulticolstyle and \etocruledstyle codes to lessen the risk of a page break after the title (in the one-column case). ~1.07h [2013/10/16]^ New commands \etocdepthtag.toc, \etocsettagdepth, \etocobeydepthtags, \etocignoredepthtags. ~1.07g [2013/10/13]^ New commands \etocsettocdepth, \etocsettocdepth.toc, \etocobeytoctocdepth, \etoc~-ignoretoctocdepth which emulate part of tocvsec2 functionality ; measures to make tocvsec2 partially compatible with etoc. New commands \etocsetnexttocdepth, \invisibletableofcontents, \invisiblelocaltableofcontents. Switched from tikz-qtree to forest for the first `toc as tree' example. Command names are linked to their descriptions, and many other changes in the documentation. Removed printing of temporary message when the local toc id is not yet stabilized; indeed \localtableofcontents can have many uses, such as filling up some token list register and one may wish to not have anything typeset, even in an intermediate run. All of tex etoc.dtx, etex etoc.dtx, xetex etoc.dtx, latex etoc.dtx, pdflatex etoc.dtx are now possible, and the extracted file etoc.tex allows easy customization of compilation options for the documentation (default is via dvipdfmx which produces the smallest file). ~1.07f [2013/03/07]^ New macros \etocthelinkedname, \etocthelinkednumber, \etocthelinkedpage, and \etocthelink. ~1.07e [2013/03/01]^ Improvements in the package own line styles with regards to penalties and vertical spaces. Addition to the documentation of an example of a tree-like table of contents (uses tikz). More such examples added 2013/03/03. ~1.07d [2013/02/24]^ Minor code improvements and new documentation section ``Another compatibility mode''. ~1.07b [2013/02/02]^ Removal of the \xspace from the macros \etocname, \etocnumber, \etocpage. Additional examples in the documentation. ~1.07 [2013/01/29]^ New commands: \etocthename, \etocthenumber, \etocthe~-page, \etoclink, \etoctoccontentsline, \etoctoccontentsline~lowast \etocnopar, \etocaftercontentshook Modified command: \etocmulticolstyle New documentation section ``Surprising uses of etoc'' which explains how to do ``Lists of arbitrary things'', in addition to the tables of contents. ~1.06 [2012/12/07]^ The standard macros \l@section etc... are modified only during the calls to \tableofcontents; they can thus be customized as will by the user (with the help of a package like tocloft) and this will be taken into account by etoc for the TOCs typeset in compatibility mode. ~1.05 [2012/12/01]^ \localtableofcontents replaces \tableofcontents~lowast (for compatibility with the memoir class). Compatibility with KOMA-script and memoir document classes. ~1.04 [2012/11/24]^ A (possibly local) table of contents can be labeled: \tableofcontents \label{toc:1} and reproduced elsewhere in the document (with a possibly completely different layout): \tableofcontents \ref{toc:1} ~1.02 [2012/11/18]^ Initial version. \end{jfverbatim} \end{multicols} \endgroup % group for modified verbatim printing of the changes log \makeatletter \let\check@percent\original@check@percent \makeatother \small % Que c'est pénible cette syntaxe \markboth/\markright de LaTeX ! % Pourquoi est-ce que \markright n'a pas été définie comme #1#2-> truc avec #2 ?? \makeatletter \if@twoside \renewcommand *{\sectionmark }[1]{% \markboth {\unexpanded{{% % counteract some changes done by my macrocode hooks % so we must make sure it is in a scope limiting context % (perhaps it is already, will not check, wasted already % too much time on this header matter) November 2022 \hypersetup{linkcolor=RoyalBlue}% \ifodd\value{page}(\hyperref[changelog]{change log}, \hyperlink{FRONTPAGE}{user manual front page})\hfill\fi \hyperref[imp]{\thesection. Implementation}% \ifodd\value{page}\else\hfill(\hyperref[changelog]{change log}, \hyperlink{FRONTPAGE}{user manual front page})\fi }}% } {\unexpanded{{% \hypersetup{linkcolor=RoyalBlue}% \ifodd\value{page}(\hyperref[changelog]{change log}, \hyperlink{FRONTPAGE}{user manual front page})\hfill\fi \hyperref[imp]{\thesection. Implementation}% \ifodd\value{page}\else\hfill(\hyperref[changelog]{change log}, \hyperlink{FRONTPAGE}{user manual front page})\fi }}% }% } \else % faudrait cependant que je réfléchisse à quoi faire exactement en oneside % mais comme ceci ne peut arriver que si quelqu'un customise etoc.tex % ce qui n'arrivera JAMAIS, je laisse tomber \renewcommand *{\sectionmark }[1]{% \markright {\unexpanded{{% \hypersetup{linkcolor=RoyalBlue}% \ifodd\value{page}(\hyperref[changelog]{change log}, \hyperlink{FRONTPAGE}{user manual front page})\hfill\fi \hyperref[imp]{\thesection. Implementation}% \ifodd\value{page}\else\hfill(\hyperref[changelog]{change log}, \hyperlink{FRONTPAGE}{user manual front page})\fi }}% }% } \fi \makeatother \section{Implementation}\label{imp} % ce \noindent est obsolète 2022/08/26 à cause des hooks à macrocode plus bas % transférés depuis xint.dtx. Il est doublement obsolète car je rajoute un % paragraphe de texte de toute façon avant le premier macrocode. % \indent % !!!!!!!!!!!!!!!!! Lundi 09 mars 2015 à 09:32:22 % il faut faire un paragraphe après \section sinon pas d'espacement % vertical en sortie de blocs macrocode. Pas évident à trouver, vu que % je customisais différentes choses qui pouvaient affecter macrocode. % 9 mars 2015 % Pour rappel on avait dans le préambule: % \def\MacroFont{\ttfamily\small\hyphenchar\font45 \baselineskip11pt\relax} % 28 février 2023 % Mis à jour % \def\MacroFont{\ttfamily\hyphenchar\font45\relax\setstretch{1}} % ce qui donne donc le \macro@font qui sera utilisé. % J'ai déjà fait \setstretch{1} au déput de la partie The code, donc % je peux le supprimer ici \def\macro@font{\ttfamily\hyphenchar\font45\relax} % 26 septembre 2021 \catcode1 14 % pour pouvoir utiliser ^^A, car je l'avais mis à \active \StopEventually{\normalsize \ifnum\NoSourceCode=1 \texttt{\parindent 0pt\rightskip 1cm minus 1cm This documentation has been compiled without inclusion of the source code. To produce the documentation with source code included:\endgraf \ \ \ \ run etex on etoc.dtx to produce etoc.tex,\endgraf \ \ \ \ then thrice pdflatex on etoc.tex.\endgraf }% \fi \end{document}} %%%%%%%%%%%% % 26 août 2022, transfert depuis xint de hack de doc % % This worked remarkably well with almost no changes! Particularly for % hyperlinking to the documentation part from the macro definitions! But % also for internall cross-links in implementation part despite no usage % there of any sectioning mark-up (so I don't need the \@sect hack, and % related \csa, \csan, \csh, \cshn, \cshintitle, \cshnintitle macros). % I noticed in passing that I never used any \begin{macro} mark-up here % in the etoc.dtx. Perhaps I should and should one day look at what doc=V3 % brings... % % See xint.dtx for comments, as I have removed most when copying. \makeatletter \def\odef #1{\expandafter\def\expandafter#1\expandafter}% needed from xintkernel %%% xint.dtx does \def\macro@font {\ttfamily }% (with a font allowing hyphenation) %%% Our \macro@font has been defined earlier from \MacroFont in preamble and %%% is \ttfamily\small\hyphenchar\font45 \baselineskip11pt\relax %%% etoc.dtx: see further below for how the * is handled in \macro@finish \renewcommand\lowast{{\iflabelmacro@allowed\xintdocMacrocodeFallbackColorCmd\fi \raisebox{-.25\height}{*}}} \AddToHook{env/macrocode/begin}{\makestarlowast} % https://github.com/latex3/latex2e/issues/563 % (but I don't use sectioning commands in implementation part of etoc.dtx so far) \AddToHook{env/macrocode/after}{\@nobreakfalse} \AddToHook{env/macrocode/begin}{\partopsep0pt\relax} \begingroup \catcode`\|=\z@ \catcode`\[=\@ne \catcode`\]=\tw@ \catcode`\{=12 \catcode`\}=12 % Let % be active to use a color for it and gray-out % comments left in code (there are few) \catcode`\%=13 \catcode`\ =\active \catcode`\\=\active |gdef|xmacro@code#1% \end{macrocode}[#1|end[macrocode]] |endgroup %%% 2022/08/27: for etoc.dtx try to really use comment color in comments %%% this is not a complete solution, but enough for use case \begingroup\catcode`\%=\active\catcode`\^^M 13 \gdef%{\begingroup\color{macrocodecommentcolor}^^A \let\xintdocMacrocodeFallbackColorCmd\@empty^^A \@percentchar\odef {\expandafter\endgroup }}\endgroup \begingroup\let\newcount\@gobble\@definecounter{CodelineNo}\endgroup \def\theCodelineNo{\reset@font\scriptsize\arabic{CodelineNo}} \def\theHCodelineNo{\the\value{section}.\the\value{CodelineNo}} %%% not needed for etoc.dtx %%%%%%% attention j'utilise plus bas \MakePrivateLetters pour %%%%%%% problème de straight quotes depuis 2023/01/18 (1.1c) %%% \def\xintMakePrivateLetters{\catcode`: 11 \catcode`? 11 \catcode`@ 11 %%% \catcode`^ 11 \catcode`_ 11 } %%% \def\xintexprMakePrivateLetters{\xintMakePrivateLetters \catcode`! 11 } %%% \let\MakePrivateLetters\xintMakePrivateLetters % \definecolor{etocnamecolor}{RGB}{228,57,0} % \colorlet{verbcolor}{Maroon} % % \colorlet{privatecommentcolor}{cyan} % \colorlet{macrocodecommentcolor}{gray} % \colorlet{macrocodenewmacrocolor}{verbcolor} % \colorlet{macrocodelinktouserdoccolor}{etocnamecolor}% and bold face % \colorlet{macrocodelinktosectioncolor}{DarkBlue}% and bold face % \colorlet{macrocodelinktocodelinecolor}{DarkBlue} % \colorlet{macrocodenoncscolor}{Green} \def\xintdocMacrocodeFallbackColorCmd{\normalcolor} \odef\init@crossref{\init@crossref% \everypar{\refstepcounter{CodelineNo}% \llap{{\xintdocMacrocodeFallbackColorCmd\theCodelineNo}\ \hskip\@totalleftmargin}% }% \catcode`\%\active }% \def\scan@macro{% % we do not insert it yet % \special@escape@char \step@checksum % \ifscan@allowed \let\macro@namepart\@empty % we need this for reasons explained below \let\macro@spacepart\@empty \def\next{\futurelet\next\macro@switch}% % \else \let\next\@empty \fi \next } % unchanged: % \def\macro@switch{\ifcat\noexpand\next a% % \let\next\macro@name % \else \let\next\short@macro \fi % \next} \def\short@macro#1{\special@escape@char#1} % \def\macro@name#1{\edef\macro@namepart{\macro@namepart#1}% % \futurelet\next\more@macroname} % \def\more@macroname{\ifcat\noexpand\next a% % \let\next\macro@name % \else \let\next\macro@finish \fi % \next} \def\more@macroname{\ifcat\noexpand\next a% \expandafter\macro@name % we keep the \next for usage later and start filtering out of the way spaces % this is caused by necessity of handling things such as \let\foo\bar % but also not be fooled by \let#6\macro \else \expandafter\macro@gatherspaces \fi } \def\macro@gatherspaces{% \ifx\next\@xobeysp \expandafter\macro@gatherspaces@i \else \expandafter\macro@finish \fi}% \def\macro@gatherspaces@i#1{% \odef\macro@spacepart{\macro@spacepart#1}% #1 = active space \futurelet\next\macro@gatherspaces}% \newif\iflabelmacro@allowed \newcounter{xintMacroCnt} %%% pour l'instant pas relevant pour etoc, pas de mark-up par \subsection etc... \def\xintimplabelprefix{src-} \let\xintdoclabelprefix\empty %%% next thing is used in xint.dtx in a hack of \@sect but we don't have so %%% far sectioning mark-up in etoc.dtx implementation part %%% \let\xintlabelprefix\xintimplabelprefix \catcode`_ 11 \catcode`* 11 \def\macro@finish{% \iflabelmacro@allowed \expandafter\in@\expandafter{\expandafter.\macro@namepart,}% {.csname,.expandafter,.noexpand,.else,% %.t,.w,.x,.y,.z,.XINT_x,.XINT_y,% %.XINT_tmpa,.XINT_tmpb,.XINT_tmpc,.XINT_tmpd,.XINT_tmpe,% _ is letter here %.XINT_expr_defbin_b,.XINT_expr_defbin_c,.XINT_expr_defbin_d,% .empty,.space,.protect,}% \ifin@ {\xintdocMacrocodeFallbackColorCmd\special@escape@char\macro@namepart}% \else \ifcsname alreadydefined-\macro@namepart\endcsname \hyperref[etocmacro-\macro@namepart]{\special@escape@char\macro@namepart}% \else % this will make a rather large number of macro names in the string pool... \global\expandafter\let\csname alreadydefined-\macro@namepart\endcsname\@empty \label{etocmacro-\macro@namepart}% \stepcounter{xintMacroCnt}% % try to link to a labeled reference in the user documentation (xint-all.pdf) \ifcsname r@\xintdoclabelprefix\macro@namepart\endcsname {\hypersetup{linkcolor=macrocodelinktouserdoccolor}% \hyperref[\xintdoclabelprefix\macro@namepart]% {\textbf{\special@escape@char\macro@namepart}}}% \else % try to link to a labeled section in implementation part %% THIS BRANCH WILL NEVER BE USED IN etoc.dtx FROM ABSENCE OF %% ASSOCIATED MARK-UP \ifcsname r@\xintimplabelprefix\macro@namepart\endcsname {\hypersetup{linkcolor=macrocodelinktosectioncolor}% \hyperref[\xintimplabelprefix\macro@namepart]% {\textbf{\special@escape@char\macro@namepart}}}% \else \textcolor{macrocodenewmacrocolor}{\textbf{\special@escape@char\macro@namepart}}% \fi\fi \fi \fi \labelmacro@allowedfalse \expandafter\in@\expandafter{\expandafter.\macro@namepart,}{.expandafter,}% \ifin@ \ifx\next\scan@macro\labelmacro@allowedtrue\fi \fi \else % end of labelmacro@allowedtrue branch %%% etoc.dtx adds complications to handle \newcommand* \if0\ifx\next\scan@macro0\else\ifx\next\lowast0\else1\fi\fi \expandafter\in@\expandafter{\expandafter.\macro@namepart,}% {.def,.edef,.let,.gdef,.xdef,%.odef,.oodef,.fdef, .chardef,.newif,.newtoks,.newcommand,.DeclareRobustCommand,% .newread,.newwrite,}% \ifin@\labelmacro@allowedtrue\fi \fi \ifcsname r@etocmacro-\macro@namepart\endcsname \hyperref[etocmacro-\macro@namepart]{\special@escape@char\macro@namepart}% \else {\xintdocMacrocodeFallbackColorCmd\special@escape@char\macro@namepart}% \fi \fi % \ifnot@excluded % \edef\@tempa{\noexpand\SpecialIndex{\bslash\macro@namepart}}% % \@tempa % \fi \macro@spacepart }% \catcode`_ 8 \catcode`* 11 %%% In order mainly to colorize #1, #2, etc... we do this rather %%% non-economical thing of colorizing all of macrocode with %%% the "non control sequence color", hence this means all %%% control sequences will have their own color command... %%% This is because when doing this in June 2022 for xint, I did %%% not want to hack more doc.sty scanning process of tokens, %%% but perhaps I should, it would be more economical. Kept as is %%% when transferring to etoc.dtx 2022/08/26 {\sbox0{\color{macrocodenoncscolor}\xdef\foo{\current@color}}} \ifpdf \edef\xintdoc@macrocode@pushcolor {\pdfcolorstack\noexpand\@pdfcolorstack push{\foo}\relax} \def\xintdoc@macrocode@popcolor{\pdfcolorstack\@pdfcolorstack pop\relax} \else \ifxetex \edef\xintdoc@macrocode@pushcolor{\special{color push \foo}} \def\xintdoc@macrocode@popcolor{\special{color pop}} \else \ifnum\Withdvipdfmx=1 \edef\xintdoc@macrocode@pushcolor{\special{color push \foo}} \def\xintdoc@macrocode@popcolor{\special{color pop}} \fi\fi\fi %%% 2022/08/26 \par added for etoc.dtx \AddToHook{env/macrocode/before}{\xintdoc@macrocode@pushcolor\par} \AddToHook{env/macrocode/end}{\xintdoc@macrocode@popcolor} % let's use some more quiet color for links inside the code \AddToHook{env/macrocode/begin}{\hypersetup{linkcolor=macrocodelinktocodelinecolor}} % let code line numbers really be fully in the margin \MacroIndent\z@ % 2023/02/22, 1.2 uses setspace % 2023/02/27, I return to single line spacing finally %\AddToHook{env/macrocode/before}{\vskip.5\baselineskip} \makeatother % 18 janvier 2023 fix d'un problème de guillements courbes et d'inutilité de upquote, % import de mon code de lgrmath de novembre 2022 % useless with doc.sty as \verb, verbatim and macrocode do not use \@noligs % \usepackage{upquote} % \begingroup \catcode`\'\active\catcode`\`\active \gdef\MakePrivateLetters{\makeatletter\def`{\textasciigrave}\def'{\textquotesingle}} \endgroup % https://github.com/latex3/latex2e/issues/953, for the record % will be used in code comments % I could re-define \csb, but perhaps better as the mark-up is not yet there % when I define this to opt for a new name \makeatletter \DeclareRobustCommand\csbc[1]{{\hypersetup{linkcolor=macrocodelinktocodelinecolor}% \ifcsname r@etocmacro-#1\endcsname \hyperref[etocmacro-#1]{\ttfamily\hyphenchar\font45 \char`\\ #1}% \else % for .toc suffixed macros \ifcsname r@etocmacro-\xintTrimUnbraced{-4}{#1}\endcsname \hyperref[etocmacro-\xintTrimUnbraced{-4}{#1}] {\ttfamily\hyphenchar\font45 \char`\\ #1}% \else % red color was not enough for me to identify misspelled macro names % but I should have a warning mechanism, the problem is how to % have it activated only at right time? {\fboxsep-\fboxrule\color{Orchid}% %\fbox{\textcolor{red}{\ttfamily\hyphenchar\font45 \char`\\ #1}}% \fbox{\ttfamily\hyphenchar\font45 \char`\\ #1}% }% % ah ok let's do this (2023/01/22, 1.2) \ifcsname r@etocmacro-etocname\endcsname \expanded{\noexpand\AtEndDocument {\noexpand\PackageError{etoc}{Pas de référence à #1\on@line}% {Corriger!} }% }% \fi \fi \fi }% } \makeatother \setcounter{secnumdepth}{3} \paragraph{About the syntax highlighting of the code:} Control\normalmarginpar\marginpar{\footnotesize\rmfamily\itshape\RaggedRight The ``syntax highlighting'' was added at release \etocrelease{1.09f} of 2022/08/30.\par} sequences are mostly hyperlinks. When a user level command gets defined it hyperlinks to the user documentation with bold face and \textbf{\textcolor{macrocodelinktouserdoccolor}{using this colour}}. Further instances if they occur will use \textcolor{macrocodelinktocodelinecolor}{this colour} to link to their place of first definition inside the code lines. Package macros with no user level documentation hyperlink to their first place of definition in the code. And such non-user level macros, at the location of their first definitions will have their names displayed using bold face and \textbf{\textcolor{macrocodenewmacrocolor}{this colour}} (it is not an hyperlink then). Comments located \emph{inside} the code source (very little are left at \etocrelease{1.1a}) have been configured \textcolor{macrocodecommentcolor}{to be rendered in their own colour}, and \textcolor{macrocodenoncscolor}{non commented-out and non-control sequences tokens use this colour}. Other tokens use the fall-back normal colour. A package macro mentioned in code comments also hyperlinks to the location of its first definition using {\textcolor{macrocodelinktocodelinecolor}{this colour}}. Known limitations: \begin{enumerate}[nosep] \item The location of first definition may be disappointing as it may be a provisory definition. \item Macros such as \csbc{Etoc@next} are there for matters of code branching only, and the first encountered definition has no relevant significance. \item Macros defined using |\csname...\endcsname| or alike constructs are not detected by the syntax highlighting automatization. Apart from manual intervention, this appears complex to solve as moreover the macro name may be there indirectly as an argument such as |#1|. %%%% This was caused by a ... 2013 oversight in my way of customizing txtt, %%%% see in preamble near loading of txfonts... fixed 2023/01/18 %%%% \item Bold face has an increased character width, somewhat offsetting the %%%% codelines alignment. \end{enumerate} \paragraph{An apology:} the code comments served mainly as a record for the author's benefit of the historical evolution of the package and rarely as a description of what the macros do. At \etocrelease{1.1a} I have removed almost all code comments which had accumulated as in a palimpsest. As a result, very few comments actually remain. \etocrelease{1.1c} re-added comments to those parts of the code which got refactored at and since \etocrelease{1.1a}, revigorating the palimpsest stratification. \paragraph{About \etoc and the processing of \texttt{.toc} file data:} \etoc,% % \normalmarginpar\marginpar{\footnotesize\rmfamily\itshape\RaggedRight This paragraph and the next were added very late in the history of the package, at \etocrelease{1.09h} and later.\par} % when not left in compatibility mode, hijacks the \csa{contentsline} expansion so as to not execute \csa{l@chapter}, \csa{l@section} etc..., but rather to parse the data and extract from it the \emph{name}, \emph{number}, and \emph{page number}. % The \LaTeX{} |.toc| data is \emph{not structured}, but contains already typesetting mark-up. The \etoc maneuvers to disentangle \emph{name} and \emph{number} are somewhat fragile as they expect the |.toc| file to contain the \csa{contentsline} arguments to be arranged in a certain manner. Of course \etoc can be easily broken if changes happen to how data is stored there. Things would have been much easier for \etoc in 2012 if the \csa{contentsline} arguments had considered the section titles (aka \emph{name} for \etoc) and their numbers (which are not numbers in the sense of things with which \TeX\ can compute, in general) separately, each providing an argument to \csa{contentsline}. But some mix is prepared, which may depend on the document class also, and besides usually handles \csa{part} levels very differently. Fortunately upstream changes happen rarely.% % \normalmarginpar\marginpar{\footnotesize\rmfamily\itshape\RaggedRight Prior to \etocrelease{1.1a}, \etoc aliased \csa{l@chapter}, \csa{l@section}, etc... (at the time of TOC typesetting only) to its own \csbc{Etoc@lxyz} in order to leave time to \ctanpkg{hyperref} to add its mark-up. Thus the disentangling of name from number was more complex than it is now. With \etocrelease{1.1a}, \etoc leaves \csa{l@chapter} etc... unmodified (and unused) and only hijacks \csa{contentsline}.} % The other core part of \etoc present from day one of the package is that it creates a tree-like structure of the sectioning levels present in the |.toc| file. But this is purely virtual, and handled via a notion of ``level'' and \TeX\ conditionals. It could be fun to implement officially such a tree (where the children of a sectioning title are the sectioning levels at a greater depth such as subsections versus a section). Let us recall that \LaTeX{} provides zero means to know from a subsection for example, what is the title of the section containing it, or chapter, or part. To do this one has to create a really structured document which neither core \LaTeX{} nor the main document classes do. This remark was given for document body, but it also applies to the |.toc| data. But \etoc adds at least some kind of follow-up to the successive encountered sectioning titles, and is thus able, to ``on-the-fly'' add some kind of structure and follow the chaining of levels. Ultimately this is why the \csbc{etocsetstyle} offers \marg{start} and \marg{finish} parts in additions to \marg{contents} (which I divided into a \marg{prefix} and a \marg{contents}). At some point one could imagine that a really \emph{structured} document (in opposition to what core \LaTeX{} from thirty years ago up to nowadays realizes) would store in the |.toc| data directly a tree structure, where each node would have attributes name, number, page number, completely separated from any typesetting. Once this exists then basically \etoc disappears. In brief, once \etoc ideas will have permeated the society, it will disappear as its was born only to palliate the absence of real structure in the |.toc| file (which is sort of inherited from the absence of real structure in a \LaTeX{} document body). % 9 avril 2015 (1.08d) pour forcer indentation après macrocode % par un effet particulier si avant macrocode un enumerate, inefficient, % mais vraiment pas envie d'investiguer. % % l'esthétique est un peu douteuse mais je laisse ? % non finalement je supprime % \makeatletter % \def\endmacrocode{% % \ifpm@module \endgroup \pm@modulefalse \fi % \everypar{}% % \global\@inlabelfalse % \endtrivlist\@endpefalse % <<-- ajouté % \close@crossref} % \makeatother % This is obsolete as 1.09g of 2022/11/17 has removed this hack, also % for colorizing reasons from 1.09n. % November 2012 % I don't want to have to type at this location (far from the top of the % file) explicitly the package version or version date, as it is % inconvenient to have to remember to do this when updating the package. % Also, I prefer not to add macros to the |.sty| file giving the package % date, name, or version. So I extracted this from the real macrocode % environment (leaving out the \init@crossref.) % The catcode hackery next is to avoid to have <*package> to be listed % in the commented source code... % (c) 2012/11/19 jf burnol ;-) \MakePercentIgnore % % \catcode`\<=0 \catcode`\>=11 \catcode`\*=11 \catcode`\/=11 % \let\relax % \def<*package>{\catcode`\<=12 \catcode`\>=12 \catcode`\*=12 \catcode`\/=12} % % %<*package> % \etocrelease{1.1a} implements a radical change to legacy core internals for % compatibility with some (future) \ctanpkg{hyperref} changes. In order to % facilitate this overhaul, it required \LaTeX{} 2020-10-01 for the fourth % argument to \cs{contentsline} lines in the |.toc| file to be always present. % % At \etocrelease{1.2a}, this requirement has been lifted so that we % re-incorporated compatibility with old \cs{contentsline} fetching 4 or only % 3 arguments depending on presence or not of \ctanpkg{hyperref}. Fortunately % the code refactoring completed at \etocrelease{1.2} made this easier. % Testing on ``old'' \LaTeX{} was limited to one single check on a TL2019 % install. % % Also \etocrelease{1.2} use \csa{expanded}, we now test for its existence and % provide alternative code if it is not provided by the engine. % % TeXLive started producing \LaTeX{} format incorporating by default the % \eTeX{} extensions I think twenty years ago with TL2003, so let's require at % least the \LaTeX{} of December of 2003 (but its is no guarantee that it will % actually be with engine providing \csa{ifdefined}, \csa{unless}, % \csa{numexpr} or \csa{unexpanded} or maybe others yet that we use). % \begin{macrocode} \NeedsTeXFormat{LaTeX2e}[2003/12/01] \ProvidesPackage{etoc}[2023/10/29 v1.2d Completely customisable TOCs (JFB)] % \end{macrocode} % Gentle Info message in the log to mention no testing is done of current % \etoc on old \LaTeX{} installations. % \begin{macrocode} \newif\ifEtoc@oldLaTeX \@ifl@t@r\fmtversion{2020/10/01} {} {\Etoc@oldLaTeXtrue \PackageInfo{etoc}{Old LaTeX (\fmtversion) detected!\MessageBreak Since 1.1a (2023/01/14), etoc prefers LaTeX at least\MessageBreak as recent as 2020-10-01, for reasons of the .toc file,\MessageBreak and used to require it (from 1.1a to 1.2).\MessageBreak This etoc (1.2d) does not *require* it, but has not been\MessageBreak tested thoroughly on old LaTeX (especially if document\MessageBreak does not use hyperref) and retrofitting was done only\MessageBreak on basis of author partial remembrances of old context.\MessageBreak Reported}} % \end{macrocode} % \etocrelease{1.2} adds experimental support (only tested with standard % classes and few packages) for \csbc{locallistoffigures} and % \csbc{locallistoftables}. Did I say this is experimental? When \LaTeX{} % will have added official hook to \csa{addcontentsline}, I will probably % revise the way \etoc hacks into it for this \emph{experimental} % functionality. % % As it is \textbf{experimental}, I think we can all agree I don't have % to spend too much space documenting it in user manual. So I shall be % brief when I will get to it. And I will remain brief here too. % % Now that \etoc uses package options, I will use \ctanpkg{kvoptions} as I am % familiar with it. I understand upstream \LaTeX{} now has support for % key-value input, put I simply have had no time to read the interface. % Besides not sure it was there for the |2020-10-01| required release. % \begin{macrocode} \RequirePackage{kvoptions} \SetupKeyvalOptions{prefix=Etoc@} \newif\ifEtoc@lof \DeclareVoidOption{lof}{\Etoc@loftrue \PackageInfo{etoc}{Experimental support for \string\locallistoffigures.\MessageBreak Barely tested, use at own risk}% } \newif\ifEtoc@lot \DeclareVoidOption{lot}{\Etoc@lottrue \PackageInfo{etoc}{Experimental support for \string\locallistoftables.\MessageBreak Barely tested, use at own risk}% } \@ifclassloaded{memoir}{ \PackageInfo{etoc} {As this is with memoir class, all `...totoc' options\MessageBreak are set true by default. Reported} \DeclareBoolOption[true]{maintoctotoc} \DeclareBoolOption[true]{localtoctotoc} \DeclareBoolOption[true]{localloftotoc} \DeclareBoolOption[true]{locallottotoc} }{ \DeclareBoolOption[false]{maintoctotoc} \DeclareBoolOption[false]{localtoctotoc} \DeclareBoolOption[false]{localloftotoc} \DeclareBoolOption[false]{locallottotoc} } \DeclareBoolOption[true]{ouroboros} % \end{macrocode} % The \etocoption{deeplevels} option added at \etocrelease{1.2a}. Adapted % from an intial patch contributed by Matthew Trescott in the context of % the \href{https://github.com/doxygen/doxygen}{Doxygen} project. % It sets the maximum level usable with \csbc{etocsetlevel} (and never % displayed) at |12| rather than |6|. % % Such an extension of the number of levels handled by \etoc would have been % much more cumbersome to achieve prior to the \etocrelease{1.2} refactoring % which replaced usage of a booleans by a stack storage of the succession of % levels seen in the |.toc| file (from which \etoc creates virtual nesting % structure), which actually is completely scalable and can handle unlimited % number of levels. Basically we only needed to replace the formerly used % \csa{Etoc@@six@@} by a \csbc{Etoc@maxlevel} set to have value |12| but this % simple change caused also many modification to messages involved in % \etoc-user interactions, and a disproportionate quantity of time passed on % updating the documentation, even though in a minimal way, and of course a % minimal amount of testing but \etoc is lacking a strong regression test % suite which for lack of time has not yet been put into place. As it is so % simple we could do some option |maxlevel=| but well, there is no % real need, because the extra potential levels do not cause any overhead to % the actual \etoc handling of tables of contents, so it is even tempting to % adopt |12| (which is way beyond any realistic needs of a real document) as % default, but this would break the documents in the wild which have used the % advanced techniques based on hiding one or more levels via setting it at % numerical depth |6|. % \begin{macrocode} \DeclareBoolOption[false]{deeplevels} \DeclareDefaultOption{\PackageWarning{etoc}{Option `\CurrentOption' is unknown.}} \ProcessKeyvalOptions* \DisableKeyvalOption[action=error,package=etoc]{etoc}{lof} \DisableKeyvalOption[action=error,package=etoc]{etoc}{lot} \DisableKeyvalOption[action=error,package=etoc]{etoc}{deeplevels} % \end{macrocode} % The real verbosity problem of \LaTeX{} is not so much the log, which should % actually be as detailed as possible (and the default \csa{errorcontexlines} % setting of \LaTeX{} is to my view misguided), but the humongous output to % console, most of it being perfectly useless in 99\% of cases. Despite % \csa{PackageInfo} adding stuff to the log only, I finally decided not to use % this next hunk. % \begin{macrocode} % \PackageInfo{etoc}{Status of options at loading time:\MessageBreak % lof = \ifEtoc@lof true\else false\fi\MessageBreak % lot = \ifEtoc@lot true\else false\fi\MessageBreak % maintototoc = \ifEtoc@maintoctotoc true\else false\fi\MessageBreak % localtoctotoc = \ifEtoc@localtoctotoc true\else false\fi\MessageBreak % localloftotoc = \ifEtoc@localloftotoc true\else false\fi\MessageBreak % locallottotoc = \ifEtoc@locallottotoc true\else false\fi\MessageBreak % ouroboros = \ifEtoc@ouroboros true\else false\fi\MessageBreak % deeplevels = \ifEtoc@deeplevels true\else false\fi\@gobble % } % \end{macrocode} % For many many years \etoc had no options. Let's be modern and provide an % \csbc{etocsetup}. % \begin{macrocode} \def\etocsetup#1{\setkeys{etoc}{#1}} \def\etocifmaintoctotoc{\ifEtoc@maintoctotoc \expandafter\@firstoftwo \else \expandafter\@secondoftwo \fi} \def\etociflocaltoctotoc{\ifEtoc@localtoctotoc \expandafter\@firstoftwo \else \expandafter\@secondoftwo \fi} \def\etociflocalloftotoc{\ifEtoc@localloftotoc \expandafter\@firstoftwo \else \expandafter\@secondoftwo \fi} \def\etociflocallottotoc{\ifEtoc@locallottotoc \expandafter\@firstoftwo \else \expandafter\@secondoftwo \fi} \RequirePackage{multicol} \def\etoc@{\etoc@} \long\def\Etoc@gobtoetoc@ #1\etoc@{} \newtoks\Etoc@toctoks \def\Etoc@par{\par} \def\etocinline{\def\Etoc@par{}} \let\etocnopar\etocinline \def\etocdisplay{\def\Etoc@par{\par}} % \end{macrocode} % \csbc{etocglobaldefs} should be used only for special things such as TOC as % a table; it should be put in a group to limit its scope. If used in the % preamble, it must come \emph{after} \ctanpkg{tableof} if the latter is % loaded too. % \begin{macrocode} \let\Etoc@global\@empty \def\etocglobaldefs{\let\Etoc@global\global\let\tof@global\global} \def\etoclocaldefs {\let\Etoc@global\@empty\let\tof@global\@empty} % \end{macrocode} % Some have been renamed at \etocrelease{1.2}. % \begin{macrocode} \newif\ifEtoc@numbered \newif\ifEtoc@hyperref \newif\ifEtoc@parskip \newif\ifEtoc@tocwithid \newif\ifEtoc@standardlines % \end{macrocode} % These next three added at \etocrelease{1.2}. The latter two for handling % compatibility layer with \ctanpkg{tocloft} % and \ctanpkg{tocbibind}.\par^^A encore ce problème de ligne supp si plein! % \begin{macrocode} \newif\ifEtoc@etocstyle \newif\ifEtoc@classstyle \newif\ifEtoc@keeporiginaltoc \newif\ifEtoc@skipprefix \newif\ifEtoc@isfirst \newif\ifEtoc@localtoc \newif\ifEtoc@skipthisone \newif\ifEtoc@stoptoc \newif\ifEtoc@notactive \newif\ifEtoc@mustclosegroup \newif\ifEtoc@isemptytoc \newif\ifEtoc@checksemptiness \def\etocchecksemptiness {\Etoc@checksemptinesstrue } \def\etocdoesnotcheckemptiness {\Etoc@checksemptinessfalse } \newif\ifEtoc@notocifnotoc \def\etocnotocifnotoc {\Etoc@checksemptinesstrue\Etoc@notocifnotoctrue } \newcounter{etoc@tocid} \def\Etoc@tocext{toc} \def\Etoc@lofext{lof} \def\Etoc@lotext{lot} \let\Etoc@currext\Etoc@tocext \def\etocifislocal{\ifEtoc@localtoc\expandafter\@firstoftwo\else \expandafter\@secondoftwo\fi } \def\etocifislocaltoc{\etocifislocal{\ifx\Etoc@currext\Etoc@tocext \expandafter\@firstoftwo\else \expandafter\@secondoftwo\fi}% {\@secondoftwo}% } \def\etocifislocallof{\etocifislocal{\ifx\Etoc@currext\Etoc@lofext \expandafter\@firstoftwo\else \expandafter\@secondoftwo\fi}% {\@secondoftwo}% } \def\etocifislocallot{\etocifislocal{\ifx\Etoc@currext\Etoc@lotext \expandafter\@firstoftwo\else \expandafter\@secondoftwo\fi}% {\@secondoftwo}% } % \end{macrocode} % Formerly a \LaTeX{} counter |etoc@tocdepth| was declared here but at % \etocrelease{1.2} it has been replaced by macro storage.\par % \begin{macrocode} \expandafter\def\csname Etoc@-3@@\endcsname {-\thr@@} \expandafter\def\csname Etoc@-2@@\endcsname {-\tw@} \expandafter\let\csname Etoc@-1@@\endcsname \m@ne \expandafter\let\csname Etoc@0@@\endcsname \z@ \expandafter\let\csname Etoc@1@@\endcsname \@ne \expandafter\let\csname Etoc@2@@\endcsname \tw@ \expandafter\let\csname Etoc@3@@\endcsname \thr@@ \expandafter\chardef\csname Etoc@4@@\endcsname 4 \expandafter\chardef\csname Etoc@5@@\endcsname 5 \expandafter\chardef\csname Etoc@6@@\endcsname 6 % \end{macrocode} % \etocoption{deeplevels} option needs a few extra declarations. % \begin{macrocode} \ifEtoc@deeplevels \expandafter\chardef\csname Etoc@7@@\endcsname 7 \expandafter\chardef\csname Etoc@8@@\endcsname 8 \expandafter\chardef\csname Etoc@9@@\endcsname 9 \expandafter\chardef\csname Etoc@10@@\endcsname 10 \expandafter\chardef\csname Etoc@11@@\endcsname 11 \expandafter\chardef\csname Etoc@12@@\endcsname 12 \fi % \end{macrocode} % \etocrelease{1.2a} adds \csbc{Etoc@maxlevel} which replaces formerly % used \csa{Etoc@@six@@}. It adds also \csbc{etocthemaxlevel} as % user interface to its explicit numerical value. % \begin{macrocode} \expandafter\let\expandafter\Etoc@maxlevel \csname Etoc@\ifEtoc@deeplevels12\else6\fi @@\endcsname \edef\etocthemaxlevel{\number\Etoc@maxlevel} % \end{macrocode} % For \csbc{etocsetlevel}, \etocrelease{1.2a} uses a comparison with % \csbc{Etoc@minf} so that only levels suitable for the document class can be % used. So \etoc now will not define unneeded `book' levelname with numerical % level |-2| except if with \ctanpkg{memoir}. % \begin{macrocode} \@ifclassloaded{memoir}{\def\Etoc@minf{-\thr@@}}{\def\Etoc@minf{-\tw@}} \let\Etoc@none@@ \Etoc@minf \expandafter\let\expandafter\Etoc@all@@ \csname Etoc@\ifEtoc@deeplevels11\else5\fi @@\endcsname % \end{macrocode} % \csa{Etoc@dolevels} will hold the names of all declared levels % (independently of their numerical levels), in a traditional % \LaTeX{} |\do| separated manner, except that for some reason % I used \csa{Etoc@do}. TODO: maybe use |\do|. % \begin{macrocode} \let\Etoc@dolevels\@empty \def\Etoc@newlevel #1{\expandafter\def\expandafter\Etoc@dolevels\expandafter {\Etoc@dolevels\Etoc@do{#1}}} % \end{macrocode} % \etocrelease{1.2} has done some refactoring here (and above), reducing % the number of definitions. Formerly each defined sectioning level got two % macros assigned to it: one holding the numerical level (as chardef or count, % or even tokens for |-\tw@|), the other in a textual representation such as % |minusone|. The latter do not get defined anymore. % % MEMO: the legacy name space here is rather poor as anything can happen after % \csa{Etoc@} with the sole and only characteristic that it terminates with % |@@|. So this means no package control sequence is allowed to end in |@@| % else it is in risk of being overwritten, were it not for the special % filtering done by \csbc{etocsetlevel}. For matters of % \csbc{etocsetnexttocdepth} allowing both name and numerical arguments, we % employed the cheap device to define ourselves special levels named by % explicit integers for internal usage, hence we need to filter them out here % from being redefined. We also filter out names starting with |@| for other % reasons, but still it was not true at \etocrelease{1.2} that the package % could safely use |\Etoc@@...@@| macros, as \csbc{etocsetlevel} creates since % then also a |\Etoc@@|\meta{name}|@@|. There was in particular a chardef % \csa{Etoc@@six@@} hence if user chose ``|six|'' as level name % \csa{Etoc@@six@@} acquired a new meaning and this could cause strange % symptoms, the main one being the disappearance from TOCs of levels at same % numerical depth than the one now given by the modified % \csa{Etoc@@six@@}. (There was no \csa{Etoc@six@@} so the bug was really only % one of \etocrelease{1.2} not of earlier releases). % % \etocrelease{1.2} adds here \csbc{etocifunknownlevelTF} and % \csbc{etoclevel} for a higher level interface, which may be used by third % parties such as the \ctanpkg{yathesis} class and will allow \etoc at some % point to modify its internal naming conventions. % % The |-\tw@| case needed for \csbc{Etoc@minf} (or for \ctanpkg{memoir}) means % that two expansions of \csbc{etoclevel} do not always deliver a single % token, it is at any rate always self-delimiting in assignments and % \csa{ifnum} tests. I hesitated using only explicit digit tokens by the way. % % The dummy sectioning levels ``all'' and ``none'' play a special role and % will be declared by \csbc{etocifunknownlevelTF} as ``known''. % % TODO: is it worthwile to still allow `7' to `12` as level ``names''? This is % done here for perfact backward compatibility but they have to be excluded % under \etocoption{deeplevels} option, and it would be better to do something % not depending on whether that option is used or not. % \begin{macrocode} \ifdefined\expanded \def\etocsetlevel#1#2{\expanded{\noexpand\etoc@setlevel{#1}{#2}}}% \else \def\etocsetlevel#1#2{{\edef\Etoc@tmp{\noexpand\etoc@setlevel{#1}{#2}}\expandafter}\Etoc@tmp}% \fi \def\etoc@setlevel#1#2{% \edef\Etoc@tmp{\the\numexpr#2}% \if1\ifnum\Etoc@tmp>\Etoc@maxlevel0\fi\unless\ifnum\Etoc@minf<\Etoc@tmp;\fi1% \ifEtoc@deeplevels \in@{.#1,}{.none,.all,.figure,.table,.-3,.-2,.-1,.0,.1,.2,.3,.4,.5,.6,% .7,.8,.9,.10,.11,.12,}% \else \in@{.#1,}{.none,.all,.figure,.table,.-3,.-2,.-1,.0,.1,.2,.3,.4,.5,.6,}% \fi % \end{macrocode} % Letter or other agnostic test. First time I ever use \csa{@car} as I never % paid attention to its existence and in more macro-coding intensive context % such as \ctanpkg{xint} I use my own. % \begin{macrocode} \ifin@\else\if\@car#1\@nil @\in@true\fi\fi \ifin@ \PackageWarning{etoc} {Sorry, but `#1' is forbidden as level name.\MessageBreak \if\@car#1\@nil @% (because of the @ as first character)\MessageBreak\fi Reported}% \else \etocifunknownlevelTF{#1}{\Etoc@newlevel{#1}}{}% \expandafter\let\csname Etoc@#1@@\expandafter\endcsname \csname Etoc@\Etoc@tmp @@\endcsname % \end{macrocode} % This is to allow ``to toc'' entries to not break the core mechanism % used to let local tables of contents (now also lists of) % know their scope, in case for example we have one after the other % \csbc{localtableofcontents}, \csbc{locallistoffigures}, % \csbc{locallistoftables} and each has created its ``to toc'' entry: % main TOC will handle the |@| as aliases to || and local % TOCs and Lists Of will ignore them. % % So we create |@| as aliases to ||. This is really % needed only for the level names actually involved by ``to toc'' thing, but % let's do it systematically to avoid implementation complications. % \begin{macrocode} \expandafter\edef\csname Etoc@@#1@@\endcsname {\expandafter\noexpand\csname Etoc@#1@@\endcsname}% % \end{macrocode} % As ``to toc'' will use some \csa{addcontentsline}, we must make % \ctanpkg{hyperref} happy and also define the suitable |toclevel@| prefixed % extra macros. % \begin{macrocode} \expandafter\edef\csname toclevel@@#1\endcsname {\expandafter\noexpand\csname toclevel@#1\endcsname}% % \end{macrocode} % But we don't set \ctanpkg{hyperref}'s \csa{toclevel@\string#1} to be % numerically \csa{Etoc@tmp}, with some hesitation. The level defined by % \csbc{etocsetlevel} should only be for interpretation by \etoc for the % contents of the |.toc| file. If it also influences how \ctanpkg{hyperref} % hooks into \csa{section} and like commands influence the PDF bookmarks, % unexpected results could follow. It is up to user to set-up by themself % possibly needed extra \ctanpkg{hyperref} configuration in this regard. % \begin{macrocode} \fi \else \PackageWarning{etoc} {Argument `\detokenize{#2}' of \string\etocsetlevel\space should represent one of\MessageBreak \ifnum\Etoc@minf=-\thr@@-2, \fi-1, 0, 1, 2, \ifEtoc@deeplevels ...\else3, 4\fi, \the\numexpr\Etoc@maxlevel-1, or \number\Etoc@maxlevel\space but evaluates to \Etoc@tmp.\MessageBreak The level of `#1' will be set to \number\Etoc@maxlevel.\MessageBreak Tables of contents will ignore `#1' as long\MessageBreak as its level is \number\Etoc@maxlevel\space (=\string\etocthemaxlevel).% \MessageBreak Reported}% \etocifunknownlevelTF{#1}{\Etoc@newlevel{#1}}{}% \expandafter\let\csname Etoc@#1@@\endcsname\Etoc@maxlevel \fi } % \end{macrocode} % Maybe let it first use \csbc{etocifunknownlevelTF} and raise in the % ``unknown'' branch a suitable expandable error message (and return say |-3|)? % % I may also need for internal usage a variant for only numerical |#1| which be % submitted to a \csa{the}\csa{numexpr}. Not so far. % % Unfortunately the name ``level'' here does not convey to user the fact that % the argument of \csbc{etocifunknownlevelTF} is a ``name'' not a numerical % thing. % \begin{macrocode} \def\etoclevel#1{\csname Etoc@#1@@\endcsname} \def\etocthelevel#1{\number\csname Etoc@#1@@\endcsname} \def\etocifunknownlevelTF#1{\@ifundefined{Etoc@#1@@}} \@ifclassloaded{memoir}{\etocsetlevel{book}{-2}}{} \etocsetlevel{part}{-1} \etocsetlevel{chapter}{0} \etocsetlevel{section}{1} \etocsetlevel{subsection}{2} \etocsetlevel{subsubsection}{3} \etocsetlevel{paragraph}{4} \etocsetlevel{subparagraph}{5} % \end{macrocode} % Prior to \etocrelease{1.2}, only under class \ctanpkg{memoir} was % \csbc{etocsetlevel} used with |appendix|. It does not seem to hurt to do it % generally, with a check whether document class provides chapters. % \begin{macrocode} \ifdefined\c@chapter \etocsetlevel{appendix}{0} \else \etocsetlevel{appendix}{1} \fi % \end{macrocode} % The ``to toc'' mechanism will add to the |.toc| file \csa{contentsline} entries % with first argument such as |@section| or |@subsection|. They will % generally behave as |section|, resp. |subsection|, etc\dots\ This special % mark-up is needed for ``to toc'' inclusions to not break the \etoc mechanism % for delimiting the scope of local tables of contents. % \begin{macrocode} \def\Etoc@do#1{\@namedef{l@@#1}{\csname l@#1\endcsname}} \Etoc@dolevels % \end{macrocode} % We do not issue \csbc{etocsetlevel}|{figure}{6}| (or |{12}|) as anyhow the % \csbc{etocsetlevel} interface forbids |figure| and |table| as first % argument. % \begin{macrocode} \let\Etoc@figure@@\Etoc@maxlevel \let\Etoc@table@@ \Etoc@maxlevel % \end{macrocode} % \etocrelease{1.09g} adapts to \ctanpkg{hyperref} depending on whether the % latter is at |7.00u| or earlier. Indeed internal changes to % \ctanpkg{hyperref} at |7.00u| broke \etoc. Thanks to Denis~\textsc{Bitouzé} % for reporting the issue. % % \etocrelease{1.1a} radically simplifies matters at \etoc core, and if these % changes had been in place earlier there would have been no incompatibility % with the \ctanpkg{hyperref} |7.00u| release. % % At \etocrelease{1.2a} we drop the \etocrelease{1.1a} requirement of \LaTeX % from |2020-10-01| and must cater for \csa{contentsline} with 3 or 4 % arguments. Fortunately, the code refactorings engaged at % \etocrelease{1.1a} and completed at \etocrelease{1.2} made such a retro-fit % relatively simple. Let's hope nothing was overlooked, though. % % But we can not assume anymore \csa{@gobblethree} exists... hesitation here % whether to use a \csbc{Etoc@gobblethree} or directly name it % \csa{@gobblethree}. % \begin{macrocode} \let\Etoc@gobblethreeorfour\@gobblefour \ifdefined\@gobblethree \let\Etoc@gobblethree\@gobblethree \else \long\def\Etoc@gobblethree#1#2#3{}% \fi \AtBeginDocument{% \@ifpackageloaded{parskip}{\Etoc@parskiptrue}{}% \@ifpackageloaded{hyperref} {\Etoc@hyperreftrue} {\ifEtoc@oldLaTeX \let\Etoc@gobblethreeorfour\Etoc@gobblethree \let\Etoc@etoccontentsline@fourargs\Etoc@etoccontentsline@ \long\def\Etoc@etoccontentsline@#1#2#3{% \Etoc@etoccontentsline@fourargs{#1}{#2}{#3}{}% }% \fi }% } \def\etocskipfirstprefix {\global\Etoc@skipprefixtrue } % \end{macrocode} % Start of heart of \etoc's hacks into the execution of the |.toc| file % commands. It goes via a redefinition of \csa{contentsline} which will % launch an extraction process leading to the construction of \csbc{etocname}, % \csbc{etocnumber}, and \csbc{etocpage}, then the styles as defined by user % via \csbc{etocsetstyle} get executed in accordance to the levels. % % In passing \etoc is witness to the linear succession of sectioning levels % and executes the \marg{start} and \marg{finish} parts of each used level at % the right time (they are rather called ``|begin|'' and ``|end|'' in the code % though). % % \etocrelease{1.2} did a complete rewrite of how \etoc creates virtually a % nesting structure out of the flat succession of the \csa{contentsline}'s for % various levels. Ever since the first release this was based on using % boolean flags, one for each level. The flag was on if the level had been % seen, hence its ``begin'' macro executed, but not yet its ``end'' macro. % This is now replaced by a stack storage \csbc{Etoc@stackofends} which is % simply, e.g. |{2}{0}{-3}{}|, to mean that first a chapter (|0|) was seen % then a subsection (|2|). The |{-3}{}| trail is for matters of avoiding % brace removal in the implementation next (I could have replaced it by a % single token being numerically |-3|). This structure made implementing the % \etocoption{deeplevels} painless (but time-consumingly documented) at % \etocrelease{1.2a}. % % When a new level is encountered and set in \csbc{Etoc@level}, it is compared % to the left most entry in the stack. If higher, the ``begin'' macro is % executed and the \csbc{Etoc@level} is pushed (as a digit with possibly a % minus sign) to the left of the stack to record that the ``end'' macro is now % on the queue for execution (sic). If equal, nothing has to be done, if % lower, the ``end'' macro of the left-most stored level is executed then this % level is removed, and one proceeds with the next one, etc... legacy code was % using a bunch of TeX conditionals rather, and I recall how in 2012 I was % unfamiliar with its strange syntax and had lots of troubles; once I got % something working it got frozen and basically did not change since then. % The \etocrelease{1.2} implementation has replaced all of this by % maintenance of a single ``stack'', which is more economical in terms of % used macros and potentially more scalable too. % % About \csbc{Etoc@level} I have hesitated using only digit and sign tokens, % but it is currently let to some \csa{chardef} (in exceptional % \ctanpkg{memoir} case of |book| level it can expand to |-\tw@|, and there is % also the \csa{m@ne} count). \etocrelease{1.2} thus keeps defining such % \csa{chardef}'s but has at least dropped auxiliary macros (see the % definitions prior to \csbc{etocsetlevel}) which held some alphabetical % denotations such as ``minusone'' or ``zero'', and the \emph{begin}, % \emph{prefix}, \emph{content} and \emph{end} macros associated with each % level now use a digit (and sign perhaps) (see \csbc{etocsetstyle}). With % \csbc{Etoc@level} already storing directly such a digit, one would avoid a % \csa{number} or \csa{the}\csa{numexpr} at some places, but would have to be % more careful in the various \csa{ifnum}. % % This (always globally defined) \csbc{Etoc@level} must now never be set to % the numerical value \texttt{6} (or \texttt{12} if option % \etocoption{deeplevels}): it is legal to add to the |.toc| file dummy % sectioning levels associated to the maximal numerical level % \csbc{etocthemaxlevel} (such dummy sectioning will be ignored but can be % assigned locally a non-ignored level for special effects) and if % \csbc{Etoc@level} was, as prior to \etocrelease{1.2}, systematically set to % the numerical level of the last seen \csa{contentsline}, this could cause % \csbc{Etoc@@startlocaltoc} to fail to correctly set the ``local top''. % Indeed it now only has \csbc{Etoc@level} at his disposal, the legacy boolean % flags being gone. % % The \csa{Etoc@isfirsttrue} was formally incorporated as last token of the % ``begin'' macros as defined by \csbc{etocsetstyle}, but has been displaced % by \etocrelease{1.2} to the code below. % \begin{macrocode} \def\Etoc@updatestackofends#1\etoc@{\gdef\Etoc@stackofends{#1}} \def\Etoc@stackofends{{-3}{}} \def\Etoc@doendsandbegin{% \expandafter\Etoc@traversestackofends\Etoc@stackofends\etoc@ } % \end{macrocode} % We compare the new level with those for which the \marg{start} parts of the % \csbc{etocsetstyle} declarations have been executed to decide if it is time % to execute their \marg{finish} parts. In passing we set the boolean % \csbc{ifEtoc@isfirst} which is needed for \csbc{etociffirst} and % \csbc{etocxiffirst}. % \begin{macrocode} \def\Etoc@traversestackofends#1{% \ifnum#1>\Etoc@level \csname Etoc@end@#1\endcsname \expandafter\Etoc@traversestackofends \else \Etoc@traversestackofends@done{#1}% \fi } \def\Etoc@traversestackofends@done#1#2{#2% \ifnum#1<\Etoc@level \csname Etoc@begin@\the\numexpr\Etoc@level\endcsname \Etoc@global\Etoc@isfirsttrue \edef\Etoc@tmp{{\the\numexpr\Etoc@level}}% \else \Etoc@global\Etoc@isfirstfalse \let\Etoc@tmp\@empty \fi \expandafter\Etoc@updatestackofends\Etoc@tmp{#1}% } % \end{macrocode} % Ever since the first release of \etoc, the code has to be careful that the % |\Etoc@end@| user defined macros may close groups. This is the reason % why some assignments have to be done globally (|2015/03/08|). % % \etocrelease{1.1a} of |2023/01/14| implements a radical change to legacy % core internals for compatibility with (attow future) \ctanpkg{hyperref}. % Formerly \csbc{Etoc@etoccontentsline@} fetched only the first argument. It % now also fetches all four (the fourth argument of \csa{contentsline} is % always present since \LaTeX{} |2020-10-01|). The \csbc{Etoc@lxyz} used to % receive only the two arguments (possibly hacked by \ctanpkg{hyperref}) of % \csa{l@chapter}, \csa{l@section}, etc..., (these macros had been |\let| to % \csbc{Etoc@lxyz}), and examined them to see if they were carrying % hyperlinking data. The \etocrelease{1.1a} and later version receives as % third argument the fourth one of \csa{contentsline}, i.e.\@ the hyperlinking % target, and adds the hyperlinking according to the status of % \ctanpkg{hyperref}'s \csa{Hy@linktoc}. % % This is a breaking change if a user hacked \csa{contentsline} to do some % specific pre-processing of the data, as this extra will now be ignored. The % kind of hack one can think of is perhaps to pre-process the section title to % turn it into uppercase, this kind of things, but why do such things when one % is using \etoc which precisely provides a general interface for such % customization? Besides as the \LaTeX{} legacy set-up already mixes up in % various ways name and number in the second argument of \csa{contentsline}, % doing such hacks in a non-breaking way was not easy, and could have broken % \etoc easily anyhow. % % The major hacker was \ctanpkg{hyperref}... Indeed in 2012 when I started % work on \etoc, it was not clear to me how \ctanpkg{hyperref} would end up % using the fourth argument of \csa{contentsline} and I did not want to spend % too much time tracing hyperref code. So I simply let \ctanpkg{hyperref} do % its stuff, and added specific post-processing branches to unravel it. % It looks quite dumb in retrospect (at this time the |.toc| file lines % with \csa{contentsline} had either three or four arguments which contributed % for the design decisions back then). % % All \ctanpkg{hyperref} specific branches are now gone, replaced by extra % code added depending on the status of the \csbc{ifEtoc@hyperref} boolean. % We also check the \csa{Hy@linktoc} \csa{chardef} status and, imitating % \ctanpkg{hyperref}, do not hyperlink the page number argument if it turns out % empty. This maintains backwards-compatibility with earlier releases of % \etoc. % % TODO: should this code ensure |#1| is actually a legit level name and if not % issue some nice error message? This would add system-level overhead only for % careless people who do not read docs... % \begin{macrocode} \def\Etoc@etoccontentsline #1{% \let\Etoc@next\Etoc@gobblethreeorfour \ifnum\csname Etoc@#1@@\endcsname=\Etoc@maxlevel \else \Etoc@skipthisonefalse % \end{macrocode} % MEMO: the mechanism added to make % added toc entries from ``list of'' titles invisible to the local tocs, % goes via such a |#1| starting with an |@|. In that case \csa{Etoc@\string#1@@} % is not a \csa{chardef} but expands to one (or to a count or |-\tw@| perhaps, % or a |\numexpr...\relax|). % \begin{macrocode} \global\expandafter\let\expandafter\Etoc@level\csname Etoc@#1@@\endcsname % \end{macrocode} % The trick goes through a slight overhead here to filter out such special % ``|@|``-level names and not make them update what will serve as top level for % local tocs or listsof. Formerly this was managed by booleans, then for % \etocrelease{1.1d} (released as \etocrelease{1.2}) it got replaced by % sole usage of \csbc{Etoc@level}, and finally a specific % \csbc{Etoc@virtualtop} which gets its updates here. % \begin{macrocode} \if @\@car#1\@nil\else\global\let\Etoc@virtualtop\Etoc@level\fi \ifEtoc@localtoc \ifEtoc@stoptoc \Etoc@skipthisonetrue \else \ifEtoc@notactive \Etoc@skipthisonetrue \else \unless\ifnum\Etoc@level>\etoclocaltop \Etoc@skipthisonetrue \global\Etoc@stoptoctrue \fi \fi \fi \fi \ifEtoc@skipthisone \else \unless\ifnum\Etoc@level>\c@tocdepth \ifEtoc@standardlines \let\Etoc@next\Etoc@savedcontentsline \else \let\Etoc@next\Etoc@etoccontentsline@ \fi \fi \fi \fi \Etoc@next{#1}% } % \end{macrocode} % Hesitation at \etocrelease{1.2} about having \csbc{Etoc@level} being % always explicit digit and perhaps negative sign. For now is a % \csa{chardef} or \csa{m@ne} \csa{count} (perhaps |-\tw@| also). % \begin{macrocode} \def\Etoc@etoccontentsline@ #1#2#3#4{% \Etoc@doendsandbegin \Etoc@global\edef\Etoc@prefix {\expandafter\noexpand \csname Etoc@prefix@\the\numexpr\Etoc@level\endcsname }% \Etoc@global\edef\Etoc@contents{\expandafter\noexpand \csname Etoc@contents@\the\numexpr\Etoc@level\endcsname }% \ifEtoc@skipprefix \Etoc@global\def\Etoc@prefix{\@empty}\fi \global\Etoc@skipprefixfalse \Etoc@lxyz{#2}{#3}{#4}% \Etoc@prefix \Etoc@contents } % \end{macrocode} % A \textbf{breaking change} is made at \etocrelease{1.1a}: \csbc{etoclink} % will always create an hyperlink, even in case of \ctanpkg{hyperref} being % (possibly locally) configured to obey |linktoc=none|. Formerly, in such % case, \csbc{etoclink} added no hyperlink because \etoc identified the % hyperlink target from the \ctanpkg{hyperref} hacked arguments of % \csa{l@section} et al, rather than picking it from the fourth argument of % \csa{contentsline}. % % Another \textbf{breaking change} (documented only at \etocrelease{1.1b}): % all three of \csbc{etocthelinkedname}, \csbc{etocthelinkednumber}, and % \csbc{etocthelinkedpage} are always hyperlinks (for the latter, only if page % number is not empty to match \ctanpkg{hyperref} ways). Formerly they obeyed % the |linktoc| status, somewhat counterintuitively, but this meant that % \csbc{etocname} etc... were their robust variants, which meant one could % store easily for later usage (see the documentation examples with % ``treetoks'') their precise meaning. The breaking change happened in part % because I was fooled myself by the macro names, and refactored the code in % two steps separated by months so in second step I forgot I had only % provisory code. And I decided finally to keep the breaking change. % % Under |linktoc=page| option, \ctanpkg{hyperref} has a ``feature'' to add one % level of bracing to first argument of the \csa{l@section} etc macros. So % for \etoc |<1.1a| this meant some extra work to dig into such a possible % brace pair to check if the entry was numbered. At \etocrelease{1.1a}, the % \ctanpkg{hyperref} modified \csa{contentsline} is not executed, hence there % is no such complication. But the trimming of the now unneeded branches was % not yet done at \etocrelease{1.1a}, \etocrelease{1.1b}, and got completed % only at \etocrelease{1.1c}, together with some renamings and refactoring. % \begin{macrocode} \def\Etoc@lxyz #1#2#3{% \ifEtoc@hyperref \Etoc@global\def\etocthelink##1{\hyperlink{#3}{##1}}% \else \Etoc@global\let\etocthelink\@firstofone \fi \Etoc@global\def\etocthepage {#2}% % \end{macrocode} % Prior to \etocrelease{1.1a} an hyperlink was incorporated into % \csbc{etocthelinkedpage} only if \ctanpkg{hyperref} added an hyperlink to % the page number, i.e.\@ under |linktoc=page| or |linktoc=all| (and a non % empty page number). With \etocrelease{1.1a}, the hyperlink is always added % (if a non empty page number). % \begin{macrocode} \ifEtoc@hyperref \ifx\etocthepage\@empty \Etoc@global\let\etocthelinkedpage\@empty \else \Etoc@global\def\etocthelinkedpage{\hyperlink {#3}{#2}}% \fi \else \Etoc@global\let\etocthelinkedpage\etocthepage \fi % \end{macrocode} % Define \csbc{etocthename} but this will perhaps be adjusted later if it is % found out that the entry was numbered. % \begin{macrocode} \Etoc@global\def\etocthename{#1}% % \end{macrocode} % Now we check if the entry is numbered and disentangle the number from the % name to define correctly \csbc{etocthename} and \csbc{etocthenumber}. The % delimiter tokens were modified at \etocrelease{1.1c} for a slight % optimization. And secondary macros have less to do since the % \etocrelease{1.1a} initiated refactoring. % \begin{macrocode} \futurelet\Etoc@getnb@token\Etoc@@getnb #1\hspace\etoc@ % \end{macrocode} % Even if \csbc{etocthenumber} was let to \csa{@empty}, it may happen in % special circumstances (related to KOMA-script, see below) that % \csbc{etocthename} got redefined. We will thus use its current contents to % define appropriately \csbc{etocthelinkedname}. % % In presence of \ctanpkg{hyperref} we let always \csbc{etocthelinkedname} and % \csbc{etocthelinkednumber} (for a numbered entry) carry an hyperlink. This % is a \textbf{breaking change} at \etocrelease{1.1a}: formerly if the TOC (or % the specific entry in the |.toc| file, as it is always possibly to inject % \csa{hypersetup}) was typeset under |linktoc=none| or |linktoc=page| status, % then no hyperlinks were incorporated. This is how \csbc{etocthename} and % \csbc{etocthenumber} are configured, but \csbc{etocthelinkedname} and % \csbc{etocthelinkednumber} will since \etocrelease{1.1a} always be % hyperlinked in presence of \ctanpkg{hyperref}. % \begin{macrocode} \ifEtoc@hyperref \def\Etoc@tmp##1##2{\Etoc@global\def##2{\hyperlink{#3}{##1}}}% \expandafter\Etoc@tmp\expandafter{\etocthename}\etocthelinkedname \ifEtoc@numbered \expandafter\Etoc@tmp\expandafter{\etocthenumber}\etocthelinkednumber \else \Etoc@global\let\etocthelinkednumber\@empty \fi \else \Etoc@global\let\etocthelinkedname \etocthename \Etoc@global\let\etocthelinkednumber\etocthenumber \fi % \end{macrocode} % Defaults in absence of \ctanpkg{hyperref}. We externalize to another % macro the \ctanpkg{hyperref} case switch. % \begin{macrocode} \Etoc@global\expandafter\let\csname etoclink \endcsname \etocthelink \Etoc@global\expandafter\let\csname etocname \endcsname \etocthename \Etoc@global\expandafter\let\csname etocnumber \endcsname\etocthenumber \Etoc@global\expandafter\let\csname etocpage \endcsname \etocthepage \ifEtoc@hyperref \Etoc@lxyz@linktoc \fi } % \end{macrocode} % In presence of \ctanpkg{hyperref}, \etoc \etocrelease{1.1a} imports the % \ctanpkg{hyperref} own logic and tests \csa{Hy@linktoc} to decide if % \emph{name}, \emph{number} and \emph{page} get hyperlinks. This adds a % dependency that \csa{Hy@linktoc} should exist and have the expected % interpretation. % \begin{shaded} % \setstretch{1}% % \textbf{MEMO:} \emph{Matters of tagging will have to wait for \LaTeX\ itself % to show me what it does in \csa{l@section} etc... so that I can imitate.} % % Updated 2023/02/26: this is now partly available and gave me an idea of % what will be needed here. As the \etoc way goes through none of the % \LaTeX{} hook points, I will have to add the suitable \csa{UseHook} at % various places, after having stored the \csa{contentsline} original % arguments in the same macros as the \LaTeX{} new kernel code will do. % % Some difficulties though in perspective as \etoc separates name and number % and has no concept akin to \csa{@dottedtocline}. Also if the user employs % \csbc{etocsetstyle} with \csa{l@section}, hooks may be executed twice if I % put them not in \csbc{etocname} but in the \marg{prefix} and \marg{content} % parts for each level.\par % \end{shaded} % \begin{macrocode} \def\Etoc@lxyz@linktoc{% \ifcase\Hy@linktoc % \end{macrocode} % none: nothing to do % \begin{macrocode} \or % \end{macrocode} % section (aka name for etoc): link name and number % \begin{macrocode} \Etoc@global\expandafter\let\csname etocname \endcsname\etocthelinkedname \Etoc@global\expandafter\let\csname etocnumber \endcsname\etocthelinkednumber \or % page \Etoc@global\expandafter\let\csname etocpage \endcsname\etocthelinkedpage \else % all \Etoc@global\expandafter\let\csname etocname \endcsname\etocthelinkedname \Etoc@global\expandafter\let\csname etocnumber \endcsname\etocthelinkednumber \Etoc@global\expandafter\let\csname etocpage \endcsname\etocthelinkedpage \fi } % \end{macrocode} % Now for the disentangling of the ``number'' from the ``name''. % % At some point we will pick up the first token and check if it is % \csa{numberline} or like token to identify a numbered entry. % But this step can cause brace removal so we \csa{futurelet} to % peek ahead. % % Prior to \etocrelease{1.1a} it could be possible that the first token following % \csbc{Etoc@@getnb} was an opening brace and nevertheless the entry was % numbered, because of a \ctanpkg{hyperref} ``feature'' in case of % |linktoc=page| option. But at \etocrelease{1.1a}, \etoc handles directly the argument % of \csa{contentsline} so the presence of an opening brace implies the entry % is not numbered. For some reason \etocrelease{1.1a} kept the extra code to check in % case the next token was an opening brace whether the whole entry was braced, % which would have been indicative in the past (but not at \etocrelease{1.1a}) of a % |linktoc=page| context (\etoc prior to \etocrelease{1.1a} never tested the value of % \csa{Hy@linktoc} as it did not want to be dependent on details of % \ctanpkg{hyperref} handling of options). This legacy, now superfluous, code % branch is removed at \etocrelease{1.1c}, bringing some simplification here, in % particular the removal of an \csa{ifEtoc@bracedname} boolean. Also, when % branching from here to the \csbc{Etoc@getnb@nonbr}, we won't need to check % if the entry had a special ``Part'' syntax, which is another simplification. % % The |@nonbr| means ``no number'', and is not to be misinterpreted as % ``non braced''... (this was more confusing to the author on return to % \etoc code, when it still had branches % handling issues described above with an extra brace pair). % \begin{macrocode} \def\Etoc@@getnb {% \let\Etoc@next\Etoc@getnb \ifx\Etoc@getnb@token\@sptoken\let\Etoc@next\Etoc@getnb@nonbr\fi \ifx\Etoc@getnb@token\bgroup \let\Etoc@next\Etoc@getnb@nonbr\fi \Etoc@next } % \end{macrocode} % \etocrelease{1.08n} tries to handle reasonably the \csa{nonumberline} of % \ctanpkg{KOMA-script}. If it expands to |\numberline{}|, \etoc will % consider the line numbered with an empty number (afaict, the meaning of % \csa{nonumberline} is either empty or \csa{numberline}|{}|). This got % modified at \etocrelease{1.1c} (see below). % % At \etocrelease{1.09f} we get rid of the \csa{nonumberline} from inside % \csbc{etocthename} when it has empty meaning, so the expansion of the latter % can safely be delayed by custom section styles (for example if the build up % some token list to be executed later not immediately). \etocrelease{1.1c} fixes a % regression committed at \etocrelease{1.1a}: for a \csa{nonumberline} with empty % meaning the \csbc{etocthelinkedname} did not end up hyperlinked. % % A change, almost a bug fix, but the former behavior was actually % deliberate, at \etocrelease{1.1c} regarding the KOMA-script \csa{nonumberline} % token: formerly, when it expanded to \csa{numberline}|{}| (this % can happen only when the TOC is typeset in compatibility mode for % the global display) then \csbc{ifEtoc@numbered} was set to true. % But this is only a KOMA-script typesetting thing, and should not % have influenced \etoc's decisions when its (user or package) own % line styles are used: at \etocrelease{1.1c} it is thus decided that in such % circumstances the \csbc{etocifnumbered} will pick the false % branch, and the empty \csbc{etocthelinkednumber} will not be % hyperlinked. % % No brace removal of the |#1| here a priori possible because we took care to % check that \csbc{Etoc@getnb} was not followed by either a space or an % opening brace. % % The \csbc{Etoc@@getit} branch for ``Parts'' used to be executed from inside % \csbc{Etoc@lxyz}. At \etocrelease{1.1c} we jump directly to it from here. % \begin{macrocode} \def\Etoc@getnb #1{% \in@{#1}{\numberline\chapternumberline\partnumberline\booknumberline}% \ifin@ \let\Etoc@next\Etoc@getnb@nmbrd \else \ifnum\Etoc@level=\m@ne \let\Etoc@next\Etoc@@getit \else \let\Etoc@next\Etoc@getnb@nonbr \fi % \end{macrocode} % Remove a KOMA-script \csa{nonumberline} token if present and process the % entry always as not numbered (see above comments). Prior to \etocrelease{1.1c}, the % code branched according to the meaning of the \csa{nonumberline} token, % which was a bit silly. % \begin{macrocode} \in@{#1}{\nonumberline}% \ifin@ \let\Etoc@next\Etoc@getnb@nonumberline \fi \fi \Etoc@next #1% } % \end{macrocode} % Prior to \etocrelease{1.1a}, \csbc{etocthelinkedname} and \csbc{etocthelinkednumber} % (for a numberd entry) were defined to carry links only if an hyperlink was % actually found, now they are defined in \csbc{Etoc@lxyz} to always provide % the hyperlinking to the target title in the document. % % \etocrelease{1.1a} and \etocrelease{1.1b} still had here some superfluous % code which was trimmed at \etocrelease{1.1c}. % % Also, \etocrelease{1.1c} fixes here a brace removal bug (which had always been there I % guess): if the numbered heading title was braced one level of bracing was % removed. The bug had no effect in a document using \ctanpkg{hyperref} (and % its default |linktoc| setting) as the \csa{hyperlink} wrapper limited the % scope. But in a document without hyperref it would have been seen with % input such as |\section{{\color{blue}Stuff}}|. % \begin{macrocode} \def\Etoc@getnb@nmbrd #1#2{% \Etoc@global\Etoc@numberedtrue \Etoc@global\def\etocthenumber {#2}% \Etoc@getnb@nmbrd@getname\@empty }% % \end{macrocode} % We added an \csa{@empty} token to prevent brace removal. % \begin{macrocode} \def\Etoc@getnb@nmbrd@getname #1\hspace\etoc@ {% \Etoc@global\expandafter\def\expandafter\etocthename\expandafter{#1}% } % \end{macrocode} % Not numbered entry. % \begin{macrocode} \def\Etoc@getnb@nonbr #1\etoc@ {% \Etoc@global\Etoc@numberedfalse \Etoc@global\let\etocthenumber \@empty } % \end{macrocode} % Special KOMA branch: |#1| starts with \csa{nonumberline} (prior to \etocrelease{1.1c} % the |#1| would have already lost this token, and this branch was executed % only in case \csa{nonumberline} had empty meaning). We need to remove this % token from |#1| and redefine \csbc{etocthename}. % % \etocrelease{1.1a} code still had here some complications with a ``braced name'' branch % which was in fact never executed at \etocrelease{1.1a}, as the \ctanpkg{hyperref} hacks % into the expansion of \csa{contentsline} were not executed. These now % unneeded complications got removed at \etocrelease{1.1c}. % % \etocrelease{1.1c} also fixes a regression caused by \etocrelease{1.1a} in this branch: the % \csbc{etocthelinkedname} had lost its hyperlink. % % The \csa{nonumberline} extra token guarantees no brace stripping here. % \begin{macrocode} \def\Etoc@getnb@nonumberline #1\hspace\etoc@ {% \Etoc@global\Etoc@numberedfalse \Etoc@global\let\etocthenumber \@empty \Etoc@global\expandafter\def\expandafter\etocthename\expandafter{\@gobble#1}% } % \end{macrocode} % This branch handles the peculiar ``Part'' syntax. No brace stripping % possible here when grabbing |#1|, due to previous checks that it does % not start by a space token or an opening brace. % % \etocrelease{1.1c} handles this as a sub-branch from \csbc{Etoc@@getnb} which brings % simplifications. Also the code has been somewhat strengthened so as to % avoid in later processing a brace removal issue on the name (which was a bug % of legacy earlier code), when it turns our we are handling a numbered Part % indeed. % % The whole thing is anyhow quite fragile due to \LaTeX{}'s handling by % standard classes of |.toc| file entries for parts being even more already % pre-formatted for typesetting than for other levels. % \begin{macrocode} \def\Etoc@@getit #1\hspace#2{% \ifx\etoc@#2% \Etoc@global\Etoc@numberedfalse \Etoc@global\let\etocthenumber \@empty \else \Etoc@global\Etoc@numberedtrue \Etoc@global\def\etocthenumber {#1}% \expandafter\Etoc@getit@getname \expandafter\@empty \fi } % \end{macrocode} % Chain of \csa{expandafter}'s to get rid of the added \csa{@empty} token to % avoid a brace removal. And this is the end of the \etocrelease{1.1a} refactoring, % completed at \etocrelease{1.1c}. % \begin{macrocode} \def\Etoc@getit@getname #1\hspace\etoc@ {% \Etoc@global\expandafter\def\expandafter\etocthename\expandafter{#1}% } % \end{macrocode} % place-holder % \begin{macrocode} \let\etocthename \@empty \let\etocthenumber \@empty \let\etocthepage \@empty \let\etocthelinkedname \@empty \let\etocthelinkednumber \@empty \let\etocthelinkedpage \@empty \let\etocthelink \@firstofone \DeclareRobustCommand*{\etocname} {} \DeclareRobustCommand*{\etocnumber}{} \DeclareRobustCommand*{\etocpage} {} \DeclareRobustCommand*{\etoclink} {\@firstofone} \DeclareRobustCommand*{\etocifnumbered} {\ifEtoc@numbered\expandafter\@firstoftwo\else\expandafter\@secondoftwo\fi} \expandafter\let\expandafter\etocxifnumbered\csname etocifnumbered \endcsname \DeclareRobustCommand*{\etociffirst} {\ifEtoc@isfirst\expandafter\@firstoftwo\else\expandafter\@secondoftwo\fi} \expandafter\let\expandafter\etocxiffirst\csname etociffirst \endcsname \def\Etoc@readtoc {% \ifeof \Etoc@tf \else \read \Etoc@tf to \Etoc@buffer \Etoc@toctoks=\expandafter\expandafter\expandafter {\expandafter\the\expandafter\Etoc@toctoks\Etoc@buffer}% \expandafter\Etoc@readtoc \fi } % \end{macrocode} % \etocrelease{1.07m} moves the reading of the toc file At Begin Document. Needed for % Babel activated characters.\par^^A extra \par needed to avoid empty line... % \begin{macrocode} \Etoc@toctoks {}% (superfluous, but for clarity) \AtBeginDocument{\IfFileExists{\jobname.toc} {{\endlinechar=\m@ne \makeatletter \newread\Etoc@tf \openin\Etoc@tf\@filef@und \Etoc@readtoc \global\Etoc@toctoks=\expandafter{\the\Etoc@toctoks}% \closein\Etoc@tf}} {\typeout{No file \jobname.toc.}}} % \end{macrocode} % \etocrelease{1.2c} removes a legacy test it had copied over % from \ctanpkg{hyperref} internals, whose purpose was to check % if the |.toc| file had been produced in an earlier % no-hyperref pass, which in the past would trigger % failure. For specifics see % \url{https://github.com/latex3/hyperref/issues/305}. % \begin{macrocode} \def\Etoc@openouttoc{% \if@filesw \newwrite \tf@toc \immediate \openout \tf@toc \jobname .toc\relax \fi \global\let\Etoc@openouttoc\empty } % \end{macrocode} % The |\gdef\Etoc@stackofends{{-3}{}}| is in theory superfluous as normally % this stack should always have been restored on exit to its initial state, % but... % % It would perhaps be better to issue here \csa{Etoc@notactivetrue}, prior to % |\the\Etoc@toctoks| but it is up to the caller macros to do it. % \csbc{Etoc@minf} is a level which is lower (i.e. more encompassing than all % others), so numerically \texttt{-2} for standard classes and \texttt{-3} for % \ctanpkg{memoir} class. % % The \csbc{Etoc@doendsandbegin} will not try to execute a (non-existing) % ``begin'' macro for the level \texttt{-3}. % \begin{macrocode} \def\Etoc@toctoc{% \gdef\Etoc@stackofends{{-3}{}}% \global\let\Etoc@level\Etoc@minf \global\let\Etoc@virtualtop\Etoc@minf \the\Etoc@toctoks \ifEtoc@notactive \else \gdef\Etoc@level{-\thr@@}% \Etoc@doendsandbegin \fi } % \end{macrocode} % Memo: \csbc{etoclocaltop} has only meaningful meaning when the toc is local % and is ``active''. Except that I used a "notactive" flag to torture myself, % so: has the \csbc{ifEtoc@notactive} flag set to |false|. % % The \etocrelease{1.2} removal of usage of boolean flags associated to % the levels has made the next definition more succinct. Their former r\^ole is % picked up by \csbc{Etoc@level}. % % MEMO: the \csbc{etoclocaltableofcontentshook} has been added during development % \etocrelease{1.2} probably for reasons of symmetry with handling of the % local ``lists of'' code, but at time of release I can't remember clearly. % Hesitation where to put it exactly. % % \etocrelease{1.2} adds a \csbc{Etoc@@startlocaltochook} for a refactoring of % \csbc{localtableofcontentswithrelativedepth}. It also serves to make the % emptiness check with local ``lists of'', as will be seen further down. % \begin{macrocode} \def\Etoc@@startlocaltoc#1#2{% \ifEtoc@localtoc \ifnum #1=#2\relax \global\let\etoclocaltop\Etoc@virtualtop \Etoc@@startlocaltochook \etoclocaltableofcontentshook % \end{macrocode} % The \csbc{ifEtoc@etocstyle} boolean is true when \etoc is left in its default % mode (no usage of \csbc{etocsettocstyle} or \csbc{etocclasstocstyle}). It % inhibits \csbc{Etoc@tableofcontents} from using the specified % \marg{before\string_toc} and \marg{after\string_toc} from usage of % \csbc{etocsettocstyle}. And here we can insert the code we wish to do the % title. % % \begin{shaded} % \setstretch{1}% % \textbf{MEMO}: for legacy reason \etoc shares a lot of code between global TOC and % local TOCs. But it would probably have been better to separate the two and % provide an \csa{etocsetlocaltocstyle} that the user can use in preamble. % As it stands \csbc{etocsettocstyle} if used in preamble also influences the % global TOC, so basically one has to use it again after it (if it comes first % in the document). % \end{shaded} % % The \csa{ifEtoc@ouroboros} mechanism when it is set to false appears rather % audacious. % \begin{macrocode} \ifEtoc@etocstyle \etocetoclocaltocmaketitle \fi \ifx\Etoc@aftertitlehook\@empty \else \ifEtoc@localtoctotoc \ifEtoc@ouroboros \else \let\Etoc@tmp\contentsline \def\contentsline{\let\contentsline\Etoc@tmp\Etoc@gobblethreeorfour}% \fi \fi \fi \global\Etoc@notactivefalse \fi \fi } \let\etoc@startlocaltoc\@gobble \let\Etoc@@startlocaltoc@toc\Etoc@@startlocaltoc \let\Etoc@@startlocaltochook\@empty \unless\ifEtoc@deeplevels % \end{macrocode} % This only hard-codes the built-in \LaTeX\ defaults. % \begin{macrocode} \def\etocdivisionnameatlevel#1{% \ifcase\numexpr#1\relax \ifdefined\c@chapter chapter\else section\fi% \or section% \or subsection% \or subsubsection% \or paragraph% \or subparagraph% \or empty% \else\ifnum\numexpr#1<\m@ne book% \else part% \fi \fi } \else % \end{macrocode} % The definition given to \csbc{etocdivisionnameatlevel} in the % \etocoption{deeplevels} branch is only needed if one wants to locate a % local table of contents at a deep place, and one has not made use of % \csbc{etocsettocstyle} to configure the heading by oneself. I have % used in the default definition the headings as in the % \href{https://github.com/doxygen/doxygen/}{Doxygen} \LaTeX{} templates % originating in the % \href{https://github.com/doxygen/doxygen/pull/9936}{Doxygen\#9936} PR. % \begin{macrocode} \def\etocdivisionnameatlevel#1{% \ifcase\numexpr#1\relax \ifdefined\c@chapter chapter\else section\fi% \or section% \or subsection% \or subsubsection% \or subsubsubsection% \or subsubsubsubsection% \or subsubsubsubsubsection% \or subsubsubsubsubsubsection% \or paragraph% \or subparagraph% \else\ifnum\numexpr#1>\z@ empty% \else\ifnum\numexpr#1=\m@ne part% \else book% \fi\fi \fi } \fi \def\etoclocalheadtotoc#1#2{\addcontentsline{toc}{@#1}{#2}} \def\etocglobalheadtotoc{\addcontentsline{toc}} % \end{macrocode} % I have coded this so that it can be copied pasted to a user document and % customized at will. \etocrelease{1.2a} uses a better test for knowing if % the starred command of previous line created an inline heading with % \csa{everypar}: \etocrelease{1.2} simply tested if \csbc{etoclocaltop} was % at least |3| but this does not scale well with \etocoption{deeplevels}. % Only worry here is whether the \csa{if@noskipsec} thing really works with % all document classes. At least it is in \LaTeX{} kernel.\par^^A pénible % \begin{macrocode} \providecommand*\UseName{\@nameuse} \def\etocetoclocaltocmaketitle{% \UseName{\etocdivisionnameatlevel{\etoclocaltop+1}}*{\localcontentsname}% \if@noskipsec\leavevmode\par\fi \etociflocaltoctotoc {\etocifisstarred {}% star variant, do not add to toc {\etoclocalheadtotoc {\etocdivisionnameatlevel{\etoclocaltop+1}}% {\localcontentsname}% }% }% {}% }% % \end{macrocode} % In dev, I used \csa{etoc} prefix for the next two, but I % decided to drop it for release. % \begin{macrocode} \def\localcontentsname {\contentsname}% \let\etoclocaltableofcontentshook\@empty % \end{macrocode} % The big thing at \etocrelease{1.2}: experimental support code for % \csbc{locallistoffigures} and \csbc{locallistoftables}! There were two % possibilities to implement the `localtoc' mechanism: either add some extra % things to the |.lof| and |.lot| files, or get their data duplicated in the % |.toc| file. I have chosen for time being the latter path, hence this goes % via hacking into \csa{addcontentsline} and it must be the case that the % document class uses it (from \csa{caption}). If some package has modified % the implementation of captions of figures and tables and insertes data in % the |.lof| or |.lot| files directly via \csa{addtocontents} for example % and not via \csa{addcontentsline}, then the \etoc mechanism will fail. % \begin{macrocode} \if1\ifEtoc@lof0\fi\ifEtoc@lot0\fi1% \else \AtBeginDocument{% \let\Etoc@originaladdcontentsline\addcontentsline \def\addcontentsline{\Etoc@hackedaddcontentsline}% }% \fi % \end{macrocode} % For optimization of execution speed we define the macro conditionnally on % the option status (wihch is frozen). In the first case, |#1=lof,.lot| would % work but this is not realistic. % \begin{macrocode} \ifEtoc@lof \ifEtoc@lot \def\Etoc@hackedaddcontentsline#1{% \expanded{\noexpand\in@{.#1,}}{.lof,.lot,}% \ifin@\expandafter\Etoc@hackedaddcontentsline@i \else\expandafter\Etoc@originaladdcontentsline \fi {#1}} \else \def\Etoc@hackedaddcontentsline#1{% \expanded{\noexpand\in@{.#1,}}{.lof,}% \ifin@\expandafter\Etoc@hackedaddcontentsline@i \else\expandafter\Etoc@originaladdcontentsline \fi {#1}} \fi \else \def\Etoc@hackedaddcontentsline#1{% \expanded{\noexpand\in@{.#1,}}{.lot,}% \ifin@\expandafter\Etoc@hackedaddcontentsline@i \else\expandafter\Etoc@originaladdcontentsline \fi {#1}} \fi % \end{macrocode} % This business of \csa{protected@file@percent} is not really needed as anyhow % \etoc reads the |.toc| file with no space token from end of lines. % \begin{macrocode} \def\Etoc@hackedaddcontentsline@i#1#2#3{% \expanded{\noexpand\in@{.#1;#2,}}{.lof;figure,.lot;table,}% \ifin@ \addtocontents {toc}{% \protect\contentsline{#2}{#3}{\thepage}{\ifEtoc@hyperref\@currentHref\fi}% \ifdefined\protected@file@percent\protected@file@percent\fi }% \fi \Etoc@originaladdcontentsline{#1}{#2}{#3}% } % \end{macrocode} % The two macros need to be redefined if \csa{expanded} is not provided by the % engine. Here we leave some tests done at execution time although they could % have been done (as above) here at definition time. % \begin{macrocode} \unless\ifdefined\expanded \def\Etoc@hackedaddcontentsline#1{% {\edef\Etoc@tmp{\noexpand\in@{.#1,}{\ifEtoc@lof.lof,\fi\ifEtoc@lot.lot,\fi}}\expandafter}% \Etoc@tmp \ifin@\expandafter\Etoc@hackedaddcontentsline@i \else\expandafter\Etoc@originaladdcontentsline \fi {#1}% } \def\Etoc@hackedaddcontentsline@i#1#2#3{% {\edef\Etoc@tmp{\noexpand\in@{.#1;#2,}}\expandafter}% \Etoc@tmp{.lof;figure,.lot;table,}% \ifin@ \addtocontents {toc}{% \protect\contentsline{#2}{#3}{\thepage}{\ifEtoc@hyperref\@currentHref\fi}% \ifdefined\protected@file@percent\protected@file@percent\fi }% \fi \Etoc@originaladdcontentsline{#1}{#2}{#3}% } \fi % \end{macrocode} % We will simply let \csbc{locallistoffigures} and \csbc{locallistoftables} % use \csbc{localtableofcontents}. We need some dedicated variant of % \csbc{Etoc@@startlocaltoc}. Hesitation where to put % \csbc{Etoc@@startlocaltochook} which has multiple usages. % \begin{macrocode} \def\Etoc@@startlocallistof#1#2#3{% \ifEtoc@localtoc \ifnum #2=#3\relax \global\let\etoclocaltop\Etoc@virtualtop \global\Etoc@notactivefalse \Etoc@@startlocaltochook \csname etoclocallistof#1shook\endcsname \ifEtoc@etocstyle \csname etocetoclistof#1smaketitle\endcsname \fi \fi \fi } \def\Etoc@@startlocallistof@setlevels#1{% % \end{macrocode} % |#1| is |figure| or |table|. % % \csbc{etoclocaltop} represents the level which will stop the local ``list % of'' contents. I hesitated whether local ``lists of'' should obey the % |tocdepth|, especially a varying one. Finally at last minute I opted for % ``Yes'', so in the end no alteration of |tocdepth| will be done here. We % will set the level to have value % \centeredline{|min(1, |\csbc{etoclocaltop}|+1)|} % At least |1|, because it really would not make % sense to show figure entries as chapter entries for a local list of figures % in a Part (if the user has for example set the % \csbc{etoclocallistoffigureshook} to do nothing, so that the line styles as % configured via \csbc{etocsetstyle} are not avoided). And it must be greater % than \csbc{etoclocaltop} else such an entry would terminate the scope of the % local contents. % % In the default context which has issued via % \csbc{etoclocallistoffigureshook} a local \csbc{etocstandardlines}, the % actual value of the level only has a ``all or nothing'' meaning: if it is % greater than |tocdepth| then the \csbc{Etoc@etoccontentsline} will not call % \csa{contentsline}, else it will and then the code from document class will % kick in. The |article| class defines \csa{l@figure} as % \centeredline{|\@dottedtocline {1}{1.5em}{2.3em}|} % And we are here in a context where necessarily |tocdepth| is at least |1| % (if it was |0| or less, as the level has been set to at least |1|, the entry % would have been filtered out earlier by \csbc{Etoc@etoccontentsline}), so % the line will show. And if \csbc{etoclocallistoffigureshook} was modified % and did not issue \csbc{etocstandardlines} and we are in this situation that % the |tocdepth| comparison did not inhibit the entry, then it will show too, % at least if the line style does not say to do nothing (notice that the \etoc % fall-back line styles are configured to do nothing for paragraph and % subparagraph entries). % % On the other hand if the |tocdepth| inhibits entries of level % \csbc{etoclocaltop}|+1|, then a \csbc{localtableofcontents} at this level % would display no contents, so why should it not also mute % \csbc{locallistoffigures}? % % This change to the level \csbc{Etoc@figure@@} or \csbc{Etoc@table@@} is done % only locally, no need to worry about collaterals after the ``List of''. % \begin{macrocode} \ifnum\etoclocaltop<\z@ \expandafter\let\csname Etoc@#1@@\endcsname\@ne \else \expandafter\let\csname Etoc@#1@@\expandafter\endcsname \csname Etoc@\the\numexpr\etoclocaltop+\@ne @@\endcsname \fi % \end{macrocode} % We now make invisible all level names whose numerical level would have % allowed them to show in these contents. |figure| and |table| are never % included in the \csbc{Etoc@dolevels} no danger to cancel them out. The % special level names |@section| etc... which are inserted by headings of % local ``lists of'' or local TOCs under \etocoption{localloftotoc} and other % options have been made invisible by \csbc{Etoc@listofhook}, no need to do % anything about them here. % \begin{macrocode} \def\Etoc@do##1{% \ifnum\etoclevel{##1}>\etoclocaltop \expandafter\let\csname Etoc@##1@@\endcsname\Etoc@maxlevel \fi}% \Etoc@dolevels } % \end{macrocode} % Let's for time being configure the figure and table lines to be rendered as % in class default. % % Ah, I remember why I added \csbc{etoclocaltableofcontentshook} above. It is % by symmetry as I had defined those next two already. % \begin{macrocode} \def\etoclocallistoffigureshook{\etocstandardlines} \def\etoclocallistoftableshook {\etocstandardlines} % \end{macrocode} % Here is some info about usage of \csbc{etoclocallistoffigureshook}, for % those who end up here from having clicked on the name from the user % manual. Its default as above means to use the class default for lines in % \csa{listoffigures}. If you redefine it to be empty, the effect is that % (except of course if \csbc{etocstandardlines} has been issued globally) the % figure lines will adopt the style configured for level % \csbc{etoclocaltop}|+1| (or more precisely the minimum of that and of |1|). % You can definitely put into the hook some % \centeredline{\csbc{etocsetstyle}|{\number\etoclevel{figure}}{}{}{...}{}|} % where the dots represent some code with \csbc{etocnumber}, \csbc{etocname}, % \csbc{etocpage}, itself possibly querying \csbc{etoclevel}|{figure}|, or % perhaps \csbc{etoclocaltop} to know the actual depth (which may the one of a % Part which can thus be distinguished from being in a Chapter, whereas % \csa{number}\csbc{etoclevel}|{figure}| will give |1| in both cases). % % There is variant which is to maintain the default \csbc{etocstandardlines} % in the hook and then re-define the kernel macro \csa{l@figure} to do the % desired thing. For example the default with |article| is for \csa{l@figure} % to do {|\@dottedtocline {1}{1.5em}{2.3em}|} so you can do some variant where % the second and third argument (indent and numwidth) are set according to % \csbc{etoclocaltop}. % % I hope the above explanations help, they appear too advanced for inclusion % in the user manual so I give them here. % % In dev, I used \csa{etoc} prefix here, but I decided to drop it for release. % \begin{macrocode} \def\locallistfigurename{\listfigurename} \def\locallisttablename {\listtablename} % \end{macrocode} % Same observations as for \csbc{etocetoclocaltocmaketitle}. % \begin{macrocode} \def\etocetoclistoffiguresmaketitle{% \UseName{\etocdivisionnameatlevel{\etoclocaltop+1}}*{\locallistfigurename}% \ifnum\etoclocaltop>\tw@\mbox{}\par\fi \etociflocalloftotoc {\etocifisstarred {}% star variant, do not add to toc {\etoclocalheadtotoc {\etocdivisionnameatlevel{\etoclocaltop+1}}% {\locallistfigurename}% }% }% {}% }% \def\etocetoclistoftablesmaketitle{% \UseName{\etocdivisionnameatlevel{\etoclocaltop+1}}*{\locallisttablename}% \ifnum\etoclocaltop>\tw@\mbox{}\par\fi \etociflocallottotoc {\etocifisstarred {}% star variant, do not add to toc {\etoclocalheadtotoc {\etocdivisionnameatlevel{\etoclocaltop+1}}% {\locallisttablename}% }% }% {}% }% % \end{macrocode} % The local lists of do support the |\label/\ref| syntax as we are careful % here to position \csbc{localtableofcontents} as last token. % % The reset to \csa{@empty} of the \csa{Etoc@listofreset} is not strictly % needed as the other things can always be done with no harm. % \begin{macrocode} \let\Etoc@listofreset\@empty % \end{macrocode} % Memo: \csa{ext@toc} defined in KOMA and memoir but not in the standard classes. % \begin{macrocode} \ifEtoc@lof \def\locallistoffigures{% \def\Etoc@listofreset{% \let\Etoc@currext\Etoc@tocext \let\Etoc@@startlocaltoc\Etoc@@startlocaltoc@toc \let\Etoc@@startlocaltochook\@empty \let\Etoc@listofreset\@empty % \end{macrocode} % The \csbc{Etoc@listofhook} is executed by \csbc{localtableofcontents}. It % will be used here to let local ``lists of'' ignore all the special |.toc| % entries whose level names start with a |@|. This is to avoid the scope % limiting detection of the local list of figures or tables from being % influenced by another list of, such as a list of tables following a list of % figures which has put its title inside the |.toc| due to |locallottotoc| % option of \etoc. % \begin{macrocode} \let\Etoc@listofhook\@empty }% \let\Etoc@currext\Etoc@lofext \def\Etoc@@startlocaltoc{\Etoc@@startlocallistof{figure}}% \def\Etoc@@startlocaltochook{\Etoc@@startlocallistof@setlevels{figure}}% \def\Etoc@listofhook{% \def\Etoc@do####1{% \expandafter\let\csname Etoc@@####1@@\endcsname\Etoc@maxlevel }% \Etoc@dolevels }% \localtableofcontents } \else \def\locallistoffigures{% \PackageError{etoc}{% \string\locallistoffigures \on@line\space but\MessageBreak package was loaded without `lof' option}% {Try again with \string\usepackage[lof]{etoc}}% } \fi \ifEtoc@lot \def\locallistoftables{% \def\Etoc@listofreset{% \let\Etoc@currext\Etoc@tocext \let\Etoc@@startlocaltoc\Etoc@@startlocaltoc@toc \let\Etoc@@startlocaltochook\@empty \let\Etoc@listofreset\@empty \let\Etoc@listofhook\@empty }% \let\Etoc@currext\Etoc@lotext \def\Etoc@@startlocaltoc{\Etoc@@startlocallistof{table}}% \def\Etoc@@startlocaltochook{\Etoc@@startlocallistof@setlevels{table}}% \def\Etoc@listofhook{% \def\Etoc@do####1{% \expandafter\let\csname Etoc@@####1@@\endcsname\Etoc@maxlevel }% \Etoc@dolevels }% \localtableofcontents } \else \def\locallistoftables{% \PackageError{etoc}{% \string\locallistoftable \on@line\space but\MessageBreak package was loaded without `lot' option}% {Try again with \string\usepackage[lot]{etoc}}% } \fi % \end{macrocode} % \csbc{Etoc@tocid} is the number of the toc (possibly gotten via a |\ref| % following a \csbc{tableofcontents}), or it is |\z@| if the emptiness test is % from a global toc. Until the compilations stabilize, some local TOCs can get % printed at wrong locations naturally and emptiness tests can not be trusted % either. % % Note: (\etocrelease{1.08i} |2016/09/29|) the code has to handle both local % and total toc. Hence the flag \csbc{ifEtoc@notactive} has to be set prior % to it. For a global toc, the \csbc{Etoc@tocid} was set to |\z@|, and the % |\ifnum| in \csbc{etoc@startlocaltoc} did always fail, but I now prefer to % simply nullify the \csbc{etoc@startlocaltoc}. As its default fallback is % |\@gobble| I simply test here for the \csbc{ifEtoc@localtoc} flag. The % \csbc{Etoc@tocid} will be undefined for a global toc but it is not tested % anymore. % % The initialization such as |\global\let\Etoc@level\Etoc@minf| is needed in % case the |.toc| file contains an \csbc{etoc@startlocaltoc} before any % \csa{contentsline}. % % Local list of figures and tables set especially the tocdepth and a hook is % added here for emptiness check to work correctly with them. % % MEMO: Should I also execute \csbc{etoclocaltableofcontentshook}? % Then I would need to set \csbc{etoclocallistoffigureshook} to redefine it, % rather than be inserted as itself. % \begin{macrocode} \def\Etoc@checkifempty {% \global\Etoc@isemptytoctrue \global\Etoc@stoptocfalse \global\let\Etoc@level\Etoc@minf \global\let\Etoc@virtualtop\Etoc@minf \gdef\Etoc@stackofends{{-3}{}}% \begingroup \ifEtoc@localtoc \def\etoc@startlocaltoc##1{% \ifnum##1=\Etoc@tocid\relax \global\let\etoclocaltop\Etoc@virtualtop \Etoc@@startlocaltochook \global\Etoc@notactivefalse \fi }% % \end{macrocode} % The mechanism is to check if any \csa{contentsline} triggers execution. % For this we replace the \etoc replacement by another replacement. % \begin{macrocode} \let\contentsline\Etoc@testingcontentslinelocal \else \let\contentsline\Etoc@testingcontentsline \fi \Etoc@storetocdepth % \end{macrocode} % This here is a \etocrelease{1.09i} added work-around to avoid usage of % \csbc{etocsetlocaltop.toc} which could cause the test of emptiness of a % global TOC to actually execute some start and finish parts in some cases. % \begin{macrocode} \let\Etoc@setlocaltop@doendsandbegin\@empty \the\Etoc@toctoks \Etoc@restoretocdepth \endgroup } \DeclareRobustCommand*\etocifwasempty {\ifEtoc@isemptytoc\expandafter\@firstoftwo\else\expandafter\@secondoftwo\fi } \expandafter\let\expandafter\etocxifwasempty\csname etocifwasempty \endcsname \def\Etoc@testingcontentslinelocal #1{% \ifEtoc@stoptoc \else \ifnum\csname Etoc@#1@@\endcsname=\Etoc@maxlevel \else \global\expandafter\let\expandafter\Etoc@level\csname Etoc@#1@@\endcsname \if @\@car#1\@nil\else\global\let\Etoc@virtualtop\Etoc@level\fi \ifEtoc@notactive \else % \end{macrocode} % \csbc{ifEtoc@notactive} is \csa{iffalse} in case of a local TOC once it has % encountered the \csbc{etoc@startlocaltoc} with matching id. So here % \csbc{etoclocaltop} has been set by \csbc{Etoc@@startlocaltoc} and we % compare to the new level encountered. If the latter is at most equal to % \csbc{etoclocaltop} this means the local TOC ends there and is empty, so we % set the \csbc{ifEtoc@stoptoc} to true, which will cause the subsequent % parsing to abort immediately. If it is greater we check how it compares to % the local required toc depth. If lower or equal we conclude the toc is not % empty, and toggle the flag to stop the parsing; if greater, we are still in % doubt and must continue. % \begin{macrocode} \ifnum\Etoc@level>\etoclocaltop \unless\ifnum\Etoc@level>\c@tocdepth \global\Etoc@isemptytocfalse \global\Etoc@stoptoctrue \fi \else \global\Etoc@stoptoctrue \fi \fi \fi \fi % \end{macrocode} % The \csa{@gobblethree} was added to the \LaTeX{} kernel for its 2020-02-02 % PL 5 release and we require 2020-10-01 since \etocrelease{1.1a}. % \begin{macrocode} \Etoc@gobblethreeorfour{}% } % \end{macrocode} % Test of emptiness of the global TOC (according to current setting of the % levels and a possibly evolving tocdepth). % \begin{macrocode} \def\Etoc@testingcontentsline #1{% \ifEtoc@stoptoc \else \ifnum\csname Etoc@#1@@\endcsname=\Etoc@maxlevel \else \unless\ifnum\csname Etoc@#1@@\endcsname>\c@tocdepth \global\Etoc@isemptytocfalse \global\Etoc@stoptoctrue \fi \fi \fi \Etoc@gobblethreeorfour{}% } % \end{macrocode} % \etocrelease{1.08e} lets \csbc{localtableofcontents} do a % first scan of the |.toc| file (as stored in \csbc{Etoc@toctoks}) to % determine if the table of contents will in fact end up empty. Only, % however if user has added \csbc{etocchecksemptiness} to document. % % If this optional emptiness check is positive, nothing is typeset. % The command \csbc{etocaftertochook} is still executed though. Other % ways were envisioned (like delimited macros) to determine this potential % emptiness, but in the end I opted for execution of the |.toc| file with % suitable definitions for \csa{contentsline} and % \csbc{etoc@startlocaltoc}. Notice though that if emptiness would result from % empty line styles, this can not be detected. Emptiness means ``no % \csa{contentsline} under the TOC scope''. % % For this detection of emptiness, assignments (here and in % \csbc{Etoc@testingcontentsline}) are made globally, I think this is the best % (just in case some portions of the |.toc| file turn out to be inside some % groups --- perhaps for some silly color assignments, etc... --- whose % boundaries do not necessarily respect unit levels). % % The flag \csbc{ifEtoc@tocwithid} discriminates between a \localtoc and a % \toc|\ref{foo}|; the latter could so far possibly refer to a local or also to % a global table of contents but release \etocrelease{1.08e} has deprecated the latter use % as it complicated the code, for something truly silly. Thus |\ref{foo}| must % now be with |foo| a label of a \emph{local} TOC. As a result \csbc{ifEtoc@tocwithid} is % less used now. % % In the case of a |\ref|ed-to toc whose label was just added hence is not yet % in the |.aux| file, \csbc{Etoc@tocid} is |0|. \etoc used to issue a warning to % run latex again and did no printing at all. Release \etocrelease{1.08e} in such cases % prints the heading (this may gain one compilation step). Emptiness test is % not executed as it would necessarily turn out positive and can not be % trusted anyhow. The TOC is declared non empty, which it probably is... % % Emptiness detection for local tables of contents (either from a % \csbc{localtableofcontents} or from a \csbc{tableofcontents}|\ref{localtoc}|) % can be trusted only when the |.toc| file has stabilized.The emptiness status % of a local TOC whose Id is not yet in the |.toc| is by necessity undecided % yet (and not to be trusted really as the numbering may have changed; only % when compilation runs settle is the emptiness status to be trusted). The % code declares the TOC non empty, as it will be in 95\% of use cases. % % Dropping support for \toc|\ref{globaltoc}| means here that when a TOC id is % not found in the |.toc| file we can assume it definitely has to be a local % TOC needing more compilations. The emptiness status is undecided, the code % declares the TOC non empty. % % \etocrelease{1.08i} |2016/09/29| now does \csa{Etoc@localtoctrue} right at the start (the % earlier code could have to handle table of contents which were actually % global, via the |\label/\ref| mechanism.) It does not rely on the |\ifnum| % automatically false in \csbc{Etoc@@startlocaltoc} due to the special values |0| % or |\z@| for \csbc{Etoc@tocid}, but simply leaves \csbc{etoc@startlocaltoc} to its % default |\@gobble|. The \csa{Etoc@isemptytocfalse} is upfront in case some % code using \csbc{etocifwasempty} is in user hooks. The default is to assume the % TOC non-empty as its contents are actually still unknown. Under the % \csa{Etoc@stoptoctrue} flag, the \csbc{Etoc@etoccontentsline} is more efficient now. % % The \csbc{ifEtoc@notactive} flag needs to be set before calling % \csbc{Etoc@checkifempty}. % % I hesitated with \etocrelease{1.08i} to write something to aux file in order to let % \LaTeX\ prompt the user for extra pass, after insertion of some new % \csa{localtableofcontents}, but finally I prefer to only trick \LaTeX\ into % telling about undefined references. % % The \csa{PackageWarning} approach has the advantage % that at least in Emacs/AUCTeX the |C-cC-c| will propose |LaTeX|, not |View|. % But perhaps some automated scripts checking |aux| file will not like the % extra line which is then removed in next pass, and could possibly do one % extra unneeded compilation to check |aux| file remains identical. Hence the % second approach. (edit |2017/10/23|: good thing I documented that! I had % completely forgotten that rationale, but I wonder if it is correct.) % % Also the \csa{PackageWarning} does not trigger a visible message % near the end of the log file or console output, contrarily to a % \centeredline{|LaTeX Warning: There were undefined references.|} % followed by a % \centeredline{|LaTeX Warning: Label(s) may have changed. Rerun to get cross-references right.|} % % Method used here seems to work fine also with |latexmk|: it does not seem to % induce it into making too many runs. % \begin{macrocode} \def\Etoc@localtableofcontents#1{% \gdef\etoclocaltop{-\@m}% \Etoc@localtoctrue \global\Etoc@isemptytocfalse \edef\Etoc@tocid{#1}% \ifnum\Etoc@tocid<\@ne \setbox0\hbox{\ref{Unknown toc ref \@secondoftwo#1. \space Rerun LaTeX}}% % \end{macrocode} % Do only heading, skip all the rest. % \begin{macrocode} \global\Etoc@stoptoctrue \gdef\etoclocaltop{-\thr@@}% \Etoc@tableofcontents \expandafter\Etoc@gobtoetoc@ \fi \global\Etoc@notactivetrue \ifEtoc@checksemptiness \Etoc@checkifempty \fi \ifEtoc@isemptytoc \ifEtoc@notactive \setbox0\hbox{\ref{Unknown toc ID \number\Etoc@tocid. \space Rerun LaTeX}}% % \end{macrocode} % Assume real one will be non-empty and print only heading for this pass. % \begin{macrocode} \global\Etoc@isemptytocfalse \global\Etoc@stoptoctrue \gdef\etoclocaltop{-\thr@@}% \Etoc@tableofcontents \expandafter\expandafter\expandafter\Etoc@gobtoetoc@ \fi \else \global\Etoc@stoptocfalse \global\Etoc@notactivetrue % \end{macrocode} % We can end up here either if the emptiness check was done and turned % negative (then \csbc{etoclocaltop} has the correct level for usage in first % argument of \csbc{etocsettocstyle}), or if the emptiness check was not done. % For the latter case \csbc{etoclocaltop} has setting |-\@m|. % \begin{macrocode} \edef\etoc@startlocaltoc##1% {\noexpand\Etoc@@startlocaltoc{##1}{\Etoc@tocid}}% \Etoc@tableofcontents \fi \@gobble\etoc@ \endgroup\ifEtoc@mustclosegroup\endgroup\fi \Etoc@tocdepthreset \Etoc@listofreset \etocaftertochook }% \Etoc@localtableofcontents % \end{macrocode} % |2013/03/07|: I discover a \csa{@namedef} trick to construct the % \csbc{Etoc@again} space delimited macro:\\ % | \@namedef {Etoc@again} {...stuff...}|\\ % Original version was (copied from analogous stuff in |source2e|):\\ % | {\def\1{\Etoc@again}\expandafter\gdef\1 {...stuff...}}|\\ % and in the end (now that I think about it) I simply use \csa{@firstofone}. % % \etocrelease{1.2} has a removed a \csa{Etoc@getrefno} as the author now % knows about \csa{@car} so need to define a similar utility here! % % Much more importantly (and embarrassingly) \etocrelease{1.2} fixes a bug % which had been here for ever. The code in its innocence 2012 birth year % assumed that the first entry of \csa{r@foo}, if the latter is defined, is % always numerical! But this is broken by \ctanpkg{varioref} if one used for % example \csa{vpageref}|{foo}| before! The first brace pair will then be % |{??}|... causing in \etoc a ``Missing number'' error. % % About the current fixed code, there is no strong reason that % \csbc{Etoc@getref} should work expandably. Later % \csbc{Etoc@localtableofcontents} does % \centeredline{|\edef\Etoc@tocid{#1}\iffnum\Etoc@tocid<\@ne|} but I certainly % could organize things differently. % % Maybe I should investigate more on what nasty things car be in % first argument. Or submit it to an \csa{expanded}? % \begin{macrocode} \def\Etoc@getref #1{% \@ifundefined{r@#1} {0} {\expandafter\Etoc@getref@i\romannumeral-`0% \expandafter\expandafter\expandafter \@car\csname r@#1\endcsname0\@nil\@etoc }% } \def\Etoc@getref@i#1#2\@etoc{\ifnum9<1\string#1 #1#2\else 0\fi} \def\Etoc@ref#1{\Etoc@localtableofcontents{\Etoc@getref{#1}}} \def\Etoc@label#1{\label{#1}\futurelet\Etoc@nexttoken\Etoc@t@bleofcontents} \@firstofone{\def\Etoc@again} {\futurelet\Etoc@nexttoken\Etoc@t@bleofcontents} % \end{macrocode} % |\ref{foo}| expects |foo| to be a label to a \emph{local} TOC. % % The syntax \csbc{localtableofcontents}|\ref{foo}| is supported. % \begin{macrocode} \def\Etoc@dothis #1#2\etoc@ {\fi #1} \def\Etoc@t@bleofcontents{% \gdef\etoclocaltop{-\@M}% \ifx\Etoc@nexttoken\label\Etoc@dothis{\expandafter\Etoc@label\@gobble}\fi \ifx\Etoc@nexttoken\@sptoken\Etoc@dothis{\Etoc@again}\fi % \end{macrocode} % \csbc{Etoc@ref} will hand over directly to \csbc{Etoc@localtableofcontents}. % Argument will be (or rather expand to) zero if the reference is non-existent % yet. % \begin{macrocode} \ifx\Etoc@nexttoken\ref\Etoc@dothis{\expandafter\Etoc@ref\@gobble}\fi % \end{macrocode} % Flag to check if we were called from a \csbc{localtableofcontents}. % \begin{macrocode} \ifEtoc@tocwithid\Etoc@dothis{\Etoc@localtableofcontents{\c@etoc@tocid}}\fi % \end{macrocode} % From now on we are handling a global TOC. Earlier, I used the trick of % setting \csbc{Etoc@tocid} to |\z@| for compatibility with expansion of % \csbc{etoc@startlocaltoc}. But since \etocrelease{1.08i} \csbc{etoc@startlocaltoc} is left to be % |\@gobble|, and \csbc{Etoc@tocid} is never tested. We don't need to set the % \csbc{ifEtoc@notactive} flag as now \csbc{Etoc@testingcontentsline} tests first the % \csbc{ifEtoc@localtoc} flag (was already the case of \csbc{Etoc@etoccontentsline}). I change % a bit the style of conditionals here for clarity of code. % \begin{macrocode} \global\Etoc@isemptytocfalse \ifEtoc@checksemptiness\Etoc@checkifempty\fi \ifEtoc@isemptytoc \ifEtoc@notocifnotoc \expandafter\expandafter\expandafter\@gobble \fi \fi \Etoc@tableofcontents \endgroup \ifEtoc@mustclosegroup\endgroup\fi \Etoc@tocdepthreset \Etoc@listofreset \etocaftertochook \@gobble\etoc@ }% \Etoc@t@bleofcontents % \end{macrocode} % \etocrelease{1.08c} does not use |\arabic| in the \csa{addtocontents} since I have seen % that in some circumstances (for some right to left languages with % polyglossia or babel), one can not rely on |\arabic| having its default % definition. As the number written here will be used later in an \csa{ifnum}, I % should not have used it in the first place (done |2015/03/30|). % \begin{macrocode} \def\Etoc@table@fcontents{% \refstepcounter{etoc@tocid}% \Etoc@tocwithidfalse \futurelet\Etoc@nexttoken\Etoc@t@bleofcontents } \def\Etoc@localtable@fcontents{% \refstepcounter{etoc@tocid}% \addtocontents{toc}{\string\etoc@startlocaltoc{\the\c@etoc@tocid}}% \Etoc@tocwithidtrue \futurelet\Etoc@nexttoken\Etoc@t@bleofcontents } % \end{macrocode} % Attention that there could be a |\ref| following, thus we don't yet know % whether this is a local or global table of contents. % % The \csbc{Etoc@tocdepthset} is for \csbc{etocsetnexttocdepth} mechanism. % \begin{macrocode} \def\etoctableofcontents{% \Etoc@openouttoc \Etoc@tocdepthset \begingroup % \end{macrocode} % This group will be closed in \csbc{Etoc@t@bleofcontents} or % \csbc{Etoc@localtableofcontents}. % % Prior to its release |1.4c|, \ctanpkg{tableof} added a group pair via \csa{tof@begin} % and \csa{tof@finish}. It was removed at |1.4c|, so no need to do anything now % here about silencing \csa{tof@begingroup} and \csa{tof@endgroup}: they are % inserted only in the \ctanpkg{tableof} private copy of the |.toc| file which is % used by its own table of contents typesetting command. % % \etocrelease{1.09b} uses a |\def| in non-starred variant for allowing tricks to % recognize later on if we are in a starred or non-starred case, whatever the % user definition of \csbc{etocaftertitlehook} may be. % \begin{macrocode} \@ifstar {\let\Etoc@aftertitlehook\@empty\Etoc@table@fcontents} {\def\Etoc@aftertitlehook{\etocaftertitlehook}\Etoc@table@fcontents}% }% \etoctableofcontents \def\etocifisstarred{\ifx\Etoc@aftertitlehook\@empty \expandafter\@firstoftwo\else \expandafter\@secondoftwo \fi} \let\etocoriginaltableofcontents\tableofcontents \let\tableofcontents\etoctableofcontents % \end{macrocode} % The \csbc{Etoc@listofhook} is configured by \csbc{locallistoffigures} and % \csbc{locallistoftables}. The latter two use hooks rather than % |\begingroup...\endgroup| to manage local configuration, in part because % they want to support the |\label/\ref| special \etoc mechanism, so need to % issue \csbc{localtableofcontents} last for it to be able to pick up a % following |\label| or |\ref|. % \begin{macrocode} \let\Etoc@listofhook\@empty \newcommand*\localtableofcontents{% \Etoc@openouttoc \Etoc@tocdepthset % \end{macrocode} % This group closed in \csbc{Etoc@t@bleofcontents} or \csbc{Etoc@localtableofcontents}. % Same comment relative to \ctanpkg{tableof}. No need to do anything here. % \begin{macrocode} \begingroup \Etoc@listofhook \@ifstar {\let\Etoc@aftertitlehook\@empty\Etoc@localtable@fcontents} {\def\Etoc@aftertitlehook{\etocaftertitlehook}\Etoc@localtable@fcontents}% }% \localtableofcontents % \end{macrocode} % \etocrelease{1.09} adds \localtocwrdp. Note that changes to the tocdepth % from inside the |.toc| file during duration of local toc will remain without % effect as a substitute is used which gets a frozen non-dynamical value. % % It seems \etocrelease{1.09} actually forgot a change to % \csbc{Etoc@etoccontentsline} and the previous sentence was false and % described only what happened during the emptiness check which thus could % give false positives or false negatives. But if I had done the needed % change in \csbc{Etoc@etoccontentsline} to keep the two in sync, even if % |tocdepth| evolves from the |.toc| file, I would have created a divergence % between local TOCs (not only the % \csbc{localtableofcontentswithrelativedepth} ones) under % \csbc{etocstandardlines} and those not with standard lines. % % Redoing the whole thing at \etocrelease{1.2}. I needed to insert a suitable % hook in \csbc{Etoc@@startlocaltoc} (and also in the version used by % \csbc{Etoc@checkifempty}). And I have now at my disposal % \csbc{Etoc@listofreset} to reset it (it will be expanded after both the % emptiness check and the typesetting are completed, and at same grouping % level as the trigger command defined here). I do not want to add tokens % after \csbc{localtableofcontents} to not break the |\label/\ref| thing, % which is one reason for this way of proceeding. % \begin{macrocode} \newcommand*\localtableofcontentswithrelativedepth[1]{% \def\Etoc@@startlocaltochook{% \global\c@tocdepth\numexpr\etoclocaltop+#1\relax }% \def\Etoc@listofreset{\let\Etoc@@startlocaltochook\@empty \let\Etoc@listofreset\@empty}% \localtableofcontents }% \localtableofcontentswithrelativedepth % \end{macrocode} % Prior to \etocrelease{1.2}, \csbc{Etoc@tableofcontents} was constructed % by \csbc{etocsettocstyle} as one big macro where |#1| and |#2| had been % inserted. It now simply stores |#1| and |#2| each in a macro and % \csbc{Etoc@tableofcontents} is defined once and for all. Also the boolean % \csbc{ifEtoc@etocstyle} is added which helps keeping the emulation of % the document class only for the global document TOC but use a better choice % for local tables of contents (especially those in deeper sub-levels), % which is activated via \csbc{etocetoclocaltocstyle} (near end of code). % % \csbc{etocstoretocstyleinto} added at \etocrelease{1.2}. Too lazy % to check if |#1| pre-exists. Well, rather, too annoying to do this check % as one may want to redefine |#1| without further ado. % \begin{macrocode} \newcommand\etocsettocstyle[2]{% \Etoc@etocstylefalse \Etoc@classstylefalse \def\Etoc@tableofcontents@user@before{#1}% \def\Etoc@tableofcontents@user@after {#2}% }% \def\etocstoretocstyleinto#1{% %% \@ifdefinable#1{% \edef#1{\noexpand\Etoc@etocstylefalse\noexpand\Etoc@classstylefalse \def\noexpand\Etoc@tableofcontents@user@before{% \unexpanded\expandafter{\Etoc@tableofcontents@user@before}% }% \def\noexpand\Etoc@tableofcontents@user@after{% \unexpanded\expandafter{\Etoc@tableofcontents@user@after}% }% }% %% }% }% % \end{macrocode} % The macro names added here at \etocrelease{1.2} are provisory. Next % release will probably do a complete renaming of various internals because % this is currently a complete mess with some names differing only by an |@| % versus a voyel, but not necessarily being at a deeper level of expansion the % more |@|'s they have... the deepest one being this \csbc{Etoc@tableofcontents}... % \begin{macrocode} \def\Etoc@tableofcontents {% \Etoc@tableofcontents@etoc@before \ifEtoc@localtoc\ifEtoc@etocstyle\expandafter\expandafter\expandafter\@gobble\fi\fi \Etoc@tableofcontents@user@before \Etoc@tableofcontents@contents \ifEtoc@localtoc\ifEtoc@etocstyle\expandafter\expandafter\expandafter\@gobble\fi\fi \Etoc@tableofcontents@user@after \Etoc@tableofcontents@etoc@after \@gobble\etoc@ } \def\Etoc@tableofcontents@etoc@before{% \ifnum\c@tocdepth>\Etoc@minf \else \expandafter\Etoc@gobtoetoc@ \fi \Etoc@par \Etoc@beforetitlehook \etocbeforetitlehook \Etoc@storetocdepth \let\Etoc@savedcontentsline\contentsline \let\contentsline\Etoc@etoccontentsline \ifEtoc@standardlines \else % \end{macrocode} % \etocrelease{1.1a}'s \csbc{Etoc@lxyz} now fetches 3 not 2 arguments and the % \csa{l@section} etc... are not |\let| to it anymore, as they used to be here % formerly. % % For backwards compatibility the \csa{etocsavedchaptertocline} % etc... are still defined but issue a warning since \etocrelease{1.1a} % and an error since \etocrelease{1.2}. % \begin{macrocode} \def\Etoc@do##1{% \expandafter\def\csname etocsaved##1tocline\endcsname {\PackageError{etoc}{% \expandafter\string\csname etocsaved##1tocline\endcsname\space has been deprecated\MessageBreak at 1.1a and is removed at 1.2.\MessageBreak Use \expandafter\string\csname l@##1\endcsname\space directly.\MessageBreak Reported \on@line}% {I will use \expandafter\string \csname l@##1\endcsname\space myself for this time.% }% \csname l@##1\endcsname }% }% \Etoc@dolevels \fi }% % \end{macrocode} % \etocrelease{1.09} makes \csbc{etocsetnexttocdepth} usable in |#1| (but this % is not 100\% compatible with the emptiness check). It makes an % \csbc{etoclocaltop} usable in |#1| if under checksemptiness regime. % % (|#1| above now means \csbc{Etoc@tableofcontents@user@before} since \etocrelease{1.2}) % \begin{macrocode} \def\Etoc@tableofcontents@contents{% \Etoc@tocdepthset \ifEtoc@parskip\parskip\z@skip\fi \Etoc@aftertitlehook % \end{macrocode} % \etocrelease{1.09} has replaced former \csa{Etoc@localtop} (\emph{minus one}) by % \csbc{etoclocaltop}. Under checksemptinesstrue regime its value is already % known, but it will be obtained again from the toc file execution. As it is % used only if TOC is active, resetting it here this way is decorative and % could be removed. % \begin{macrocode} \gdef\etoclocaltop{-\thr@@}% \Etoc@toctoc \etocaftercontentshook }% \def\Etoc@tableofcontents@etoc@after{% \@nobreakfalse \Etoc@restoretocdepth % \end{macrocode} % \csa{contentsline} was set to \csbc{Etoc@etoccontentsline} by a non-global |\let|, % and it will recover its normal value from exiting a scope limiting group. % But \ctanpkg{tableof} (since |1.4a|) under \csbc{etocglobaldefs} does a global % redefinition of \csa{contentsline}. Its \csa{tof@finish} then does a global % restore of \csa{contentsline}, but it will be to the \etoc set % value. \csa{tof@finish} is active only if either the table of contents was % typeset using \csa{tableof}, \csa{tablenotof}, \csa{tableoftaggedcontents}, or % \csa{nextocwithtags} was used. If not active it is either undefined (no % package \ctanpkg{tableof}) or |\@empty|. Prior to \ctanpkg{tableof} |1.4c|, the % \csa{tof@finish} closed a group and could be undefined as well, but not if % \csbc{etocglobaldefs}. % % If rather than |\@empty| the \csa{tof@finish} fall-back was |\relax| we could % use here \csa{@ifundefined} to check in one go (matters of speaking because % expansion of \csa{@ifundefined} is not in "one-go"). Maybe I should update % \ctanpkg{tableof}, but for time being I will simply add an extra test. All this is % probably lots of time on irrelevant issue. % \begin{macrocode} \ifx\Etoc@global\global \@ifundefined{tof@finish} {} {\ifx\tof@finish\@empty \else \global\let\contentsline\Etoc@savedcontentsline \fi }% \fi } % \end{macrocode} % Refactored at \etocrelease{1.2} to check if the style is actually known % and its level is from |-1| (|-2| in memoir class) to |5| inclusive. % If not raise a warning. % \begin{macrocode} \def\etocsetstyle#1{\ifcsname Etoc@#1@@\endcsname \expandafter\Etoc@setstyle@a \else \expandafter\Etoc@setstyle@error \fi {#1}% } \def\Etoc@setstyle@error #1{% \PackageWarning{etoc}{`#1' is unknown to etoc. \space Did you\MessageBreak forget some \string\etocsetlevel{#1}{}?\MessageBreak Reported}% \@gobblefour } \def\Etoc@setstyle@a #1{% \edef\Etoc@tmp{\the\numexpr\csname Etoc@#1@@\endcsname}% \if1\unless\ifnum\Etoc@tmp<\Etoc@maxlevel 0\fi \unless\ifnum\Etoc@tmp>\Etoc@minf 0\fi1% \Etoc@standardlinesfalse \expandafter\Etoc@setstyle@b\expandafter\Etoc@tmp \else \ifnum\Etoc@tmp=\Etoc@maxlevel \in@{.#1,}{.figure,.table,}% \ifin@ \PackageWarning{etoc} {You can not use \string\etocsetstyle\space with `#1'.\MessageBreak Check the package documentation (in particular about\MessageBreak \string\etoclocallistoffigureshook/\string\etoclocallistoftableshook)% \MessageBreak on how to customize figure and table entries in local\MessageBreak lists. Reported}% \else \PackageInfo{etoc} {Attempt to set the style of `#1',\MessageBreak whose level is currently the maximal one \etocthemaxlevel,\MessageBreak which is never displayed. \space This will be ignored\MessageBreak but note that we do quit compatibility mode.\MessageBreak Reported}% \Etoc@standardlinesfalse \fi \else % \end{macrocode} % This branch was actually in the end only for the case of a level equal to % |-2|, with a document class not \ctanpkg{memoir}, but \etocrelease{1.2a} % prevents \csbc{etocsetlevel} to use numerical level |-2| in such case. % \begin{macrocode} \PackageWarning{etoc}{This should not happen. Reported}% \fi \expandafter\@gobblefour \fi } % \end{macrocode} % Prior to \etocrelease{1.2} the |#1| here was some alphabetical string % such as |minusone|. We now use digit tokens (and minus sign) in the macro % names. The ``begin'' macros formerly incorporated % \csa{Etoc@global}\csa{Etoc@isfirsttrue}. They are now located in % \csbc{Etoc@traversestackofends}. % % \etocrelease{1.2} adds \csbc{etocstorelinestylesinto}. And % \csbc{etocstorethislinestyleinto}. No error check on the level. % \begin{macrocode} \long\def\Etoc@setstyle@b#1#2#3#4#5{% \expandafter\def\csname Etoc@begin@#1\endcsname {#2}% \expandafter\def\csname Etoc@prefix@#1\endcsname {#3}% \expandafter\def\csname Etoc@contents@#1\endcsname {#4}% \expandafter\def\csname Etoc@end@#1\endcsname {#5}% } \def\Etoc@setstyle@e#1{% \expandafter\let\csname Etoc@begin@#1\endcsname \@empty \expandafter\let\csname Etoc@prefix@#1\endcsname \@empty \expandafter\let\csname Etoc@contents@#1\endcsname \@empty \expandafter\let\csname Etoc@end@#1\endcsname \@empty } \def\Etoc@storelines@a#1{% \noexpand\Etoc@setstyle@b{#1}% {\expandafter\Etoc@expandonce\csname Etoc@begin@#1\endcsname}% {\expandafter\Etoc@expandonce\csname Etoc@prefix@#1\endcsname}% {\expandafter\Etoc@expandonce\csname Etoc@contents@#1\endcsname}% {\expandafter\Etoc@expandonce\csname Etoc@end@#1\endcsname}% } \def\Etoc@expandonce#1{\unexpanded\expandafter{#1}} \def\etocstorelinestylesinto#1{% \edef#1{\Etoc@storelines@a{-2}\Etoc@storelines@a{-1}\Etoc@storelines@a{0}% \Etoc@storelines@a {1}\Etoc@storelines@a {2}\Etoc@storelines@a{3}% \Etoc@storelines@a {4}\Etoc@storelines@a {5}% \ifEtoc@deeplevels \Etoc@storelines@a{6}\Etoc@storelines@a{7}\Etoc@storelines@a{8}% \Etoc@storelines@a{9}\Etoc@storelines@a{10}\Etoc@storelines@a{11}% \fi }% } \def\etocstorethislinestyleinto#1#2{% \edef#2{\expandafter\Etoc@storelines@a\expandafter{\number\etoclevel{#1}}}% }% % \end{macrocode} % Customization macros of the package default line styles. % \begin{macrocode} \def\etocfontminustwo {\normalfont \LARGE \bfseries} \def\etocfontminusone {\normalfont \large \bfseries} \def\etocfontzero {\normalfont \large \bfseries} \def\etocfontone {\normalfont \normalsize \bfseries} \def\etocfonttwo {\normalfont \normalsize} \def\etocfontthree {\normalfont \footnotesize} % \end{macrocode} % placeholder for comments % \begin{macrocode} \def\etocsepminustwo {4ex \@plus .5ex \@minus .5ex} \def\etocsepminusone {4ex \@plus .5ex \@minus .5ex} \def\etocsepzero {2.5ex \@plus .4ex \@minus .4ex} \def\etocsepone {1.5ex \@plus .3ex \@minus .3ex} \def\etocseptwo {.5ex \@plus .1ex \@minus .1ex} \def\etocsepthree {.25ex \@plus .05ex \@minus .05ex} % \end{macrocode} % placeholder for comments % \begin{macrocode} \def\etocbaselinespreadminustwo {1} \def\etocbaselinespreadminusone {1} \def\etocbaselinespreadzero {1} \def\etocbaselinespreadone {1} \def\etocbaselinespreadtwo {1} \def\etocbaselinespreadthree {.9} % \end{macrocode} % placeholder for comments % \begin{macrocode} \def\etocminustwoleftmargin {1.5em plus 0.5fil} \def\etocminustworightmargin {1.5em plus -0.5fil} \def\etocminusoneleftmargin {1em} \def\etocminusonerightmargin {1em} \def\etoctoclineleaders {\hbox{\normalfont\normalsize\hb@xt@2ex {\hss.\hss}}} \def\etocabbrevpagename {p.~} % \end{macrocode} % Versions earlier than \etocrelease{1.08b} (and since \etocrelease{1.05} |2012/12/01|) defined % \csbc{etocpartname} (for use by \etoc's own line styles) to expand to % \csa{partname}. But this didn't make sense in the context for example of % \ctanpkg{babel} and \ctanpkg{babel-french}, because \csa{frenchpartname} does things depending on % the current value of the counter |part|. The code in recent \ctanpkg{babel-french} (but % not yet |v2.5a| when \csbc{etocpartname} was introduced) constructs control % sequences \csa{ordinali}, etc... If the part counter is zero, this gives % \csa{ordinal}. Usually this is not defined, hence no error happens (as it is % constructed via |\csname|), but under class \ctanpkg{memoir} the bug showed up. All % this to explain that I found out about this long lasting problem only on % |2015/03/14|. Probably a sign that \etoc's own line styles are rarely % used... % \begin{macrocode} \def\etocpartname {Part} \def\etocbookname {Book} % \end{macrocode} % The macro \csbc{etocdefaultlines} was initially called \csbc{etoctoclines}. Now % \csbc{etoctoclines} just does \csa{Etoc@standardlinesfalse}. % % Version \etocrelease{1.09f} wraps \csbc{etocbookname}, respectively % \csbc{etocpartname}, in the book, resp. part, line styles inside a % (potential) hyperlink together with the number. % % \etocrelease{1.2a} does not define a `book' style if not with % \ctanpkg{memoir} class as the numerical level |-2| is made available only % with that class. % % Unfortunately \csa{@ifclassloaded} was preamble-only until the |2021-11-15| % LaTeX release (and also \csa{@ifpackageloaded}). Anyway let's refactor this % \csbc{etocdefaultlines} at \etocrelease{1.2a} to use encapsulating macros % rather than be a single one with gigantic contents. % \begin{macrocode} \def\etocdefaultlines{% \Etoc@standardlinesfalse \etocdefaultlines@setbook \etocdefaultlines@setpart \etocdefaultlines@setchapter \etocdefaultlines@setsection \etocdefaultlines@setsubsection \etocdefaultlines@setsubsubsection \etocdefaultlines@setdeeperones } % \end{macrocode} % \etocrelease{1.2b} adds \csb{etocnoprotrusion} as an alias to the % \LaTeX{} kernel |2018/12/01| command \csa{noprotrusion} which is used since % that release in \csa{@dottedtocline} after the page number. And it uses it % in its own default line styles for section and subsection. % \begin{macrocode} \def\etocnoprotrusion{\leavevmode\kern-\p@\kern\p@} \@ifclassloaded{memoir}{% \def\etocdefaultlines@setbook{% \Etoc@setstyle@b {-2}% {\addpenalty\@M\etocskipfirstprefix} {\addpenalty\@secpenalty} {\begingroup \etocfontminustwo \addvspace{\etocsepminustwo}% \parindent \z@ \leftskip \etocminustwoleftmargin \rightskip \etocminustworightmargin \parfillskip \@flushglue \vbox{\etocifnumbered{\etoclink{\etocbookname\enspace\etocthenumber:\quad}}{}% \etocname \baselineskip\etocbaselinespreadminustwo\baselineskip \par}% \addpenalty\@M\addvspace{\etocsepminusone}% \endgroup} {}% } }{\let\etocdefaultlines@setbook\@empty} \def\etocdefaultlines@setpart{% \Etoc@setstyle@b {-1}% {\addpenalty\@M\etocskipfirstprefix} {\addpenalty\@secpenalty} {\begingroup \etocfontminusone \addvspace{\etocsepminusone}% \parindent \z@ \leftskip \etocminusoneleftmargin \rightskip \etocminusonerightmargin \parfillskip \@flushglue \vbox{\etocifnumbered{\etoclink{\etocpartname\enspace\etocthenumber.\quad}}{}% \etocname \baselineskip\etocbaselinespreadminusone\baselineskip \par}% \addpenalty\@M\addvspace{\etocsepzero}% \endgroup} {}% } % \end{macrocode} % No need to worry about left protrusion activation and the delicacies of % \csa{leftprotrusion} from \ctanpkg{microtype}, as the paragraph indentation % here is nil. So, no changes at \etocrelease{1.2b}. % \begin{macrocode} \def\etocdefaultlines@setchapter{% \Etoc@setstyle@b {0}% {\addpenalty\@M\etocskipfirstprefix} {\addpenalty\@itempenalty} {\begingroup \etocfontzero \addvspace{\etocsepzero}% \parindent \z@ \parfillskip \@flushglue \vbox{\etocifnumbered{\etocnumber.\enspace}{}\etocname \baselineskip\etocbaselinespreadzero\baselineskip \par}% \endgroup} {\addpenalty{-\@highpenalty}\addvspace{\etocsepminusone}}% } % \end{macrocode} % This is now very old code, dating back to earliest releases, and looks % a bit too convoluted. There was probably a better way with suitable % \csa{nobreak} and |\null| trick. But I am too old to revisit these things % now. And, by the way, as paragraph indentation is zeroed, no need to worry % about perhaps activating explictly protrusion on the left. % \begin{macrocode} \def\etocdefaultlines@setsection{% \Etoc@setstyle@b {1}% {\addpenalty\@M\etocskipfirstprefix} {\addpenalty\@itempenalty} {\begingroup \etocfontone \addvspace{\etocsepone}% \parindent \z@ \parfillskip \z@ \setbox\z@\vbox{\parfillskip\@flushglue \etocname\par \setbox\tw@\lastbox \global\setbox\@ne\hbox{\unhbox\tw@\ }}% \dimen\z@=\wd\@ne \setbox\z@=\etoctoclineleaders \advance\dimen\z@\wd\z@ \etocifnumbered {\setbox\tw@\hbox{\etocnumber, \etocabbrevpagename\etocpage\etocnoprotrusion}} {\setbox\tw@\hbox{\etocabbrevpagename\etocpage\etocnoprotrusion}}% \advance\dimen\z@\wd\tw@ \ifdim\dimen\z@ < \linewidth \vbox{\etocname~% \leaders\box\z@\hfil\box\tw@ \baselineskip\etocbaselinespreadone\baselineskip \par}% \else \vbox{\etocname~% \leaders\copy\z@\hfil\break \hbox{}\leaders\box\z@\hfil\box\tw@ \baselineskip\etocbaselinespreadone\baselineskip \par}% \fi \endgroup} {\addpenalty\@secpenalty\addvspace{\etocsepzero}}% } \def\etocdefaultlines@setsubsection{% \Etoc@setstyle@b {2}% {\addpenalty\@medpenalty\etocskipfirstprefix} {\addpenalty\@itempenalty} {\begingroup \etocfonttwo \addvspace{\etocseptwo}% \parindent \z@ \parfillskip \z@ \setbox\z@\vbox{\parfillskip\@flushglue \etocname\par\setbox\tw@\lastbox \global\setbox\@ne\hbox{\unhbox\tw@}}% \dimen\z@=\wd\@ne \setbox\z@=\etoctoclineleaders \advance\dimen\z@\wd\z@ \etocifnumbered {\setbox\tw@\hbox{\etocnumber, \etocabbrevpagename\etocpage\etocnoprotrusion}} {\setbox\tw@\hbox{\etocabbrevpagename\etocpage\etocnoprotrusion}}% \advance\dimen\z@\wd\tw@ \ifdim\dimen\z@ < \linewidth \vbox{\etocname~% \leaders\box\z@\hfil\box\tw@ \baselineskip\etocbaselinespreadtwo\baselineskip \par}% \else \vbox{\etocname~% \leaders\copy\z@\hfil\break \hbox{}\leaders\box\z@\hfil\box\tw@ \baselineskip\etocbaselinespreadtwo\baselineskip \par}% \fi \endgroup} {\addpenalty\@secpenalty\addvspace{\etocsepone}}% } \def\etocdefaultlines@setsubsubsection{% \Etoc@setstyle@b {3}% {\addpenalty\@M \etocfontthree \vspace{\etocsepthree}% \noindent \etocskipfirstprefix} {\allowbreak\,--\,} {\etocname} {.\hfil \begingroup \baselineskip\etocbaselinespreadthree\baselineskip \par \endgroup \addpenalty{-\@highpenalty}} } \def\etocdefaultlines@setdeeperones{% \Etoc@setstyle@e{4}% \Etoc@setstyle@e{5}% \ifEtoc@deeplevels \Etoc@setstyle@e{6}% \Etoc@setstyle@e{7}% \Etoc@setstyle@e{8}% \Etoc@setstyle@e{9}% \Etoc@setstyle@e{10}% \Etoc@setstyle@e{11}% \fi } % \end{macrocode} % The \csbc{etocinnertopsep} default value is too big as well as \csbc{etocbelowtocskip} % and \csbc{etocabovetocskip}, I guess, but if I am remember correctly I chose them % to mimic the standard TOC spacings in |article| class. % \begin{macrocode} \def\etocabovetocskip{3.5ex \@plus 1ex \@minus .2ex} \def\etocbelowtocskip{3.5ex \@plus 1ex \@minus .2ex} \def\etoccolumnsep{2em} \def\etocmulticolsep{0ex} \def\etocmulticolpretolerance{-1} \def\etocmulticoltolerance{200} \def\etocdefaultnbcol{2} \def\etocinnertopsep{2ex} \newcommand\etocmulticolstyle[2][\etocdefaultnbcol]{% \etocsettocstyle {\let\etocoldpar\par \addvspace{\etocabovetocskip}% \ifnum #1>\@ne \expandafter\@firstoftwo \else \expandafter\@secondoftwo \fi {\multicolpretolerance\etocmulticolpretolerance \multicoltolerance\etocmulticoltolerance \setlength{\columnsep}{\etoccolumnsep}% \setlength{\multicolsep}{\etocmulticolsep}% \begin{multicols}{#1}[#2\etocoldpar\addvspace{\etocinnertopsep}]} {#2\ifvmode\else\begingroup\interlinepenalty\@M\parskip\z@skip \@@par\endgroup \fi \nobreak\addvspace{\etocinnertopsep}% \pretolerance\etocmulticolpretolerance \tolerance\etocmulticoltolerance}% }% {\ifnum #1>\@ne \expandafter\@firstofone \else \expandafter\@gobble \fi {\end{multicols}}% \addvspace{\etocbelowtocskip}}% } % \end{macrocode} % placeholder for comments % \begin{macrocode} \def\etocinnerbottomsep{3.5ex} \def\etocinnerleftsep{2em} \def\etocinnerrightsep{2em} \def\etoctoprule{\hrule} \def\etocleftrule{\vrule} \def\etocrightrule{\vrule} \def\etocbottomrule{\hrule} \def\etoctoprulecolorcmd{\relax} \def\etocbottomrulecolorcmd{\relax} \def\etocleftrulecolorcmd{\relax} \def\etocrightrulecolorcmd{\relax} % \end{macrocode} % placeholder % \begin{macrocode} \def\etoc@ruledheading #1{% \hb@xt@\linewidth{\color@begingroup \hss #1\hss\hskip-\linewidth \etoctoprulecolorcmd\leaders\etoctoprule\hss \phantom{#1}% \leaders\etoctoprule\hss\color@endgroup}% \nointerlineskip\nobreak\vskip\etocinnertopsep} \newcommand*\etocruledstyle[2][\etocdefaultnbcol]{% \etocsettocstyle {\addvspace{\etocabovetocskip}% \ifnum #1>\@ne \expandafter\@firstoftwo \else \expandafter\@secondoftwo \fi {\multicolpretolerance\etocmulticolpretolerance \multicoltolerance\etocmulticoltolerance \setlength{\columnsep}{\etoccolumnsep}% \setlength{\multicolsep}{\etocmulticolsep}% \begin{multicols}{#1}[\etoc@ruledheading{#2}]} {\etoc@ruledheading{#2}% \pretolerance\etocmulticolpretolerance \tolerance\etocmulticoltolerance}} {\ifnum #1>\@ne\expandafter\@firstofone \else \expandafter\@gobble \fi {\end{multicols}}% \addvspace{\etocbelowtocskip}}} % \end{macrocode} % placeholder % \begin{macrocode} \def\etocframedmphook{\relax} \long\def\etocbkgcolorcmd{\relax} \long\def\Etoc@relax{\relax} % \end{macrocode} % placeholder for comments % \begin{macrocode} \newbox\etoc@framed@titlebox \newbox\etoc@framed@contentsbox \newcommand*\etocframedstyle[2][\etocdefaultnbcol]{% \etocsettocstyle{% \addvspace{\etocabovetocskip}% \sbox\z@{#2}% \dimen\z@\dp\z@ \ifdim\wd\z@<\linewidth \dp\z@\z@ \else \dimen\z@\z@ \fi \setbox\etoc@framed@titlebox=\hb@xt@\linewidth{\color@begingroup \hss \ifx\etocbkgcolorcmd\Etoc@relax \else \sbox\tw@{\color{white}% \vrule\@width\wd\z@\@height\ht\z@\@depth\dimen\z@}% \ifdim\wd\z@<\linewidth \dp\tw@\z@\fi \box\tw@ \hskip-\wd\z@ \fi \copy\z@ \hss \hskip-\linewidth \etoctoprulecolorcmd\leaders\etoctoprule\hss \hskip\wd\z@ \etoctoprulecolorcmd\leaders\etoctoprule\hss\color@endgroup}% \setbox\z@\hbox{\etocleftrule\etocrightrule}% \dimen\tw@\linewidth\advance\dimen\tw@-\wd\z@ \advance\dimen\tw@-\etocinnerleftsep \advance\dimen\tw@-\etocinnerrightsep \setbox\etoc@framed@contentsbox=\vbox\bgroup \hsize\dimen\tw@ \kern\dimen\z@ \vskip\etocinnertopsep \hbox\bgroup \begin{minipage}{\hsize}% \etocframedmphook \ifnum #1>\@ne \expandafter\@firstoftwo \else \expandafter\@secondoftwo \fi {\multicolpretolerance\etocmulticolpretolerance \multicoltolerance\etocmulticoltolerance \setlength{\columnsep}{\etoccolumnsep}% \setlength{\multicolsep}{\etocmulticolsep}% \begin{multicols}{#1}} {\pretolerance\etocmulticolpretolerance \tolerance\etocmulticoltolerance}} {\ifnum #1>\@ne\expandafter\@firstofone \else \expandafter\@gobble \fi {\end{multicols}\unskip }% \end{minipage}% \egroup \vskip\etocinnerbottomsep \egroup \vbox{\hsize\linewidth \ifx\etocbkgcolorcmd\Etoc@relax \else \kern\ht\etoc@framed@titlebox \kern\dp\etoc@framed@titlebox \hb@xt@\linewidth{\color@begingroup \etocleftrulecolorcmd\etocleftrule \etocbkgcolorcmd \leaders\vrule \@height\ht\etoc@framed@contentsbox \@depth\dp\etoc@framed@contentsbox \hss \etocrightrulecolorcmd\etocrightrule \color@endgroup}\nointerlineskip \vskip-\dp\etoc@framed@contentsbox \vskip-\ht\etoc@framed@contentsbox \vskip-\dp\etoc@framed@titlebox \vskip-\ht\etoc@framed@titlebox \fi \box\etoc@framed@titlebox\nointerlineskip \hb@xt@\linewidth{\color@begingroup {\etocleftrulecolorcmd\etocleftrule}% \hss\box\etoc@framed@contentsbox\hss \etocrightrulecolorcmd\etocrightrule\color@endgroup} \nointerlineskip \vskip\ht\etoc@framed@contentsbox \vskip\dp\etoc@framed@contentsbox \hb@xt@\linewidth{\color@begingroup\etocbottomrulecolorcmd \leaders\etocbottomrule\hss\color@endgroup}} \addvspace{\etocbelowtocskip}}} % \end{macrocode} % For time being I will not however add the versions for ``lists of'', as % anyhow probably nobody apart myself ever uses these things. % % It is impossible to know what kind of division heading |#2| uses, so there % is not much I can do here at \etocrelease{1.2} apart from providing a % user interface for adding the suitable thing to the |.toc| file. And I % discover at time of writing (finishing the \etocrelease{1.2} % documentation) that I already have \csbc{etoclocalheadtotoc}. I only need to % add \csbc{etocglobalheadtotoc}. % \begin{macrocode} \newcommand\etoc@multicoltoc[2][\etocdefaultnbcol]{% \etocmulticolstyle[#1]{#2}% \tableofcontents} \newcommand\etoc@multicoltoci[2][\etocdefaultnbcol]{% \etocmulticolstyle[#1]{#2}% \tableofcontents*} \newcommand\etoc@local@multicoltoc[2][\etocdefaultnbcol]{% \etocmulticolstyle[#1]{#2}% \localtableofcontents} \newcommand\etoc@local@multicoltoci[2][\etocdefaultnbcol]{% \etocmulticolstyle[#1]{#2}% \localtableofcontents*} % \end{macrocode} % placeholder for comments % \begin{macrocode} \newcommand*\etoc@ruledtoc[2][\etocdefaultnbcol]{% \etocruledstyle[#1]{#2}% \tableofcontents} \newcommand*\etoc@ruledtoci[2][\etocdefaultnbcol]{% \etocruledstyle[#1]{#2}% \tableofcontents*} \newcommand*\etoc@local@ruledtoc[2][\etocdefaultnbcol]{% \etocruledstyle[#1]{#2}% \localtableofcontents} \newcommand*\etoc@local@ruledtoci[2][\etocdefaultnbcol]{% \etocruledstyle[#1]{#2}% \localtableofcontents*} % \end{macrocode} % placeholder for comments % \begin{macrocode} \newcommand*\etoc@framedtoc[2][\etocdefaultnbcol]{% \etocframedstyle[#1]{#2}% \tableofcontents} \newcommand*\etoc@framedtoci[2][\etocdefaultnbcol]{% \etocframedstyle[#1]{#2}% \tableofcontents*} \newcommand*\etoc@local@framedtoc[2][\etocdefaultnbcol]{% \etocframedstyle[#1]{#2}% \localtableofcontents} \newcommand*\etoc@local@framedtoci[2][\etocdefaultnbcol]{% \etocframedstyle[#1]{#2}% \localtableofcontents*} % \end{macrocode} % placeholder for comments % \begin{macrocode} \def\etocmulticol{\begingroup \Etoc@mustclosegrouptrue \@ifstar {\etoc@multicoltoci} {\etoc@multicoltoc}} \def\etocruled{\begingroup \Etoc@mustclosegrouptrue \@ifstar {\etoc@ruledtoci} {\etoc@ruledtoc}} \def\etocframed{\begingroup \Etoc@mustclosegrouptrue \@ifstar {\etoc@framedtoci} {\etoc@framedtoc}} \def\etoclocalmulticol{\begingroup \Etoc@mustclosegrouptrue \@ifstar {\etoc@local@multicoltoci} {\etoc@local@multicoltoc}} \def\etoclocalruled{\begingroup \Etoc@mustclosegrouptrue \@ifstar {\etoc@local@ruledtoci} {\etoc@local@ruledtoc}} \def\etoclocalframed{\begingroup \Etoc@mustclosegrouptrue \@ifstar {\etoc@local@framedtoci} {\etoc@local@framedtoc}} % \end{macrocode} % \etocrelease{1.2} makes local TOCs in compatibility display style use % |\subsection*| rather than |\section*|. This is not good for local TOCs to % a |\part| but anyhow the default is via \csbc{etocetoclocaltocstyle} which % will do the right thing and the change here is irrelevant. More comments % below about handling \ctanpkg{memoir} and \ctanpkg{KOMA-script}. % % The macros next will be modified if under |book| or \ctanpkg{memoir} class. % The \ctanpkg{KOMA-script} case uses rather the |leveldown| mechanism. % These local TOCs things are used only under \csbc{etocclasstocstyle}. % With \csbc{etocetoclocaltocstyle}, they are not used. % \begin{macrocode} \def\etocmemoirtoctotocfmt #1#2{% \PackageWarning{etoc} {\string\etocmemoirtoctotocfmt\space is deprecated.\MessageBreak Use in its place \string\etocsettoclineforclasstoc,\MessageBreak and \string\etocsettoclineforclasslistof{toc} (or {lof}, {lot}). I will do this now.\MessageBreak Reported}% \etocsettoclineforclasstoc{#1}{#2}% \etocsettoclineforclasslistof{toc}{#1}{#2}% } \def\etocsettoclineforclasstoc #1#2{% \def\etocclassmaintocaddtotoc{\etocglobalheadtotoc{#1}{#2}}% } \def\etocsettoclineforclasslistof #1#2#3{% \@namedef{etocclasslocal#1addtotoc}{\etoclocalheadtotoc{#2}{#3}}% } \let\etocclasslocaltocaddtotoc\@empty \let\etocclasslocallofaddtotoc\@empty \let\etocclasslocallotaddtotoc\@empty \ifdefined\c@chapter \def\etocclasslocaltocmaketitle{\section*{\localcontentsname}} \def\etocclasslocallofmaketitle{\section*{\locallistfigurename}} \def\etocclasslocallotmaketitle{\section*{\locallisttablename}} \etocsettoclineforclasstoc {chapter}{\contentsname} \etocsettoclineforclasslistof{toc}{section}{\localcontentsname} \etocsettoclineforclasslistof{lof}{section}{\locallistfigurename} \etocsettoclineforclasslistof{lot}{section}{\locallisttablename} \else \def\etocclasslocaltocmaketitle{\subsection*{\localcontentsname}}% \def\etocclasslocallofmaketitle{\subsection*{\locallistfigurename}}% \def\etocclasslocallotmaketitle{\subsection*{\locallisttablename}}% \etocsettoclineforclasstoc {section}{\contentsname} \etocsettoclineforclasslistof{toc}{subsection}{\localcontentsname} \etocsettoclineforclasslistof{lof}{subsection}{\locallistfigurename} \etocsettoclineforclasslistof{lot}{subsection}{\locallisttablename} \fi % \end{macrocode} % This is moved to a macro to localize complications with conditionals. % \begin{macrocode} \def\etocclasslocalperhapsaddtotoc #1{% \etocifisstarred {} {\csname ifEtoc@local#1totoc\endcsname \csname etocclasslocal#1addtotoc\endcsname \fi }% } % \end{macrocode} % No need for a \csa{phantomsection} if the \csa{addcontentsline} is after % |\section*|. For the standard classes, I make no effort to adjust level % used for the local heading if it is local to a \csa{part}, not a % \csa{section}. Anyhow this code will not be used by default for % local TOCs due to \csbc{etocetoclocaltocstyle}. % \begin{macrocode} \def\etocarticlestyle{% \etocsettocstyle {\ifEtoc@localtoc \@nameuse{etocclasslocal\Etoc@currext maketitle}% \etocclasslocalperhapsaddtotoc\Etoc@currext \else \section *{\contentsname \@mkboth {\MakeUppercase \contentsname} {\MakeUppercase \contentsname}}% \etocifisstarred{}{\etocifmaintoctotoc{\etocclassmaintocaddtotoc}{}}% \fi } {}% } \def\etocarticlestylenomarks{% \etocsettocstyle {\ifEtoc@localtoc \@nameuse{etocclasslocal\Etoc@currext maketitle}% \etocclasslocalperhapsaddtotoc\Etoc@currext \else \section *{\contentsname}% \etocifisstarred{}{\etocifmaintoctotoc{\etocclassmaintocaddtotoc}{}}% \fi } {}% } % \end{macrocode} % Make definitions with |book| in the macro names or redefine them % for |book|? Chose the latter. % \begin{macrocode} \def\etocbookstyle{% \etocsettocstyle {\if@twocolumn \@restonecoltrue \onecolumn \else \@restonecolfalse \fi \ifEtoc@localtoc \@nameuse{etocclasslocal\Etoc@currext maketitle}% \etocclasslocalperhapsaddtotoc\Etoc@currext \else \chapter *{\contentsname \@mkboth {\MakeUppercase \contentsname} {\MakeUppercase \contentsname}}% \etocifisstarred{}{\etocifmaintoctotoc{\etocclassmaintocaddtotoc}{}}% \fi }% {\if@restonecol \twocolumn \fi}% } \def\etocbookstylenomarks{% \etocsettocstyle {\if@twocolumn \@restonecoltrue \onecolumn \else \@restonecolfalse \fi \ifEtoc@localtoc \@nameuse{etocclasslocal\Etoc@currext maketitle}% \etocclasslocalperhapsaddtotoc\Etoc@currext \else \chapter *{\contentsname}% \etocifisstarred{}{\etocifmaintoctotoc{\etocclassmaintocaddtotoc}{}}% \fi }% {\if@restonecol \twocolumn \fi}% } \let\etocreportstyle\etocbookstyle \let\etocreportstylenomarks\etocbookstylenomarks % \end{macrocode} % |v3.7i| of memoir has moved the \csa{phantomsection} to a better location, % before typesetting the title and we follow suit at \etocrelease{1.09a}, and % at \etocrelease{1.09b}. Formerly \etoc used \csbc{etocaftertitlehook} to % mimic the memoir code but as its name indicate, it is supposedly executed % after the title... and this also had the defect of making % \csbc{etocaftertitlehook} not anymore a user command. Thus we here use some % refactoring of the \csbc{Etoc@aftertitlehook} internal mechanism to help % recognize if we are in the starred case or not. % % \csa{phantomsection} is always defined by memoir, empty if hyperref absent. % % Updates at \etocrelease{1.2} for the standard display style inherited % from the class to actually be usable with local table of contents. % Unfortunately the printing of the title rigidly hard-codes a % |\thispagestyle{chapter}|: % \begin{verbatim} % \@lofmaketitle ->\@nameuse {lofheadstart} {\parindent \z@ \parskip \z@ \interli % nepenalty \@M \@nameuse {printlofnonum}\@nameuse {printloftitle}{\listfigurenam % e }\@nameuse {lofmark}\thispagestyle {chapter}\@nameuse {afterloftitle} } \@aft % erheading % \end{verbatim} % \vskip-\baselineskip % Oh well I discover there is a \csa{chapterheadstart} but not % \csa{sectionheadstart}... % % Actually now \etoc will by default not use the class inherited style for the % local TOC titles, so maybe I should have not wasted time on this. From the % \csbc{etocsettocstyle} arguments one can know if this is for a local TOC, % but one can not know the level, which is inferred from the actual execution % of the TOC data. There is a problem though that the \ctanpkg{memoir} % default would be usable for a local TOC in a |\part|. Although one can % argue if it makes sense to display a TOC as prominently as a chapter anyway. % Again, the default with \etoc will anyhow not use this as % \csbc{etocetoclocaltocstyle} deactivates the \csbc{etocsettocstyle} for % local TOCs. % % MEMO: would it make sense to have an \csa{etocsetlocaltocstyle}? As % explained above this would however induced dramatic internal \etoc changes as one % would have to wait for title insertion until the time one knows the local % level. Which is exactly what \csbc{etocetoclocaltocstyle} via the % \csbc{ifEtoc@etocstyle} does. % % Update at \etocrelease{1.2} to account for \csbc{locallistoffigures} and % \csbc{locallistoftables}. % \begin{macrocode} \def\etocmemoirstyle{% \etocsettocstyle {\ensureonecol \par \begingroup \phantomsection \ifx\Etoc@aftertitlehook\@empty \else % \end{macrocode} % This branch executed for the non-starred variant % \begin{macrocode} \ifmem@em@starred@listof \else % \end{macrocode} % Global case is only for \csa{tableofcontents} as \etoc does not hack into % \csa{listofpictures} and \csa{listoftables}. % % Local case will not be executed in default configurations (cf % \csbc{etocetoclocaltocstyle}). % % \csbc{etocclasslocalperhapsaddtotoc} is to avoid worries with conditionals. % \begin{macrocode} \ifEtoc@localtoc \etocclasslocalperhapsaddtotoc\Etoc@currext \else \ifEtoc@maintoctotoc \etocclassmaintocaddtotoc \fi \fi \fi \fi \ifEtoc@localtoc % \end{macrocode} % Trying to mimic a section title but there is no \csa{sectionheadstart} % there is no \csa{printsectiontitle} etc... Oh well I will be more % radical then. % \begin{macrocode} \@namedef{@\Etoc@currext maketitle}{% \@nameuse{etocclasslocal\Etoc@currext maketitle}% }% \fi \@nameuse {@\Etoc@currext maketitle} %<< space token here from memoir code \ifx\Etoc@aftertitlehook\@empty \else % \end{macrocode} % Execute etoc hook before the \csa{cfttocbeforelisthook} and keep distinction % between starred and non-starred contexts for other hooks (by testing if % \csbc{Etoc@aftertitlehook} is empty or not). Notice that the memoir class % way of implementing \csbc{tableofcontents} leaves no way for code executed % by the TOC code to know if it is executed in starred or non-starred context. % \begin{macrocode} \Etoc@aftertitlehook \let \Etoc@aftertitlehook \relax \fi \parskip \cftparskip \@nameuse {cft\Etoc@currext beforelisthook}% }% {\@nameuse {cft\Etoc@currext afterlisthook}% \endgroup\restorefromonecol }% } % \end{macrocode} % Compatibility layer for the \ctanpkg{KOMA-script} classes: % % \etocrelease{1.09c} (|2020/05/15|) did an update as \ctanpkg{KOMA-script} % deprecated \csa{iftocfeature}. Thanks to Bilel Omrani for report. I % did not check if cloning of KOMA code required some further updates. % \etocrelease{1.09f} added more updates. % % At \etocrelease{1.2} this is further updated to be usable also for list % of figures and tables. However, this update is somewhat theoretical because % \etoc does not interfere at all with \csa{listoffigures} and % \csa{listoftables}: the update is useful only to make \etoc's % \csbc{locallistoffigures} and \csbc{locallistoftables} usable in display % style compatibility mode. % % But during development on this I became aware that \ctanpkg{KOMA-script} % since its |3.30| release has the feature that an unnumbered section resets % the counters of subsections. This creates a problem (whose description I % have moved to the user manual) which can be alleviated for local TOCs at the % highest level below global one by using KOMA's |\setuptoc{toc}{leveldown}|. % So I decided to do this systematically, as in the code next via a new % private hook, but the problem will remain for local TOCs at lower levels, % and there does not seem to be any way to tell KOMA to use say % |\subsubsection*|, barring, from what I understand from the manual, usage of % its \csa{deftocheading}. So in a second stage I decided that per default % \etoc would rather use for local TOCs, and not only for KOMA classes but all % classes, an adaptive heading fitted to the ``local top''. As this ``local % top'' can only be determined from inside the expansion of \csbc{Etoc@toctoc} % which contains the |.toc| file data, the boolean \csbc{ifEtoc@etocstyle} % was added which will make \csbc{etocsettocstyle} configuration ignored. In % this way, with \csbc{etocetoclocaltocstyle}, the document class emulation % will apply to the global TOC whereas local TOCs will use the adaptive % scheme. To avoid duplication other relevant info is moved to the user % manual. % % We put the trigger of |leveldown| for KOMA classes in % \csbc{Etoc@beforetitlehook}. So there will be no test with % \csbc{ifEtoc@localtoc} here contrarily to the case of standard classes % and memoir. Again, all of this normally is not relevant as by default \etoc % \etocrelease{1.2} will use its \csbc{etocetoclocaltocstyle} which % for local TOCs ignores the emulation code of the main TOC. % \begin{macrocode} \let\Etoc@beforetitlehook\@empty \if1\@ifclassloaded{scrartcl}0{\@ifclassloaded{scrbook}0{\@ifclassloaded{scrreprt}01}}% \expandafter\@gobble \else % \end{macrocode} % Surely paranoid here but I don't have time to go through KOMA documentation % (I am not really familiar with these classes). % % MEMO: I do not know if \ctanpkg{KOMA-script}'s \csa{setuptoc} sets options % locally or globally. If globally the code below must be modifed to unset % the |totoc| option depending on at time of use status of the \etoc own % |totoc| options. % \begin{macrocode} \ifdefined\setuptoc \def\Etoc@beforetitlehook{% \ifEtoc@localtoc \etocclasslocalperhapsaddtotoc\Etoc@currext \setuptoc{\Etoc@currext}{leveldown}% \else \etocifisstarred{}{\etocifmaintoctotoc{\setuptoc{toc}{totoc}}}% \fi }% \fi \expandafter\@firstofone \fi {\def\etocclasslocalperhapsaddtotoc #1{% \etocifisstarred {}% {\csname ifEtoc@local#1totoc\endcsname \setuptoc{\Etoc@currext}{totoc}% \fi }% }% } \ifdefined\Iftocfeature \def\etoc@Iftocfeature{\Iftocfeature}% \else \def\etoc@Iftocfeature{\iftocfeature}% \fi % \end{macrocode} % Peut-être en fait je devrais toujours faire |\let\if@dynlist\if@tocleft|? % Mais je ne l'ai pas vu dans le code de KOMA pour les LOF et LOT (globales, % évidemment). Mais cela m'obligerait à lire vraiment le code source de KOMA. % Pas le temps. % \begin{macrocode} \def\etocscrartclstyle{% \etocsettocstyle {\ifx\Etoc@currext\Etoc@tocext \expandafter\@firstofone \else \expandafter\@gobble \fi {\let\if@dynlist\if@tocleft}% \edef\@currext{\Etoc@currext}% \@ifundefined{listof\@currext name}% {\def\list@fname{\listofname~\@currext}}% {\expandafter\let\expandafter\list@fname \csname listof\@currext name\endcsname}% \etoc@Iftocfeature {\@currext}{onecolumn} {\etoc@Iftocfeature {\@currext}{leveldown} {} {\if@twocolumn \aftergroup \twocolumn \onecolumn \fi }} {}% \etoc@Iftocfeature {\@currext}{numberline}% {\def \nonumberline {\numberline {}}}{}% \expandafter\tocbasic@listhead\expandafter {\list@fname}% \begingroup \expandafter \expandafter \expandafter \endgroup \expandafter \ifx \csname microtypesetup\endcsname \relax \else \etoc@Iftocfeature {\@currext}{noprotrusion}{} {\microtypesetup {protrusion=false}% \PackageInfo {tocbasic}% {character protrusion at \@currext\space deactivated}}% \fi \etoc@Iftocfeature{\@currext}{noparskipfake}{}{% \ifvmode \@tempskipa\lastskip \vskip-\lastskip \addtolength{\@tempskipa}{\parskip}\vskip\@tempskipa\fi }% \setlength {\parskip }{\z@ }% \setlength {\parindent }{\z@ }% \setlength {\parfillskip }{\z@ \@plus 1fil}% \csname tocbasic@@before@hook\endcsname \csname tb@\@currext @before@hook\endcsname }% end of before_toc {% start of after_toc % \end{macrocode} % (This next discussion has not been revised at \etocrelease{1.2} so let's % hope it is fine). % % At \etocrelease{1.09f} I considered adding this \csa{BeforeClosingMainAux} hunk % to the second argument of \csbc{etocsettocstyle}-emulation of \ctanpkg{KOMA-script}. % But: % \begin{itemize} % \item there seems to be no interface to \csa{tocbasic@end@toc@file}, % % \item % it defaults to issuing a \csa{par}, but we want etoc to still be able % to produce other TOCs, possibly inline, and they should not be % influenced by it and I don't want at this stage to add an interface % to enable/disable and have to document it, % % \item % the whole thing appears to me to be ill-conceived in so far as it % sort of implies the \csbc{tableofcontents} is used only once, as each % instance will again add this \csa{tocbasic@end@toc@file} to end of % toc file, which may thus end up being executed multiple times. % \end{itemize} % So rather than putting the thing in the |.toc| file, we will execute % it here. This way it will not impact other TOCs typeset via etoc % design facilities in the document. % \begin{macrocode} % \BeforeClosingMainAux % {\addtocontents % {toc}{\string\providecommand\string\tocbasic@end@toc@file{}% % \string\tocbasic@end@toc@file}% % }% \providecommand\tocbasic@end@toc@file{}\tocbasic@end@toc@file \edef\@currext{\Etoc@currext}% \csname tb@\@currext @after@hook\endcsname \csname tocbasic@@after@hook\endcsname }% end of after_toc } \let\etocscrbookstyle\etocscrartclstyle \let\etocscrreprtstyle\etocscrartclstyle % \end{macrocode} % The \csbc{etocclasstocstyle} will be redefined according to document % class. Then, later, it will be extended with an % \csa{Etoc@classstyletrue}. % \begin{macrocode} \def\etocclasstocstyle{\etocarticlestyle} \newcommand*\etocmarkboth[1]{% \@mkboth{\MakeUppercase{#1}}{\MakeUppercase{#1}}} \newcommand*\etocmarkbothnouc[1]{\@mkboth{#1}{#1}} \newcommand\etoctocstyle[3][section]{\etocmulticolstyle[#2]% {\csname #1\endcsname *{#3}}} \newcommand\etoctocstylewithmarks[4][section]{\etocmulticolstyle[#2]% {\csname #1\endcsname *{#3\etocmarkboth{#4}}}} \newcommand\etoctocstylewithmarksnouc[4][section]{\etocmulticolstyle[#2]% {\csname #1\endcsname *{#3\etocmarkbothnouc{#4}}}} \def\Etoc@redefetocstylesforchapters{% \renewcommand\etoctocstylewithmarks[4][chapter]{% \etocmulticolstyle[##2]{\csname ##1\endcsname *{##3\etocmarkboth{##4}}}% } \renewcommand\etoctocstylewithmarksnouc[4][chapter]{% \etocmulticolstyle[##2]{\csname ##1\endcsname *{##3\etocmarkbothnouc{##4}}}% } \renewcommand\etoctocstyle[3][chapter]{% \etocmulticolstyle[##2]{\csname ##1\endcsname *{##3}} } } \@ifclassloaded{scrartcl} {\renewcommand*\etocclasstocstyle{\etocscrartclstyle}}{} \@ifclassloaded{book} {\renewcommand*\etocfontone{\normalfont\normalsize} \renewcommand*\etocclasstocstyle{\etocbookstyle} \Etoc@redefetocstylesforchapters}{} \@ifclassloaded{report} {\renewcommand*\etocfontone{\normalfont\normalsize} \renewcommand*\etocclasstocstyle{\etocreportstyle} \Etoc@redefetocstylesforchapters}{} \@ifclassloaded{scrbook} {\renewcommand*\etocfontone{\normalfont\normalsize} \renewcommand*\etocclasstocstyle{\etocscrbookstyle} \Etoc@redefetocstylesforchapters}{} \@ifclassloaded{scrreprt} {\renewcommand*\etocfontone{\normalfont\normalsize} \renewcommand*\etocclasstocstyle{\etocscrreprtstyle} \Etoc@redefetocstylesforchapters}{} \@ifclassloaded{memoir} {\renewcommand*\etocfontone{\normalfont\normalsize} \renewcommand*\etocclasstocstyle{\etocmemoirstyle} \Etoc@redefetocstylesforchapters}{} \def\etoctocloftstyle {% \etocsettocstyle{% \@cfttocstart \par \begingroup \parindent\z@ \parskip\cftparskip % \end{macrocode} % I don't feel like redefining \csa{@cftmaketoctitle} etc to apply ``level % down''. Up to the user to use the tocloft interface after the main TOC % to do appropriate actions. I consider emitting a warning, but then if % the user has customize \csa{@cftmaketoctitle} or variant, how to know? % (apart from numerous ifx tests). % \begin{macrocode} \@nameuse{@cftmake\Etoc@currext title}% % \end{macrocode} % But for adding an appropriate entry to the toc file I can intervene silently. % I can remove the test \csa{if@cfttocbibind} here as anyhow I have to test % status of \etoc `to toc' options. % \begin{macrocode} \ifEtoc@localtoc \etoctocloftlocalperhapsaddtotoc\Etoc@currext \else \etocifisstarred {}{\ifEtoc@maintoctotoc\@cftdobibtoc\fi}% \fi }% {% \endgroup \@cfttocfinish }% } \def\etoctocloftlocalperhapsaddtotoc#1{% \etocifisstarred {}% {\csname ifEtoc@local#1totoc\endcsname \ifdefined\c@chapter\def\@tocextra{@section}\else\def\@tocextra{@subsection}\fi \csname @cftdobib#1\endcsname \fi }% } % \end{macrocode} % This is active only if \ctanpkg{tocbibind} boolean \csa{if@dotoctoc} is found % true at begin document and there was no use of \csbc{etocsettocstyle} in the % preamble. The part on local TOC also applies to local LOF and LOT but is % executed only if \csbc{etocclasstocstyle} was present in the preamble. Under % the default \csbc{etocetoclocaltocstyle}, only the global TOC is under % influence of this (assuming thus that \ctanpkg{tocbibind} was loaded without % its |nottoc| or |none| option). % \begin{macrocode} \def\etoctocbibindstyle {% \etocsettocstyle {% \toc@start \ifEtoc@localtoc \@nameuse{etocclasslocal\Etoc@currext maketitle}% \etocclasslocalperhapsaddtotoc\Etoc@currext \else \etoc@tocbibind@dotoctitle \fi }% {\toc@finish}% } \def\etoc@tocbibind@dotoctitle {% % \end{macrocode} % If \ctanpkg{tocbibind} is loaded but later between |\begin{document}| and % \csa{tableofcontents} the user does \csbc{etocsetup}|{maintoctotoc=afalse}| % we have to catch this. % \begin{macrocode} \if@bibchapter \etocifisstarred {\chapter*{\contentsname}\prw@mkboth{\contentsname} % id. }% {\ifEtoc@maintoctotoc \toc@chapter{\contentsname} %<-space from original \else \chapter*{\contentsname}\prw@mkboth{\contentsname} % id. \fi }% \else \etocifisstarred {\@nameuse{\@tocextra}*{\contentsname\prw@mkboth{\contentsname}} %<-space } {\ifEtoc@maintoctotoc \toc@section{\@tocextra}{\contentsname} %<-space from original \else \@nameuse{\@tocextra}*{\contentsname\prw@mkboth{\contentsname}} % id. \fi }% \fi }% % \end{macrocode} % The \etocrelease{1.2} added a bug here in the non-\ctanpkg{memoir} % \ctanpkg{tocloft} branch, the needed \csa{AtBeginDocument} was removed by % accident and as a result the overwriting by \ctanpkg{tocloft} of % \csbc{tableofcontents} was not undone. % \begin{macrocode} \@ifclassloaded{memoir} {} {% memoir not loaded \@ifpackageloaded{tocloft} {\if@cftnctoc\else \ifEtoc@keeporiginaltoc \else \AtBeginDocument{\let\tableofcontents\etoctableofcontents}% \fi \fi } {\AtBeginDocument {\@ifpackageloaded{tocloft} {\if@cftnctoc\else \PackageWarningNoLine {etoc} {Package `tocloft' was loaded after `etoc'.\MessageBreak To prevent it from overwriting \protect\tableofcontents, it will\MessageBreak be tricked into believing to have been loaded with its\MessageBreak option `titles'. \space But this will cause the `tocloft'\MessageBreak customization of the titles of the main list of figures\MessageBreak and list of tables to not apply either.\MessageBreak You should load `tocloft' before `etoc'.}% \AtEndDocument{\PackageWarning{etoc} {Please load `tocloft' before `etoc'!\@gobbletwo}}% \fi \@cftnctoctrue }% {}% }% }% } \@ifclassloaded{memoir} {} {% memoir not loaded \AtBeginDocument{% \@ifpackageloaded{tocloft} {% \def\etocclasstocstyle{% \etoctocloftstyle \Etoc@classstyletrue }% \ifEtoc@etocstyle \ifEtoc@classstyle \etocclasstocstyle \Etoc@etocstyletrue \fi \else \ifEtoc@classstyle \etocclasstocstyle \fi \fi }% {% no tocloft \@ifpackageloaded {tocbibind} % \end{macrocode} % For some reason this \etocrelease{1.2} code had no |\fi| matching the % |\if@dotoctoc|. Fixed at \etocrelease{1.2d}. % \begin{macrocode} {\if@dotoctoc \def\etocclasstocstyle{% \etoctocbibindstyle \Etoc@classstyletrue }% \ifEtoc@etocstyle \ifEtoc@classstyle \etocclasstocstyle \Etoc@etocstyletrue \fi \else \ifEtoc@classstyle \etocclasstocstyle \fi \fi % \end{macrocode} % Not clear if I should interpret \csa{Etoc@keeporiginaltoctrue} in this sense % to not modify \ctanpkg{tocbibind} overwrite of \csbc{tableofcontents}. But % let's obey this interpretation. % \begin{macrocode} \ifEtoc@keeporiginaltoc \else \let\tableofcontents\etoctableofcontents \fi \fi }% end of tocbibind without tocloft at begin document code {}% empty false branch }% end of no tocloft at begin document code % \end{macrocode} % Maybe I should check if the options were already set. I will simply % make the message more generic. % \begin{macrocode} \@ifpackageloaded{tocbibind} {% tocbibind, perhaps with tocloft \if@dotoctoc \ifEtoc@keeporiginaltoc \else \let\tableofcontents\etoctableofcontents \fi \etocsetup{maintoctotoc,localtoctotoc}% \PackageInfo{etoc}{% Setting (or re-setting) the options `maintoctotoc' and\MessageBreak `localtoctotoc' to true as tocbibind was detected and\MessageBreak found to be configured for `TOC to toc'.\MessageBreak Reported at begin document}% \fi \if@dotoclof \ifEtoc@lof \etocsetup{localloftotoc}% \PackageInfo{etoc}{% Setting (or re-setting) `localloftotoc=true' as the\MessageBreak package tocbibind was detected and is configured for\MessageBreak `LOF to toc'. Reported at begin document}% \fi \fi \if@dotoclot \ifEtoc@lot \etocsetup{locallottotoc}% \PackageInfo{etoc}{% Setting (or re-setting) `locallottotoc=true' as the\MessageBreak package tocbibind was detected and is configured for\MessageBreak `LOT to toc'. Reported at begin document}% \fi \fi }% end of tocbibind branch {}% }% end of at begin document }% end of not with memoir branch % \end{macrocode} % \LaTeX\ 2021 fall release lets \csa{contentsline} always grab four % arguments, so with \etocrelease{1.09e} |2021/09/23| we make sure our % \csa{addtocontents} will always provide \csa{contentsline} with four % arguments. This extra |{}| is done without checking LaTeX's version by % laziness, as an impact on documents compiled with former LaTeX could be % visible only with very special contexts that only the author himself would % ever consider. % % Let's also add \csa{protected@file@percent} at \etocrelease{1.09e} although % this is a priori of no relevance as \etoc reads the toc file with % |\endlinechar=-1| regime. % % When using \csa{addcontentsline} nothing needs to be done as both things are % handled by \LaTeX\ upstream. % % \etocrelease{1.2} executes the \csbc{ifEtoc@hyperref} test inside the fourth % argument, rather than using one \csa{addtocontents} in each branch. % \begin{macrocode} \def\Etoc@addtocontents #1#2{% \addtocontents {toc}{% \protect\contentsline{#1}{#2}{\thepage}{\ifEtoc@hyperref\@currentHref\fi}% \ifdefined\protected@file@percent\protected@file@percent\fi }% } \def\Etoc@addcontentsline@ #1#2#3{% \@namedef{toclevel@#1}{#3}\addcontentsline {toc}{#1}{#2}% } \DeclareRobustCommand*{\etoctoccontentsline} {\@ifstar{\Etoc@addcontentsline@}{\Etoc@addtocontents}} \def\Etoc@addtocontents@immediately#1#2{% \begingroup \let\Etoc@originalwrite\write \def\write{\immediate\Etoc@originalwrite}% \Etoc@addtocontents{#1}{#2}% \endgroup } \def\Etoc@addcontentsline@@immediately#1#2#3{% \begingroup \let\Etoc@originalwrite\write \def\write{\immediate\Etoc@originalwrite}% \Etoc@addcontentsline@{#1}{#2}{#3}% \endgoroup } \DeclareRobustCommand*{\etocimmediatetoccontentsline} {\@ifstar{\Etoc@addcontentsline@@immediately}{\Etoc@addtocontents@immediately}} % \end{macrocode} % Formerly a \LaTeX{} counter |etoc@tocdepth| was used but at % \etocrelease{1.2} it has been replaced by macro-storage. % \begin{macrocode} \def\Etoc@storetocdepth {\xdef\Etoc@savedtocdepth{\number\c@tocdepth}} \def\Etoc@restoretocdepth {\global\c@tocdepth\Etoc@savedtocdepth\relax} \def\etocobeytoctocdepth {\def\etoc@settocdepth {\afterassignment\Etoc@@nottoodeep \global\c@tocdepth}} \def\Etoc@@nottoodeep {\ifnum\Etoc@savedtocdepth<\c@tocdepth \global\c@tocdepth\Etoc@savedtocdepth\relax\fi } \def\etocignoretoctocdepth {\let\etoc@settocdepth\@gobble } \def\etocsettocdepth {\futurelet\Etoc@nexttoken\Etoc@set@tocdepth } \def\Etoc@set@tocdepth {\ifx\Etoc@nexttoken\bgroup \expandafter\Etoc@set@tocdepth@ \else\expandafter\Etoc@set@toctocdepth \fi } \def\Etoc@set@tocdepth@ #1{\@ifundefined {Etoc@#1@@} {\PackageWarning{etoc} {Unknown sectioning unit #1, \protect\etocsettocdepth\space ignored}} {\global\c@tocdepth\csname Etoc@#1@@\endcsname}% } \def\Etoc@set@toctocdepth #1#{\Etoc@set@toctocdepth@ } \def\Etoc@set@toctocdepth@ #1{% \@ifundefined{Etoc@#1@@}% {\PackageWarning{etoc} {Unknown sectioning depth #1, \protect\etocsettocdepth.toc ignored}}% {\addtocontents {toc} {\protect\etoc@settocdepth\expandafter\protect\csname Etoc@#1@@\endcsname}}% } % \end{macrocode} % placeholder % \begin{macrocode} \def\etocimmediatesettocdepth #1#{\Etoc@set@toctocdepth@immediately} \def\Etoc@set@toctocdepth@immediately #1{% \@ifundefined{Etoc@#1@@}% {\PackageWarning{etoc} {Unknown sectioning depth #1, \protect\etocimmediatesettocdepth.toc ignored}}% {\begingroup \let\Etoc@originalwrite\write \def\write{\immediate\Etoc@originalwrite}% \addtocontents {toc} {\protect\etoc@settocdepth\expandafter\protect \csname Etoc@#1@@\endcsname}% \endgroup }% } % \end{macrocode} % placeholder % \begin{macrocode} \def\etocdepthtag #1#{\Etoc@depthtag } \def\Etoc@depthtag #1{\addtocontents {toc}{\protect\etoc@depthtag {#1}}} % \end{macrocode} % \etocrelease{1.09f} adds \csbc{etocimmediatedepthtag.toc}. This can serve in some % circumstances, see user documentation. Apologies for long delay to Norman % Ramsey who reported problem and his fix in July... 2016! % \begin{macrocode} \def\etocimmediatedepthtag #1#{\Etoc@depthtag@immediately } \def\Etoc@depthtag@immediately #1{% \begingroup \let\Etoc@originalwrite\write \def\write{\immediate\Etoc@originalwrite}% \addtocontents {toc}{\protect\etoc@depthtag {#1}}% \endgroup } \def\etocignoredepthtags {\let\etoc@depthtag \@gobble } \def\etocobeydepthtags {\let\etoc@depthtag \Etoc@depthtag@ } \def\Etoc@depthtag@ #1{\@ifundefined{Etoc@depthof@#1}% {}% ignore in silence if tag has no associated depth {\afterassignment\Etoc@@nottoodeep \global\c@tocdepth\csname Etoc@depthof@#1\endcsname}% } \def\etocsettagdepth #1#2{\@ifundefined{Etoc@#2@@}% {\PackageWarning{etoc} {Unknown sectioning depth #2, \protect\etocsettagdepth\space ignored}}% {\@namedef{Etoc@depthof@#1}{\@nameuse{Etoc@#2@@}}}% } % \end{macrocode} % We must cancel all \ctanpkg{tocvsec2} toc-related actions. But a check must be done % for the memoir class, as its \ctanpkg{tocvsec2} emulation does not have the % incompatible things etoc needs to revert. % \begin{macrocode} \def\Etoc@tocvsec@err #1{\PackageError {etoc} {The command \protect#1\space is incompatible with `etoc'} {Use \protect\etocsettocdepth.toc as replacement}% }% \AtBeginDocument {% \@ifclassloaded{memoir} {\PackageInfo {etoc} {Regarding `memoir' class command \protect\settocdepth, consider\MessageBreak \protect\etocsettocdepth.toc as a drop-in replacement with more\MessageBreak capabilities (see `etoc' manual). \space Also, \protect\etocsettocdepth\MessageBreak and \protect\etocsetnexttocdepth\space should be used in place of\MessageBreak `memoir' command \protect\maxtocdepth\@gobble}% }% {\@ifpackageloaded {tocvsec2}{% \def\maxtocdepth #1{\Etoc@tocvsec@err \maxtocdepth }% \def\settocdepth #1{\Etoc@tocvsec@err \settocdepth }% \def\resettocdepth {\@ifstar {\Etoc@tocvsec@err \resettocdepth }% {\Etoc@tocvsec@err \resettocdepth }% }% % \end{macrocode} % If \etoc is added to a \LaTeX{} document using already \ctanpkg{tocvsec2}. % \begin{macrocode} \def\save@tocdepth #1#2#3{}% \let\reset@tocdepth\relax \let\remax@tocdepth\relax \let\tableofcontents\etoctableofcontents \PackageWarningNoLine {etoc} {Package `tocvsec2' detected and its modification of\MessageBreak \protect\tableofcontents\space reverted. \space Use \protect\etocsettocdepth.toc\MessageBreak as a replacement for `tocvsec2' toc-related commands}% }% tocvsec2 loaded {}% tocvsec2 not loaded }% }% % \end{macrocode} % placeholder % \begin{macrocode} \def\invisibletableofcontents {\etocsetnexttocdepth {-3}\tableofcontents }% \def\invisiblelocaltableofcontents {\etocsetnexttocdepth {-3}\localtableofcontents }% \def\etocsetnexttocdepth #1{% \@ifundefined{Etoc@#1@@} {\PackageWarning{etoc} {Unknown sectioning unit #1, \protect\etocsetnextocdepth\space ignored}} {\Etoc@setnexttocdepth{\csname Etoc@#1@@\endcsname}}% }% \def\Etoc@setnexttocdepth#1{% \def\Etoc@tocdepthset{% \Etoc@tocdepthreset \edef\Etoc@tocdepthreset {% \global\c@tocdepth\the\c@tocdepth\space \global\let\noexpand\Etoc@tocdepthreset\noexpand\@empty }% \global\c@tocdepth#1% \global\let\Etoc@tocdepthset\@empty }% }% \let\Etoc@tocdepthreset\@empty \let\Etoc@tocdepthset \@empty \def\etocsetlocaltop #1#{\Etoc@set@localtop}% \def\Etoc@set@localtop #1{% \@ifundefined{Etoc@#1@@}% {\PackageWarning{etoc} {Unknown sectioning depth #1, \protect\etocsetlocaltop.toc ignored}}% {\addtocontents {toc} {\protect\etoc@setlocaltop\expandafter\protect\csname Etoc@#1@@\endcsname}}% }% % \end{macrocode} % placeholder % \begin{macrocode} \def\etocimmediatesetlocaltop #1#{\Etoc@set@localtop@immediately}% \def\Etoc@set@localtop@immediately #1{% \@ifundefined{Etoc@#1@@}% {\PackageWarning{etoc} {Unknown sectioning depth #1, \protect\etocimmediatesetlocaltop.toc ignored}}% {\begingroup \let\Etoc@originalwrite\write \def\write{\immediate\Etoc@originalwrite}% \addtocontents {toc} {\protect\etoc@setlocaltop\expandafter\protect \csname Etoc@#1@@\endcsname}% \endgroup }% }% % \end{macrocode} % \etocrelease{1.09i} would like to rename this to \csa{Etoc@setlocaltop}, for % consistency with internal macros, but too late it is already in user |.toc| files. % \begin{macrocode} \def\etoc@setlocaltop #1{% \ifnum#1=\Etoc@maxlevel \Etoc@skipthisonetrue \else \Etoc@skipthisonefalse % \end{macrocode} % MEMO: the \csbc{Etoc@level} thus continues receiving updates from various % \csbc{etoc@setlocaltop} present in the |.toc| file even once the local toc % is already done, but this has no importance, as the code in % \csbc{Etoc@toctoc} after executing the code contents is not influenced by % this but only by the final status of \csbc{Etoc@stackofends} remains the % same. And this gets updated via \csbc{Etoc@setlocaltop@doendsandbegin} (see % below). % % I should check if not worthwile to move the \csbc{ifEtoc@stoptoc} test % earlier. % % There should be two notions of local top. One for a potential barrier, % stopping a toc, the other for setting a local top. These two should be % distinct. Or at least additional to this one which does both. But then I % would have to document. And test. And implement first. % \begin{macrocode} \global\let\Etoc@level #1% \global\let\Etoc@virtualtop #1% \ifEtoc@localtoc \ifEtoc@stoptoc \Etoc@skipthisonetrue \else \ifEtoc@notactive \Etoc@skipthisonetrue \else \unless\ifnum\Etoc@level>\etoclocaltop \Etoc@skipthisonetrue \global\Etoc@stoptoctrue \fi \fi \fi \fi \fi \let\Etoc@next\@empty \ifEtoc@skipthisone \else \ifnum\Etoc@level>\c@tocdepth \else \ifEtoc@standardlines \else % \end{macrocode} % So here the \csbc{etocsetlocaltop}|.toc| will cause various starts and % finish parts to get executed, even for the somewhat fictitious levels. But % this may cause collaterals, in particular we have to be careful about the % \csbc{ifEtoc@skipprefix} Boolean, which may be set to \csa{iftrue} in % the \marg{start} part of the level style and thus needs to be reset to % \csa{iffalse}. This is done automatically in \csbc{Etoc@etoccontentsline@} % but here we are not executing it so we need to add somewhere a % |\global\Etoc@skipprefixfalse| (else we may impact rendering of subsequent % level). So we put it together with \csbc{Etoc@doendsandbegin} in a wrapper. % This wrapper is also there to avoid a problem when the TOC is checked for % emptiness, as we need then to be able to tell \csbc{etoc@setlocaltop} to % not execute anything. % % This also stresses % that the name of the macro is a bit of a misnomer, yes it serves to delimit % local table of contents, but really it is implemented as a ghost of a % sectioning unit which does have an impact (on the global TOC or local TOCs % from encompassing levels), as it triggers when encountered the \marg{finish} % portions of previous finer levels (and the \marg{finish} code of its own % level will be executed sooner or later), and the \marg{start} code of % subsequent finer levels (as well as its own \marg{start} code at least once, % depending on how levels are nested). % \begin{macrocode} \let\Etoc@next\Etoc@setlocaltop@doendsandbegin \fi \fi \fi \Etoc@next }% % \end{macrocode} % It is important to reset the \csbc{ifEtoc@skipprefix} boolean, as is done in % \csbc{Etoc@etoccontentsline@}.\par % \begin{macrocode} \def\Etoc@setlocaltop@doendsandbegin{% \Etoc@doendsandbegin \global\Etoc@skipprefixfalse } \addtocontents {toc}{\protect\@ifundefined{etoctocstyle}% {\let\protect\etoc@startlocaltoc\protect\@gobble \let\protect\etoc@settocdepth\protect\@gobble \let\protect\etoc@depthtag\protect\@gobble \let\protect\etoc@setlocaltop\protect\@gobble}{}}% % \end{macrocode} % Initializations. % \begin{macrocode} \def\etocstandardlines {\Etoc@standardlinestrue} \def\etoctoclines {\Etoc@standardlinesfalse} \etocdefaultlines \etocstandardlines \def\etocstandarddisplaystyle{% \PackageWarningNoLine{etoc}{% \string\etocstandarddisplaystyle \on@line\MessageBreak is deprecated. \space Please use \string\etocclasstocstyle}% } \expandafter\def\expandafter\etocclasstocstyle\expandafter{% \etocclasstocstyle \Etoc@classstyletrue } \def\etocetoclocaltocstyle{\Etoc@etocstyletrue} \def\etocusertocstyle{\Etoc@etocstylefalse} \etocclasstocstyle \etocetoclocaltocstyle \etocobeytoctocdepth \etocobeydepthtags \let\etocbeforetitlehook \@empty \let\etocaftertitlehook \@empty \let\etocaftercontentshook \@empty \let\etocaftertochook \@empty % \end{macrocode} % |listings| abuses \csa{tableofcontents} for its \csa{lstlistoflistings}. It % doesn't seem worth to let my version of \csbc{tableofcontents} have to check for % this special circumstance. So at \etocrelease{1.09d}, simply add this (the % boolean was added at \etocrelease{1.2}): % \begin{macrocode} \def\etockeeporiginaltableofcontents {\Etoc@keeporiginaltoctrue\let\tableofcontents\etocoriginaltableofcontents}% \endinput % \end{macrocode} % \MakePercentComment \Finale %% %% End of file `etoc.dtx'.