public inbox for gentoo-commits@lists.gentoo.org
 help / color / mirror / Atom feed
From: "Ionen Wolkens" <ionen@gentoo.org>
To: gentoo-commits@lists.gentoo.org
Subject: [gentoo-commits] repo/gentoo:master commit in: www-client/qutebrowser/
Date: Fri, 15 Oct 2021 15:53:39 +0000 (UTC)	[thread overview]
Message-ID: <1634312635.0b8b467249ed31d90aaeb9e535d039c08379bafa.ionen@gentoo> (raw)

commit:     0b8b467249ed31d90aaeb9e535d039c08379bafa
Author:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
AuthorDate: Tue Oct 12 19:02:25 2021 +0000
Commit:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
CommitDate: Fri Oct 15 15:43:55 2021 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=0b8b4672

www-client/qutebrowser: sync and update live ebuild

Now also running asciidoc2html needed for :help / qute://help
to function (these are pre-converted in release copy).

Done in prepare_all given has to be before python_compile for
simplicity (compile_all runs after compile) and only only done
once rather than per-implementation (not that using multiple).

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

 www-client/qutebrowser/metadata.xml            |   2 -
 www-client/qutebrowser/qutebrowser-9999.ebuild | 162 +++++++++++++++----------
 2 files changed, 95 insertions(+), 69 deletions(-)

diff --git a/www-client/qutebrowser/metadata.xml b/www-client/qutebrowser/metadata.xml
index bfc1e23ae3f..44b66f5f900 100644
--- a/www-client/qutebrowser/metadata.xml
+++ b/www-client/qutebrowser/metadata.xml
@@ -24,8 +24,6 @@
 	<use>
 		<flag name="adblock">Enable Brave's ABP-style adblocker library
 			for improved adblocking</flag>
-		<flag name="scripts">Installs userscripts from the misc/userscripts
-			directory to /usr/share/qutebrowser/userscripts.</flag>
 		<flag name="widevine">Unsupported closed-source DRM capability
 			(required by Netflix VOD)</flag>
 	</use>

diff --git a/www-client/qutebrowser/qutebrowser-9999.ebuild b/www-client/qutebrowser/qutebrowser-9999.ebuild
index c015de929af..22d3277e686 100644
--- a/www-client/qutebrowser/qutebrowser-9999.ebuild
+++ b/www-client/qutebrowser/qutebrowser-9999.ebuild
@@ -3,92 +3,120 @@
 
 EAPI=8
 
-PYTHON_COMPAT=( python3_{8..9} )
-DISTUTILS_USE_SETUPTOOLS="rdepend"
+DISTUTILS_SINGLE_IMPL=1
+PYTHON_COMPAT=( python3_{8..10} )
+inherit distutils-r1 optfeature xdg
 
-inherit desktop distutils-r1 git-r3 optfeature xdg
+if [[ ${PV} == 9999 ]]; then
+	inherit git-r3
+	EGIT_REPO_URI="https://github.com/qutebrowser/qutebrowser.git"
+else
+	SRC_URI="https://github.com/qutebrowser/qutebrowser/releases/download/v${PV}/${P}.tar.gz"
+	KEYWORDS="~amd64 ~arm64 ~x86"
+fi
 
 DESCRIPTION="Keyboard-driven, vim-like browser based on PyQt5 and QtWebEngine"
-HOMEPAGE="https://www.qutebrowser.org/ https://github.com/qutebrowser/qutebrowser"
-EGIT_REPO_URI="https://github.com/${PN}/${PN}.git"
+HOMEPAGE="https://www.qutebrowser.org/"
 
 LICENSE="GPL-3+"
 SLOT="0"
-IUSE="scripts test"
+IUSE="+adblock widevine"
 
-BDEPEND="
-	app-text/asciidoc"
 RDEPEND="
-	dev-python/attrs[${PYTHON_USEDEP}]
-	dev-python/colorama[${PYTHON_USEDEP}]
-	dev-python/cssutils[${PYTHON_USEDEP}]
+	dev-qt/qtcore:5[icu]
+	dev-qt/qtgui:5[png]
 	$(python_gen_cond_dep 'dev-python/importlib_resources[${PYTHON_USEDEP}]' python3_8)
