LuaLaTeX: automatisez la compilation multiple avec pour ToC, Index, Bibliographie, Glossaire et autres sur CI

Aug 18 2020

Pour avoir des constructions reproductibles et fiables de documents sur un système CI distant, je voudrais automatiser tous les outils de ligne de commande et les multiples compilations nécessaires pour produire un document complet. Ce pipeline devrait fonctionner dans n'importe quel document prêt à l'emploi, quels que soient les plugins réellement utilisés dans le document.

Je crois comprendre qu'il existe un moyen pour une version LaTeX d'effectuer automatiquement toutes les étapes nécessaires, mais jusqu'à présent, je n'ai eu aucun succès avec aucune approche.

Détails

Ma configuration actuelle est la suivante:

  • Les documents sont écrits et compilés sur ma machine en utilisant LuaLaTeX et MiKTeX
  • Le CI se compose de l'image MiKTeX Docker ( voir ici ) avec toutes les polices et ressources personnalisées installées

Localement, je dois effectuer différentes actions en séquence pour compiler un document que je dois connaître en tant qu'auteur d'un document. Mais le CI devrait être capable de construire n'importe quel document sans appliquer de paramètres spéciaux par document et produire des erreurs lorsque le document ne peut pas être compilé correctement ou qu'il manque quelque chose.

Exemple: glossaire

Lorsque j'ai besoin de créer un document dans lequel j'utilise le glossariespackage, la version locale ressemblera à ceci

lualatex doc.tex
makeglossaries doc
lualatex doc.tex

Maintenant, le CI ne sait pas si le document nécessite cette étape ou non, mais devrait toujours être en mesure de créer le document. Dans la documentation des glossaires, il est fait mention du automakeparamètre et de l' --shell-escapeoption de compilation de documents qui, je suppose, me permettraient de tout compiler en même temps mais cela ne fonctionne pas sur le CI. De même, j'ai les mêmes problèmes avec la ToC, les index, la bibliographie, etc.

Sommaire

Existe-t-il un moyen commun d'automatiser la compilation complexe pour différents packages? (Soit intégré à LuaLaTeX, soit à certains scripts personnalisés à usage général)

Y a-t-il un problème avec ma configuration qui pourrait empêcher toutes les étapes de se dérouler automatiquement?

J'ai parcouru de nombreuses ressources pour des packages spécifiques ou LaTeX en général, mais je n'ai pas pu trouver quelque chose qui fonctionne. Votre aide est très appréciée.

Réponses

3 AlexPovel Oct 08 2020 at 19:01

Comme d'autres et vous-même l'ont mentionné, latexmksemble l'outil approprié pour ce travail. Pour voir comment cela peut être implémenté, permettez-moi de mettre en évidence les bits pertinents de mon propre pipeline de document / modèle LaTeX CI (sur GitLab). Cela devrait être un exemple utilisable pour une "compilation complexe pour différents paquets". J'irai aussi dans la configuration d' accompagnement Dockerfileet GitLab CI , en plus de la latexmkpartie / spécifique à LaTeX , car toutes les parties sont étroitement couplées.

Tout ce qui est détaillé ci-dessous peut être vu mis en œuvre et (espérons-le ...) fonctionner dans ce projet . J'essaie de garder cette réponse aussi autonome que possible. Le lien vers le projet contiendra le dernier état, qui remplacera éventuellement cette réponse.


Paquets LaTeX et distribution (Debian)

Dans le pipeline lié, il existe quelques packages nécessitant une attention particulière dans la configuration. Il est peu probable que vous ayez exactement les mêmes exigences, mais je les énumère ici par souci d'exhaustivité.

  1. glossaries-extra, en s'appuyant sur glossaries, nécessite bib2glsde convertir et de traiter des *.bibfichiers pour lualatextravailler avec.

    Cela se reflète dans la configuration en deux volets:

    1. L'image Docker nécessite un environnement Java Runtime pour bib2gls,
    2. latexmkdoit être informé de la présence de bib2glsfichiers.
  2. pgfplotsavec son contouroption de \addplot3( exemples ) nécessite le gnuplotprogramme externe . Encore une fois, cela se reflète deux fois:

    1. lualatex(ou le moteur de votre choix) nécessite un accès en écriture extérieur pour gnuplotécrire ses résultats de calcul dans des fichiers pour pgfplotslire: --shell-escapeest nécessaire, dont latexmkil faut le dire.
    2. gnuplot, car un paquet de distribution (par opposition à un paquet LaTeX) doit être présent, par exemple apt-get install gnuplotsur un hôte Debian.
  3. LaTeX ne peut pas intégrer de *.svgfichiers nativement . L'incorporation de ces fichiers nécessite d'abord la conversion au format PDF (ou à un autre format intégrable). Ceci peut être réalisé en utilisant Inkscape et sa *.pdf_texroutine . Cependant, cela nous laisse avec deux fichiers supplémentaires par fichier SVG: *.pdfet *.pdf_tex. À chaque modification du fichier SVG, les fichiers dérivés doivent être mis à jour. Cela conduit à des conflits potentiels, également dans le cadre du contrôle de version ( gitetc.): quelles versions conserver?

    Le svgpackage LaTeX résout ces problèmes en automatisant le processus de conversion. Les fichiers générés *.pdfet *.pdf_texpeuvent être traités comme des fichiers temporaires / dérivés et supprimés librement. Seuls les SVG restent, en tant que source unique de vérité . En prime, étant basés sur du texte (XML) , ils conviennent également aux VCS comme git(quels PDF binaires ne sont pas vraiment).

    Comme précédemment, cela se reflète dans la configuration ci-dessous à deux endroits:

    1. Pour appeler la CLI inkscape(par opposition à l'interface graphique; pour que cela fonctionne, inkscapedoit être sur votre $PATH) pour la lecture et l'écriture, le moteur LaTeX nécessite --shell-escape.
    2. inkscape doit être disponible dans l'environnement de construction (image Docker).
  4. En utilisant tcolorboxet sa \newtcolorboxcommande, j'ai créé un nouvel environnement pour les exemples :

    \newtcolorbox[%
      auto counter,%
      number within=chapter,%
      % Set cleveref, see https://tex.stackexchange.com/a/126023/120853:
      crefname={Example}{Examples},
      % List of Examples. *.loe file ending could clash with package thmtools,
      % careful if that is used!
      list inside=loe,
    ]{example}% Name of environment itself
        [2]% Number of arguments for the environment
        []% Default of optional argument, which is the first one. Use it for label
        {%
            beforeafter skip=18pt plus 4pt minus 4pt,%
            width=0.95\linewidth,%
            % Center box; see https://tex.stackexchange.com/a/273111/120853:
            enlarge left by=0.025\linewidth,
            title=Example\ \thetcbcounter: #2,%
            fonttitle=\sffamily,%
            leftrule=1mm,%
            arc is angular,%
            parbox,% Allows regular paragraph breaks
            breakable,% Breaks across pages
            enhanced,% Hands drawing to tikz
            rightrule=0mm,%
            bottomrule=0mm,%
            % Setting what ends up in 'list of' so that '<Title>' is not shown:
            list text=#2,
            #1,%
            colback=black!05,%
            colframe=black!70,%
            % float,
        }%
    

    Cela ressemble à:

    Ceci est pertinent car il s'intègre à l' komascriptutilisation de l' list inside=loeinstruction, ce qui nous permet de récupérer et d'imprimer une liste d'exemples , comme la liste standard des figures :

    % Declare a new list of contents, with the file suffix in brackets.
    % This will give access to \listof<name>s
    \DeclareNewTOC[%
        type=example,% This also creates types=example+s, that is by appending an s
        % Listname is "List of <Type>s" by default
        % listname={...},
    ]{loe}
    

    Enfin, latexmkdoit être informé de ce *.loefichier nouvellement créé . Ceci est important car latexmkfonctionne en examinant les fichiers auxiliaires pour les changements pour évaluer la progression et la fin de la compilation.

  5. Dans la même veine que le point précédent, l'utilisation du listingspackage nous permettra d'imprimer une liste de listes à partir du *.lolfichier généré . Comme avant, latexmkvoudra le savoir.

Enfin, cela aboutit au .latexmkrcfichier suivant :

# Contents of .latexmkrc

# PERL latexmk config file

# PDF-generating modes are:
# 1: pdflatex, as specified by $pdflatex variable (still largely in use)
# 2: postscript conversion, as specified by the $ps2pdf variable (useless) # 3: dvi conversion, as specified by the $dvipdf variable (useless)
# 4: lualatex, as specified by the $lualatex variable (best) # 5: xelatex, as specified by the $xelatex variable (second best)
$pdf_mode = 4; # --shell-escape option (execution of code outside of latex) is required for the #'svg' package. # It converts raw SVG files to the PDF+PDF_TEX combo using InkScape. $lualatex = "lualatex --shell-escape";

# option 2 is same as 1 (run biber when necessary), but also deletes the
# regeneratable bbl-file in a clenaup (`latexmk -c`). Do not use if original
# bib file is not available!
$bibtex_use = 2; # default: 1 # Let latexmk know about generated files, so they can be used to detect if a # rerun is required, or be deleted in a cleanup. # loe: List of Examples (KOMAScript) # lol: List of Listings (listings package) push @generated_exts, 'loe', 'lol'; # Also delete the *.glstex files from package glossaries-extra. Problem is, # that that package generates files of the form "basename-digit.glstex" if # multiple glossaries are present. Latexmk looks for "basename.glstex" and so # does not find those. For that purpose, use wildcard. # Also delete files generated by gnuplot/pgfplots contour plots # (.dat, .script, .table), # and XML file generated by biber runs. $clean_ext = "%R-*.glstex %R_contourtmp*.* %R.run.xml";

# Grabbed from latexmk CTAN distribution:
# Implementing glossary with bib2gls and glossaries-extra, with the
# log file (.glg) analyzed to get dependence on a .bib file.
# !!! ONLY WORKS WITH VERSION 4.54 or higher of latexmk

# Push new file endings into list holding those files
# that are kept and later used again (like idx, bbl, ...):
push @generated_exts, 'glstex', 'glg';

# Add custom dependency.
# latexmk checks whether a file with ending as given in the 2nd
# argument exists ('toextension'). If yes, check if file with
# ending as in first argument ('fromextension') exists. If yes,
# run subroutine as given in fourth argument.
# Third argument is whether file MUST exist. If 0, no action taken.
add_cus_dep('aux', 'glstex', 0, 'run_bib2gls');

# PERL subroutine. $_[0] is the argument (filename in this case). # File from author from here: https://tex.stackexchange.com/a/401979/120853 sub run_bib2gls { if ( $silent ) {
    #    my $ret = system "bib2gls --silent --group '$_[0]'"; # Original version
        my $ret = system "bib2gls --silent --group $_[0]"; # Runs in PowerShell
    } else {
    #    my $ret = system "bib2gls --group '$_[0]'"; # Original version
        my $ret = system "bib2gls --group $_[0]"; # Runs in PowerShell
    };

    my ($base, $path) = fileparse( $_[0] ); if ($path && -e "$base.glstex") { rename "$base.glstex", "$path$base.glstex";
    }

    # Analyze log file.
    local *LOG;
    $LOG = "$_[0].glg";
    if (!$ret && -e $LOG) {
        open LOG, "<$LOG"; while (<LOG>) { if (/^Reading (.*\.bib)\s$/) {
        rdb_ensure_file( $rule, $1 );
        }
    }
    close LOG;
    }
    return $ret;
}

