diff options
author | Mikle Kolyada <zlogene@gentoo.org> | 2020-01-20 22:18:58 +0300 |
---|---|---|
committer | Mikle Kolyada <zlogene@gentoo.org> | 2020-02-09 13:25:16 +0300 |
commit | 595611085bc532afb9f31fa23cee734bc37d21a4 (patch) | |
tree | d14390821fe99522b20344c964e08d2ae2cc2c6c /eclass | |
parent | dev-ruby/rcairo: add ruby27 (diff) | |
download | gentoo-595611085bc532afb9f31fa23cee734bc37d21a4.tar.gz gentoo-595611085bc532afb9f31fa23cee734bc37d21a4.tar.bz2 gentoo-595611085bc532afb9f31fa23cee734bc37d21a4.zip |
latex-package: kill POSIX and old EAPI
Reviewed-by: David Saifert <soap@gentoo.org>
Reviewed-by: Michał Górny <mgorny@gentoo.org>
Signed-off-by: Mikle Kolyada <zlogene@gentoo.org>
Diffstat (limited to 'eclass')
-rw-r--r-- | eclass/latex-package.eclass | 136 |
1 files changed, 64 insertions, 72 deletions
diff --git a/eclass/latex-package.eclass b/eclass/latex-package.eclass index 1a684ef00a66..e24fd1875f47 100644 --- a/eclass/latex-package.eclass +++ b/eclass/latex-package.eclass @@ -1,4 +1,4 @@ -# Copyright 1999-2018 Gentoo Foundation +# Copyright 1999-2020 Gentoo Authors # Distributed under the terms of the GNU General Public License v2 # @ECLASS: latex-package.eclass @@ -7,7 +7,7 @@ # @AUTHOR: # Matthew Turk <satai@gentoo.org> # Martin Ehmsen <ehmsen@gentoo.org> -# @SUPPORTED_EAPIS: 0 1 2 3 4 5 6 7 +# @SUPPORTED_EAPIS: 7 # @BLURB: An eclass for easy installation of LaTeX packages # @DESCRIPTION: # This eClass is designed to be easy to use and implement. The vast majority of @@ -50,21 +50,21 @@ # signatures EVERY TIME. For this reason, if you are grabbing from the CTAN, # you must either grab each file individually, or find a place to mirror an # archive of them. (iBiblio) -# -# It inherits base and eutils in EAPI 5 and earlier. -case ${EAPI:-0} in - 0|1|2|3|4|5) inherit base eutils ;; -esac +if [[ -z ${_LATEX_PACKAGE_ECLASS} ]]; then +_LATEX_PACKAGE_ECLASS=1 RDEPEND="virtual/latex-base" DEPEND="${RDEPEND} >=sys-apps/texinfo-4.2-r5" + case ${EAPI:-0} in - 0|1|2|3|4|5|6) ;; - 7) BDEPEND="${DEPEND}"; DEPEND="" ;; - *) die "${ECLASS}: Unknown EAPI ${EAPI}" ;; + [0-6]) + die "Unsupported EAPI=${EAPI:-0} (too old) for ${ECLASS}" ;; + 7) ;; + *) die "Unsupported EAPI=${EAPI} (unknown) for ${ECLASS}" ;; esac + HOMEPAGE="http://www.tug.org/" TEXMF="/usr/share/texmf-site" @@ -81,14 +81,6 @@ SUPPLIER="misc" # must be set after inherit, as it gets automatically cleared otherwise. LATEX_DOC_ARGUMENTS="" -# Kept for backwards compatibility -latex-package_has_tetex_3() { - case ${EAPI:-0} in - 0|1|2|3|4|5) return 0 ;; - *) die "${FUNCNAME} no longer supported in EAPI ${EAPI}" ;; - esac -} - # @FUNCTION: latex-package_src_doinstall # @USAGE: [ module ] # @DESCRIPTION: @@ -105,93 +97,94 @@ latex-package_src_doinstall() { # This actually follows the directions for a "single-user" system # at http://www.ctan.org/installationadvice/ modified for gentoo. - [ -z "$1" ] && latex-package_src_install all + [[ -z ${1} ]] && latex-package_src_install all - while [ "$1" ]; do - case $1 in + while [[ ${1} ]]; do + case ${1} in "sh") - for i in `find . -maxdepth 1 -type f -name "*.${1}"` - do - dobin $i || die "dobin $i failed" - done + while read -r -d '' i; do + dobin ${i} + done < <(find -maxdepth 1 -type f -name "*.${1}") ;; + "sty" | "cls" | "fd" | "clo" | "def" | "cfg") - for i in `find . -maxdepth 1 -type f -name "*.${1}"` - do + while read -r -d '' i; do insinto ${TEXMF}/tex/latex/${PN} - doins $i || die "doins $i failed" - done + doins ${i} + done < <(find -maxdepth 1 -type f -name "*.${1}") ;; + "dvi" | "ps" | "pdf") - for i in `find . -maxdepth 1 -type f -name "*.${1}"` - do + while read -r -d '' i; do insinto /usr/share/doc/${PF} - doins $i || die "doins $i failed" + doins ${i} dosym /usr/share/doc/${PF}/$(basename ${i}) ${TEXMF}/doc/latex/${PN}/${i} - case "${EAPI:-0}" in - 0|1|2|3) ;; - *) - # prevent compression of symlink target - docompress -x /usr/share/doc/${PF}/$(basename ${i}) - ;; - esac - done + docompress -x /usr/share/doc/${PF}/$(basename ${i}) + done < <(find -maxdepth 1 -type f -name "*.${1}") ;; + "tex" | "dtx") if ! in_iuse doc || use doc ; then - for i in `find . -maxdepth 1 -type f -name "*.${1}"` - do - [ -n "${LATEX_PACKAGE_SKIP}" ] && has ${i##*/} ${LATEX_PACKAGE_SKIP} && continue - einfo "Making documentation: $i" - if pdflatex ${LATEX_DOC_ARGUMENTS} --halt-on-error --interaction=nonstopmode $i ; then - pdflatex ${LATEX_DOC_ARGUMENTS} --halt-on-error --interaction=nonstopmode $i || die + while read -r -d '' i; do + [[ -n ${LATEX_PACKAGE_SKIP} ]] && \ + has ${i##*/} ${LATEX_PACKAGE_SKIP} && \ + continue + + einfo "Making documentation: ${i}" + # some macros need compiler called twice, do it here. + set -- pdflatex ${LATEX_DOC_ARGUMENTS} --halt-on-error --interaction=nonstopmode ${i} + if "${@}"; then + "${@}" else einfo "pdflatex failed, trying texi2dvi" - texi2dvi -q -c --language=latex $i || die + texi2dvi -q -c --language=latex ${i} || die fi - done + done < <(find -maxdepth 1 -type f -name "*.${1}") fi ;; + "tfm" | "vf" | "afm") - for i in `find . -maxdepth 1 -type f -name "*.${1}"` - do + while read -r -d '' i; do insinto ${TEXMF}/fonts/${1}/${SUPPLIER}/${PN} - doins $i || die "doins $i failed" - done + doins ${i} + done < <(find -maxdepth 1 -type f -name "*.${1}") ;; + "pfb") - for i in `find . -maxdepth 1 -type f -name "*.pfb"` - do + while read -r -d '' i; do insinto ${TEXMF}/fonts/type1/${SUPPLIER}/${PN} - doins $i || die "doins $i failed" - done + doins ${i} + done < <(find -maxdepth 1 -type f -name "*.pfb") ;; "ttf") - for i in `find . -maxdepth 1 -type f -name "*.ttf"` - do + while read -r -d '' i; do insinto ${TEXMF}/fonts/truetype/${SUPPLIER}/${PN} - doins $i || die "doins $i failed" - done + doins ${i} + done < <(find -maxdepth 1 -type f -name "*.ttf") ;; "bst") - for i in `find . -maxdepth 1 -type f -name "*.bst"` - do + while read -r -d '' i; do insinto ${TEXMF}/bibtex/bst/${PN} - doins $i || die "doins $i failed" - done + doins ${i} + done < <(find -maxdepth 1 -type f -name "*.bst") ;; + "styles") latex-package_src_doinstall sty cls fd clo def cfg bst ;; + "doc") latex-package_src_doinstall tex dtx dvi ps pdf ;; + "fonts") latex-package_src_doinstall tfm vf afm pfb ttf ;; + "bin") latex-package_src_doinstall sh ;; + "all") latex-package_src_doinstall styles fonts bin doc ;; @@ -206,11 +199,10 @@ latex-package_src_doinstall() { # relevant files that will be installed latex-package_src_compile() { debug-print function $FUNCNAME $* - for i in `find \`pwd\` -maxdepth 1 -type f -name "*.ins"` - do - einfo "Extracting from $i" - latex --halt-on-error --interaction=nonstopmode $i || die - done + while read -r -d '' i; do + einfo "Extracting from ${i}" + latex --halt-on-error --interaction=nonstopmode ${i} || die + done < <(find -maxdepth 1 -type f -name "*.ins") } # @FUNCTION: latex-package_src_install @@ -219,9 +211,7 @@ latex-package_src_compile() { latex-package_src_install() { debug-print function $FUNCNAME $* latex-package_src_doinstall all - if [ -n "${DOCS}" ] ; then - dodoc ${DOCS} - fi + einstalldocs } # @FUNCTION: latex-package_pkg_postinst @@ -251,3 +241,5 @@ latex-package_rehash() { } EXPORT_FUNCTIONS src_compile src_install pkg_postinst pkg_postrm + +fi |