From 4cec95dac159628430edabe7cf7c612aaef8e6fe Mon Sep 17 00:00:00 2001 From: LogCreative Date: Fri, 23 Dec 2022 23:23:48 +0800 Subject: [PATCH] ci: make install (#145) --- Makefile | 8 +++++ src/MANIFEST.md | 27 ++++++++++++---- src/build.lua | 26 +++++++++++---- src/doc/sjtubeamerdevguide.tex | 58 ++++++++++++++++++++++------------ 4 files changed, 87 insertions(+), 32 deletions(-) diff --git a/Makefile b/Makefile index 81290d01..c441123a 100644 --- a/Makefile +++ b/Makefile @@ -20,6 +20,14 @@ build: prepare format: latexindent main.tex -l latexindent.yaml -w $(LATEXINDENT_ARGS) +# Install the package to TeX Live / MacTeX +# For MiKTeX users, if you encounter `please use --texmfhome option`, +# I wish you could do the job manually by using +# `l3build install --texmfhome path/to/install`. +# For more details, see the development guide. +install: + cd src && l3build install + # Clean temporary files clean: latexmk -C $(LATEXMK_ARGS) diff --git a/src/MANIFEST.md b/src/MANIFEST.md index 3b12a33b..11202e2e 100644 --- a/src/MANIFEST.md +++ b/src/MANIFEST.md @@ -4,15 +4,29 @@ This file is a listing of all files considered to be part of this package. It is automatically generated with `l3build manifest`. +## Minimal manifest + +The following group lists all the necessary files that required by the runtime. +You could install these files to your TeX distribution or distribute them with +your main document. +### Minimal workset + +* vi/ +* beamercolorthemesjtubeamer.sty +* beamerfontthemesjtubeamer.sty +* beamerinnerthemesjtubeamer.sty +* beamerouterthemesjtubeamer.sty +* beamerthemesjtubeamer.sty +* sjtucover.sty +* sjtuvi.sty + + ## Repository manifest The following groups list the files included in the development repository of the package. Files listed with a ‘†’ marker are included in the TDS but not CTAN files, and files listed with ‘‡’ are included in both. -> **Minimal workset**: All files in **Derived files** and **Graphic resources**. -Or directly use files in **TeX files (TDS)**. - ### Source files These are source files for a number of purposes, including the `unpack` process which @@ -220,9 +234,10 @@ The following group lists the files included in the CTAN package. ## Online manifest -The following group lists the files included in the Online distribution. -You could upload the package to any online plateforms or use it as the -minimal workset on the local machine. +The following group lists the files included in the online distribution. +You could upload the package to any online plateforms. Compared with +**Minimal workset**, this distribution comes with all the plugins and +quick start guide as the main file. You could generate the package by going to the root directory and using the command `make build-online` in the terminal. diff --git a/src/build.lua b/src/build.lua index f7cc2bf6..e41e9120 100644 --- a/src/build.lua +++ b/src/build.lua @@ -291,15 +291,28 @@ end -- FIXME: subfolders could not be detected. Use plain text for temporary fix. manifest_setup = function () local groups = { + { + subheading = "Minimal manifest", + description = [[ +The following group lists all the necessary files that required by the runtime. +You could install these files to your TeX distribution or distribute them with +your main document.]] + }, + { + name = "Minimal workset", + description = "* vi/", + dir = tdsdir.."/tex/"..moduledir, + files = {"*.*"}, + exclude = {".",".."}, + flag = false, + skipfiledescription = true, + }, { subheading = "Repository manifest", description = [[ The following groups list the files included in the development repository of the package. Files listed with a ‘†’ marker are included in the TDS but not CTAN files, and files listed with ‘‡’ are included in both. - -> **Minimal workset**: All files in **Derived files** and **Graphic resources**. -Or directly use files in **TeX files (TDS)**. ]], }, { @@ -435,9 +448,10 @@ The following group lists the files included in the CTAN package. { subheading = "Online manifest", description = [[ -The following group lists the files included in the Online distribution. -You could upload the package to any online plateforms or use it as the -minimal workset on the local machine. +The following group lists the files included in the online distribution. +You could upload the package to any online plateforms. Compared with +**Minimal workset**, this distribution comes with all the plugins and +quick start guide as the main file. You could generate the package by going to the root directory and using the command `make build-online` in the terminal. ]], diff --git a/src/doc/sjtubeamerdevguide.tex b/src/doc/sjtubeamerdevguide.tex index ab98547d..d4ca64d0 100644 --- a/src/doc/sjtubeamerdevguide.tex +++ b/src/doc/sjtubeamerdevguide.tex @@ -228,7 +228,7 @@ \subsection{Build Overview} \begin{itemize} \item Unpacking Doc\TeX{} files. \item Generating documentation. - \item Caching and clean demos. + \item Caching and cleaning demos. \item Generating Visual Studio Code snippets (as is in \texttt{.vscode/sjtubeamer.code-snippets}) \item Generating \texttt{MANIFEST.md} to show the repository structure. @@ -241,7 +241,7 @@ \subsection{Build Overview} \item Compiling \verb"main.tex" for users. \item Building the cover collection. \item Formatting codes. - \item Build the online distribution \texttt{sjtubeamer-online.zip}. + \item Building the online distribution \texttt{sjtubeamer-online.zip}. \end{itemize} \subsection{l3build}\label{sec:l3build} @@ -258,12 +258,29 @@ \subsubsection{Built-In Commands}\label{sec:builtincmd} \fcmd{l3build install} This command will install current version from \verb"source" to your \TeX{} distribution. Remember to update the -\verb"l3build" to the latest version to avoid misbehaving. This -command requires an argument \verb"--texmfhome" option to specify the -install path, which could be obtained from Mik\TeX{} Console or the -\verb"tlmgr". Then, refresh the database of filenames in your TeX{} -distribution. This command is useful if you want this template to be globally -available for all documents on your computer. +\verb"l3build" to the latest version to avoid misbehaving. + +For MiK\TeX{} users, this command requires an argument +\begin{verbatim} + l3build install --texmfhome /path/to/install +\end{verbatim} +to specify the install path, which could be obtained from Mik\TeX{} Console +(Settings $\rightarrow$ Directories $\rightarrow$ TEXMF root directories +(Install)). It is often not necessary for \TeX{} Live and Mac\TeX{} users, +unless you want to install the files in a different place other than +\verb"TEXMFHOME" (the value could be obtained by +\verb"kpsewhich -var-value TEXMFHOME"). If you specify the package location by +\verb"--texmfhome", then you need to refresh the database of filenames in your +TeX{} distribution by \verb"texhash" or \verb"sudo texhash" to elevate the +privileges if it prompts ``directory not writable. Skipping...''. In fact, if +the filenames stay the same, you don't need to refresh the database (no need to +use the command \verb"texhash" after the first-time installation, basically). +You don't need to \verb"texhash" at all if you follow the default behavior of +installing the package into \verb"TEXMFHOME" (which will be detected +automatically without the database). + +This command is useful if you want this template to be globally available for +all documents on your computer. \fcmd{l3build unpack} This command will unpack the source code and create a sandbox environment in \verb"build/local". You can create your own test @@ -272,9 +289,9 @@ \subsubsection{Built-In Commands}\label{sec:builtincmd} \fcmd{l3build check} Process a regression test, with an optional parameter to perform one of the following tests: -\begin{center} - \ttfamily color font inner outer sjtuvi -\end{center} +\begin{verbatim} + color font inner outer sjtuvi +\end{verbatim} which will show if the module is standing-free. If the compilation error occurs, please check if your code uses one definition from another module without requiring it first, or an undefined control sequence occurs. @@ -282,16 +299,9 @@ \subsubsection{Built-In Commands}\label{sec:builtincmd} This command will also move the generated style files to the root directory. \fcmd{l3build doc} This command will generate the documentation of this -package. -% We set an overall testing file \verb"doc/min.tex" to test all features of \themename. -% \begin{center} -% unpack $\rightarrow$ \verb"min.tex" $\rightarrow$ documentations -% \end{center} -Since the doc has a lot of dependencies (or unit tests), you can cache the demo +package. Since the doc has a lot of dependencies (or unit tests), you can cache the demo files to \verb"support/tutorial" directory. This could be done by the exclusive \verb"l3build cache-demo" in Section \ref{sec:exclcmd}. -% Change the variable in \verb"build.lua": \verb"cachedemo=true" to cache the demo automatically, and remove the variable to clean the cached files. -% We highly recommend that using *nix to compile the doc. \fcmd{l3build save color} If you make some modification to the framework (except \verb"sjtucover") and change the result. To save the current @@ -431,6 +441,14 @@ \subsection{Continuous Integration}\label{sec:make} For those who are familiar with \verb"makefile" system, the following commands might be helpful to build the package under the root directory: +\fcmd{make install} This command will run \verb"l3build install", which installs +the unpacked files to \TeX{} Live and Mac\TeX{} \verb"TEXMFHOME" directory +according to \verb"l3build" documentation. +Unfortunately, it is likely to fail on MiK\TeX{} since the \verb"TEXMFHOME" is +usually empty. Hope that MiK\TeX{} users won't use this command or try to modify +the \verb"Makefile" to add some parameters mentioned in Section \ref{sec:l3build} +to meet your need. + \fcmd{make generate} This command will unpack the Doc\TeX{} files into style files and update the generated files in the root directory. @@ -1050,7 +1068,7 @@ \subsection{Beamer Interface}\label{sec:beamer} package \cite{beamerman}. You can acquire the doc by the terminal command: \begin{verbatim} - texdoc beame + texdoc beamer \end{verbatim} Then, you could choose to use some preset theme, or call the macro to control the appearance of each component.