-	dev-python/jinja[${PYTHON_USEDEP}]
-	dev-python/markupsafe[${PYTHON_USEDEP}]
-	dev-python/pygments[${PYTHON_USEDEP}]
-	dev-python/pypeg2[${PYTHON_USEDEP}]
-	dev-python/PyQt5[${PYTHON_USEDEP},dbus,declarative,multimedia,gui,network,opengl,printsupport,sql,widgets]
-	dev-python/PyQtWebEngine[${PYTHON_USEDEP}]
-	>=dev-python/pyyaml-5.4.1[${PYTHON_USEDEP},libyaml(+)]
-	dev-python/typing-extensions[${PYTHON_USEDEP}]
-	dev-python/zipp[${PYTHON_USEDEP}]
-"
-
-distutils_enable_tests setup.py
-
-# Tests restricted as the deplist (misc/requirements/requirements-tests.txt)
-# isn't complete and X11 is required in order to start up qutebrowser.
-RESTRICT="test"
-
-python_compile() {
-	${EPYTHON} scripts/asciidoc2html.py || die
-	distutils-r1_python_compile
+	$(python_gen_cond_dep '
+		>=dev-python/colorama-0.4.4[${PYTHON_USEDEP}]
+		>=dev-python/jinja-3.0.2[${PYTHON_USEDEP}]
+		>=dev-python/markupsafe-2.0.1[${PYTHON_USEDEP}]
+		dev-python/pygments[${PYTHON_USEDEP}]
+		dev-python/PyQt5[${PYTHON_USEDEP},dbus,declarative,multimedia,gui,network,opengl,printsupport,sql,widgets]
+		dev-python/PyQtWebEngine[${PYTHON_USEDEP}]
+		>=dev-python/pyyaml-5.4.1[${PYTHON_USEDEP},libyaml(+)]
+		>=dev-python/typing-extensions-3.10.0.2[${PYTHON_USEDEP}]
+		>=dev-python/zipp-3.6.0[${PYTHON_USEDEP}]
+		adblock? ( dev-python/adblock[${PYTHON_USEDEP}] )
+	')
+	widevine? ( www-plugins/chrome-binary-plugins )"
+BDEPEND="
+	app-text/asciidoc
+	$(python_gen_cond_dep '
+		test? (
+			dev-python/beautifulsoup4[${PYTHON_USEDEP}]
+			dev-python/cheroot[${PYTHON_USEDEP}]
+			dev-python/flask[${PYTHON_USEDEP}]
+			dev-python/hypothesis[${PYTHON_USEDEP}]
+			dev-python/pytest-bdd[${PYTHON_USEDEP}]
+			dev-python/pytest-mock[${PYTHON_USEDEP}]
+			dev-python/pytest-qt[${PYTHON_USEDEP}]
+			dev-python/pytest-rerunfailures[${PYTHON_USEDEP}]
+			dev-python/pytest-xvfb[${PYTHON_USEDEP}]
+			dev-python/tldextract[${PYTHON_USEDEP}]
+		)
+	')"
+
+distutils_enable_tests pytest
+
+python_prepare_all() {
+	distutils-r1_python_prepare_all
+
+	if use widevine; then
+		sed "/yield from _qtwebengine_settings_args/a\    yield '--widevine-path=${EPREFIX}/usr/$(get_libdir)/chromium-browser/WidevineCdm/_platform_specific/linux_x64/libwidevinecdm.so'" \
+			-i ${PN}/config/qtargs.py || die
+	fi
+
+	sed -i '/setup.py/d' misc/Makefile || die
+
+	[[ ${PV} != 9999 ]] || ${EPYTHON} scripts/asciidoc2html.py || die
+
+	# these plugins/tests are unnecessary here and have extra dependencies
+	sed -e '/pytest-benchmark/d;s/--benchmark[^ ]*//' \
+		-e '/pytest-instafail/d;s/--instafail//' \
+		-i pytest.ini || die
+	[[ ${PV} == 9999 ]] || rm tests/unit/scripts/test_problemmatchers.py || die
+	[[ ${PV} != 9999 ]] || rm tests/unit/scripts/test_run_vulture.py || die
 }
 
-python_compile_all() {
-	a2x -f manpage doc/${PN}.1.asciidoc || die "Failed generating man page"
+python_test() {
+	local EPYTEST_DESELECT=(
+		# end2end and other IPC tests are broken with "Name error" if
+		# socket path is over 104 characters (=124 in /var/tmp/portage)
+		# https://github.com/qutebrowser/qutebrowser/issues/888 (not just OSX)
+		tests/end2end
+		tests/unit/misc/test_ipc.py
+		# tests that don't know about our newer qtwebengine
+		tests/unit/browser/webengine/test_webenginedownloads.py::TestDataUrlWorkaround
+		tests/unit/utils/test_version.py::TestChromiumVersion
+		# needs qtwebkit and isn't skipped by default
+		tests/unit/config/test_websettings.py::test_config_init
+		# may misbehave depending on installed old python versions
+		tests/unit/misc/test_checkpyver.py::test_old_python
+	)
+	use widevine && EPYTEST_DESELECT+=( tests/unit/config/test_qtargs.py )
+
+	# skip benchmarks (incl. _tree), and warning tests broken by -Wdefault
+	epytest -k 'not _bench and not _matches_tree and not _warning'
 }
 
 python_install_all() {
-	doman doc/${PN}.1
-	domenu misc/org.${PN}.${PN}.desktop
-	doicon -s scalable icons/${PN}.svg
-
-	if use scripts; then
-		insinto /usr/share/qutebrowser/userscripts/
-		doins misc/userscripts/README.md
-		exeinto /usr/share/qutebrowser/userscripts/
-		doexe misc/userscripts/add-nextcloud-bookmarks \
-		      misc/userscripts/add-nextcloud-cookbook \
-		      misc/userscripts/cast \
-		      misc/userscripts/dmenu_qutebrowser \
-		      misc/userscripts/format_json \
-		      misc/userscripts/getbib \
-		      misc/userscripts/kodi \
-		      misc/userscripts/open_download \
-		      misc/userscripts/openfeeds \
-		      misc/userscripts/password_fill \
-		      misc/userscripts/qr \
-		      misc/userscripts/qute-bitwarden \
-		      misc/userscripts/qutedmenu \
-		      misc/userscripts/qute-keepass \
-		      misc/userscripts/qute-keepassxc \
-		      misc/userscripts/qute-lastpass \
-		      misc/userscripts/qute-pass \
-		      misc/userscripts/readability \
-		      misc/userscripts/readability-js \
-		      misc/userscripts/ripbang \
-		      misc/userscripts/rss \
-		      misc/userscripts/taskadd \
-		      misc/userscripts/tor_identity \
-		      misc/userscripts/view_in_mpv
-	fi
+	emake -f misc/Makefile DESTDIR="${D}" PREFIX="${EPREFIX}/usr" install
 
-	distutils-r1_python_install_all
+	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
 
 	optfeature "PDF display support" www-plugins/pdfjs
+
+	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 setup to use yt-dlp or youtube-dl."
+	fi
 }


             reply	other threads:[~2021-10-15 15:53 UTC|newest]

Thread overview: 201+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2021-10-15 15:53 Ionen Wolkens [this message]
  -- strict thread matches above, loose matches on Subject: below --
2025-04-12 22:17 [gentoo-commits] repo/gentoo:master commit in: www-client/qutebrowser/ Ionen Wolkens
2025-04-12 22:08 Ionen Wolkens
2025-04-12 22:08 Ionen Wolkens
2025-03-24 16:56 Ionen Wolkens
2025-03-13  6:10 Ionen Wolkens
2025-01-07  6:49 Ionen Wolkens
2025-01-01 10:20 Joonas Niilola
2024-12-15  1:06 Ionen Wolkens
2024-12-06 16:01 Ionen Wolkens
2024-11-15  2:31 Ionen Wolkens
2024-11-15  2:23 Ionen Wolkens
2024-11-13 10:16 Ionen Wolkens
2024-11-13 10:04 Ionen Wolkens
2024-11-13 10:04 Ionen Wolkens
2024-11-04 16:15 Ionen Wolkens
2024-10-23  7:13 Joonas Niilola
2024-10-12 21:14 Ionen Wolkens
2024-09-03 12:31 Ionen Wolkens
2024-09-03 12:31 Ionen Wolkens
2024-07-05 14:03 Arthur Zamarin
2024-06-25 16:36 Ionen Wolkens
2024-06-24  8:21 Joonas Niilola
2024-06-18 18:14 Ionen Wolkens
2024-06-03 19:27 Ionen Wolkens
2024-06-03 19:27 Ionen Wolkens
2024-04-15  1:17 Ionen Wolkens
2024-03-27 11:01 Ionen Wolkens
2024-03-27 11:01 Ionen Wolkens
2024-02-09  9:09 Ionen Wolkens
2024-01-09 14:08 Ionen Wolkens
2024-01-08 23:03 Ionen Wolkens
2024-01-08 12:59 Ionen Wolkens
2023-12-16 12:06 Ionen Wolkens
2023-12-08 15:55 Ionen Wolkens
2023-11-30 11:52 Ionen Wolkens
2023-11-27  8:47 Ionen Wolkens
2023-11-06 14:07 Ionen Wolkens
2023-11-01 14:03 Ionen Wolkens
2023-10-20  1:15 Ionen Wolkens
2023-10-10 20:20 Ionen Wolkens
2023-09-17  1:59 Ionen Wolkens
2023-09-15  6:08 Ionen Wolkens
2023-08-21 16:08 Ionen Wolkens
2023-08-18 20:10 Ionen Wolkens
2023-08-18 19:51 Ionen Wolkens
2023-08-18 14:34 Ionen Wolkens
2023-08-18 14:34 Ionen Wolkens
2023-08-18 14:34 Ionen Wolkens
2023-08-17  0:21 Ionen Wolkens
2023-07-25  0:10 Ionen Wolkens
2023-07-23 16:07 Ionen Wolkens
2023-07-22 12:28 Ionen Wolkens
2023-03-18 23:22 Ionen Wolkens
2023-03-18 23:22 Ionen Wolkens
2023-03-18 23:22 Ionen Wolkens
2023-03-14  5:18 Ionen Wolkens
2023-03-11 14:09 Ionen Wolkens
2023-03-11 14:09 Ionen Wolkens
2023-03-09 20:13 Ionen Wolkens
2023-03-05 16:05 Ionen Wolkens
2023-02-17 22:58 Ionen Wolkens
2023-02-17 22:58 Ionen Wolkens
2023-01-20 22:48 Ionen Wolkens
2023-01-14 12:07 Ionen Wolkens
2022-12-17 11:45 Ionen Wolkens
2022-11-04  4:14 Ionen Wolkens
2022-09-07  7:51 Michał Górny
2022-08-17 15:48 Ionen Wolkens
2022-08-03  0:22 Ionen Wolkens
2022-07-20  6:47 Ionen Wolkens
2022-07-12 22:19 Ionen Wolkens
2022-07-11 22:57 Ionen Wolkens
2022-07-07  4:39 Ionen Wolkens
2022-06-22 18:26 Ionen Wolkens
2022-06-22 18:26 Ionen Wolkens
2022-06-18  9:31 Ionen Wolkens
2022-06-16 13:16 Ionen Wolkens
2022-06-11 13:18 Ionen Wolkens
2022-06-09  3:50 Ionen Wolkens
2022-05-26 15:00 Ionen Wolkens
2022-05-26 15:00 Ionen Wolkens
2022-04-29 11:23 Ionen Wolkens
2022-04-21  4:41 Ionen Wolkens
2022-04-01 17:46 Ionen Wolkens
2022-01-20 18:10 Ionen Wolkens
2021-11-21  2:38 Ionen Wolkens
2021-11-21  2:38 Ionen Wolkens
2021-11-21  2:38 Ionen Wolkens
2021-10-22 14:35 Agostino Sarubbo
2021-10-22  7:26 Ionen Wolkens
2021-10-21 21:11 Ionen Wolkens
2021-10-21 21:11 Ionen Wolkens
2021-10-21 21:11 Ionen Wolkens
2021-10-15 15:53 Ionen Wolkens
2021-10-15 15:53 Ionen Wolkens
2021-10-15 15:53 Ionen Wolkens
2021-10-15 15:53 Ionen Wolkens
2021-10-15 15:53 Ionen Wolkens
2021-10-14 10:00 Michał Górny
2021-09-21  6:33 Ionen Wolkens
2021-09-21  6:33 Ionen Wolkens
2021-09-21  6:33 Ionen Wolkens
2021-06-30  2:05 Stefan Strogin
2021-06-18 11:40 Stefan Strogin
2021-06-18 11:40 Stefan Strogin
2021-05-22 15:28 Stefan Strogin
2021-05-22  2:40 Stefan Strogin
2021-04-27 10:54 Stefan Strogin
2021-04-22 22:30 Stefan Strogin
2021-04-08  2:33 Stefan Strogin
2021-04-08  1:31 Stefan Strogin
2021-03-20  8:25 Joonas Niilola
2021-03-12 23:45 Stefan Strogin
2021-03-12 14:50 Joonas Niilola
2021-02-15 19:12 Stefan Strogin
2021-01-06 12:48 Stefan Strogin
2021-01-06  9:41 Stefan Strogin
2020-12-24  8:48 Michał Górny
2020-12-06  0:48 Stefan Strogin
2020-12-06  0:48 Stefan Strogin
2020-10-17 23:25 Stefan Strogin
2020-10-17 23:25 Stefan Strogin
2020-09-07  8:55 David Seifert
2020-08-30 16:08 Sam James
2020-08-12  2:21 Stefan Strogin
2020-08-12  2:08 Stefan Strogin
2020-07-09 17:16 Stefan Strogin
2020-07-09 17:16 Stefan Strogin
2020-06-11  2:21 Stefan Strogin
2020-05-12 13:57 Joonas Niilola
2020-05-12 13:57 Joonas Niilola
2020-05-12 13:57 Joonas Niilola
2020-02-28  5:37 Joonas Niilola
2020-02-28  5:37 Joonas Niilola
2020-02-28  5:37 Joonas Niilola
2020-02-28  5:37 Joonas Niilola
2020-02-28  5:37 Joonas Niilola
2020-01-03  9:15 Joonas Niilola
2019-12-27 21:32 Sebastian Pipping
2019-12-10 17:25 Joonas Niilola
2019-12-10 17:25 Joonas Niilola
2019-12-10 17:25 Joonas Niilola
2019-12-10 17:25 Joonas Niilola
2019-12-10 17:25 Joonas Niilola
2019-11-17 22:10 Tim Harder
2019-09-04 14:21 Justin Bronder
2019-07-18 22:22 Justin Bronder
2019-06-18 17:24 Justin Bronder
2019-05-25  3:32 Justin Bronder
2019-04-09 21:41 Justin Bronder
2019-03-20 18:18 Justin Bronder
2019-03-11 14:11 Justin Bronder
2019-02-26 18:40 Justin Bronder
2019-02-26  2:27 Justin Bronder
2019-02-26  2:22 Justin Bronder
2019-02-26  2:17 Justin Bronder
2019-01-31  2:44 Justin Bronder
2019-01-31  2:43 Justin Bronder
2018-10-29 15:03 Justin Bronder
2018-10-10 15:08 Justin Bronder
2018-10-10 15:08 Justin Bronder
2018-10-04 16:11 Justin Bronder
2018-09-03  2:28 Justin Bronder
2018-07-11 15:23 Justin Bronder
2018-07-03 19:38 Justin Bronder
2018-06-22 14:21 Justin Bronder
2018-06-11 14:31 Justin Bronder
2018-05-29 14:37 Justin Bronder
2018-05-04 15:07 Justin Bronder
2018-03-19 14:23 Justin Bronder
2018-03-12 14:29 Justin Bronder
2018-01-24 15:35 Justin Bronder
2018-01-16 16:17 Justin Bronder
2017-11-28 13:00 Justin Bronder
2017-11-04 23:17 Justin Bronder
2017-11-04 23:17 Justin Bronder
2017-10-29 16:31 Justin Bronder
2017-10-26 21:02 Justin Bronder
2017-10-26 17:59 Justin Bronder
2017-10-26 17:44 Justin Bronder
2017-10-26 17:44 Justin Bronder
2017-10-26 17:44 Justin Bronder
2017-10-26 17:44 Justin Bronder
2017-07-14 21:03 Michał Górny
2017-05-29 13:37 Patrice Clement
2017-04-12 21:06 Michał Górny
2017-01-16 18:46 Tim Harder
2017-01-15 17:21 Patrice Clement
2016-12-09  8:34 Tim Harder
2016-11-12  5:03 Tim Harder
2016-08-06  2:18 Tim Harder
2016-07-12 17:55 Tim Harder
2016-07-12 17:55 Tim Harder
2016-05-05  5:33 Tim Harder
2016-04-12  3:14 Tim Harder
2016-04-09  2:15 Tim Harder
2016-03-15  7:38 Tim Harder
2016-03-11  3:15 Tim Harder
2015-10-26 13:38 Ian Delaney
2015-10-26  9:08 Ian Delaney

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=1634312635.0b8b467249ed31d90aaeb9e535d039c08379bafa.ionen@gentoo \
    --to=ionen@gentoo.org \
    --cc=gentoo-commits@lists.gentoo.org \
    --cc=gentoo-dev@lists.gentoo.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox