diff options
Diffstat (limited to 'libre/qutebrowser/PKGBUILD')
-rw-r--r-- | libre/qutebrowser/PKGBUILD | 148 |
1 files changed, 104 insertions, 44 deletions
diff --git a/libre/qutebrowser/PKGBUILD b/libre/qutebrowser/PKGBUILD index d9665313a..cce2822b2 100644 --- a/libre/qutebrowser/PKGBUILD +++ b/libre/qutebrowser/PKGBUILD @@ -1,83 +1,143 @@ -# Maintainer (Arch): Morten Linderud <foxboron@archlinux.org> -# Maintainer (Arch): Lukas Fleischer <lfleischer@archlinux.org> -# Contributor (Arch): Pierre Neidhardt <ambrevar@gmail.com> -# Contributor (Arch): Florian Bruhin (The Compiler) <archlinux.org@the-compiler.org> +# Maintainer (arch): Morten Linderud <foxboron@archlinux.org> +# Maintainer (arch): Lukas Fleischer <lfleischer@archlinux.org> +# Contributor: Pierre Neidhardt <ambrevar@gmail.com> +# Contributor: Florian Bruhin (The Compiler) <archlinux.org@the-compiler.org> # Maintainer: Omar Vega Ramos <ovruni@gnu.org.pe> # Contributor: André Silva <emulatorman@hyperbola.info> # Contributor: bill-auger <bill-auger@programmer.net> # parabola changes and rationale: -# - removed qt5-webengine dependency -# - set webkit backend as default -# - condensed the excessive webkit rant on the welcome screen +# - removed 'qt5-webengine' dependency +# - set webkit backend as default +# - condensed the excessive webkit rant on the welcome screen +# - pin to strongly-coupled dependency versions + + +# NOTE: Arch has no QT webkit. Parabola retains 'qt5-webkit' primarily +# to support 'qutebrowser' and 'qt5-styleplugins'. +# Qt5 and webkit are supported upstream; but that may change. +# Watch https://github.com/qutebrowser/qutebrowser/issues/4039 +# especiallly, WRT movableink/webkit + mnutt/PyQt6-QtWebKit. + + +# NOTE: for each qt5-base N.N.N release, re-build as a chain - build order: +# (qt5-base-N.N.N) <- qt5-webkit <- python-pyqt5 <- qutebrowser +# for each ''python N.N release, re-build as a chain - build order: +# (python-N.N) <- python-pyqt5 <- qutebrowser pkgname=qutebrowser -pkgver=1.13.1 +pkgver=3.1.0 pkgrel=1 -_pkgrel_armv7h=.parabola1 # this could be an 'any' package -_pkgrel_i686=.parabola2 # but our different arches do not always roll at the same speed -_pkgrel_x86_64=.parabola3 -eval "pkgrel+=\$_pkgrel_${CARCH}" -pkgdesc="A keyboard-driven, vim-like browser based on PyQt5" -pkgdesc+=" and QtWebKit" -arch=('armv7h' 'i686' 'x86_64') +pkgrel+=.parabola1 +pkgdesc="A keyboard-driven, vim-like browser based on Python and Qt" +pkgdesc+=" and WebKit" +arch=("any") +arch=(armv7h i686 x86_64) # per arch version constraints url="https://www.qutebrowser.org/" license=("GPL") -depends=("python-attrs" "python-jinja" "python-pygments" "python-pypeg2" - "python-pyqt5" "python-yaml" "qt5-base" "qt5-webkit") +depends=("python-jinja" "python-pyqt6" "python-yaml" "qt6-base" "python-pyqt6-webengine") +depends=( ${depends[*]/python-pyqt6-webengine/qt5-webkit} ) +depends=( ${depends[*]/python-pyqt6/python-pyqt5} ) +depends=( ${depends[*]/qt6-base/qt5-base} ) makedepends=("asciidoc" "python-setuptools") -optdepends=("gst-libav: media playback with qt5-webkit backend" - "gst-plugins-base: media playback with qt5-webkit backend" - "gst-plugins-good: media playback with qt5-webkit backend" - "gst-plugins-bad: media playback with qt5-webkit backend" - "gst-plugins-ugly: media playback with qt5-webkit backend" - "pdfjs: displaying PDF in-browser" -) +makedepends=( ${makedepends[*]/asciidoc/asciidoc>=10.2.0} ) # <10.2.0 depends on python2 +optdepends=("python-adblock: adblocking backend" + "python-pygments" + "pdfjs: displaying PDF in-browser") +optdepends+=("gst-libav: media playback with qt5-webkit backend" + "gst-plugins-base: media playback with qt5-webkit backend" + "gst-plugins-good: media playback with qt5-webkit backend" + "gst-plugins-bad: media playback with qt5-webkit backend" + "gst-plugins-ugly: media playback with qt5-webkit backend") options=(!emptydirs) source=("https://github.com/qutebrowser/qutebrowser/releases/download/v$pkgver/qutebrowser-$pkgver.tar.gz" "https://github.com/qutebrowser/qutebrowser/releases/download/v$pkgver/qutebrowser-$pkgver.tar.gz.asc") source+=("warning-webkit.html") -validpgpkeys=("E04E560002401B8EF0E76F0A916EB0C8FD55A072") # Florian Bruhin -sha256sums=('2896851f07c6258cf8991975eed200ca8477ae393a6a7a40249035b2f36ee2d8' +noextract=(qutebrowser-$pkgver.tar.gz) # armv7h needs this +validpgpkeys=("27F3BB4FC217EECB858578AEEF7EE4D039690B7B") +sha256sums=('500dcc1cca08d6b0b814fa306e2208e25335acbe0e2cf999fb51916e0f4b2e5f' 'SKIP') sha256sums+=('e18216f24387b61a109611958bb59248beaf5afc90da8654e29ea8b0a7ef1610') -_version_constraint() # (dep_pkgname) +_version_constraint() # (dep_pkgname [precision]) { - local dep_pkgname=$1 - local version=$(pacman -S --print-format='%v' ${dep_pkgname} | tail -n 1) - version=${version%-*} - local version_inc=${version%.*}.$(( ${version##*.} + 1 )) + Log() { [[ "${FUNCNAME[2]}" == package ]] && echo "$@" >&2 || : ; } + - echo -n "${dep_pkgname}>=${version}" "${dep_pkgname}<${version_inc}" + local dep_pkgname=$1 + 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 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='[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 ; + 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 "$pkgname-$pkgver" + # armv7h needs this + # bsdtar: Pathname can't be converted from UTF-8 to current locale + tar xzf "$srcdir"/qutebrowser-$pkgver.tar.gz - cp "$srcdir"/warning-webkit.html qutebrowser/html/ -} + cd "qutebrowser-$pkgver/qutebrowser" -build() { - cd "$pkgname-$pkgver" + # tone-down the webkit warning on the first-run welcome page + cp "$srcdir"/warning-webkit.html html/ # make sure webkit is the default backend - sed -i 's/webengine/webkit/' qutebrowser/config/configdata.yml + sed -i 's|default: webengine|default: webkit|' config/configdata.yml + ! grep 'default: webengine' config/configdata.yml || + ! echo "prepare() requires re-working - config still prefers webengine" || return 1 +} - export PYTHONHASHSEED=0 +build() { + cd "$pkgname-$pkgver" make -f misc/Makefile all } package() { - cd "$pkgname-$pkgver" - - depends+=( $(_version_constraint 'python' ) \ - $(_version_constraint 'python-pyqt5') \ - $(_version_constraint 'qt5-base' ) ) + # pin to strongly-coupled dependency versions + depends=( $(_version_constraint python 2) \ + $(_version_constraint qt5-base 3) ${depends[*]%qt5-base} ) + cd "$pkgname-$pkgver" make -f misc/Makefile DESTDIR="$pkgdir" PREFIX=/usr install } |