commit:     0aaf82d2d2bb51f15629cd210a24a0746c0a836f
Author:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
AuthorDate: Sun Nov 30 18:02:02 2025 +0000
Commit:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
CommitDate: Sun Nov 30 18:09:26 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=0aaf82d2

www-client/qutebrowser: add 3.6.3

Signed-off-by: Ionen Wolkens <ionen <AT> gentoo.org>

 www-client/qutebrowser/Manifest                 |   2 +
 www-client/qutebrowser/qutebrowser-3.6.3.ebuild | 167 ++++++++++++++++++++++++
 2 files changed, 169 insertions(+)

diff --git a/www-client/qutebrowser/Manifest b/www-client/qutebrowser/Manifest
index b185ec289f6f..090db7c7f216 100644
--- a/www-client/qutebrowser/Manifest
+++ b/www-client/qutebrowser/Manifest
@@ -2,3 +2,5 @@ DIST qutebrowser-3.6.1.tar.gz 6091194 BLAKE2B 
682c70f9f6999ba13b5f179cbbb6606e4e
 DIST qutebrowser-3.6.1.tar.gz.asc 659 BLAKE2B 
c31b9d246dea1c2cb543e46e7edafbae7eab7674d560da46ad8100fe8ac0dfc0bef543dfeeb60942db7e062f0cceb9f652dec01be5f13e3b2479e0b48b2b9873
 SHA512 
f09dba36e43cc1089800e5da78ce5880a124b996d057d94d3af6bc7e853c876b187e9a653992193bf7092e8cbf86c80b384375ae8c8e2803d44bb4d6ad468c3c
 DIST qutebrowser-3.6.2.tar.gz 6092677 BLAKE2B 
1b59d10e9827967a62234a23e41f601fc07024c24032d5e409e7e98dac2f91922a7c1e8472fc1e09bf7098b7fa76d416abb1ffe0c74e6a9ba2f40d79ebbcff0e
 SHA512 
6c342265d970481bb3417abc8a7c37b64dcbf2f658b195eaff0185642abd001c1ede79d4c42005cb498e819be47fce1cd17abce490c5fa7f05cd4a1c462bdc10
 DIST qutebrowser-3.6.2.tar.gz.asc 659 BLAKE2B 
9e67558490ef56ffeb3cd76ff8ce49c26b0acf423d3fb7dcdf364b68d300cdb96089de054917dff419c5bf6b1b91873d91492454cfc3cc78cb7c53ba7801257e
 SHA512 
559d36e97d762996a62d53b37fbe24a5823f963c81b29f70b58fb42a80ba98b41c78d3f61ec5607c593433db0e36ea69ad0e9273c613de367c14e9d167cb6345
+DIST qutebrowser-3.6.3.tar.gz 6093285 BLAKE2B 
1e6919ebfca492bde901b3e9d01aa2e6d9e9f840be747545329c09b76085a41fc70bad592103b7610913184e8466846f28e4d7bcb335ccb4ab1d910e33193771
 SHA512 
d1965d775128b466d452d3239f232711860180c138fc223c9b7b6af11aa8ff06d7b8100f1d63257552efcc0c94ddcd99cc0fb3a431f04f0c8dcc80550a9fcfd8
+DIST qutebrowser-3.6.3.tar.gz.asc 659 BLAKE2B 
9cb49abf4aaacd81184c5675c239e91b032cdbfd89c4ae687c7e8483e098f63c5ab0e5ca30d4697979288135fcde41bc1266d117f7c0475e1ad9798d72cc5a5b
 SHA512 
c4263aba3832c58598d9eddf65316955bb02ce7fd46df1640e4a2803c454e9584a326e19559766478987c3467f971b6631889d8597dc5db720ed600e787d3b3e

