texlive[56496] Master: localloc now in generic (30sep20)

commits+karl at tug.org commits+karl at tug.org
Wed Sep 30 23:31:21 CEST 2020


Revision: 56496
          http://tug.org/svn/texlive?view=revision&revision=56496
Author:   karl
Date:     2020-09-30 23:31:20 +0200 (Wed, 30 Sep 2020)
Log Message:
-----------
localloc now in generic (30sep20)

Modified Paths:
--------------
    trunk/Master/tlpkg/tlpsrc/collection-latexextra.tlpsrc
    trunk/Master/tlpkg/tlpsrc/collection-plaingeneric.tlpsrc

Added Paths:
-----------
    trunk/Master/texmf-dist/doc/generic/localloc/
    trunk/Master/texmf-dist/doc/generic/localloc/localloc.README
    trunk/Master/texmf-dist/doc/generic/localloc/localloc.pdf
    trunk/Master/texmf-dist/doc/generic/localloc/localtst.tex
    trunk/Master/texmf-dist/source/generic/localloc/
    trunk/Master/texmf-dist/source/generic/localloc/localloc.drv
    trunk/Master/texmf-dist/source/generic/localloc/localloc.dtx
    trunk/Master/texmf-dist/tex/generic/localloc/
    trunk/Master/texmf-dist/tex/generic/localloc/localloc.sty

Removed Paths:
-------------
    trunk/Master/texmf-dist/doc/latex/localloc/
    trunk/Master/texmf-dist/source/latex/localloc/
    trunk/Master/texmf-dist/tex/latex/localloc/

Added: trunk/Master/texmf-dist/doc/generic/localloc/localloc.README
===================================================================
--- trunk/Master/texmf-dist/doc/generic/localloc/localloc.README	                        (rev 0)
+++ trunk/Master/texmf-dist/doc/generic/localloc/localloc.README	2020-09-30 21:31:20 UTC (rev 56496)
@@ -0,0 +1,43 @@
+Readme File for the package `localloc' by Bernd Raichle
+Copyright (C) 1991,1994,1995 Bernd Raichle.  All rights reserved.
+
+  The `localloc' package reimplements plain-TeX's basic allocation
+macros to allow local allocation of registers.  It can be used with
+ * plain-TeX,
+ * LaTeX2e,
+ * LaTeX 2.09,
+and all other formats which are based on plain-TeX.
+  In the past people complained about the restriction of 256
+registers imposed by TeX and want either more registers or a more
+clever way to maintain this limited resource.  This package shows
+and implements a mechanism which doesn't remove this restrictions
+but allows local allocation of registers.  Using this mechanism
+you can often replace global register allocations by ones local
+to a group allowing the register to be used for other purposes
+after the group is left.
+
+
+Installation:
+-------------
+
+This package contains 2 files, namely
+ * localloc.README	This README file
+ * localloc.dtx		The docstrip archive file containing the
+			source for the macro file `localloc.sty'
+			and the documentation.
+
+To unpack the archive file you need `docstrip.tex' version 2.x or
+newer.  You can find this file in the LaTeX2e release; it can be
+used with plain-TeX _and_ LaTeX.  Run `localloc.dtx' through
+plainTeX or LaTeX to unpack the archive file:
+	tex localloc.dtx
+or
+	latex localloc.dtx
+
+
+This package is supported by
+
+Bernd Raichle
+Stettener Str. 73
+D-73732 Esslingen, FRG
+Email: raichle at Informatik.Uni-Stuttgart.DE


Property changes on: trunk/Master/texmf-dist/doc/generic/localloc/localloc.README
___________________________________________________________________
Added: svn:eol-style
## -0,0 +1 ##
+native
\ No newline at end of property
Added: trunk/Master/texmf-dist/doc/generic/localloc/localloc.pdf
===================================================================
(Binary files differ)

Index: trunk/Master/texmf-dist/doc/generic/localloc/localloc.pdf
===================================================================
--- trunk/Master/texmf-dist/doc/generic/localloc/localloc.pdf	2020-09-30 21:30:46 UTC (rev 56495)
+++ trunk/Master/texmf-dist/doc/generic/localloc/localloc.pdf	2020-09-30 21:31:20 UTC (rev 56496)

Property changes on: trunk/Master/texmf-dist/doc/generic/localloc/localloc.pdf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/pdf
\ No newline at end of property
Added: trunk/Master/texmf-dist/doc/generic/localloc/localtst.tex
===================================================================
--- trunk/Master/texmf-dist/doc/generic/localloc/localtst.tex	                        (rev 0)
+++ trunk/Master/texmf-dist/doc/generic/localloc/localtst.tex	2020-09-30 21:31:20 UTC (rev 56496)
@@ -0,0 +1,117 @@
+%%
+%% This is file `localtst.tex',
+%% generated with the docstrip utility.
+%%
+%% The original source files were:
+%%
+%% localloc.dtx  (with options: `test')
+%% 
+%% This is a file of the `localloc' package reimplementing
+%% plain-TeX's and LaTeX's basic allocation macros to allow
+%% local allocation of registers.
+%% 
+%% -- Copyright (C) 1991-1995 Bernd Raichle.  All rights reserved --
+%% 
+%% This package is distributed in the hope that it will be useful,
+%% but WITHOUT ANY WARRANTY; without even the implied warranty of
+%% MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
+%% 
+%% 
+%% IMPORTANT NOTICE:
+%% 
+%% Copying of this file is authorized only if either
+%% (1) you make absolutely no changes to your copy, including name, or
+%% (2) if you do make changes, you name it something other than
+%%     localloc.dtx, localloc.doc, localloc.tex, or localloc.sty.
+%% 
+%% For error reports see original source file `localloc.dtx'.
+%% 
+\begingroup\expandafter\expandafter\expandafter\endgroup
+\expandafter\ifx\csname ProvidesPackage\endcsname\relax
+\else
+  \NeedsTeXFormat{LaTeX2e}
+  \ProvidesFile{localtst.tex}%
+    [1995/09/24 v1.1b %
+     Additional LaTeX Kernel Macros (local allocation)]
+\fi
+\edef\FORMAT{%
+  \expandafter\ifx\csname documentstyle\endcsname\relax 0%
+  \else\expandafter\ifx\csname documentclass\endcsname\relax
+  1\else 2\fi\fi}
+\immediate\write16{=====>>> You are using %
+  \ifcase\FORMAT plainTeX\or LaTeX 2.09\or LaTeX 2e\else ??\fi}
+\ifcase\FORMAT
+  \input localloc.sty\relax \or
+  \documentstyle[localloc]{article}\begin{document}\or
+  \documentclass{article}\usepackage{localloc}\begin{document}\fi
+\tracingstats=1
+\def\Message#1{\immediate\write16{#1}}
+\def\RegVal#1{\the\csname test#1\endcsname}
+\def\ShowSet#1{\if l#1local\else global\fi:
+   \RegVal{i#1} \RegVal{ii#1}/\RegVal{iii#1}
+   \RegVal{iv#1}}
+\def\ShowAll#1{\Message{#1 -- \ShowSet{g} -- \ShowSet{l}}}
+\def\ShowIns{\Message{Insertions:
+   \the\testinsi, \the\testinsii, \the\testinsiii}}
+\chardef\testig=0    \chardef\testil=0
+\chardef\testiig=0   \chardef\testiil=0
+\chardef\testiiig=0  \chardef\testiiil=0
+\chardef\testivg=0   \chardef\testivl=0
+\chardef\testinsii=0 \chardef\testinsiii=0
+\newinsert\testinsi
+{\count0=\testinsi \advance\count0 -2
+ \loop\csname newbox\endcsname\testig
+ \ifnum\testig<\count0\repeat}
+\newbox\testig \lnewbox\testil
+\ShowAll{Level 0}
+\begingroup
+ \lnewbox\testiil \newbox\testiig
+ \ShowAll{Level 1}
+ \begingroup
+  \newbox\testivg \lnewbox\testivl
+  \ShowAll{Level 2}\ShowIns
+ \endgroup
+ \lnewbox\testiiil \newbox\testiiig
+ \ShowAll{Level 1b}
+ \csname newinsert\endcsname\testinsii
+ \ShowIns
+ \begingroup
+  \newbox\testivg \lnewbox\testivl
+  \ShowAll{Level 2}
+ \endgroup
+ \ShowAll{Level 1b}
+\endgroup
+\newinsert\testinsiii
+\ShowAll{Level 0}\ShowIns
+\begingroup
+ \lnewbox\testiil \newbox\testiig
+ \lnewbox\testiiil \newbox\testiiig
+ \ShowAll{Level 1}
+ \begingroup
+  \newbox\testivg \lnewbox\testivl
+  \newbox\testvg \lnewbox\testvl
+  \ShowAll{Level 2}\ShowIns
+ \endgroup
+ \ShowAll{Level 1}
+\endgroup
+\ShowAll{Level 0}
+\end{document}
+%% \CharacterTable
+%%  {Upper-case    \A\B\C\D\E\F\G\H\I\J\K\L\M\N\O\P\Q\R\S\T\U\V\W\X\Y\Z
+%%   Lower-case    \a\b\c\d\e\f\g\h\i\j\k\l\m\n\o\p\q\r\s\t\u\v\w\x\y\z
+%%   Digits        \0\1\2\3\4\5\6\7\8\9
+%%   Exclamation   \!     Double quote  \"     Hash (number) \#
+%%   Dollar        \$     Percent       \%     Ampersand     \&
+%%   Acute accent  \'     Left paren    \(     Right paren   \)
+%%   Asterisk      \*     Plus          \+     Comma         \,
+%%   Minus         \-     Point         \.     Solidus       \/
+%%   Colon         \:     Semicolon     \;     Less than     \<
+%%   Equals        \=     Greater than  \>     Question mark \?
+%%   Commercial at \@     Left bracket  \[     Backslash     \\
+%%   Right bracket \]     Circumflex    \^     Underscore    \_
+%%   Grave accent  \`     Left brace    \{     Vertical bar  \|
+%%   Right brace   \}     Tilde         \~}
+%%
+\endinput
+%%
+%% End of file `localtst.tex'.


Property changes on: trunk/Master/texmf-dist/doc/generic/localloc/localtst.tex
___________________________________________________________________
Added: svn:eol-style
## -0,0 +1 ##
+native
\ No newline at end of property
Added: trunk/Master/texmf-dist/source/generic/localloc/localloc.drv
===================================================================
--- trunk/Master/texmf-dist/source/generic/localloc/localloc.drv	                        (rev 0)
+++ trunk/Master/texmf-dist/source/generic/localloc/localloc.drv	2020-09-30 21:31:20 UTC (rev 56496)
@@ -0,0 +1,57 @@
+%%
+%% This is file `localloc.drv',
+%% generated with the docstrip utility.
+%%
+%% The original source files were:
+%%
+%% localloc.dtx  (with options: `driver')
+%% 
+%% This is a file of the `localloc' package reimplementing
+%% plain-TeX's and LaTeX's basic allocation macros to allow
+%% local allocation of registers.
+%% 
+%% -- Copyright (C) 1991-1995 Bernd Raichle.  All rights reserved --
+%% 
+%% This package is distributed in the hope that it will be useful,
+%% but WITHOUT ANY WARRANTY; without even the implied warranty of
+%% MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
+%% 
+%% 
+%% IMPORTANT NOTICE:
+%% 
+%% Copying of this file is authorized only if either
+%% (1) you make absolutely no changes to your copy, including name, or
+%% (2) if you do make changes, you name it something other than
+%%     localloc.dtx, localloc.doc, localloc.tex, or localloc.sty.
+%% 
+%% For error reports see original source file `localloc.dtx'.
+%% 
+  \NeedsTeXFormat{LaTeX2e}
+  \ProvidesFile{localloc.dtx}%
+    [1995/09/24 v1.1b %
+     Additional LaTeX Kernel Macros (local allocation)]
+\NeedsTeXFormat{LaTeX2e}
+\documentclass[a4paper]{ltxdoc}
+\GetFileInfo{localloc.dtx}
+\begin{document}
+ \DocInput{\filename}
+\end{document}
+%% \CharacterTable
+%%  {Upper-case    \A\B\C\D\E\F\G\H\I\J\K\L\M\N\O\P\Q\R\S\T\U\V\W\X\Y\Z
+%%   Lower-case    \a\b\c\d\e\f\g\h\i\j\k\l\m\n\o\p\q\r\s\t\u\v\w\x\y\z
+%%   Digits        \0\1\2\3\4\5\6\7\8\9
+%%   Exclamation   \!     Double quote  \"     Hash (number) \#
+%%   Dollar        \$     Percent       \%     Ampersand     \&
+%%   Acute accent  \'     Left paren    \(     Right paren   \)
+%%   Asterisk      \*     Plus          \+     Comma         \,
+%%   Minus         \-     Point         \.     Solidus       \/
+%%   Colon         \:     Semicolon     \;     Less than     \<
+%%   Equals        \=     Greater than  \>     Question mark \?
+%%   Commercial at \@     Left bracket  \[     Backslash     \\
+%%   Right bracket \]     Circumflex    \^     Underscore    \_
+%%   Grave accent  \`     Left brace    \{     Vertical bar  \|
+%%   Right brace   \}     Tilde         \~}
+%%
+\endinput
+%%
+%% End of file `localloc.drv'.


Property changes on: trunk/Master/texmf-dist/source/generic/localloc/localloc.drv
___________________________________________________________________
Added: svn:eol-style
## -0,0 +1 ##
+native
\ No newline at end of property
Added: trunk/Master/texmf-dist/source/generic/localloc/localloc.dtx
===================================================================
--- trunk/Master/texmf-dist/source/generic/localloc/localloc.dtx	                        (rev 0)
+++ trunk/Master/texmf-dist/source/generic/localloc/localloc.dtx	2020-09-30 21:31:20 UTC (rev 56496)
@@ -0,0 +1,1026 @@
+% \iffalse
+%
+% Package `localloc' to use with LaTeX 2e/2.09 and plain-TeX
+% Copyright (C) 1991,1994,1995 Bernd Raichle.  All rights reserved.
+%
+%
+% Copying of this file is authorized only if either
+% (1) you make absolutely no changes to your copy, including name, or
+% (2) if you do make changes, you name it something other than
+%     localloc.dtx, localloc.doc, localloc.tex, or localloc.sty.
+% This restriction helps ensure that all styles developed here
+% remain identical.
+%
+% Error reports in case of UNCHANGED versions please to:
+%        Bernd Raichle
+%        Stettener Str. 73
+%        D-73732 Esslingen
+%        Federal Republic of Germany
+% Email: raichle at Informatik.Uni-Stuttgart.DE
+%
+%
+% ========== INSTALLATION GUIDE: ==========
+%
+% The complete distribution consists of a set of files, which are
+% packed and documented in _one_ `docstrip archive file' called
+% `localloc.dtx' (the file you are currently reading).  This archive
+% file can be unpacked to create the necessary files containing the
+% macros, documentation, etc.
+%
+% To unpack the archive file you need:
+%
+%   * `localloc.dtx' (it is the file you are currently reading)
+%
+%   * `docstrip.tex' version 2.x or newer
+%     (You can find this file in the LaTeX 2e release.)
+%
+% Then run `localloc.dtx' through plainTeX or LaTeX to unpack the
+% archive file:
+%
+%     tex localloc.dtx
+% or
+%     latex localloc.dtx
+%
+% This will create a set of file which contain the macro code or
+% code to produce the documentation of the `localloc' package.
+%
+% --------------- start of docstrip archive file ------------------
+% \fi
+%
+% \CheckSum{369}
+%
+% \iffalse
+%<*install>
+\def\batchfile{localloc.dtx}
+\input docstrip.tex
+\preamble
+
+This is a file of the `localloc' package reimplementing
+plain-TeX's and LaTeX's basic allocation macros to allow
+local allocation of registers.
+
+-- Copyright (C) 1991-1995 Bernd Raichle.  All rights reserved --
+
+This package is distributed in the hope that it will be useful,
+but WITHOUT ANY WARRANTY; without even the implied warranty of
+MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
+
+
+IMPORTANT NOTICE:
+
+Copying of this file is authorized only if either
+(1) you make absolutely no changes to your copy, including name, or
+(2) if you do make changes, you name it something other than
+    localloc.dtx, localloc.doc, localloc.tex, or localloc.sty.
+
+For error reports see original source file `localloc.dtx'.
+
+\endpreamble
+%\generateFile{localloc.ins}{t}{\from{localloc.dtx}{install}}
+\generateFile{localloc.sty}{t}{\from{localloc.dtx}{package}}
+\generateFile{localloc.drv}{t}{\from{localloc.dtx}{driver}}
+\generateFile{localtst.tex}{t}{\from{localloc.dtx}{test}}
+
+\Msg{***********************************************************}
+\Msg{*}
+\Msg{* To finish the installation you have to move the following}
+\Msg{* file into a directory searched by TeX:}
+\Msg{*}
+\Msg{* \space\space localloc.sty}
+\Msg{*}
+\Msg{* To produce the documentation of this archive file run the}
+\Msg{* file `localloc.drv' through LaTeX 2e:}
+\Msg{*}
+\Msg{* \space\space latex localloc.drv}
+\Msg{*}
+\Msg{* Happy TeXing}
+\Msg{***********************************************************}
+\relax\endinput
+%</install>
+% \fi
+%
+% \changes{v1.1b}{95/09/24}{Released after a long sleep in my
+%                archives; prefixed some tokens with \cs{lcllc@}.}
+% \changes{v1.1a}{94/10/16}{English documentation; added support for
+%                \LaTeXe; added self unpacking archive code.}
+% \changes{v1.0b}{91/09/06}{Error in \cs{newinsert}: consecutive calls
+%                return the same insertion register number.}
+% \changes{v1.0a}{91/09/04}{All macros in {plain.tex} replaced.}
+%
+% \DoNotIndex{\fileversion,\filedate,\docdate,\filename}
+% \DoNotIndex{\begingroup,\endgroup,\def,\relax}
+% \DoNotIndex{\ifnum,\ifcase,\else,\fi}
+% \DoNotIndex{\expandafter,\the}
+% \DoNotIndex{\@ne,\m at ne,\next}
+%
+%
+% \newcommand{\PiCTeX}{\protect\pPiCTeX}
+% \newcommand{\pPiCTeX}{\relax
+%     P\kern-.12em\lower.5ex\hbox{I}\kern-.075emC\kern-.11em\TeX}
+%
+%
+% \title{An Enhanced Implementation of the Allocation Macros in \LaTeXe,
+%    \LaTeX~2.09, and plain-\TeX}
+% \date{\filedate~(\fileversion)}
+% \author{Bernd Raichle\\
+%         Stettener Str.~73\\
+%         D-73732 Esslingen, FRG\\
+%         Email: {\tt raichle at Informatik.Uni-Stuttgart.DE}}
+%
+% \maketitle
+%
+% \begin{abstract}
+%   This style option reimplements the allocation command macros
+%   provided by plain-\TeX\ and adds macros to allow allocation 
+%   of local registers inside groups.
+% \end{abstract} 
+% 
+%^^A \tableofcontents
+%
+% \section{Introduction}
+%
+% \subsection{Restrictions of {\tt plain.tex}'s Register Allocation Macros}
+%
+%  In {\tt plain.tex}, Donald E.\ Knuth writes about the macros for
+%  register allocation~\cite[lines 149ff]{plain.tex-3.14159}: 
+%  \begin{quote}
+%    When a register is used only temporarily, it need not be
+%    allocated;  grouping can be used, making the value previously in
+%    the register return after the close of the group.  The main use
+%    of these macros is for registers that are defined by one macro
+%    and used by others, possibly at different nesting levels.  All
+%    such registers should be defined through these macros; otherwise
+%    conflicts may occur, especially when two or more more macro
+%    packages are being used at once.
+%  \end{quote}
+%  Additional remarks can be read in the TeXbook~\cite[p.~346]{DEK91}:
+%  \begin{quote}
+%    {\it Allocation of registers.\/} The second major part of the
+%    {\tt plain.tex} file provides a foundation on which systems of
+%    independently developed macros can coexist peacefully without
+%    interfering in their usage of registers. The idea is that macro
+%    writers should abide by the macro conventions following ground
+%    rules: [\ldots]
+%    (4)~Furthermore, it's possible to use any register in a group, if
+%    you ensure that \TeX's grouping mechanism will restore the
+%    register when you're done with the group, and if you are certain
+%    that other macros will not make global assignments to that
+%    register when you need it. \
+%    (5)~But when a register is used by several macros, or over long
+%    spans of time, it should be allocated by \verb+\newcount+,
+%    \verb+\newdimen+, \verb+\newbox+, etc. \ (6)~Similar remarks apply
+%    [\ldots]
+%    to insertions (which require \verb+\box+, \verb+\count+,
+%    \verb+\dimen+, and \verb+\skip+ registers all having the same
+%    number).
+%  \end{quote}
+%
+%  This means, that within plain-\TeX\ and all formats based on
+%  plain-\TeX\ a user can not allocate a register for temporary use
+%  using the given mechanisms.  Nonetheless there is often the need
+%  for a allocated register which is only used within a rather small
+%  piece of document text and should be set free for reuse in the rest
+%  of the formatting run:
+%
+%  If a macro~\verb+\macroa+ needs a register which should never be
+%  destroyed by another macro~\verb+\macrob+ which is called by
+%  \verb+\macroa+, you either have to know about the realisation of
+%  \verb+\macrob+ or you have to allocate a new register.
+%
+%  The name of this newly allocated register is only known to the
+%  macro package in which macro~\verb+\macroa+ resides.  If you have
+%  a lot of macros which needs registers by their own it is possible
+%  that all of the 256~registers of one type will be allocated.  In
+%  most cases it would be possible to share some of these registers by
+%  more than one macro because the register is only needed within (an
+%  environment delimited by) a group.  To share registers---if they are
+%  used only locally---it will be necessary to provide a mechanism to
+%  allocate registers locally.  Unfortunately {\tt plain.tex} and all
+%  derived formats, like \LaTeX, misses this mechanism leading to the
+%  problem that some macro packages cannot be combined.
+%
+%  In the following example it is necessary to call two macros
+%  |\macroa| and |macrob| in the same group (e.g.\ because |\macroa|
+%  performs special actions at the begin and |\macrob| at the end of
+%  an environment).  Further you do not have any knowledge about the
+%  use of scratch register in |\macroa|, |\macrob| or the text in the
+%  argument specified by the user.  Therefore it is impossible to use
+%  a scratch register to save the current value of |\hsize|; we have
+%  to allocate a new register to save it.
+%\begin{verbatim}
+%    \newdimen\savedhsize
+%\end{verbatim}
+%\begin{verbatim}
+%    \def\callAandB#1{\begingroup
+%        \savedhsize=\hsize
+%        \hsize=0.8\hsize    \macroa
+%        #1\relax
+%        \hsize=\savedhsize  \macrob
+%      \endgroup}
+%\end{verbatim}
+%  If there will be a mechanism, e.g. by a macro |\lnewdimen|, to
+%  allocate a local register it is possible to use this local register
+%  inside the group without worrying about possible dependencies
+%  between the macros and the user specified text.  Additionally after
+%  leaving the group, the dimen register will be free to be used by
+%  other macros.
+%\begin{verbatim}
+%    \def\callAandB#1{\begingroup
+%        \lnewdimen\savedhsize  \savedhsize=\hsize
+%        \hsize=0.8\hsize    \macroa
+%        #1\relax
+%        \hsize=\savedhsize  \macrob
+%      \endgroup}
+%\end{verbatim}
+%
+%
+% \subsection{Local Register Allocation Macros}
+%
+% \DescribeMacro{\newcount}
+% \DescribeMacro{\newdimen}
+% \DescribeMacro{\newskip}
+% \DescribeMacro{\newbox}
+% {\let\newinsert=\relax \DescribeMacro{\newinsert}}^^A
+%  When using this reimplementation of the allocation macros, the {\tt
+%  plain.tex} macros |\newcount|, |\newdimen|, |\newskip|, and
+%  |\newbox| will have a changed behaviour in two aspects:
+%  \begin{itemize}
+%  \item Do not assume that registers which are allocated consecutively
+%     have consecutive register numbers.  In general you should not
+%     make any assumption about the order of register numbers.
+%  \item It is possible that a register was locally allocated and used
+%     in the past.  After leaving the group the register is set to free
+%     and the old value---normally zero---is restored.  Nonetheless
+%     you should not assume that a newly allocated register is
+%     initialised with the value zero.
+%  \end{itemize}
+%
+% {\let\newmuskip=\relax \DescribeMacro{\newmuskip}}
+% {\let\newtoks=\relax \DescribeMacro{\newtoks}}^^A
+%  The behaviour of the macros |\newmuskip| and |\newtoks| are not
+%  changed because they are not used for insertions.  Nonetheless this
+%  can be changed in a future version.
+%  
+% \DescribeMacro{\lnewcount}
+% \DescribeMacro{\lnewdimen}
+% \DescribeMacro{\lnewskip}
+% \DescribeMacro{\lnewmuskip}
+% \DescribeMacro{\lnewbox}
+% \DescribeMacro{\lnewtoks}
+%  |\lnewcount|, |\lnewdimen|, |\lnewskip|, |\lnewmuskip|, |\lnewbox|,
+%  and |\lnewtoks| are the set of new macros to allocate registers
+%  within the scope of the current group.  At the end of the current
+%  group the allocated register is freed.
+%
+%  As with their global counterparts you should not assume that the
+%  registers are allocated in a consecutive order---neither increasing
+%  nor decreasing---or that the allocated register is initialised with
+%  zero.
+%
+%
+% \subsection{Usage Examples}
+%
+% \subsubsection{\LaTeX's Picture Environment}
+%
+%  \LaTeX's picture environment uses the box register |\@picbox| and
+%  the dimen register |\@picht| to save the contents of a picture and
+%  the user specified height of this picture at the beginning of the
+%  environment.  These two registers are set at the beginning and used
+%  at the end of the |picture| environment.  Because the two registers
+%  are used nowhere else, it is possible to share them by only
+%  allocating them within the environment.
+%
+%  This is the simplified code for the |\begin{picture}| and
+%  |\end{picture}| commands; the macros |\begin| and |\end| start and
+%  end a new group:
+%\begin{verbatim}
+%\newbox\@picbox
+%\newdimen\@picht
+%\end{verbatim}
+%\begin{verbatim}
+%\def\picture(#1,#2){%
+%  \@picht = #2\unitlength  % save picture height
+%  \setbox\@picbox = \hbox to #1\unitlength\bgroup
+%    \ignorespaces}
+%\end{verbatim}
+%\begin{verbatim}
+%\def\endpicture{%
+%    \hss
+%  \egroup                  % close picture box
+%  \ht\@picbox = \@picht    % set box height to save picture height
+%  \dp\@picbox = 0pt        % set box depth to 0pt
+%  \mbox{\box\@picbox}}     % output this box
+%\end{verbatim}
+%
+%  Using the new local allocation macros the code changes is simple:
+%  Move the |\newbox| and |\newdimen| command within the |\picture|
+%  macro definition and rename them to |\lnewbox| and |\lnewdimen|:
+%\begin{verbatim}
+% %\newbox\@picbox
+% %\newdimen\@picht
+%\end{verbatim}
+%\begin{verbatim}
+%\def\picture(#1,#2){%
+%  \lnewbox\@picbox
+%  \lnewdimen\@picht
+%  \@picht = #2\unitlength  % save picture height
+%  \setbox\@picbox = \hbox to #1\unitlength\bgroup
+%    \ignorespaces}
+%\end{verbatim}
+%
+%  Additionally we can use a property of the usage pattern of these
+%  two registers:
+%  Within a nested use of the |picture| environment---you can use
+%  subpictures within a picture---these registers are allocated for
+%  each nesting level.  This is not really necessary because the box
+%  and the dimen register is always used in a group and is never
+%  changed globally.
+%  It is possible to add tests to avoid a (local) reallocation of
+%  these registers:
+%\begin{verbatim}
+%\let\@picbox=\relax    % mark register as not yet allocated
+%\let\@picht =\relax    % mark register as not yet allocated
+%\end{verbatim}
+%\begin{verbatim}
+%\def\picture(#1,#2){%
+%  \ifx\@picbox\relax \lnewbox\@picbox  \fi
+%  \ifx\@picht\relax  \lnewdimen\@picht \fi
+%  \@picht = #2\unitlength  % save picture height
+%  \setbox\@picbox = \hbox to #1\unitlength\bgroup
+%    \ignorespaces}
+%\end{verbatim}
+%
+%
+% \subsubsection{\LaTeX's {\tt\protect\bslash multiput} Macro}
+%
+%  Another example of registers which are used only in one rarely
+%  used macro, are the count register |\@multicnt| and the two dimen
+%  registers |\@xdim| and |\@ydim| for the |\multiput| command.  To
+%  change it according to the scheme above you have to insert an
+%  additional grouping.
+%
+%  In \LaTeXe\ these three rarely used registers and some more are
+%  shared with the |\bezier| command, whose definition has to be
+%  changed accordingly.  This shows the need---and advantage---of a
+%  better allocation scheme.
+%
+% \subsubsection{\PiCTeX}
+%
+%  The macro package \PiCTeX\ uses a lot of dimen registers.  A subset
+%  of these registers are only used within a picture or within a set
+%  of drawing and parameter setting commands.
+%
+%  As an example the dimen registers |\totalarclength| is only used in
+%  a very restrictic set of commands, i.e., it can be allocated within
+%  the scope of the higher level commands or within \PiCTeX's
+%  |\beginpicture| \ldots\ |\endpicture| environment.
+%
+%
+% \StopEventually{^^A
+%   \begin{thebibliography}{0}
+%   \bibitem{DEK91} Donald E.\ Knuth,
+%     {\it The \TeX{}book},
+%     Addison-Wesley Publ., Reading, Mass., Juni 1991.
+%   \bibitem{plain.tex-3.14159} File {\tt plain.tex},
+%     version 3.14159,
+%     March 1995.
+%   \end{thebibliography}
+% }
+%
+%
+%
+% \section{Implementation}
+%
+%
+% \subsection{Prolog, \LaTeXe\ Package Declarations, etc.}
+%
+%    The very first thing we do is to ensure that this file is not
+%    read in twice.  To this end we check whether the macro
+%    |\lnewcount| is defined. If so, we just stop reading this file.
+%    \begin{macrocode}
+%<+package>\expandafter\ifx\csname lnewcount\endcsname\relax
+%<+package>\else \expandafter\endinput \fi
+%    \end{macrocode}
+%
+%    For the sake of \LaTeXe\ users declarations for this package are
+%    included.  The additional group hack is needed to prevent the
+%    definition of |\ProvidesPackage| as |\relax| if it is undefined.
+%    \begin{macrocode}
+%<+package|test>\begingroup\expandafter\expandafter\expandafter\endgroup
+%<+package|test>\expandafter\ifx\csname ProvidesPackage\endcsname\relax
+%<+package|test>\else
+  \NeedsTeXFormat{LaTeX2e}
+%<+package>  \ProvidesPackage{localloc}%
+%<+test>  \ProvidesFile{localtst.tex}%
+%<*!package&!test>
+  \ProvidesFile{localloc.dtx}%
+%</!package&!test>
+    [1995/09/24 v1.1b %
+     Additional LaTeX Kernel Macros (local allocation)]
+%<+package|test>\fi
+%    \end{macrocode}
+%
+%    \begin{macrocode}
+%<*package>
+%    \end{macrocode}
+%
+%    To allow the use of this file within a plain-\TeX\ job, we have
+%    to change the category code of the `at' character~{\tt @}.
+%    \begin{macrocode}
+\expandafter\chardef\csname lcllc at at\endcsname=\catcode`\@
+\catcode`\@=11 % \makeatletter
+%    \end{macrocode}
+%
+%
+% \subsection{Accessing the {\tt muskip} registers}
+%
+%    Beside the well-known \TeX\ registers, like |\count| or |\box|,
+%    there is another set of registers which are used only in few
+%    macros.  The |\muskip| registers are normally used in math mode
+%    only and the coercion of the value in a |\muskip| register to an
+%    integer (|\count|), dimension (|\dimen|), or glue (|\glue|)
+%    produces an error.
+%
+%    The unit of a |\muskip| value is~$1$\,mu---there are $18$\,mu in
+%    $1$\,em of the current font in {\em math family~2}.  If you
+%    assign a value to a |\muskip| register, this value is represented
+%    in the unit~mu, not in~pt.  The dimension of the |\muskip| value
+%    is computed, if this value is used by |\mskip| or |\mkern|.
+%
+%    To use a |\muskip| register as a replacement for a |\count|
+%    register, it is necessary to do assignments, additions, and other
+%    operations in units of~mu.  If you want to coerce an
+%    integer to a |\muskip| register, you have to get the value with
+%    |\the| and add the keyword~|mu| while scanning the number. To get
+%    the integer value of a |\muskip| register, you can use the
+%    following macro~|\lcllc at cnvmutocnt|.
+%
+% \begin{macro}{\lcllc at cnvmutocnt}
+%    The macro |\lcllc at cnvmutocnt| ist called with a |\muskip| register
+%    or a value in~|mu| units as its argument.  It will expand to the
+%    integer value.  To get the value of a register, we first expand
+%    the value of this register to a list of tokens with \TeX's |\the|
+%    primitive.
+%    Example: if the register has the value~$3.4$\,mu, the expansion of
+%    |\the| produces the tokens $\mbox{\tt 3}_{12} \mbox{\tt .}_{12}
+%    \mbox{\tt 4}_{12} \mbox{\tt m}_{12} \mbox{\tt u}_{12}$.
+%    \begin{macrocode}
+\def\lcllc at cnvmutocnt#1{\expandafter\lcllc at delmukey\the#1}
+%    \end{macrocode}
+%
+%    After we have expanded the value of the register, it is necessary
+%    to strip of the unit keyword~|mu| and the fraction of the value.
+%    To do this, we have to use tokens with {\em category code}~12 to
+%    match the expansion string produced by~|\the|.
+%    \begin{macrocode}
+\begingroup \catcode`\M=12 \catcode`\U=12 \catcode`\.=12
+  \lowercase{\endgroup
+\def\lcllc at delmukey#1.#2MU{#1}}
+%    \end{macrocode}
+% \end{macro}
+%
+%
+%  \subsection{Allocation registers}
+%
+%  \subsubsection{Registers defined in {\tt plain.tex}}
+%
+%    Plain-\TeX's allocation macros use a fixed set of |count|
+%    registers containing a set of numbers with the highest allocated
+%    register number.  To make the following macro code more readable,
+%    alias names for these |count| registers are defined.
+%    \begin{macrocode}
+\countdef\count at ptr    = 10
+\countdef\dimen at ptr    = 11
+\countdef\skip at ptr     = 12
+\countdef\muskip at ptr   = 13
+\countdef\box at ptr      = 14
+\countdef\toks at ptr     = 15
+\countdef\read at ptr     = 16
+\countdef\write at ptr    = 17
+\countdef\mathfam at ptr  = 18
+%    \end{macrocode}
+%    {\tt plain.tex} for \TeX~3 introduces a new allocation command
+%    needing an additional allocation count register.  To simplify the
+%    code of this package with older versions of {\tt plain.tex}, a
+%    dummy count register is allocated and used.
+%    \begin{macrocode}
+\begingroup\expandafter\expandafter\expandafter\endgroup
+\expandafter\ifx\csname newlanguage\endcsname\relax
+  \csname newcount\endcsname\language at ptr
+\else
+  \countdef\language at ptr = 19
+\fi
+%    \end{macrocode}
+%
+%    The allocation command for insertion uses another register, which
+%    is already aliased as |\insc at unt|.
+%\begin{verbatim}
+%\countdef\insc at unt = 20 % = 19 in older versions of `plain.tex'
+%\end{verbatim}
+%
+%
+%  \subsubsection{Additional Registers}
+%
+%    For the new local allocation macros additional registers are
+%    needed containing the boundaries for all types of locally
+%    allocated registers.  Whereas all globally allocated registers
+%    are located in the lower region of the register numbers (with the
+%    exception of the set of registers needed for an insertion),
+%    locally allocated registers are taken from the higher region of
+%    the register numbers---from top towards the bottom.
+%
+%    To avoid using six additional count registers we use |\muskip|
+%    registers to save the current lower boundary of the allocatable
+%    register region.  These boundaries are initialised either
+%    with~$256$ or the actual boundary of the insertion allocation
+%    register.
+%    \begin{macrocode}
+\newmuskip\count at limit  \count at limit  = \the\insc at unt mu
+\newmuskip\dimen at limit  \dimen at limit  = \the\insc at unt mu
+\newmuskip\skip at limit   \skip at limit   = \the\insc at unt mu
+\newmuskip\box at limit    \box at limit    = \the\insc at unt mu
+\newmuskip\muskip at limit \muskip at limit = 256mu
+\newmuskip\toks at limit   \toks at limit   = 256mu
+%    \end{macrocode}
+%
+%    To simplify the code of the following allocation macros and to
+%    save macro space, two additional |\muskip| registers are
+%    allocated and initialised with the constants $16$ and~$256$.
+%    \begin{macrocode}
+\newmuskip\cclvi at mu     \cclvi at mu     = 256mu
+\newmuskip\xvi at mu       \xvi at mu       = 16mu
+%    \end{macrocode}
+%
+%
+%  \subsection{Allocation Macros for the ``End User''}
+%
+%  \subsubsection{Global Allocation Macros}
+%
+% \begin{macro}{\newcount} \begin{macro}{\newdimen}
+% \begin{macro}{\newskip}  \begin{macro}{\newmuskip}
+% \begin{macro}{\newbox}   \begin{macro}{\newtoks}
+% \begin{macro}{\newread}  \begin{macro}{\newwrite}
+% \begin{macro}{\newfam}   \begin{macro}{\newlanguage}
+%    We have to replace the original macros in {\tt plain.tex} by new
+%    ones to allow locally allocated registers.  Otherwise it will be
+%    possible that the two regions, the lower one with globally
+%    allocated registers and the higher one with locally allocated
+%    registers, will overlap resulting in a double use of the same
+%    register.
+%
+%    With the new macros it will be unnecessary to un-outer the {\tt
+%    plain.tex} macros, because the local allocation macros have to be
+%    non outer.  Nonetheless we want to use this package in
+%    conjunction with \LaTeX\ and therefore we have to define some of
+%    them as non outer.
+%
+%    The top level macros use the low level macro |\alloc@| which has
+%    the following parameters:
+%    The boundaries of the lower and the higher region, the type of
+%    the allocated register, a flag if we have to check on overlapping
+%    with insertion registers, the \TeX\ primitive to be used to
+%    define this register, and the user given control sequence.
+%    \begin{macrocode} 
+%\outer
+\def\newcount  {\alloc@\count at ptr  \count at limit \count  1\countdef }
+%\outer
+\def\newdimen  {\alloc@\dimen at ptr  \dimen at limit \dimen  1\dimendef }
+%\outer
+\def\newskip   {\alloc@\skip at ptr   \skip at limit  \skip   1\skipdef  }
+% \outer
+\def\newmuskip {\alloc@\muskip at ptr \muskip at limit\muskip 0\muskipdef}
+%\outer
+\def\newbox    {\alloc@\box at ptr    \box at limit   \box    1\chardef  }
+% \outer
+\def\newtoks   {\alloc@\toks at ptr   \toks at limit  \toks   0\toksdef  }
+% \outer
+\def\newread   {\alloc@\read at ptr   \xvi at mu      \read   0\chardef  }
+%\outer
+\def\newwrite  {\alloc@\write at ptr  \xvi at mu      \write  0\chardef  }
+%\outer
+\def\newfam    {\alloc@\mathfam at ptr\xvi at mu      \fam    0\chardef  }
+% \outer
+\def\newlanguage{\alloc@\lang at ptr  \cclvi at mu   \language0\chardef  }
+%    \end{macrocode}
+% \end{macro}\end{macro}\end{macro}\end{macro}\end{macro}
+% \end{macro}\end{macro}\end{macro}\end{macro}\end{macro}
+%
+%    |\newinsert| needs additional code because this macro has to
+%    allocate a set of |\box|, |\count|, |\dimen|, and |\skip|
+%    registers with the restriction that all registers have to have
+%    the same number. |\newinsert| is redefined at the end of this
+%    file.
+%
+%
+%  \subsubsection{Local Allocation Macros}
+%
+%
+% \begin{macro}{\lnewcount} \begin{macro}{\lnewdimen}
+% \begin{macro}{\lnewskip}  \begin{macro}{\lnewmuskip}
+% \begin{macro}{\lnewbox}   \begin{macro}{\lnewtoks}
+%    There is an equivalent set of macros to allocate registers
+%    locally.  Instead of using the low level macro |\alloc@| it uses
+%    the macro |\lalloc@| with the same set of parameters.
+%    \begin{macrocode}
+\def\lnewcount {\lalloc@\count at ptr \count at limit \count  1\countdef }
+\def\lnewdimen {\lalloc@\dimen at ptr \dimen at limit \dimen  1\dimendef }
+\def\lnewskip  {\lalloc@\skip at ptr  \skip at limit  \skip   1\skipdef  }
+\def\lnewmuskip{\lalloc@\muskip at ptr\muskip at limit\muskip 0\muskipdef}
+\def\lnewbox   {\lalloc@\box at ptr   \box at limit   \box    1\chardef  }
+\def\lnewtoks  {\lalloc@\toks at ptr  \toks at limit  \toks   0\toksdef  }
+%    \end{macrocode}
+% \end{macro}\end{macro}\end{macro}\end{macro}\end{macro}\end{macro}
+%
+%    Local allocation macros for |\read|, |\write| streams, math
+%    |\fam|, |language| numbers, or insertions are possible but not
+%    very useful because of the global nature of these resources.
+%
+%
+%  \subsection{Low Level Allocation Macros}
+%
+%    The allocation scheme used by the macros in {\tt plain.tex} is
+%    simple:
+%    \begin{itemize}
+%    \item all allocations are global,
+%    \item register, math family, language, input/output stream
+%      numbers are allocated using the lowest possible number, i.e.,
+%      it is done from lower number to higher numbers,
+%    \item the set of insertion registers (|box|, |count|, |skip|, and
+%      |dimen|), which have to have the same register number, are
+%      allocated beginning from~$255$ to lower numbers.
+%    \end{itemize}
+%
+%    Contrary to this simple scheme this package uses numbers for
+%    locally allocated registers from top to bottom interfering with
+%    the original insertion register allocation scheme {\it and\/} the
+%    simple test for a register number overflow.
+%
+% \begin{macro}{\lcllc at insnums}
+%    Insertion registers are now allocated in a non-monotonous order
+%    using the lowest possible number (because the allocation of the
+%    needed set of registers is done in a global way).  To allow the
+%    checking of overlapping of globally or locally allocated
+%    registers with the registers used for insertions, the insertion
+%    register numbers are saved as a list in |\lcllc at insnums|.
+%    Each entry in this list is saved as \mbox{\tt\string\do$\langle
+%    n\rangle$.}; the list is initialised as empty.
+%    \begin{macrocode} 
+\def\lcllc at insnums{}
+%    \end{macrocode} 
+% \end{macro}
+%
+% \begin{macro}{\lcllc at checkins}
+%    Whenever a new |box|, |count|, |skip|, or |dimen| register is
+%    allocated it has to be checked first, if the next possible
+%    free register is already allocated for an insertion.
+%
+%    To detect a collision between a possibly free register number and
+%    the set of insertion registers, the macro |\lcllc at checkins| is
+%    called with the register number to be tested in
+%    |\allocationnumber|.  The argument of this macro has to be either
+%    $1$ or~$-1$ and is used to get the next register number to be
+%    tested against the insertion number list if an additional
+%    iteration is needed.  The result is a register number in
+%    |\allocationnumber| which is not used for an insertion.  (Note:
+%    Nonetheless it can be an out-of-region register number of an
+%    already used register!)
+%    \begin{macrocode} 
+\def\lcllc at checkins#1{%
+  \begingroup
+%    \end{macrocode} 
+%    After opening a new group, the macro |\do| is defined to read the
+%    next insertion number delimited by a simple dot.  It then tests
+%    this number against the current |\allocationnumber| and if the
+%    register numbers are equal, |\allocationnumber| is advanced by the
+%    given argument (which is $1$ or~$-1$).
+%
+%    To avoid a global change of |\allocationnumber|, a group hack
+%    with expansion is used:  If the list |\lcllc at insnums| is expanded
+%    with this definition of |\do|, the result is empty if the
+%    register number is not used for an insertion.  Otherwise it
+%    expands to the |\advance| command followed by an additional
+%    |lcllc at checkins| (which has to be protected by |\noexpand|) to
+%    start another iteration with the changed |\allocationnumber|.
+%    \begin{macrocode} 
+    \def\do##1.{%
+      \ifnum##1=\allocationnumber
+        \advance\allocationnumber#1\relax
+        \noexpand\lcllc at checkins{#1}%
+      \fi}%
+%    \end{macrocode}
+%    The following expanded definition text of |\x| contains code to
+%    close the group and the expansion of |\lcllc at insnums|, which is
+%    either empty or contains the change of |\allocationnumber| and an
+%    iterative call of |\lcllc at checkins|.  After the definition is
+%    completed, the code is executed which closes the group.
+%    \begin{macrocode}
+    \edef\x{\endgroup \lcllc at insnums}%
+  \x}
+%    \end{macrocode} 
+% \end{macro}
+%
+%
+% \begin{macro}{\alloc@}
+%    |\alloc@| is the low level macro for global allocation, which is
+%    called with six arguments.  The macro itself only uses the first
+%    four argument: The two boundaries, the item type to be allocated,
+%    and a flag if this item is propably used for an insertion.  The
+%    remaining two arguments, the \TeX\ primitive and the control
+%    sequence to assign the allocated number is used by
+%    |\lcllc at def|.
+%    \begin{macrocode}
+\def\alloc@#1#2#3#4{%
+%    \end{macrocode}
+%    In the first step we assign the boundary of the lower region for
+%    this item type to |\allocationnumber| and increment it by one.
+%    \begin{macrocode}
+  \allocationnumber#1%
+  \advance\allocationnumber\@ne
+%    \end{macrocode}
+%    If this item type is used by insertion, we have to check for
+%    collision with the |\lcllc at checkins| macro.  After the execution of
+%    this macro, |\allocationnumber| contains the next free number to
+%    be used for allocation.  This number is assigned globally to the
+%    register containing the boundary.
+%    \begin{macrocode}
+  \ifnum#4=\@ne \lcllc at checkins\@ne \fi
+  \global#1\allocationnumber
+%    \end{macrocode}
+%    We now have found an unused register.  Nonetheless it is possible
+%    that the register number is either not in the range of existing
+%    register number or it is used for a locally allocated register.
+%    |\ch at ck| is used to test these things.
+%    \begin{macrocode}
+  \ch at ck#1#2#3%
+%    \end{macrocode}
+%    At the end the \meta{control sequence} is defined using the
+%    found |\allocationnumber|.
+%    \begin{macrocode}
+  \lcllc at def\global{}#3}
+%    \end{macrocode}
+%  \end{macro}
+%
+%
+%  \begin{macro}{\lalloc@}
+%    |\lalloc@| is the low level macro for local allocation.  The
+%    definition of this macro a copy of |\alloc@| with some small
+%    changes.
+%    \begin{macrocode}
+\def\lalloc@#1#2#3#4{%
+%    \end{macrocode}
+%    In the first step we assign the boundary of the {\it higher\/}
+%    region and {\it decrement\/} it by one.   Because the higher
+%    boundary is saved in a |\muskip| register, we have to use
+%    |\lcllc at cnvmutocnt| to get the boundary value.
+%    \begin{macrocode}
+  \allocationnumber\lcllc at cnvmutocnt#2%
+  \advance\allocationnumber\m at ne
+%    \end{macrocode}
+%    The check for insertion number collisions is called with~$-1$ to
+%    decrement the register number to get the next free register
+%    number.  The |\allocationnumber| is then assigned {\it locally\/}
+%    to the |\muskip| register containing the boundary.
+%    \begin{macrocode}
+  \ifnum#4=\@ne \lcllc at checkins\m at ne \fi
+  #2\the\allocationnumber mu %
+%    \end{macrocode}
+%    The check for an already used globally allocated register or a
+%    range underflow is needed, too.
+%    \begin{macrocode}
+  \ch at ck#1#2#3%
+%    \end{macrocode}
+%    At the end the \meta{control sequence} is defined using the
+%    found |\allocationnumber|.
+%    \begin{macrocode}
+  \lcllc at def\relax{(local)}#3}
+%    \end{macrocode}
+%  \end{macro}
+%
+%
+%  \begin{macro}{\ch at ck}
+%    The test macro |\ch at ck| for a collision of the globally and
+%    locally allocated registers from {\tt plain.tex} has to be
+%    changed because the higher boundary is given as a |\muskip| value
+%    instead of a normal integer.
+%    \begin{macrocode}
+\def\ch at ck#1#2#3{%
+  \ifnum#1<\lcllc at cnvmutocnt#2\relax \else
+    \errmessage{No room for a new #3}%
+    % \allocationnumber\m at ne
+  \fi}
+%    \end{macrocode}
+%  \end{macro}
+%
+%
+%  \begin{macro}{\lcllc at def}
+%    |\lcllc at def| is used to assign the found |\allocationnumber|
+%    to the \meta{control sequence} using the \TeX\ primitive.
+%    Additionally an entry is written to the {\tt log} file.
+%    \begin{macrocode}
+\def\lcllc at def#1#2#3#4#5{%
+  #1#4#5=\allocationnumber
+  \wlog{\string#5#2=\string#3\the\allocationnumber}}
+%    \end{macrocode}
+%  \end{macro}
+%
+%
+%  \subsubsection{Low Level Insertion Allocation Macros}
+%
+%    Insertions need a set of registers with the same register number.
+%    To find a new register number when allocating an insertion, we
+%    have to get the maximum of all boundaries used for an insertion.
+%
+%  \begin{macro}{\lcllc at getmax}
+%    |\lcllc at getmax| is used to assign |\allocationnumber| to the
+%    maximum of |\allocationnumber| and its argument.
+%    \begin{macrocode}
+\def\lcllc at getmax#1{%
+  \ifnum#1<\allocationnumber \else
+    \allocationnumber#1\advance\allocationnumber\@ne
+  \fi}
+%    \end{macrocode}
+%  \end{macro}
+%
+%  \begin{macro}{\newinsert}
+%    |\newinsert| globally allocates a set of registers used for an
+%    insertion.
+%    \begin{macrocode}
+\outer\def\newinsert{%
+%    \end{macrocode}
+%    First we have to find the maximum of all globally allocated
+%    register number used for an insertion.   We start
+%    by setting |\allocationnumber| to~$-1$\,\ldots
+%    \begin{macrocode}
+  \allocationnumber\m at ne
+%    \end{macrocode}
+%    \ldots\,and get the maxmimum of the boundaries for |count|,
+%    |dimen|, |skip|, and |box| registers.
+%    \begin{macrocode}
+  \lcllc at getmax\count at ptr \lcllc at getmax\dimen at ptr
+  \lcllc at getmax\skip at ptr  \lcllc at getmax\box at ptr
+%    \end{macrocode}
+%    Then we have to check if this |\allocationnumber| is already used
+%    for another insertion.
+% \changes{v1.0b}{91/09/06}{\cs{lcllc at checkins} inserted}
+%    \begin{macrocode}
+  \lcllc at checkins\@ne
+%    \end{macrocode}
+%    At last we have to check if this |\allocationnumber| is used for
+%    one of the locally allocated registers.
+%    \begin{macrocode}
+  \ch at ck\allocationnumber\count at limit\count
+  \ch at ck\allocationnumber\dimen at limit\dimen
+  \ch at ck\allocationnumber\skip at limit\skip
+  \ch at ck\allocationnumber\box at limit\box
+%    \end{macrocode}
+%    The found register number for insertions is then (globally)
+%    inserted into the list of insertion numbers.
+%    \begin{macrocode}
+  \begingroup
+    \let\do\relax
+    \xdef\lcllc at insnums{\do\the\allocationnumber.\lcllc at insnums}%
+  \endgroup
+%    \end{macrocode}
+%    At the end the \meta{control sequence} is defined using the
+%    found |\allocationnumber|.
+%    \begin{macrocode}
+  \lcllc at def\global{}\insert\chardef}
+%    \end{macrocode}
+%  \end{macro}
+%
+%    The register |\insc at unt| which is used to contain the boundary
+%    number for insertion registers in the original {\tt plain.tex}
+%    macro is not used anymore.
+%
+%
+%    Finally, the category code of the `at' character~{\tt @} is reset
+%    to its original value.
+%    \begin{macrocode}
+\catcode`\@=\lcllc at at
+%    \end{macrocode}
+%
+%    \begin{macrocode}
+%</package>
+%    \end{macrocode}
+%
+%
+% \iffalse
+%<*driver>
+\NeedsTeXFormat{LaTeX2e}
+\documentclass[a4paper]{ltxdoc}
+\GetFileInfo{localloc.dtx}
+\begin{document}
+ \DocInput{\filename}
+\end{document}
+%</driver>
+% \fi
+%
+% \iffalse
+%
+% \section{Test File}
+%
+%  A first version of a test file which can be used for plain-TeX,
+%  \LaTeX~2.09, and \LaTeXe.  The result shows the allocated register
+%  numbers.  You should notice that the insertions and global box
+%  registers are not contiguously allocated but interfere.  Further
+%  from one to the next line there is a new global register number
+%  greater than the former one.  Whereas the local register numbers
+%  are set to zero when leaving a group and they are recycled in the
+%  next lines.
+%
+%    \begin{macrocode}
+%<*test>
+% This test file can be used with plain-TeX & LaTeX 2.09/2e.
+%
+\edef\FORMAT{%
+  \expandafter\ifx\csname documentstyle\endcsname\relax 0%
+  \else\expandafter\ifx\csname documentclass\endcsname\relax
+  1\else 2\fi\fi}
+\immediate\write16{=====>>> You are using %
+  \ifcase\FORMAT plainTeX\or LaTeX 2.09\or LaTeX 2e\else ??\fi}
+\ifcase\FORMAT
+  \input localloc.sty\relax \or
+  \documentstyle[localloc]{article}\begin{document}\or
+  \documentclass{article}\usepackage{localloc}\begin{document}\fi
+\tracingstats=1
+% some macros
+\def\Message#1{\immediate\write16{#1}}
+\def\RegVal#1{\the\csname test#1\endcsname}
+\def\ShowSet#1{\if l#1local\else global\fi:
+   \RegVal{i#1} \RegVal{ii#1}/\RegVal{iii#1}
+   \RegVal{iv#1}}
+\def\ShowAll#1{\Message{#1 -- \ShowSet{g} -- \ShowSet{l}}}
+\def\ShowIns{\Message{Insertions:
+   \the\testinsi, \the\testinsii, \the\testinsiii}}
+% initialise
+\chardef\testig=0    \chardef\testil=0
+\chardef\testiig=0   \chardef\testiil=0
+\chardef\testiiig=0  \chardef\testiiil=0
+\chardef\testivg=0   \chardef\testivl=0
+\chardef\testinsii=0 \chardef\testinsiii=0
+% allocate an insertion/set of registers
+\newinsert\testinsi
+% make sure that a collision boxes/insertions occurs
+{\count0=\testinsi \advance\count0 -2
+ \loop\csname newbox\endcsname\testig
+ \ifnum\testig<\count0\repeat}
+%
+\newbox\testig \lnewbox\testil
+\ShowAll{Level 0}
+\begingroup
+ \lnewbox\testiil \newbox\testiig
+ \ShowAll{Level 1}
+ \begingroup
+  \newbox\testivg \lnewbox\testivl
+  \ShowAll{Level 2}\ShowIns
+ \endgroup
+ \lnewbox\testiiil \newbox\testiiig
+ \ShowAll{Level 1b}
+ \csname newinsert\endcsname\testinsii
+ \ShowIns
+ \begingroup
+  \newbox\testivg \lnewbox\testivl
+  \ShowAll{Level 2}
+ \endgroup
+ \ShowAll{Level 1b}
+\endgroup
+\newinsert\testinsiii
+\ShowAll{Level 0}\ShowIns
+\begingroup
+ \lnewbox\testiil \newbox\testiig
+ \lnewbox\testiiil \newbox\testiiig
+ \ShowAll{Level 1}
+ \begingroup
+  \newbox\testivg \lnewbox\testivl
+  \newbox\testvg \lnewbox\testvl
+  \ShowAll{Level 2}\ShowIns
+ \endgroup
+ \ShowAll{Level 1}
+\endgroup
+\ShowAll{Level 0}
+\end{document}
+%</test>
+%    \end{macrocode}
+%
+% \fi
+%
+% \Finale
+%
+%% \CharacterTable 
+%%  {Upper-case    \A\B\C\D\E\F\G\H\I\J\K\L\M\N\O\P\Q\R\S\T\U\V\W\X\Y\Z 
+%%   Lower-case    \a\b\c\d\e\f\g\h\i\j\k\l\m\n\o\p\q\r\s\t\u\v\w\x\y\z 
+%%   Digits        \0\1\2\3\4\5\6\7\8\9 
+%%   Exclamation   \!     Double quote  \"     Hash (number) \# 
+%%   Dollar        \$     Percent       \%     Ampersand     \& 
+%%   Acute accent  \'     Left paren    \(     Right paren   \) 
+%%   Asterisk      \*     Plus          \+     Comma         \, 
+%%   Minus         \-     Point         \.     Solidus       \/ 
+%%   Colon         \:     Semicolon     \;     Less than     \< 
+%%   Equals        \=     Greater than  \>     Question mark \?  
+%%   Commercial at \@     Left bracket  \[     Backslash     \\ 
+%%   Right bracket \]     Circumflex    \^     Underscore    \_ 
+%%   Grave accent  \`     Left brace    \{     Vertical bar  \| 
+%%   Right brace   \}     Tilde         \~} 
+%% 
+%
+\endinput


Property changes on: trunk/Master/texmf-dist/source/generic/localloc/localloc.dtx
___________________________________________________________________
Added: svn:eol-style
## -0,0 +1 ##
+native
\ No newline at end of property
Added: trunk/Master/texmf-dist/tex/generic/localloc/localloc.sty
===================================================================
--- trunk/Master/texmf-dist/tex/generic/localloc/localloc.sty	                        (rev 0)
+++ trunk/Master/texmf-dist/tex/generic/localloc/localloc.sty	2020-09-30 21:31:20 UTC (rev 56496)
@@ -0,0 +1,153 @@
+%%
+%% This is file `localloc.sty',
+%% generated with the docstrip utility.
+%%
+%% The original source files were:
+%%
+%% localloc.dtx  (with options: `package')
+%% 
+%% This is a file of the `localloc' package reimplementing
+%% plain-TeX's and LaTeX's basic allocation macros to allow
+%% local allocation of registers.
+%% 
+%% -- Copyright (C) 1991-1995 Bernd Raichle.  All rights reserved --
+%% 
+%% This package is distributed in the hope that it will be useful,
+%% but WITHOUT ANY WARRANTY; without even the implied warranty of
+%% MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
+%% 
+%% 
+%% IMPORTANT NOTICE:
+%% 
+%% Copying of this file is authorized only if either
+%% (1) you make absolutely no changes to your copy, including name, or
+%% (2) if you do make changes, you name it something other than
+%%     localloc.dtx, localloc.doc, localloc.tex, or localloc.sty.
+%% 
+%% For error reports see original source file `localloc.dtx'.
+%% 
+\expandafter\ifx\csname lnewcount\endcsname\relax
+\else \expandafter\endinput \fi
+\begingroup\expandafter\expandafter\expandafter\endgroup
+\expandafter\ifx\csname ProvidesPackage\endcsname\relax
+\else
+  \NeedsTeXFormat{LaTeX2e}
+  \ProvidesPackage{localloc}%
+    [1995/09/24 v1.1b %
+     Additional LaTeX Kernel Macros (local allocation)]
+\fi
+\expandafter\chardef\csname lcllc at at\endcsname=\catcode`\@
+\catcode`\@=11 % \makeatletter
+\def\lcllc at cnvmutocnt#1{\expandafter\lcllc at delmukey\the#1}
+\begingroup \catcode`\M=12 \catcode`\U=12 \catcode`\.=12
+  \lowercase{\endgroup
+\def\lcllc at delmukey#1.#2MU{#1}}
+\countdef\count at ptr    = 10
+\countdef\dimen at ptr    = 11
+\countdef\skip at ptr     = 12
+\countdef\muskip at ptr   = 13
+\countdef\box at ptr      = 14
+\countdef\toks at ptr     = 15
+\countdef\read at ptr     = 16
+\countdef\write at ptr    = 17
+\countdef\mathfam at ptr  = 18
+\begingroup\expandafter\expandafter\expandafter\endgroup
+\expandafter\ifx\csname newlanguage\endcsname\relax
+  \csname newcount\endcsname\language at ptr
+\else
+  \countdef\language at ptr = 19
+\fi
+\newmuskip\count at limit  \count at limit  = \the\insc at unt mu
+\newmuskip\dimen at limit  \dimen at limit  = \the\insc at unt mu
+\newmuskip\skip at limit   \skip at limit   = \the\insc at unt mu
+\newmuskip\box at limit    \box at limit    = \the\insc at unt mu
+\newmuskip\muskip at limit \muskip at limit = 256mu
+\newmuskip\toks at limit   \toks at limit   = 256mu
+\newmuskip\cclvi at mu     \cclvi at mu     = 256mu
+\newmuskip\xvi at mu       \xvi at mu       = 16mu
+\def\newcount  {\alloc@\count at ptr  \count at limit \count  1\countdef }
+\def\newdimen  {\alloc@\dimen at ptr  \dimen at limit \dimen  1\dimendef }
+\def\newskip   {\alloc@\skip at ptr   \skip at limit  \skip   1\skipdef  }
+\def\newmuskip {\alloc@\muskip at ptr \muskip at limit\muskip 0\muskipdef}
+\def\newbox    {\alloc@\box at ptr    \box at limit   \box    1\chardef  }
+\def\newtoks   {\alloc@\toks at ptr   \toks at limit  \toks   0\toksdef  }
+\def\newread   {\alloc@\read at ptr   \xvi at mu      \read   0\chardef  }
+\def\newwrite  {\alloc@\write at ptr  \xvi at mu      \write  0\chardef  }
+\def\newfam    {\alloc@\mathfam at ptr\xvi at mu      \fam    0\chardef  }
+\def\newlanguage{\alloc@\lang at ptr  \cclvi at mu   \language0\chardef  }
+\def\lnewcount {\lalloc@\count at ptr \count at limit \count  1\countdef }
+\def\lnewdimen {\lalloc@\dimen at ptr \dimen at limit \dimen  1\dimendef }
+\def\lnewskip  {\lalloc@\skip at ptr  \skip at limit  \skip   1\skipdef  }
+\def\lnewmuskip{\lalloc@\muskip at ptr\muskip at limit\muskip 0\muskipdef}
+\def\lnewbox   {\lalloc@\box at ptr   \box at limit   \box    1\chardef  }
+\def\lnewtoks  {\lalloc@\toks at ptr  \toks at limit  \toks   0\toksdef  }
+\def\lcllc at insnums{}
+\def\lcllc at checkins#1{%
+  \begingroup
+    \def\do##1.{%
+      \ifnum##1=\allocationnumber
+        \advance\allocationnumber#1\relax
+        \noexpand\lcllc at checkins{#1}%
+      \fi}%
+    \edef\x{\endgroup \lcllc at insnums}%
+  \x}
+\def\alloc@#1#2#3#4{%
+  \allocationnumber#1%
+  \advance\allocationnumber\@ne
+  \ifnum#4=\@ne \lcllc at checkins\@ne \fi
+  \global#1\allocationnumber
+  \ch at ck#1#2#3%
+  \lcllc at def\global{}#3}
+\def\lalloc@#1#2#3#4{%
+  \allocationnumber\lcllc at cnvmutocnt#2%
+  \advance\allocationnumber\m at ne
+  \ifnum#4=\@ne \lcllc at checkins\m at ne \fi
+  #2\the\allocationnumber mu %
+  \ch at ck#1#2#3%
+  \lcllc at def\relax{(local)}#3}
+\def\ch at ck#1#2#3{%
+  \ifnum#1<\lcllc at cnvmutocnt#2\relax \else
+    \errmessage{No room for a new #3}%
+    % \allocationnumber\m at ne
+  \fi}
+\def\lcllc at def#1#2#3#4#5{%
+  #1#4#5=\allocationnumber
+  \wlog{\string#5#2=\string#3\the\allocationnumber}}
+\def\lcllc at getmax#1{%
+  \ifnum#1<\allocationnumber \else
+    \allocationnumber#1\advance\allocationnumber\@ne
+  \fi}
+\outer\def\newinsert{%
+  \allocationnumber\m at ne
+  \lcllc at getmax\count at ptr \lcllc at getmax\dimen at ptr
+  \lcllc at getmax\skip at ptr  \lcllc at getmax\box at ptr
+  \lcllc at checkins\@ne
+  \ch at ck\allocationnumber\count at limit\count
+  \ch at ck\allocationnumber\dimen at limit\dimen
+  \ch at ck\allocationnumber\skip at limit\skip
+  \ch at ck\allocationnumber\box at limit\box
+  \begingroup
+    \let\do\relax
+    \xdef\lcllc at insnums{\do\the\allocationnumber.\lcllc at insnums}%
+  \endgroup
+  \lcllc at def\global{}\insert\chardef}
+\catcode`\@=\lcllc at at
+%% \CharacterTable
+%%  {Upper-case    \A\B\C\D\E\F\G\H\I\J\K\L\M\N\O\P\Q\R\S\T\U\V\W\X\Y\Z
+%%   Lower-case    \a\b\c\d\e\f\g\h\i\j\k\l\m\n\o\p\q\r\s\t\u\v\w\x\y\z
+%%   Digits        \0\1\2\3\4\5\6\7\8\9
+%%   Exclamation   \!     Double quote  \"     Hash (number) \#
+%%   Dollar        \$     Percent       \%     Ampersand     \&
+%%   Acute accent  \'     Left paren    \(     Right paren   \)
+%%   Asterisk      \*     Plus          \+     Comma         \,
+%%   Minus         \-     Point         \.     Solidus       \/
+%%   Colon         \:     Semicolon     \;     Less than     \<
+%%   Equals        \=     Greater than  \>     Question mark \?
+%%   Commercial at \@     Left bracket  \[     Backslash     \\
+%%   Right bracket \]     Circumflex    \^     Underscore    \_
+%%   Grave accent  \`     Left brace    \{     Vertical bar  \|
+%%   Right brace   \}     Tilde         \~}
+%%
+\endinput
+%%
+%% End of file `localloc.sty'.


Property changes on: trunk/Master/texmf-dist/tex/generic/localloc/localloc.sty
___________________________________________________________________
Added: svn:eol-style
## -0,0 +1 ##
+native
\ No newline at end of property
Modified: trunk/Master/tlpkg/tlpsrc/collection-latexextra.tlpsrc
===================================================================
--- trunk/Master/tlpkg/tlpsrc/collection-latexextra.tlpsrc	2020-09-30 21:30:46 UTC (rev 56495)
+++ trunk/Master/tlpkg/tlpsrc/collection-latexextra.tlpsrc	2020-09-30 21:31:20 UTC (rev 56496)
@@ -696,7 +696,6 @@
 depend lkproof
 depend lmake
 depend locality
-depend localloc
 depend logbox
 depend logical-markup-utils
 depend logpap

Modified: trunk/Master/tlpkg/tlpsrc/collection-plaingeneric.tlpsrc
===================================================================
--- trunk/Master/tlpkg/tlpsrc/collection-plaingeneric.tlpsrc	2020-09-30 21:30:46 UTC (rev 56495)
+++ trunk/Master/tlpkg/tlpsrc/collection-plaingeneric.tlpsrc	2020-09-30 21:31:20 UTC (rev 56496)
@@ -56,6 +56,7 @@
 depend letterspacing
 depend librarian
 depend listofitems
+depend localloc
 depend mathdots
 depend metatex
 depend midnight



More information about the tex-live-commits mailing list.