LuaLaTeX: TOC, Index, Bibliography, Glossary और दूसरों के लिए एकाधिक संकलन को CI पर स्वचालित करें
दूरस्थ CI सिस्टम पर दस्तावेज़ों का प्रतिलिपि प्रस्तुत करने योग्य और विश्वसनीय निर्माण करने के लिए, मैं एक संपूर्ण दस्तावेज़ बनाने के लिए आवश्यक सभी कमांड लाइन टूल्स और कई संकलनों को स्वचालित करना चाहूंगा। इस पाइपलाइन को बॉक्स से बाहर किसी भी दस्तावेज़ को काम करना चाहिए, भले ही दस्तावेज़ में प्लगइन्स का वास्तव में उपयोग किया जाए।
यह मेरी समझ है कि लाटेक्स बिल्ड के लिए सभी आवश्यक कदमों को स्वचालित रूप से करने का एक तरीका है, लेकिन अभी तक मुझे किसी भी दृष्टिकोण के साथ कोई सफलता नहीं मिली।
विवरण
मेरा वर्तमान सेटअप यह है:
- दस्तावेज़ LuaLaTeX और MiKTeX का उपयोग करके मेरी मशीन पर लिखे और संकलित किए गए हैं
- CI में MiKTeX Docker छवि ( यहां देखें ) शामिल है जिसमें सभी कस्टम फोंट और संसाधन इंस्टॉल किए गए हैं
स्थानीय रूप से मुझे एक दस्तावेज संकलित करने के लिए विभिन्न क्रियाओं को करना पड़ता है जिसे मुझे एक दस्तावेज के लेखक के रूप में जानना होता है। लेकिन CI को प्रति दस्तावेज़ सेटिंग्स को लागू किए बिना किसी भी दस्तावेज़ का निर्माण करने और त्रुटियों का उत्पादन करने में सक्षम होना चाहिए जब डॉक्टर सही तरीके से संकलन नहीं कर सकते हैं या कुछ गायब है।
उदाहरण: शब्दावली
जब मुझे एक दस्तावेज बनाने की आवश्यकता होती है जहां मैं glossaries
पैकेज का उपयोग करता हूं तो स्थानीय बिल्ड इस तरह दिखाई देगा
lualatex doc.tex
makeglossaries doc
lualatex doc.tex
अब सीआई को यह नहीं पता है कि डॉक्टर को इस कदम की आवश्यकता है या नहीं, लेकिन अभी भी दस्तावेज़ बनाने में सक्षम होना चाहिए। शब्दावलियों के दस्तावेज़ीकरण में automake
परम का उल्लेख है और --shell-escape
दस्तावेजों को संकलित करने का विकल्प है जो मुझे लगता है कि मुझे एक ही बार में सब कुछ संकलित करने की अनुमति देगा लेकिन यह सीआई पर काम नहीं करता है। इसी तरह मुझे टीओसी, सूचकांकों, ग्रंथ सूची आदि के साथ भी यही समस्या है।
सारांश
क्या विभिन्न पैकेजों के लिए जटिल संकलन को स्वचालित करने का एक सामान्य तरीका है? (या तो LuaLaTeX या कुछ सामान्य सामान्य प्रयोजन लिपियों के लिए बनाया गया)
क्या मेरे सेटअप में कोई समस्या है जो सभी चरणों को स्वचालित रूप से होने से रोक सकती है?
मैंने विशिष्ट पैकेजों या लाटेक्स के लिए बहुत सारे संसाधनों के माध्यम से काम किया है, लेकिन कुछ ऐसा नहीं कर पाया जो काम करता हो। आपकी मदद की बहुत सराहना की है।
जवाब
जैसा कि अन्य और स्वयं ने उल्लेख किया है, latexmkइस नौकरी के लिए सही उपकरण लगता है। यह देखने के लिए कि इसे कैसे लागू किया जा सकता है, मुझे अपने स्वयं के LaTeX दस्तावेज़ / टेम्पलेट CI पाइपलाइन (GITLL पर) से प्रासंगिक बिट्स को उजागर करने दें। यह "विभिन्न संकुल के लिए जटिल संकलन" के लिए एक प्रयोग करने योग्य उदाहरण होना चाहिए। मैं LaTeX-specific / part के अलावा GitLab CI कॉन्फिगरेशन के साथ Dockerfile- साथ जाऊंगाlatexmk
, क्योंकि सभी भाग कसकर युग्मित हैं।
इस परियोजना में काम करने के लिए नीचे दी गई हर चीज को लागू किया जा सकता है और (उम्मीद है ...) । मैं इस उत्तर को यथासंभव आत्म-निहित रखने की कोशिश कर रहा हूं। परियोजना के लिंक में नवीनतम स्थिति शामिल होगी, जो अंततः इस उत्तर को छोड़ देगी।
LaTeX और वितरण (डेबियन) पैकेज
लिंक किए गए पाइपलाइन में, एक युगल पैकेज हैं जो सेटअप में विशेष ध्यान देने की आवश्यकता है। यह संभावना नहीं है कि आपके पास समान आवश्यकताएं होंगी, लेकिन मैं उन्हें पूर्णता के लिए यहां सूचीबद्ध कर रहा हूं।
glossaries-extra, के शीर्ष पर
glossaries
, के साथ काम करने के लिए फ़ाइलों bib2glsको परिवर्तित करने और संसाधित करने की आवश्यकता होती है ।*.bib
lualatex
यह सेटअप दो गुना में परिलक्षित होता है:
- डॉकर छवि के लिए एक जावा रनटाइम पर्यावरण की आवश्यकता है
bib2gls
, latexmk
bib2gls
फ़ाइलों की उपस्थिति के बारे में बताया जाना चाहिए ।
- डॉकर छवि के लिए एक जावा रनटाइम पर्यावरण की आवश्यकता है
pgfplotsइसके ( उदाहरण के )
contour
विकल्प के साथ बाहरी कार्यक्रम की आवश्यकता होती है । फिर, यह दो गुना परिलक्षित होता है:\addplot3
gnuplotlualatex
(या अपनी पसंद के इंजन) को पढ़ने केgnuplot
लिए फ़ाइलों के लिए अपने अभिकलन परिणाम लिखने के लिए बाहर लिखने की आवश्यकता होती हैpgfplots
:--shell-escape
की आवश्यकता होती है, जिसमेंlatexmk
से बताया जाना चाहिए।gnuplot
, एक वितरण पैकेज के रूप में (एक लाटेक्स पैकेज के विपरीत) कोapt-get install gnuplot
डेबियन होस्ट पर मौजूद होना चाहिए ।
LaTeX मूल रूप से
*.svg
फ़ाइलों को एम्बेड नहीं कर सकता है । ऐसी फ़ाइलों को एम्बेड करने के लिए पहले पीडीएफ (या कुछ अन्य एम्बेड करने योग्य प्रारूप) में रूपांतरण की आवश्यकता होती है। यह इंकस्केप और इसकी *.pdf_texदिनचर्या का उपयोग करके प्राप्त किया जा सकता है । हालांकि, यह हमें एसवीजी फ़ाइल प्रति दो अतिरिक्त फ़ाइलों के साथ छोड़ देता है:*.pdf
और*.pdf_tex
। एसवीजी फ़ाइल में हर परिवर्तन पर, व्युत्पन्न फ़ाइलों को अद्यतन करना होगा। यह संभावित संघर्षों की ओर जाता है, संस्करण नियंत्रण (git
आदि) के संदर्भ में भी : कौन से संस्करण रखे जाने हैं?svgLaTeX पैकेज रूपांतरण प्रक्रिया को स्वचालित करके इन समस्याओं को हल करती है। उत्पन्न
*.pdf
और*.pdf_tex
फ़ाइलों को अस्थायी / व्युत्पन्न फ़ाइलों के रूप में माना जा सकता है और स्वतंत्र रूप से त्याग दिया जा सकता है। सत्य के एकल स्रोत के रूप में केवल एसवीजी ही रहते हैं । एक बोनस के रूप में, पाठ-आधारित (एक्सएमएल) होने के नाते , वे वीसीएस जैसेgit
(जो बाइनरी पीडीएफ वास्तव में नहीं हैं) के लिए भी उपयुक्त हैं।पहले की तरह, यह दो स्थानों पर नीचे दिए गए सेटअप में परिलक्षित होता है:
- पढ़ने के लिए और लिखने के लिए CLI
inkscape
(GUI के विपरीत, काम करने के लिए, आपकेinkscape
पास होना चाहिए$PATH
) को कॉल करने के लिए, LaTeX इंजन की आवश्यकता होती है--shell-escape
। inkscape
बिल्ड वातावरण (डॉकर छवि) में उपलब्ध होने की आवश्यकता है।
- पढ़ने के लिए और लिखने के लिए CLI
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
गेज संकलन प्रगति और खत्म करने के लिए परिवर्तन के लिए सहायक फ़ाइलों की जांच करके काम करता है।पिछले बिंदु के समान एक नस में, 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 कॉन्फिगरेशन (वर्ण सीमा के कारण टिप्पणी के बिना) होगा:
- ऊपर DockerHub रिपॉजिटरी से छवि को खींचो, किसी भी
ENTRYPOINT
निर्देश को कुछ नहीं (उर्फ एक सामान्य शेल) के साथ बदल दें। यहscript
काम करने के लिए महत्वपूर्ण है , जबकिENTRYPOINT
आपके डेस्कटॉप पर कंटेनर चलाने के लिए सुविधाजनक है। - बदलें
n.a.
में\newcommand*{\GitVersion}{n.a.}
और\newcommand*{\GitShortHash}{n.a.}
से*.cls
LaTeX वर्ग फ़ाइल (परियोजना जड़ में) है कि निर्माण की वास्तविक, वर्तमान मूल्यों के साथ। यह वीसीएस मेटाडेटा को पीडीएफ में मुद्रित करने की अनुमति देता है। - केवल जारी करके PDF में LaTeX बनाएँ
latexmk
। यह.latexmkrc
ऊपर से अपने निर्देशों को आकर्षित करेगा , ऊपर देखें। - से एक पीडीएफ संकलित करें
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: []
क्षमा करें, मुझे नहीं पता कि सीआई किस लिए खड़ा है, लेकिन यदि आपके पास अपनी मशीन पर जीएनयू है, तो आप इस तरह से एक छोटा सा मेकफाइ लिख सकते हैं:
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 मेक क्लीनॉल’ आपकी निर्देशिका को सुव्यवस्थित करने में आपकी मदद कर सकते हैं।
मैंने 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;
}
यहां से ले जाया गया ।
अंतिम परिणाम दस्तावेज़ और इसकी सामग्री की परवाह किए बिना एक सुसंगत बिल्ड अनुभव सुनिश्चित करता है। यह दृष्टिकोण लचीला और एक्स्टेंसिबल भी है जो लिखते समय स्थानीय डॉकटर कंटेनर से सटीक समान टूल चेन का उपयोग करने की अनुमति दे सकता है।