diff --git a/www-client/qutebrowser/qutebrowser-3.6.3.ebuild 
b/www-client/qutebrowser/qutebrowser-3.6.3.ebuild
new file mode 100644
index 000000000000..ed2f3df45884
--- /dev/null
+++ b/www-client/qutebrowser/qutebrowser-3.6.3.ebuild
@@ -0,0 +1,167 @@
+# Copyright 1999-2025 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=8
+
+DISTUTILS_SINGLE_IMPL=1
+DISTUTILS_USE_PEP517=setuptools
+PYTHON_COMPAT=( python3_{11..14} )
+inherit distutils-r1 xdg
+
+if [[ ${PV} == 9999 ]]; then
+       inherit git-r3
+       EGIT_REPO_URI="https://github.com/qutebrowser/qutebrowser.git";
+else
+       inherit verify-sig
+       SRC_URI="
+               
https://github.com/qutebrowser/qutebrowser/releases/download/v${PV}/${P}.tar.gz
+               verify-sig? ( 
https://github.com/qutebrowser/qutebrowser/releases/download/v${PV}/${P}.tar.gz.asc
 )
+       "
+       VERIFY_SIG_OPENPGP_KEY_PATH=/usr/share/openpgp-keys/qutebrowser.gpg
+       KEYWORDS="~amd64 ~arm64"
+fi
+
+DESCRIPTION="Keyboard-driven, vim-like browser based on Python and Qt"
+HOMEPAGE="https://qutebrowser.org/";
+
+LICENSE="GPL-3+"
+SLOT="0"
+IUSE="+adblock pdf widevine"
+
+RDEPEND="
+       $(python_gen_cond_dep '
+               dev-python/pyqt6-webengine[${PYTHON_USEDEP},widgets]
+               
dev-python/pyqt6[${PYTHON_USEDEP},dbus,gui,network,opengl,printsupport,qml,sql,widgets]
+               dev-python/colorama[${PYTHON_USEDEP}]
+               dev-python/jinja2[${PYTHON_USEDEP}]
+               dev-python/markupsafe[${PYTHON_USEDEP}]
+               dev-python/pygments[${PYTHON_USEDEP}]
+               dev-python/pyyaml[${PYTHON_USEDEP}]
+               dev-python/zipp[${PYTHON_USEDEP}]
+               dev-qt/qtbase:6[icu,sqlite]
+               adblock? ( dev-python/adblock[${PYTHON_USEDEP}] )
+               pdf? ( www-plugins/pdfjs )
+               widevine? ( www-plugins/chrome-binary-plugins )
+       ')
+"
+BDEPEND="
+       $(python_gen_cond_dep '
+               test? (
+                       dev-python/pyqt6[testlib]
+                       dev-python/beautifulsoup4[${PYTHON_USEDEP}]
+                       dev-python/cheroot[${PYTHON_USEDEP}]
+                       dev-python/flask[${PYTHON_USEDEP}]
+                       dev-python/pillow[${PYTHON_USEDEP}]
+                       dev-python/tldextract[${PYTHON_USEDEP}]
+               )
+       ')
+"
+
+if [[ ${PV} == 9999 ]]; then
+       BDEPEND+=" app-text/asciidoc"
+else
+       BDEPEND+=" verify-sig? ( >=sec-keys/openpgp-keys-qutebrowser-20251024 )"
+fi
+
+EPYTEST_PLUGINS=( hypothesis pytest-{bdd,mock,qt,rerunfailures,xvfb} )
+distutils_enable_tests pytest
+
+src_prepare() {
+       distutils-r1_src_prepare
+
+       if use pdf; then
+               # does not hurt to enable by default if it was explicitly 
requested
+               sed -e '/^content.pdfjs:/,+1s/false/true/' \
+                       -i ${PN}/config/configdata.yml || die
+       fi
+
+       # let eclass handle python
+       sed -i '/setup.py/d' misc/Makefile || die
+
+       if [[ ${PV} == 9999 ]]; then
+               # call asciidoc(1) rather than the single target python module
+               sed -e '/cmdline = /s/= .*/= ["asciidoc"]/' \
+                       -i scripts/asciidoc2html.py || die
+
+               "${EPYTHON}" scripts/asciidoc2html.py || die
+       fi
+
+       if use test; then
+               # skip unnecessary (for us) pytest plugins, and ignore Qt's
+               # warnings that tend to newly appear with new versions
+               sed -e '/pytest-benchmark/d' -e 's/--benchmark[^ ]*//' \
+                       -e '/pytest-instafail/d' -e 's/--instafail//' \
+                       -e '/qt_log_level_fail/s/WARNING/CRITICAL/' \
+                       -i pytest.ini || die
+
+               if [[ ${PV} == 9999 ]]; then
+                       # likewise, needs vulture
+                       rm tests/unit/scripts/test_run_vulture.py || die
+               else
+                       # https://github.com/qutebrowser/qutebrowser/issues/7620
+                       rm tests/unit/scripts/test_problemmatchers.py || die
+               fi
+       fi
+}
+
+python_test() {
+       local -x PYTEST_QT_API=pyqt6
+
+       local EPYTEST_DESELECT=(
+               # end2end/IPC tests are broken with "Name error" if socket path 
is over
+               # ~108 characters (>124 in /var/tmp/portage) due to Linux 
limitations,
+               # skip rather than bother using /tmp+cleanup over ${T} (end2end 
tests
+               # are important, but the other tests should be enough for 
downstream)
+               tests/end2end
+               tests/unit/misc/test_ipc.py
+               # python eclasses provide a fake "failing" python2 and trips 
this test
+               tests/unit/misc/test_checkpyver.py::test_old_python
+               # not worth running dbus over
+               tests/unit/browser/test_notification.py::TestDBus
+               # fails in ebuild, seems due to saving fake downloads in the 
wrong location
+               
tests/unit/browser/webengine/test_webenginedownloads.py::TestDataUrlWorkaround
+               # may fail if environment is very large (bug #819393)
+               
tests/unit/commands/test_userscripts.py::test_custom_env\[_POSIXUserscriptRunner\]
+               # may fail if chromium version is unrecognized (aka newer 
qtwebengine)
+               tests/unit/utils/test_version.py
+               # no longer XFAIL due to being fixed in python
+               
tests/unit/utils/test_urlmatch.py::test_invalid_patterns\[host-ipv6-two-closing\]
+       )
+
+       local epytestargs=(
+               # prefer pytest-xvfb over virtx given same upstream and is 
expected
+               -p xvfb
+               # skip warning tests broken by -Wdefault, and benchmarks
+               -k 'not _bench and not _matches_tree and not _warning'
+               # override eclass' settings, tempdirs are re-used by Qt
+               -o tmp_path_retention_policy=all
+       )
+
+       epytest "${epytestargs[@]}"
+}
+
+python_install_all() {
+       emake -f misc/Makefile DESTDIR="${D}" PREFIX="${EPREFIX}"/usr install
+
+       rm -- "${ED}"/usr/share/${PN}/scripts/{mkvenv,utils}.py || die
+       fperms -x 
/usr/share/${PN}/{scripts/cycle-inputs.js,userscripts/README.md}
+       python_fix_shebang "${ED}"/usr/share/${PN}
+
+       einstalldocs
+}
+
+pkg_postinst() {
+       xdg_pkg_postinst
+
+       if [[ ! ${REPLACING_VERSIONS} ]]; then
+               elog "Note that optional scripts in 
${EROOT}/usr/share/${PN}/{user,}scripts"
+               elog "have additional dependencies not covered by this ebuild, 
for example"
+               elog "view_in_mpv needs media-video/mpv[lua] and 
net-misc/yt-dlp."
+       fi
+
+       if has_version 'dev-qt/qtwebengine:6[bindist]'; then
+               ewarn
+               ewarn "USE=bindist is set on dev-qt/qtwebengine, be warned that 
this"
+               ewarn "will prevent playback of proprietary media formats (e.g. 
h264)."
+       fi
+}

Reply via email to