% \iffalse meta-comment
% ======================================================================
% floatbytocbasic.dtx
% Copyright © 2008–2023 Markus Kohm
%
% This work is a KOMA-Script spin-off. For the original sources of
% KOMA-Script's `float.hak' see file `scrhack.dtx' in the KOMA-Script
% sources at .
%
% Development is taking place as part of `scrhack' at
% . New issues
% should be reported there as well as known issues can be found.
%
% This work may be distributed and/or modified under the conditions of
% the LaTeX Project Public License, version 1.3c of the license.
% The latest version of this license is in
% http://www.latex-project.org/lppl.txt
% and version 1.<3c or later is part of all distributions of LaTeX
% version 2005/12/01 or later and of this work.
%
% The Current Maintainer and author of this work is Markus Kohm.
%
% This work consists of the file `floatbytocbasic.dtx' and `README.md'.
%
% The recommended way to install `floatbytocbasic' is to use
% the package manager of your TeX distribution.
% ======================================================================
%
%<*dtx>
\ifx\ProvidesFile\undefined\def\ProvidesFile#1[#2]{}\fi
\ProvidesFile{floatbytocbasic.dtx}
%
%<*dtx|package>
%\ProvidesPackage{floatbytocbasic}
[2023-08-16 v1.0
% sources and unpack driver of
improved float package using tocbasic]
%
%<*dtx>
\ifx\documentclass\undefined
\input docstrip.tex
\generate{%
\file{floatbytocbasic.sty}{%
\from{floatbytocbasic.dtx}{package}%
}%
}%
\else
\let\endbatchfile\relax
\fi
\endbatchfile
\documentclass[ngerman,USenglish]{koma-script-source-doc}
\usepackage{babel}
\usepackage{csquotes}
\usepackage[style=alphabetic]{biblatex}
\begin{filecontents}[force]{\jobname.bib}
@online{pkg:float,
author={Anselm Lingnau},
title={\pkg*{float} --- Improved interface for floating objects},
version={1.3d},
date={2001-11-08},
url={https://ctan.org/pkg/float},
urldate={2023-07-14},
note={Improves the interface for defining floating objects such as figures
and tables. Introduces the boxed float, the ruled float and the
plaintop float. You can define your own floats and improve the
behaviour of the old ones.},
}
@manual{pkg:float:manual,
author={Anselm Lingnau},
date={2001-11-08},
title={An Improved Environment for Floats},
url={http://mirrors.ctan.org/macros/latex/contrib/float/float.pdf},
urldate={2023-07-14},
abstract={This style option improves the interface for defining floating
objects such as figures and tables in \LaTeX. It adds the notion
of a ‘float style’ that governs appearance of floats. New kinds of
floats may be defined using \cs{newfloat} command analogous to
\cs{newtheorem}. This style option also incorporates the
functionality of David Carlisle’s style option \pkg{here}, giving
floating environments a \texttt{[H]} option which means ‘PUT IT
HERE’ (as opposed to the standard \texttt{[h]} option which means
‘You may put it here if you like’).},
}
@online{pkg:xpatch,
author = {Enrico Gregorio},
version = {0.3},
date = {2020-03-25},
title = {\pkg*{xpatch} – Extending \pkg{etoolbox} patching commands},
url = {https://ctan.org/pkg/xpatch},
urldate = {2023-07-19},
note = {The package generalises the macro patching commands provided
by Philipp Lehmann's \pkg{etoolbox}.},
}
@manual{pkg:xpatch:manual,
author = {Enrico Gregorio},
version = {0.3},
date = {2020-03-25},
title = {The \pkg*{xpatch} package
extending \pkg{etoolbox} patching commands},
url = {http://mirrors.ctan.org/macros/latex/contrib/xpatch/xpatch.pdf},
urldate = {2023-07-19},
abstract = {},
}
@online{pkg:scrlfile,
author = {Markus Kohm},
version = {3.41},
date = {2023-07-07},
title = {\pkg*{scrlfile} – Installation control (not only) for
\KOMAScript{} packages},
url = {https://ctan.org/pkg/scrlfile},
urldate = {2023-07-19},
note = {The package provides hooks for the execution of commands before
or after loading files, classes or packages independent from the
\LaTeX{} kernel version.},
}
@online{pkg:koma-script,
author={Markus Kohm},
version={3.41},
date={2023-07-07},
title={{\KOMAScript} --- A bundle of versatile classes and packages},
url={https://ctan.org/pkg/koma-script},
urldate={2023-07-14},
note={The \KOMAScript{} bundle provides replacements for the \pkg*{article},
\pkg*{report}, and \pkg*{book} classes with emphasis on typography and
versatility. There is also a letter class.},
}
@online{pkg:tocbasic,
author={Markus Kohm},
version={3.41},
date={2023-07-07},
title={\pkg*{tocbasic} --- Management of tables/lists of contents (and the
like)},
url={https://ctan.org/pkg/tocbasic},
urldate={2023-07-14},
note={The package provides means to create specialised ``table of
contents''-like lists of features of a document.},
}
@manual{pkg:koma-script:manual:de,
author={Markus Kohm},
date={2023-06-16},
title={{\KOMAScript}},
subtitle={Die Anleitung},
url={http://mirrors.ctan.org/macros/latex/contrib/koma-script/scrguide-de.pdf},
urldate={2023-07-04},
}
@manual{pkg:koma-script:manual:en,
author={Markus Kohm},
date={2023-06-16},
title={{\KOMAScript}},
subtitle={The Guide},
url={http://mirrors.ctan.org/macros/latex/contrib/koma-script/scrguide-en.pdf},
urldate={2023-07-14},
}
\end{filecontents}
\addbibresource{\jobname.bib}
\setcounter{StandardModuleDepth}{2}
\begin{document}
\nocite{pkg:float,pkg:koma-script,pkg:tocbasic}
\DocInput{floatbytocbasic.dtx}
\end{document}
%
%\fi
%
% \changes{v0.1}{2023/06/01}{start of \KOMAScript{} spin-off}
% \changes{v1.0}{2023/08/19}{first package release}
%
% \GetFileInfo{floatbytocbasic.dtx}
% \title{Improving Package \pkg{float} Using
% \href{https://komascript.de/}{\KOMAScript} Package \pkg{tocbasic}}
% \author{\href{mailto:komascript@gmx.info}{Markus Kohm}}
% \date{Version \filedate{} \fileversion}
% \maketitle
% \begin{abstract}
% Package \pkg*{floatbytocbasic} has started as hack module of the
% \KOMAScript{} package \pkg*{scrhack} years ago to fix an issue when using
% package \pkg{float} with \KOMAScript~3. This became necessary because
% package \pkg{float} still depends on an interface once proposed by the
% \KOMAScript{} author, but which has long since failed to meet
% requirements. Unfortunately, this problem could not be solved in dialog
% with the author of \pkg{float}. Although \pkg*{floatbytocbasic} still
% loads the \pkg{float} package, it then changes some internal commands to
% use and optimally support the \KOMAScript{} package \pkg{tocbasic}. On the
% one hand, the user interface of \pkg{float} remains usable unchanged, but
% at the same time the package benefits from many possibilities of
% \pkg{tocbasic}.
% \end{abstract}
%
% \tableofcontents
%
%\iffalse
%<*doc>
%\fi
\section{Why should I use this package instead of
\texorpdfstring{\pkg{float}}{float} only if I use a \KOMAScript{} class or
\KOMAScript{} package \texorpdfstring{\pkg{tocbasic}}{tocbasic}?}
\label{sec:whywithkomascript}
The main symptom of using a deprecated interface to \KOMAScript{} by package
\pkg{float}, namely the use of \cs{float@listhead} and
\cs{float@addtolists}, are corresponding warnings when using one of the
\KOMAScript{} classes at the same time, for example:
\begin{verbatim}
Class scrbook Warning: \float@addtolists detected!
(scrbook) Implementation of \float@addtolist became
(scrbook) deprecated in KOMA-Script v3.01 2008/11/14 and
(scrbook) has been replaced by several more flexible
(scrbook) features of package `tocbasic`.
(scrbook) Since Version 3.12 support for deprecated
(scrbook) \float@addtolist interface has been
(scrbook) restricted to only some of the KOMA-Script
(scrbook) features and been removed from others.
(scrbook) Loading of package `scrhack' may help to
(scrbook) avoid this warning, if you are using a
(scrbook) a package that still implements the
(scrbook) deprecated \float@addtolist interface.
\end{verbatim}
or
\begin{verbatim}
Class scrbook Warning: \float@listhead detected!
(scrbook) Implementation of \float@listhead became
(scrbook) deprecated in KOMA-Script v3.01 2008/11/14 and
(scrbook) has been replaced by several more flexible
(scrbook) features of package `tocbasic`.
(scrbook) Maybe implementation of \float@listhead will
(scrbook) removed from KOMA-Script soon.
(scrbook) Loading of package `scrhack' may help to
(scrbook) avoid this warning, if you are using a
(scrbook) a package that still implements the
(scrbook) deprecated \float@listhead interface.
\end{verbatim}
If you know, that the issue is because of loading package \pkg{float} you can
avoid it using \pkg{floatbytocbasic} as explained in \autoref{sec:howtouse}.
\section{Why should I use this package instead of
\texorpdfstring{\pkg{float}}{float} only if I don't use a \KOMAScript{}
class or package?}
\label{sec:whywithoutkomascript}
Package \pkg{float} does not check if a file extension or environment already
has been defined when using \cs{newfloat}. So several definitions of float
environments either with the same name or the same file extension could happen
by accident. Package \pkg*{floatbytocbasic} adds test to avoid such
issues. Alternatively you can force the definition or do the definition only
if needed. See description of \cs{deffloat}, \cs{renewfloat} and
\cs{providefloat} in \autoref{sec:howtouse} for more information.
Package \pkg{tocbasic} provides several additional features, e.g.:
\begin{itemize}
\item automatic handling of language switching using \pkg{babel},
\item optional numbered heading for a list/table of contents,
\item optional adding an entry to the table of contents for a list/table of
contents even if the heading is not numbered,
\item easy configuration of entries to a list/table of contents.
\end{itemize}
Several more features can be added by the class or other packages. See section
about \pkg*{tocbasic} in the \KOMAScript{} manual, either
\autocite{pkg:koma-script:manual:en} or \autocite{pkg:koma-script:manual:de}.
\section{How to use \texorpdfstring{\pkg*{floatbytocbasic}}{floatbytocbasic}}
\label{sec:howtouse}
In the document preamble of your document you just can replace
\begin{verbatim}
\usepackage{float}
\end{verbatim}
by
\begin{verbatim}
\usepackage{floatbytocbasic}
\end{verbatim}
to load package \pkg*{floatbytocbasic}. This does still also load package
\pkg{float} but additionally patches several commands of \pkg{float} to avoid
the issues shown in \autoref{sec:whywithkomascript}.
If you want you can alternatively also load both packages explicitly, either
\pkg{float} before \pkg{floatbytocbasic} or---if you
want---\pkg{floatbytocbasic} before \pkg{float}. This is also useful, if you
use a package, that uses \pkg*{float} itself. In this case, you always should
load \pkg{floatbytocbasic} \emph{before} the package, that uses
\pkg{float}. Otherwise it is very likely that for some new float environments
the enhancements of \pkg*{floatbytocbasic} will not be used. Only if
\pkg*{floatbytocbasic} is loaded before the first use of \cs{newfloat} can it
be ensured that the definition of the new sliding environments is really done
with the help of \pkg{tocbasic} and thus its extended user interface is used.
When using a class that uses \pkg{float}, the correct operation can be ensured
with
\begin{verbatim}
\AddToHook{package/float/after}{\RequirePackage{floatbytocbasic}}
\end{verbatim}
even before \cs{documentclass}. This requires at least \LaTeX{}
2020/10/01. For older versions of \LaTeX{} you can use
\begin{verbatim}
\RequirePackage{scrlfile}
\AfterPackage{float}{\RequirePackage{floatbytocbasic}}
\end{verbatim}
also before \cs{documentclass}. This would require the \KOMAScript{} package
\pkg{scrlfile}\nocite{pkg:scrlfile}.
\begin{description}
\item[Note:] You \emph{should not} load \pkg*{float} after loading package
\pkg*{floatrow}. However, if you do, \pkg{floatrowbytocbasic} will be
loaded automatically.
\end{description}
The user interface of \pkg*{floatbytocbasic} is the same as of \pkg{float},
see \autocite{pkg:float:manual}. Following we document only the differences.
\DescribeCommand{\newfloat}
\DescribeCommand{\providefloat}
\DescribeCommand{\renewfloat}
\DescribeCommand{\deffloat}
See \autocite[section~2]{pkg:float:manual} for the basic usage of \cs{newfloat}.
The command takes three mandatory arguments and an optional one; it is of
the form:
\begin{quote}
\cs{newfloat}\marg{type}\marg{placement}\marg{ext}\oarg{within}
\end{quote}
\pkg{floatbytocbasic} adds the registration of the file extension \meta{ext},
which is the third argument. The main problem here is to decide what to do, if
\meta{ext} already has been registered. Package \pkg{float} simply does not
care for this case. It does neither report an error nor a warning, but just
redefine the float \meta{type} and reuses the auxiliary file extension
\meta{ext}. Because of the ``\texttt{new}'' in the name of the command, we
have decided to do it a little bit different. If the owner of the \meta{ext}
is \texttt{float}, it is assumed, that using the same auxiliary file is
intended and only an info is written to the \file{log}-file. Otherwise an
error is reported. But we also decided to define three new commands:
\begin{quote}\raggedright
\cs{deffloat}\marg{type}\marg{placement}\marg{ext}\oarg{within}\\
\cs{providefloat}\marg{type}\marg{placement}\marg{ext}\oarg{within}\\
\cs{renewfloat}\marg{type}\marg{placement}\marg{ext}\oarg{within}
\end{quote}
\cs{deffloat} also does not care for already existing \meta{type} environment
or already registered \meta{ext}. \cs{providefloat} does not overwrite
existing \meta{type} environment or already registered \meta{ext} for other
owners but \texttt{float}. \cs{renewfloat} does overwrite only already
existing \meta{type} environment with registered \meta{ext}. There are also
cases like defined \cs{\meta{type}} but not \cs{end\meta{type}} or not defined
environment \meta{type} but registered \meta{ext}. But there are no special
commands to handle these. If users need to take care for these cases, they can
test for definition using the \LaTeX{} kernel macro \cs{@ifundefined} and the
\pkg{tocbasic} command \cs{Ifattoclist}, described in the \KOMAScript{} user
manuals \autocite{pkg:koma-script:manual:en}
resp. \autocite{pkg:koma-script:manual:de}.
%
% \iffalse
%
% \fi
%
% \MaybeStop{\printbibliography[heading=bibintoc]\PrintIndex}
%
% \iffalse
%<*package>
% \fi
% \section{Implementation}
%
% \pkg{floatbytocbasic} depend on \KOMAScript{} package \pkg{tocbasic}. So we
% load it already before everything else. We use this package also to require
% at least \KOMAScript{} 3.41, which is one version before the intended
% spin-off.
% \begin{macrocode}
\@ifpackageloaded{floatrow}{%
\PackageWarning{floatbytocbasic}{%
package incompatible with package floatrow.\MessageBreak
Automatically using floatrowbytocbasic%
}%
\RequirePackage{floatrowbytocbasic}%
\endinput
}{}
\RequirePackage{tocbasic}[2023/07/07]
% \end{macrocode}
%
% We also load package \pkg{float}, because we reuse most of the code:
% \begin{macrocode}
\RequirePackage{float}
% \end{macrocode}
%
% As often as possible, we do not redefine macors of \pkg{float}, but patch
% them using \pkg{xpatch}\nocite{pkg:xpatch}:
% \begin{macrocode}
\RequirePackage{xpatch}
% \end{macrocode}
%
% We also use the new document command interface. So if the \LaTeX{} kernel is
% too old, we require \pkg{xparse}:
% \begin{macrocode}
\@ifundefined{NewDocumentCommand}{%
\RequirePackage{xparse}%
}{}
% \end{macrocode}
%
% \begin{command}{\deffloat}
% Basicly \cs{deffloat} is \cs{newfloat} of \pkg{float}:
% \begin{macrocode}
\@ifundefined{NewCommandCopy}{\let\deffloat\newfloat}{%
\NewCommandCopy\deffloat\newfloat
}
% \end{macrocode}
% But we also have to take care, that a not yet registered \meta{ext} has to
% be registered.
% \begin{description}
% \item[Note:] We do not need to setup feature \texttt{chapteratlist}, because
% classes like the \KOMAScript{} classes should use
%\begin{verbatim}
% \AtAddToTocList[float]{\setuptoc{\@currext}{chapteratlist}}
%\end{verbatim}
% to implement such features.
% \end{description}
% \begin{macrocode}
\xpretocmd\deffloat{%
\Ifattoclist{#3}{%
\let\reserved@a\relax
\owneroftoc[\def\reserved@a]{#3}\relax
\@ifundefined{reserved@a}{}{%
\Ifstr{\reserved@a}{float}{%
\PackageInfo{floatbytocbasic}{%
reusing file extension `#3' for\MessageBreak
float type `#1'%
}%
}{%
\PackageWarning{floatbytocbasic}{%
reusing file extension `#3' of owner\MessageBreak
`\reserved@a' for float `#1'\MessageBreak
not recommended%
}%
}%
}%
}{\addtotoclist[float]{#3}}%
}{}{%
\PackageError{floatbytocbasic}{incompatible definition of
\string\newfloat}{%
Package `floatbytocbasic' depends on the original definition of package
`float'.\MessageBreak
Some changes to that definition are tolerated.\MessageBreak
\@ifundefined{deffloat}%
{But it seems the definition is completely missing!}%
{But the current definition is incompatible!}%
\MessageBreak
Make sure, you have installed the original package `float' as referred
by\Messagebreak
section ``References'' of the manual.%
}%
}
% \end{macrocode}
% \end{command}
%
% \begin{command}{\newfloat,\providefloat,\renewfloat}
% \cs{newfloat} and \cs{renewfloat} similar to \cs{newcommand} and
% \cs{renewcommand} do some tests and maybe report an error, before
% (nevertheless) defining the float.
% \begin{macrocode}
\RenewDocumentCommand{\newfloat}{mmmo}{%
\@tempswatrue
\Ifattoclist{#3}{%
\let\reserved@a\relax
\owneroftoc[\def\reserved@a]{#3}\relax
\@ifundefined{reserved@a}{}{%
\Ifstr{\reserved@a}{float}{}{%
\PackageError{floatbytocbasic}{%
reusing `#3' of owner `\reserved@a' not allowed%
}{%
Each file extension should be used only once.\MessageBreak
Reusing is only allowed with the same owner/category.\MessageBreak
You, the class, or another package already uses `#3'.\MessageBreak
\@eha
}%
\@tempswafalse
}%
}%
}{}%
\if@tempswa
\expandafter\@ifdefinable\csname #1\endcsname{%
\IfValueTF{#4}{%
\deffloat{#1}{#2}{#3}[#4]%
}{%
\deffloat{#1}{#2}{#3}%
}%
}%
\fi
}
\NewDocumentCommand{\providefloat}{mmmo}{%
\@ifundefined{#1}{%
\newfloat{#1}{#2}{#3}[#4]%
}{}%
}
\NewDocumentCommand{\renewfloat}{mmmo}{%
\@ifundefined{#1}{%
\@latex@error{Environment #1 undefined}\@ehc
\removefromtoclist{#3}%
}{%
\Ifattoclist{#3}{%
\removefromtoclist{#3}%
}{%
\PackageError{floatbytocbasic}{extension `#3' not yet registered}{%
I can only renew floats with already registered
extensions.\MessageBreak
\@ehc
}%
}%
}%
\expandafter\let\csname #1\endcsname\relax
\expandafter\let\csname end#1\endcsname\relax
\newfloat{#1}{#2}{#3}[#4]%
}
% \end{macrocode}
% \end{command}
%
% \begin{command}{\listof}
% This command is redefined using a complete new definition using
% \pkg{tocbasic}'s \cs{listoftoc}.
% \begin{macrocode}
\renewcommand*\listof[2]{%
\@ifundefined{ext@#1}{%
\PackageError{floatbytocbasic}{unknown float type `#1'}\@eha
}{%
\@ifundefined{l@#1}{\expandafter\let\csname l@#1\endcsname\l@figure
\@ifundefined{l@#1}{%
\DeclareTOCStyleEntry[level=1,numwidth=2.3em,indent=1.5em]
{default}{#1}%
}{}%
}{}%
\listoftoc[{#2}]{\csname ext@#1\endcsname}%
}%
}%
% \end{macrocode}
% \end{command}
%
% \iffalse
%
% \fi
%
% \Finale
% \PrintChanges
%
% \endinput
% Local Variables:
% mode: doctex
% ispell-local-dictionary: "en_US"
% eval: (flyspell-mode 1)
% TeX-master: t
% End: