LuaLaTeX: TOC, Index, Bibliography, Glossary और दूसरों के लिए एकाधिक संकलन को CI पर स्वचालित करें

Aug 18 2020

दूरस्थ CI सिस्टम पर दस्तावेज़ों का प्रतिलिपि प्रस्तुत करने योग्य और विश्वसनीय निर्माण करने के लिए, मैं एक संपूर्ण दस्तावेज़ बनाने के लिए आवश्यक सभी कमांड लाइन टूल्स और कई संकलनों को स्वचालित करना चाहूंगा। इस पाइपलाइन को बॉक्स से बाहर किसी भी दस्तावेज़ को काम करना चाहिए, भले ही दस्तावेज़ में प्लगइन्स का वास्तव में उपयोग किया जाए।

यह मेरी समझ है कि लाटेक्स बिल्ड के लिए सभी आवश्यक कदमों को स्वचालित रूप से करने का एक तरीका है, लेकिन अभी तक मुझे किसी भी दृष्टिकोण के साथ कोई सफलता नहीं मिली।

विवरण

मेरा वर्तमान सेटअप यह है:

  • दस्तावेज़ LuaLaTeX और MiKTeX का उपयोग करके मेरी मशीन पर लिखे और संकलित किए गए हैं
  • CI में MiKTeX Docker छवि ( यहां देखें ) शामिल है जिसमें सभी कस्टम फोंट और संसाधन इंस्टॉल किए गए हैं

स्थानीय रूप से मुझे एक दस्तावेज संकलित करने के लिए विभिन्न क्रियाओं को करना पड़ता है जिसे मुझे एक दस्तावेज के लेखक के रूप में जानना होता है। लेकिन CI को प्रति दस्तावेज़ सेटिंग्स को लागू किए बिना किसी भी दस्तावेज़ का निर्माण करने और त्रुटियों का उत्पादन करने में सक्षम होना चाहिए जब डॉक्टर सही तरीके से संकलन नहीं कर सकते हैं या कुछ गायब है।

उदाहरण: शब्दावली

जब मुझे एक दस्तावेज बनाने की आवश्यकता होती है जहां मैं glossariesपैकेज का उपयोग करता हूं तो स्थानीय बिल्ड इस तरह दिखाई देगा

lualatex doc.tex
makeglossaries doc
lualatex doc.tex

अब सीआई को यह नहीं पता है कि डॉक्टर को इस कदम की आवश्यकता है या नहीं, लेकिन अभी भी दस्तावेज़ बनाने में सक्षम होना चाहिए। शब्दावलियों के दस्तावेज़ीकरण में automakeपरम का उल्लेख है और --shell-escapeदस्तावेजों को संकलित करने का विकल्प है जो मुझे लगता है कि मुझे एक ही बार में सब कुछ संकलित करने की अनुमति देगा लेकिन यह सीआई पर काम नहीं करता है। इसी तरह मुझे टीओसी, सूचकांकों, ग्रंथ सूची आदि के साथ भी यही समस्या है।

सारांश

क्या विभिन्न पैकेजों के लिए जटिल संकलन को स्वचालित करने का एक सामान्य तरीका है? (या तो LuaLaTeX या कुछ सामान्य सामान्य प्रयोजन लिपियों के लिए बनाया गया)

क्या मेरे सेटअप में कोई समस्या है जो सभी चरणों को स्वचालित रूप से होने से रोक सकती है?

मैंने विशिष्ट पैकेजों या लाटेक्स के लिए बहुत सारे संसाधनों के माध्यम से काम किया है, लेकिन कुछ ऐसा नहीं कर पाया जो काम करता हो। आपकी मदद की बहुत सराहना की है।

जवाब

3 AlexPovel Oct 08 2020 at 19:01

जैसा कि अन्य और स्वयं ने उल्लेख किया है, latexmkइस नौकरी के लिए सही उपकरण लगता है। यह देखने के लिए कि इसे कैसे लागू किया जा सकता है, मुझे अपने स्वयं के LaTeX दस्तावेज़ / टेम्पलेट CI पाइपलाइन (GITLL पर) से प्रासंगिक बिट्स को उजागर करने दें। यह "विभिन्न संकुल के लिए जटिल संकलन" के लिए एक प्रयोग करने योग्य उदाहरण होना चाहिए। मैं LaTeX-specific / part के अलावा GitLab CI कॉन्फिगरेशन के साथ Dockerfile- साथ जाऊंगाlatexmk , क्योंकि सभी भाग कसकर युग्मित हैं।