latexmkrécupérera ce fichier et en tirera automatiquement les configurations, s'il est nommé .latexmkrc. Ainsi, la nécessité de spécifier l'emplacement de ce fichier disparaît explicitement s'il est présent dans pwd.

Environnement de construction (image Docker)

L'image Docker requise est plus facilement obtenue en utilisant une debianimage de base et en installant texlive-full(et tous les packages requis mentionnés ci-dessus, ou tout ce dont vous avez besoin). Cela peut être aussi simple que ce qui suit Dockerfile:

FROM debian:testing

RUN apt-get update --yes \
    && apt-get install --yes --no-install-recommends \
        texlive-full

Pour mes propres besoins, j'ai préparé un Dockerfile beaucoup plus complexe (commentaires supprimés en raison de la limite de caractères):

ARG BASE_OS
ARG OS_VERSION

FROM ${BASE_OS}:${OS_VERSION} as BASE RUN apt-get update && \ apt-get install --yes --no-install-recommends \ wget \ ca-certificates \ perl FROM BASE as PREPARE ARG TL_VERSION ARG TL_INSTALL_ARCHIVE="install-tl-unx.tar.gz" ARG EISVOGEL_ARCHIVE="Eisvogel.tar.gz" ARG INSTALL_TL_DIR="install-tl" COPY texlive.sh . RUN \ ./texlive.sh get ${TL_VERSION} && \
    wget https://github.com/Wandmalfarbe/pandoc-latex-template/releases/latest/download/${EISVOGEL_ARCHIVE} RUN \ mkdir ${INSTALL_TL_DIR} && \
    tar --extract --file=${TL_INSTALL_ARCHIVE} --directory=${INSTALL_TL_DIR} --strip-components 1 && \
    \
    tar --extract --file=${EISVOGEL_ARCHIVE} FROM BASE as MAIN ARG BUILD_DATE="n/a" ARG VCS_REF="n/a" ARG TL_VERSION ARG TL_PROFILE="texlive.profile" LABEL \ maintainer="Alex Povel <[email protected]>" \ org.label-schema.build-date=${BUILD_DATE} \
    org.label-schema.description="TeXLive with most packages, JavaRE, Inkscape, pandoc and more" \
    org.label-schema.url="https://collaborating.tuhh.de/alex/latex-git-cookbook" \
    org.label-schema.vcs-url="https://github.com/alexpovel/latex-extras-docker" \
    org.label-schema.vcs-ref=${VCS_REF} \ org.label-schema.schema-version="1.0" ARG INSTALL_DIR="/install/" WORKDIR ${INSTALL_DIR}

