diff options
Diffstat (limited to 'libre/icedove-extension-enigmail/PKGBUILD')
-rw-r--r-- | libre/icedove-extension-enigmail/PKGBUILD | 84 |
1 files changed, 53 insertions, 31 deletions
diff --git a/libre/icedove-extension-enigmail/PKGBUILD b/libre/icedove-extension-enigmail/PKGBUILD index 0e82deacb..c6a773040 100644 --- a/libre/icedove-extension-enigmail/PKGBUILD +++ b/libre/icedove-extension-enigmail/PKGBUILD @@ -1,12 +1,12 @@ -# Maintainer (Arch): Eli Schwartz <eschwartz@archlinux.org> -# Maintainer (Arch): Jonas Witschel <diabonas@archlinux.org> -# Contributor (Arch): Daniel Landau <daniel.landau@iki.fi> -# Contributor (Arch): Einhard Leichtfuß <alguien@respiranto.de> -# Contributor (Arch): Xyne -# Contributor (Arch): David Manouchehri <d@32t.ca> -# Contributor (Arch): Alexander Fehr <pizzapunk gmail com> -# Contributor (Arch): Thomas Jost <schnouki schnouki net> -# Contributor (Arch): Hinrich Harms <arch hinrich de> +# Maintainer (arch): Eli Schwartz <eschwartz@archlinux.org> +# Maintainer (arch): Jonas Witschel <diabonas@archlinux.org> +# Contributor: Daniel Landau <daniel.landau@iki.fi> +# Contributor: Einhard Leichtfuß <alguien@respiranto.de> +# Contributor: Xyne +# Contributor: David Manouchehri <d@32t.ca> +# Contributor: Alexander Fehr <pizzapunk gmail com> +# Contributor: Thomas Jost <schnouki schnouki net> +# Contributor: Hinrich Harms <arch hinrich de> # Maintainer: Omar Vega Ramos <ovruni@gnu.org.pe> @@ -14,6 +14,7 @@ # * replace 'thunderbird' dependency with 'icedove' # * apply dependency version constraints # * allow building arch-specific packages (different version constraints) +# * pin to strongly-coupled dependency versions _pkgname=thunderbird-extension-enigmail @@ -48,32 +49,54 @@ validpgpkeys=('4F9F89F5505AC1D1A260631CDB1187B9DD5F693B') # Patrick Brunschwig < _version_constraint() # (dep_pkgname [precision]) { + Log() { [[ "${FUNCNAME[2]}" == package ]] && echo "$@" >&2 || : ; } + + local dep_pkgname=$1 - local full_version=$(pacman -S --print-format='%v' ${dep_pkgname} | tail -n 1) - local n_dots=$(tmp=${full_version%-*} ; tmp=${tmp//[^\.]} ; echo "${#tmp}") + declare -i req_precision=$2 + local full_version=$(pacman -S --print-format='%v' ${dep_pkgname} 2> /dev/null | tail -n 1) + local n_dots=$(tmp=${full_version%-*} ; tmp=${tmp//[^\.]} ; echo "${#tmp}" ;) local def_precision=$(( n_dots + 1 )) - local precision=$( [[ "$2" =~ ^[1-${def_precision}]$ ]] && echo $2 || echo ${def_precision} ) - local pkgver_rx='[^-\.\ ]+' + local is_prec_valid=$(( req_precision > 0 && req_precision <= def_precision )) + local precision=$((( is_prec_valid )) && echo ${req_precision} || echo ${def_precision}) + local pkgver_rx='[0-9A-Za-z_]+' + pkgver_rx=$(sed 's|\]|\+]|' <<<${pkgver_rx}) # according to the wiki, '+' is not allowed, + # but some pkgver have it (eg: 5.15.10+kde+r130) local subver_rx='\.'${pkgver_rx} - local pkgrel_rx='[^-\ ]+' + local pkgrel_rx='[0-9]+' + local garbage_rx='[^0-9].*' local capture_rx=${pkgver_rx} - for (( n_dots=1 ; n_dots < precision ; n_dots++ )) ; do capture_rx+=${subver_rx} ; done ; - - if [[ "${full_version}" =~ ^(${capture_rx})(${subver_rx})*-${pkgrel_rx}$ ]] - then local version=${BASH_REMATCH[1]} - local subver_inc=$(( ${version##*.} + 1 )) - local version_inc=$( [[ "${version}" =~ \. ]] && echo ${version%.*}.${subver_inc} || \ - echo ${subver_inc} ) - local constraint_string="${dep_pkgname}>=${version} ${dep_pkgname}<${version_inc}" - - echo "applied version constraint: ${constraint_string}" >&2 - - echo -n "${constraint_string}" - else echo "ERROR: _version_constraint() error parsing: dep_pkgname='${dep_pkgname}' full_version='${full_version}'" >&2 + for (( n_dots=1 ; n_dots < precision ; ++n_dots )) ; do capture_rx+=${subver_rx} ; done ; + local version pkgrel has_dot_char version_min version_max constraint_string + declare -i subver subver_inc pkgrel_inc + + if [[ "${full_version}" =~ ^(${capture_rx})(${subver_rx})*-(${pkgrel_rx}).*$ ]] + then version=${BASH_REMATCH[1]} # pkgver cut to the requested precision + #unused=${BASH_REMATCH[2]} # discarded pkgver segments + pkgrel=${BASH_REMATCH[3]} # pkgrel with non-numerics right-trimmed + has_dot_char=$([[ "${version}" =~ \. ]] ; echo $(( ! $? )) ; ) + subver=$(sed "s|${garbage_rx}||" <<<${version##*.}) # right-trim from any non-numeric + version=$( (( has_dot_char )) && echo ${version%.*}.${subver} || echo ${subver} ) + subver_inc=$(( subver + 1 )) + pkgrel_inc=$(( pkgrel + 1 )) + version_min=$( (( ! is_prec_valid )) && echo ${full_version%-*}-${pkgrel} || \ + echo ${version} ) + version_max=$( ( (( ! is_prec_valid )) && echo ${full_version%-*}-${pkgrel_inc} ) || \ + ( [[ "${version}" =~ \. ]] && echo ${version%.*}.${subver_inc} ) || \ + echo ${subver_inc} ) + constraint_string="${dep_pkgname}>=${version_min} ${dep_pkgname}<${version_max}" + + Log "Applied version constraint: '${constraint_string}'" + else Log "ERROR: in _version_constraint() parsing: dep_pkgname='${dep_pkgname}' full_version='${full_version}'" exit 1 fi + + unset -f Log + + echo -n "${constraint_string}" } + prepare() { cd "${srcdir}"/enigmail @@ -97,10 +120,9 @@ build() { } package() { - # parabola dependency version contraints - local gnupg_constraints="$( _version_constraint 'gnupg' )" - local icedove_constraints="$(_version_constraint 'icedove')" - depends+=( ${gnupg_constraints} ${icedove_constraints} ) + # pin to strongly-coupled dependency versions + depends=( ${depends[*]/gnupg/} $(_version_constraint 'gnupg' ) ) + depends=( ${depends[*]/icedove/} $(_version_constraint 'icedove') ) # upstream min thunderbird version contraint local min_icedove_ver=$(grep strict_min_version "${srcdir}"/enigmail/build-tb/dist/manifest.json | sed 's|.*: "\([0-9]*\)\..*|\1|g') |