इस परियोजना में काम करने के लिए नीचे दी गई हर चीज को लागू किया जा सकता है और (उम्मीद है ...) । मैं इस उत्तर को यथासंभव आत्म-निहित रखने की कोशिश कर रहा हूं। परियोजना के लिंक में नवीनतम स्थिति शामिल होगी, जो अंततः इस उत्तर को छोड़ देगी।


LaTeX और वितरण (डेबियन) पैकेज

लिंक किए गए पाइपलाइन में, एक युगल पैकेज हैं जो सेटअप में विशेष ध्यान देने की आवश्यकता है। यह संभावना नहीं है कि आपके पास समान आवश्यकताएं होंगी, लेकिन मैं उन्हें पूर्णता के लिए यहां सूचीबद्ध कर रहा हूं।

  1. glossaries-extra, के शीर्ष पर glossaries, के साथ काम करने के लिए फ़ाइलों bib2glsको परिवर्तित करने और संसाधित करने की आवश्यकता होती है ।*.biblualatex

    यह सेटअप दो गुना में परिलक्षित होता है:

    1. डॉकर छवि के लिए एक जावा रनटाइम पर्यावरण की आवश्यकता है bib2gls,
    2. latexmkbib2glsफ़ाइलों की उपस्थिति के बारे में बताया जाना चाहिए ।
  2. pgfplotsइसके ( उदाहरण के ) contourविकल्प के साथ बाहरी कार्यक्रम की आवश्यकता होती है । फिर, यह दो गुना परिलक्षित होता है:\addplot3gnuplot

    1. lualatex(या अपनी पसंद के इंजन) को पढ़ने के gnuplotलिए फ़ाइलों के लिए अपने अभिकलन परिणाम लिखने के लिए बाहर लिखने की आवश्यकता होती है pgfplots: --shell-escapeकी आवश्यकता होती है, जिसमें latexmkसे बताया जाना चाहिए।
    2. gnuplot, एक वितरण पैकेज के रूप में (एक लाटेक्स पैकेज के विपरीत) को apt-get install gnuplotडेबियन होस्ट पर मौजूद होना चाहिए ।
  3. LaTeX मूल रूप से *.svgफ़ाइलों को एम्बेड नहीं कर सकता है । ऐसी फ़ाइलों को एम्बेड करने के लिए पहले पीडीएफ (या कुछ अन्य एम्बेड करने योग्य प्रारूप) में रूपांतरण की आवश्यकता होती है। यह इंकस्केप और इसकी *.pdf_texदिनचर्या का उपयोग करके प्राप्त किया जा सकता है । हालांकि, यह हमें एसवीजी फ़ाइल प्रति दो अतिरिक्त फ़ाइलों के साथ छोड़ देता है: *.pdfऔर *.pdf_tex। एसवीजी फ़ाइल में हर परिवर्तन पर, व्युत्पन्न फ़ाइलों को अद्यतन करना होगा। यह संभावित संघर्षों की ओर जाता है, संस्करण नियंत्रण ( gitआदि) के संदर्भ में भी : कौन से संस्करण रखे जाने हैं?

    svgLaTeX पैकेज रूपांतरण प्रक्रिया को स्वचालित करके इन समस्याओं को हल करती है। उत्पन्न *.pdfऔर *.pdf_texफ़ाइलों को अस्थायी / व्युत्पन्न फ़ाइलों के रूप में माना जा सकता है और स्वतंत्र रूप से त्याग दिया जा सकता है। सत्य के एकल स्रोत के रूप में केवल एसवीजी ही रहते हैं । एक बोनस के रूप में, पाठ-आधारित (एक्सएमएल) होने के नाते , वे वीसीएस जैसे git(जो बाइनरी पीडीएफ वास्तव में नहीं हैं) के लिए भी उपयुक्त हैं।

    पहले की तरह, यह दो स्थानों पर नीचे दिए गए सेटअप में परिलक्षित होता है:

    1. पढ़ने के लिए और लिखने के लिए CLI inkscape(GUI के विपरीत, काम करने के लिए, आपके inkscapeपास होना चाहिए $PATH) को कॉल करने के लिए, LaTeX इंजन की आवश्यकता होती है --shell-escape
    2. inkscape बिल्ड वातावरण (डॉकर छवि) में उपलब्ध होने की आवश्यकता है।
  4. tcolorboxइसका उपयोग और इसकी \newtcolorboxकमान, मैंने उदाहरणों के लिए एक नया वातावरण बनाया :

    \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,
        }%
    

    ऐसा दिखता है:

    यह प्रासंगिक है क्योंकि यह निर्देश komascriptका उपयोग करने के साथ एकीकृत करता है list inside=loe, हमें उदाहरणों की मानक सूची की तरह, उदाहरणों की सूची लाने और मुद्रित करने की अनुमति देता है :

    % 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}
    

    अंत में, latexmkइस नई बनाई गई *.loeफ़ाइल के बारे में बताया जाना चाहिए । यह महत्वपूर्ण है क्योंकि latexmkगेज संकलन प्रगति और खत्म करने के लिए परिवर्तन के लिए सहायक फ़ाइलों की जांच करके काम करता है।

  5. पिछले बिंदु के समान एक नस में, listingsपैकेज का उपयोग करके हम उत्पन्न फ़ाइल से लिस्टिंग की सूची प्रिंट कर सकेंगे *.lol। पहले की तरह, latexmkइसके बारे में जानना चाहेगा।

अंत में, यह निम्नलिखित .latexmkrcफ़ाइल में समाप्त होता है :

# 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;
}

latexmkयदि यह नाम है , तो इस फ़ाइल को उठाएँगे और इसमें से विन्यास स्वतः निकालेंगे .latexmkrc। तो यह निर्दिष्ट करने की आवश्यकता है कि फ़ाइल का स्थान स्पष्ट रूप से गायब हो जाता है यदि यह मौजूद है pwd

बिल्ड एनवायरनमेंट (डॉकर छवि)

आवश्यक डॉकर छवि सबसे आसानी से एक debianआधार छवि और स्थापित करने का उपयोग करके प्राप्त की जाती है texlive-full(और ऊपर उल्लिखित कोई भी आवश्यक पैकेज, या जो भी आपको चाहिए)। यह निम्नलिखित के रूप में सरल हो सकता है Dockerfile:

FROM debian:testing

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

अपनी जरूरतों के लिए, मैंने एक बहुत अधिक डॉकफेराइल तैयार किया (वर्ण सीमा के कारण हटाए गए टिप्पणियां):

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" ]

यह उपयोगकर्ता को यह निर्दिष्ट करने की अनुमति देता है कि कौन सा TeXLive (उनके अभिलेखागार से ड्राइंग) और निर्माण के लिए डेबियन संस्करण। इसके लिए उसे निम्नलिखित texlive.shलिपि की आवश्यकता होती है । यह latest(डॉकर) टैग और कुछ ऐतिहासिक संस्करण (जैसे डेबियन 9, TeXLive 2018) के बीच चुनता है , जिस स्थिति में यह 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

इसके अलावा, TeXLive इंस्टॉलेशन मैन्युअल रूप से उनकी install-tlस्क्रिप्ट का उपयोग करके किया जाता है । एक अनअटेंडेड इंस्टॉल के लिए, इसे एक प्रोफाइल फाइल की आवश्यकता होती है , इस तरह texlive.profile(वर्ण सीमा के कारण हटाए गए टिप्पणियां):

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

यदि आप करेंगे, तो यह फ़ाइल छवि निर्माण प्रक्रिया का मूल है। यह निर्दिष्ट करता है कि कौन से LaTeX पैकेज डाउनलोड और इंस्टॉल करें। आप संशोधित कर सकते हैं, और शायद सबसे महत्वपूर्ण रूप से पतला, आपका निर्माण यहां। उदाहरण के लिए, दस्तावेज़ीकरण फ़ाइलों को स्थापित / डाउनलोड करना यहां स्पष्ट रूप से छोड़ा गया है, कुछ ऐसा जो केवल चलने पर संभव नहीं है apt-get install texlive-full, जिससे कई जीबी अंतरिक्ष की बचत होती है।

ध्यान दें कि ये छवियां पहले से ही निर्मित और उपलब्ध हैं (लगातार एकीकृत तरीके से: git pushस्रोत रेपो पर प्रत्येक एक बिल्ड ट्रिगर करेगा) डॉकहॉब पर । टग आर्काइव सर्वर को स्ट्रेच किए बिना , इसका उपयोग करने से यह स्वयं के निर्माण के रूप में उसी छवि को शुद्ध करेगा । ये चित्र स्वचालित रूप से DockerHub के बिल्ड हुक को नियोजित करते हैं , जहाँ सेटिंग्स पृष्ठ कुछ इस तरह दिखता है ( यहाँ भी देखें ):

CI कॉन्फ़िगरेशन

यह GitLab के लिए विशिष्ट है। मैंने इसे GitHub / Travis के लिए अभी तक लागू नहीं किया है।