COPY ${TL_PROFILE} . COPY --from=PREPARE /install-tl/ /texlive.sh ./ COPY --from=PREPARE /eisvogel.tex /usr/share/pandoc/data/templates/eisvogel.latex ARG TEXLIVE_INSTALL_PREFIX="/usr/local/texlive" ARG TEXLIVE_INSTALL_TEXDIR="${TEXLIVE_INSTALL_PREFIX}/${TL_VERSION}" ARG TEXLIVE_INSTALL_TEXMFCONFIG="~/.texlive${TL_VERSION}/texmf-config"
ARG TEXLIVE_INSTALL_TEXMFVAR="~/.texlive${TL_VERSION}/texmf-var" ARG TEXLIVE_INSTALL_TEXMFHOME="~/texmf" ARG TEXLIVE_INSTALL_TEXMFLOCAL="${TEXLIVE_INSTALL_PREFIX}/texmf-local"
ARG TEXLIVE_INSTALL_TEXMFSYSCONFIG="${TEXLIVE_INSTALL_TEXDIR}/texmf-config" ARG TEXLIVE_INSTALL_TEXMFSYSVAR="${TEXLIVE_INSTALL_TEXDIR}/texmf-var"

RUN ./texlive.sh install ${TL_VERSION} RUN luaotfload-tool --update || echo "luaotfload-tool not found, skipping." RUN apt-get update && \ apt-get install --yes --no-install-recommends \ default-jre-headless \ inkscape \ gnuplot-nox \ ghostscript RUN apt-get update && \ apt-get install --yes --no-install-recommends \ librsvg2-bin \ pandoc WORKDIR /tex/ RUN rm --recursive ${INSTALL_DIR}

CMD [ "--lualatex" ]

ENTRYPOINT [ "latexmk" ]

Il permet à l'utilisateur de spécifier les versions de TeXLive (tirées de leurs archives) et Debian à construire. Pour cela, il nécessite le texlive.shscript suivant . Il choisit entre la latestbalise (Docker) et une version historique (par exemple Debian 9, TeXLive 2018), auquel cas il télécharge à partir des archives TUG :

#!/bin/bash

# Script to fetch `install-tl` script from different sources, depending on argument
# given.

# Error out of any of the variables used here are unbound, e.g. no CLI arg given.
set -u

usage() {
    echo "Usage: $0 get|install latest|version (YYYY)" } if [[ $# != 2 ]]; then
    echoerr "Unsuitable number of arguments given."
    usage
    # From /usr/include/sysexits.h
    exit 64
fi

# From: https://stackoverflow.com/a/2990533/11477374
echoerr() { echo "$@" 1>&2; } # Bind CLI arguments to explicit names: ACTION=${1}
VERSION=${2} # Download the `install-tl` script from the `tlnet-final` subdirectory, NOT # from the parent directory. The latter contains an outdated, non-final `install-tl` # script, causing this exact problem: # https://tug.org/pipermail/tex-live/2017-June/040376.html HISTORIC_URL="ftp://tug.org/historic/systems/texlive/${VERSION}/tlnet-final"
REGULAR_URL="http://mirror.ctan.org/systems/texlive/tlnet"

case ${ACTION} in "get") if [[ ${VERSION} == "latest" ]]
        then
            # Get from default, current repository
            wget ${REGULAR_URL}/${TL_INSTALL_ARCHIVE}
        else
            # Get from historic repository
            wget ${HISTORIC_URL}/${TL_INSTALL_ARCHIVE}
        fi
    ;;
    "install")
        if [[ ${VERSION} == "latest" ]] then # Install using default, current repository perl install-tl \ --profile=${TL_PROFILE}
        else
            # Install using historic repository (`install-tl` script and repository
            # versions need to match)
            perl install-tl \
                --profile=${TL_PROFILE} \ --repository=${HISTORIC_URL}
        fi

        # For `command` usage, see:
        # https://www.gnu.org/software/bash/manual/html_node/Bash-Builtins.html#Bash-Builtins.
        # The following test assumes the most basic program, `tex`, is present.
        if command -v tex &> /dev/null
        then
            # If automatic `install-tl` process has already adjusted PATH, we are happy.
            echo "PATH and installation seem OK."
        else
            # Try and make installation available on path manually.
            #
            # The first wildcard expands to the architecture (should be 'x86_64-linux',
            # which might change in TeXLive upstream, so do not hardcode here),
            # the second one expands to all binaries found in that directory.
            # Only link if directory exists, else we end up with a junk symlink.
            EXPECTED_INSTALL_TEXDIR=${TEXLIVE_INSTALL_TEXDIR}/bin/* # `ls` found to be more robust than `[ -d ... ]`. if ls ${EXPECTED_INSTALL_TEXDIR} 1>/dev/null 2>&1
            then
                SYMLINK_DESTINATION="/usr/local/bin"

                # "String contains", see: https://stackoverflow.com/a/229606/11477374
                if [[ ! ${PATH} == *${SYMLINK_DESTINATION}* ]]
                then
                    # Should never get here, but make sure.
                    echoerr "Symlink destination ${SYMLINK_DESTINATION} not in PATH (${PATH}), exiting."
                    exit 1
                fi

                echo "Symlinking TeXLive binaries in ${EXPECTED_INSTALL_TEXDIR}" echo "to a directory (${SYMLINK_DESTINATION}) found on PATH (${PATH})" # Notice the wildcard: ln --symbolic --verbose ${EXPECTED_INSTALL_TEXDIR}/* ${SYMLINK_DESTINATION}

                if command -v tex &> /dev/null
                then
                    echo "PATH and installation seem OK."
                else
                    echoerr "Manual symlinking failed and TeXLive did not modify PATH automatically."
                    echoerr "Exiting."
                    exit 1
                fi
            else
                echoerr "Expected TeXLive installation dir not found and TeXLive installation did not modify PATH automatically."
                echoerr "Exiting."
                exit 1
            fi
        fi
    ;;
    *)
        echoerr "Input not understood."
        usage
        # From /usr/include/sysexits.h
        exit 64
esac

De plus, l'installation de TeXLive se fait manuellement à l'aide de leur install-tlscript. Pour une installation sans assistance, il nécessite un fichier de profil , comme celui-ci texlive.profile(commentaires supprimés en raison de la limite de caractères):

selected_scheme scheme-custom

collection-basic 1
collection-bibtexextra 1
collection-binextra 1
collection-fontsextra 1
collection-fontsrecommended 1
collection-fontutils 1
collection-formatsextra 1
collection-langenglish 1
collection-langeuropean 1
collection-langgerman 1
collection-latex 1
collection-latexextra 1
collection-latexrecommended 1
collection-luatex 1
collection-mathscience 1
collection-pictures 1
collection-plaingeneric 1
collection-publishers 1
collection-xetex 1

collection-context 0
collection-games 0
collection-humanities 0
collection-langarabic 0
collection-langchinese 0
collection-langcjk 0
collection-langcyrillic 0
collection-langczechslovak 0
collection-langfrench 0
collection-langgreek 0
collection-langitalian 0
collection-langjapanese 0
collection-langkorean 0
collection-langother 0
collection-langpolish 0
collection-langportuguese 0
collection-langspanish 0
collection-metapost 0
collection-music 0
collection-pstricks 0
collection-texworks 0
collection-wintools 0

instopt_adjustpath 1
instopt_adjustrepo 0
instopt_letter 0
instopt_portable 0
instopt_write18_restricted 1
tlpdbopt_autobackup 0
tlpdbopt_backupdir tlpkg/backups
tlpdbopt_create_formats 1
tlpdbopt_desktop_integration 0
tlpdbopt_file_assocs 0
tlpdbopt_generate_updmap 0
tlpdbopt_install_docfiles 0
tlpdbopt_install_srcfiles 0
tlpdbopt_post_code 1

Si vous voulez, ce fichier est au cœur du processus de création d'image. Il spécifie les packages LaTeX à télécharger et à installer. Vous pouvez modifier, et probablement plus important encore, votre build ici. Par exemple, l'installation / le téléchargement de fichiers de documentation est explicitement omis ici, ce qui n'est pas possible lors de l'exécution simple, ce qui permet d' apt-get install texlive-fulléconomiser plusieurs Go d'espace.

Notez que ces images sont déjà construites et disponibles (de manière intégrée en continu: chaque git pushsur le dépôt source déclenchera une compilation) sur DockerHub . Leur utilisation donnera la même image que la construction vous-même, sans forcer les serveurs d'archives TUG . Ces images sont construites automatiquement en utilisant le hook de construction de DockerHub , où la page des paramètres ressemble un peu (voir aussi ici ):

Configuration CI

Ceci est spécifique à GitLab. Je n'ai pas encore implémenté cela pour GitHub / Travis.

Dans un référentiel donné avec un ou plusieurs *.texfichiers à la racine ainsi qu'un README.md, la configuration CI YAML ci-dessous (sans commentaires en raison de la limite de caractères):

  1. Tirez l'image du référentiel DockerHub ci-dessus, en remplaçant toute ENTRYPOINTinstruction par rien (c'est-à-dire un shell normal). Ceci est important pour que la scriptpièce fonctionne, alors que an ENTRYPOINTest pratique pour exécuter le conteneur sur votre bureau.
  2. Remplacez le fichier de classe n.a.in \newcommand*{\GitVersion}{n.a.}et \newcommand*{\GitShortHash}{n.a.}from *.clsLaTeX (à la racine du projet) par les valeurs actuelles et actuelles de cette construction. Cela permet aux métadonnées du VCS d'être imprimées dans le PDF.
  3. Construisez le LaTeX en PDF par simple émission latexmk. Il tirera ses instructions de .latexmkrc, voir ci-dessus.
  4. Compilez un PDF à partir de README.md, en utilisant pandoc, qui utilise à nouveau lualatexpour la conversion. Ceci utilise un modèle pour une sortie plus jolie. Cette étape est plus un gadget / une vitrine pour pandoc.

Les PDF résultants sont des artefacts du pipeline CI et peuvent être téléchargés après une exécution réussie.

default:
    image:
        name: alexpovel/latex
        entrypoint: [ "" ]
    retry:
        max: 1
        when: runner_system_failure
    artifacts:
        name: "$CI_COMMIT_REF_NAME"
        paths:
            - "*.pdf"
stages:
    - prepare
    - build

insert_git_metadata:
    stage: prepare
    script:
        - |
            declare -A GITINFO=(
                [GitVersion]=$CI_COMMIT_REF_NAME [GitShortHash]=$CI_COMMIT_SHORT_SHA
            )
        - |
            for k in "${!GITINFO[@]}" do sed -i "s~\(newcommand\*{\\\\$k}\){.*}~\1{${GITINFO[$k]}}~" *.cls
                done
    artifacts:
        paths:
            - "*.cls"
    needs: []

build_latex:
    stage: build
    script:
        - latexmk
    dependencies:
        - insert_git_metadata

build_pandoc:
    stage: build
    script:
        - 'sed -i "s~\(^date: \)\".*\"~\1\"$(date +"%B %-d, %Y")\"~" README.md'
        - |
            pandoc README.md \
            --template eisvogel --pdf-engine=lualatex --number-sections \
            -o README.pdf
    needs: []
tfran Aug 18 2020 at 01:38

Désolé, je ne sais pas ce que signifie CI, mais si vous avez GNU make sur votre machine, vous pouvez écrire un petit makefile comme celui-ci:

FILE=yourfilename


.PHONY: clean cleanall

all:$(FILE).pdf clean: -rm *.aux *.blg *.out *.bbl *.lot *.lof *.glo *.ist *.acn *.acr *.alg *.glg *.gls *.toc *.bcf *.run.xml cleanall: -rm *.aux *.blg *.out *.bbl *.log *.lot *.lof *.glo *.ist *.acn *.acr *.alg *.glg *.gls *.toc *.bcf *.run.xml #report#.pdf $(FILE).pdf: *.tex
    E:\miktex-portable\texmfs\install\miktex\bin\x64\lualatex.exe $(FILE) E:\miktex-portable\texmfs\install\miktex\bin\x64\biber.exe $(FILE)
    E:\miktex-portable\texmfs\install\miktex\bin\x64\makeglossaries.exe $(FILE) E:\miktex-portable\texmfs\install\miktex\bin\x64\lualatex.exe $(FILE)
    E:\miktex-portable\texmfs\install\miktex\bin\x64\lualatex.exe $(FILE)

L'exemple est fait pour Windows comme OS. Au lieu de E: \ miktex-portable ... \ adaptez le chemin qui correspond à votre installation. Si vous avez GNU / Linux, vous pouvez définir $ PATH de telle sorte que vous n'ayez pas besoin de spécifier le chemin complet des exécutables (c'est-à-dire simplement dire «lualatex $ (FILE)» etc.). Il est entendu que la liste de références est créée à l'aide de biber et biblatex. Le makefile (même nom de fichier) doit être placé dans le même répertoire où se trouvent vos fichiers * .tex. Ensuite, il vous suffit de saisir «make» dans le terminal de ligne de commande. De même, «make clean» et «make cleanall» peuvent vous aider à ranger votre répertoire.

ymindstorm Aug 26 2020 at 18:55

Ce que j'ai fini par faire, c'est de m'inscrire latexmkau CI et d'appliquer des règles supplémentaires latexmkpour aider avec le glossariespackage.

La build automatisée effectue les opérations suivantes après avoir configuré l'environnement de build et l'image docker miktex:

mpm --install=latexmk

Lors de la construction du document, la commande suivante est utilisée:

latexmk -r "<path-to-rc-file>/.latexmkrc" -lualatex -latexoption="-interaction=nonstopmode"

Le .latexmkrcfichier est dans un sous-module Git partagé entre tous nos référentiels de documents où nous avons également nos classes de documents partagées, etc.

Voici le contenu de .latexmkrc

# This shows how to use lualatex (http://en.wikipedia.org/wiki/LuaTeX)
# with latexmk.  
#
#   WARNING: The method shown here is suitable only for ver. 4.51 and
#            later of latexmk, not for earlier versions.
#

$pdf_mode = 4; $postscript_mode = $dvi_mode = 0; # This shows how to use the glossaries package # (http://www.ctan.org/pkg/glossaries) and the glossaries-extra package # (http://www.ctan.org/pkg/glossaries-extra) with latexmk. add_cus_dep( 'acn', 'acr', 0, 'makeglossaries' ); add_cus_dep( 'glo', 'gls', 0, 'makeglossaries' ); $clean_ext .= " acr acn alg glo gls glg";
sub makeglossaries {
   my ($base_name, $path) = fileparse( $_[0] ); pushd $path;
   my $return = system "makeglossaries", $base_name;
   popd;
   return $return;
}

pris d' ici .

Le résultat final garantit une expérience de construction cohérente quel que soit le document et son contenu. Cette approche est également flexible et extensible, ce qui peut permettre d'utiliser exactement la même chaîne d'outils à partir d'un conteneur Docker local lors de l'écriture.