% \iffalse meta-comment % % File: romanbar.dtx % Version: 2025-01-28 v1.0g % Info: Roman numbers with bars % % Copyright (C) 2011 - 2025 by % H.-Martin Münch % % The original code for the bars was written by Prof. Enrico Gregorio % (https://profs.sci.univr.it/~gregorio/), and published at % https://tex.stackexchange.com/a/24084 % I (H.-Martin Münch) submitted this package to CTAN % (after diverse updates of the code and writing a documentation). % % This work may be distributed and/or modified under the % conditions of the LaTeX Project Public License, either % version 1.3c of this license or (at your option) any later % version. This version of this license is in % https://www.latex-project.org/lppl/lppl-1-3c.txt % and the latest version of this license is in % https://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. % % This work has the LPPL maintenance status "maintained". % % The Current Maintainer of this work is H.-Martin Münch. % % This work consists of the main source file romanbar.dtx, % the README, and the derived files % romanbar.sty, romanbar.pdf, % romanbar.ins, romanbar.drv, % romanbar-example.tex, romanbar-example.pdf. % % "romanbar" is available on CTAN: % https://www.ctan.org/pkg/romanbar % % Also a TDS.ZIP file is provided that contains all the files % already sorted in a TDS tree: % https://mirror.ctan.org/install/macros/latex/contrib/romanbar.tds.zip % %<*ignore> \begingroup \catcode123=1 % \catcode125=2 % \def\x{LaTeX2e}% \expandafter\endgroup \ifcase 0\ifx\install y1\fi\expandafter \ifx\csname processbatchFile\endcsname\relax\else1\fi \ifx\fmtname\x\else 1\fi\relax \else\csname fi\endcsname % %<*install> \input docstrip.tex \Msg{********************************************************************} \Msg{* Installation *} \Msg{* Package: romanbar 2025-01-28 v1.0g Roman numbers with bars (HMM) *} \Msg{********************************************************************} \keepsilent \askforoverwritefalse \let\MetaPrefix\relax \preamble This is a generated file. Project: romanbar Version: 2025-01-28 v1.0g Copyright (C) 2011 - 2025 by H.-Martin Muench This work may be distributed and/or modified under the conditions of the LaTeX Project Public License, either version 1.3c of this license or (at your option) any later version. This version of this license is in https://www.latex-project.org/lppl/lppl-1-3c.txt and the latest version of this license is in https://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. This work has the LPPL maintenance status "maintained". The Current Maintainer of this work is H.-Martin Muench. This work consists of the main source file romanbar.dtx, the README, and the derived files romanbar.sty, romanbar.pdf, romanbar.ins, romanbar.drv, romanbar-example.tex, romanbar-example.pdf. In memoriam Claudia Simone Barth + 1996-01-30 Tommy Muench + 2014-01-02 Hans-Klaus Muench + 2014-08-24 \endpreamble \let\MetaPrefix\DoubleperCent \generate{% \file{romanbar.ins}{\from{romanbar.dtx}{install}}% \file{romanbar.drv}{\from{romanbar.dtx}{driver}}% \usedir{tex/latex/romanbar}% \file{romanbar.sty}{\from{romanbar.dtx}{package}}% \usedir{doc/latex/romanbar}% \file{romanbar-example.tex}{\from{romanbar.dtx}{example}}% } \catcode32=13\relax% active space \let =\space% \Msg{************************************************************************} \Msg{*} \Msg{* To finish the installation you have to move the following} \Msg{* file into a directory searched by TeX:} \Msg{*} \Msg{* romanbar.sty} \Msg{*} \Msg{* To produce the documentation run the file `romanbar.drv'} \Msg{* through (pdf)LaTeX, e.g.} \Msg{* pdflatex romanbar.drv} \Msg{* makeindex -s gind.ist romanbar.idx} \Msg{* pdflatex romanbar.drv} \Msg{* makeindex -s gind.ist romanbar.idx} \Msg{* pdflatex romanbar.drv} \Msg{*} \Msg{* At least three runs are necessary e.g. to get the} \Msg{* references right!} \Msg{*} \Msg{* Happy TeXing!} \Msg{*} \Msg{************************************************************************} \endbatchfile % %<*ignore> \fi % % % \section{The documentation driver file} % % The next bit of code contains the documentation driver file for % \TeX , i.\,e., the file that will produce the documentation you % are currently reading. It will be extracted from this file by the % \texttt{docstrip} programme. That is, run \LaTeX{} on \texttt{docstrip} % and specify the \texttt{driver} option when \texttt{docstrip} % asks for options. % % \begin{macrocode} %<*driver> \NeedsTeXFormat{LaTeX2e}[2024-11-01] \ProvidesFile{romanbar.drv}% [2025-01-28 v1.0g Roman numbers with bars (HMM)] \documentclass{ltxdoc}[2024/02/08]% v2.1j \usepackage{holtxdoc}[2019/12/09]% v0.30 \hypersetup{% pdfsubject={Writing Roman numbers with bars (HMM)},% pdfkeywords={LaTeX, romanbar, roman, Roman, bars},% pdfencoding=auto,% pdflang={en},% breaklinks=true,% linktoc=all,% pdfstartview=FitH,% pdfpagelayout=OneColumn,% bookmarksnumbered=true,% bookmarksopen=true,% bookmarksopenlevel=2,% pdfmenubar=true,% pdftoolbar=true,% pdfwindowui=true,% pdfnewwindow=true% } \CodelineIndex \hyphenation{docu-ment ana-lysed} \begin{document} \DocInput{romanbar.dtx}% \end{document} % % \end{macrocode} % \fi % % \GetFileInfo{romanbar.drv} % % \begingroup % \def\x{\#,\$,\^,\_,\~,\ ,\&,\{,\},\%}% % \makeatletter % \@onelevel@sanitize\x % \expandafter\endgroup % \expandafter\DoNotIndex\expandafter{\x} % \expandafter\DoNotIndex\expandafter{\string\ } % \begingroup % \makeatletter % \lccode`9=32\relax % \lowercase{%^^A % \edef\x{\noexpand\DoNotIndex{\@backslashchar9}}%^^A % }%^^A % \expandafter\endgroup\x % % \DoNotIndex{\,,\@Roman,\@bsphack,\@esphack,\@roman,\@slowromancap,\c@romanbarcount,% % \documentclass,\begin,\end,\listfiles,\MessageBreak,\NeedsTeXFormat,% % \newline,\noindent,\ProvidesPackage,\space,\textsf,\texttt,\usepackage,% % \DeclareRobustCommand,\dimexpr,\ht,\if,\ifdim,\ifnum,\ifx,\item,% % \kern,\makebox,\newcommand,\number,\PackageError,\pagenumbering,% % \raisebox,\RequirePackage,\rlap,\Roman,\roman,% % \romanbardimD,\romanbardimH,\romanbardimW,\romanbartmp,\romannumeral,% % \sbox,\section,\setcounter,\setlength,\theexample,\theromanbarcount,% % \verb,\vrule,\wd,\XRoman,\xroman,\z@} % % \title{The \xpackage{romanbar} package} % \author{H.-Martin Münch\\\xemail{Martin.Muench at Uni-Bonn.de}} % \date{2025-01-28 v1.0g} % \maketitle % % \begin{abstract} % \noindent This \LaTeX{} package allows to write Roman numbers % (or any other text) with horizontal bars. Additionally, % commands for converting Arabic numbers into Roman ones are provided % and an |\ifnumeric| test function. % \end{abstract} % \bigskip % % \noindent Disclaimer for web links: The author is not responsible for any contents % referred to in this work unless having full knowledge of illegal contents. % If any damage occurs by the use of information presented there, % only the author of the respective pages might be liable, % not the one who has referred to those pages. % % \tableofcontents % % \bigskip % % \section{Introduction} % \indent This \LaTeX{} package allows to write Roman numbers % (or any other text) with horizontal bars. Additionally, % commands for converting Arabic numbers into Roman ones are provided % and an |\ifnumeric| test function.\bigskip % % \section{Usage} % \indent Just load the package placing % \begin{quote} % |\usepackage{romanbar}| % \end{quote} % \noindent in the preamble of your \LaTeXe{} source file.\newline % |\Romanbar{...}| then produces a Roman number with bars (please see the example file). % |\romannum{...}| turns an Arabic number into a lowercase Roman one, and % |\Romannum{...}| turns an Arabic number into an uppercase Roman one. % |\ifnumeric{test}{true}{false}| tests for |test| being numeric. % % \subsection*{Options} % \DescribeMacro{options} % \indent The \xpackage{romanbar} package takes no options. % % \section{Alternatives\label{sec:Alternatives}} % \begin{description} % \item[-] the original code written by Prof. Enrico Gregorio\newline % (\url{https://profs.sci.univr.it/~gregorio/}),\newline % \url{https://tex.stackexchange.com/a/24084} % \end{description} %\begin{verbatim} %\def\barroman#1{\sbox0{#1}\dimen0=\dimexpr\wd0+1pt\relax % \makebox[\dimen0]{\rlap{\vrule width\dimen0 height 0.06ex depth 0.06ex}% % \rlap{\vrule width\dimen0 height\dimexpr\ht0+0.03ex\relax % depth\dimexpr-\ht0+0.09ex\relax}% % \kern.5pt#1\kern.5pt}} % %\barroman{I} \barroman{XI} %\end{verbatim} % \begin{description} % \item[-] Some fonts provide single characters for Roman numerals, % \hbox{cf. e.\,g.} \url{https://tex.stackexchange.com/q/38695}. % With \TeX-engines like \LuaLaTeX{} and \XeLaTeX{} % unicode can be used directly if an according font is used % (e.\,g.~|\usepackage{fontspec}\usepackage{libertine}|). % \end{description} % % \noindent (You programmed or found another alternative, % which is available at \url{https://www.ctan.org/}?\newline % OK, send an e-mail to me with the name, location at % \url{https://www.ctan.org/}, and a short notice, % and I will probably include it in the list above.) % % \newpage % % \section{Example} % % \begin{macrocode} %<*example> \NeedsTeXFormat{LaTeX2e}[2024-11-01] \documentclass[british]{article}[2024/06/29]% v1.4n \usepackage[extension=pdf,% plainpages=false,% pdfpagelabels=true,% hyperindex=false,% pdflang={en},% pdftitle={romanbar package example},% pdfauthor={H.-Martin Muench},% pdfsubject={Example for the romanbar package},% pdfkeywords={LaTeX, romanbar, roman, Roman, bars},% pdfview=Fit,pdfstartview=Fit,% pdfpagelayout=SinglePage% ]{hyperref}[2024-11-05]% v7.01l \usepackage{romanbar}[2025-01-28]% v1.0g \listfiles \begin{document} \pagenumbering{arabic} \section*{Example for romanbar} This example demonstrates the use of package\newline \textsf{romanbar}, v1.0g as of 2025-01-28.\newline There are no options to be used.\newline \noindent For more details please see the documentation! \noindent This package provides the command \verb|\Romanbar| to print bars below and over the following: \begin{description} \item[-] Roman numbers: \verb|\Romanbar{MMXXV}| prints \Romanbar{MMXXV} \item[-] Arabic numbers turned into upper-case Roman numbers:\newline \verb|\Romanbar{2025}| prints \Romanbar{2025} \item[-] negative Arabic numbers turned into upper-case Roman numbers \newline (although historically there were no negative Roman numbers): \newline \verb|\Romanbar{-25}| prints \Romanbar{-25} \item[-] zero Arabic number ($0$; although historically there was no Roman zero):\newline \verb|\Romanbar{0}| prints \Romanbar{0} \item[-] some arbitrary text: \verb|\Romanbar{Caesar}| prints \Romanbar{Caesar}\newline (with descenders: \Romanbar{AgjpqyW}) \newcounter{example} \setcounter{example}{25} \item[-] some counter's value: \verb|\Romanbar{\theexample}| prints \Romanbar{\theexample} \newline (where the value of \texttt{example} is \theexample) \item[-] Arabic numbers, without turning them into upper-case Roman numbers:\newline \verb|\Romanbar{\relax 2025}| prints \Romanbar{\relax 2025} \end{description} Special care was taken for "L" (50), e.\,g.~in 555/DLV: \Romanbar{555}. \verb|\romannum{...}| converts an Arabic number into a lower-case Roman one, e.\,g.~\verb|\romannum{2025}| prints \romannum{2025}, and \verb|\Romannum{...}| converts an Arabic number into an upper-case Roman one, e.\,g.~\verb|\Romannum{2025}| prints \Romannum{2025}. \end{document} % % \end{macrocode} % % \StopEventually{} % % \bigskip % % \section{The implementation} % % We start off by checking that we are loading into \LaTeXe{} and % announcing the name and version of this package. % % \begin{macrocode} %<*package> % \end{macrocode} % % \begin{macrocode} \NeedsTeXFormat{LaTeX2e}[2024-11-01] \ProvidesPackage{romanbar}[2025-01-28 v1.0g Roman numbers with bars (HMM)] % \end{macrocode} % % A short description of the \xpackage{romanbar} package: % % \begin{macrocode} %% Allows to write Roman numbers (or any other text) with bars %% and to convert Arabic numbers into Roman ones. % \end{macrocode} % % There are no options to be processed. % % \begin{macrocode} \RequirePackage{trimclip}[2020/08/19]% v1.2 \newcounter{romanbarcount} \newdimen\romanbardimH \newdimen\romanbardimD \newdimen\romanbardimW % \end{macrocode} % \begin{macro}{\gobbleminus} % % A command to gobble a possible minus sign is needed and % |\gobbleminus| from \url{https://texfaq.org/FAQ-isitanum} % is used. % % \begin{macrocode} \def\gobbleminus#1{\ifx-#1\else#1\fi} %% from https://texfaq.org/FAQ-isitanum % \end{macrocode} % \end{macro} % \begin{macro}{\ifnumeric} % % We want to test whether the argument passed to |\Romanbar| is numeric % and therefore define |\ifnumeric{test}{true}{false}|, % where |test| is to be analysed, |true| is the code to be executed, % if |test| is numeric, and |false| is the code to be executed, % if |test| is not numeric. This is done similar to % \url{https://tex.stackexchange.com/a/17119}. % % \begin{macrocode} \newcommand{\ifnumeric}[3]{% %% similar to https://tex.stackexchange.com/a/17119 \sbox\z@{\c@romanbarcount=0\gobbleminus#1\relax}% \ifdim\wd0>\z@\relax#3% is not numeric \else#2% is numeric \fi% } % \end{macrocode} % \end{macro} % \begin{macro}{\r@iseL} % % We define |\r@iseL| to raise any L~(50), otherwise a good deal % of the horizontal part of the letter would be swallowed by the lower bar % under the \textquotedblleft number\textquotedblright . % % \begin{macrocode} \def\r@iseL#1{\ifx @#1% then terminate \else% \if L#1\raisebox{0.05ex}{\begin{clipbox}{0pt 0pt 0pt 0.05ex}L\end{clipbox}}% \else #1\fi% \expandafter\r@iseL% \fi% } % \end{macrocode} % \end{macro} % \begin{macro}{\Romanbar} % % We define the |\Romanbar| command. % % \begin{macrocode} \DeclareRobustCommand{\Romanbar}[1]{% \ifnumeric{#1}{% is numeric % \end{macrocode} % % If its parameter is numeric, the temporary counter |romanbarcount| is set to the value. % % \begin{macrocode} \setcounter{romanbarcount}{#1}% % \end{macrocode} % % Regularly there are no non-positive Roman numbers, therefore we do some trick % similar to |\XRoman| from the \url{https://ctan.org/pkg/pageslts} package. % % \begin{macrocode} %% similar to \XRoman from the https://ctan.org/pkg/pageslts package \ifnum\theromanbarcount<1% \ifnum #1>0\relax% \Roman@bar{\Roman{#1}}% \else% \ifnum #1<0\relax% -\Roman@bar{\expandafter\@slowromancap\romannumeral\number-#1@}% \else% \Roman@bar{0}% \fi% \fi% \else\Roman@bar{\@Roman\c@romanbarcount}% \fi% }{% is not numeric \Roman@bar{#1}% }% } % \end{macrocode} % \end{macro} % \begin{macro}{\Roman@bar} % % Whether it is numeric or not, in the end |\Roman@bar| is applied to it. % % \begin{macrocode} \DeclareRobustCommand{\Roman@bar}[1]{% #1 is in Roman, i.e. MMXXIII %% (or any other text, "Caesar" would work, too); %% similar to code of by Prof. Enrico Gregorio (egreg) at %% https://tex.stackexchange.com/a/24084 \@bsphack% \edef\romanbartmp{#1}% %% height: \sbox0{\textsf{\romanbartmp}}% %% top line: %% + top of top line: \setlength{\romanbardimH}{\dimexpr\ht0+0.05ex\relax}% %% + bottom of top line: \setlength{\romanbardimD}{\dimexpr-\ht0+0.05ex\relax}% %% width: \sbox0{\textsf{\expandafter\r@iseL\romanbartmp @}}% \setlength{\romanbardimW}{\dimexpr\wd0+1pt\relax}% \@esphack% \makebox[\romanbardimW]{% \rlap{\vrule width\romanbardimW height\romanbardimH depth\romanbardimD}% top line \rlap{\vrule width\romanbardimW height 0.06ex depth 0.03ex}% bottom line \kern0.5pt\textsf{\expandafter\r@iseL\romanbartmp @}\kern0.5pt}% } % \end{macrocode} % \end{macro} % \begin{macro}{\romannum} % % While it is not needed for the bars, it is sometimes asked for a command % to convert an Arabic number into a Roman one. |\roman{...}| can only be applied % to a counter, i.\,e.~|\roman{25}| does not work, but %\begin{verbatim} %\newcounter{examplecounter} %\setcounter{examplecounter}{25} %\roman{examplecounter} %\end{verbatim} % would be necessary. Further non-negative values would not work. % |\romannum| accepts any number as argument. (If the argument is no number, % an error message is given and the argument printed (executed) % without applying anything to it.) % % \begin{macrocode} \DeclareRobustCommand{\romannum}[1]{% \ifnumeric{#1}{% is numeric \setcounter{romanbarcount}{#1}% %% similar to \xroman from the https://ctan.org/pkg/pageslts package \ifnum\c@romanbarcount<1\relax% \ifnum #1>0\relax% \roman{#1}% \else% \ifnum #1<0\relax% -\romannumeral\number-#1@% \else% 0% \fi% \fi% \else\@roman\c@romanbarcount% \fi% }{% is not numeric \PackageError{romanbar}{% Argument of \string\romannum\space is not a number}{% The command \string\romannum\space converts an Arabic number into a % lower-case Roman one,\MessageBreak% but the used argument of \string\romannum\space is not an Arabic number % but\MessageBreak% `#1`,\MessageBreak% which will now be printed unchanged.}% #1% }% } % \end{macrocode} % \end{macro} % \begin{macro}{\Romannum} % % The same for upper-case Roman numbers, |\Romannum| instead of |\Roman|: % % \begin{macrocode} \DeclareRobustCommand{\Romannum}[1]{% \ifnumeric{#1}{% is numeric \setcounter{romanbarcount}{#1}% %% similar to \XRoman from the http://ctan.org/pkg/pageslts package \ifnum\c@romanbarcount<1\relax% \ifnum #1>0\relax% \Roman{#1}% \else% \ifnum #1<0\relax% -\expandafter\@slowromancap\romannumeral\number-#1@% \else% 0% \fi% \fi% \else\@Roman\c@romanbarcount% \fi% }{% is not numeric \PackageError{romanbar}{% Argument of \string\Romannum\space is not a number}{% The command \string\Romannum\space converts an Arabic number into an % upper-case Roman one,\MessageBreak% but the used argument of \string\Romannum\space is not an Arabic number % but\MessageBreak% `#1`.}% #1% }% } % \end{macrocode} % \end{macro} % \begin{macrocode} % % \end{macrocode} % % \section{Installation} % \subsection{Downloads} % Everything is available at \url{https://www.CTAN.org/}, % but may need additional packages themselves. % % \DescribeMacro{romanbar.dtx} % For unpacking the |romanbar.dtx| file and constructing the documentation % it is required: % \begin{description} % \item[-] \LaTeXe{}[2024-11-01] or newer, % \url{https://www.ctan.org/starter} % % \item[-] document class \xpackage{ltxdoc}, 2024/02/08, v2.1j, % \url{https://www.ctan.org/pkg/ltxdoc} % % \item[-] package \xpackage{holtxdoc}, 2019/12/09, v0.30, % \url{https://www.ctan.org/pkg/holtxdoc} % % \item[-] package \xpackage{hypdoc}, 2023-10-26, v1.19, % \url{https://www.ctan.org/pkg/hypdoc} % \end{description} % % \DescribeMacro{romanbar.sty} % The \texttt{romanbar.sty} for \LaTeXe{} (i.\,e.~each document using % the \xpackage{romanbar} package) requires: % \begin{description} % \item[-] \TeX Format \LaTeXe{}[2024-11-01] or newer, % \url{https://www.ctan.org/starter} % % \item[-] package \xpackage{trimclip}, 2020/08/19, v1.2, % from the \xpackage{adjustbox} bundle, % \url{https://www.ctan.org/pkg/adjustbox} % \end{description} % % \DescribeMacro{romanbar-example.tex} % The \texttt{romanbar-example.tex} requires the same files as all % documents using the \xpackage{romanbar} package and additionally: % \begin{description} % \item[-] class \xpackage{article}, 2024/06/29, v1.4n , from \xpackage{classes}: % \url{https://www.ctan.org/pkg/classes} % % \item[-] package \xpackage{romanbar}, 2025-01-28, v1.0g, % \url{https://www.ctan.org/pkg/romanbar} % (Well, it is the example file for this package, and because you are reading the % documentation for the \xpackage{romanbar} package, it can be assumed that you already % have some version of it -- is it the current one?) % \end{description} % % \DescribeMacro{Oberdiek} % \DescribeMacro{holtxdoc} % All packages of \textsc{Heiko Oberdiek's} bundle `oberdiek' % (especially \xpackage{holtxdoc}) are also available in a TDS compliant ZIP archive:\newline % \url{https://mirrors.ctan.org/macros/latex/contrib/oberdiek.zip}.\newline % It is probably best to download and use this, because the packages in there % are quite probably both recent and compatible among themselves.\bigskip % % \DescribeMacro{hyperref} % \noindent \xpackage{hyperref} is not included in that bundle and needs to be % downloaded separately,\newline % \url{https://mirrors.ctan.org/macros/latex/contrib/hyperref.zip}.\bigskip % % \DescribeMacro{Münch} % A hyperlinked list of my (other) packages can be found at % \url{https://www.ctan.org/author/muench-hm}. % % \subsection{Package, unpacking TDS} % \paragraph{Package.} This package is available on CTAN: % \begin{description} % \item[\url{http://mirrors.ctan.org/macros/latex/contrib/romanbar/romanbar.dtx}]\hspace*{0.1cm} \newline % The source file. % \item[\url{http://mirrors.ctan.org/macros/latex/contrib/romanbar/romanbar.pdf}]\hspace*{0.1cm} \newline % The documentation. % \item[\url{http://mirrors.ctan.org/macros/latex/contrib/romanbar/romanbar-example.pdf}]\hspace*{0.1cm} \newline % The compiled example file, as it should look like. % \item[\url{http://mirrors.ctan.org/macros/latex/contrib/romanbar/README}]\hspace*{0.1cm} \newline % The README file. % \end{description} % There is also a romanbar.tds.zip available: % \begin{description} % \item[\url{https://mirrors.ctan.org/install/macros/latex/contrib/romanbar.tds.zip}]\hspace*{0.1cm} \newline % Everything in \xfile{TDS} compliant, compiled format. % \end{description} % which additionally contains\newline % \begin{tabular}{ll} % romanbar.ins & The installation file.\\ % romanbar.drv & The driver to generate the documentation.\\ % romanbar.sty & The \xext{sty}le file.\\ % romanbar-example.tex & The example file. % \end{tabular} % % \bigskip % % \noindent For required other packages, please see the preceding subsection. % % \paragraph{Unpacking.} The \xfile{.dtx} file is a self-extracting % \docstrip{} archive. The files are extracted by running the % \xext{.dtx} through \plainTeX{}: % \begin{quote} % \verb|tex romanbar.dtx| % \end{quote} % % About generating the documentation see paragraph~\ref{GenDoc} below.\bigskip % % \paragraph{TDS.} Now the different files must be moved into % the different directories in your installation TDS tree % (also known as \xfile{texmf} tree): % \begin{quote} % \def\t{^^A % \begin{tabular}{@{}>{\ttfamily}l@{ $\rightarrow$ }>{\ttfamily}l@{}} % romanbar.sty & tex/latex/romanbar/romanbar.sty\\ % romanbar.pdf & doc/latex/romanbar/romanbar.pdf\\ % romanbar-example.tex & doc/latex/romanbar/romanbar-example.tex\\ % romanbar-example.pdf & doc/latex/romanbar/romanbar-example.pdf\\ % romanbar.dtx & source/latex/romanbar/romanbar.dtx % \end{tabular}^^A % }^^A % \sbox0{\t}^^A % \ifdim\wd0>\linewidth % \begingroup % \advance\linewidth by\leftmargin % \advance\linewidth by\rightmargin % \edef\x{\endgroup % \def\noexpand\lw{\the\linewidth}^^A % }\x % \def\lwbox{^^A % \leavevmode % \hbox to \linewidth{^^A % \kern-\leftmargin\relax % \hss % \usebox0 % \hss % \kern-\rightmargin\relax % }^^A % }^^A % \ifdim\wd0>\lw % \sbox0{\small\t}^^A % \ifdim\wd0>\linewidth % \ifdim\wd0>\lw % \sbox0{\footnotesize\t}^^A % \ifdim\wd0>\linewidth % \ifdim\wd0>\lw % \sbox0{\scriptsize\t}^^A % \ifdim\wd0>\linewidth % \ifdim\wd0>\lw % \sbox0{\tiny\t}^^A % \ifdim\wd0>\linewidth % \lwbox % \else % \usebox0 % \fi % \else % \lwbox % \fi % \else % \usebox0 % \fi % \else % \lwbox % \fi % \else % \usebox0 % \fi % \else % \lwbox % \fi % \else % \usebox0 % \fi % \else % \lwbox % \fi % \else % \usebox0 % \fi % \end{quote} % If you have a \xfile{docstrip.cfg} that configures and enables \docstrip's % TDS installing feature, then some files can already be in the right % place, see the documentation of \docstrip{}. % % \subsection{Refresh file name databases} % % If your \TeX~distribution (\TeX\,Live, \mikTeX, \dots) relies on % file name databases, you must refresh these. For example, \TeX\,Live\ users % run \verb|texhash| or \verb|mktexlsr|. % % \subsection{Some details for the interested} % % \paragraph{Unpacking with \LaTeX{}.} % The \xfile{.dtx} chooses its action depending on the format: % \begin{description} % \item[\plainTeX:] Run \docstrip{} and extract the files. % \item[\LaTeX:] Generate the documentation. % \end{description} % If you insist on using \LaTeX{} for \docstrip{} (really, % \docstrip{} does not need \LaTeX ), then inform the autodetect routine % about your intention: % \begin{quote} % \verb|latex \let\install=y\input{romanbar.dtx}| % \end{quote} % Do not forget to quote the argument according to the demands % of your shell. % % \paragraph{Generating the documentation.\label{GenDoc}} % You can use both the \xfile{.dtx} or the \xfile{.drv} to generate % the documentation. The process can be configured by a % configuration file \xfile{ltxdoc.cfg}. For instance, put the following % line into this file, if you want to have A4 as paper format: % \begin{quote} % \verb|\PassOptionsToClass{a4paper}{article}| % \end{quote} % % \noindent An example follows how to generate the % documentation with \pdfLaTeX : % % \begin{quote} %\begin{verbatim} %pdflatex romanbar.dtx %makeindex -s gind.ist romanbar.idx %pdflatex romanbar.dtx %makeindex -s gind.ist romanbar.idx %pdflatex romanbar.dtx %\end{verbatim} % \end{quote} % % \subsection{Compiling the example} % % The example file, \textsf{romanbar-example.tex}, can be compiled via\newline % |(pdf)latex romanbar-example.tex|. % % \section{Acknowledgements} % % I would like to thank Prof.~\textsc{Enrico Gregorio} (egreg) for his answer % at \url{https://tex.stackexchange.com/a/24084} and % \textsc{Heiko Oberdiek} for providing a lot of useful packages (from which % I also got everything I know about creating a file in \xext{dtx} format, OK, say it: copying). % % \phantomsection % \begin{History}\label{History} % \begin{Version}{2011/07/25 v1.0a} % \item First code by Prof.~\textsc{Enrico Gregorio} (egreg) at % \url{https://tex.stackexchange.com/a/24084} % \end{Version} % \begin{Version}{2011/07/26 v1.0b} % \item Packed into a \xext{sty} file. % \item Removed the requirement of \eTeX{} for the package. % \end{Version} % \begin{Version}{2011/08/25 v1.0c} % \item Renamed \xpackage{romanbar} package. % \item Minor details. % \end{Version} % \begin{Version}{2011/09/16 v1.0d} % \item Made commands robust. % \item Minor details. % \end{Version} % \begin{Version}{2011/12/16 v1.0e} % \item Additionally accepts now Arabic numbers and converts them to Roman ones with bars. % \item Also non-positive numbers are now accepted. % \end{Version} % \begin{Version}{2012/01/01 v1.0f} % \item Added |\romannum| and |\Romannum| to convert Arabic to Roman numbers (without bars). % \item |\r@iseL|. % \item Created a \xfile{dtx}, example, and README. % \item Uploaded to CTAN. % \end{Version} % \begin{Version}{2025-01-28 v1.0g} % \item Converted to UTF-8. % \item Updated to \LaTeX{} format 2024-11-01. % \item Documentation updates. % \item Using the \xpackage{trimclip} package for improved handling % \hbox{of \textquotedblleft L\textquotedblright .} % \item Again using \eTeX{} for the package. Version~1.0b removed the requirement % of \eTeX{} for this package. Now it is 2025 and \eTeX{} can be assumed standard. % Therefore \eTeX{} is used for this package. Also own counters and % own dimens instead of scratch ones are used now. % \end{Version} % \end{History} % \bigskip % % When you find a mistake or have a suggestion for an improvement of this package, % please send an e-mail to the maintainer, thanks! (Please see BUG REPORTS in the README.) % % \PrintIndex % % \Finale \endinput