*.texरूट पर एक या एक से अधिक फाइलों के साथ दिए गए रिपॉजिटरी में, साथ ही README.mdनीचे दिए गए CI YAML कॉन्फिगरेशन (वर्ण सीमा के कारण टिप्पणी के बिना) होगा:

  1. ऊपर DockerHub रिपॉजिटरी से छवि को खींचो, किसी भी ENTRYPOINTनिर्देश को कुछ नहीं (उर्फ एक सामान्य शेल) के साथ बदल दें। यह scriptकाम करने के लिए महत्वपूर्ण है , जबकि ENTRYPOINTआपके डेस्कटॉप पर कंटेनर चलाने के लिए सुविधाजनक है।
  2. बदलें n.a.में \newcommand*{\GitVersion}{n.a.}और \newcommand*{\GitShortHash}{n.a.}से *.clsLaTeX वर्ग फ़ाइल (परियोजना जड़ में) है कि निर्माण की वास्तविक, वर्तमान मूल्यों के साथ। यह वीसीएस मेटाडेटा को पीडीएफ में मुद्रित करने की अनुमति देता है।
  3. केवल जारी करके PDF में LaTeX बनाएँ latexmk। यह .latexmkrcऊपर से अपने निर्देशों को आकर्षित करेगा , ऊपर देखें।
  4. से एक पीडीएफ संकलित करें README.md, का उपयोग करते हुए pandoc, जो फिर से उपयोग करता है lualatexरूपांतरण के लिए। यह prettier आउटपुट के लिए एक टेम्पलेट का उपयोग कर रहा है। यह कदम एक नौटंकी / प्रदर्शन के लिए अधिक है pandoc

परिणामी PDF CI पाइपलाइन की कलाकृतियां हैं और एक सफल रन के बाद डाउनलोड की जा सकती हैं।

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

क्षमा करें, मुझे नहीं पता कि सीआई किस लिए खड़ा है, लेकिन यदि आपके पास अपनी मशीन पर जीएनयू है, तो आप इस तरह से एक छोटा सा मेकफाइ लिख सकते हैं:

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)

उदाहरण विंडोज के लिए ओएस के रूप में बनाया गया है। E: \ miktex-पोर्टेबल ... के बजाय उस पथ को अनुकूलित करें जो आपकी स्थापना के लिए उपयुक्त हो। यदि आपके पास GNU / Linux है तो आप $ PATH को सेट कर सकते हैं जैसे कि आपको निष्पादनयोग्य के लिए पूर्ण पथ निर्दिष्ट करने की आवश्यकता नहीं है (जैसे कि 'lualatex $ (FILE)' आदि)। यह समझा जाता है कि बीबर और भाईचारे का उपयोग करके संदर्भ सूची बनाई जा रही है। Makefile (समान फ़ाइल नाम) को उसी निर्देशिका में रखा जाना चाहिए जहाँ आपकी * .ex फ़ाइलें स्थित हैं। फिर, आपको बस कमांड लाइन टर्मिनल में 'मेक' दर्ज करना होगा। इसी तरह can मेक क्लीन ’और clean मेक क्लीनॉल’ आपकी निर्देशिका को सुव्यवस्थित करने में आपकी मदद कर सकते हैं।

ymindstorm Aug 26 2020 at 18:55

मैंने latexmkजो कुछ किया वह सीआई के लिए लागू है और पैकेज के latexmkसाथ मदद करने के लिए अतिरिक्त नियम लागू कर रहा है glossaries

बिल्ड वातावरण और मिकटेक्स docker छवि को सेट करने के बाद स्वचालित बिल्ड निम्न करता है:

mpm --install=latexmk

दस्तावेज़ का निर्माण करते समय, निम्न कमांड का उपयोग किया जाता है:

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

.latexmkrcफ़ाइल एक Git submodule हमारे दस्तावेज़ खजाने के सभी के बीच साझा किया है जहां हम भी हमारे साझा दस्तावेज़ कक्षाएं आदि

यहाँ की सामग्री हैं .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;
}

यहां से ले जाया गया ।

अंतिम परिणाम दस्तावेज़ और इसकी सामग्री की परवाह किए बिना एक सुसंगत बिल्ड अनुभव सुनिश्चित करता है। यह दृष्टिकोण लचीला और एक्स्टेंसिबल भी है जो लिखते समय स्थानीय डॉकटर कंटेनर से सटीक समान टूल चेन का उपयोग करने की अनुमति दे सकता है।