[pacman-dev] [PATCH v2 1/3] makepkg: refactor archive compression for reusability
Allan McRae
allan at archlinux.org
Sun Oct 8 14:02:30 UTC 2017
On 08/10/17 16:50, Eli Schwartz wrote:
> This allows for more easily extending the list of allowed compression
> methods, as it has to be modified in only one place.
>
> Also allow the user to specify their own preferred command + options for
> source packages in addition to compiled packages. Currently,
> makepkg.conf(5) erroneously claims this is already possible.
>
> Signed-off-by: Eli Schwartz <eschwartz at archlinux.org>
> ---
>
> v2: refactor into a new libmakepkg library
> Fix gitignore
>
> I still prefer compress_as() over compress_to(), unless you'd like this
> function to write the file as well, rather than just compress from
> stdin -> stdout
>
> scripts/Makefile.am | 1 +
> scripts/libmakepkg/.gitignore | 6 +----
> scripts/libmakepkg/util/compress.sh.in | 47 ++++++++++++++++++++++++++++++++++
> scripts/makepkg.sh.in | 37 +++++++-------------------
> 4 files changed, 58 insertions(+), 33 deletions(-)
> create mode 100644 scripts/libmakepkg/util/compress.sh.in
>
> diff --git a/scripts/Makefile.am b/scripts/Makefile.am
> index 0a36fc58..3ec652ce 100644
> --- a/scripts/Makefile.am
> +++ b/scripts/Makefile.am
> @@ -96,6 +96,7 @@ LIBMAKEPKG_IN = \
> libmakepkg/tidy/strip.sh \
> libmakepkg/tidy/zipman.sh \
> libmakepkg/util.sh \
> + libmakepkg/util/compress.sh \
> libmakepkg/util/message.sh \
> libmakepkg/util/option.sh \
> libmakepkg/util/parseopts.sh \
> diff --git a/scripts/libmakepkg/.gitignore b/scripts/libmakepkg/.gitignore
> index ceb7bfc4..cf1426a2 100644
> --- a/scripts/libmakepkg/.gitignore
> +++ b/scripts/libmakepkg/.gitignore
> @@ -10,8 +10,4 @@ srcinfo.sh
> tidy.sh
> tidy/*.sh
> util.sh
> -util/message.sh
> -util/option.sh
> -util/parseopts.sh
> -util/pkgbuild.sh
> -util/source.sh
> +util/*.sh
Unrelated change. Separate patch please.
In fact, since aca153bf, that whole file can just be *.sh
> diff --git a/scripts/libmakepkg/util/compress.sh.in b/scripts/libmakepkg/util/compress.sh.in
> new file mode 100644
> index 00000000..4e020e7f
> --- /dev/null
> +++ b/scripts/libmakepkg/util/compress.sh.in
> @@ -0,0 +1,47 @@
> +#!/bin/bash
> +#
> +# compress.sh - functions to compress archives in a uniform manner
> +#
> +# Copyright (c) 2017 Pacman Development Team <pacman-dev at archlinux.org>
> +#
> +# This program is free software; you can redistribute it and/or modify
> +# it under the terms of the GNU General Public License as published by
> +# the Free Software Foundation; either version 2 of the License, or
> +# (at your option) any later version.
> +#
> +# This program is distributed in the hope that it will be useful,
> +# but WITHOUT ANY WARRANTY; without even the implied warranty of
> +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
> +# GNU General Public License for more details.
> +#
> +# You should have received a copy of the GNU General Public License
> +# along with this program. If not, see <http://www.gnu.org/licenses/>.
> +#
> +
> +[[ -n "$LIBMAKEPKG_UTIL_COMPRESS_SH" ]] && return
> +LIBMAKEPKG_UTIL_COMPRESS_SH=1
> +
> +LIBRARY=${LIBRARY:-'@libmakepkgdir@'}
> +
> +source "$LIBRARY/util/message.sh"
> +
> +
> +# Wrapper around many stream compression formats, for use in the middle of a
> +# pipeline. A tar archive is passed on stdin and compressed to stdout.
> +compress_as() {
> + # $1: final archive filename extension for compression type detection
> +
> + local filename="$1"
> +
> + case "$filename" in
> + *tar.gz) ${COMPRESSGZ[@]:-gzip -c -f -n} ;;
> + *tar.bz2) ${COMPRESSBZ2[@]:-bzip2 -c -f} ;;
> + *tar.xz) ${COMPRESSXZ[@]:-xz -c -z -} ;;
> + *tar.lrz) ${COMPRESSLRZ[@]:-lrzip -q} ;;
> + *tar.lzo) ${COMPRESSLZO[@]:-lzop -q} ;;
> + *tar.Z) ${COMPRESSZ[@]:-compress -c -f} ;;
> + *tar) cat ;;
> + *) warning "$(gettext "'%s' is not a valid archive extension.")" \
> + "$ext"; cat ;;
> + esac
> +}
> diff --git a/scripts/makepkg.sh.in b/scripts/makepkg.sh.in
> index fdc8bb6a..6449accd 100644
> --- a/scripts/makepkg.sh.in
> +++ b/scripts/makepkg.sh.in
> @@ -754,21 +754,8 @@ create_package() {
> msg2 "$(gettext "Compressing package...")"
> # TODO: Maybe this can be set globally for robustness
> shopt -s -o pipefail
> - # bsdtar's gzip compression always saves the time stamp, making one
> - # archive created using the same command line distinct from another.
> - # Disable bsdtar compression and use gzip -n for now.
> list_package_files | LANG=C bsdtar -cnf - --null --files-from - |
> - case "$PKGEXT" in
> - *tar.gz) ${COMPRESSGZ[@]:-gzip -c -f -n} ;;
> - *tar.bz2) ${COMPRESSBZ2[@]:-bzip2 -c -f} ;;
> - *tar.xz) ${COMPRESSXZ[@]:-xz -c -z -} ;;
> - *tar.lrz) ${COMPRESSLRZ[@]:-lrzip -q} ;;
> - *tar.lzo) ${COMPRESSLZO[@]:-lzop -q} ;;
> - *tar.Z) ${COMPRESSZ[@]:-compress -c -f} ;;
> - *tar) cat ;;
> - *) warning "$(gettext "'%s' is not a valid archive extension.")" \
> - "$PKGEXT"; cat ;;
> - esac > "${pkg_file}" || ret=$?
> + compress_as "$PKGEXT" > "${pkg_file}" || ret=$?
>
> shopt -u -o pipefail
>
> @@ -849,26 +836,20 @@ create_srcpackage() {
> done
> done
>
> - local TAR_OPT
> - case "$SRCEXT" in
> - *tar.gz) TAR_OPT="-z" ;;
> - *tar.bz2) TAR_OPT="-j" ;;
> - *tar.xz) TAR_OPT="-J" ;;
> - *tar.lrz) TAR_OPT="--lrzip" ;;
> - *tar.lzo) TAR_OPT="--lzop" ;;
> - *tar.Z) TAR_OPT="-Z" ;;
> - *tar) TAR_OPT="" ;;
> - *) warning "$(gettext "'%s' is not a valid archive extension.")" \
> - "$SRCEXT" ;;
> - esac
> -
> local fullver=$(get_full_version)
> local pkg_file="$SRCPKGDEST/${pkgbase}-${fullver}${SRCEXT}"
>
> # tar it up
> msg2 "$(gettext "Compressing source package...")"
> cd_safe "${srclinks}"
> - if ! LANG=C bsdtar -cL ${TAR_OPT} -f "$pkg_file" ${pkgbase}; then
> +
> + # TODO: Maybe this can be set globally for robustness
> + shopt -s -o pipefail
> + LANG=C bsdtar -cLf - ${pkgbase} | compress_as "$SRCEXT" > "${pkg_file}" || ret=$?
> +
> + shopt -u -o pipefail
> +
> + if (( ret )); then
> error "$(gettext "Failed to create source package file.")"
> exit 1 # TODO: error code
> fi
>
More information about the pacman-dev
mailing list