texlive[56751] Master: mylatex (24oct20)
commits+karl at tug.org
commits+karl at tug.org
Sat Oct 24 22:30:05 CEST 2020
Revision: 56751
http://tug.org/svn/texlive?view=revision&revision=56751
Author: karl
Date: 2020-10-24 22:30:05 +0200 (Sat, 24 Oct 2020)
Log Message:
-----------
mylatex (24oct20)
Modified Paths:
--------------
trunk/Master/tlpkg/bin/tlpkg-ctan-check
trunk/Master/tlpkg/libexec/ctan2tds
trunk/Master/tlpkg/tlpsrc/collection-latexextra.tlpsrc
Added Paths:
-----------
trunk/Master/texmf-dist/doc/latex/mylatex/
trunk/Master/texmf-dist/doc/latex/mylatex/README.txt
trunk/Master/texmf-dist/tex/latex/mylatex/
trunk/Master/texmf-dist/tex/latex/mylatex/mylatex.ltx
trunk/Master/tlpkg/tlpsrc/mylatex.tlpsrc
Added: trunk/Master/texmf-dist/doc/latex/mylatex/README.txt
===================================================================
--- trunk/Master/texmf-dist/doc/latex/mylatex/README.txt (rev 0)
+++ trunk/Master/texmf-dist/doc/latex/mylatex/README.txt 2020-10-24 20:30:05 UTC (rev 56751)
@@ -0,0 +1,18 @@
+
+CTAN:macros/latex/contrib/supported/mylatex
+
+ All the files in this directory may be redistributed and/or modified
+ under the terms of the LaTeX Project Public License Distributed from
+ CTAN archives in directory macros/latex/base/lppl.txt; either version
+ 1 of the License, or (at your option) any later version.
+
+David Carlisle https://github.com/davidcarlisle/dpctex
+
+2020-10-23
+
+
+mylatex.ltx
+ This file provides a method of making a special format tailored to
+ one document, with all the class and packages, and other preamble
+ material pre-loaded. This can save quite a lot of time on some
+ systems. See the comments in the file.
Property changes on: trunk/Master/texmf-dist/doc/latex/mylatex/README.txt
___________________________________________________________________
Added: svn:eol-style
## -0,0 +1 ##
+native
\ No newline at end of property
Added: trunk/Master/texmf-dist/tex/latex/mylatex/mylatex.ltx
===================================================================
--- trunk/Master/texmf-dist/tex/latex/mylatex/mylatex.ltx (rev 0)
+++ trunk/Master/texmf-dist/tex/latex/mylatex/mylatex.ltx 2020-10-24 20:30:05 UTC (rev 56751)
@@ -0,0 +1,230 @@
+%%%
+%%% mylatex.ltx
+%%%%%%%%%%%%%%%
+%%%
+%%% Use this file to make a format based on the preamble of any LaTeX
+%%% file
+%%%
+%%% There are no restrictions on the distribution or modification of
+%%% this file, except that other people should not attempt to alter
+%%% the master copy on the ctan archives.
+%%%
+%%% Making the format
+%%%%%%%%%%%%%%%%%%%%%
+%%%
+%%% Given a LaTeX file `abc.tex', use initex as follows:
+%%%
+%%% initex &latex mylatex.ltx abc (Generic TeX)
+%%%
+%%% You may need to quote the & from your commandline and also
+%%% most modern systems use an --ini option rather than a separate
+%%% initex program so this may need to be
+%%%
+%%% pdftex --ini "&latex" mylatex.ltx abc
+%%%
+%%% To produce a format extending pdflatex for example.
+%%%
+%%% If you are on a Mac or using some shell that makes it inconvenient
+%%% to use a command line such as the above examples then you may
+%%% make a file `mylatex.tex' with the single line
+%%% \input mylatex.ltx abc
+%%% and then pass the file mylatex.tex to your (ini)tex shell to produce
+%%% the format, ie something equivalent to initex &latex mylatex.tex.
+%%%
+%%% If you are using OzTeX, see the separate instructions below.
+%%%
+%%% This should make a format file mylatex.fmt which you can then use
+%%% as follows
+%%%
+%%% Using the new format
+%%%%%%%%%%%%%%%%%%%%%%%%
+%%%
+%%% tex &mylatex abc (generic TeX)
+%%%
+%%% As above you may need to quote the & so for pdflatex
+%%%
+%%% pdflatex "&mylatex" abc
+%%%
+%%% This will process your document, abc.tex, just as LaTeX does, but
+%%% quicker as the contents of the preamble will be stored in the
+%%% format file and will not need to be run each time.
+%%%
+%%% If (vir)tex fails to find your mylatex.fmt then it is not searching
+%%% in the current directory, either modify your TEXFORMATS path (or
+%%% equivalent) to search `.' or (on unix/dos) use ./ as in:
+%%% virtex \&./mylatex abc
+%%%
+%%% Making and using the format with OzTeX
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+%%%
+%%% Given a LaTeX file `abc.tex', do this: select `TeX...' from OzTeX's
+%%% TeX menu, and go to the folder containing the file `abc.tex' as if you
+%%% were selecting the file `abc.tex'. Then hit the Cancel button - this
+%%% procedure sets OzTeX's working folder to the one containing abc.tex.
+%%% Next, select iniTeX from the TeX menu, and type:
+%%%
+%%% &latex mylatex.ltx abc
+%%%
+%%% This should make a format file mylatex.fmt which you can save in the
+%%% same folder as the file you're working on.
+%%%
+%%% To use the new format, put this at the very start of the very first
+%%% line of your document:
+%%%
+%%% %&mylatex
+%%%
+%%% Further Notes
+%%%%%%%%%%%%%%%%%
+%%%
+%%% The file abc.tex must contain a line *just* with
+%%% \begin{document}
+%%% Everything up to (but not including) the \begin{document} will
+%%% be saved in the format and not executed in subsequent runs.
+%%%
+%%% If you are modifying the document (or working on a similar document)
+%%% you may wish to add new commands to your document preamble.
+%%% The `mylatex' format normally skips the whole preamble (believing
+%%% it to be pre-loaded) and so such new commands do not take effect.
+%%% You could re-make the format, preloading the new preamble, but that
+%%% might be inconvenient to do every time, and so an alternative scheme
+%%% has been introduced.
+%%% If the preamble contains a comment mylatex (ie a line just
+%%% containing a % white space and the word mylatex) then the mylatex
+%%% format will start reading the preable at that point so any new
+%%% commands can be placed after such a comment and they will be
+%%% executed.
+%%%
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+%%% David Carlisle
+%%% 1994/09/27
+%%%
+%%% Modified 1994/10/21 after comments by
+%%% Volker Kunert <volker at numsun1.mathematik.uni-halle.de>
+%%% Modified 1996/01/26 To fix printout of preloaded files (which
+%%% hasnt worked since December 94 release, and to fix
+%%% incompatibility with \makeindex command.
+%%% Modified 1997/10/04 To generalise the \makeindex support to work
+%%% with any (well most:-) \openout uses in the preamble.
+%%% Modified 1997/10/09 Most? Ross Moore pointed out I just broke
+%%% changebar, so further tinkering. Also useful discussions
+%%% with Ross lead to the following changes.
+%%% Added `mylatex' comment feature.
+%%% Added some font preloading.
+%%% Modified 1998/01/21 Jean-Francois Mertens pointed out that comments
+%%% before the first TeX command were broken by the previous
+%%% version. In particular %&mylatex special comments which
+%%% would be picked up by some TeX versions to automatically
+%%% select the format.
+%%% Modified 1998/10/14 Rowland McDonnell added notes on how to use
+%%% mylatex.ltx with OzTeX
+%%% Modified 1999/01/04 Rowland McDonnell corrected notes on how to
+%%% use mylatex.ltx with OzTeX.
+%%% Modified 2020/10/23 Phelype Oleinik updated to work with new hook code
+%%% in \begin{document}
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+
+\makeatletter
+
+% Save the original definitions.
+\let\MYLATEXdocument\document
+\let\MYLATEXopenout\openout
+
+% new for 2020-10-01
+\ifx\@execute at begin@hook\@undefined
+\else
+ \let\MYLATEX at execute@begin at hook\@execute at begin@hook
+ \def\@execute at begin@hook#1{}%
+\fi
+
+% The version of \document to use on the initex run.
+% Just preloads some fonts, puts back \document and \openout,
+% sets up the banner to display the file list of files preloaded,
+% then sets up some special catcodes so the preamble will be
+% skipped on normal runs with the new format.
+\def\document{\endgroup
+% Force some font preloading.
+ {\setbox\z@\hbox{%
+ $$% math (not bold, some setups don't have \boldmath)
+ \normalfont% normal
+ {\ifx\large\@undefined\else\large\fi % large and footnote
+ \ifx\footnotesize\@undefined\else\footnotesize\fi}%
+ {\bfseries\itshape}% bold and bold italic
+ {\itshape}% italic
+ \ttfamily% monospace
+ \sffamily% sans serif
+ }}%
+ \let\document\MYLATEXdocument
+ \let\openout\MYLATEXopenout
+ \let\@execute at begin@hook\MYLATEX at execute@begin at hook
+ \makeatother
+ \everyjob\expandafter{\the\everyjob
+ \begingroup
+ \listfiles
+ \expandafter\MYLATEXcustomised\@dofilelist
+ \endgroup}%
+ \@addtofilelist{.}%
+ \catcode`\\=13\relax%
+ \catcode`\#=12\relax%
+ \catcode`\ =9\relax%
+ \dump}
+
+
+% In principle \openout stream= filename need not be space terminated,
+% and need not be immediate, but this covers \makeindex \makeglossary
+% and index package's \newindex which are all the cases of \openout
+% that occur before \begin{document} that I could see.
+% Thanks to Ross Moore for pointing out \AtBeginDocument is too late
+% eg changebar package *closes* the stream in \AtBeginDocument, so need
+% to make sure it is opened before that. Make a special purpose hook.
+%
+\def\openout#1 {%
+ \g at addto@macro\MYLATEXopens{\immediate\openout#1 }}
+\let\MYLATEXopens\@empty
+
+% Templates for ending the `preamble skipping process'.
+\def\MYLATEXbegin{\begin{document}}
+\def\MYLATEXcomment{mylatex}
+
+% Banner for \everyjob.
+\def\MYLATEXcustomised#1#2#3\typeout#4{%
+ \typeout{CUSTOMISED FORMAT. Preloaded files:^^J%
+ \@spaces\@spaces.}#3}
+
+% While the preamble is being skipped, the EOL is active
+% and defined to grab each line and inspect it looking
+% for \begin{document} or mylatex lines.
+% The special catcodes required are not enabled until after the
+% first TeX command in the file, so as to avoid problems with
+% the special processing that TeX does on the first line, choosing
+% the format, or the file name etc.
+{\catcode`\^^M=\active%
+ \catcode`\/=0 %
+ /catcode`\\=13 %
+ /gdef\{/catcode`/\=0 /catcode`/^^M=13 /catcode`/%=9 ^^M}%
+ /long/gdef^^M#1^^M{%
+ /def/MYLATEXline{#1}%
+% If hit a comment `mylatex' then do as if you'd hit \begin{document}
+% except don't run the real \document as a \begin{document} will be
+% coming up later in the file at the end of the preamble.
+ /ifx/MYLATEXline/MYLATEXcomment%
+ /let/MYLATEXbegin/relax%
+ /let/MYLATEXline/relax%
+ /fi%
+% If hit \begin{document} put things back as they should be, run the
+% hook with any save \openouts then do the original \document code.
+ /ifx/MYLATEXline/MYLATEXbegin%
+ /catcode`/^^M=5/relax%
+ /let^^M/par%
+ /catcode`/#=6/relax%
+ /catcode`/%=14/relax%
+ /catcode`/ =10/relax%
+ /expandafter/MYLATEXopens/expandafter/MYLATEXbegin%
+ /else%
+% Otherwise grab the next line to look at.
+ /expandafter^^M%
+ /fi}}%
+
+% Trick lookahead to allow mylatex.ltx and the document filename to be
+% given on the same command line. (initex &latex mylatex.ltx abc.tex)
+\expandafter\input\endinput%
+
Property changes on: trunk/Master/texmf-dist/tex/latex/mylatex/mylatex.ltx
___________________________________________________________________
Added: svn:eol-style
## -0,0 +1 ##
+native
\ No newline at end of property
Modified: trunk/Master/tlpkg/bin/tlpkg-ctan-check
===================================================================
--- trunk/Master/tlpkg/bin/tlpkg-ctan-check 2020-10-24 20:28:26 UTC (rev 56750)
+++ trunk/Master/tlpkg/bin/tlpkg-ctan-check 2020-10-24 20:30:05 UTC (rev 56751)
@@ -519,7 +519,7 @@
musical musicography musikui musixguit
musixtex musixtex-fonts musixtnt musuos muthesis
mversion mwcls mwe mweights mxedruli
- mycv mylatexformat mynsfc
+ mycv mylatex mylatexformat mynsfc
na-box na-position nag nameauth namedef namespc nanicolle nanumtype1 nar
natbib natded nath nature
navigator navydocs
Modified: trunk/Master/tlpkg/libexec/ctan2tds
===================================================================
--- trunk/Master/tlpkg/libexec/ctan2tds 2020-10-24 20:28:26 UTC (rev 56750)
+++ trunk/Master/tlpkg/libexec/ctan2tds 2020-10-24 20:30:05 UTC (rev 56751)
@@ -2024,6 +2024,7 @@
'musixtex', 'NULL', # not musixdoc.sty
'musixtnt', 'musixtnt.tex',
'mycv', 'mycv.*\.tex|' . $standardtex,
+ 'mylatex', '.*\.ltx',
'mylatexformat', '.*\.ltx',
'nag', '\.nag|' . $standardtex,
'navigator', '(t-)?navigator.tex|' . $standardtex,
Modified: trunk/Master/tlpkg/tlpsrc/collection-latexextra.tlpsrc
===================================================================
--- trunk/Master/tlpkg/tlpsrc/collection-latexextra.tlpsrc 2020-10-24 20:28:26 UTC (rev 56750)
+++ trunk/Master/tlpkg/tlpsrc/collection-latexextra.tlpsrc 2020-10-24 20:30:05 UTC (rev 56751)
@@ -821,6 +821,7 @@
depend mversion
depend mwe
depend mycv
+depend mylatex
depend mylatexformat
depend nag
depend nameauth
Added: trunk/Master/tlpkg/tlpsrc/mylatex.tlpsrc
===================================================================
More information about the tex-live-commits
mailing list.