* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-03-10 21:10 Miroslav Šulc
  0 siblings, 0 replies; 6663+ messages in thread
From: Miroslav Šulc @ 2024-03-10 21:10 UTC (permalink / raw
  To: gentoo-commits
commit:     ece8a551eed30f9fa366d10f9a1e8d69451eb01c
Author:     Volkmar W. Pogatzki <gentoo <AT> pogatzki <DOT> net>
AuthorDate: Thu Feb 29 06:18:36 2024 +0000
Commit:     Miroslav Šulc <fordfrog <AT> gentoo <DOT> org>
CommitDate: Sun Mar 10 21:10:09 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=ece8a551
ant-tasks.eclass: @DEPRECATED
all packages which inherit ant-tasks.eclass are PMASKED for removal
Signed-off-by: Volkmar W. Pogatzki <gentoo <AT> pogatzki.net>
Signed-off-by: Miroslav Šulc <fordfrog <AT> gentoo.org>
 eclass/ant-tasks.eclass | 3 ++-
 1 file changed, 2 insertions(+), 1 deletion(-)
diff --git a/eclass/ant-tasks.eclass b/eclass/ant-tasks.eclass
index d599238ba253..c1a82ccbab5b 100644
--- a/eclass/ant-tasks.eclass
+++ b/eclass/ant-tasks.eclass
@@ -1,6 +1,7 @@
-# Copyright 2007-2023 Gentoo Authors
+# Copyright 2007-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
+# @DEPRECATED:
 # @ECLASS: ant-tasks.eclass
 # @MAINTAINER:
 # java@gentoo.org
^ permalink raw reply related	[flat|nested] 6663+ messages in thread
* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-04-30 18:34 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-04-30 18:34 UTC (permalink / raw
  To: gentoo-commits
commit:     88c9b8245a62a58c2a5ad72d83af880d34dab644
Author:     Lucio Sauer <watermanpaint <AT> posteo <DOT> net>
AuthorDate: Fri Apr 12 10:45:14 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Tue Apr 30 18:18:34 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=88c9b824
stardict.eclass: inline mirror://sourceforge
bump copyright to 2024
Signed-off-by: Lucio Sauer <watermanpaint <AT> posteo.net>
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/stardict.eclass | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/eclass/stardict.eclass b/eclass/stardict.eclass
index 080c01f92470..b69310c7cb18 100644
--- a/eclass/stardict.eclass
+++ b/eclass/stardict.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2023 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: stardict.eclass
@@ -48,7 +48,7 @@ if [[ -n ${FROM_LANG} && -n ${TO_LANG} ]]; then
 fi
 
 HOMEPAGE="http://stardict.sourceforge.net/"
-SRC_URI="mirror://sourceforge/stardict/${DICT_P}.tar.bz2"
+SRC_URI="https://downloads.sourceforge.net/stardict/${DICT_P}.tar.bz2"
 S="${WORKDIR}/${DICT_P}"
 
 LICENSE="GPL-2"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-04-30 19:19 Alfredo Tupone
  0 siblings, 0 replies; 6663+ messages in thread
From: Alfredo Tupone @ 2024-04-30 19:19 UTC (permalink / raw
  To: gentoo-commits
commit:     74414ea0c4d70c96bbec234df290d7e5f14d8f51
Author:     Alfredo Tupone <tupone <AT> gentoo <DOT> org>
AuthorDate: Fri Mar 22 18:02:23 2024 +0000
Commit:     Alfredo Tupone <tupone <AT> gentoo <DOT> org>
CommitDate: Tue Apr 30 19:19:19 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=74414ea0
toolchain.eclass: To make "tc_has_feature ada" actually work
tc_has_feature ada is used to add BDEPEND on a ada compiler,.
Without setting TC_FEATURES the test does not work
Signed-off-by: Alfredo Tupone <tupone <AT> gentoo.org>
 eclass/toolchain.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index f475b76c8de1..b51f146ce25b 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -300,7 +300,7 @@ if [[ ${PN} != kgcc64 && ${PN} != gcc-* ]] ; then
 	IUSE+=" go"
 	IUSE+=" +sanitize"  TC_FEATURES+=( sanitize )
 	IUSE+=" graphite" TC_FEATURES+=( graphite )
-	IUSE+=" ada"
+	IUSE+=" ada" TC_FEATURES+=( ada )
 	IUSE+=" vtv"
 	IUSE+=" jit"
 	IUSE+=" +pie +ssp pch"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-04-30 19:25 Alfredo Tupone
  0 siblings, 0 replies; 6663+ messages in thread
From: Alfredo Tupone @ 2024-04-30 19:25 UTC (permalink / raw
  To: gentoo-commits
commit:     c84ba1bebef686f74503ec61c9b8eb86ed2adbff
Author:     Alfredo Tupone <tupone <AT> gentoo <DOT> org>
AuthorDate: Fri Mar 22 18:02:23 2024 +0000
Commit:     Alfredo Tupone <tupone <AT> gentoo <DOT> org>
CommitDate: Tue Apr 30 19:24:58 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=c84ba1be
Building the ada compiler require both c++ and ada USE flags enabled.
Otherwise drop ada.
Signed-off-by: Alfredo Tupone <tupone <AT> gentoo.org>
 eclass/toolchain.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index b51f146ce25b..4d057de7a0f3 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -2507,7 +2507,7 @@ _tc_use_if_iuse() {
 
 is_ada() {
 	gcc-lang-supported ada || return 1
-	_tc_use_if_iuse ada
+	_tc_use_if_iuse cxx && _tc_use_if_iuse ada
 }
 
 is_cxx() {
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-01  0:27 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-05-01  0:27 UTC (permalink / raw
  To: gentoo-commits
commit:     8724e2f4b41d72d2442c1efd3b340bf9879971a0
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Apr 30 03:18:17 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed May  1 00:26:21 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=8724e2f4
toolchain.eclass: add TODO for JIT
Suggested by Arsen.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 1 +
 1 file changed, 1 insertion(+)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 645e18ff27ca..9887bc40c8d9 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1893,6 +1893,7 @@ gcc_do_make() {
 
 #---->> src_test <<----
 
+# TODO: add JIT testing
 toolchain_src_test() {
 	# GCC's testsuite is a special case.
 	#
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-01  0:27 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-05-01  0:27 UTC (permalink / raw
  To: gentoo-commits
commit:     467c2e2e91f66157ebfc278d7726827c3d8a6e3b
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Apr 30 03:16:07 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed May  1 00:26:20 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=467c2e2e
toolchain.eclass: iterate over older slots if test manifest doesn't exist
Iterate over all known slots (at least those using the "new" SLOT value
from --with-major-version-only since ~GCC 10 in Gentoo) if we couldn't
find a test manifest for GCC_TESTS_COMPARISON_SLOT, rather than expecting
pristine results.
This makes life easier when installing a new slot (or newly enabling
tests for one). It's *particularly* useful, I think, for arch testers
who might want to establish a baseline once but not have to keep doing
it across many chroots for each new slot.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 12 +++++++++++-
 1 file changed, 11 insertions(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 4d057de7a0f3..645e18ff27ca 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1930,7 +1930,17 @@ toolchain_src_test() {
 		--manifest="${T}"/${CHOST}.xfail \
 		--produce_manifest &> /dev/null
 
-	local manifest="${GCC_TESTS_COMPARISON_DIR}/${GCC_TESTS_COMPARISON_SLOT}/${CHOST}.xfail"
+	# If there's no manifest available, check older slots, as it's better
+	# than nothing. We start with 10 for the fallback as the first version
+	# we started using --with-major-version-only.
+	local possible_slot
+	for possible_slot in "${GCC_TESTS_COMPARISON_SLOT}" $(seq ${SLOT} -1 10) ; do
+		[[ -f "${GCC_TESTS_COMPARISON_DIR}/${possible_slot}/${CHOST}.xfail" ]] && break
+	done
+	if [[ ${possible_slot} != "${GCC_TESTS_COMPARISON_SLOT}" ]] ; then
+		ewarn "Couldn't find manifest for ${GCC_TESTS_COMPARISON_SLOT}; falling back to ${possible_slot}"
+	fi
+	local manifest="${GCC_TESTS_COMPARISON_DIR}/${possible_slot}/${CHOST}.xfail"
 
 	if [[ -f "${manifest}" ]] ; then
 		# TODO: Distribute some baseline results in e.g. gcc-patches.git?
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-01  3:02 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-05-01  3:02 UTC (permalink / raw
  To: gentoo-commits
commit:     dca524fbf33c5cf70f912d28b344d9bc82e8ba4e
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed May  1 02:34:02 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed May  1 02:34:02 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=dca524fb
toolchain.eclass: add another TODO for tests (multilib)
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 1 +
 1 file changed, 1 insertion(+)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index b2db0f96850a..12d31d20d914 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1894,6 +1894,7 @@ gcc_do_make() {
 #---->> src_test <<----
 
 # TODO: add JIT testing
+# TODO: add multilib testing
 toolchain_src_test() {
 	# GCC's testsuite is a special case.
 	#
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-02  0:24 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-05-02  0:24 UTC (permalink / raw
  To: gentoo-commits
commit:     dcea0f85eec14d826f5704e25f757d05fe420668
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu May  2 00:24:02 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu May  2 00:24:02 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=dcea0f85
toolchain.eclass: fix validate_failures.py cp for non-gcc
Thanks to matoro for reporting.
Fixes: 5e9a0a17e43d3f5d7d7c1e3a8a7e58f8d26861cf
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 12d31d20d914..25dedd4e5262 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -633,7 +633,7 @@ toolchain_src_prepare() {
 	fi
 
 	if use test ; then
-		cp "${DISTDIR}"/${PN}-validate-failures-${GCC_VALIDATE_FAILURES_VERSION}.py "${T}"/validate_failures.py || die
+		cp "${DISTDIR}"/gcc-validate-failures-${GCC_VALIDATE_FAILURES_VERSION}.py "${T}"/validate_failures.py || die
 		chmod +x "${T}"/validate_failures.py || die
 	fi
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-02 17:44 Florian Schmaus
  0 siblings, 0 replies; 6663+ messages in thread
From: Florian Schmaus @ 2024-05-02 17:44 UTC (permalink / raw
  To: gentoo-commits
commit:     8e1f6270338817598e4ce37e7fc1aa3826298970
Author:     Florian Schmaus <flow <AT> gentoo <DOT> org>
AuthorDate: Wed May  1 08:33:44 2024 +0000
Commit:     Florian Schmaus <flow <AT> gentoo <DOT> org>
CommitDate: Thu May  2 17:44:17 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=8e1f6270
texlive-module.eclass: install man pages in right location
The TeX Live packages under dev-texlive/* currently do not install the
man pages in the right location. They are under
/usr/share/texmf-dist/doc/man.
Install them at the right location using doman.
Having dev-texlive/* packages installing man pages requires that we
filter man pages already installed by app-text/texlive-core to avoid
file collisions. As a consequence, unfortunately, we have to hard code
the list of man pages installed by texlive-core. Or, at least, folks
from #-tex and myself could not come up with a solution that does not
require hard coding that list.
Thanks to ulm for providing feedback.
Signed-off-by: Florian Schmaus <flow <AT> gentoo.org>
Thanks-to: Ulrich Müller <ulm <AT> gentoo.org>
 eclass/texlive-module.eclass | 187 +++++++++++++++++++++++++++++++++++++++++++
 1 file changed, 187 insertions(+)
diff --git a/eclass/texlive-module.eclass b/eclass/texlive-module.eclass
index 401b75bc4d11..da33e25a39dc 100644
--- a/eclass/texlive-module.eclass
+++ b/eclass/texlive-module.eclass
@@ -359,6 +359,193 @@ texlive-module_src_install() {
 		if [[ -d texmf-doc ]]; then
 			cp -pR texmf-doc "${ED}/usr/share/" || die
 		fi
+
+		if ver_test -ge 2023 && [[ ${CATEGORY} == dev-texlive ]]; then
+			local texlive_core_man_pages=(
+				afm2pl.1
+				aleph.1
+				allcm.1
+				allec.1
+				allneeded.1
+				amstex.1
+				autosp.1
+				axohelp.1
+				bibtex.1
+				chkdvifont.1
+				chktex.1
+				chkweb.1
+				ctangle.1
+				ctie.1
+				ctwill.1
+				ctwill-refsort.1
+				ctwill-twinx.1
+				cweave.1
+				cweb.1
+				detex.1
+				devnag.1
+				deweb.1
+				disdvi.1
+				dt2dv.1
+				dv2dt.1
+				dvi2fax.1
+				dvi2tty.1
+				dvibook.1
+				dviconcat.1
+				dvicopy.1
+				dvidvi.1
+				dvihp.1
+				dvilj.1
+				dvilj2p.1
+				dvilj4.1
+				dvilj4l.1
+				dvilj6.1
+				dvilualatex-dev.1
+				dviluatex.1
+				dvipdfm.1
+				dvipdfmx.1
+				dvipdft.1
+				dvipos.1
+				dvired.1
+				dviselect.1
+				dvispc.1
+				dvitodvi.1
+				dvitomp.1
+				dvitype.1
+				e2pall.1
+				ebb.1
+				eptex.1
+				euptex.1
+				extractbb.1
+				fmtutil.1
+				fmtutil.cnf.5
+				fmtutil-sys.1
+				fontinst.1
+				gftodvi.1
+				gftopk.1
+				gftype.1
+				gsftopk.1
+				hishrink.1
+				histretch.1
+				hitex.1
+				inimf.1
+				initex.1
+				kpsepath.1
+				kpsetool.1
+				kpsewhere.1
+				kpsexpand.1
+				lacheck.1
+				latex.1
+				latex-dev.1
+				luahbtex.1
+				luajittex.1
+				lualatex-dev.1
+				luatex.1
+				makeindex.1
+				makejvf.1
+				mendex.1
+				mf.1
+				mf-nowin.1
+				mft.1
+				mkindex.1
+				mkocp.1
+				mkofm.1
+				mktexfmt.1
+				mktexlsr.1
+				mktexmf.1
+				mktexpk.1
+				mktextfm.1
+				mpost.1
+				msxlint.1
+				odvicopy.1
+				odvitype.1
+				ofm2opl.1
+				opl2ofm.1
+				otangle.1
+				otp2ocp.1
+				outocp.1
+				ovf2ovp.1
+				ovp2ovf.1
+				patgen.1
+				pbibtex.1
+				pdfclose.1
+				pdfetex.1
+				pdflatex.1
+				pdflatex-dev.1
+				pdfopen.1
+				pdftex.1
+				pdftosrc.1
+				pktogf.1
+				pktype.1
+				platex-dev.1
+				pltotf.1
+				pmxab.1
+				pooltype.1
+				ppltotf.1
+				prepmx.1
+				ps2frag.1
+				pslatex.1
+				ptex.1
+				ptftopl.1
+				rubibtex.1
+				rumakeindex.1
+				scor2prt.1
+				synctex.1
+				synctex.5
+				tangle.1
+				tex.1
+				tex2aspc.1
+				texconfig.1
+				texconfig-sys.1
+				texhash.1
+				texlinks.1
+				texlua.1
+				texluac.1
+				tftopl.1
+				tie.1
+				tpic2pdftex.1
+				ttf2afm.1
+				ttfdump.1
+				twill.1
+				upbibtex.1
+				updmap.1
+				updmap.cfg.5
+				updmap-sys.1
+				uplatex-dev.1
+				uppltotf.1
+				uptex.1
+				uptftopl.1
+				vftovp.1
+				vlna.1
+				vptovf.1
+				weave.1
+				xdvipdfmx.1
+				xelatex-dev.1
+				xetex.1
+				xml2pmx.1
+			)
+			local f
+			local grep_expressions=()
+			# Transform texlive_core_man_pages into grep expressions
+			# that will be used to filter out any man page that is
+			# already installed by app-text/texlive-core.
+			for f in "${texlive_core_man_pages[@]}"; do
+				# Ensure that all dots are escaped so that they are
+				# matched literarily. Also wrap the file in '/' and '$'
+				# within the expression.
+				grep_expressions+=(-e "/${f//./\\.}\$")
+			done
+
+			ebegin "Installing man pages"
+			find texmf-dist/doc/man -type f -name '*.[0-9n]' -print |
+				grep -v "${grep_expressions[@]}" |
+				xargs -d '\n' --no-run-if-empty doman
+			[[ "${PIPESTATUS[*]}" =~ ^0(" 0")*$ ]]
+			eend $? || die "error installing man pages"
+
+			# Delete all man pages under texmf-dist/doc/man
+			find texmf-dist/doc/man -type f -name '*.[0-9n]' -delete ||
+				die "error deleting man pages under texmf-dist"
+		fi
 	else
 		if [[ -d texmf-dist/doc ]]; then
 			rm -rf texmf-dist/doc || die
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-03  2:48 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-05-03  2:48 UTC (permalink / raw
  To: gentoo-commits
commit:     2a0d96794900df3d0b2c25734cd5471468bd3fb0
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu May  2 22:43:24 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May  3 02:48:24 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=2a0d9679
xorg-3.eclass: cleanup autotools logic a bit more
EAUTORECONF_DEPENDS is always empty since 3db70e9c014e415ae38a713b47cf7b299fd11945.
Fixes: 3db70e9c014e415ae38a713b47cf7b299fd11945
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/xorg-3.eclass | 2 --
 1 file changed, 2 deletions(-)
diff --git a/eclass/xorg-3.eclass b/eclass/xorg-3.eclass
index dde954ca77aa..21cddc92773d 100644
--- a/eclass/xorg-3.eclass
+++ b/eclass/xorg-3.eclass
@@ -137,9 +137,7 @@ if [[ ${PN} != util-macros ]] ; then
 	# Required even by xorg-server
 	[[ ${PN} == "font-util" ]] || EAUTORECONF_DEPEND+=" >=media-fonts/font-util-1.2.0"
 fi
-BDEPEND+=" ${EAUTORECONF_DEPENDS}"
 [[ ${XORG_EAUTORECONF} != no ]] && BDEPEND+=" ${EAUTORECONF_DEPEND}"
-unset EAUTORECONF_DEPENDS
 unset EAUTORECONF_DEPEND
 
 # @ECLASS_VARIABLE: FONT_DIR
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-03  2:48 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-05-03  2:48 UTC (permalink / raw
  To: gentoo-commits
commit:     6c5bb90fca515fb854e5c567decd7528df32f354
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu May  2 22:45:02 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May  3 02:48:31 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=6c5bb90f
xorg-3.eclass: conditionalize autotools deps on XORG_EAUTORECONF
xorg-3.eclass only calls autoreconf if XORG_EAUTORECONF is set, although
the logic got cleaned up more in fae3e3b3eeec2d252ad42afeba11ac8ffeb70c42.
We therefore don't need to depend on autoconf, automake, etc unless
XORG_EAUTORECONF is set. Set AUTOTOOLS_AUTO_DEPEND from autotools.eclass
to opt-out of the auto dependencies and use the AUTOTOOLS_DEPEND variable
it sets when XORG_EAUTORECONF.
Note that libtool.eclass still adds a dep on elt-patches so we're OK
for that part (we call elibtoolize where we can).
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/xorg-3.eclass | 5 ++---
 1 file changed, 2 insertions(+), 3 deletions(-)
diff --git a/eclass/xorg-3.eclass b/eclass/xorg-3.eclass
index 21cddc92773d..ee4038533bfd 100644
--- a/eclass/xorg-3.eclass
+++ b/eclass/xorg-3.eclass
@@ -58,6 +58,7 @@ fi
 : "${XORG_MULTILIB:="no"}"
 
 # we need to inherit autotools first to get the deps
+AUTOTOOLS_AUTO_DEPEND=no
 inherit autotools libtool multilib toolchain-funcs flag-o-matic \
 	${FONT_ECLASS} ${GIT_ECLASS}
 unset FONT_ECLASS GIT_ECLASS
@@ -129,9 +130,7 @@ fi
 
 # Set up autotools shared dependencies
 # Remember that all versions here MUST be stable
-EAUTORECONF_DEPEND+="
-	>=dev-build/libtool-2.2.6a
-	sys-devel/m4"
+EAUTORECONF_DEPEND+=" ${AUTOTOOLS_DEPEND}"
 if [[ ${PN} != util-macros ]] ; then
 	EAUTORECONF_DEPEND+=" >=x11-misc/util-macros-1.18"
 	# Required even by xorg-server
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-03 11:43 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-05-03 11:43 UTC (permalink / raw
  To: gentoo-commits
commit:     1bb3b5e672ba80e446b4c9dc27918a80c97c1be9
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri May  3 11:40:27 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May  3 11:40:59 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=1bb3b5e6
gnuconfig.eclass: drop EAPI 5 support
autotools.eclass hasn't had EAPI 5 support for ~2 years since
50710f3d0e8f19fab5571d9596c336314e96b5cf so this wasn't being used
anyway (non-autotools.eclass use of gnuconfig.eclass is very niche).
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/gnuconfig.eclass | 8 ++++----
 1 file changed, 4 insertions(+), 4 deletions(-)
diff --git a/eclass/gnuconfig.eclass b/eclass/gnuconfig.eclass
index df3c74867608..fb73087aeacf 100644
--- a/eclass/gnuconfig.eclass
+++ b/eclass/gnuconfig.eclass
@@ -6,7 +6,7 @@
 # Sam James <sam@gentoo.org>
 # @AUTHOR:
 # Will Woods <wwoods@gentoo.org>
-# @SUPPORTED_EAPIS: 5 6 7 8
+# @SUPPORTED_EAPIS: 6 7 8
 # @BLURB: Refresh bundled gnuconfig files (config.guess, config.sub)
 # @DESCRIPTION:
 # This eclass is used to automatically update files that typically come with
@@ -17,7 +17,7 @@
 #
 
 case ${EAPI:-0} in
-	5|6|7|8) ;;
+	6|7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
@@ -39,7 +39,7 @@ GNUCONFIG_DEPEND="sys-devel/gnuconfig"
 : "${GNUCONFIG_AUTO_DEPEND:=yes}"
 if [[ ${GNUCONFIG_AUTO_DEPEND} != "no" ]] ; then
 	case ${EAPI} in
-		5|6) DEPEND=${GNUCONFIG_DEPEND} ;;
+		6) DEPEND=${GNUCONFIG_DEPEND} ;;
 		*) BDEPEND=${GNUCONFIG_DEPEND} ;;
 	esac
 fi
@@ -122,7 +122,7 @@ gnuconfig_findnewest() {
 	local prefix
 
 	case ${EAPI} in
-		5|6)
+		6)
 			prefix="${EPREFIX}"
 			;;
 		*)
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-03 11:43 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-05-03 11:43 UTC (permalink / raw
  To: gentoo-commits
commit:     59b986917e336e0e161ef75bcc0b29b3357686d9
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri May  3 03:20:15 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May  3 11:40:08 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=59b98691
gnuconfig.eclass: add GNUCONFIG_DEPEND
The motivation here is to allow autotools.eclass consumers setting
AUTOTOOLS_AUTO_DEPEND=no to not have a useless gnuconfig dependency.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/gnuconfig.eclass | 22 +++++++++++++++++++---
 1 file changed, 19 insertions(+), 3 deletions(-)
diff --git a/eclass/gnuconfig.eclass b/eclass/gnuconfig.eclass
index 0791798632cd..df3c74867608 100644
--- a/eclass/gnuconfig.eclass
+++ b/eclass/gnuconfig.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2022 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: gnuconfig.eclass
@@ -24,9 +24,25 @@ esac
 if [[ -z ${_GNUCONFIG_ECLASS} ]] ; then
  _GNUCONFIG_CLASS=1
 
-BDEPEND="sys-devel/gnuconfig"
+# @ECLASS_VARIABLE: GNUCONFIG_DEPEND
+# @OUTPUT_VARIABLE
+# @DESCRIPTION:
+# Contains dependency on gnuconfig in *DEPEND format.
+GNUCONFIG_DEPEND="sys-devel/gnuconfig"
 
-[[ ${EAPI} == [56] ]] && DEPEND="${BDEPEND}"
+# @ECLASS_VARIABLE: GNUCONFIG_AUTO_DEPEND
+# @PRE_INHERIT
+# @DESCRIPTION:
+# Set to 'no' to disable automatically adding to DEPEND.  This lets
+# ebuilds form conditional depends by using ${GNUCONFIG_DEPEND} in
+# their own DEPEND string.
+: "${GNUCONFIG_AUTO_DEPEND:=yes}"
+if [[ ${GNUCONFIG_AUTO_DEPEND} != "no" ]] ; then
+	case ${EAPI} in
+		5|6) DEPEND=${GNUCONFIG_DEPEND} ;;
+		*) BDEPEND=${GNUCONFIG_DEPEND} ;;
+	esac
+fi
 
 # @FUNCTION: gnuconfig_update
 # @USAGE: [file1 file2 ...]
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-03 11:43 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-05-03 11:43 UTC (permalink / raw
  To: gentoo-commits
commit:     691f40a3f2455e23e27c630b7658dd07428ac44a
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri May  3 03:22:15 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May  3 11:40:09 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=691f40a3
autotools.eclass: conditionalize gnuconfig dependency
Use newly-added GNUCONFIG_DEPEND so that AUTOTOOLS_AUTO_DEPEND=no doesn't
result in a useless dependency on gnuconfig.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/autotools.eclass | 8 ++++++--
 1 file changed, 6 insertions(+), 2 deletions(-)
diff --git a/eclass/autotools.eclass b/eclass/autotools.eclass
index 1ced771c5345..a456e9b9f589 100644
--- a/eclass/autotools.eclass
+++ b/eclass/autotools.eclass
@@ -33,6 +33,7 @@ _AUTOTOOLS_ECLASS=1
 
 [[ ${EAPI} == 6 ]] && inherit eqawarn
 
+GNUCONFIG_AUTO_DEPEND=no
 inherit gnuconfig libtool
 
 # @ECLASS_VARIABLE: WANT_AUTOCONF
@@ -164,9 +165,12 @@ fi
 # @DESCRIPTION:
 # Contains the combination of requested automake/autoconf/libtool
 # versions in *DEPEND format.
-AUTOTOOLS_DEPEND="${_automake_atom}
+AUTOTOOLS_DEPEND="
+	${GNUCONFIG_DEPEND}
+	${_automake_atom}
 	${_autoconf_atom}
-	${_libtool_atom}"
+	${_libtool_atom}
+"
 RDEPEND=""
 
 # @ECLASS_VARIABLE: AUTOTOOLS_AUTO_DEPEND
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-04 19:57 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-05-04 19:57 UTC (permalink / raw
  To: gentoo-commits
commit:     20895df96333b30e3a803de12e64f75b40125ef1
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat May  4 14:53:35 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat May  4 19:56:58 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=20895df9
llvm.org.eclass: Remove old snapshot support
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 6 ------
 1 file changed, 6 deletions(-)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index 3d133f855380..0f8d55bb0578 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -75,12 +75,6 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 				19.0.0_pre20240427)
 					EGIT_COMMIT=338561657685c1831a53563b1bc36ffc7470239e
 					;;
-				19.0.0_pre20240420)
-					EGIT_COMMIT=f03cd2db91956456f1c5e2da86d3c50183eebd28
-					;;
-				19.0.0_pre20240410)
-					EGIT_COMMIT=ee284d2da0720dc21191d6f545504cbfcf5dcbcf
-					;;
 				*)
 					die "Unknown snapshot: ${PV}"
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-04 19:57 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-05-04 19:57 UTC (permalink / raw
  To: gentoo-commits
commit:     7bc977bbafc2221fed92c92a145c179e5dd3bdd0
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat May  4 19:24:35 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat May  4 19:56:59 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=7bc977bb
llvm.org.eclass: Add 19.0.0_pre20240504 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index 0f8d55bb0578..623a7c1f3f4a 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -72,6 +72,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 			_LLVM_SOURCE_TYPE=snapshot
 
 			case ${PV} in
+				19.0.0_pre20240504)
+					EGIT_COMMIT=76aa042dde6ba9ba57c680950f5818259ee02690
+					;;
 				19.0.0_pre20240427)
 					EGIT_COMMIT=338561657685c1831a53563b1bc36ffc7470239e
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-06  4:39 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-05-06  4:39 UTC (permalink / raw
  To: gentoo-commits
commit:     46c037e3f73d1b9d19c996d091c2f8b2d6fc5812
Author:     Eli Schwartz <eschwartz93 <AT> gmail <DOT> com>
AuthorDate: Sun May  5 20:57:36 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon May  6 04:39:26 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=46c037e3
stardict.eclass: stop optionally depending on stardict
Since commit cb140e2e6bf42b5ca7f88f53afd2806c252a6ac4 it hasn't been
available and was in fact removed for being completely dead. There's no
real point in asking for it in the eclass.
Signed-off-by: Eli Schwartz <eschwartz93 <AT> gmail.com>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/stardict.eclass | 5 +----
 1 file changed, 1 insertion(+), 4 deletions(-)
diff --git a/eclass/stardict.eclass b/eclass/stardict.eclass
index b69310c7cb18..bd7080ea1229 100644
--- a/eclass/stardict.eclass
+++ b/eclass/stardict.eclass
@@ -56,10 +56,7 @@ SLOT="0"
 IUSE="+zlib"
 
 BDEPEND="
-	|| (
-		>=app-text/stardict-2.4.2
-		app-text/sdcv
-	)
+	app-text/sdcv
 	zlib? (
 		app-arch/gzip
 		app-text/dictd
^ permalink raw reply related	[flat|nested] 6663+ messages in thread
* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-06 17:11 Ionen Wolkens
  0 siblings, 0 replies; 6663+ messages in thread
From: Ionen Wolkens @ 2024-05-06 17:11 UTC (permalink / raw
  To: gentoo-commits
commit:     25df2b9b57d98be95930ec595206af60db6c340a
Author:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
AuthorDate: Mon May  6 16:53:43 2024 +0000
Commit:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
CommitDate: Mon May  6 17:07:25 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=25df2b9b
linux-mod-r1.eclass: update depmod --config paths for kmod-32
kmod-32's tools/depmod.c adds 'DISTCONFDIR "/depmod.d"' which
is $prefix/lib/depmod.d.
Largely a no-op on merged-usr because of the /lib -> /usr/lib symlink,
but could potentially impact split-usr if both directories get used
(albeit this is only used when a different ROOT is used).
Ordering matches the current depmod.c (etc first, then run, etc...).
On a side-note, kmod-32 also now has configurable /lib/modules path
albeit this is not done on Gentoo at the moment (the default without
the prefix is used). May need updates in the future to figure out
which to use though.
Don't believe this is worth a ML review.
Signed-off-by: Ionen Wolkens <ionen <AT> gentoo.org>
 eclass/linux-mod-r1.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/linux-mod-r1.eclass b/eclass/linux-mod-r1.eclass
index 8d384c2b30c8..4b267aae4db1 100644
--- a/eclass/linux-mod-r1.eclass
+++ b/eclass/linux-mod-r1.eclass
@@ -1260,7 +1260,7 @@ _modules_update_depmod() {
 
 				# EROOT from -b is not used when looking for configuration
 				# directories, so pass the whole list from kmod's tools/depmod.c
-				--config="${EROOT}"/{etc,run,usr/local/lib,lib}/depmod.d
+				--config="${EROOT}"/{etc,run,{usr/{local/,},}lib}/depmod.d
 			)
 
 		nonfatal edob depmod "${depmodargs[@]}" && return 0
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-06 17:28 Ulrich Müller
  0 siblings, 0 replies; 6663+ messages in thread
From: Ulrich Müller @ 2024-05-06 17:28 UTC (permalink / raw
  To: gentoo-commits
commit:     4af0ecd6a4b3b781a92e98d2b8e302b5852f7034
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Sun May  5 13:11:01 2024 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Mon May  6 17:28:05 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=4af0ecd6
Revert "elisp-common.eclass: Set no-native-compile in generated files"
"no-byte-compile: t" implies "no-native-compile: t", therefore this was
redundant.
This reverts commit 2ab9bda58e464656cdf1e31b7e8b293cf1ec0caf.
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 eclass/elisp-common.eclass | 2 --
 1 file changed, 2 deletions(-)
diff --git a/eclass/elisp-common.eclass b/eclass/elisp-common.eclass
index 3d99838a0221..8b4c1be99bb7 100644
--- a/eclass/elisp-common.eclass
+++ b/eclass/elisp-common.eclass
@@ -333,7 +333,6 @@ elisp-make-autoload-file() {
 	;; Local ${null}Variables:
 	;; version-control: never
 	;; no-byte-compile: t
-	;; no-native-compile: t
 	;; no-update-autoloads: t
 	;; End:
 
@@ -723,7 +722,6 @@ elisp-site-regen() {
 
 	;; Local ${null}Variables:
 	;; no-byte-compile: t
-	;; no-native-compile: t
 	;; buffer-read-only: t
 	;; End:
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-06 17:28 Ulrich Müller
  0 siblings, 0 replies; 6663+ messages in thread
From: Ulrich Müller @ 2024-05-06 17:28 UTC (permalink / raw
  To: gentoo-commits
commit:     b935d9a5dabe2facdf27d7715d5b72cf5dad561d
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Sun May  5 13:10:45 2024 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Mon May  6 17:28:06 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=b935d9a5
elisp-common.eclass: Add lexical-binding cookies to generated Lisp files
This suppresses the warning spam in recent Emacs from Git.
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 eclass/elisp-common.eclass | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/eclass/elisp-common.eclass b/eclass/elisp-common.eclass
index 8b4c1be99bb7..ad9d3c7e60c6 100644
--- a/eclass/elisp-common.eclass
+++ b/eclass/elisp-common.eclass
@@ -322,7 +322,7 @@ elisp-make-autoload-file() {
 	ebegin "Generating autoload file for GNU Emacs"
 
 	cat >"${f}" <<-EOF
-	;;; ${f##*/} --- autoloads for ${PN}
+	;;; ${f##*/} --- autoloads for ${PN}  -*-lexical-binding:t-*-
 
 	;;; Commentary:
 	;; Automatically generated by elisp-common.eclass
@@ -705,7 +705,7 @@ elisp-site-regen() {
 	done
 
 	cat <<-EOF >"${T}"/site-gentoo.el || ret=$?
-	;;; site-gentoo.el --- site initialisation for Gentoo-installed packages
+	;;; site-gentoo.el --- Gentoo site initialisation  -*-lexical-binding:t-*-
 
 	;;; Commentary:
 	;; Automatically generated by elisp-common.eclass
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-07  7:57 Andreas K. Hüttel
  0 siblings, 0 replies; 6663+ messages in thread
From: Andreas K. Hüttel @ 2024-05-07  7:57 UTC (permalink / raw
  To: gentoo-commits
commit:     fc4b35b62d9846c2f5c157225cb35f295badf73a
Author:     Andreas K. Hüttel <dilfridge <AT> gentoo <DOT> org>
AuthorDate: Mon Apr 22 00:57:53 2024 +0000
Commit:     Andreas K. Hüttel <dilfridge <AT> gentoo <DOT> org>
CommitDate: Tue May  7 07:55:32 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=fc4b35b6
perl-module.eclass: Implement dependency on PERL_FEATURES
Signed-off-by: Andreas K. Hüttel <dilfridge <AT> gentoo.org>
 eclass/perl-module.eclass | 47 ++++++++++++++++++++++++++++++++++++-----------
 1 file changed, 36 insertions(+), 11 deletions(-)
diff --git a/eclass/perl-module.eclass b/eclass/perl-module.eclass
index 7bb02abed8c5..029fc78e4a85 100644
--- a/eclass/perl-module.eclass
+++ b/eclass/perl-module.eclass
@@ -44,6 +44,28 @@ esac
 # a use-conditional build time dependency on virtual/perl-Test-Simple, and
 # the required RESTRICT setting.
 
+# @ECLASS_VARIABLE: PERL_USEDEP
+# @OUTPUT_VARIABLE
+# @DESCRIPTION:
+# An eclass-generated USE-dependency string for the features of the
+# installed Perl. While by far not as critical as for Python, this should
+# be used to depend at least on Perl packages installing compiled
+# (binary) files.
+#
+# Example use:
+# @CODE
+# RDEPEND=dev-perl/DBI[${PERL_USEDEP}]
+# @CODE
+#
+# Example value:
+# @CODE
+# perl_features_debug=,perl_features_ithreads=,perl_features_quadmath=
+# @CODE
+PERL_USEDEP="perl_features_debug=,perl_features_ithreads=,perl_features_quadmath="
+
+GENTOO_PERL_DEPSTRING=" || ( >=dev-lang/perl-5.38.2-r3[${PERL_USEDEP}] <dev-lang/perl-5.38.2-r3 )"
+GENTOO_PERL_USESTRING="perl_features_debug perl_features_ithreads perl_features_quadmath"
+
 case ${EAPI} in
 	7)
 		[[ ${CATEGORY} == perl-core ]] && \
@@ -51,14 +73,16 @@ case ${EAPI} in
 
 		case "${GENTOO_DEPEND_ON_PERL:-yes}" in
 			yes)
-				DEPEND="dev-lang/perl"
-				BDEPEND="dev-lang/perl"
-				RDEPEND="dev-lang/perl:="
+				IUSE=${GENTOO_PERL_USESTRING}
+				DEPEND=${GENTOO_PERL_DEPSTRING}
+				BDEPEND=${GENTOO_PERL_DEPSTRING}
+				RDEPEND="${GENTOO_PERL_DEPSTRING} dev-lang/perl:="
 				;;
 			noslotop)
-				DEPEND="dev-lang/perl"
-				BDEPEND="dev-lang/perl"
-				RDEPEND="dev-lang/perl"
+				IUSE=${GENTOO_PERL_USESTRING}
+				DEPEND=${GENTOO_PERL_DEPSTRING}
+				BDEPEND=${GENTOO_PERL_DEPSTRING}
+				RDEPEND=${GENTOO_PERL_DEPSTRING}
 				;;
 		esac
 
@@ -78,17 +102,18 @@ case ${EAPI} in
 
 		case "${GENTOO_DEPEND_ON_PERL:-yes}" in
 			yes|noslotop)
-				DEPEND="dev-lang/perl"
-				BDEPEND="dev-lang/perl
+				IUSE=${GENTOO_PERL_USESTRING}
+				DEPEND=${GENTOO_PERL_DEPSTRING}
+				BDEPEND="${GENTOO_PERL_DEPSTRING}
 					 test? ( >=virtual/perl-Test-Simple-1 )"
-				IUSE="test"
+				IUSE+=" test"
 				RESTRICT="!test? ( test )"
 				;;&
 			yes)
-				RDEPEND="dev-lang/perl:="
+				RDEPEND="${GENTOO_PERL_DEPSTRING} dev-lang/perl:="
 				;;
 			noslotop)
-				RDEPEND="dev-lang/perl"
+				RDEPEND=${GENTOO_PERL_DEPSTRING}
 				;;
 		esac
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-08  8:06 Ulrich Müller
  0 siblings, 0 replies; 6663+ messages in thread
From: Ulrich Müller @ 2024-05-08  8:06 UTC (permalink / raw
  To: gentoo-commits
commit:     4bbeea154b6bf6a5ff93a80e83c5c8ee753c282a
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Wed May  8 08:01:12 2024 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Wed May  8 08:01:12 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=4bbeea15
epatch.eclass: Mark as DEAD
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 eclass/epatch.eclass | 3 ++-
 1 file changed, 2 insertions(+), 1 deletion(-)
diff --git a/eclass/epatch.eclass b/eclass/epatch.eclass
index c42aef8e80d1..ff3fd13721fe 100644
--- a/eclass/epatch.eclass
+++ b/eclass/epatch.eclass
@@ -1,6 +1,7 @@
-# Copyright 1999-2023 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
+# @DEAD
 # @ECLASS: epatch.eclass
 # @MAINTAINER:
 # base-system@gentoo.org
^ permalink raw reply related	[flat|nested] 6663+ messages in thread
* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-09 19:54 Conrad Kostecki
  0 siblings, 0 replies; 6663+ messages in thread
From: Conrad Kostecki @ 2024-05-09 19:54 UTC (permalink / raw
  To: gentoo-commits
commit:     d08d86d18206b5d91330f1a91a3331d197205ed4
Author:     Michael Mair-Keimberger <mmk <AT> levelnine <DOT> at>
AuthorDate: Mon Apr  8 18:48:14 2024 +0000
Commit:     Conrad Kostecki <conikost <AT> gentoo <DOT> org>
CommitDate: Thu May  9 19:54:15 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=d08d86d1
eclass/freedict.eclass: support EAPI8
Signed-off-by: Michael Mair-Keimberger <mmk <AT> levelnine.at>
Closes: https://github.com/gentoo/gentoo/pull/36165
Signed-off-by: Conrad Kostecki <conikost <AT> gentoo.org>
 eclass/freedict.eclass | 10 ++++++----
 1 file changed, 6 insertions(+), 4 deletions(-)
diff --git a/eclass/freedict.eclass b/eclass/freedict.eclass
index b649afc7c1af..a292e31f5139 100644
--- a/eclass/freedict.eclass
+++ b/eclass/freedict.eclass
@@ -6,14 +6,14 @@
 # maintainer-needed@gentoo.org
 # @AUTHOR:
 # Original author: Seemant Kulleen <seemant@gentoo.org>
-# @SUPPORTED_EAPIS: 7
+# @SUPPORTED_EAPIS: 7 8
 # @BLURB: Ease the installation of freedict translation dictionaries
 # @DESCRIPTION:
 # This eclass exists to ease the installation of freedict translation
 # dictionaries.
 
 case ${EAPI} in
-	7) ;;
+	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
@@ -23,12 +23,14 @@ _FREEDICT_ECLASS=1
 # @ECLASS_VARIABLE: FREEDICT_P
 # @DESCRIPTION:
 # Strips PN of 'freedict' prefix, to be used in SRC_URI and doins
-FREEDICT_P=${PN/freedict-/}
+FREEDICT_P="${PN/freedict-/}"
 
 [[ ${FORLANG} ]] && die "FORLANG is banned, set DESCRIPTION instead"
 [[ ${TOLANG} ]] && die "TOLANG is banned, set DESCRIPTION instead"
 
-HOMEPAGE="https://freedict.sourceforge.net/en/"
+HOMEPAGE="
+	https://freedict.sourceforge.net/en/
+	https://github.com/freedict/fd-dictionaries"
 SRC_URI="https://freedict.sourceforge.net/download/linux/${FREEDICT_P}.tar.gz"
 
 LICENSE="GPL-2+"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-09 19:54 Conrad Kostecki
  0 siblings, 0 replies; 6663+ messages in thread
From: Conrad Kostecki @ 2024-05-09 19:54 UTC (permalink / raw
  To: gentoo-commits
commit:     fd708545f0ecc491e196c6043080c0c4c09eb441
Author:     Michael Mair-Keimberger <mmk <AT> levelnine <DOT> at>
AuthorDate: Mon Apr  8 18:58:17 2024 +0000
Commit:     Conrad Kostecki <conikost <AT> gentoo <DOT> org>
CommitDate: Thu May  9 19:54:02 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=fd708545
eclass/vim-spell.eclass: support EAPI8
Signed-off-by: Michael Mair-Keimberger <mmk <AT> levelnine.at>
Closes: https://github.com/gentoo/gentoo/pull/36166
Signed-off-by: Conrad Kostecki <conikost <AT> gentoo.org>
 eclass/vim-spell.eclass | 23 +++++++++++------------
 1 file changed, 11 insertions(+), 12 deletions(-)
diff --git a/eclass/vim-spell.eclass b/eclass/vim-spell.eclass
index 855518d23e5b..607771ae8035 100644
--- a/eclass/vim-spell.eclass
+++ b/eclass/vim-spell.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2023 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: vim-spell.eclass
@@ -6,7 +6,7 @@
 # Vim Maintainers <vim@gentoo.org>
 # @AUTHOR:
 # Ciaran McCreesh <ciaranm@gentoo.org>
-# @SUPPORTED_EAPIS: 6 7
+# @SUPPORTED_EAPIS: 6 7 8
 # @BLURB: Eclass for managing Vim spell files.
 # @DESCRIPTION:
 # How to make a vim spell file package using prebuilt spell lists
@@ -39,15 +39,14 @@
 #     <?xml version="1.0" encoding="UTF-8"?>
 #     <!DOCTYPE pkgmetadata SYSTEM "https://www.gentoo.org/dtd/metadata.dtd">
 #     <pkgmetadata>
-#        <maintainer type="person">
-#                <email>your@email.tld</email>
-#                <name>Your Name</name>
-#        </maintainer>
-#        <maintainer type="project">
-#                <email>vim@gentoo.org</email>
-#                <name>Vim Maintainers</name>
-#        </maintainer>
-#
+#     	<maintainer type="person">
+#     		<email>your@email.tld</email>
+#     		<name>Your Name</name>
+#     	</maintainer>
+#     	<maintainer type="project">
+#     		<email>vim@gentoo.org</email>
+#     		<name>Vim Maintainers</name>
+#     	</maintainer>
 #     	<longdescription lang="en">
 #     		Vim spell files for French (fr). Supported character sets are
 #     		UTF-8 and latin1.
@@ -64,7 +63,7 @@
 # for another language rather than keeping them Gentoo-specific.
 
 case ${EAPI} in
-	6|7) ;;
+	6|7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-10 17:28 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-05-10 17:28 UTC (permalink / raw
  To: gentoo-commits
commit:     0831622e109dde6f781219c904f7b275c1b8877f
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat May  4 08:39:43 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May 10 17:27:03 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=0831622e
perl-module.eclass: respect toolchain variables for Module::Build via --config ...
Based off https://github.com/Perl-Toolchain-Gang/Module-Build/blob/a2ecdf98c25af7dfc7070280232513e8ccec4986/lib/Module/Build/Cookbook.pm#L63.
Bug: https://bugs.gentoo.org/261375
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/perl-module.eclass | 11 ++++++++++-
 1 file changed, 10 insertions(+), 1 deletion(-)
diff --git a/eclass/perl-module.eclass b/eclass/perl-module.eclass
index 029fc78e4a85..fd1af4f945b1 100644
--- a/eclass/perl-module.eclass
+++ b/eclass/perl-module.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2023 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: perl-module.eclass
@@ -274,6 +274,15 @@ perl-module_src_configure() {
 			--libdoc= \
 			--destdir="${D}" \
 			--create_packlist=1 \
+			--config ar="$(tc-getAR)" \
+			--config cc="$(tc-getCC)" \
+			--config ld="$(tc-getCC)" \
+			--config cpp="$(tc-getCPP)" \
+			--config nm="$(tc-getNM)" \
+			--config ranlib="$(tc-getRANLIB)" \
+			--config ccflags="${CFLAGS}" \
+			--config optimize="${CFLAGS}" \
+			--config ldflags="${LDFLAGS}" \
 			"${myconf_local[@]}"
 		einfo "perl Build.PL" "$@"
 		perl Build.PL "$@" <<< "${pm_echovar}" \
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-10 17:28 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-05-10 17:28 UTC (permalink / raw
  To: gentoo-commits
commit:     9be198be536915b3e9f3da57eca25c90d7ca3214
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat May  4 10:24:28 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May 10 17:27:04 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=9be198be
perl-module.eclass: stop using ${D} for MakeMaker in src_configure
See https://metacpan.org/dist/ExtUtils-MakeMaker/view/lib/ExtUtils/MakeMaker.pm#DESTDIR.
Bug: https://bugs.gentoo.org/778806
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/perl-module.eclass | 3 +--
 1 file changed, 1 insertion(+), 2 deletions(-)
diff --git a/eclass/perl-module.eclass b/eclass/perl-module.eclass
index 9e3cfab16f94..aed16b41df89 100644
--- a/eclass/perl-module.eclass
+++ b/eclass/perl-module.eclass
@@ -292,7 +292,6 @@ perl-module_src_configure() {
 			PREFIX="${EPREFIX}"/usr \
 			INSTALLDIRS=vendor \
 			INSTALLMAN3DIR='none' \
-			DESTDIR="${D}" \
 			"${myconf_local[@]}"
 		einfo "perl Makefile.PL" "$@"
 		perl Makefile.PL "$@" <<< "${pm_echovar}" \
@@ -452,7 +451,7 @@ perl-module_src_install() {
 		else
 			local myinst_local=("${myinst[@]}")
 		fi
-		emake "${myinst_local[@]}" ${mytargets}
+		emake DESTDIR="${D}" "${myinst_local[@]}" ${mytargets}
 	fi
 
 	case ${EAPI} in
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-10 17:28 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-05-10 17:28 UTC (permalink / raw
  To: gentoo-commits
commit:     9923973f58e7f5af1b1b53d9077b210224fc81b0
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat May  4 10:18:43 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May 10 17:27:04 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=9923973f
perl-module.eclass: stop using ${D} for Module::Build in src_configure
See https://github.com/Perl-Toolchain-Gang/Module-Build/blob/a2ecdf98c25af7dfc7070280232513e8ccec4986/lib/Module/Build/Cookbook.pm#L122.
Bug: https://bugs.gentoo.org/778806
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/perl-module.eclass | 3 +--
 1 file changed, 1 insertion(+), 2 deletions(-)
diff --git a/eclass/perl-module.eclass b/eclass/perl-module.eclass
index fd1af4f945b1..9e3cfab16f94 100644
--- a/eclass/perl-module.eclass
+++ b/eclass/perl-module.eclass
@@ -272,7 +272,6 @@ perl-module_src_configure() {
 		set -- \
 			--installdirs=vendor \
 			--libdoc= \
-			--destdir="${D}" \
 			--create_packlist=1 \
 			--config ar="$(tc-getAR)" \
 			--config cc="$(tc-getCC)" \
@@ -439,7 +438,7 @@ perl-module_src_install() {
 
 	if [[ -f Build ]]; then
 		mytargets="${mytargets:-install}"
-		mbparams="${mbparams:---pure}"
+		mbparams="${mbparams:---destdir="${D}" --pure}"
 		einfo "./Build ${mytargets} ${mbparams}"
 		./Build ${mytargets} ${mbparams} \
 			|| die "./Build ${mytargets} ${mbparams} failed"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-10 17:28 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-05-10 17:28 UTC (permalink / raw
  To: gentoo-commits
commit:     e8ba6eb2883553aec1e45c819924e3453c532fd3
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat May  4 10:35:06 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May 10 17:27:06 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=e8ba6eb2
perl-module.eclass: sort toolchain vars
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/perl-module.eclass | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/eclass/perl-module.eclass b/eclass/perl-module.eclass
index eb496e4a64df..f32c2c237d05 100644
--- a/eclass/perl-module.eclass
+++ b/eclass/perl-module.eclass
@@ -275,8 +275,8 @@ perl-module_src_configure() {
 			--create_packlist=1 \
 			--config ar="$(tc-getAR)" \
 			--config cc="$(tc-getCC)" \
-			--config ld="$(tc-getCC)" \
 			--config cpp="$(tc-getCPP)" \
+			--config ld="$(tc-getCC)" \
 			--config nm="$(tc-getNM)" \
 			--config ranlib="$(tc-getRANLIB)" \
 			--config ccflags="${CFLAGS}" \
@@ -291,8 +291,8 @@ perl-module_src_configure() {
 		set -- \
 			AR="$(tc-getAR)" \
 			CC="$(tc-getCC)" \
-			LD="$(tc-getCC)" \
 			CPP="$(tc-getCPP)" \
+			LD="$(tc-getCC)" \
 			NM="$(tc-getNM)" \
 			RANLIB="$(tc-getRANLIB)" \
 			OPTIMIZE="${CFLAGS}" \
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-10 17:28 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-05-10 17:28 UTC (permalink / raw
  To: gentoo-commits
commit:     3a650e223a09b0616a4e619c73cc033478fb7a61
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat May  4 10:32:18 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May 10 17:27:05 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=3a650e22
perl-module.eclass: respect toolchain environment for MakeMaker
based on https://bugs.gentoo.org/261375#c5 and https://metacpan.org/dist/ExtUtils-MakeMaker/view/lib/ExtUtils/MakeMaker.pm#OPTIMIZE.
Bug: https://bugs.gentoo.org/261375
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/perl-module.eclass | 8 ++++++++
 1 file changed, 8 insertions(+)
diff --git a/eclass/perl-module.eclass b/eclass/perl-module.eclass
index aed16b41df89..eb496e4a64df 100644
--- a/eclass/perl-module.eclass
+++ b/eclass/perl-module.eclass
@@ -289,6 +289,14 @@ perl-module_src_configure() {
 	elif [[ -f Makefile.PL ]] ; then
 		einfo "Using ExtUtils::MakeMaker"
 		set -- \
+			AR="$(tc-getAR)" \
+			CC="$(tc-getCC)" \
+			LD="$(tc-getCC)" \
+			CPP="$(tc-getCPP)" \
+			NM="$(tc-getNM)" \
+			RANLIB="$(tc-getRANLIB)" \
+			OPTIMIZE="${CFLAGS}" \
+			LDFLAGS="${LDFLAGS}" \
 			PREFIX="${EPREFIX}"/usr \
 			INSTALLDIRS=vendor \
 			INSTALLMAN3DIR='none' \
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-11  0:55 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-05-11  0:55 UTC (permalink / raw
  To: gentoo-commits
commit:     4d6705884ff5a06e8dbbbd86d0b4f8decf300275
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat May 11 00:54:29 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat May 11 00:54:29 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=4d670588
go-env.eclass: update GCC workaround for LTO
Not fixed upstream yet so change workaround to look for sys-devel/gcc[debug]
instead as 14 is released now.
Bug: https://bugs.gentoo.org/912152
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/go-env.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/go-env.eclass b/eclass/go-env.eclass
index baba0d3ee8b3..e0987ec7dee7 100644
--- a/eclass/go-env.eclass
+++ b/eclass/go-env.eclass
@@ -34,7 +34,7 @@ go-env_set_compile_environment() {
 	use x86 && export GO386=$(go-env_go386)
 
 	# XXX: Hack for checking ICE (bug #912152, gcc PR113204)
-	[[ $(gcc-fullversion) == 14.0.1 ]] && filter-lto
+	has_version -b "sys-devel/gcc[debug]" && filter-lto
 
 	export CGO_CFLAGS="${CGO_CFLAGS:-$CFLAGS}"
 	export CGO_CPPFLAGS="${CGO_CPPFLAGS:-$CPPFLAGS}"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-11  1:58 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-05-11  1:58 UTC (permalink / raw
  To: gentoo-commits
commit:     31791351d915acb4db8135beb1a2a107538daeeb
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat May 11 01:52:04 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat May 11 01:52:19 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=31791351
alternatives.eclass: support EAPI 8
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/alternatives.eclass | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/eclass/alternatives.eclass b/eclass/alternatives.eclass
index 2489fc67359a..7871e7f42b4a 100644
--- a/eclass/alternatives.eclass
+++ b/eclass/alternatives.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2022 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: alternatives.eclass
@@ -6,7 +6,7 @@
 # maintainer-needed@gentoo.org
 # @AUTHOR:
 # Alastair Tse <liquidx@gentoo.org> (03 Oct 2003)
-# @SUPPORTED_EAPIS: 7
+# @SUPPORTED_EAPIS: 7 8
 # @BLURB: Creates symlink to the latest version of multiple slotted packages.
 # @DESCRIPTION:
 # When a package is SLOT'ed, very often we need to have a symlink to the
@@ -42,7 +42,7 @@
 # consider using this unless you are want to do something special.
 
 case ${EAPI} in
-	7) ;;
+	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-11  6:21 Hans de Graaff
  0 siblings, 0 replies; 6663+ messages in thread
From: Hans de Graaff @ 2024-05-11  6:21 UTC (permalink / raw
  To: gentoo-commits
commit:     2b71eff4ae0058a049cb95d8f43dba38e2ab7008
Author:     Hans de Graaff <graaff <AT> gentoo <DOT> org>
AuthorDate: Sat May 11 06:20:15 2024 +0000
Commit:     Hans de Graaff <graaff <AT> gentoo <DOT> org>
CommitDate: Sat May 11 06:21:01 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=2b71eff4
eclass/apache2.eclass: remove rustls dependency
This dependency differs per ebuild and has been moved to the ebuilds.
Signed-off-by: Hans de Graaff <graaff <AT> gentoo.org>
 eclass/apache-2.eclass | 1 -
 1 file changed, 1 deletion(-)
diff --git a/eclass/apache-2.eclass b/eclass/apache-2.eclass
index 17b8b0e2a64a..352337f551d6 100644
--- a/eclass/apache-2.eclass
+++ b/eclass/apache-2.eclass
@@ -162,7 +162,6 @@ RDEPEND="
 	apache2_modules_session_crypto? (
 		dev-libs/apr-util[openssl]
 	)
-	apache2_modules_tls? ( >=net-libs/rustls-ffi-0.9.2:= <net-libs/rustls-ffi-11 )
 	gdbm? ( sys-libs/gdbm:= )
 	ldap? ( net-nds/openldap:= )
 	selinux? ( sec-policy/selinux-apache )
^ permalink raw reply related	[flat|nested] 6663+ messages in thread
* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-11  6:44 Joonas Niilola
  0 siblings, 0 replies; 6663+ messages in thread
From: Joonas Niilola @ 2024-05-11  6:44 UTC (permalink / raw
  To: gentoo-commits
commit:     567cb9242b182006a4b80f9266e3641f422472f0
Author:     Joonas Niilola <juippis <AT> gentoo <DOT> org>
AuthorDate: Sat May 11 06:41:45 2024 +0000
Commit:     Joonas Niilola <juippis <AT> gentoo <DOT> org>
CommitDate: Sat May 11 06:44:32 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=567cb924
go-env.eclass: temporary EAPI guard for EAPI-6
 - there are still a handful of EAPI-6 ebuilds which don't support BDEPENDs.
   While the has_version check is imperfect without -b switch, this is better
   than nothing. I assume gcc[debug] isn't be that widely used either.
Signed-off-by: Joonas Niilola <juippis <AT> gentoo.org>
 eclass/go-env.eclass | 9 ++++++++-
 1 file changed, 8 insertions(+), 1 deletion(-)
diff --git a/eclass/go-env.eclass b/eclass/go-env.eclass
index e0987ec7dee7..1a2c9787a146 100644
--- a/eclass/go-env.eclass
+++ b/eclass/go-env.eclass
@@ -34,7 +34,14 @@ go-env_set_compile_environment() {
 	use x86 && export GO386=$(go-env_go386)
 
 	# XXX: Hack for checking ICE (bug #912152, gcc PR113204)
-	has_version -b "sys-devel/gcc[debug]" && filter-lto
+	case ${EAPI} in
+		6)
+			has_version "sys-devel/gcc[debug]" && filter-lto
+			;;
+		*)
+			has_version -b "sys-devel/gcc[debug]" && filter-lto
+			;;
+	esac
 
 	export CGO_CFLAGS="${CGO_CFLAGS:-$CFLAGS}"
 	export CGO_CPPFLAGS="${CGO_CPPFLAGS:-$CPPFLAGS}"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-11 13:39 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-05-11 13:39 UTC (permalink / raw
  To: gentoo-commits
commit:     612110afb9863977815127fa296628fd4c99b701
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat May 11 13:36:54 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat May 11 13:36:54 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=612110af
Add 19.0.0_pre20240509 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index 623a7c1f3f4a..3ada7d2a373b 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -72,6 +72,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 			_LLVM_SOURCE_TYPE=snapshot
 
 			case ${PV} in
+				19.0.0_pre20240509)
+					EGIT_COMMIT=a7ee81e8279e0bf6e05617a4a638e5f2f8e45022
+					;;
 				19.0.0_pre20240504)
 					EGIT_COMMIT=76aa042dde6ba9ba57c680950f5818259ee02690
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-12  4:51 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-05-12  4:51 UTC (permalink / raw
  To: gentoo-commits
commit:     ded2b2cd180ee3896423dca54c4f24962d5c9b0a
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun May 12 04:49:41 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun May 12 04:49:41 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=ded2b2cd
flag-o-matic.eclass: allow -mevex512 and -mno-evex512
The whole -m/-mno-* situation needs to be improved in the eclass but
let's do this for now for the benefit of Chromium (see 754d6f5226a532ed086afa276b48e89ffafe0484).
Bug: https://bugs.gentoo.org/931623
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/flag-o-matic.eclass | 2 ++
 1 file changed, 2 insertions(+)
diff --git a/eclass/flag-o-matic.eclass b/eclass/flag-o-matic.eclass
index 0e5271c7824f..ecac452aa0ef 100644
--- a/eclass/flag-o-matic.eclass
+++ b/eclass/flag-o-matic.eclass
@@ -139,6 +139,8 @@ _setup-allowed-flags() {
 		-mno-fxsr -mno-hle -mno-rtm -mno-xsave -mno-xsaveopt
 		# gcc 4.9
 		-mno-avx512cd -mno-avx512er -mno-avx512f -mno-avx512pf -mno-sha
+
+		-mevex512 -mno-evex512
 	)
 
 	# Allow some safe individual flags. Should come along with the bug reference.
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-13  7:07 Miroslav Šulc
  0 siblings, 0 replies; 6663+ messages in thread
From: Miroslav Šulc @ 2024-05-13  7:07 UTC (permalink / raw
  To: gentoo-commits
commit:     0a8b1dd5b29020e81f14a5aeb13fd5a73d850e23
Author:     Volkmar W. Pogatzki <gentoo <AT> pogatzki <DOT> net>
AuthorDate: Mon May 13 05:17:22 2024 +0000
Commit:     Miroslav Šulc <fordfrog <AT> gentoo <DOT> org>
CommitDate: Mon May 13 07:07:17 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=0a8b1dd5
ant-tasks.eclass: drop ant-tasks.eclass
Signed-off-by: Volkmar W. Pogatzki <gentoo <AT> pogatzki.net>
Closes: https://github.com/gentoo/gentoo/pull/36659
Signed-off-by: Miroslav Šulc <fordfrog <AT> gentoo.org>
 eclass/ant-tasks.eclass | 172 ------------------------------------------------
 1 file changed, 172 deletions(-)
diff --git a/eclass/ant-tasks.eclass b/eclass/ant-tasks.eclass
deleted file mode 100644
index 2b10e0f3e1e0..000000000000
--- a/eclass/ant-tasks.eclass
+++ /dev/null
@@ -1,172 +0,0 @@
-# Copyright 2007-2024 Gentoo Authors
-# Distributed under the terms of the GNU General Public License v2
-
-# @DEAD
-# @ECLASS: ant-tasks.eclass
-# @MAINTAINER:
-# java@gentoo.org
-# @AUTHOR:
-# Vlastimil Babka <caster@gentoo.org>
-# @SUPPORTED_EAPIS: 7
-# @PROVIDES: java-utils-2
-# @BLURB: Eclass for building dev-java/ant-* packages
-# @DESCRIPTION:
-# This eclass provides functionality and default ebuild variables for building
-# dev-java/ant-* packages easily.
-
-case ${EAPI} in
-	7) ;;
-	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
-esac
-
-if [[ -z ${_ANT_TASKS_ECLASS} ]]; then
-_ANT_TASKS_ECLASS=1
-
-# we set ant-core dep ourselves, restricted
-JAVA_ANT_DISABLE_ANT_CORE_DEP=true
-# rewriting build.xml for are the testcases has no reason atm
-JAVA_PKG_BSFIX_ALL=no
-inherit java-pkg-2 java-ant-2
-
-# @ECLASS_VARIABLE: ANT_TASK_JDKVER
-# @PRE_INHERIT
-# @DESCRIPTION:
-# Affects the >=virtual/jdk version set in DEPEND string. Defaults to 1.8, can
-# be overridden from ebuild BEFORE inheriting this eclass.
-ANT_TASK_JDKVER=${ANT_TASK_JDKVER-1.8}
-
-# @ECLASS_VARIABLE: ANT_TASK_JREVER
-# @PRE_INHERIT
-# @DESCRIPTION:
-# Affects the >=virtual/jre version set in DEPEND string. Defaults to 1.8, can
-# be overridden from ebuild BEFORE inheriting this eclass.
-ANT_TASK_JREVER=${ANT_TASK_JREVER-1.8}
-
-# @ECLASS_VARIABLE: ANT_TASK_NAME
-# @DESCRIPTION:
-# The name of this ant task as recognized by ant's build.xml, derived from $PN
-# by removing the ant- prefix. Read-only.
-ANT_TASK_NAME="${PN#ant-}"
-
-# @ECLASS_VARIABLE: ANT_TASK_DEPNAME
-# @PRE_INHERIT
-# @DESCRIPTION:
-# Specifies JAVA_PKG_NAME (PN{-SLOT} used with java-pkg_jar-from) of the package
-# that this one depends on. Defaults to the name of ant task, ebuild can
-# override it before inheriting this eclass. In case there is more than one
-# dependency, the variable can be specified as bash array with multiple strings,
-# one for each dependency.
-ANT_TASK_DEPNAME=${ANT_TASK_DEPNAME-${ANT_TASK_NAME}}
-
-# @ECLASS_VARIABLE: ANT_TASK_DISABLE_VM_DEPS
-# @PRE_INHERIT
-# @DEFAULT_UNSET
-# @DESCRIPTION:
-# If set, no JDK/JRE deps are added.
-
-# @VARIABLE: ANT_TASK_PV
-# @INTERNAL
-# @DESCRIPTION:
-# Version of ant-core this task is intended to register and thus load with.
-ANT_TASK_PV="${PV}"
-
-# default for final releases
-MY_PV=${PV}
-
-UPSTREAM_PREFIX="mirror://apache/ant/source"
-GENTOO_PREFIX="https://dev.gentoo.org/~fordfrog/distfiles"
-
-# source/workdir name
-MY_P="apache-ant-${MY_PV}"
-
-# Default values for standard ebuild variables, can be overridden from ebuild.
-DESCRIPTION="Apache Ant's optional tasks depending on ${ANT_TASK_DEPNAME}"
-HOMEPAGE="https://ant.apache.org/"
-SRC_URI="${UPSTREAM_PREFIX}/${MY_P}-src.tar.bz2
-	${GENTOO_PREFIX}/ant-${PV}-gentoo.tar.bz2"
-LICENSE="Apache-2.0"
-SLOT="0"
-
-RDEPEND="~dev-java/ant-core-${PV}:0"
-DEPEND="${RDEPEND}"
-
-if [[ -z "${ANT_TASK_DISABLE_VM_DEPS}" ]]; then
-	RDEPEND+=" >=virtual/jre-${ANT_TASK_JREVER}"
-	DEPEND+=" >=virtual/jdk-${ANT_TASK_JDKVER}"
-fi
-
-# Would run the full ant test suite for every ant task
-RESTRICT="test"
-
-S="${WORKDIR}/${MY_P}"
-
-# @FUNCTION: ant-tasks_src_unpack
-# @USAGE: [ base ] [ jar-dep ] [ all ]
-# @DESCRIPTION:
-# The function Is split into two parts, defaults to both of them ('all').
-#
-# base: performs the unpack, build.xml replacement and symlinks ant.jar from
-#	ant-core
-#
-# jar-dep: symlinks the jar file(s) from dependency package(s)
-ant-tasks_src_unpack() {
-	[[ -z "${1}" ]] && ant-tasks_src_unpack all
-
-	while [[ -n "${1}" ]]; do
-		case ${1} in
-			base)
-				unpack ${A}
-				cd "${S}"
-
-				# replace build.xml with our modified for split building
-				if [ -e "${WORKDIR}"/${PV}-build.patch ] ; then
-					eapply "${WORKDIR}"/${PV}-build.patch
-				else
-					mv -f "${WORKDIR}"/build.xml .
-				fi
-
-				cd lib
-				# remove bundled xerces
-				rm -f *.jar
-
-				# ant.jar to build against
-				java-pkg_jar-from --build-only ant-core ant.jar;;
-			jar-dep)
-				# get jar from the dependency package(s)
-				if [[ -n "${ANT_TASK_DEPNAME}" ]]; then
-					for depname in "${ANT_TASK_DEPNAME[@]}"; do
-						java-pkg_jar-from ${depname}
-					done
-				fi;;
-			all)
-				ant-tasks_src_unpack base jar-dep;;
-		esac
-		shift
-	done
-
-}
-
-# @FUNCTION: ant-tasks_src_compile
-# @DESCRIPTION:
-# Compiles the jar with installed ant-core.
-ant-tasks_src_compile() {
-	ANT_TASKS="none" eant -Dbuild.dep=${ANT_TASK_NAME} jar-dep
-}
-
-# @FUNCTION: ant-tasks_src_install
-# @DESCRIPTION:
-# Installs the jar and registers its presence for the ant launcher script.
-# Version param ensures it won't get loaded (thus break) when ant-core is
-# updated to newer version.
-ant-tasks_src_install() {
-	java-pkg_dojar build/lib/${PN}.jar
-	java-pkg_register-ant-task --version "${ANT_TASK_PV}"
-
-	# create the compatibility symlink
-	dodir /usr/share/ant/lib
-	dosym /usr/share/${PN}/lib/${PN}.jar /usr/share/ant/lib/${PN}.jar
-}
-
-fi
-
-EXPORT_FUNCTIONS src_unpack src_compile src_install
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-13  8:35 Florian Schmaus
  0 siblings, 0 replies; 6663+ messages in thread
From: Florian Schmaus @ 2024-05-13  8:35 UTC (permalink / raw
  To: gentoo-commits
commit:     cc5f4511b43b91f6df2fe63a4194ab596b706a80
Author:     Florian Schmaus <flow <AT> gentoo <DOT> org>
AuthorDate: Mon May 13 08:31:53 2024 +0000
Commit:     Florian Schmaus <flow <AT> gentoo <DOT> org>
CommitDate: Mon May 13 08:31:53 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=cc5f4511
texlive-module.eclass: check if texmf-dist/doc/man exists
Closes: https://bugs.gentoo.org/931798
Closes: https://bugs.gentoo.org/931799
Closes: https://bugs.gentoo.org/931800
Closes: https://bugs.gentoo.org/931801
Closes: https://bugs.gentoo.org/931802
Closes: https://bugs.gentoo.org/931803
Closes: https://bugs.gentoo.org/931804
Closes: https://bugs.gentoo.org/931805
Closes: https://bugs.gentoo.org/931806
Closes: https://bugs.gentoo.org/931807
Closes: https://bugs.gentoo.org/931808
Closes: https://bugs.gentoo.org/931809
Closes: https://bugs.gentoo.org/931810
Closes: https://bugs.gentoo.org/931811
Closes: https://bugs.gentoo.org/931812
Signed-off-by: Florian Schmaus <flow <AT> gentoo.org>
 eclass/texlive-module.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/texlive-module.eclass b/eclass/texlive-module.eclass
index da33e25a39dc..0daca41961ff 100644
--- a/eclass/texlive-module.eclass
+++ b/eclass/texlive-module.eclass
@@ -360,7 +360,7 @@ texlive-module_src_install() {
 			cp -pR texmf-doc "${ED}/usr/share/" || die
 		fi
 
-		if ver_test -ge 2023 && [[ ${CATEGORY} == dev-texlive ]]; then
+		if ver_test -ge 2023 && [[ -d texmf-dist/doc/man && ${CATEGORY} == dev-texlive ]]; then
 			local texlive_core_man_pages=(
 				afm2pl.1
 				aleph.1
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-13 13:22 Michael Orlitzky
  0 siblings, 0 replies; 6663+ messages in thread
From: Michael Orlitzky @ 2024-05-13 13:22 UTC (permalink / raw
  To: gentoo-commits
commit:     b7e37226a665a0613facd10386bbbbec8696699e
Author:     Michael Orlitzky <mjo <AT> gentoo <DOT> org>
AuthorDate: Thu May  9 20:07:19 2024 +0000
Commit:     Michael Orlitzky <mjo <AT> gentoo <DOT> org>
CommitDate: Mon May 13 13:13:26 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=b7e37226
eclass/acct-user.eclass: use $PN to construct make.conf override vars
If (after upcasing and replacing hyphens by underscores) ACCT_USER_NAME
is set to something that isn't valid in a bash variable name, the eclass
will crash: it uses ACCT_USER_NAME to construct the make.conf override
variables in pkg_pretend() and src_install(). This commit constructs the
variable names using PN instead of ACCT_USER_NAME. In ::gentoo, the two
are equivalent, but in an overlay this allows weirder usernames at the
expense of slightly mismatched variable names.
Signed-off-by: Michael Orlitzky <mjo <AT> gentoo.org>
 eclass/acct-user.eclass | 12 +++++++-----
 1 file changed, 7 insertions(+), 5 deletions(-)
diff --git a/eclass/acct-user.eclass b/eclass/acct-user.eclass
index 765487391fbd..9eab1f4c4ae6 100644
--- a/eclass/acct-user.eclass
+++ b/eclass/acct-user.eclass
@@ -231,8 +231,9 @@ acct-user_pkg_pretend() {
 	[[ ${ACCT_USER_ID} -ge -1 ]] || die "Ebuild error: ACCT_USER_ID=${ACCT_USER_ID} invalid!"
 	local user_id=${ACCT_USER_ID}
 
-	# check for the override
-	local override_name=${ACCT_USER_NAME^^}
+	# check for the override, use PN in case this is an overlay and
+	# ACCT_USER_NAME is not PN and not valid in a bash variable name
+	local override_name=${PN^^}
 	local override_var=ACCT_USER_${override_name//-/_}_ID
 	if [[ -n ${!override_var} ]]; then
 		user_id=${!override_var}
@@ -274,8 +275,9 @@ acct-user_src_install() {
 	# serialize for override support
 	local ACCT_USER_GROUPS=${ACCT_USER_GROUPS[*]}
 
-	# support make.conf overrides
-	local override_name=${ACCT_USER_NAME^^}
+	# support make.conf overrides, use PN in case this is an overlay and
+	# ACCT_USER_NAME is not PN and not valid in a bash variable name
+	local override_name=${PN^^}
 	override_name=${override_name//-/_}
 	local var
 	for var in ACCT_USER_{ID,COMMENT,SHELL,HOME{,_OWNER,_PERMS},GROUPS}; do
@@ -437,7 +439,7 @@ acct-user_pkg_postinst() {
 		has "${g}" "${groups[@]}" || del_groups+="${del_groups:+, }${g}"
 	done
 	if [[ -n ${del_groups} ]]; then
-		local override_name=${ACCT_USER_NAME^^}
+		local override_name=${PN^^}
 		override_name=${override_name//-/_}
 		ewarn "Removing user ${ACCT_USER_NAME} from group(s): ${del_groups}"
 		ewarn "To retain the user's group membership in the local system"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-13 13:22 Michael Orlitzky
  0 siblings, 0 replies; 6663+ messages in thread
From: Michael Orlitzky @ 2024-05-13 13:22 UTC (permalink / raw
  To: gentoo-commits
commit:     bd3da28e258a68566d1abe18aa6713594adcd0ff
Author:     Michael Orlitzky <mjo <AT> gentoo <DOT> org>
AuthorDate: Thu May  9 20:17:12 2024 +0000
Commit:     Michael Orlitzky <mjo <AT> gentoo <DOT> org>
CommitDate: Mon May 13 13:13:27 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=bd3da28e
eclass/acct-group.eclass: use $PN to construct make.conf override vars
If (after upcasing and replacing hyphens by underscores) ACCT_GROUP_NAME
is set to something that isn't valid in a bash variable name, the eclass
will crash: it uses ACCT_GROUP_NAME to construct the make.conf override
variables in pkg_pretend() and src_install(). This commit constructs the
variable names using PN instead of ACCT_GROUP_NAME. In ::gentoo, the two
are equivalent, but in an overlay this allows weirder group names at the
expense of slightly mismatched variable names.
Signed-off-by: Michael Orlitzky <mjo <AT> gentoo.org>
 eclass/acct-group.eclass | 10 ++++++----
 1 file changed, 6 insertions(+), 4 deletions(-)
diff --git a/eclass/acct-group.eclass b/eclass/acct-group.eclass
index 6dd6dc06a07e..2c2c88cfc7e1 100644
--- a/eclass/acct-group.eclass
+++ b/eclass/acct-group.eclass
@@ -96,8 +96,9 @@ acct-group_pkg_pretend() {
 	[[ ${ACCT_GROUP_ID} -ge -1 ]] || die "Ebuild error: ACCT_GROUP_ID=${ACCT_GROUP_ID} invalid!"
 	local group_id=${ACCT_GROUP_ID}
 
-	# check for the override
-	local override_name=${ACCT_GROUP_NAME^^}
+	# check for the override, use PN in case this is an overlay and
+	# ACCT_GROUP_NAME is not PN and not valid in a bash variable name
+	local override_name=${PN^^}
 	local override_var=ACCT_GROUP_${override_name//-/_}_ID
 	if [[ -n ${!override_var} ]]; then
 		group_id=${!override_var}
@@ -132,8 +133,9 @@ acct-group_pkg_pretend() {
 acct-group_src_install() {
 	debug-print-function ${FUNCNAME} "${@}"
 
-	# check for the override
-	local override_name=${ACCT_GROUP_NAME^^}
+	# check for the override, use PN in case this is an overlay and
+	# ACCT_GROUP_NAME is not PN and not valid in a bash variable name
+	local override_name=${PN^^}
 	local override_var=ACCT_GROUP_${override_name//-/_}_ID
 	if [[ -n ${!override_var} ]]; then
 		ewarn "${override_var}=${!override_var} override in effect, support will not be provided."
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-13 13:22 Michael Orlitzky
  0 siblings, 0 replies; 6663+ messages in thread
From: Michael Orlitzky @ 2024-05-13 13:22 UTC (permalink / raw
  To: gentoo-commits
commit:     b7643fbe45d849aee68e4a162c05f48b4f830029
Author:     Michael Orlitzky <mjo <AT> gentoo <DOT> org>
AuthorDate: Wed May  8 14:41:55 2024 +0000
Commit:     Michael Orlitzky <mjo <AT> gentoo <DOT> org>
CommitDate: Mon May 13 13:13:22 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=b7643fbe
acct-user.eclass: make ACCT_USER_NAME writable
The ACCT_USER_NAME variable is set to $PN by Gentoo policy. Prior to
this commit, it was also marked "readonly", preventing it from being
changed in an ebuild. In an overlay, and combined with the package
naming restrictions in the PMS, this has the unfortunate side effect of
prohibiting some otherwise-valid usernames. We drop the "readonly" to
allow those users to be managed (in overlays) using GLEP81 packages.
Signed-off-by: Michael Orlitzky <mjo <AT> gentoo.org>
 eclass/acct-user.eclass | 10 +++++-----
 1 file changed, 5 insertions(+), 5 deletions(-)
diff --git a/eclass/acct-user.eclass b/eclass/acct-user.eclass
index 66a4d6667888..765487391fbd 100644
--- a/eclass/acct-user.eclass
+++ b/eclass/acct-user.eclass
@@ -1,4 +1,4 @@
-# Copyright 2019-2023 Gentoo Authors
+# Copyright 2019-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: acct-user.eclass
@@ -58,12 +58,12 @@ inherit user-info
 # << Eclass variables >>
 
 # @ECLASS_VARIABLE: ACCT_USER_NAME
-# @INTERNAL
 # @DESCRIPTION:
-# The name of the user.  This is forced to ${PN} and the policy prohibits
-# it from being changed.
+# The name of the user.  This is forced to ${PN} and the policy
+# prohibits it from being changed.  The variable is left writable for
+# use in overlays; package naming restrictions would prohibit some
+# otherwise-valid usernames.
 ACCT_USER_NAME=${PN}
-readonly ACCT_USER_NAME
 
 # @ECLASS_VARIABLE: ACCT_USER_ID
 # @REQUIRED
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-13 13:22 Michael Orlitzky
  0 siblings, 0 replies; 6663+ messages in thread
From: Michael Orlitzky @ 2024-05-13 13:22 UTC (permalink / raw
  To: gentoo-commits
commit:     d5eb382b49a78b0ad0283480f8eef68cd97c4739
Author:     Michael Orlitzky <mjo <AT> gentoo <DOT> org>
AuthorDate: Wed May  8 21:19:32 2024 +0000
Commit:     Michael Orlitzky <mjo <AT> gentoo <DOT> org>
CommitDate: Mon May 13 13:13:26 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=d5eb382b
acct-group.eclass: make ACCT_GROUP_NAME writable
The ACCT_GROUP_NAME variable is set to $PN by Gentoo policy. Prior to
this commit, it was also marked "readonly", preventing it from being
changed in an ebuild. In an overlay, and combined with the package
naming restrictions in the PMS, this has the unfortunate side effect of
prohibiting some otherwise-valid group names. We drop the "readonly" to
allow those groups to be managed (in overlays) using GLEP81 packages.
Signed-off-by: Michael Orlitzky <mjo <AT> gentoo.org>
 eclass/acct-group.eclass | 8 ++++----
 1 file changed, 4 insertions(+), 4 deletions(-)
diff --git a/eclass/acct-group.eclass b/eclass/acct-group.eclass
index a0ad86066309..6dd6dc06a07e 100644
--- a/eclass/acct-group.eclass
+++ b/eclass/acct-group.eclass
@@ -1,4 +1,4 @@
-# Copyright 2019-2023 Gentoo Authors
+# Copyright 2019-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: acct-group.eclass
@@ -50,12 +50,12 @@ inherit user-info
 # << Eclass variables >>
 
 # @ECLASS_VARIABLE: ACCT_GROUP_NAME
-# @INTERNAL
 # @DESCRIPTION:
 # The name of the group.  This is forced to ${PN} and the policy
-# prohibits it from being changed.
+# prohibits it from being changed.  The variable is left writable for
+# use in overlays; package naming restrictions would prohibit some
+# otherwise-valid group names.
 ACCT_GROUP_NAME=${PN}
-readonly ACCT_GROUP_NAME
 
 # @ECLASS_VARIABLE: ACCT_GROUP_ID
 # @REQUIRED
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-13 21:53 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-05-13 21:53 UTC (permalink / raw
  To: gentoo-commits
commit:     7010b055a0051e6557cfd2ef644e432fe84dc388
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon May 13 21:49:39 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon May 13 21:51:23 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=7010b055
toolchain.eclass: don't depend on self if gnat-gpl
Without this, we get:
```
 * Error: circular dependencies:
(sys-devel/gcc-13.2.1_p20240210:13/13::gentoo, ebuild scheduled for merge) depends on
 (dev-lang/gnat-gpl-2021-r5:10/10::gentoo, ebuild scheduled for merge) (buildtime)
  (sys-devel/gcc-13.2.1_p20240210:13/13::gentoo, ebuild scheduled for merge) (buildtime)
```
Reported on IRC by dormito.
Fixes: 74414ea0c4d70c96bbec234df290d7e5f14d8f51
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 25dedd4e5262..7d69f3b90e91 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -393,7 +393,7 @@ fi
 
 # TODO: Add a pkg_setup & pkg_pretend check for whether the active compiler
 # supports Ada.
-if tc_has_feature ada ; then
+if [[ ${PN} != gnat-gpl ]] && tc_has_feature ada ; then
 	BDEPEND+=" ada? ( || ( sys-devel/gcc[ada] dev-lang/gnat-gpl[ada] ) )"
 fi
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-14  8:20 Florian Schmaus
  0 siblings, 0 replies; 6663+ messages in thread
From: Florian Schmaus @ 2024-05-14  8:20 UTC (permalink / raw
  To: gentoo-commits
commit:     7d549d95818204c6d7a770d1c0de0fa0e6fcb5e8
Author:     Florian Schmaus <flow <AT> gentoo <DOT> org>
AuthorDate: Fri Apr  5 12:45:54 2024 +0000
Commit:     Florian Schmaus <flow <AT> gentoo <DOT> org>
CommitDate: Tue May 14 07:58:12 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=7d549d95
texlive-common.eclass: eftmutil-sys: use edob
Signed-off-by: Florian Schmaus <flow <AT> gentoo.org>
 eclass/texlive-common.eclass | 8 +++++---
 1 file changed, 5 insertions(+), 3 deletions(-)
diff --git a/eclass/texlive-common.eclass b/eclass/texlive-common.eclass
index 15d475799a88..072581dde78e 100644
--- a/eclass/texlive-common.eclass
+++ b/eclass/texlive-common.eclass
@@ -22,6 +22,8 @@ case ${EAPI} in
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
+inherit edo
+
 if [[ -z ${_TEXLIVE_COMMON_ECLASS} ]]; then
 _TEXLIVE_COMMON_ECLASS=1
 
@@ -199,9 +201,9 @@ etexmf-update() {
 efmtutil-sys() {
 	if has_version 'app-text/texlive-core' ; then
 		if [[ -z ${ROOT} && -x "${EPREFIX}"/usr/bin/fmtutil-sys ]] ; then
-			einfo "Rebuilding formats"
-			"${EPREFIX}"/usr/bin/fmtutil-sys --all &> /dev/null ||
-				die -n "fmtutil-sys returned non-zero exit status ${?}"
+			edob -m "Rebuilding TexLive formats" \
+				 -l fmtutils-sys-all \
+				 "${EPREFIX}"/usr/bin/fmtutil-sys --all
 		else
 			ewarn "Cannot run fmtutil-sys for some reason."
 			ewarn "Your formats might be inconsistent with your installed ${PN} version"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-14  9:19 Florian Schmaus
  0 siblings, 0 replies; 6663+ messages in thread
From: Florian Schmaus @ 2024-05-14  9:19 UTC (permalink / raw
  To: gentoo-commits
commit:     b5d7d615c01a4b76bccde0a06de3a9ac3c7a850c
Author:     Florian Schmaus <flow <AT> gentoo <DOT> org>
AuthorDate: Tue May 14 09:19:09 2024 +0000
Commit:     Florian Schmaus <flow <AT> gentoo <DOT> org>
CommitDate: Tue May 14 09:19:24 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=b5d7d615
edob: do not die if log file exists
Signed-off-by: Florian Schmaus <flow <AT> gentoo.org>
 eclass/edo.eclass | 1 -
 1 file changed, 1 deletion(-)
diff --git a/eclass/edo.eclass b/eclass/edo.eclass
index ed8ec8d3201e..5fd77a676a8b 100644
--- a/eclass/edo.eclass
+++ b/eclass/edo.eclass
@@ -80,7 +80,6 @@ edob() {
 	[[ -z ${log_name} ]] && log_name="$(basename ${1})"
 
 	local log_file="${T}/${log_name}.log"
-	[[ -f ${log_file} ]] && die "Log file ${log_file} exists. Consider using \"edob -l\""
 
 	ebegin "${message}"
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-15 14:20 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-05-15 14:20 UTC (permalink / raw
  To: gentoo-commits
commit:     32928116fdcf631b6999705c78640e5718bd7a27
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat May 11 18:53:28 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Wed May 15 14:19:43 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=32928116
cargo.eclass: Optimize crate unpacking
Unpack crates in parallel using xargs to utilize multicore systems
better.  Perform checksumming via a single sha256sum invocation.
For dev-python/watchfiles, this speeds up unpacking on my machine
from 2.6 s to 0.75 s (warm cache).
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
Closes: https://github.com/gentoo/gentoo/pull/36645
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/cargo.eclass | 56 +++++++++++++++++++++++++++++++----------------------
 1 file changed, 33 insertions(+), 23 deletions(-)
diff --git a/eclass/cargo.eclass b/eclass/cargo.eclass
index 0f2da982f60c..5a16d3a30528 100644
--- a/eclass/cargo.eclass
+++ b/eclass/cargo.eclass
@@ -329,40 +329,50 @@ _cargo_gen_git_config() {
 cargo_src_unpack() {
 	debug-print-function ${FUNCNAME} "$@"
 
-	mkdir -p "${ECARGO_VENDOR}" || die
-	mkdir -p "${S}" || die
+	mkdir -p "${ECARGO_VENDOR}" "${S}" || die
 
 	local archive shasum pkg
+	local crates=()
 	for archive in ${A}; do
 		case "${archive}" in
 			*.crate)
-				# when called by pkgdiff-mg, do not unpack crates
-				[[ ${PKGBUMPING} == ${PVR} ]] && continue
-
-				ebegin "Loading ${archive} into Cargo registry"
-				tar -xf "${DISTDIR}"/${archive} -C "${ECARGO_VENDOR}/" || die
-				# generate sha256sum of the crate itself as cargo needs this
-				shasum=$(sha256sum "${DISTDIR}"/${archive} | cut -d ' ' -f 1)
-				pkg=$(basename ${archive} .crate)
-				cat <<- EOF > ${ECARGO_VENDOR}/${pkg}/.cargo-checksum.json
-				{
-					"package": "${shasum}",
-					"files": {}
-				}
-				EOF
-				# if this is our target package we need it in ${WORKDIR} too
-				# to make ${S} (and handle any revisions too)
-				if [[ ${P} == ${pkg}* ]]; then
-					tar -xf "${DISTDIR}"/${archive} -C "${WORKDIR}" || die
-				fi
-				eend $?
+				crates+=( "${archive}" )
 				;;
 			*)
-				unpack ${archive}
+				unpack "${archive}"
 				;;
 		esac
 	done
 
+	if [[ ${PKGBUMPING} != ${PVR} ]]; then
+		pushd "${DISTDIR}" >/dev/null || die
+
+		ebegin "Unpacking crates"
+		printf '%s\0' "${crates[@]}" |
+			xargs -0 -P "$(makeopts_jobs)" -n 1 -- \
+				tar -x -C "${ECARGO_VENDOR}" -f
+		assert
+		eend $?
+
+		while read -d '' -r shasum archive; do
+			pkg=${archive%.crate}
+			cat <<- EOF > ${ECARGO_VENDOR}/${pkg}/.cargo-checksum.json || die
+			{
+				"package": "${shasum}",
+				"files": {}
+			}
+			EOF
+
+			# if this is our target package we need it in ${WORKDIR} too
+			# to make ${S} (and handle any revisions too)
+			if [[ ${P} == ${pkg}* ]]; then
+				tar -xf "${archive}" -C "${WORKDIR}" || die
+			fi
+		done < <(sha256sum -z "${crates[@]}" || die)
+
+		popd >/dev/null || die
+	fi
+
 	cargo_gen_config
 }
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-15 18:02 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-05-15 18:02 UTC (permalink / raw
  To: gentoo-commits
commit:     ec0d09c191f0b047aec7c9dad3abca98973fb972
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Wed May 15 18:02:03 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Wed May 15 18:02:03 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=ec0d09c1
cargo.eclass: Revert "Optimize crate unpacking"
Reverts: 32928116fdcf631b6999705c78640e5718bd7a27
Bug: https://bugs.gentoo.org/931955
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/cargo.eclass | 56 ++++++++++++++++++++++-------------------------------
 1 file changed, 23 insertions(+), 33 deletions(-)
diff --git a/eclass/cargo.eclass b/eclass/cargo.eclass
index 5a16d3a30528..0f2da982f60c 100644
--- a/eclass/cargo.eclass
+++ b/eclass/cargo.eclass
@@ -329,50 +329,40 @@ _cargo_gen_git_config() {
 cargo_src_unpack() {
 	debug-print-function ${FUNCNAME} "$@"
 
-	mkdir -p "${ECARGO_VENDOR}" "${S}" || die
+	mkdir -p "${ECARGO_VENDOR}" || die
+	mkdir -p "${S}" || die
 
 	local archive shasum pkg
-	local crates=()
 	for archive in ${A}; do
 		case "${archive}" in
 			*.crate)
-				crates+=( "${archive}" )
+				# when called by pkgdiff-mg, do not unpack crates
+				[[ ${PKGBUMPING} == ${PVR} ]] && continue
+
+				ebegin "Loading ${archive} into Cargo registry"
+				tar -xf "${DISTDIR}"/${archive} -C "${ECARGO_VENDOR}/" || die
+				# generate sha256sum of the crate itself as cargo needs this
+				shasum=$(sha256sum "${DISTDIR}"/${archive} | cut -d ' ' -f 1)
+				pkg=$(basename ${archive} .crate)
+				cat <<- EOF > ${ECARGO_VENDOR}/${pkg}/.cargo-checksum.json
+				{
+					"package": "${shasum}",
+					"files": {}
+				}
+				EOF
+				# if this is our target package we need it in ${WORKDIR} too
+				# to make ${S} (and handle any revisions too)
+				if [[ ${P} == ${pkg}* ]]; then
+					tar -xf "${DISTDIR}"/${archive} -C "${WORKDIR}" || die
+				fi
+				eend $?
 				;;
 			*)
-				unpack "${archive}"
+				unpack ${archive}
 				;;
 		esac
 	done
 
-	if [[ ${PKGBUMPING} != ${PVR} ]]; then
-		pushd "${DISTDIR}" >/dev/null || die
-
-		ebegin "Unpacking crates"
-		printf '%s\0' "${crates[@]}" |
-			xargs -0 -P "$(makeopts_jobs)" -n 1 -- \
-				tar -x -C "${ECARGO_VENDOR}" -f
-		assert
-		eend $?
-
-		while read -d '' -r shasum archive; do
-			pkg=${archive%.crate}
-			cat <<- EOF > ${ECARGO_VENDOR}/${pkg}/.cargo-checksum.json || die
-			{
-				"package": "${shasum}",
-				"files": {}
-			}
-			EOF
-
-			# if this is our target package we need it in ${WORKDIR} too
-			# to make ${S} (and handle any revisions too)
-			if [[ ${P} == ${pkg}* ]]; then
-				tar -xf "${archive}" -C "${WORKDIR}" || die
-			fi
-		done < <(sha256sum -z "${crates[@]}" || die)
-
-		popd >/dev/null || die
-	fi
-
 	cargo_gen_config
 }
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-17  6:25 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-05-17  6:25 UTC (permalink / raw
  To: gentoo-commits
commit:     bf9a8b7af96bb7161956fc8276d9d07f021bda8a
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat May 11 18:53:28 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Fri May 17 06:25:48 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=bf9a8b7a
cargo.eclass: Optimize crate unpacking
Unpack crates in parallel using xargs to utilize multicore systems
better.  Perform checksumming via a single sha256sum invocation.
For dev-python/watchfiles, this speeds up unpacking on my machine
from 2.6 s to 0.75 s (warm cache).
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
Closes: https://github.com/gentoo/gentoo/pull/36645
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/cargo.eclass | 56 +++++++++++++++++++++++++++++++----------------------
 1 file changed, 33 insertions(+), 23 deletions(-)
diff --git a/eclass/cargo.eclass b/eclass/cargo.eclass
index 0f2da982f60c..a685cd99fb38 100644
--- a/eclass/cargo.eclass
+++ b/eclass/cargo.eclass
@@ -329,40 +329,50 @@ _cargo_gen_git_config() {
 cargo_src_unpack() {
 	debug-print-function ${FUNCNAME} "$@"
 
-	mkdir -p "${ECARGO_VENDOR}" || die
-	mkdir -p "${S}" || die
+	mkdir -p "${ECARGO_VENDOR}" "${S}" || die
 
 	local archive shasum pkg
+	local crates=()
 	for archive in ${A}; do
 		case "${archive}" in
 			*.crate)
-				# when called by pkgdiff-mg, do not unpack crates
-				[[ ${PKGBUMPING} == ${PVR} ]] && continue
-
-				ebegin "Loading ${archive} into Cargo registry"
-				tar -xf "${DISTDIR}"/${archive} -C "${ECARGO_VENDOR}/" || die
-				# generate sha256sum of the crate itself as cargo needs this
-				shasum=$(sha256sum "${DISTDIR}"/${archive} | cut -d ' ' -f 1)
-				pkg=$(basename ${archive} .crate)
-				cat <<- EOF > ${ECARGO_VENDOR}/${pkg}/.cargo-checksum.json
-				{
-					"package": "${shasum}",
-					"files": {}
-				}
-				EOF
-				# if this is our target package we need it in ${WORKDIR} too
-				# to make ${S} (and handle any revisions too)
-				if [[ ${P} == ${pkg}* ]]; then
-					tar -xf "${DISTDIR}"/${archive} -C "${WORKDIR}" || die
-				fi
-				eend $?
+				crates+=( "${archive}" )
 				;;
 			*)
-				unpack ${archive}
+				unpack "${archive}"
 				;;
 		esac
 	done
 
+	if [[ ${PKGBUMPING} != ${PVR} && ${crates[@]} ]]; then
+		pushd "${DISTDIR}" >/dev/null || die
+
+		ebegin "Unpacking crates"
+		printf '%s\0' "${crates[@]}" |
+			xargs -0 -P "$(makeopts_jobs)" -n 1 -t -- \
+				tar -x -C "${ECARGO_VENDOR}" -f
+		assert
+		eend $?
+
+		while read -d '' -r shasum archive; do
+			pkg=${archive%.crate}
+			cat <<- EOF > ${ECARGO_VENDOR}/${pkg}/.cargo-checksum.json || die
+			{
+				"package": "${shasum}",
+				"files": {}
+			}
+			EOF
+
+			# if this is our target package we need it in ${WORKDIR} too
+			# to make ${S} (and handle any revisions too)
+			if [[ ${P} == ${pkg}* ]]; then
+				tar -xf "${archive}" -C "${WORKDIR}" || die
+			fi
+		done < <(sha256sum -z "${crates[@]}" || die)
+
+		popd >/dev/null || die
+	fi
+
 	cargo_gen_config
 }
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-17 12:07 Andrew Ammerlaan
  0 siblings, 0 replies; 6663+ messages in thread
From: Andrew Ammerlaan @ 2024-05-17 12:07 UTC (permalink / raw
  To: gentoo-commits
commit:     f439b4ec05b1982f06f67fbf39a46ae0db187a76
Author:     Andrew Ammerlaan <andrewammerlaan <AT> gentoo <DOT> org>
AuthorDate: Wed May  8 06:02:53 2024 +0000
Commit:     Andrew Ammerlaan <andrewammerlaan <AT> gentoo <DOT> org>
CommitDate: Fri May 17 12:06:42 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=f439b4ec
linux-mod-r1.eclass: add USE=initramfs
Adds a new variable that adds the "initramfs" flag when set. This new
flag controls whether or not the modules that were built should be
included in the initramfs. If the modules should be included, then we
also rebuild the initramfs/uki in post_install using installkernel.
Bug: https://bugs.gentoo.org/923025
Bug: https://bugs.gentoo.org/928271
Signed-off-by: Andrew Ammerlaan <andrewammerlaan <AT> gentoo.org>
 eclass/linux-mod-r1.eclass | 54 ++++++++++++++++++++++++++++++++++++++++++++++
 1 file changed, 54 insertions(+)
diff --git a/eclass/linux-mod-r1.eclass b/eclass/linux-mod-r1.eclass
index 4b267aae4db1..d9651f962604 100644
--- a/eclass/linux-mod-r1.eclass
+++ b/eclass/linux-mod-r1.eclass
@@ -131,6 +131,15 @@ IDEPEND="
 	sys-apps/kmod[tools]
 "
 
+if [[ ${MODULES_INITRAMFS_IUSE} ]]; then
+	IUSE+=" ${MODULES_INITRAMFS_IUSE}"
+	IDEPEND+="
+		${MODULES_INITRAMFS_IUSE#+}? (
+			sys-kernel/installkernel
+		)
+	"
+fi
+
 if [[ -n ${MODULES_OPTIONAL_IUSE} ]]; then
 	: "${MODULES_OPTIONAL_IUSE#+}? ( | )"
 	RDEPEND=${_/|/${RDEPEND}} DEPEND=${_/|/${DEPEND}} \
@@ -179,6 +188,22 @@ fi
 #
 # May want to look at KERNEL_CHOST before considering this.
 
+# @ECLASS_VARIABLE: MODULES_INITRAMFS_IUSE
+# @DEFAULT_UNSET
+# @PRE_INHERIT
+# @DESCRIPTION:
+# If set, adds the specified USE flag. When this flag is enabled the
+# installed kernel modules are registered for inclusion in the dracut
+# initramfs. Additionally, if distribution kernels are used
+# (USE="dist-kernel") then these kernels are re-installed.
+#
+# The typical recommended value is "initramfs" or "+initramfs" (global
+# IUSE).
+#
+# If MODULES_INITRAMFS_IUSE is not set, or the specified flag is not
+# enabled, then the installed kernel modules are omitted from the
+# dracut initramfs.
+
 # @ECLASS_VARIABLE: MODULES_SIGN_HASH
 # @USER_VARIABLE
 # @DEFAULT_UNSET
@@ -471,6 +496,19 @@ linux-mod-r1_pkg_postinst() {
 	dist-kernel_compressed_module_cleanup "${EROOT}/lib/modules/${KV_FULL}"
 	_modules_update_depmod
 
+	if [[ -z ${ROOT} && ${MODULES_INITRAMFS_IUSE} ]] &&
+		use dist-kernel && use ${MODULES_INITRAMFS_IUSE#+}
+	then
+			dist-kernel_reinstall_initramfs "${KV_DIR}" "${KV_FULL}"
+	fi
+
+	if has_version virtual/dist-kernel && ! use dist-kernel; then
+		ewarn "virtual/dist-kernel is installed, but USE=\"dist-kernel\""
+		ewarn "is not enabled for ${CATEGORY}/${PN}."
+		ewarn "It's recommended to globally enable the dist-kernel USE flag"
+		ewarn "to automatically trigger initramfs rebuilds on kernel updates"
+	fi
+
 	# post_process ensures modules were installed and that the eclass' USE
 	# are likely not no-ops (unfortunately postinst itself may be missed)
 	[[ -v _MODULES_GLOBAL[ran:post_process] ]] ||
@@ -550,6 +588,7 @@ modules_post_process() {
 	# which can lead to unnecessarily increased size or stale modules)
 #	_modules_process_depmod.d "${mods[@]#"${path}/"}"
 
+	_modules_process_dracut.conf.d "${mods[@]##*/}"
 	_modules_process_strip "${mods[@]}"
 	_modules_process_sign "${mods[@]}"
 	_modules_sanity_modversion "${mods[@]}" # after strip/sign in case broke it
@@ -904,6 +943,21 @@ _modules_process_depmod.d() {
 	)
 }
 
+# @FUNCTION: _modules_process_dracut.conf.d
+# @USAGE: <module>...
+# @INTERNAL
+# @DESCRIPTION:
+# Create dracut.conf.d snippet defining if module should be included in the
+# initramfs.
+_modules_process_dracut.conf.d() {
+	(
+		insinto /usr/lib/dracut/dracut.conf.d
+		[[ ${MODULES_INITRAMFS_IUSE} ]] && use ${MODULES_INITRAMFS_IUSE#+} &&
+			: add || : omit
+		newins - 10-${PN}.conf <<<"${_}_drivers+=\" ${*%.ko} \""
+	)
+}
+
 # @FUNCTION: _modules_process_sign
 # @USAGE: <module>...
 # @INTERNAL
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-17 12:07 Andrew Ammerlaan
  0 siblings, 0 replies; 6663+ messages in thread
From: Andrew Ammerlaan @ 2024-05-17 12:07 UTC (permalink / raw
  To: gentoo-commits
commit:     7ca8ee3261f35705fbe94af7688e41815b42c0e6
Author:     Andrew Ammerlaan <andrewammerlaan <AT> gentoo <DOT> org>
AuthorDate: Thu May  9 17:33:00 2024 +0000
Commit:     Andrew Ammerlaan <andrewammerlaan <AT> gentoo <DOT> org>
CommitDate: Fri May 17 12:06:47 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=7ca8ee32
linux-mod-r1.eclass: do not reset kernel env vars in binpkgs
Closes: https://bugs.gentoo.org/931213
Bug: https://bugs.gentoo.org/926063
Signed-off-by: Andrew Ammerlaan <andrewammerlaan <AT> gentoo.org>
Closes: https://github.com/gentoo/gentoo/pull/36597
Signed-off-by: Andrew Ammerlaan <andrewammerlaan <AT> gentoo.org>
 eclass/linux-mod-r1.eclass | 5 +++++
 1 file changed, 5 insertions(+)
diff --git a/eclass/linux-mod-r1.eclass b/eclass/linux-mod-r1.eclass
index d9651f962604..6060074d8734 100644
--- a/eclass/linux-mod-r1.eclass
+++ b/eclass/linux-mod-r1.eclass
@@ -661,6 +661,11 @@ _modules_check_migration() {
 # Handles linux-info bits to provide usable sources, KV_ variables,
 # and CONFIG_CHECK use.
 _modules_prepare_kernel() {
+	# The modules we build are specific to each kernel version, we don't
+	# want to reset the environment to use the user selected kernel version.
+	# Bug 931213, 926063
+	SKIP_KERNEL_BINPKG_ENV_RESET=1
+
 	get_version
 
 	# linux-info allows skipping checks if SKIP_KERNEL_CHECK is set and
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-17 12:07 Andrew Ammerlaan
  0 siblings, 0 replies; 6663+ messages in thread
From: Andrew Ammerlaan @ 2024-05-17 12:07 UTC (permalink / raw
  To: gentoo-commits
commit:     05ad18f837f89cfa2b20e01264ef6332c240072c
Author:     Andrew Ammerlaan <andrewammerlaan <AT> gentoo <DOT> org>
AuthorDate: Thu May  9 17:01:00 2024 +0000
Commit:     Andrew Ammerlaan <andrewammerlaan <AT> gentoo <DOT> org>
CommitDate: Fri May 17 12:06:46 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=05ad18f8
linux-info.eclass: respect eselect kernel setting in binpkgs
Commit f51cd5b64c14ddfb83488a12d538c66a4a309376 resets kernel environment
variables when binpkgs are merged, this makes sense since we care about the
system that the binpkg will be installed on, not the system the binpkg was
built on. This introduced Bug 931213 as a side-effect, which will be fixed
in a separate commit to linux-mod-r1.eclass. In preparation of that, we document
and rename the LINUX_INFO_BINARY_RESET to SKIP_KERNEL_BINPKG_ENV_RESET.
However, commit f51cd5b64c14ddfb83488a12d538c66a4a309376 also makes binpkgs
always use the running kernel version. This behaviour is surprising and
confusing. In principle the 'eselect kernel' setting should still be respected
when binpkgs are used.
Bug: https://bugs.gentoo.org/926063
Bug: https://bugs.gentoo.org/931213
Signed-off-by: Andrew Ammerlaan <andrewammerlaan <AT> gentoo.org>
 eclass/linux-info.eclass | 14 +++++++++++---
 1 file changed, 11 insertions(+), 3 deletions(-)
diff --git a/eclass/linux-info.eclass b/eclass/linux-info.eclass
index 864594f607ca..9449a6359d2a 100644
--- a/eclass/linux-info.eclass
+++ b/eclass/linux-info.eclass
@@ -158,6 +158,14 @@ KERNEL_DIR="${KERNEL_DIR:-${ROOT%/}/usr/src/linux}"
 # This is a user flag and should under _no circumstances_ be set in the ebuild.
 : "${SKIP_KERNEL_CHECK:=""}"
 
+# @ECLASS_VARIABLE: SKIP_KERNEL_BINPKG_ENV_RESET
+# @DEFAULT_UNSET
+# @DESCRIPTION:
+# If set, do not reset the kernel environment variables when merging a package
+# as a binpkg.
+# Main use-case is for kernel modules, i.e. linux-mod-r1.eclass.
+# This should be set before running linux-info_pkg_setup
+
 # And to ensure all the weirdness with crosscompile
 inherit toolchain-funcs
 [[ ${EAPI} == 6 ]] && inherit eapi7-ver
@@ -696,12 +704,12 @@ linux-info_get_any_version() {
 		die "${FUNCNAME}() called on non-Linux system, please fix the ebuild"
 	fi
 
-	if [[ ${MERGE_TYPE} == binary && -z ${LINUX_INFO_BINARY_RESET} ]]; then
+	if [[ ${MERGE_TYPE} == binary && -z ${SKIP_KERNEL_BINPKG_ENV_RESET} ]]; then
 		unset KV_FULL _LINUX_CONFIG_EXISTS_DONE KV_OUT_DIR
-		LINUX_INFO_BINARY_RESET=1
+		SKIP_KERNEL_BINPKG_ENV_RESET=1
 	fi
 
-	if [[ ${MERGE_TYPE} != binary ]] && ! get_version; then
+	if ! get_version; then
 		ewarn "Unable to calculate Linux Kernel version for build, attempting to use running version"
 	fi
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-17 23:05 Ionen Wolkens
  0 siblings, 0 replies; 6663+ messages in thread
From: Ionen Wolkens @ 2024-05-17 23:05 UTC (permalink / raw
  To: gentoo-commits
commit:     2e1c05e68ecf30083b5fe1e2f83aa0c5548ce9a0
Author:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
AuthorDate: Fri May 17 21:45:44 2024 +0000
Commit:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
CommitDate: Fri May 17 23:02:54 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=2e1c05e6
linux-mod-r1.eclass: update depmod.d comment
Likely a non-issue with dracut now (untested) but will leave it
alone for now and just updating comment. Maybe if users start
having more problems that'd require it or if we want to more
liberally rename modules install paths while ensuring it does not
use the old one on a same kernel (point of this was just to make
things more robust and is not hard-required).
Also adjust the commented out function to match dracut.conf.d (guess
glob makes it more straight forward, not that it's necessary).
Signed-off-by: Ionen Wolkens <ionen <AT> gentoo.org>
 eclass/linux-mod-r1.eclass | 9 +++++----
 1 file changed, 5 insertions(+), 4 deletions(-)
diff --git a/eclass/linux-mod-r1.eclass b/eclass/linux-mod-r1.eclass
index 6060074d8734..6d35a7068bfb 100644
--- a/eclass/linux-mod-r1.eclass
+++ b/eclass/linux-mod-r1.eclass
@@ -583,10 +583,11 @@ modules_post_process() {
 	(( ${#mods[@]} )) ||
 		die "${FUNCNAME[0]} was called with no installed modules under ${path}"
 
-	# TODO?: find way for sane use with dracut (its 90kernel-modules-extra
-	# parses depmod.d files directly and assumes should include its modules
-	# which can lead to unnecessarily increased size or stale modules)
-#	_modules_process_depmod.d "${mods[@]#"${path}/"}"
+	# TODO?: look into re-introducing after verifying it works as expected,
+	# formerly omitted because dracut's 90kernel-modules-extra parses depmod.d
+	# files directly and assumes should include its modules but we now create
+	# dracut omit files that *hopefully* prevent this
+#	_modules_process_depmod.d "${mods[@]##*/}"
 
 	_modules_process_dracut.conf.d "${mods[@]##*/}"
 	_modules_process_strip "${mods[@]}"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-17 23:05 Ionen Wolkens
  0 siblings, 0 replies; 6663+ messages in thread
From: Ionen Wolkens @ 2024-05-17 23:05 UTC (permalink / raw
  To: gentoo-commits
commit:     166cfd020d65a3c4189a0897fa2dc11fa503211f
Author:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
AuthorDate: Fri May 17 21:55:03 2024 +0000
Commit:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
CommitDate: Fri May 17 23:03:39 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=166cfd02
linux-mod-r1.eclass: minor style & misc adjustments
No real functional changes:
* fix indent for dist-kernel_reinstall_initramfs
* explicit return 0 to avoid returning a failure, not that return
  codes should ever be checked for that function
* use printf %q for LD path in case of unlikely spaces
* move dist-kernel version sanity check inside
  _modules_sanity_kernelversion which fits and is called from the
  same function the check was in (also document it)
Signed-off-by: Ionen Wolkens <ionen <AT> gentoo.org>
 eclass/linux-mod-r1.eclass | 47 ++++++++++++++++++++++++----------------------
 1 file changed, 25 insertions(+), 22 deletions(-)
diff --git a/eclass/linux-mod-r1.eclass b/eclass/linux-mod-r1.eclass
index 6d35a7068bfb..43c5a7d7b140 100644
--- a/eclass/linux-mod-r1.eclass
+++ b/eclass/linux-mod-r1.eclass
@@ -499,7 +499,7 @@ linux-mod-r1_pkg_postinst() {
 	if [[ -z ${ROOT} && ${MODULES_INITRAMFS_IUSE} ]] &&
 		use dist-kernel && use ${MODULES_INITRAMFS_IUSE#+}
 	then
-			dist-kernel_reinstall_initramfs "${KV_DIR}" "${KV_FULL}"
+		dist-kernel_reinstall_initramfs "${KV_DIR}" "${KV_FULL}"
 	fi
 
 	if has_version virtual/dist-kernel && ! use dist-kernel; then
@@ -695,24 +695,6 @@ _modules_prepare_kernel() {
 	fi
 
 	linux-info_pkg_setup
-
-	if use dist-kernel &&
-		! has_version "~virtual/dist-kernel-${KV_MAJOR}.${KV_MINOR}.${KV_PATCH}"
-	then
-		ewarn
-		ewarn "The kernel modules in ${CATEGORY}/${PN} are being built for"
-		ewarn "kernel version ${KV_FULL}. But this does not match the"
-		ewarn "installed version of virtual/dist-kernel."
-		ewarn
-		ewarn "If this is not intentional, the problem may be corrected by"
-		ewarn "using \"eselect kernel\" to set the default kernel version to"
-		ewarn "the same version as the installed version of virtual/dist-kernel."
-		ewarn
-		ewarn "If the distribution kernel is being downgraded, ensure that"
-		ewarn "virtual/dist-kernel is also downgraded to the same version"
-		ewarn "before rebuilding external kernel modules."
-		ewarn
-	fi
 }
 
 # @FUNCTION: _modules_prepare_sign
@@ -857,7 +839,7 @@ _modules_prepare_toolchain() {
 	# can work but raises concerns about breaking packages that may use these
 	if linux_chkconfig_present LTO_CLANG_THIN && tc-ld-is-lld; then
 		KERNEL_LD=${T}/linux-mod-r1_ld.lld
-		printf '#!/usr/bin/env sh\nexec %s "${@}" --thinlto-cache-dir=\n' \
+		printf '#!/usr/bin/env sh\nexec %q "${@}" --thinlto-cache-dir=\n' \
 			"${LD}" > "${KERNEL_LD}" || die
 		chmod +x -- "${KERNEL_LD}" || die
 	fi
@@ -899,7 +881,7 @@ _modules_prepare_toolchain() {
 # If enabled in the kernel configuration, this compresses the given
 # modules using the same format.
 _modules_process_compress() {
-	use modules-compress || return
+	use modules-compress || return 0
 
 	local -a compress
 	if linux_chkconfig_present MODULE_COMPRESS_XZ; then
@@ -1144,7 +1126,10 @@ _modules_sanity_kernelbuilt() {
 # @DESCRIPTION:
 # Prints a warning if the kernel version is greater than to
 # MODULES_KERNEL_MAX (while only considering same amount of version
-# components), or aborts if it is less than MODULES_KERNEL_MIN
+# components), or aborts if it is less than MODULES_KERNEL_MIN.
+#
+# With USE=dist-kernel, also warn if virtual/dist-kernel is of a
+# different version than the one being built against.
 _modules_sanity_kernelversion() {
 	local kv=${KV_MAJOR}.${KV_MINOR}.${KV_PATCH}
 
@@ -1194,6 +1179,24 @@ _modules_sanity_kernelversion() {
 			ewarn
 		fi
 	fi
+
+	if use dist-kernel &&
+		! has_version "~virtual/dist-kernel-${KV_MAJOR}.${KV_MINOR}.${KV_PATCH}"
+	then
+		ewarn
+		ewarn "The kernel modules in ${CATEGORY}/${PN} are being built for"
+		ewarn "kernel version ${KV_FULL}. But this does not match the"
+		ewarn "installed version of virtual/dist-kernel."
+		ewarn
+		ewarn "If this is not intentional, the problem may be corrected by"
+		ewarn "using \"eselect kernel\" to set the default kernel version to"
+		ewarn "the same version as the installed version of virtual/dist-kernel."
+		ewarn
+		ewarn "If the distribution kernel is being downgraded, ensure that"
+		ewarn "virtual/dist-kernel is also downgraded to the same version"
+		ewarn "before rebuilding external kernel modules."
+		ewarn
+	fi
 }
 
 # @FUNCTION: _modules_sanity_modversion
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-18  3:50 Benda XU
  0 siblings, 0 replies; 6663+ messages in thread
From: Benda XU @ 2024-05-18  3:50 UTC (permalink / raw
  To: gentoo-commits
commit:     bd29b1782a348f0017d74a92204acd6f2704c96c
Author:     Yiyang Wu <xgreenlandforwyy <AT> gmail <DOT> com>
AuthorDate: Mon Apr  8 06:10:07 2024 +0000
Commit:     Benda XU <heroxbd <AT> gentoo <DOT> org>
CommitDate: Sat May 18 03:45:39 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=bd29b178
rocm.eclass: remove xnack flag for broader compatibility
Initially, rocm.eclass append xnack[1,2] feature flag to gfx9 GPUs,
since ROCm upstream does this in many of their math libraries, e.g.
rocBLAS [3]. The list includes gfx90a:xnack+, indicating xnack is usable
for MI200 series, thus rocm.eclass append :xnack+ to gfx90a.
But it turns out xnack- is also common for MI200 series, restricting to
xnack+ produces incompatible GPU kernel with xnack- mode.
Also, community also explores using xnack on other gfx9 GPU [4,5], which
is previously restricted to xnack- in rocm.eclass.
By not appending xnack feature flag, GPU kernels are compiled to "xnack
any" mode, which can be run in either mode, potentially scarifying some
performance [6,7], with no direct evidence. rocFFT reports no
performance penalty[8].
For the reason above, do not append xnack feature flag to AMDGPU_TARGETS,
which is compatible with GPUs operate in both xnack mode.
[1] https://wiki.gentoo.org/wiki/ROCm#XNACK_target_feature
[2] https://rocm.docs.amd.com/en/latest/conceptual/gpu-memory.html#xnack
[3] https://github.com/ROCm/rocBLAS/blob/release/rocm-rel-5.0/CMakeLists.txt#L201
[4] https://niconiconi.neocities.org/tech-notes/xnack-on-amd-gpus/
[5] https://arxiv.org/abs/2401.02680
[6] https://llvm.org/docs/AMDGPUUsage.html#target-features
[7] https://docs.olcf.ornl.gov/systems/crusher_quick_start_guide.html#compiling-hip-kernels-for-specific-xnack-modes
[8] https://github.com/ROCm/rocFFT/commit/cd2689360ba3b3579d044d8925838ff307b4b4cf
Signed-off-by: Yiyang Wu <xgreenlandforwyy <AT> gmail.com>
Signed-off-by: Benda Xu <heroxbd <AT> gentoo.org>
Closes: https://github.com/gentoo/gentoo/pull/36254
 eclass/rocm.eclass | 19 ++-----------------
 1 file changed, 2 insertions(+), 17 deletions(-)
diff --git a/eclass/rocm.eclass b/eclass/rocm.eclass
index 9804ecde97d0..e03e8bdd507a 100644
--- a/eclass/rocm.eclass
+++ b/eclass/rocm.eclass
@@ -1,4 +1,4 @@
-# Copyright 2022-2023 Gentoo Authors
+# Copyright 2022-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: rocm.eclass
@@ -201,22 +201,7 @@ unset -f _rocm_set_globals
 # Append default target feature to GPU arch. See
 # https://llvm.org/docs/AMDGPUUsage.html#target-features
 get_amdgpu_flags() {
-	local amdgpu_target_flags
-	for gpu_target in ${AMDGPU_TARGETS}; do
-	local target_feature=
-		case ${gpu_target} in
-			gfx906|gfx908)
-				target_feature=:xnack-
-				;;
-			gfx90a)
-				target_feature=:xnack+
-				;;
-			*)
-				;;
-		esac
-		amdgpu_target_flags+="${gpu_target}${target_feature};"
-	done
-	echo "${amdgpu_target_flags}"
+	echo $(printf "%s;" ${AMDGPU_TARGETS[@]})
 }
 
 # @FUNCTION: check_amdgpu
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-18 13:25 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-05-18 13:25 UTC (permalink / raw
  To: gentoo-commits
commit:     277634d1957c735f02bd64a3a68ccf05995d8a16
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat May 18 13:08:10 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat May 18 13:25:16 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=277634d1
Add 19.0.0_pre20240518 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index 3ada7d2a373b..08fa68022174 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -72,6 +72,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 			_LLVM_SOURCE_TYPE=snapshot
 
 			case ${PV} in
+				19.0.0_pre20240518)
+					EGIT_COMMIT=702198fc9ac5dba392f9d9ba7c56467996343c0a
+					;;
 				19.0.0_pre20240509)
 					EGIT_COMMIT=a7ee81e8279e0bf6e05617a4a638e5f2f8e45022
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-20 17:02 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-05-20 17:02 UTC (permalink / raw
  To: gentoo-commits
commit:     a3895e6ab84b171c1470ac790b8002d9d9a820de
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Tue May 14 11:13:52 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Mon May 20 16:56:42 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=a3895e6a
distutils-r1.eclass: Add a QA warning for pure Python file mismatch
If the package is creating at least one pure Python wheel, check whether
the baseline package contents (i.e. everything but compiled Python
modules, extensions and .dist-info) match between implementations.
This is meant to ensure that we can safely optimize builds by reusing
pure Python wheels from previous builds.
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/distutils-r1.eclass | 40 ++++++++++++++++++++++++++++++++++++++++
 1 file changed, 40 insertions(+)
diff --git a/eclass/distutils-r1.eclass b/eclass/distutils-r1.eclass
index 955c41fe4e2d..29e901720e6c 100644
--- a/eclass/distutils-r1.eclass
+++ b/eclass/distutils-r1.eclass
@@ -2022,6 +2022,44 @@ distutils-r1_src_configure() {
 	return ${ret}
 }
 
+# @FUNCTION: _distutils-r1_compare_installed_files
+# @INTERNAL
+# @DESCRIPTION:
+# Verify the the match between files installed between this and previous
+# implementation.
+_distutils-r1_compare_installed_files() {
+	debug-print-function ${FUNCNAME} "${@}"
+
+	# QA check requires diff(1).
+	if ! type -P diff &>/dev/null; then
+		return
+	fi
+
+	# Perform the check only if at least one potentially reusable wheel
+	# has been produced.  Nonpure packages (e.g. NumPy) may install
+	# interpreter configuration details into sitedir.
+	if [[ ${!DISTUTILS_WHEELS[*]} != *-none-any.whl* &&
+			${!DISTUTILS_WHEELS[*]} != *-abi3-*.whl ]]; then
+		return
+	fi
+
+	local sitedir=${BUILD_DIR}/install$(python_get_sitedir)
+	if [[ -n ${_DISTUTILS_PREVIOUS_SITE} ]]; then
+		diff -dur \
+			--exclude=__pycache__ \
+			--exclude='*.dist-info' \
+			--exclude="*$(get_modname)" \
+			"${_DISTUTILS_PREVIOUS_SITE}" "${sitedir}"
+		if [[ ${?} -ne 0 ]]; then
+			eqawarn "Package creating at least one pure Python wheel installs different"
+			eqawarn "Python files between implementations.  See diff in build log, above"
+			eqawarn "this message."
+		fi
+	fi
+
+	_DISTUTILS_PREVIOUS_SITE=${sitedir}
+}
+
 # @FUNCTION: _distutils-r1_post_python_compile
 # @INTERNAL
 # @DESCRIPTION:
@@ -2056,6 +2094,8 @@ _distutils-r1_post_python_compile() {
 		find "${bindir}" -type f -exec sed -i \
 			-e "1s@^#!\(${EPREFIX}/usr/bin/\(python\|pypy\)\)@#!${root}\1@" \
 			{} + || die
+
+		_distutils-r1_compare_installed_files
 	fi
 }
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-20 17:02 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-05-20 17:02 UTC (permalink / raw
  To: gentoo-commits
commit:     314c6b009037cf21ddfb35b6c372c5dd3819e0c5
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Tue May 14 12:09:24 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Mon May 20 16:56:43 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=314c6b00
distutils-r1.eclass: Support reusing prior wheels when compatible
Support reusing the wheels built for earlier Python implementations
if they are compatible with the subsequent implementations being built.
This includes pure Python wheels in packages that do not set
DISTUTILS_EXT, and stable ABI wheels.
Closes: https://bugs.gentoo.org/931689
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/distutils-r1.eclass | 38 ++++++++++++++++++++++++++++++++++++++
 1 file changed, 38 insertions(+)
diff --git a/eclass/distutils-r1.eclass b/eclass/distutils-r1.eclass
index 29e901720e6c..a8f9817a3cf0 100644
--- a/eclass/distutils-r1.eclass
+++ b/eclass/distutils-r1.eclass
@@ -189,6 +189,18 @@ esac
 #     ${DISTUTILS_DEPS}"
 # @CODE
 
+# @ECLASS_VARIABLE: DISTUTILS_ALLOW_WHEEL_REUSE
+# @DEFAULT_UNSET
+# @USER_VARIABLE
+# @DESCRIPTION:
+# If set to a non-empty value, the eclass is allowed to reuse a wheel
+# that was built for a prior Python implementation, provided that it is
+# compatible with the current one, rather than building a new one.
+#
+# This is an optimization that can avoid the overhead of calling into
+# the build system in pure Python packages and packages using the stable
+# Python ABI.
+
 if [[ -z ${_DISTUTILS_R1_ECLASS} ]]; then
 _DISTUTILS_R1_ECLASS=1
 
@@ -1585,6 +1597,32 @@ distutils-r1_python_compile() {
 	esac
 
 	if [[ ${DISTUTILS_USE_PEP517} ]]; then
+		if [[ ${DISTUTILS_ALLOW_WHEEL_REUSE} ]]; then
+			local whl
+			for whl in "${!DISTUTILS_WHEELS[@]}"; do
+				# use only wheels corresponding to the current directory
+				if [[ ${PWD} != ${DISTUTILS_WHEELS["${whl}"]} ]]; then
+					continue
+				fi
+
+				# 1. Use pure Python wheels only if we're not expected
+				# to build extensions.  Otherwise, we may end up
+				# not building the extension at all when e.g. PyPy3
+				# is built without one.
+				#
+				# 2. For CPython, we can reuse stable ABI wheels.  Note
+				# that this relies on the assumption that we're building
+				# from the oldest to the newest implementation,
+				# and the wheels are forward-compatible.
+				if [[ ( ! ${DISTUTILS_EXT} && ${whl} == *py3-none-any* ) ||
+					( ${EPYTHON} == python* && ${whl} == *-abi3-* ) ]]
+				then
+					distutils_wheel_install "${BUILD_DIR}/install" "${whl}"
+					return
+				fi
+			done
+		fi
+
 		distutils_pep517_install "${BUILD_DIR}/install"
 		DISTUTILS_WHEELS+=( "${DISTUTILS_WHEEL_PATH}" "${PWD}" )
 	fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-20 17:02 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-05-20 17:02 UTC (permalink / raw
  To: gentoo-commits
commit:     a0e04d66dad73b419f423ef1a3e0459f7715da50
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Tue May 14 10:26:59 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Mon May 20 16:56:42 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=a0e04d66
distutils-r1.eclass: Store created wheels in DISTUTILS_WHEELS
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/distutils-r1.eclass | 11 +++++++++++
 1 file changed, 11 insertions(+)
diff --git a/eclass/distutils-r1.eclass b/eclass/distutils-r1.eclass
index 1037c0abe239..955c41fe4e2d 100644
--- a/eclass/distutils-r1.eclass
+++ b/eclass/distutils-r1.eclass
@@ -1532,6 +1532,15 @@ distutils_pep517_install() {
 	DISTUTILS_WHEEL_PATH=${WHEEL_BUILD_DIR}/${wheel}
 }
 
+# @VARIABLE: DISTUTILS_WHEELS
+# @DESCRIPTION:
+# An associative array of wheels created as a result
+# of distutils-r1_python_compile invocations, mapped to the source
+# directories.  Note that this includes only wheels implicitly created
+# by the eclass, and not wheels created as a result of direct
+# distutils_pep517_install calls in the ebuild.
+declare -g -A DISTUTILS_WHEELS=()
+
 # @FUNCTION: distutils-r1_python_compile
 # @USAGE: [additional-args...]
 # @DESCRIPTION:
@@ -1541,6 +1550,7 @@ distutils_pep517_install() {
 #
 # If DISTUTILS_USE_PEP517 is set to any other value, builds a wheel
 # using the PEP517 backend and installs it into ${BUILD_DIR}/install.
+# Path to the wheel is then added to DISTUTILS_WHEELS array.
 #
 # In legacy mode, runs 'esetup.py build'. Any parameters passed to this
 # function will be appended to setup.py invocation, i.e. passed
@@ -1576,6 +1586,7 @@ distutils-r1_python_compile() {
 
 	if [[ ${DISTUTILS_USE_PEP517} ]]; then
 		distutils_pep517_install "${BUILD_DIR}/install"
+		DISTUTILS_WHEELS+=( "${DISTUTILS_WHEEL_PATH}" "${PWD}" )
 	fi
 }
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-20 17:02 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-05-20 17:02 UTC (permalink / raw
  To: gentoo-commits
commit:     c607b1afeebb85474a0beac84944e7ad54d0a54e
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Tue May 14 10:17:08 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Mon May 20 16:56:41 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=c607b1af
distutils-r1.eclass: Set DISTUTILS_WHEEL_PATH in PEP517 install
Store the created wheel path in DISTUTILS_WHEEL_PATH when returning
from distutils_pep517_install.
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/distutils-r1.eclass | 9 ++++++++-
 1 file changed, 8 insertions(+), 1 deletion(-)
diff --git a/eclass/distutils-r1.eclass b/eclass/distutils-r1.eclass
index a67122a59a33..1037c0abe239 100644
--- a/eclass/distutils-r1.eclass
+++ b/eclass/distutils-r1.eclass
@@ -1343,6 +1343,10 @@ distutils_wheel_install() {
 		\) -delete || die
 }
 
+# @VARIABLE: DISTUTILS_WHEEL_PATH
+# @DESCRIPTION:
+# Path to the wheel created by distutils_pep517_install.
+
 # @FUNCTION: distutils_pep517_install
 # @USAGE: <root>
 # @DESCRIPTION:
@@ -1350,7 +1354,8 @@ distutils_wheel_install() {
 # backend and install it into <root>.
 #
 # This function is intended for expert use only.  It does not handle
-# wrapping executables.
+# wrapping executables.  The wheel path is returned
+# in DISTUTILS_WHEEL_PATH variable.
 distutils_pep517_install() {
 	debug-print-function ${FUNCNAME} "${@}"
 	[[ ${#} -eq 1 ]] || die "${FUNCNAME} takes exactly one argument: root"
@@ -1523,6 +1528,8 @@ distutils_pep517_install() {
 	[[ -n ${wheel} ]] || die "No wheel name returned"
 
 	distutils_wheel_install "${root}" "${WHEEL_BUILD_DIR}/${wheel}"
+
+	DISTUTILS_WHEEL_PATH=${WHEEL_BUILD_DIR}/${wheel}
 }
 
 # @FUNCTION: distutils-r1_python_compile
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-20 17:02 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-05-20 17:02 UTC (permalink / raw
  To: gentoo-commits
commit:     6cc41bab19c96e2bf1456389fd368f98ba16605c
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Wed May 15 15:40:39 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Mon May 20 16:56:45 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=6cc41bab
distutils-r1.eclass: Update scikit-build-core to 0.9.4
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/distutils-r1.eclass | 8 +++-----
 1 file changed, 3 insertions(+), 5 deletions(-)
diff --git a/eclass/distutils-r1.eclass b/eclass/distutils-r1.eclass
index a8f9817a3cf0..3aa2c8984ab2 100644
--- a/eclass/distutils-r1.eclass
+++ b/eclass/distutils-r1.eclass
@@ -279,7 +279,7 @@ _distutils_set_globals() {
 				;;
 			scikit-build-core)
 				bdep+='
-					>=dev-python/scikit-build-core-0.8.2[${PYTHON_USEDEP}]
+					>=dev-python/scikit-build-core-0.9.4[${PYTHON_USEDEP}]
 				'
 				;;
 			setuptools)
@@ -1457,8 +1457,6 @@ distutils_pep517_install() {
 				"${DISTUTILS_ARGS[@]}"
 			)
 
-			# NB: we need to pass strings for boolean fields
-			# https://github.com/scikit-build/scikit-build-core/issues/707
 			config_settings=$(
 				"${EPYTHON}" - "${cmake_args[@]}" <<-EOF || die
 					import json
@@ -1466,8 +1464,8 @@ distutils_pep517_install() {
 					print(json.dumps({
 						"cmake.args": ";".join(sys.argv[1:]),
 						"cmake.build-type": "${CMAKE_BUILD_TYPE}",
-						"cmake.verbose": "true",
-						"install.strip": "false",
+						"cmake.verbose": True,
+						"install.strip": False,
 					}))
 				EOF
 			)
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-20 17:02 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-05-20 17:02 UTC (permalink / raw
  To: gentoo-commits
commit:     e6198d16c66dea2cf6db7fb528cd911493c90bd2
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Wed May 15 15:42:19 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Mon May 20 16:56:45 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=e6198d16
distutils-r1.eclass: Pass ninja options to scikit-build-core
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/distutils-r1.eclass | 6 ++++++
 1 file changed, 6 insertions(+)
diff --git a/eclass/distutils-r1.eclass b/eclass/distutils-r1.eclass
index 3aa2c8984ab2..71b80fafe1a5 100644
--- a/eclass/distutils-r1.eclass
+++ b/eclass/distutils-r1.eclass
@@ -1457,11 +1457,17 @@ distutils_pep517_install() {
 				"${DISTUTILS_ARGS[@]}"
 			)
 
+			local -x NINJAOPTS=$(get_NINJAOPTS)
 			config_settings=$(
 				"${EPYTHON}" - "${cmake_args[@]}" <<-EOF || die
 					import json
+					import os
+					import shlex
 					import sys
+
+					ninjaopts = shlex.split(os.environ["NINJAOPTS"])
 					print(json.dumps({
+						"build.tool-args": ninjaopts,
 						"cmake.args": ";".join(sys.argv[1:]),
 						"cmake.build-type": "${CMAKE_BUILD_TYPE}",
 						"cmake.verbose": True,
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-20 17:02 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-05-20 17:02 UTC (permalink / raw
  To: gentoo-commits
commit:     d5e060a2d9ae439620689acc720d9a11a859a3a1
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Fri May 17 13:09:44 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Mon May 20 16:56:46 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=d5e060a2
python-utils-r1.eclass: Fix cleanup in failing epytest
Fix epytest to call `die -n` after performing the cleanup, rather than
before.  This ensures that stray cache files are cleaned up even if
we're actually going to die, e.g. when using
`FEATURES=test-fail-continue`.
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
Closes: https://github.com/gentoo/gentoo/pull/36672
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/python-utils-r1.eclass | 3 ++-
 1 file changed, 2 insertions(+), 1 deletion(-)
diff --git a/eclass/python-utils-r1.eclass b/eclass/python-utils-r1.eclass
index 584ed831f816..c47565fa1db2 100644
--- a/eclass/python-utils-r1.eclass
+++ b/eclass/python-utils-r1.eclass
@@ -1444,7 +1444,7 @@ epytest() {
 	set -- "${EPYTHON}" -m pytest "${args[@]}" "${@}" ${EPYTEST_FLAGS}
 
 	echo "${@}" >&2
-	"${@}" || die -n "pytest failed with ${EPYTHON}"
+	"${@}"
 	local ret=${?}
 
 	# remove common temporary directories left over by pytest plugins
@@ -1455,6 +1455,7 @@ epytest() {
 		find "${BUILD_DIR}" -name '*-pytest-*.pyc' -delete || die
 	fi
 
+	[[ ${ret} -ne 0 ]] && die -n "pytest failed with ${EPYTHON}"
 	return ${ret}
 }
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-20 17:02 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-05-20 17:02 UTC (permalink / raw
  To: gentoo-commits
commit:     be50ed0537e06560614cedc379c60292300a7e3e
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Tue May 14 12:48:38 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Mon May 20 16:56:44 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=be50ed05
python-utils-r1.eclass: Support passing EPYTEST_FLAGS
Closes: https://bugs.gentoo.org/905863
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/python-utils-r1.eclass | 11 ++++++++++-
 1 file changed, 10 insertions(+), 1 deletion(-)
diff --git a/eclass/python-utils-r1.eclass b/eclass/python-utils-r1.eclass
index 275ac3a96523..584ed831f816 100644
--- a/eclass/python-utils-r1.eclass
+++ b/eclass/python-utils-r1.eclass
@@ -1321,6 +1321,15 @@ _python_check_occluded_packages() {
 # Specifies the number of jobs for parallel (pytest-xdist) test runs.
 # When unset, defaults to -j from MAKEOPTS, or the current nproc.
 
+# @ECLASS_VARIABLE: EPYTEST_FLAGS
+# @USER_VARIABLE
+# @DEFAULT_UNSET
+# @DESCRIPTION:
+# Additional flags to pass to pytest.  This is intended to be set
+# in the environment when debugging packages (options such as -x or -s
+# are useful here), rather than globally.  It must not be set
+# in ebuilds.
+
 # @FUNCTION: epytest
 # @USAGE: [<args>...]
 # @DESCRIPTION:
@@ -1432,7 +1441,7 @@ epytest() {
 	for x in "${EPYTEST_IGNORE[@]}"; do
 		args+=( --ignore "${x}" )
 	done
-	set -- "${EPYTHON}" -m pytest "${args[@]}" "${@}"
+	set -- "${EPYTHON}" -m pytest "${args[@]}" "${@}" ${EPYTEST_FLAGS}
 
 	echo "${@}" >&2
 	"${@}" || die -n "pytest failed with ${EPYTHON}"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-21  8:58 Florian Schmaus
  0 siblings, 0 replies; 6663+ messages in thread
From: Florian Schmaus @ 2024-05-21  8:58 UTC (permalink / raw
  To: gentoo-commits
commit:     90b41ec50f152da26b8c8d4004d38d7cd4b3dd53
Author:     Florian Schmaus <flow <AT> gentoo <DOT> org>
AuthorDate: Mon May 20 11:00:27 2024 +0000
Commit:     Florian Schmaus <flow <AT> gentoo <DOT> org>
CommitDate: Tue May 21 08:58:07 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=90b41ec5
texlive-module.eclass: do not treat grep returning 1 as error
In case every man page of the dev-texlive/* package is filtered, because
the man pages are already installed by texlive-core, grep returns an
exit status of 1, which we must not treat as an error condition.
Adjust the PIPESTATUS comparison accordingly.
Closes: https://bugs.gentoo.org/931994
Signed-off-by: Florian Schmaus <flow <AT> gentoo.org>
 eclass/texlive-module.eclass | 5 ++++-
 1 file changed, 4 insertions(+), 1 deletion(-)
diff --git a/eclass/texlive-module.eclass b/eclass/texlive-module.eclass
index 0daca41961ff..b202a0188b66 100644
--- a/eclass/texlive-module.eclass
+++ b/eclass/texlive-module.eclass
@@ -539,7 +539,10 @@ texlive-module_src_install() {
 			find texmf-dist/doc/man -type f -name '*.[0-9n]' -print |
 				grep -v "${grep_expressions[@]}" |
 				xargs -d '\n' --no-run-if-empty doman
-			[[ "${PIPESTATUS[*]}" =~ ^0(" 0")*$ ]]
+			# The grep in the middle of the pipe may return 1 in case
+			# everything from the input is dropped.
+			# See https://bugs.gentoo.org/931994
+			[[ "${PIPESTATUS[*]}" == "0 "[01]" 0" ]]
 			eend $? || die "error installing man pages"
 
 			# Delete all man pages under texmf-dist/doc/man
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-21  8:58 Florian Schmaus
  0 siblings, 0 replies; 6663+ messages in thread
From: Florian Schmaus @ 2024-05-21  8:58 UTC (permalink / raw
  To: gentoo-commits
commit:     66780befaf58c6956afb4221911bd2ed1c240810
Author:     Florian Schmaus <flow <AT> gentoo <DOT> org>
AuthorDate: Mon May 20 11:04:55 2024 +0000
Commit:     Florian Schmaus <flow <AT> gentoo <DOT> org>
CommitDate: Tue May 21 08:58:08 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=66780bef
texlive-module.eclass: include PIPESTATUS in die message
Signed-off-by: Florian Schmaus <flow <AT> gentoo.org>
 eclass/texlive-module.eclass | 5 +++--
 1 file changed, 3 insertions(+), 2 deletions(-)
diff --git a/eclass/texlive-module.eclass b/eclass/texlive-module.eclass
index 7d40bfc58994..d7ec59c25a8a 100644
--- a/eclass/texlive-module.eclass
+++ b/eclass/texlive-module.eclass
@@ -539,11 +539,12 @@ texlive-module_src_install() {
 			find texmf-dist/doc/man -type f -name '*.[0-9n]' -print |
 				grep -v "${grep_expressions[@]}" |
 				xargs -d '\n' --no-run-if-empty nonfatal doman
+			local pipestatus="${PIPESTATUS[*]}"
 			# The grep in the middle of the pipe may return 1 in case
 			# everything from the input is dropped.
 			# See https://bugs.gentoo.org/931994
-			[[ "${PIPESTATUS[*]}" == "0 "[01]" 0" ]]
-			eend $? || die "error installing man pages"
+			[[ ${pipestatus} == "0 "[01]" 0" ]]
+			eend $? || die "error installing man pages (pipestatus: ${pipestatus})"
 
 			# Delete all man pages under texmf-dist/doc/man
 			find texmf-dist/doc/man -type f -name '*.[0-9n]' -delete ||
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-21  8:58 Florian Schmaus
  0 siblings, 0 replies; 6663+ messages in thread
From: Florian Schmaus @ 2024-05-21  8:58 UTC (permalink / raw
  To: gentoo-commits
commit:     0c2599b9db997df77af21ca8d3ce8da16e512649
Author:     Florian Schmaus <flow <AT> gentoo <DOT> org>
AuthorDate: Mon May 20 11:02:15 2024 +0000
Commit:     Florian Schmaus <flow <AT> gentoo <DOT> org>
CommitDate: Tue May 21 08:58:08 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=0c2599b9
texlive-module.eclass: invoke doman with nonfatal
In case doman fails, we do not want to die immediatly as it would
"break" the ebegin/eend combination. Instead, the exit status is passed
through xargs. It will then subsequently appear in PIPESTATUS, where it
is processed by eend || die.
Signed-off-by: Florian Schmaus <flow <AT> gentoo.org>
Suggested-by: Ulrich Müller <ulm <AT> gentoo.org>
 eclass/texlive-module.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/texlive-module.eclass b/eclass/texlive-module.eclass
index b202a0188b66..7d40bfc58994 100644
--- a/eclass/texlive-module.eclass
+++ b/eclass/texlive-module.eclass
@@ -538,7 +538,7 @@ texlive-module_src_install() {
 			ebegin "Installing man pages"
 			find texmf-dist/doc/man -type f -name '*.[0-9n]' -print |
 				grep -v "${grep_expressions[@]}" |
-				xargs -d '\n' --no-run-if-empty doman
+				xargs -d '\n' --no-run-if-empty nonfatal doman
 			# The grep in the middle of the pipe may return 1 in case
 			# everything from the input is dropped.
 			# See https://bugs.gentoo.org/931994
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-22  1:44 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-05-22  1:44 UTC (permalink / raw
  To: gentoo-commits
commit:     69d4cc312072ad28491d2dce5798dd49d63713e5
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed May 22 01:40:06 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed May 22 01:43:56 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=69d4cc31
perl-module.eclass: don't set 'ccflags' for Module::Build
TL;DR: If we set 'ccflags', we're clobbering the Perl default. We're already
setting 'optimize' which is what we're supposed to use here.
We set ccflags *and* optimize for Module::Build (which dev-perl/Net-DNS uses),
while we only set OPTIMIZE (case is fine) for MM (which dev-perl/Net-LibIDN2 uses).
ccflags clobbers the Perl default, while optimize appends. We should just set optimize -
to not clobber what Perl sets, but also for consistency between the two build systems).
(Unfortunately, this does mean we also inherit things we don't really
want to, which don't affect ABI, like -fno-strict-aliasing, but let's
live with it for now...)
Bug: https://bugs.gentoo.org/261375
Bug: https://bugs.gentoo.org/877659
Closes: https://bugs.gentoo.org/932176
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/perl-module.eclass | 1 -
 1 file changed, 1 deletion(-)
diff --git a/eclass/perl-module.eclass b/eclass/perl-module.eclass
index f32c2c237d05..432d1ab315dd 100644
--- a/eclass/perl-module.eclass
+++ b/eclass/perl-module.eclass
@@ -279,7 +279,6 @@ perl-module_src_configure() {
 			--config ld="$(tc-getCC)" \
 			--config nm="$(tc-getNM)" \
 			--config ranlib="$(tc-getRANLIB)" \
-			--config ccflags="${CFLAGS}" \
 			--config optimize="${CFLAGS}" \
 			--config ldflags="${LDFLAGS}" \
 			"${myconf_local[@]}"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-25  5:55 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-05-25  5:55 UTC (permalink / raw
  To: gentoo-commits
commit:     e790e4d2c3dc3b996854ce70ace17244e8e8b9d8
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat May 25 05:55:09 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat May 25 05:55:24 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=e790e4d2
plasma.kde.org.eclass: support 6.x betas
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/plasma.kde.org.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/plasma.kde.org.eclass b/eclass/plasma.kde.org.eclass
index 491f1fcecc8c..1a626de37bfb 100644
--- a/eclass/plasma.kde.org.eclass
+++ b/eclass/plasma.kde.org.eclass
@@ -63,7 +63,7 @@ if [[ ${KDE_BUILD_TYPE} == live ]]; then
 	fi
 elif [[ -z ${KDE_ORG_COMMIT} ]]; then
 	case ${PV} in
-		5.??.[6-9][05]* )
+		5.??.[6-9][05]* | 6.?.[6-9][05]* )
 			_KDE_SRC_URI+="unstable/plasma/$(ver_cut 1-3)/"
 			RESTRICT+=" mirror"
 			;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-25  8:35 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-05-25  8:35 UTC (permalink / raw
  To: gentoo-commits
commit:     63c74a9a2231c426759af524cd14004d04f1cf32
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat May 25 08:33:25 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat May 25 08:35:14 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=63c74a9a
Remove support for old snapshots
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 9 ---------
 1 file changed, 9 deletions(-)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index f0915a0e42cc..9d2dc78e0d92 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -78,15 +78,6 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 				19.0.0_pre20240518)
 					EGIT_COMMIT=702198fc9ac5dba392f9d9ba7c56467996343c0a
 					;;
-				19.0.0_pre20240509)
-					EGIT_COMMIT=a7ee81e8279e0bf6e05617a4a638e5f2f8e45022
-					;;
-				19.0.0_pre20240504)
-					EGIT_COMMIT=76aa042dde6ba9ba57c680950f5818259ee02690
-					;;
-				19.0.0_pre20240427)
-					EGIT_COMMIT=338561657685c1831a53563b1bc36ffc7470239e
-					;;
 				*)
 					die "Unknown snapshot: ${PV}"
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-26  8:18 Miroslav Šulc
  0 siblings, 0 replies; 6663+ messages in thread
From: Miroslav Šulc @ 2024-05-26  8:18 UTC (permalink / raw
  To: gentoo-commits
commit:     bfe9319b5d4631a85ebbb9c2fcda1d46f09c2320
Author:     Volkmar W. Pogatzki <gentoo <AT> pogatzki <DOT> net>
AuthorDate: Sun May 26 07:38:15 2024 +0000
Commit:     Miroslav Šulc <fordfrog <AT> gentoo <DOT> org>
CommitDate: Sun May 26 08:18:19 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=bfe9319b
java-osgi.eclass: drop EAPI 7
Signed-off-by: Volkmar W. Pogatzki <gentoo <AT> pogatzki.net>
Closes: https://github.com/gentoo/gentoo/pull/36819
Signed-off-by: Miroslav Šulc <fordfrog <AT> gentoo.org>
 eclass/java-osgi.eclass | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/eclass/java-osgi.eclass b/eclass/java-osgi.eclass
index 7019fab7b203..172b42225c6e 100644
--- a/eclass/java-osgi.eclass
+++ b/eclass/java-osgi.eclass
@@ -1,4 +1,4 @@
-# Copyright 2007-2022 Gentoo Authors
+# Copyright 2007-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: java-osgi.eclass
@@ -6,7 +6,7 @@
 # java@gentoo.org
 # @AUTHOR:
 # Java maintainers <java@gentoo.org>
-# @SUPPORTED_EAPIS: 7 8
+# @SUPPORTED_EAPIS: 8
 # @PROVIDES: java-utils-2
 # @BLURB: Java OSGi eclass
 # @DESCRIPTION:
@@ -16,7 +16,7 @@
 # could extend this so that Gentoo Java system would be fully OSGi compliant.
 
 case ${EAPI} in
-	7|8) ;;
+	8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-05-31 12:42 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-05-31 12:42 UTC (permalink / raw
  To: gentoo-commits
commit:     857bea2590e56110ce52f52fb593f34900d7c6e1
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Wed Feb 21 14:33:30 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Fri May 31 12:42:39 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=857bea25
llvm-r1.eclass: Use := slot op in examples
Include the ':=' slot operator in examples.  While generally LLVM
does not change its ABI within a single slot, it technically reserves
that possibility and it has historically been used in LLVM 11.1.0.
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm-r1.eclass | 8 ++++----
 1 file changed, 4 insertions(+), 4 deletions(-)
diff --git a/eclass/llvm-r1.eclass b/eclass/llvm-r1.eclass
index 658946a1ecbd..075df9218be8 100644
--- a/eclass/llvm-r1.eclass
+++ b/eclass/llvm-r1.eclass
@@ -31,8 +31,8 @@
 # DEPEND="
 #   dev-libs/libfoo[${LLVM_USEDEP}]
 #   $(llvm_gen_dep '
-#     sys-devel/clang:${LLVM_SLOT}
-#     sys-devel/llvm:${LLVM_SLOT}
+#     sys-devel/clang:${LLVM_SLOT}=
+#     sys-devel/llvm:${LLVM_SLOT}=
 #   ')
 # "
 # @CODE
@@ -158,8 +158,8 @@ unset -f _llvm_set_globals
 # @CODE
 # DEPEND="
 #   $(llvm_gen_dep '
-#     sys-devel/clang:${LLVM_SLOT}
-#     sys-devel/llvm:${LLVM_SLOT}
+#     sys-devel/clang:${LLVM_SLOT}=
+#     sys-devel/llvm:${LLVM_SLOT}=
 #   ')
 # "
 # @CODE
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-06-01  6:19 Hans de Graaff
  0 siblings, 0 replies; 6663+ messages in thread
From: Hans de Graaff @ 2024-06-01  6:19 UTC (permalink / raw
  To: gentoo-commits
commit:     b51412f49546e7531d05540588390e91a5a5a825
Author:     Hans de Graaff <graaff <AT> gentoo <DOT> org>
AuthorDate: Sun May 12 06:39:40 2024 +0000
Commit:     Hans de Graaff <graaff <AT> gentoo <DOT> org>
CommitDate: Sat Jun  1 06:19:04 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=b51412f4
ruby-ng-gnome2.eclass: allow EAPI 8
Signed-off-by: Hans de Graaff <graaff <AT> gentoo.org>
 eclass/ruby-ng-gnome2.eclass | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/eclass/ruby-ng-gnome2.eclass b/eclass/ruby-ng-gnome2.eclass
index 77c004f56998..c38c5f15904d 100644
--- a/eclass/ruby-ng-gnome2.eclass
+++ b/eclass/ruby-ng-gnome2.eclass
@@ -6,7 +6,7 @@
 # Ruby herd <ruby@gentoo.org>
 # @AUTHOR:
 # Author: Hans de Graaff <graaff@gentoo.org>
-# @SUPPORTED_EAPIS: 7
+# @SUPPORTED_EAPIS: 7 8
 # @PROVIDES: ruby-ng
 # @BLURB: An eclass to simplify handling of various ruby-gnome2 parts.
 # @DESCRIPTION:
@@ -14,7 +14,7 @@
 # ruby-gnome2 since they share a very common installation procedure.
 
 case ${EAPI} in
-	7) ;;
+	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-06-01  6:19 Hans de Graaff
  0 siblings, 0 replies; 6663+ messages in thread
From: Hans de Graaff @ 2024-06-01  6:19 UTC (permalink / raw
  To: gentoo-commits
commit:     c4106df30b444ae1a74c9ddf66528fbce7185539
Author:     Hans de Graaff <graaff <AT> gentoo <DOT> org>
AuthorDate: Sun May 12 06:33:52 2024 +0000
Commit:     Hans de Graaff <graaff <AT> gentoo <DOT> org>
CommitDate: Sat Jun  1 06:19:04 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=c4106df3
ruby-ng-gnome2.eclass: drop obsolete SRC_URI
The last version below 3.4.0 that used this SRC_URI has been removed in
2021 in bd4380d7b621baa6b63b24bedce94dfebe171cf3
Signed-off-by: Hans de Graaff <graaff <AT> gentoo.org>
 eclass/ruby-ng-gnome2.eclass | 9 ++-------
 1 file changed, 2 insertions(+), 7 deletions(-)
diff --git a/eclass/ruby-ng-gnome2.eclass b/eclass/ruby-ng-gnome2.eclass
index 8cce47cf1903..77c004f56998 100644
--- a/eclass/ruby-ng-gnome2.eclass
+++ b/eclass/ruby-ng-gnome2.eclass
@@ -47,13 +47,8 @@ ruby_add_bdepend "
 HOMEPAGE="https://ruby-gnome.github.io/"
 LICENSE="LGPL-2.1+"
 SLOT="0"
-if ver_test -ge "3.4.0"; then
-	SRC_URI="https://github.com/ruby-gnome/ruby-gnome/archive/${PV}.tar.gz -> ruby-gnome2-${PV}.tar.gz"
-	RUBY_S=ruby-gnome-${PV}/${RUBY_FAKEGEM_NAME}
-else
-	SRC_URI="https://downloads.sourceforge.net/ruby-gnome2/ruby-gnome2-all-${PV}.tar.gz"
-	RUBY_S=ruby-gnome2-all-${PV}/${RUBY_FAKEGEM_NAME}
-fi
+SRC_URI="https://github.com/ruby-gnome/ruby-gnome/archive/${PV}.tar.gz -> ruby-gnome2-${PV}.tar.gz"
+RUBY_S=ruby-gnome-${PV}/${RUBY_FAKEGEM_NAME}
 
 ruby-ng-gnome2_all_ruby_prepare() {
 	# Avoid compilation of dependencies during test.
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-06-01  6:19 Hans de Graaff
  0 siblings, 0 replies; 6663+ messages in thread
From: Hans de Graaff @ 2024-06-01  6:19 UTC (permalink / raw
  To: gentoo-commits
commit:     6d38c6eace7a34a42dfd60401e9c3bd85766509f
Author:     Hans de Graaff <graaff <AT> gentoo <DOT> org>
AuthorDate: Sun May 12 06:32:32 2024 +0000
Commit:     Hans de Graaff <graaff <AT> gentoo <DOT> org>
CommitDate: Sat Jun  1 06:19:04 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=6d38c6ea
ruby-ng-gnome2.eclass: remove "default" SRC_URI
This default was never used since it was always overwritten by the
if/else following it.
Signed-off-by: Hans de Graaff <graaff <AT> gentoo.org>
 eclass/ruby-ng-gnome2.eclass | 1 -
 1 file changed, 1 deletion(-)
diff --git a/eclass/ruby-ng-gnome2.eclass b/eclass/ruby-ng-gnome2.eclass
index e10f1e625993..8cce47cf1903 100644
--- a/eclass/ruby-ng-gnome2.eclass
+++ b/eclass/ruby-ng-gnome2.eclass
@@ -44,7 +44,6 @@ BDEPEND="virtual/pkgconfig"
 ruby_add_bdepend "
 	dev-ruby/pkg-config
 	test? ( >=dev-ruby/test-unit-2 )"
-SRC_URI="https://downloads.sourceforge.net/ruby-gnome2/ruby-gnome2-all-${PV}.tar.gz"
 HOMEPAGE="https://ruby-gnome.github.io/"
 LICENSE="LGPL-2.1+"
 SLOT="0"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-06-01 21:11 Alfredo Tupone
  0 siblings, 0 replies; 6663+ messages in thread
From: Alfredo Tupone @ 2024-06-01 21:11 UTC (permalink / raw
  To: gentoo-commits
commit:     d7b08071fdc32a112221f564862e350da18ad0ee
Author:     Alfredo Tupone <tupone <AT> gentoo <DOT> org>
AuthorDate: Sat Jun  1 21:09:49 2024 +0000
Commit:     Alfredo Tupone <tupone <AT> gentoo <DOT> org>
CommitDate: Sat Jun  1 21:10:45 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=d7b08071
dune.eclass: filter TEXTRELS warnings on 32 bit arch
Closes: https://bugs.gentoo.org/928104
Signed-off-by: Alfredo Tupone <tupone <AT> gentoo.org>
 eclass/dune.eclass | 6 +++++-
 1 file changed, 5 insertions(+), 1 deletion(-)
diff --git a/eclass/dune.eclass b/eclass/dune.eclass
index f0faea007c9f..ba54e87ceaf9 100644
--- a/eclass/dune.eclass
+++ b/eclass/dune.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2023 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: dune.eclass
@@ -185,6 +185,10 @@ dune-install() {
 }
 
 dune_src_install() {
+	# OCaml generates textrels on 32-bit arches
+	if use arm || use ppc || use x86 ; then
+		export QA_TEXTRELS='.*'
+	fi
 	dune-install ${1:-${DUNE_PKG_NAME}}
 }
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-06-01 21:34 Alfredo Tupone
  0 siblings, 0 replies; 6663+ messages in thread
From: Alfredo Tupone @ 2024-06-01 21:34 UTC (permalink / raw
  To: gentoo-commits
commit:     387f6b19891fc78d3369a0e85518c4d706dddbc2
Author:     Alfredo Tupone <tupone <AT> gentoo <DOT> org>
AuthorDate: Sat Jun  1 21:33:40 2024 +0000
Commit:     Alfredo Tupone <tupone <AT> gentoo <DOT> org>
CommitDate: Sat Jun  1 21:34:37 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=387f6b19
findlib.eclass: ignore TEXTRELS
Closes: https://bugs.gentoo.org/738418
Signed-off-by: Alfredo Tupone <tupone <AT> gentoo.org>
 eclass/findlib.eclass | 6 +++++-
 1 file changed, 5 insertions(+), 1 deletion(-)
diff --git a/eclass/findlib.eclass b/eclass/findlib.eclass
index fdcaa0c1b77c..f0371ef00e10 100644
--- a/eclass/findlib.eclass
+++ b/eclass/findlib.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2023 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: findlib.eclass
@@ -68,6 +68,10 @@ findlib_src_preinst() {
 # @DESCRIPTION:
 # Install with a properly setup findlib
 findlib_src_install() {
+	# OCaml generates textrels on 32-bit arches
+	if use arm || use ppc || use x86 ; then
+		export QA_TEXTRELS='.*'
+	fi
 	findlib_src_preinst
 	make DESTDIR="${D}" "$@" install || die "make failed"
 }
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-06-02  8:22 Ionen Wolkens
  0 siblings, 0 replies; 6663+ messages in thread
From: Ionen Wolkens @ 2024-06-02  8:22 UTC (permalink / raw
  To: gentoo-commits
commit:     3373a27c24cd4b06084f8e0ac9fb9d2a695ac214
Author:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
AuthorDate: Sun Jun  2 07:08:01 2024 +0000
Commit:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
CommitDate: Sun Jun  2 08:22:07 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=3373a27c
qt6-build.eclass: use different workaround for cpu flags issues
This also replaces the nasty workaround from qtbase's ebuild
on top of the function here.
Should "hopefully" be far less error prone, while still allowing
-march=native for people who aren't affected. Does mean slightly
worse optimizations for those affected, but this still tries
to use the highest x86-64-v* and should be insignificant.
Tentative, can't fully test without having an affected cpu so
may still need work.
Closes: https://bugs.gentoo.org/933374
Signed-off-by: Ionen Wolkens <ionen <AT> gentoo.org>
 eclass/qt6-build.eclass | 87 ++++++++++++++++++++++++++++++++-----------------
 1 file changed, 58 insertions(+), 29 deletions(-)
diff --git a/eclass/qt6-build.eclass b/eclass/qt6-build.eclass
index 4fc838c478af..4966c52adc4c 100644
--- a/eclass/qt6-build.eclass
+++ b/eclass/qt6-build.eclass
@@ -122,7 +122,7 @@ qt6-build_src_prepare() {
 	fi
 
 	_qt6-build_prepare_env
-	_qt6-build_match_cpu_flags
+	_qt6-build_sanitize_cpu_flags
 
 	# LTO cause test failures in several components (e.g. qtcharts,
 	# multimedia, scxml, wayland, webchannel, ...).
@@ -235,34 +235,6 @@ _qt6-build_create_user_facing_links() {
 	done < "${BUILD_DIR}"/user_facing_tool_links.txt || die
 }
 
-# @FUNCTION: _qt6-build_match_cpu_flags
-# @INTERNAL
-# @DESCRIPTION:
-# Try to adjust -m* cpu CXXFLAGS so that they match a configuration
-# accepted by Qt's headers, see bug #908420.
-_qt6-build_match_cpu_flags() {
-	use amd64 || use x86 || return 0
-
-	local flags=() intrin intrins
-	while IFS=' ' read -ra intrins; do
-		[[ ${intrins[*]} == *=[^_]* && ${intrins[*]} == *=_* ]] &&
-			for intrin in "${intrins[@]%=*}"; do
-				[[ ${intrin} ]] && flags+=( -mno-${intrin} )
-			done
-	done < <(
-		$(tc-getCXX) -E -P ${CXXFLAGS} ${CPPFLAGS} - <<-EOF | tail -n 2
-			avx2=__AVX2__ =__BMI__ =__BMI2__ =__F16C__ =__FMA__ =__LZCNT__ =__POPCNT__
-			avx512f=__AVX512F__ avx512bw=__AVX512BW__ avx512cd=__AVX512CD__ avx512dq=__AVX512DQ__ avx512vl=__AVX512VL__
-		EOF
-		assert
-	)
-
-	if (( ${#flags[@]} )); then
-		einfo "Adjusting CXXFLAGS for https://bugs.gentoo.org/908420 with: ${flags[*]}"
-		append-cxxflags "${flags[@]}"
-	fi
-}
-
 # @FUNCTION: _qt6-build_prepare_env
 # @INTERNAL
 # @DESCRIPTION:
@@ -289,6 +261,63 @@ _qt6-build_prepare_env() {
 	readonly QT6_TRANSLATIONDIR=${QT6_DATADIR}/translations
 }
 
+# @FUNCTION: _qt6-build_sanitize_cpu_flags
+# @INTERNAL
+# @DESCRIPTION:
+# Qt hardly support use of -mno-* or -march=native for unusual CPUs
+# (or VMs) that support incomplete x86-64 feature levels, and attempts
+# to allow this anyway has worked poorly.  This instead tries to detect
+# unusual configurations and fallbacks to generic -march=x86-64* if so
+# (bug #898644,#908420,#913400,#933374).
+_qt6-build_sanitize_cpu_flags() {
+	# less of an issue with non-amd64, will revisit only if needed
+	use amd64 || return 0
+
+	local cpuflags=(
+		# list of checked cpu features by qtbase in configure.cmake
+		aes avx avx2 avx512{bw,cd,dq,er,f,ifma,pf,vbmi,vbmi2,vl}
+		f16c rdrnd rdseed sha sse2 sse3 sse4_1 sse4_2 ssse3 vaes
+
+		# extras checked by qtbase's qsimd_p.h
+		bmi bmi2 f16c fma lzcnt popcnt
+	)
+
+	# check if any known problematic -mno-* C(XX)FLAGS
+	if ! is-flagq "@($(IFS='|'; echo "${cpuflags[*]/#/-mno-}"))"; then
+		# check if qsimd_p.h (search for "enable all") will accept -march
+		: "$($(tc-getCXX) -E -P ${CXXFLAGS} ${CPPFLAGS} - <<-EOF | tail -n 1
+				#if (defined(__AVX2__) && (__BMI__ + __BMI2__ + __F16C__ + __FMA__ + __LZCNT__ + __POPCNT__) != 6) || \
+					(defined(__AVX512F__) && (__AVX512BW__ + __AVX512CD__ + __AVX512DQ__ + __AVX512VL__) != 4)
+				bad
+				#endif
+			EOF
+			assert
+		)"
+		[[ ${_} == bad ]] || return 0 # *should* be fine as-is
+	fi
+
+	# determine highest(known) usable x86-64 feature level
+	local march=$(
+		$(tc-getCXX) -E -P ${CXXFLAGS} ${CPPFLAGS} - <<-EOF | tail -n 1
+			default
+			#if (__CRC32__ + __LAHF_SAHF__ + __POPCNT__ + __SSE3__ + __SSE4_1__ + __SSE4_2__ + __SSSE3__) == 7
+			x86-64-v2
+			#  if (__AVX__ + __AVX2__ + __BMI__ + __BMI2__ + __F16C__ + __FMA__ + __LZCNT__ + __MOVBE__ + __XSAVE__) == 9
+			x86-64-v3
+			#    if (__AVX512BW__ + __AVX512CD__ + __AVX512DQ__ + __AVX512F__ + __AVX512VL__ + __EVEX256__ + __EVEX512__) == 7
+			x86-64-v4
+			#    endif
+			#  endif
+			#endif
+		EOF
+		assert
+	)
+
+	filter-flags '-march=*' "${cpuflags[@]/#/-m}" "${cpuflags[@]/#/-mno-}"
+	[[ ${march} == x86-64* ]] && append-flags $(test-flags-CXX -march=${march})
+	einfo "C(XX)FLAGS were adjusted due to Qt limitations: ${CXXFLAGS}"
+}
+
 fi
 
 EXPORT_FUNCTIONS src_unpack src_prepare src_configure src_test src_install
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-06-06 20:37 Mike Gilbert
  0 siblings, 0 replies; 6663+ messages in thread
From: Mike Gilbert @ 2024-06-06 20:37 UTC (permalink / raw
  To: gentoo-commits
commit:     66011abd663671947fe07835f0d9cc360f5de317
Author:     Eli Schwartz <eschwartz93 <AT> gmail <DOT> com>
AuthorDate: Sun Jun  2 19:08:07 2024 +0000
Commit:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
CommitDate: Thu Jun  6 20:36:48 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=66011abd
meson.eclass: stop using the incomparably broken "meson compile"
With my upstream meson hat on, I have griped about this for years any
time someone mentions "meson compile" to me. I think it was badly
motivated and shouldn't exist.
The purpose of this command is "for symmetry" with meson setup and meson
test and meson install, even though all of those are python programs
first and foremost, which have ninja targets that simply call back into
the meson tool but with less control.
Symmetry doesn't make a whole lot of sense. The compile phase actually
is implemented as a... ninja file, not a python program. Using ninja
directly is:
- faster, since you don't load hundreds of python modules into memory,
  just to fork out to ninja
- easier to control, since you can directly control the ninja arguments
The "meson compile" program actually, in fact, only really exists for
two reasons:
- meson supports multiple backends -- only when manually requested -- on
  operating systems other than linux. Namely, VS on Windows, and xcode
  on macOS. The wrapper first checks which backend has been generated,
  and then runs the appropriate command there. It also provides the
  ninja argument syntax for options that multiple backends understand,
  so, you can pass -v -j8 and it actually works regardless of backend
  (even if in fact it has to pass `-verbosity:minimal -maxCpuCount:8` to
  do it).
- via retconning, on Windows when using the MSVC `cl.exe` meson compile
  started actually adding this to PATH and setting it up (because it
  requires sourcing a batch script in order to both add to PATH and set
  inscrutable mandatory environment variables) to prevent ninja utterly
  failing if you missed this yourself.
For portage purposes, neither of these matter whatsoever. Even if
portage were to ever use cl.exe on Windows (???) it could set up the
environment just fine on its own, and actually using alternative
backends would require extending the eclass to configure xcode/vs for
tremendous slowdown in compile time, which would be silly.
In exchange for all these features portage doesn't need, what do we get?
meson compile unabashedly doesn't support all possible ninja arguments,
and says you should instead pass the combination of --ninja-args "..."
--vs-args "..." --xcode-args "..." and it will figure out which ones are
relevant for *your* backend and forward it to the backend. We don't
actually do that -- it would be super ugly for the common case of -v
-j8.
As a result, we ignore $NINJAOPTS, which ninja-utils.eclass claims we
are allowed to use. Instead we manually parse out some subset of
"supported" values. We *cannot* respect NINJAOPTS anyways, because...
... meson compile sucks and cannot handle it. To be more accurate: it
expects --ninja-args to be formatted using `meson-format-array`, the
same format that machine files use. No thank you!
And we still have to move to get_NINJAOPTS, then pass it as:
```
meson compile -C "${BUILD_DIR}" --ninja-args="['-j', '8', '-k', '0', '-v', '-l', '0']"
```
instead of:
```
meson compile -C "${BUILD_DIR}" -j 8 -v -l 0 --ninja-args="['-k0']"
```
The overengineered complexity of this is immense. ninja-utils.eclass
exists for an extremely good reason, provides best practices, and means
we don't have to maintain an interface to a custom tool with unintuitive
behavior since we get precisely the common functionality we already
want, for free.
Just use eninja.
Fixes:
- the absolute inability to use standard $NINJAOPTS to fine-tune
  meson-using packages, for example to keep going and collect all the
  build errors before aborting with a failure.
- support for ${NINJA_VERBOSE} (expected to be the fallback if
  MESON_VERBOSE isn't set)
Signed-off-by: Eli Schwartz <eschwartz93 <AT> gmail.com>
Signed-off-by: Mike Gilbert <floppym <AT> gentoo.org>
 eclass/meson.eclass | 16 ++--------------
 1 file changed, 2 insertions(+), 14 deletions(-)
diff --git a/eclass/meson.eclass b/eclass/meson.eclass
index a22a85887584..a2bc5537e458 100644
--- a/eclass/meson.eclass
+++ b/eclass/meson.eclass
@@ -440,23 +440,11 @@ meson_src_compile() {
 
 	pushd "${BUILD_DIR}" > /dev/null || die
 
-	local mesoncompileargs=(
-		--jobs "$(get_makeopts_jobs 0)"
-		--load-average "$(get_makeopts_loadavg 0)"
-	)
-
 	case ${MESON_VERBOSE} in
-		OFF) ;;
-		*) mesoncompileargs+=( --verbose ) ;;
+		OFF) NINJA_VERBOSE=OFF eninja "$@" ;;
+		*) eninja "$@" ;;
 	esac
-
-	mesoncompileargs+=( "$@" )
-
-	set -- meson compile "${mesoncompileargs[@]}"
-	echo "$@" >&2
-	"$@"
 	local rv=$?
-	[[ ${rv} -eq 0 ]] || die -n "compile failed"
 
 	popd > /dev/null || die
 	return ${rv}
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-06-08  3:53 Ulrich Müller
  0 siblings, 0 replies; 6663+ messages in thread
From: Ulrich Müller @ 2024-06-08  3:53 UTC (permalink / raw
  To: gentoo-commits
commit:     0883d6e38e1f7132a0e2998917243c0996f2d151
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Sat Jun  8 03:52:16 2024 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Sat Jun  8 03:52:16 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=0883d6e3
epatch.eclass: Remove dead eclass
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 eclass/epatch.eclass | 381 ---------------------------------------------------
 1 file changed, 381 deletions(-)
diff --git a/eclass/epatch.eclass b/eclass/epatch.eclass
deleted file mode 100644
index ff3fd13721fe..000000000000
--- a/eclass/epatch.eclass
+++ /dev/null
@@ -1,381 +0,0 @@
-# Copyright 1999-2024 Gentoo Authors
-# Distributed under the terms of the GNU General Public License v2
-
-# @DEAD
-# @ECLASS: epatch.eclass
-# @MAINTAINER:
-# base-system@gentoo.org
-# @SUPPORTED_EAPIS: 6
-# @BLURB: easy patch application functions
-# @DEPRECATED: eapply from EAPI 7
-# @DESCRIPTION:
-# An eclass providing epatch and epatch_user functions to easily apply
-# patches to ebuilds. Mostly superseded by eapply* in EAPI 6.
-
-if [[ -z ${_EPATCH_ECLASS} ]]; then
-
-case ${EAPI} in
-	6) ;;
-	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
-esac
-
-inherit estack
-
-# @VARIABLE: EPATCH_SOURCE
-# @DESCRIPTION:
-# Default directory to search for patches.
-EPATCH_SOURCE="${WORKDIR}/patch"
-# @VARIABLE: EPATCH_SUFFIX
-# @DESCRIPTION:
-# Default extension for patches (do not prefix the period yourself).
-EPATCH_SUFFIX="patch.bz2"
-# @VARIABLE: EPATCH_OPTS
-# @DESCRIPTION:
-# Options to pass to patch.  Meant for ebuild/package-specific tweaking
-# such as forcing the patch level (-p#) or fuzz (-F#) factor.  Note that
-# for single patch tweaking, you can also pass flags directly to epatch.
-EPATCH_OPTS=""
-# @VARIABLE: EPATCH_COMMON_OPTS
-# @DESCRIPTION:
-# Common options to pass to `patch`.  You probably should never need to
-# change these.  If you do, please discuss it with base-system first to
-# be sure.
-# @CODE
-#	-g0 - keep RCS, ClearCase, Perforce and SCCS happy #24571
-#	--no-backup-if-mismatch - do not leave .orig files behind
-#	-E - automatically remove empty files
-# @CODE
-EPATCH_COMMON_OPTS="-g0 -E --no-backup-if-mismatch"
-# @VARIABLE: EPATCH_EXCLUDE
-# @DESCRIPTION:
-# List of patches not to apply.	 Note this is only file names,
-# and not the full path.  Globs accepted.
-EPATCH_EXCLUDE=""
-# @VARIABLE: EPATCH_MULTI_MSG
-# @DESCRIPTION:
-# Change the printed message for multiple patches.
-EPATCH_MULTI_MSG="Applying various patches (bugfixes/updates) ..."
-# @VARIABLE: EPATCH_FORCE
-# @DESCRIPTION:
-# Only require patches to match EPATCH_SUFFIX rather than the extended
-# arch naming style.
-EPATCH_FORCE="no"
-# @VARIABLE: EPATCH_USER_EXCLUDE
-# @DEFAULT_UNSET
-# @DESCRIPTION:
-# List of patches not to apply.	 Note this is only file names,
-# and not the full path.  Globs accepted.
-
-# @FUNCTION: epatch
-# @USAGE: [options] [patches] [dirs of patches]
-# @DESCRIPTION:
-# epatch is designed to greatly simplify the application of patches.  It can
-# process patch files directly, or directories of patches.  The patches may be
-# compressed (bzip/gzip/etc...) or plain text.  You generally need not specify
-# the -p option as epatch will automatically attempt -p0 to -p4 until things
-# apply successfully.
-#
-# If you do not specify any patches/dirs, then epatch will default to the
-# directory specified by EPATCH_SOURCE.
-#
-# Any options specified that start with a dash will be passed down to patch
-# for this specific invocation.  As soon as an arg w/out a dash is found, then
-# arg processing stops.
-#
-# When processing directories, epatch will apply all patches that match:
-# @CODE
-#	if ${EPATCH_FORCE} != "yes"
-#		??_${ARCH}_foo.${EPATCH_SUFFIX}
-#	else
-#		*.${EPATCH_SUFFIX}
-# @CODE
-# The leading ?? are typically numbers used to force consistent patch ordering.
-# The arch field is used to apply patches only for the host architecture with
-# the special value of "all" means apply for everyone.  Note that using values
-# other than "all" is highly discouraged -- you should apply patches all the
-# time and let architecture details be detected at configure/compile time.
-#
-# If EPATCH_SUFFIX is empty, then no period before it is implied when searching
-# for patches to apply.
-#
-# Refer to the other EPATCH_xxx variables for more customization of behavior.
-epatch() {
-	_epatch_draw_line() {
-		# create a line of same length as input string
-		[[ -z $1 ]] && set "$(printf "%65s" '')"
-		echo "${1//?/=}"
-	}
-
-	unset P4CONFIG P4PORT P4USER # keep perforce at bay #56402
-
-	# First process options.  We localize the EPATCH_OPTS setting
-	# from above so that we can pass it on in the loop below with
-	# any additional values the user has specified.
-	local EPATCH_OPTS=( ${EPATCH_OPTS[*]} )
-	while [[ $# -gt 0 ]] ; do
-		case $1 in
-		-*) EPATCH_OPTS+=( "$1" ) ;;
-		*) break ;;
-		esac
-		shift
-	done
-
-	# Let the rest of the code process one user arg at a time --
-	# each arg may expand into multiple patches, and each arg may
-	# need to start off with the default global EPATCH_xxx values
-	if [[ $# -gt 1 ]] ; then
-		local m
-		for m in "$@" ; do
-			epatch "${m}"
-		done
-		return 0
-	fi
-
-	local SINGLE_PATCH="no"
-	# no args means process ${EPATCH_SOURCE}
-	[[ $# -eq 0 ]] && set -- "${EPATCH_SOURCE}"
-
-	if [[ -f $1 ]] ; then
-		SINGLE_PATCH="yes"
-		set -- "$1"
-		# Use the suffix from the single patch (localize it); the code
-		# below will find the suffix for us
-		local EPATCH_SUFFIX=$1
-
-	elif [[ -d $1 ]] ; then
-		# We have to force sorting to C so that the wildcard expansion is consistent #471666.
-		evar_push_set LC_COLLATE C
-		# Some people like to make dirs of patches w/out suffixes (vim).
-		set -- "$1"/*${EPATCH_SUFFIX:+."${EPATCH_SUFFIX}"}
-		evar_pop
-
-	elif [[ -f ${EPATCH_SOURCE}/$1 ]] ; then
-		# Re-use EPATCH_SOURCE as a search dir
-		epatch "${EPATCH_SOURCE}/$1"
-		return $?
-
-	else
-		# sanity check ... if it isn't a dir or file, wtf man ?
-		[[ $# -ne 0 ]] && EPATCH_SOURCE=$1
-		echo
-		eerror "Cannot find \$EPATCH_SOURCE!  Value for \$EPATCH_SOURCE is:"
-		eerror
-		eerror "  ${EPATCH_SOURCE}"
-		eerror "  ( ${EPATCH_SOURCE##*/} )"
-		echo
-		die "Cannot find \$EPATCH_SOURCE!"
-	fi
-
-	# Now that we know we're actually going to apply something, merge
-	# all of the patch options back in to a single variable for below.
-	EPATCH_OPTS="${EPATCH_COMMON_OPTS} ${EPATCH_OPTS[*]}"
-
-	local PIPE_CMD
-	case ${EPATCH_SUFFIX##*\.} in
-		xz)      PIPE_CMD="xz -dc"    ;;
-		lzma)    PIPE_CMD="lzma -dc"  ;;
-		bz2)     PIPE_CMD="bzip2 -dc" ;;
-		gz|Z|z)  PIPE_CMD="gzip -dc"  ;;
-		ZIP|zip) PIPE_CMD="unzip -p"  ;;
-		*)       ;;
-	esac
-
-	[[ ${SINGLE_PATCH} == "no" ]] && einfo "${EPATCH_MULTI_MSG}"
-
-	local x
-	for x in "$@" ; do
-		# If the patch dir given contains subdirs, or our EPATCH_SUFFIX
-		# didn't match anything, ignore continue on
-		[[ ! -f ${x} ]] && continue
-
-		local patchname=${x##*/}
-
-		# Apply single patches, or forced sets of patches, or
-		# patches with ARCH dependent names.
-		#	???_arch_foo.patch
-		# Else, skip this input altogether
-		local a=${patchname#*_} # strip the ???_
-		a=${a%%_*}              # strip the _foo.patch
-		if ! [[ ${SINGLE_PATCH} == "yes" || \
-				${EPATCH_FORCE} == "yes" || \
-				${a} == all     || \
-				${a} == ${ARCH} ]]
-		then
-			continue
-		fi
-
-		# Let people filter things dynamically
-		if [[ -n ${EPATCH_EXCLUDE}${EPATCH_USER_EXCLUDE} ]] ; then
-			# let people use globs in the exclude
-			eshopts_push -o noglob
-
-			local ex
-			for ex in ${EPATCH_EXCLUDE} ; do
-				if [[ ${patchname} == ${ex} ]] ; then
-					einfo "  Skipping ${patchname} due to EPATCH_EXCLUDE ..."
-					eshopts_pop
-					continue 2
-				fi
-			done
-
-			for ex in ${EPATCH_USER_EXCLUDE} ; do
-				if [[ ${patchname} == ${ex} ]] ; then
-					einfo "  Skipping ${patchname} due to EPATCH_USER_EXCLUDE ..."
-					eshopts_pop
-					continue 2
-				fi
-			done
-
-			eshopts_pop
-		fi
-
-		if [[ ${SINGLE_PATCH} == "yes" ]] ; then
-			ebegin "Applying ${patchname}"
-		else
-			ebegin "  ${patchname}"
-		fi
-
-		# Handle aliased patch command #404447 #461568
-		local patch="patch"
-		eval $(alias patch 2>/dev/null | sed 's:^alias ::')
-
-		# most of the time, there will only be one run per unique name,
-		# but if there are more, make sure we get unique log filenames
-		local STDERR_TARGET="${T}/${patchname}.out"
-		if [[ -e ${STDERR_TARGET} ]] ; then
-			STDERR_TARGET="${T}/${patchname}-$$.out"
-		fi
-
-		printf "***** %s *****\nPWD: %s\nPATCH TOOL: %s -> %s\nVERSION INFO:\n%s\n\n" \
-			"${patchname}" \
-			"${PWD}" \
-			"${patch}" \
-			"$(type -P "${patch}")" \
-			"$(${patch} --version)" \
-			> "${STDERR_TARGET}"
-
-		# Decompress the patch if need be
-		local count=0
-		local PATCH_TARGET
-		if [[ -n ${PIPE_CMD} ]] ; then
-			PATCH_TARGET="${T}/$$.patch"
-			echo "PIPE_COMMAND:  ${PIPE_CMD} ${x} > ${PATCH_TARGET}" >> "${STDERR_TARGET}"
-
-			if ! (${PIPE_CMD} "${x}" > "${PATCH_TARGET}") >> "${STDERR_TARGET}" 2>&1 ; then
-				echo
-				eerror "Could not extract patch!"
-				#die "Could not extract patch!"
-				count=5
-				break
-			fi
-		else
-			PATCH_TARGET=${x}
-		fi
-
-		# Check for absolute paths in patches.  If sandbox is disabled,
-		# people could (accidentally) patch files in the root filesystem.
-		# Or trigger other unpleasantries #237667.  So disallow -p0 on
-		# such patches.
-		local abs_paths=$(grep -E -n '^[-+]{3} /' "${PATCH_TARGET}" | awk '$2 != "/dev/null" { print }')
-		if [[ -n ${abs_paths} ]] ; then
-			count=1
-			printf "NOTE: skipping -p0 due to absolute paths in patch:\n%s\n" "${abs_paths}" >> "${STDERR_TARGET}"
-		fi
-		# Similar reason, but with relative paths.
-		local rel_paths=$(grep -E -n '^[-+]{3} [^	]*[.][.]/' "${PATCH_TARGET}")
-		if [[ -n ${rel_paths} ]] ; then
-			echo
-			eerror "Rejected Patch: ${patchname}!"
-			eerror " ( ${PATCH_TARGET} )"
-			eerror
-			eerror "Your patch uses relative paths '../':"
-			eerror "${rel_paths}"
-			echo
-			die "you need to fix the relative paths in patch"
-		fi
-
-		# Dynamically detect the correct -p# ... i'm lazy, so shoot me :/
-		local patch_cmd
-		while [[ ${count} -lt 5 ]] ; do
-			patch_cmd="${patch} -p${count} ${EPATCH_OPTS}"
-
-			# Generate some useful debug info ...
-			(
-			_epatch_draw_line "***** ${patchname} *****"
-			echo
-			echo "PATCH COMMAND:  ${patch_cmd} --dry-run -f < '${PATCH_TARGET}'"
-			echo
-			_epatch_draw_line "***** ${patchname} *****"
-			${patch_cmd} --dry-run -f < "${PATCH_TARGET}" 2>&1
-			ret=$?
-			echo
-			echo "patch program exited with status ${ret}"
-			exit ${ret}
-			) >> "${STDERR_TARGET}"
-
-			if [ $? -eq 0 ] ; then
-				(
-				_epatch_draw_line "***** ${patchname} *****"
-				echo
-				echo "ACTUALLY APPLYING ${patchname} ..."
-				echo "PATCH COMMAND:  ${patch_cmd} < '${PATCH_TARGET}'"
-				echo
-				_epatch_draw_line "***** ${patchname} *****"
-				${patch_cmd} < "${PATCH_TARGET}" 2>&1
-				ret=$?
-				echo
-				echo "patch program exited with status ${ret}"
-				exit ${ret}
-				) >> "${STDERR_TARGET}"
-
-				if [ $? -ne 0 ] ; then
-					echo
-					eerror "A dry-run of patch command succeeded, but actually"
-					eerror "applying the patch failed!"
-					#die "Real world sux compared to the dreamworld!"
-					count=5
-				fi
-				break
-			fi
-
-			: $(( count++ ))
-		done
-
-		(( EPATCH_N_APPLIED_PATCHES++ ))
-
-		# if we had to decompress the patch, delete the temp one
-		if [[ -n ${PIPE_CMD} ]] ; then
-			rm -f "${PATCH_TARGET}"
-		fi
-
-		if [[ ${count} -ge 5 ]] ; then
-			echo
-			eerror "Failed patch: ${patchname}!"
-			eerror " ( ${PATCH_TARGET} )"
-			eerror
-			eerror "Include in your bug report the contents of:"
-			eerror
-			eerror "  ${STDERR_TARGET}"
-			echo
-			die "Failed patch: ${patchname}!"
-		fi
-
-		# if everything worked, delete the full debug patch log
-		rm -f "${STDERR_TARGET}"
-
-		# then log away the exact stuff for people to review later
-		cat <<-EOF >> "${T}/epatch.log"
-		PATCH: ${x}
-		CMD: ${patch_cmd}
-		PWD: ${PWD}
-
-		EOF
-		eend 0
-	done
-
-	[[ ${SINGLE_PATCH} == "no" ]] && einfo "Done with patching"
-	: # everything worked
-}
-
-_EPATCH_ECLASS=1
-fi #_EPATCH_ECLASS
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-06-08  3:53 Ulrich Müller
  0 siblings, 0 replies; 6663+ messages in thread
From: Ulrich Müller @ 2024-06-08  3:53 UTC (permalink / raw
  To: gentoo-commits
commit:     47035fb9daaacb2ecf64c33b98baeeabff5071e3
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Sat Jun  8 03:51:53 2024 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Sat Jun  8 03:51:53 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=47035fb9
eutils.eclass: Remove dead eclass
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 eclass/eutils.eclass | 21 ---------------------
 1 file changed, 21 deletions(-)
diff --git a/eclass/eutils.eclass b/eclass/eutils.eclass
deleted file mode 100644
index 1e36c78f7780..000000000000
--- a/eclass/eutils.eclass
+++ /dev/null
@@ -1,21 +0,0 @@
-# Copyright 1999-2024 Gentoo Authors
-# Distributed under the terms of the GNU General Public License v2
-
-# @DEAD
-# @ECLASS: eutils.eclass
-# @MAINTAINER:
-# base-system@gentoo.org
-# @SUPPORTED_EAPIS: 6
-# @BLURB: many extra (but common) functions that are used in ebuilds
-# @DEPRECATED: native package manager functions, more specific eclasses
-
-if [[ -z ${_EUTILS_ECLASS} ]]; then
-_EUTILS_ECLASS=1
-
-# implicitly inherited (now split) eclasses
-case ${EAPI} in
-	6) inherit desktop edos2unix epatch eqawarn estack ltprune multilib \
-			preserve-libs strip-linguas toolchain-funcs vcs-clean wrapper ;;
-	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
-esac
-fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-06-08 10:29 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-06-08 10:29 UTC (permalink / raw
  To: gentoo-commits
commit:     48f76a8faeaba63830608b7acc9b6c90a52c03ad
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Jun  8 10:24:46 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat Jun  8 10:27:51 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=48f76a8f
Add 19.0.0_pre20240608 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index 9d2dc78e0d92..30d919db2300 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -72,6 +72,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 			_LLVM_SOURCE_TYPE=snapshot
 
 			case ${PV} in
+				19.0.0_pre20240608)
+					EGIT_COMMIT=5aabbf0602c48b67bb89fd37f95bf97c95ded488
+					;;
 				19.0.0_pre20240525)
 					EGIT_COMMIT=7dc2f6602212bf0a0433c157b70e4fc0d70bb730
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-06-08 15:47 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-06-08 15:47 UTC (permalink / raw
  To: gentoo-commits
commit:     5b45aef4ab0b6d0ed7f414facaf9e243cdb36cfc
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Jun  8 15:46:39 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat Jun  8 15:46:56 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=5b45aef4
ltprune.eclass: Mark @DEAD
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/ltprune.eclass | 3 ++-
 1 file changed, 2 insertions(+), 1 deletion(-)
diff --git a/eclass/ltprune.eclass b/eclass/ltprune.eclass
index 5a36647d1d1c..51f5aaabfea7 100644
--- a/eclass/ltprune.eclass
+++ b/eclass/ltprune.eclass
@@ -1,6 +1,7 @@
-# Copyright 1999-2022 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
+# @DEAD
 # @ECLASS: ltprune.eclass
 # @MAINTAINER:
 # Michał Górny <mgorny@gentoo.org>
^ permalink raw reply related	[flat|nested] 6663+ messages in thread
* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-06-10 12:46 Joonas Niilola
  0 siblings, 0 replies; 6663+ messages in thread
From: Joonas Niilola @ 2024-06-10 12:46 UTC (permalink / raw
  To: gentoo-commits
commit:     fd49668a8bb2346908b62a1bfd9fbf9ece5f972b
Author:     Martin Dummer <martin.dummer <AT> gmx <DOT> net>
AuthorDate: Wed May  1 12:49:37 2024 +0000
Commit:     Joonas Niilola <juippis <AT> gentoo <DOT> org>
CommitDate: Mon Jun 10 12:45:21 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=fd49668a
vdr-plugin-2.eclass: change qa warnings to einfo
many vdr plugins need small adjustments because API or makefile changes
in upstream media-video/vdr which can be easily fixed with small changes
These fixes should no longer be reported as "equawarn", instead now only
an "einfo" will be printed out.
Closes: https://bugs.gentoo.org/925762
Closes: https://bugs.gentoo.org/925763
Closes: https://bugs.gentoo.org/925764
Closes: https://bugs.gentoo.org/925765
Closes: https://bugs.gentoo.org/925766
Closes: https://bugs.gentoo.org/925767
Closes: https://bugs.gentoo.org/925768
Closes: https://bugs.gentoo.org/925769
Closes: https://bugs.gentoo.org/925770
Closes: https://bugs.gentoo.org/925771
Closes: https://bugs.gentoo.org/925773
Closes: https://bugs.gentoo.org/925774
Closes: https://bugs.gentoo.org/925775
Closes: https://bugs.gentoo.org/925776
Closes: https://bugs.gentoo.org/925777
Closes: https://bugs.gentoo.org/925778
Closes: https://bugs.gentoo.org/925779
Closes: https://bugs.gentoo.org/925780
Closes: https://bugs.gentoo.org/925781
Closes: https://bugs.gentoo.org/925782
Closes: https://bugs.gentoo.org/925783
Closes: https://bugs.gentoo.org/925784
Closes: https://bugs.gentoo.org/925785
Closes: https://bugs.gentoo.org/925786
Closes: https://bugs.gentoo.org/925787
Closes: https://bugs.gentoo.org/925788
Closes: https://bugs.gentoo.org/925791
Closes: https://bugs.gentoo.org/925792
Closes: https://bugs.gentoo.org/925793
Closes: https://bugs.gentoo.org/925794
Closes: https://bugs.gentoo.org/925795
Closes: https://bugs.gentoo.org/925796
Closes: https://bugs.gentoo.org/925797
Closes: https://bugs.gentoo.org/925798
Closes: https://bugs.gentoo.org/925799
Closes: https://bugs.gentoo.org/925800
Closes: https://bugs.gentoo.org/925801
Closes: https://bugs.gentoo.org/925802
Closes: https://bugs.gentoo.org/925803
Closes: https://bugs.gentoo.org/925804
Closes: https://bugs.gentoo.org/925805
Closes: https://bugs.gentoo.org/925806
Closes: https://bugs.gentoo.org/925807
Closes: https://bugs.gentoo.org/925808
Closes: https://bugs.gentoo.org/925809
Closes: https://bugs.gentoo.org/925810
Closes: https://bugs.gentoo.org/925811
Closes: https://bugs.gentoo.org/925812
Closes: https://bugs.gentoo.org/925817
Closes: https://bugs.gentoo.org/925818
Closes: https://bugs.gentoo.org/925819
Closes: https://bugs.gentoo.org/925820
Closes: https://bugs.gentoo.org/925821
Closes: https://bugs.gentoo.org/925822
Closes: https://bugs.gentoo.org/925823
Closes: https://bugs.gentoo.org/925824
Closes: https://bugs.gentoo.org/925825
Closes: https://bugs.gentoo.org/925826
Closes: https://bugs.gentoo.org/925827
Closes: https://bugs.gentoo.org/925828
Closes: https://bugs.gentoo.org/925829
Closes: https://bugs.gentoo.org/925830
Closes: https://bugs.gentoo.org/925831
Closes: https://bugs.gentoo.org/925832
Closes: https://bugs.gentoo.org/925833
Closes: https://bugs.gentoo.org/925834
Closes: https://bugs.gentoo.org/925835
Closes: https://bugs.gentoo.org/925837
Closes: https://bugs.gentoo.org/925838
Closes: https://bugs.gentoo.org/925839
Closes: https://bugs.gentoo.org/925840
Closes: https://bugs.gentoo.org/925841
Closes: https://bugs.gentoo.org/925842
Closes: https://bugs.gentoo.org/925922
Closes: https://bugs.gentoo.org/925923
Closes: https://bugs.gentoo.org/925924
Signed-off-by: Martin Dummer <martin.dummer <AT> gmx.net>
Closes: https://github.com/gentoo/gentoo/pull/36504
Signed-off-by: Joonas Niilola <juippis <AT> gentoo.org>
 eclass/vdr-plugin-2.eclass | 13 ++++++-------
 1 file changed, 6 insertions(+), 7 deletions(-)
diff --git a/eclass/vdr-plugin-2.eclass b/eclass/vdr-plugin-2.eclass
index 8f56511032c8..289c3d1a624a 100644
--- a/eclass/vdr-plugin-2.eclass
+++ b/eclass/vdr-plugin-2.eclass
@@ -160,7 +160,6 @@ vdr_create_header_checksum_file() {
 # Plugins failed on compile with wrong path of libsi includes,
 # this can be fixed by 'function + space separated list of files'
 fix_vdr_libsi_include() {
-	eqawarn "QA Notice: Fixing include of libsi-headers"
 	local f
 	for f; do
 		sed -i "${f}" \
@@ -245,7 +244,7 @@ vdr_gettext_missing() {
 
 	local GETTEXT_MISSING=$( grep xgettext Makefile )
 	if [[ -z ${GETTEXT_MISSING} ]]; then
-		eqawarn "QA Notice: Plugin isn't converted to gettext handling!"
+		einfo "Notice: Plugin isn't converted to gettext handling!"
 	fi
 }
 
@@ -306,11 +305,11 @@ vdr_i18n() {
 	if [[ -n ${I18N_OBJECT} ]]; then
 
 		if [[ "${KEEP_I18NOBJECT:-no}" = "yes" ]]; then
-			eqawarn "QA Notice: Forced to keep i18n.o"
+			einfo "Notice: Forced to keep i18n.o"
 		else
 			sed -i "s:i18n.o::g" Makefile \
 				|| die "sed failed to remove i18n from Makefile"
-			eqawarn "QA Notice: OBJECT i18n.o found, removed per sed"
+			einfo "Notice: OBJECT i18n.o found, removed per sed"
 		fi
 	fi
 
@@ -318,7 +317,7 @@ vdr_i18n() {
 	if [[ -n ${I18N_STRING} ]]; then
 		sed -i "s:^extern[[:space:]]*const[[:space:]]*tI18nPhrase://static const tI18nPhrase:" i18n.h \
 			|| die "sed failed to replace tI18nPhrase"
-		eqawarn "QA Notice: obsolete tI18nPhrase found, disabled per sed, please recheck"
+		einfo "Notice: obsolete tI18nPhrase found, disabled per sed"
 	fi
 }
 
@@ -337,7 +336,7 @@ vdr_remove_i18n_include() {
 		|| die "sed failed to remove i18n_include"
 	done
 
-	eqawarn "QA Notice: removed i18n.h include in ${@}"
+	einfo "Notice: removed i18n.h include in ${@}"
 }
 
 # @FUNCTION: vdr-plugin-2_print_enable_command
@@ -568,7 +567,7 @@ vdr-plugin-2_src_install() {
 		DESTDIR="${D%/}" \
 		|| die "emake install (makefile target) failed"
 	else
-		eqawarn "QA Notice: Plugin use still the old Makefile handling"
+		einfo "Notice: Plugin use still the old Makefile handling"
 		insinto "${VDR_PLUGIN_DIR}"
 		doins libvdr-*.so.*
 	fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-06-10 14:23 Ulrich Müller
  0 siblings, 0 replies; 6663+ messages in thread
From: Ulrich Müller @ 2024-06-10 14:23 UTC (permalink / raw
  To: gentoo-commits
commit:     c84e9a2e8477d99be37fa90357212eb20aa8784a
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Sat Jun  8 19:38:23 2024 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Mon Jun 10 14:22:49 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=c84e9a2e
common-lisp-3.eclass: sbcl supports --no-sysinit --no-userinit
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 eclass/common-lisp-3.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/common-lisp-3.eclass b/eclass/common-lisp-3.eclass
index b859c7859bfb..99825190f32e 100644
--- a/eclass/common-lisp-3.eclass
+++ b/eclass/common-lisp-3.eclass
@@ -215,7 +215,7 @@ common-lisp-export-impl-args() {
 	case "${CL_BINARY}" in
 		sbcl)
 			CL_BINARY="${CL_BINARY} --non-interactive"
-			CL_NORC="--sysinit /dev/null --userinit /dev/null"
+			CL_NORC="--no-sysinit --no-userinit"
 			CL_LOAD="--load"
 			CL_EVAL="--eval"
 			;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-06-10 14:23 Ulrich Müller
  0 siblings, 0 replies; 6663+ messages in thread
From: Ulrich Müller @ 2024-06-10 14:23 UTC (permalink / raw
  To: gentoo-commits
commit:     34e850c850431cde8a2bb93bc4f763894b3a2d5f
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Sat Jun  8 19:37:10 2024 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Mon Jun 10 14:22:43 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=34e850c8
common-lisp-3.eclass: Support EAPI 8
Minor stylistic changes.
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 eclass/common-lisp-3.eclass | 22 +++++++++++++---------
 1 file changed, 13 insertions(+), 9 deletions(-)
diff --git a/eclass/common-lisp-3.eclass b/eclass/common-lisp-3.eclass
index 26d31268a598..b859c7859bfb 100644
--- a/eclass/common-lisp-3.eclass
+++ b/eclass/common-lisp-3.eclass
@@ -1,17 +1,17 @@
-# Copyright 1999-2023 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: common-lisp-3.eclass
 # @MAINTAINER:
 # Common Lisp project <common-lisp@gentoo.org>
-# @SUPPORTED_EAPIS: 6 7
+# @SUPPORTED_EAPIS: 6 7 8
 # @BLURB: functions to support the installation of Common Lisp libraries
 # @DESCRIPTION:
 # Since Common Lisp libraries share similar structure, this eclass aims
 # to provide a simple way to write ebuilds with these characteristics.
 
 case ${EAPI} in
-	6|7) ;;
+	6|7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
@@ -121,7 +121,8 @@ common-lisp-install-sources() {
 
 	local fpredicate=$(common-lisp-get-fpredicate "${ftype}")
 
-	for path in "${@}" ; do
+	local path
+	for path ; do
 		if [[ -f ${path} ]] ; then
 			common-lisp-install-one-source ${fpredicate} "${path}" "$(dirname "${path}")"
 		elif [[ -d ${path} ]] ; then
@@ -148,7 +149,7 @@ common-lisp-install-sources() {
 # Installs ${1} asdf file in CLSOURCEROOT/CLPACKAGE and symlinks it in
 # CLSYSTEMROOT.
 common-lisp-install-one-asdf() {
-	[[ $# != 1 ]] && die "${FUNCNAME[0]} must receive exactly one argument"
+	[[ $# -eq 1 ]] || die "${FUNCNAME[0]} must receive exactly one argument"
 
 	# the suffix «.asd» is optional
 	local source=${1%.asd}.asd
@@ -166,9 +167,11 @@ common-lisp-install-one-asdf() {
 common-lisp-install-asdf() {
 	dodir "${CLSYSTEMROOT}"
 
-	[[ $# = 0 ]] && set - ${CLSYSTEMS}
-	[[ $# = 0 ]] && set - $(find . -type f -name \*.asd)
-	for sys in "${@}" ; do
+	[[ $# -eq 0 ]] && set - ${CLSYSTEMS}
+	[[ $# -eq 0 ]] && set - $(find . -type f -name \*.asd)
+
+	local sys
+	for sys ; do
 		common-lisp-install-one-asdf ${sys}
 	done
 }
@@ -187,6 +190,7 @@ common-lisp-3_src_install() {
 # Outputs an installed Common Lisp implementation. Transverses
 # CLIMPLEMENTATIONS to find it.
 common-lisp-find-lisp-impl() {
+	local lisp
 	for lisp in ${CLIMPLEMENTATIONS} ; do
 		[[ "$(best_version dev-lisp/${lisp})" ]] && echo "${lisp}" && return
 	done
@@ -203,7 +207,7 @@ common-lisp-find-lisp-impl() {
 #   * CL_LOAD: load a certain file
 #   * CL_EVAL: eval a certain expression at startup
 common-lisp-export-impl-args() {
-	if [[ $# != 1 ]]; then
+	if [[ $# -ne 1 ]]; then
 		eerror "Usage: ${FUNCNAME[0]} lisp-implementation"
 		die "${FUNCNAME[0]}: wrong number of arguments: $#"
 	fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-06-12 10:24 Arthur Zamarin
  0 siblings, 0 replies; 6663+ messages in thread
From: Arthur Zamarin @ 2024-06-12 10:24 UTC (permalink / raw
  To: gentoo-commits
commit:     e1e4f7a904235dee36d00eb23dcfcf66519c27e6
Author:     Arthur Zamarin <arthurzam <AT> gentoo <DOT> org>
AuthorDate: Wed Jun 12 06:57:12 2024 +0000
Commit:     Arthur Zamarin <arthurzam <AT> gentoo <DOT> org>
CommitDate: Wed Jun 12 10:23:41 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=e1e4f7a9
rust-toolchain.eclass: support riscv64*musl
Signed-off-by: Arthur Zamarin <arthurzam <AT> gentoo.org>
 eclass/rust-toolchain.eclass | 9 ++++++---
 1 file changed, 6 insertions(+), 3 deletions(-)
diff --git a/eclass/rust-toolchain.eclass b/eclass/rust-toolchain.eclass
index 5824a48734f9..5484d150614f 100644
--- a/eclass/rust-toolchain.eclass
+++ b/eclass/rust-toolchain.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2023 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: rust-toolchain.eclass
@@ -48,7 +48,8 @@ rust_abi() {
 		powerpc64le*) echo powerpc64le-unknown-linux-gnu;;
 		powerpc64*)   echo powerpc64-unknown-linux-gnu;;
 		powerpc*)     echo powerpc-unknown-linux-gnu;;
-		riscv64*)     echo riscv64gc-unknown-linux-gnu;;
+		riscv64*gnu)  echo riscv64gc-unknown-linux-gnu;;
+		riscv64*musl) echo riscv64gc-unknown-linux-musl;;
 		s390x*)       echo s390x-unknown-linux-gnu;;
 		x86_64*gnu)   echo x86_64-unknown-linux-gnu;;
 		x86_64*musl)  echo x86_64-unknown-linux-musl;;
@@ -127,7 +128,9 @@ rust_all_arch_uris()
 		big-endian?  ( $(rust_arch_uri powerpc64-unknown-linux-gnu   "$@") )
 		!big-endian? ( $(rust_arch_uri powerpc64le-unknown-linux-gnu "$@") )
 	)
-	riscv? ( $(rust_arch_uri riscv64gc-unknown-linux-gnu "$@") )
+	riscv? (
+		elibc_glibc? ( $(rust_arch_uri riscv64gc-unknown-linux-gnu "$@") )
+	)
 	s390?  ( $(rust_arch_uri s390x-unknown-linux-gnu     "$@") )
 	"
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-06-12 13:20 James Le Cuirot
  0 siblings, 0 replies; 6663+ messages in thread
From: James Le Cuirot @ 2024-06-12 13:20 UTC (permalink / raw
  To: gentoo-commits
commit:     375da3684e685c6fd8367ffcf37e090526d55e4d
Author:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
AuthorDate: Fri May 31 21:49:47 2024 +0000
Commit:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
CommitDate: Wed Jun 12 13:18:01 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=375da368
cargo.eclass: Enable cross-compiling by setting environment variables
CARGO_BUILD_TARGET and CARGO_TARGET_<triple>_LINKER are enough for pure
Rust. The linker otherwise defaults to `cc`. This doesn't respect any
linker specified in LDFLAGS, but this is also true for native builds. We
would need to do something with RUSTFLAGS.
The HOST_* variables are for the cc-rs crate, which is often used to
build non-Rust code. It uses the usual variables (CC, CFLAGS, etc) for
the target.
Signed-off-by: James Le Cuirot <chewi <AT> gentoo.org>
 eclass/cargo.eclass | 17 ++++++++++++++++-
 1 file changed, 16 insertions(+), 1 deletion(-)
diff --git a/eclass/cargo.eclass b/eclass/cargo.eclass
index 72c740cda906..40d98211ce7f 100644
--- a/eclass/cargo.eclass
+++ b/eclass/cargo.eclass
@@ -34,7 +34,7 @@ case ${EAPI} in
 		;;
 esac
 
-inherit flag-o-matic multiprocessing toolchain-funcs
+inherit flag-o-matic multiprocessing rust-toolchain toolchain-funcs
 
 [[ ! ${CARGO_OPTIONAL} ]] && BDEPEND="${RUST_DEPEND}"
 
@@ -525,6 +525,21 @@ cargo_src_compile() {
 	filter-lto
 	tc-export AR CC CXX PKG_CONFIG
 
+	if tc-is-cross-compiler; then
+		export CARGO_BUILD_TARGET=$(rust_abi)
+		local TRIPLE=${CARGO_BUILD_TARGET//-/_}
+		export CARGO_TARGET_"${TRIPLE^^}"_LINKER=$(tc-getCC)
+
+		# Set vars for cc-rs crate.
+		tc-export_build_env
+		export \
+			HOST_AR=$(tc-getBUILD_AR)
+			HOST_CC=$(tc-getBUILD_CC)
+			HOST_CXX=$(tc-getBUILD_CXX)
+			HOST_CFLAGS=${BUILD_CFLAGS}
+			HOST_CXXFLAGS=${BUILD_CXXFLAGS}
+	fi
+
 	set -- cargo build $(usex debug "" --release) ${ECARGO_ARGS[@]} "$@"
 	einfo "${@}"
 	"${@}" || die "cargo build failed"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-06-12 13:20 James Le Cuirot
  0 siblings, 0 replies; 6663+ messages in thread
From: James Le Cuirot @ 2024-06-12 13:20 UTC (permalink / raw
  To: gentoo-commits
commit:     e274b7b2ebe1261cb204064880be78c13300d13d
Author:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
AuthorDate: Fri Jun  7 16:57:37 2024 +0000
Commit:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
CommitDate: Wed Jun 12 13:18:00 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=e274b7b2
cargo.eclass: Drop EAPI 7 support
It is going to inherit rust-toolchain, which is EAPI 8 only.
Closes: https://bugs.gentoo.org/715890
Signed-off-by: James Le Cuirot <chewi <AT> gentoo.org>
 eclass/cargo.eclass | 19 ++-----------------
 1 file changed, 2 insertions(+), 17 deletions(-)
diff --git a/eclass/cargo.eclass b/eclass/cargo.eclass
index a685cd99fb38..72c740cda906 100644
--- a/eclass/cargo.eclass
+++ b/eclass/cargo.eclass
@@ -7,11 +7,11 @@
 # @AUTHOR:
 # Doug Goldstein <cardoe@gentoo.org>
 # Georgy Yakovlev <gyakovlev@gentoo.org>
-# @SUPPORTED_EAPIS: 7 8
+# @SUPPORTED_EAPIS: 8
 # @BLURB: common functions and variables for cargo builds
 
 case ${EAPI} in
-	7|8) ;;
+	8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
@@ -23,10 +23,6 @@ _CARGO_ECLASS=1
 RUST_DEPEND="virtual/rust"
 
 case ${EAPI} in
-	7)
-		# 1.37 added 'cargo vendor' subcommand and net.offline config knob
-		RUST_DEPEND=">=virtual/rust-1.37.0"
-		;;
 	8)
 		# 1.39 added --workspace
 		# 1.46 added --target dir
@@ -556,17 +552,6 @@ cargo_src_install() {
 
 	rm -f "${ED}/usr/.crates.toml" || die
 	rm -f "${ED}/usr/.crates2.json" || die
-
-	# it turned out to be non-standard dir, so get rid of it future EAPI
-	# and only run for EAPI=7
-	# https://bugs.gentoo.org/715890
-	case ${EAPI:-0} in
-		7)
-		if [ -d "${S}/man" ]; then
-			doman "${S}/man" || return 0
-		fi
-		;;
-	esac
 }
 
 # @FUNCTION: cargo_src_test
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-06-12 14:27 Patrick Lauer
  0 siblings, 0 replies; 6663+ messages in thread
From: Patrick Lauer @ 2024-06-12 14:27 UTC (permalink / raw
  To: gentoo-commits
commit:     64a7bf34f31437b26886cc75cff8d5585fc50236
Author:     Patrick Lauer <patrick <AT> gentoo <DOT> org>
AuthorDate: Wed Jun 12 14:16:14 2024 +0000
Commit:     Patrick Lauer <patrick <AT> gentoo <DOT> org>
CommitDate: Wed Jun 12 14:27:05 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=64a7bf34
postgres-multi.eclass: Add EAPI 8 support
Previously blocked by postgres.eclass, which was fixed in
304ab5e1acc056aca413ed69bc6791270502cbce
Signed-off-by: Patrick Lauer <patrick <AT> gentoo.org>
 eclass/postgres-multi.eclass | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/eclass/postgres-multi.eclass b/eclass/postgres-multi.eclass
index d93df851cd24..52ca83b9126f 100644
--- a/eclass/postgres-multi.eclass
+++ b/eclass/postgres-multi.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2022 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: postgres-multi.eclass
@@ -15,7 +15,7 @@
 # POSTGRES_TARGETS use flags.
 
 case ${EAPI} in
-	7) ;;
+	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-06-12 16:36 Patrick Lauer
  0 siblings, 0 replies; 6663+ messages in thread
From: Patrick Lauer @ 2024-06-12 16:36 UTC (permalink / raw
  To: gentoo-commits
commit:     7abcd95126ff4da8684953573eec02e2c71059cb
Author:     Patrick Lauer <patrick <AT> gentoo <DOT> org>
AuthorDate: Wed Jun 12 16:35:30 2024 +0000
Commit:     Patrick Lauer <patrick <AT> gentoo <DOT> org>
CommitDate: Wed Jun 12 16:36:20 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=7abcd951
postgres-multi.eclass: Fix annotations
Signed-off-by: Patrick Lauer <patrick <AT> gentoo.org>
 eclass/postgres-multi.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/postgres-multi.eclass b/eclass/postgres-multi.eclass
index 52ca83b9126f..92299b8cf34c 100644
--- a/eclass/postgres-multi.eclass
+++ b/eclass/postgres-multi.eclass
@@ -6,7 +6,7 @@
 # PostgreSQL <pgsql-bugs@gentoo.org>
 # @AUTHOR:
 # Aaron W. Swenson <titanofold@gentoo.org>
-# @SUPPORTED_EAPIS: 7
+# @SUPPORTED_EAPIS: 7 8
 # @PROVIDES: multibuild postgres
 # @BLURB: An eclass to build PostgreSQL-related packages against multiple slots
 # @DESCRIPTION:
^ permalink raw reply related	[flat|nested] 6663+ messages in thread
* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-06-12 17:13 James Le Cuirot
  0 siblings, 0 replies; 6663+ messages in thread
From: James Le Cuirot @ 2024-06-12 17:13 UTC (permalink / raw
  To: gentoo-commits
commit:     82ae7b64442ed6fb9ea99e6d64af1eb173a54adb
Author:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
AuthorDate: Wed Jun 12 16:59:23 2024 +0000
Commit:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
CommitDate: Wed Jun 12 17:13:21 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=82ae7b64
rust-toolchain.eclass: Drop unused rust_all_abis() and multilib inherit
multilib USE flags have unintentionally appeared against all Cargo
packages since this eclass was used by cargo.eclass. The rust_all_abis()
function is not used anywhere though, and removing it makes the
multilib-build inherit that is causing the issue redundant.
Signed-off-by: James Le Cuirot <chewi <AT> gentoo.org>
 eclass/rust-toolchain.eclass | 25 ++-----------------------
 1 file changed, 2 insertions(+), 23 deletions(-)
diff --git a/eclass/rust-toolchain.eclass b/eclass/rust-toolchain.eclass
index 5484d150614f..111aece796ce 100644
--- a/eclass/rust-toolchain.eclass
+++ b/eclass/rust-toolchain.eclass
@@ -7,17 +7,14 @@
 # @SUPPORTED_EAPIS: 8
 # @BLURB: helps map gentoo arches to rust ABIs
 # @DESCRIPTION:
-# This eclass contains a src_unpack default phase function, and
-# helper functions, to aid in proper rust-ABI handling for various
-# gentoo arches.
+# This eclass contains helper functions, to aid in proper rust-ABI handling for
+# various gentoo arches.
 
 case ${EAPI} in
 	8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
-inherit multilib-build
-
 # @ECLASS_VARIABLE: RUST_TOOLCHAIN_BASEURL
 # @DESCRIPTION:
 # This variable specifies the base URL used by the
@@ -57,24 +54,6 @@ rust_abi() {
   esac
 }
 
-# @FUNCTION: rust_all_abis
-# @DESCRIPTION:
-# Outputs a list of all the enabled Rust ABIs
-rust_all_abis() {
-	if use multilib; then
-		local abi
-		local ALL_ABIS=()
-		for abi in $(multilib_get_enabled_abis); do
-			ALL_ABIS+=( $(rust_abi $(get_abi_CHOST ${abi})) )
-		done
-		local abi_list
-		IFS=, eval 'abi_list=${ALL_ABIS[*]}'
-		echo ${abi_list}
-	else
-		rust_abi
-	fi
-}
-
 # @FUNCTION: rust_arch_uri
 # @USAGE: <rust-ABI> <base-uri> [alt-distfile-basename]
 # @DESCRIPTION:
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-06-13 13:21 Miroslav Šulc
  0 siblings, 0 replies; 6663+ messages in thread
From: Miroslav Šulc @ 2024-06-13 13:21 UTC (permalink / raw
  To: gentoo-commits
commit:     ad91645400d2f60a4c19a7f41024a70a499d8ea5
Author:     Volkmar W. Pogatzki <gentoo <AT> pogatzki <DOT> net>
AuthorDate: Sat Jun  8 07:26:08 2024 +0000
Commit:     Miroslav Šulc <fordfrog <AT> gentoo <DOT> org>
CommitDate: Thu Jun 13 13:21:05 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=ad916454
java-vm-2.eclass: drop EAPI 7
Signed-off-by: Volkmar W. Pogatzki <gentoo <AT> pogatzki.net>
Signed-off-by: Miroslav Šulc <fordfrog <AT> gentoo.org>
 eclass/java-vm-2.eclass | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/eclass/java-vm-2.eclass b/eclass/java-vm-2.eclass
index e5d3159f2854..c7a207ae24f7 100644
--- a/eclass/java-vm-2.eclass
+++ b/eclass/java-vm-2.eclass
@@ -4,14 +4,14 @@
 # @ECLASS: java-vm-2.eclass
 # @MAINTAINER:
 # java@gentoo.org
-# @SUPPORTED_EAPIS: 7 8
+# @SUPPORTED_EAPIS: 8
 # @BLURB: Java Virtual Machine eclass
 # @DESCRIPTION:
 # This eclass provides functionality which assists with installing
 # virtual machines, and ensures that they are recognized by java-config.
 
 case ${EAPI} in
-	7|8) ;;
+	8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-06-13 18:35 Ulrich Müller
  0 siblings, 0 replies; 6663+ messages in thread
From: Ulrich Müller @ 2024-06-13 18:35 UTC (permalink / raw
  To: gentoo-commits
commit:     e4333a984533c5d42d637f42a388f90b5eb8b856
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Thu Jun 13 18:33:07 2024 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Thu Jun 13 18:35:31 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=e4333a98
rebar.eclass: Fix EPREFIX and ED usage
The path returned by $(get_erl_libs) starts with a slash, so
${EPREFIX}/$(get_erl_libs) resulted in a double slash.
Fixes: 7ee6937e6219f250559ee26eb64e5991b27cd289
Closes: https://bugs.gentoo.org/770283
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 eclass/rebar.eclass | 12 ++++++------
 1 file changed, 6 insertions(+), 6 deletions(-)
diff --git a/eclass/rebar.eclass b/eclass/rebar.eclass
index c1a3aca67b54..1c131dd496be 100644
--- a/eclass/rebar.eclass
+++ b/eclass/rebar.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2023 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: rebar.eclass
@@ -63,7 +63,7 @@ _rebar_find_dep() {
 	local p
 	local result
 
-	pushd "${EPREFIX}/$(get_erl_libs)" >/dev/null || return 1
+	pushd "${EPREFIX}$(get_erl_libs)" >/dev/null || return 1
 	for p in ${pn} ${pn}-*; do
 		if [[ -d ${p} ]]; then
 			# Ensure there's at most one matching.
@@ -102,7 +102,7 @@ erebar() {
 
 	(( $# > 0 )) || die "erebar: at least one target is required"
 
-	local -x ERL_LIBS="${EPREFIX}/$(get_erl_libs)"
+	local -x ERL_LIBS="${EPREFIX}$(get_erl_libs)"
 	[[ ${1} == eunit ]] && local -x ERL_LIBS="."
 
 	rebar -v skip_deps=true "$@" || die -n "rebar $@ failed"
@@ -123,7 +123,7 @@ rebar_fix_include_path() {
 
 	local pn="${1}"
 	local rebar_config="${2:-rebar.config}"
-	local erl_libs="${EPREFIX}/$(get_erl_libs)"
+	local erl_libs="${EPREFIX}$(get_erl_libs)"
 	local p
 
 	p="$(_rebar_find_dep "${pn}")" \
@@ -212,7 +212,7 @@ rebar_src_prepare() {
 rebar_src_configure() {
 	debug-print-function ${FUNCNAME} "${@}"
 
-	local -x ERL_LIBS="${EPREFIX}/$(get_erl_libs)"
+	local -x ERL_LIBS="${EPREFIX}$(get_erl_libs)"
 	default
 }
 
@@ -252,7 +252,7 @@ rebar_src_install() {
 	[[ -d bin ]] && for bin in bin/*; do dobin "$bin"; done
 
 	if [[ -d priv ]]; then
-		cp -pR priv "${ED%/}/${dest}/" || die "failed to install priv/"
+		cp -pR priv "${ED%/}${dest}/" || die "failed to install priv/"
 	fi
 
 	einstalldocs
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-06-13 18:35 Ulrich Müller
  0 siblings, 0 replies; 6663+ messages in thread
From: Ulrich Müller @ 2024-06-13 18:35 UTC (permalink / raw
  To: gentoo-commits
commit:     a74cd3b3c5b4ac4cdc793e42ad04cd60f750fa17
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Thu Jun 13 18:34:34 2024 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Thu Jun 13 18:35:32 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=a74cd3b3
rebar.eclass: Drop support for EAPI 6
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 eclass/rebar.eclass | 9 +++------
 1 file changed, 3 insertions(+), 6 deletions(-)
diff --git a/eclass/rebar.eclass b/eclass/rebar.eclass
index 1c131dd496be..97638c761814 100644
--- a/eclass/rebar.eclass
+++ b/eclass/rebar.eclass
@@ -6,7 +6,7 @@
 # maintainer-needed@gentoo.org
 # @AUTHOR:
 # Amadeusz Żołnowski <aidecoe@gentoo.org>
-# @SUPPORTED_EAPIS: 6 7 8
+# @SUPPORTED_EAPIS: 7 8
 # @BLURB: Build Erlang/OTP projects using dev-util/rebar.
 # @DESCRIPTION:
 # An eclass providing functions to build Erlang/OTP projects using
@@ -20,7 +20,7 @@
 # installation in a generic way for Erlang/OTP structured projects.
 
 case ${EAPI} in
-	6|7|8) ;;
+	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
@@ -33,9 +33,6 @@ BDEPEND="
 	dev-util/rebar:0
 	>=sys-apps/gawk-4.1
 "
-if [[ ${EAPI} == 6 ]]; then
-	DEPEND+=" ${BDEPEND}"
-fi
 
 # @ECLASS_VARIABLE: REBAR_APP_SRC
 # @DESCRIPTION:
@@ -252,7 +249,7 @@ rebar_src_install() {
 	[[ -d bin ]] && for bin in bin/*; do dobin "$bin"; done
 
 	if [[ -d priv ]]; then
-		cp -pR priv "${ED%/}${dest}/" || die "failed to install priv/"
+		cp -pR priv "${ED}${dest}/" || die "failed to install priv/"
 	fi
 
 	einstalldocs
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-06-13 20:43 Andreas Sturmlechner
  0 siblings, 0 replies; 6663+ messages in thread
From: Andreas Sturmlechner @ 2024-06-13 20:43 UTC (permalink / raw
  To: gentoo-commits
commit:     500eb409f00c5714f78325d171e60789603156e7
Author:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
AuthorDate: Thu Jun 13 17:32:27 2024 +0000
Commit:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
CommitDate: Thu Jun 13 20:42:12 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=500eb409
ecm.eclass: For _KFSLOT=6, RDEPEND on >=kde-frameworks/kf-env-6
Signed-off-by: Andreas Sturmlechner <asturm <AT> gentoo.org>
 eclass/ecm.eclass | 3 ++-
 1 file changed, 2 insertions(+), 1 deletion(-)
diff --git a/eclass/ecm.eclass b/eclass/ecm.eclass
index d36b11ebd5e8..518f913815be 100644
--- a/eclass/ecm.eclass
+++ b/eclass/ecm.eclass
@@ -277,14 +277,15 @@ BDEPEND+="
 	dev-libs/libpcre2:*
 	>=kde-frameworks/extra-cmake-modules-${KFMIN}:*
 "
-RDEPEND+=" >=kde-frameworks/kf-env-4"
 if [[ ${ECM_TEST} != false ]]; then
 	IUSE+=" test"
 	RESTRICT+=" !test? ( test )"
 fi
 if [[ ${_KFSLOT} == 6 ]]; then
+	RDEPEND+=" >=kde-frameworks/kf-env-6"
 	COMMONDEPEND+=" dev-qt/qtbase:${_KFSLOT}"
 else
+	RDEPEND+=" >=kde-frameworks/kf-env-4"
 	COMMONDEPEND+=" dev-qt/qtcore:${_KFSLOT}"
 	if [[ ${ECM_TEST} != false ]]; then
 		DEPEND+=" test? ( dev-qt/qttest:5 )"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-06-14 10:00 Miroslav Šulc
  0 siblings, 0 replies; 6663+ messages in thread
From: Miroslav Šulc @ 2024-06-14 10:00 UTC (permalink / raw
  To: gentoo-commits
commit:     d7462249b3a531af33ca05b99a02806f580fa032
Author:     Volkmar W. Pogatzki <gentoo <AT> pogatzki <DOT> net>
AuthorDate: Tue Feb 13 07:19:02 2024 +0000
Commit:     Miroslav Šulc <fordfrog <AT> gentoo <DOT> org>
CommitDate: Fri Jun 14 10:00:10 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=d7462249
java-utils-2.eclass: prepend "QA Notice" to eqawarn
Closes: https://bugs.gentoo.org/813342
Signed-off-by: Volkmar W. Pogatzki <gentoo <AT> pogatzki.net>
Signed-off-by: Miroslav Šulc <fordfrog <AT> gentoo.org>
 eclass/java-utils-2.eclass | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/eclass/java-utils-2.eclass b/eclass/java-utils-2.eclass
index 58463fd5e1ed..1e0555742b84 100644
--- a/eclass/java-utils-2.eclass
+++ b/eclass/java-utils-2.eclass
@@ -2934,7 +2934,7 @@ java-pkg_ensure-dep() {
 #		if is-java-strict; then
 #			die "${dev_error}"
 #		else
-			eqawarn "java-pkg_ensure-dep: ${dev_error}"
+			eqawarn "QA Notice: java-pkg_ensure-dep: ${dev_error}"
 #			eerror "Because you have ${target_pkg} installed,"
 #			eerror "the package will build without problems, but please"
 #			eerror "report this to https://bugs.gentoo.org."
@@ -2945,7 +2945,7 @@ java-pkg_ensure-dep() {
 #		if is-java-strict; then
 #			die "${dev_error}"
 #		else
-			eqawarn "java-pkg_ensure-dep: ${dev_error}"
+			eqawarn "QA Notice: java-pkg_ensure-dep: ${dev_error}"
 #			eerror "The package will build without problems, but may fail to run"
 #			eerror "if you don't have ${target_pkg} installed,"
 #			eerror "so please report this to https://bugs.gentoo.org."
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-06-14 10:00 Miroslav Šulc
  0 siblings, 0 replies; 6663+ messages in thread
From: Miroslav Šulc @ 2024-06-14 10:00 UTC (permalink / raw
  To: gentoo-commits
commit:     b18c31b629bfbcf3d1882cff297d96ec7725b459
Author:     Volkmar W. Pogatzki <gentoo <AT> pogatzki <DOT> net>
AuthorDate: Mon Feb 12 09:47:43 2024 +0000
Commit:     Miroslav Šulc <fordfrog <AT> gentoo <DOT> org>
CommitDate: Fri Jun 14 10:00:05 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=b18c31b6
java-utils-2.eclass: solve Unexpected tag in "funcvar" state
Closes: https://bugs.gentoo.org/637768
Signed-off-by: Volkmar W. Pogatzki <gentoo <AT> pogatzki.net>
Signed-off-by: Miroslav Šulc <fordfrog <AT> gentoo.org>
 eclass/java-utils-2.eclass | 9 ++++++---
 1 file changed, 6 insertions(+), 3 deletions(-)
diff --git a/eclass/java-utils-2.eclass b/eclass/java-utils-2.eclass
index 47123287ce70..58463fd5e1ed 100644
--- a/eclass/java-utils-2.eclass
+++ b/eclass/java-utils-2.eclass
@@ -319,12 +319,15 @@ java-pkg_doexamples() {
 # arguments are passed through to find.
 #
 # @CODE
+# Parameters:
+# $1 - jar file
+# $2 - resource tree directory
+# $* - arguments to pass to find
+#
+# Example:
 #	java-pkg_addres ${PN}.jar resources ! -name "*.html"
 # @CODE
 #
-# @param $1 - jar file
-# @param $2 - resource tree directory
-# @param $* - arguments to pass to find
 java-pkg_addres() {
 	debug-print-function ${FUNCNAME} $*
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-06-14 10:00 Miroslav Šulc
  0 siblings, 0 replies; 6663+ messages in thread
From: Miroslav Šulc @ 2024-06-14 10:00 UTC (permalink / raw
  To: gentoo-commits
commit:     a065e86dbe3e86803ae1f656b86ee0278ab4b835
Author:     Volkmar W. Pogatzki <gentoo <AT> pogatzki <DOT> net>
AuthorDate: Tue Feb 13 07:32:45 2024 +0000
Commit:     Miroslav Šulc <fordfrog <AT> gentoo <DOT> org>
CommitDate: Fri Jun 14 10:00:10 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=a065e86d
java-utils-2.eclass: improve message of java-pkg_die
Closes: https://bugs.gentoo.org/591142
Signed-off-by: Volkmar W. Pogatzki <gentoo <AT> pogatzki.net>
Signed-off-by: Miroslav Šulc <fordfrog <AT> gentoo.org>
 eclass/java-utils-2.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/java-utils-2.eclass b/eclass/java-utils-2.eclass
index 1e0555742b84..ac0c67942b41 100644
--- a/eclass/java-utils-2.eclass
+++ b/eclass/java-utils-2.eclass
@@ -2816,7 +2816,7 @@ java-pkg_die() {
 	echo "!!! When you file a bug report, please include the following information:" >&2
 	echo "GENTOO_VM=${GENTOO_VM}  CLASSPATH=\"${CLASSPATH}\" JAVA_HOME=\"${JAVA_HOME}\"" >&2
 	echo "JAVACFLAGS=\"${JAVACFLAGS}\" COMPILER=\"${GENTOO_COMPILER}\"" >&2
-	echo "and of course, the output of emerge --info =${P}" >&2
+	echo "and of course, the output of emerge --info =${CATEGORY}/${PF}" >&2
 }
 
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-06-14 10:00 Miroslav Šulc
  0 siblings, 0 replies; 6663+ messages in thread
From: Miroslav Šulc @ 2024-06-14 10:00 UTC (permalink / raw
  To: gentoo-commits
commit:     41faa907e3a36f4ed00aced3499d469abb865281
Author:     Volkmar W. Pogatzki <gentoo <AT> pogatzki <DOT> net>
AuthorDate: Mon Feb 26 09:37:01 2024 +0000
Commit:     Miroslav Šulc <fordfrog <AT> gentoo <DOT> org>
CommitDate: Fri Jun 14 10:00:10 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=41faa907
java-utils-2.eclass: eerror if java-utils-2 is inherited directly
Closes: https://bugs.gentoo.org/207098
Signed-off-by: Volkmar W. Pogatzki <gentoo <AT> pogatzki.net>
Signed-off-by: Miroslav Šulc <fordfrog <AT> gentoo.org>
 eclass/java-utils-2.eclass | 6 ++++++
 1 file changed, 6 insertions(+)
diff --git a/eclass/java-utils-2.eclass b/eclass/java-utils-2.eclass
index ac0c67942b41..bc6fe9086583 100644
--- a/eclass/java-utils-2.eclass
+++ b/eclass/java-utils-2.eclass
@@ -34,6 +34,12 @@ export WANT_JAVA_CONFIG="2"
 
 has test ${JAVA_PKG_IUSE} && RESTRICT+=" !test? ( test )"
 
+# this eclass must be inherited after java-pkg-2 or java-pkg-opt-2
+# bug #207098
+if ! has java-pkg-2 ${INHERITED} && ! has java-pkg-opt-2 ${INHERITED}; then
+	eerror "java-utils-2 eclass must not be inherited directly."
+fi
+
 # @VARIABLE: JAVA_PKG_E_DEPEND
 # @INTERNAL
 # @DESCRIPTION:
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-06-14 10:00 Miroslav Šulc
  0 siblings, 0 replies; 6663+ messages in thread
From: Miroslav Šulc @ 2024-06-14 10:00 UTC (permalink / raw
  To: gentoo-commits
commit:     ad8cd90f68f7448bbaf6d4501a28ffb41555305f
Author:     Volkmar W. Pogatzki <gentoo <AT> pogatzki <DOT> net>
AuthorDate: Sun May 26 08:00:48 2024 +0000
Commit:     Miroslav Šulc <fordfrog <AT> gentoo <DOT> org>
CommitDate: Fri Jun 14 10:00:10 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=ad8cd90f
java-utils-2.eclass: drop redundant java-pkg_get-current-vm()
Removes the first of two different versions of java-pkg_get-current-vm()
Signed-off-by: Volkmar W. Pogatzki <gentoo <AT> pogatzki.net>
Closes: https://github.com/gentoo/gentoo/pull/35287
Signed-off-by: Miroslav Šulc <fordfrog <AT> gentoo.org>
 eclass/java-utils-2.eclass | 4 ----
 1 file changed, 4 deletions(-)
diff --git a/eclass/java-utils-2.eclass b/eclass/java-utils-2.eclass
index bc6fe9086583..b72a00b352d2 100644
--- a/eclass/java-utils-2.eclass
+++ b/eclass/java-utils-2.eclass
@@ -1646,10 +1646,6 @@ java-pkg_set-current-vm() {
 	export GENTOO_VM=${1}
 }
 
-java-pkg_get-current-vm() {
-	echo ${GENTOO_VM}
-}
-
 java-pkg_current-vm-matches() {
 	has $(java-pkg_get-current-vm) ${@}
 	return $?
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-06-14 12:19 Miroslav Šulc
  0 siblings, 0 replies; 6663+ messages in thread
From: Miroslav Šulc @ 2024-06-14 12:19 UTC (permalink / raw
  To: gentoo-commits
commit:     3e3b6279bd902e90032243148e7c96cc755afc6d
Author:     Volkmar W. Pogatzki <gentoo <AT> pogatzki <DOT> net>
AuthorDate: Fri Jun 14 12:12:00 2024 +0000
Commit:     Miroslav Šulc <fordfrog <AT> gentoo <DOT> org>
CommitDate: Fri Jun 14 12:19:36 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=3e3b6279
Revert "java-utils-2.eclass: eerror if java-utils-2 is inherited directly"
This reverts commit 41faa907e3a36f4ed00aced3499d469abb865281.
Bug: https://bugs.gentoo.org/207098
Signed-off-by: Volkmar W. Pogatzki <gentoo <AT> pogatzki.net>
Closes: https://github.com/gentoo/gentoo/pull/37156
Signed-off-by: Miroslav Šulc <fordfrog <AT> gentoo.org>
 eclass/java-utils-2.eclass | 6 ------
 1 file changed, 6 deletions(-)
diff --git a/eclass/java-utils-2.eclass b/eclass/java-utils-2.eclass
index b72a00b352d2..adbc5242053a 100644
--- a/eclass/java-utils-2.eclass
+++ b/eclass/java-utils-2.eclass
@@ -34,12 +34,6 @@ export WANT_JAVA_CONFIG="2"
 
 has test ${JAVA_PKG_IUSE} && RESTRICT+=" !test? ( test )"
 
-# this eclass must be inherited after java-pkg-2 or java-pkg-opt-2
-# bug #207098
-if ! has java-pkg-2 ${INHERITED} && ! has java-pkg-opt-2 ${INHERITED}; then
-	eerror "java-utils-2 eclass must not be inherited directly."
-fi
-
 # @VARIABLE: JAVA_PKG_E_DEPEND
 # @INTERNAL
 # @DESCRIPTION:
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-06-14 12:26 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-06-14 12:26 UTC (permalink / raw
  To: gentoo-commits
commit:     a3266609c65361d1dc2e7c1be9c91721c899750a
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Jun  1 09:09:37 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Fri Jun 14 12:26:04 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=a3266609
distutils-r1.eclass: Remove doc for DOCS, HTML_DOCS and PATCHES
Remove the redundant (and outdated) documentation for the DOCS,
HTML_DOCS and PATCHES variables.  All these variables are handled
through the default EAPI functions.
Closes: https://bugs.gentoo.org/932802
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/distutils-r1.eclass | 46 ----------------------------------------------
 1 file changed, 46 deletions(-)
diff --git a/eclass/distutils-r1.eclass b/eclass/distutils-r1.eclass
index 71b80fafe1a5..eac4d592efaf 100644
--- a/eclass/distutils-r1.eclass
+++ b/eclass/distutils-r1.eclass
@@ -364,52 +364,6 @@ _distutils_set_globals() {
 _distutils_set_globals
 unset -f _distutils_set_globals
 
-# @ECLASS_VARIABLE: PATCHES
-# @DEFAULT_UNSET
-# @DESCRIPTION:
-# An array containing patches to be applied to the sources before
-# copying them.
-#
-# If unset, no custom patches will be applied.
-#
-# Please note, however, that at some point the eclass may apply
-# additional distutils patches/quirks independently of this variable.
-#
-# Example:
-# @CODE
-# PATCHES=( "${FILESDIR}"/${P}-make-gentoo-happy.patch )
-# @CODE
-
-# @ECLASS_VARIABLE: DOCS
-# @DEFAULT_UNSET
-# @DESCRIPTION:
-# An array containing documents installed using dodoc. The files listed
-# there must exist in the directory from which
-# distutils-r1_python_install_all() is run (${S} by default).
-#
-# If unset, the function will instead look up files matching default
-# filename pattern list (from the Package Manager Specification),
-# and install those found.
-#
-# Example:
-# @CODE
-# DOCS=( NEWS README )
-# @CODE
-
-# @ECLASS_VARIABLE: HTML_DOCS
-# @DEFAULT_UNSET
-# @DESCRIPTION:
-# An array containing documents installed using dohtml. The files
-# and directories listed there must exist in the directory from which
-# distutils-r1_python_install_all() is run (${S} by default).
-#
-# If unset, no HTML docs will be installed.
-#
-# Example:
-# @CODE
-# HTML_DOCS=( doc/html/. )
-# @CODE
-
 # @ECLASS_VARIABLE: DISTUTILS_IN_SOURCE_BUILD
 # @DEFAULT_UNSET
 # @DESCRIPTION:
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-06-14 12:26 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-06-14 12:26 UTC (permalink / raw
  To: gentoo-commits
commit:     d344e223068c8d9eb695ba464facb4451bb07d5c
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Jun  1 09:14:26 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Fri Jun 14 12:26:05 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=d344e223
distutils-r1.eclass: Doc DISTUTILS_OPTIONAL + DISTUTILS_SINGLE_IMPL
Closes: https://bugs.gentoo.org/780807
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/distutils-r1.eclass | 5 +++++
 1 file changed, 5 insertions(+)
diff --git a/eclass/distutils-r1.eclass b/eclass/distutils-r1.eclass
index eac4d592efaf..392725d48121 100644
--- a/eclass/distutils-r1.eclass
+++ b/eclass/distutils-r1.eclass
@@ -78,6 +78,11 @@ esac
 # for your package (using ${PYTHON_DEPS}) and to either call
 # distutils-r1 default phase functions or call the build system
 # manually.
+#
+# Note that if DISTUTILS_SINGLE_IMPL is used, python-single-r1 exports
+# pkg_setup() function.  In that case, it is necessary to redefine
+# pkg_setup() to call python-single-r1_pkg_setup over correct
+# conditions.
 
 # @ECLASS_VARIABLE: DISTUTILS_SINGLE_IMPL
 # @DEFAULT_UNSET
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-06-14 12:26 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-06-14 12:26 UTC (permalink / raw
  To: gentoo-commits
commit:     8c7703e917f8ff61c4fa7881ef664eb9054c23d6
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Mon Jun 10 18:58:16 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Fri Jun 14 12:26:10 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=8c7703e9
python-r1.eclass: Override PYTHON*_USEDEP in sub-phases
Override the value of PYTHON_USEDEP and PYTHON_SINGLE_USEDEP to match
the current implementation inside sub-phase function.  This makes
it possible to use them in has_version checks with conditional
dependencies.
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/python-r1.eclass | 4 +++-
 1 file changed, 3 insertions(+), 1 deletion(-)
diff --git a/eclass/python-r1.eclass b/eclass/python-r1.eclass
index fbc6082a1d92..c5fa6770558f 100644
--- a/eclass/python-r1.eclass
+++ b/eclass/python-r1.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2023 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: python-r1.eclass
@@ -594,6 +594,8 @@ _python_multibuild_wrapper() {
 
 	local -x EPYTHON PYTHON
 	local -x PATH=${PATH} PKG_CONFIG_PATH=${PKG_CONFIG_PATH}
+	local PYTHON_USEDEP="python_targets_${MULTIBUILD_VARIANT}(-)"
+	local PYTHON_SINGLE_USEDEP="python_single_target_${MULTIBUILD_VARIANT}(-)"
 	_python_export "${MULTIBUILD_VARIANT}" EPYTHON PYTHON
 	_python_wrapper_setup
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-06-14 12:26 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-06-14 12:26 UTC (permalink / raw
  To: gentoo-commits
commit:     941e9c718887243f880ee6f8271c5e6d9aeb75db
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sun Jun  2 18:01:26 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Fri Jun 14 12:26:08 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=941e9c71
distutils-r1.eclass: Remove distutils_install_for_testing
Remove `distutils_install_for_testing` function.  It is quite complex,
and it was used only in the legacy eclass mode.  All ebuilds using it
in ::gentoo have been migrated to PEP517 build already, and the PEP517
build implement the same functionality better.
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/distutils-r1.eclass | 123 ++-------------------------------------------
 1 file changed, 5 insertions(+), 118 deletions(-)
diff --git a/eclass/distutils-r1.eclass b/eclass/distutils-r1.eclass
index f0d9d3a4b937..afed1fa547d1 100644
--- a/eclass/distutils-r1.eclass
+++ b/eclass/distutils-r1.eclass
@@ -704,123 +704,12 @@ esetup.py() {
 }
 
 # @FUNCTION: distutils_install_for_testing
-# @USAGE: [--via-root|--via-home|--via-venv] [<args>...]
+# @DEPRECATED: DISTUTILS_USE_PEP517=...
 # @DESCRIPTION:
-# Install the package into a temporary location for running tests.
-# Update PYTHONPATH appropriately and set TEST_DIR to the test
-# installation root. The Python packages will be installed in 'lib'
-# subdir, and scripts in 'scripts' subdir (like in BUILD_DIR).
-#
-# Please note that this function should be only used if package uses
-# namespaces (and therefore proper install needs to be done to enforce
-# PYTHONPATH) or tests rely on the results of install command.
-# For most of the packages, tests built in BUILD_DIR are good enough.
-#
-# The function supports three install modes.  These are:
-#
-# --via-root (the default) that uses 'setup.py install --root=...'
-# combined with PYTHONPATH and is recommended for the majority
-# of packages.
-#
-# --via-venv that creates a (non-isolated) venv and installs the package
-# into it via 'setup.py install'.  This mode does not use PYTHONPATH
-# but requires python to be called via PATH.  It may solve a few corner
-# cases that --via-root do not support.
-#
-# --via-home that uses 'setup.py install --home=...'.  This is
-# a historical mode that was mostly broken by setuptools 50.3.0+.
-# If your package does not work with the other two modes but works with
-# this one, please report a bug.
-#
-# Please note that in order to test the solution properly you need
-# to unmerge the package first.
-#
-# This function is not available in PEP517 mode.  The eclass provides
-# a venv-style install unconditionally and therefore it should no longer
-# be necessary.
+# This function used to provide an installed package for running tests.
+# It is no longer implemented, PEP517 mode must be used instead.
 distutils_install_for_testing() {
-	debug-print-function ${FUNCNAME} "${@}"
-
-	if [[ ${DISTUTILS_USE_PEP517} ]]; then
-		die "${FUNCNAME} is not implemented in PEP517 mode"
-	fi
-
-	# A few notes about --via-home mode:
-	# 1) 'install --home' is terribly broken on pypy, so we need
-	#    to override --install-lib and --install-scripts,
-	# 2) non-root 'install' complains about PYTHONPATH and missing dirs,
-	#    so we need to set it properly and mkdir them,
-	# 3) it runs a bunch of commands which write random files to cwd,
-	#    in order to avoid that, we add the necessary path overrides
-	#    in _distutils-r1_create_setup_cfg.
-
-	local install_method=root
-	case ${1} in
-		--via-home)
-			[[ ${EAPI} == 7 ]] || die "${*} is banned in EAPI ${EAPI}"
-			install_method=home
-			shift
-			;;
-		--via-root)
-			install_method=root
-			shift
-			;;
-		--via-venv)
-			install_method=venv
-			shift
-			;;
-	esac
-
-	TEST_DIR=${BUILD_DIR}/test
-	local add_args=()
-
-	if [[ ${install_method} == venv ]]; then
-		# create a quasi-venv
-		mkdir -p "${TEST_DIR}"/bin || die
-		ln -s "${PYTHON}" "${TEST_DIR}/bin/${EPYTHON}" || die
-		ln -s "${EPYTHON}" "${TEST_DIR}/bin/python3" || die
-		ln -s "${EPYTHON}" "${TEST_DIR}/bin/python" || die
-		cat > "${TEST_DIR}"/pyvenv.cfg <<-EOF || die
-			include-system-site-packages = true
-		EOF
-
-		# we only do the minimal necessary subset of activate script
-		PATH=${TEST_DIR}/bin:${PATH}
-		# unset PYTHONPATH in order to prevent BUILD_DIR from overriding
-		# venv packages
-		unset PYTHONPATH
-
-		# force root-style install (note: venv adds TEST_DIR to prefixes,
-		# so we need to pass --root=/)
-		add_args=(
-			--root=/
-		)
-	else
-		local bindir=${TEST_DIR}/scripts
-		local libdir=${TEST_DIR}/lib
-		PATH=${bindir}:${PATH}
-		PYTHONPATH=${libdir}:${PYTHONPATH}
-
-		case ${install_method} in
-			home)
-				add_args=(
-					--home="${TEST_DIR}"
-					--install-lib="${libdir}"
-					--install-scripts="${bindir}"
-				)
-				mkdir -p "${libdir}" || die
-				;;
-			root)
-				add_args=(
-					--root="${TEST_DIR}"
-					--install-lib=lib
-					--install-scripts=scripts
-				)
-				;;
-		esac
-	fi
-
-	esetup.py install "${add_args[@]}" "${@}"
+	die "${FUNCNAME} has been removed, please use PEP517 mode instead"
 }
 
 # @FUNCTION: distutils_write_namespace
@@ -1859,9 +1748,7 @@ distutils-r1_run_phase() {
 	else
 		local -x PYTHONPATH="${BUILD_DIR}/lib:${PYTHONPATH}"
 
-		# make PATH local for distutils_install_for_testing calls
-		# it makes little sense to let user modify PATH in per-impl phases
-		# and _all() already localizes it
+		# make PATH local (for historical reasons)
 		local -x PATH=${PATH}
 
 		if _python_impl_matches "${EPYTHON}" 3.{9..11}; then
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-06-14 12:26 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-06-14 12:26 UTC (permalink / raw
  To: gentoo-commits
commit:     75da06793abc7dc2dc5fc0faec81fad7c56d9d45
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sun Jun  2 17:59:01 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Fri Jun 14 12:26:07 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=75da0679
distutils-r1.eclass: Remove support for `d_e_t --install`
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/distutils-r1.eclass | 17 ++---------------
 1 file changed, 2 insertions(+), 15 deletions(-)
diff --git a/eclass/distutils-r1.eclass b/eclass/distutils-r1.eclass
index 3d72a5d3d554..f0d9d3a4b937 100644
--- a/eclass/distutils-r1.eclass
+++ b/eclass/distutils-r1.eclass
@@ -566,7 +566,7 @@ distutils_enable_sphinx() {
 }
 
 # @FUNCTION: distutils_enable_tests
-# @USAGE: [--install] <test-runner>
+# @USAGE: <test-runner>
 # @DESCRIPTION:
 # Set up IUSE, RESTRICT, BDEPEND and python_test() for running tests
 # with the specified test runner.  Also copies the current value
@@ -578,10 +578,6 @@ distutils_enable_sphinx() {
 #
 # - unittest: for built-in Python unittest module
 #
-# Additionally, if --install is passed as the first parameter,
-# 'distutils_install_for_testing --via-root' is called before running
-# the test suite.
-#
 # This function is meant as a helper for common use cases, and it only
 # takes care of basic setup.  You still need to list additional test
 # dependencies manually.  If you have uncommon use case, you should
@@ -592,14 +588,9 @@ distutils_enable_sphinx() {
 distutils_enable_tests() {
 	debug-print-function ${FUNCNAME} "${@}"
 
-	_DISTUTILS_TEST_INSTALL=
 	case ${1} in
 		--install)
-			if [[ ${DISTUTILS_USE_PEP517} ]]; then
-				die "${FUNCNAME} --install is not implemented in PEP517 mode"
-			fi
-			_DISTUTILS_TEST_INSTALL=1
-			shift
+			die "${FUNCNAME} --install is no longer supported"
 			;;
 	esac
 
@@ -1679,10 +1670,6 @@ distutils-r1_python_test() {
 
 	_python_check_EPYTHON
 
-	if [[ ${_DISTUTILS_TEST_INSTALL} ]]; then
-		distutils_install_for_testing
-	fi
-
 	case ${_DISTUTILS_TEST_RUNNER} in
 		pytest)
 			epytest
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-06-14 12:26 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-06-14 12:26 UTC (permalink / raw
  To: gentoo-commits
commit:     030257a29d8a9900668ba0b57a21250ab600d232
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Mon Jun  3 01:00:14 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Fri Jun 14 12:26:09 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=030257a2
distutils-r1.eclass: Change "PEP 517" to "PEP517", for consistency
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/distutils-r1.eclass | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/eclass/distutils-r1.eclass b/eclass/distutils-r1.eclass
index afed1fa547d1..61c0a80323ec 100644
--- a/eclass/distutils-r1.eclass
+++ b/eclass/distutils-r1.eclass
@@ -99,7 +99,7 @@ esac
 # @PRE_INHERIT
 # @DEFAULT_UNSET
 # @DESCRIPTION:
-# Enable the PEP 517 mode for the specified build system.  In this mode,
+# Enable the PEP517 mode for the specified build system.  In this mode,
 # the complete build and install is done in python_compile(),
 # a venv-style install tree is provided to python_test(),
 # and python_install() just merges the temporary install tree
@@ -182,7 +182,7 @@ esac
 # This is an eclass-generated build-time dependency string for the build
 # system packages.  This string is automatically appended to BDEPEND
 # unless DISTUTILS_OPTIONAL is used.  This variable is available only
-# in PEP 517 mode.
+# in PEP517 mode.
 #
 # Example use:
 # @CODE
@@ -1221,7 +1221,7 @@ distutils_wheel_install() {
 # @FUNCTION: distutils_pep517_install
 # @USAGE: <root>
 # @DESCRIPTION:
-# Build the wheel for the package in the current directory using PEP 517
+# Build the wheel for the package in the current directory using PEP517
 # backend and install it into <root>.
 #
 # This function is intended for expert use only.  It does not handle
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-06-14 12:26 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-06-14 12:26 UTC (permalink / raw
  To: gentoo-commits
commit:     f5102bba40a66015d03da8f20387c0f9f40d56f9
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Jun  1 09:17:46 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Fri Jun 14 12:26:06 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=f5102bba
distutils-r1.eclass: Doc DISTUTILS_IN_SOURCE_BUILD as deprecated
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/distutils-r1.eclass | 4 ++++
 1 file changed, 4 insertions(+)
diff --git a/eclass/distutils-r1.eclass b/eclass/distutils-r1.eclass
index 392725d48121..2b610a4d2ceb 100644
--- a/eclass/distutils-r1.eclass
+++ b/eclass/distutils-r1.eclass
@@ -371,6 +371,7 @@ unset -f _distutils_set_globals
 
 # @ECLASS_VARIABLE: DISTUTILS_IN_SOURCE_BUILD
 # @DEFAULT_UNSET
+# @DEPRECATED: (none)
 # @DESCRIPTION:
 # If set to a non-null value, in-source builds will be enabled.
 # If unset, the default is to use in-source builds when python_prepare()
@@ -384,6 +385,9 @@ unset -f _distutils_set_globals
 # on the sources directly, prepending setup.py arguments with
 # 'build --build-base ${BUILD_DIR}' to enforce keeping & using built
 # files in the specific root.
+#
+# In-source builds are deprecated and no longer supported in PEP517
+# mode.
 
 # @ECLASS_VARIABLE: DISTUTILS_ALL_SUBPHASE_IMPLS
 # @DEFAULT_UNSET
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-06-14 12:26 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-06-14 12:26 UTC (permalink / raw
  To: gentoo-commits
commit:     4c9973d691bf1842f7a1fcefc90e31872054bc94
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Jun  1 09:22:32 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Fri Jun 14 12:26:06 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=4c9973d6
distutils-r1.eclass: Document BUILD_DIR for consistency
Closes: https://bugs.gentoo.org/910661
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/distutils-r1.eclass | 16 ++++++++++++++++
 1 file changed, 16 insertions(+)
diff --git a/eclass/distutils-r1.eclass b/eclass/distutils-r1.eclass
index 2b610a4d2ceb..3d72a5d3d554 100644
--- a/eclass/distutils-r1.eclass
+++ b/eclass/distutils-r1.eclass
@@ -206,6 +206,22 @@ esac
 # the build system in pure Python packages and packages using the stable
 # Python ABI.
 
+# @ECLASS_VARIABLE: BUILD_DIR
+# @OUTPUT_VARIABLE
+# @DEFAULT_UNSET
+# @DESCRIPTION:
+# The current build directory. In global scope, it is supposed to
+# contain an initial build directory; if unset, it defaults to ${S}.
+#
+# When running in multi-impl mode, the BUILD_DIR variable is set
+# by python-r1.eclass.  Otherwise, it is set by distutils-r1.eclass
+# for consistency.
+#
+# Example value:
+# @CODE
+# ${WORKDIR}/foo-1.3-python3_12
+# @CODE
+
 if [[ -z ${_DISTUTILS_R1_ECLASS} ]]; then
 _DISTUTILS_R1_ECLASS=1
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-06-15  7:58 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-06-15  7:58 UTC (permalink / raw
  To: gentoo-commits
commit:     e65892a87435c5b0dddbe7b02532eeb5ae806e46
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Jun 15 07:57:41 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jun 15 07:57:41 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=e65892a8
toolchain.eclass: fix applying musl patches for live ebuilds
toolchain_fetch_git_patches had a typo for the case where we may
want to try use downloaded SRC_URI (rather than git) patches, so it
never applied them for live ebuilds.
Reported by awilfox.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 7d69f3b90e91..bc61a8bddb2c 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -589,7 +589,7 @@ toolchain_fetch_git_patches() {
 	mkdir "${WORKDIR}"/patch || die
 	mv "${WORKDIR}"/patch.tmp/${PATCH_GCC_VER}/gentoo/* "${WORKDIR}"/patch || die
 
-	if [[ -n ${MUSL_VER} || -d "${WORKDIR}"/musl ]] && [[ ${CTARGET} == *musl* ]] ; then
+	if [[ -z ${MUSL_VER} || -d "${WORKDIR}"/musl ]] && [[ ${CTARGET} == *musl* ]] ; then
 		mkdir "${WORKDIR}"/musl || die
 		mv "${WORKDIR}"/patch.tmp/${PATCH_GCC_VER}/musl/* "${WORKDIR}"/musl || die
 	fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-06-15 11:01 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-06-15 11:01 UTC (permalink / raw
  To: gentoo-commits
commit:     9024dd273dbeca9f7f36b60fa48bc5ccf7c1f08c
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Jun 15 10:17:47 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat Jun 15 11:01:25 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=9024dd27
llvm.org.eclass: Remove support for old snapshots
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 6 ------
 1 file changed, 6 deletions(-)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index a362c3bb60b1..914a731a1768 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -78,12 +78,6 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 				19.0.0_pre20240608)
 					EGIT_COMMIT=5aabbf0602c48b67bb89fd37f95bf97c95ded488
 					;;
-				19.0.0_pre20240525)
-					EGIT_COMMIT=7dc2f6602212bf0a0433c157b70e4fc0d70bb730
-					;;
-				19.0.0_pre20240518)
-					EGIT_COMMIT=702198fc9ac5dba392f9d9ba7c56467996343c0a
-					;;
 				*)
 					die "Unknown snapshot: ${PV}"
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-06-17  0:53 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-06-17  0:53 UTC (permalink / raw
  To: gentoo-commits
commit:     8ac18e94add62abf445280e5b3ddf9a20e5e17a7
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Jun 17 00:53:32 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Jun 17 00:53:32 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=8ac18e94
cargo.eclass: mention app-portage/pycargoebuild in @CRATES docs
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/cargo.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/cargo.eclass b/eclass/cargo.eclass
index 40d98211ce7f..548aaef3ed69 100644
--- a/eclass/cargo.eclass
+++ b/eclass/cargo.eclass
@@ -48,7 +48,7 @@ ECARGO_VENDOR="${ECARGO_HOME}/gentoo"
 # @PRE_INHERIT
 # @DESCRIPTION:
 # Bash string containing all crates that are to be downloaded.
-# It is used by cargo_crate_uris.
+# It is used by cargo_crate_uris. Typically generated by app-portage/pycargoebuild.
 #
 # Ideally, crate names and versions should be separated by a `@`
 # character.  A legacy syntax using hyphen is also supported but it is
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-06-17  9:39 James Le Cuirot
  0 siblings, 0 replies; 6663+ messages in thread
From: James Le Cuirot @ 2024-06-17  9:39 UTC (permalink / raw
  To: gentoo-commits
commit:     73aef61ba818739034dd5cc939a315213bc77741
Author:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
AuthorDate: Sat Jun 15 13:59:15 2024 +0000
Commit:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
CommitDate: Mon Jun 17 09:27:23 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=73aef61b
cargo.eclass: Add cargo_target_dir helper function
Several Cargo-based ebuilds cannot use cargo_src_install for various
reasons and manually install binaries from within the target directory
instead. It is common to see `target/$(usex debug debug release)`, but
this lacks the target ABI when cross-compiling, so provide a helper
function.
There are some multilib Cargo-based ebuilds that always set the target
ABI, even when not cross-compiling. It would be simpler to do this in
general, so once ebuilds have been updated to use this new helper, I
might change the eclass again accordingly.
Signed-off-by: James Le Cuirot <chewi <AT> gentoo.org>
 eclass/cargo.eclass | 10 ++++++++++
 1 file changed, 10 insertions(+)
diff --git a/eclass/cargo.eclass b/eclass/cargo.eclass
index 548aaef3ed69..7db34efb4e17 100644
--- a/eclass/cargo.eclass
+++ b/eclass/cargo.eclass
@@ -319,6 +319,16 @@ _cargo_gen_git_config() {
 	fi
 }
 
+# @FUNCTION: cargo_target_dir
+# @DESCRIPTION:
+# Return the directory within target that contains the build, e.g.
+# target/aarch64-unknown-linux-gnu/release.
+cargo_target_dir() {
+	local abi
+	tc-is-cross-compiler && abi=/$(rust_abi)
+	echo "${CARGO_TARGET_DIR:-target}${abi}/$(usex debug debug release)"
+}
+
 # @FUNCTION: cargo_src_unpack
 # @DESCRIPTION:
 # Unpacks the package and the cargo registry.
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-06-17 17:13 Andreas Sturmlechner
  0 siblings, 0 replies; 6663+ messages in thread
From: Andreas Sturmlechner @ 2024-06-17 17:13 UTC (permalink / raw
  To: gentoo-commits
commit:     d8ebc6b4f46647853745e0be779a6bcc1f50f95b
Author:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
AuthorDate: Mon Jun 17 15:59:38 2024 +0000
Commit:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
CommitDate: Mon Jun 17 17:06:30 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=d8ebc6b4
ecm.eclass: Fix _ecm_check_gcc_version
Signed-off-by: Andreas Sturmlechner <asturm <AT> gentoo.org>
 eclass/ecm.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/ecm.eclass b/eclass/ecm.eclass
index 518f913815be..3d3b9328269d 100644
--- a/eclass/ecm.eclass
+++ b/eclass/ecm.eclass
@@ -307,7 +307,7 @@ unset COMMONDEPEND
 # @DESCRIPTION:
 # Determine if the current GCC version is acceptable, otherwise die.
 _ecm_check_gcc_version() {
-	if [[ ${MERGE_TYPE} != binary && -v ${KDE_GCC_MINIMAL} ]] && tc-is-gcc; then
+	if [[ ${MERGE_TYPE} != binary && -v KDE_GCC_MINIMAL ]] && tc-is-gcc; then
 
 		local version=$(gcc-version)
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-06-19  3:16 Andreas K. Hüttel
  0 siblings, 0 replies; 6663+ messages in thread
From: Andreas K. Hüttel @ 2024-06-19  3:16 UTC (permalink / raw
  To: gentoo-commits
commit:     a7f997b3232b4bb1869dd2d3d97c5bfc89cf47de
Author:     Andreas K. Hüttel <dilfridge <AT> gentoo <DOT> org>
AuthorDate: Wed Jun 19 03:15:28 2024 +0000
Commit:     Andreas K. Hüttel <dilfridge <AT> gentoo <DOT> org>
CommitDate: Wed Jun 19 03:16:08 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=a7f997b3
perl-module.eclass: drop support for perl versions without PERL_FEATURES
Signed-off-by: Andreas K. Hüttel <dilfridge <AT> gentoo.org>
 eclass/perl-module.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/perl-module.eclass b/eclass/perl-module.eclass
index 432d1ab315dd..27cd053f0ea7 100644
--- a/eclass/perl-module.eclass
+++ b/eclass/perl-module.eclass
@@ -63,7 +63,7 @@ esac
 # @CODE
 PERL_USEDEP="perl_features_debug=,perl_features_ithreads=,perl_features_quadmath="
 
-GENTOO_PERL_DEPSTRING=" || ( >=dev-lang/perl-5.38.2-r3[${PERL_USEDEP}] <dev-lang/perl-5.38.2-r3 )"
+GENTOO_PERL_DEPSTRING=">=dev-lang/perl-5.38.2-r3[${PERL_USEDEP}]"
 GENTOO_PERL_USESTRING="perl_features_debug perl_features_ithreads perl_features_quadmath"
 
 case ${EAPI} in
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-06-20  7:29 Florian Schmaus
  0 siblings, 0 replies; 6663+ messages in thread
From: Florian Schmaus @ 2024-06-20  7:29 UTC (permalink / raw
  To: gentoo-commits
commit:     15fbf774e0357c750bd1934592370223c595b6bd
Author:     Florian Schmaus <flow <AT> gentoo <DOT> org>
AuthorDate: Wed Jun 19 12:11:51 2024 +0000
Commit:     Florian Schmaus <flow <AT> gentoo <DOT> org>
CommitDate: Thu Jun 20 07:29:48 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=15fbf774
readme.gentoo-r1.eclass: fix description of DISABLE_AUTOFORMATTING by s/fmt/fold/
The autoformatting tool was switched from fmt to fold in
3f9cdecb18c6 ("Change formatting tool as discussed with Ulrich Müller in
bug #460050, thanks a lot to him for his help.") but the description of
the DISABLE_AUTOFORMATTING variable still talks about fmt being used.
See also https://bugs.gentoo.org/460050#c7
Signed-off-by: Florian Schmaus <flow <AT> gentoo.org>
 eclass/readme.gentoo-r1.eclass | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/eclass/readme.gentoo-r1.eclass b/eclass/readme.gentoo-r1.eclass
index 202ba31f4f70..35c3d3748550 100644
--- a/eclass/readme.gentoo-r1.eclass
+++ b/eclass/readme.gentoo-r1.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2023 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: readme.gentoo-r1.eclass
@@ -34,8 +34,8 @@ esac
 # @DEFAULT_UNSET
 # @DESCRIPTION:
 # If non-empty, DOC_CONTENTS information will be strictly respected,
-# not getting it automatically formatted by fmt. If empty, it will
-# rely on fmt for formatting and 'echo -e' options to tweak lines a bit.
+# not getting it automatically formatted by fold. If empty, it will
+# rely on fold for formatting and 'echo -e' options to tweak lines a bit.
 
 # @ECLASS_VARIABLE: FORCE_PRINT_ELOG
 # @DEFAULT_UNSET
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-06-20  7:29 Florian Schmaus
  0 siblings, 0 replies; 6663+ messages in thread
From: Florian Schmaus @ 2024-06-20  7:29 UTC (permalink / raw
  To: gentoo-commits
commit:     5f5fe1e48984b8d2dc0202ac734a4feb49b46568
Author:     Florian Schmaus <flow <AT> gentoo <DOT> org>
AuthorDate: Thu Jun 20 07:29:36 2024 +0000
Commit:     Florian Schmaus <flow <AT> gentoo <DOT> org>
CommitDate: Thu Jun 20 07:29:49 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=5f5fe1e4
readme.gentoo-r1.eclass: use two spaces after full stop
Signed-off-by: Florian Schmaus <flow <AT> gentoo.org>
 eclass/readme.gentoo-r1.eclass | 8 ++++----
 1 file changed, 4 insertions(+), 4 deletions(-)
diff --git a/eclass/readme.gentoo-r1.eclass b/eclass/readme.gentoo-r1.eclass
index 35c3d3748550..48023d9c049f 100644
--- a/eclass/readme.gentoo-r1.eclass
+++ b/eclass/readme.gentoo-r1.eclass
@@ -10,7 +10,7 @@
 # @BLURB: install a doc file shown via elog messages
 # @DESCRIPTION:
 # An eclass for installing a README.gentoo doc file recording tips
-# shown via elog messages. With this eclass, those elog messages will only be
+# shown via elog messages.  With this eclass, those elog messages will only be
 # shown at first package installation and a file for later reviewing will be
 # installed under /usr/share/doc/${PF}
 #
@@ -34,7 +34,7 @@ esac
 # @DEFAULT_UNSET
 # @DESCRIPTION:
 # If non-empty, DOC_CONTENTS information will be strictly respected,
-# not getting it automatically formatted by fold. If empty, it will
+# not getting it automatically formatted by fold.  If empty, it will
 # rely on fold for formatting and 'echo -e' options to tweak lines a bit.
 
 # @ECLASS_VARIABLE: FORCE_PRINT_ELOG
@@ -50,7 +50,7 @@ esac
 # @FUNCTION: readme.gentoo_create_doc
 # @DESCRIPTION:
 # Create doc file with ${DOC_CONTENTS} variable (preferred) and, if not set,
-# look for "${FILESDIR}/README.gentoo" contents. You can use
+# look for "${FILESDIR}/README.gentoo" contents.  You can use
 # ${FILESDIR}/README.gentoo-${SLOT} also.
 # Usually called at src_install phase.
 readme.gentoo_create_doc() {
@@ -84,7 +84,7 @@ readme.gentoo_create_doc() {
 
 # @FUNCTION: readme.gentoo_print_elog
 # @DESCRIPTION:
-# Print elog messages with "${T}"/README.gentoo contents. They will be
+# Print elog messages with "${T}"/README.gentoo contents.  They will be
 # shown only when package is installed at first time.
 # Usually called at pkg_postinst phase.
 #
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-06-20  9:57 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-06-20  9:57 UTC (permalink / raw
  To: gentoo-commits
commit:     dd5030fa0ad06728735f266e00a3e6258db46a83
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Jun 20 09:55:20 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Jun 20 09:57:18 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=dd5030fa
toolchain.eclass: fix SRC_URI for releases
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index bc61a8bddb2c..c7c366a37ad0 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -526,7 +526,7 @@ get_gcc_src_uri() {
 		GCC_SRC_URI="mirror://gcc/snapshots/${SNAPSHOT}/gcc-${SNAPSHOT}.tar.xz"
 	else
 		GCC_SRC_URI="
-			mirror://gcc/gcc-${GCC_PV}/gcc-${GCC_RELEASE_VER}.tar.xz
+			mirror://gcc/releases/gcc-${GCC_PV}/gcc-${GCC_RELEASE_VER}.tar.xz
 			mirror://gnu/gcc/gcc-${GCC_PV}/gcc-${GCC_RELEASE_VER}.tar.xz
 		"
 	fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-06-23  1:00 Ionen Wolkens
  0 siblings, 0 replies; 6663+ messages in thread
From: Ionen Wolkens @ 2024-06-23  1:00 UTC (permalink / raw
  To: gentoo-commits
commit:     ab3a604aa77a4c2a0d54fd146c5b7b0ca53f1b38
Author:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
AuthorDate: Sun Jun 23 00:47:18 2024 +0000
Commit:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
CommitDate: Sun Jun 23 01:00:02 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=ab3a604a
qt6-build.eclass: handle extra -mno-* for qtwebengine
Had forgotten chromium needed extras, so went to look at
chromium's ebuild to see which ones were getting stripped
that we aren't already handling.
Signed-off-by: Ionen Wolkens <ionen <AT> gentoo.org>
 eclass/qt6-build.eclass | 11 +++++++++++
 1 file changed, 11 insertions(+)
diff --git a/eclass/qt6-build.eclass b/eclass/qt6-build.eclass
index 4966c52adc4c..24b857dab53f 100644
--- a/eclass/qt6-build.eclass
+++ b/eclass/qt6-build.eclass
@@ -282,6 +282,17 @@ _qt6-build_sanitize_cpu_flags() {
 		bmi bmi2 f16c fma lzcnt popcnt
 	)
 
+	# extras only needed by chromium in qtwebengine
+	# (see also chromium's ebuild wrt bug #530248,#544702,#546984,#853646)
+	[[ ${PN} == qtwebengine ]] && cpuflags+=(
+		mmx xop
+
+		# unclear if these two are really needed given (current) chromium
+		# does not pass these flags, albeit it may side-disable something
+		# else so keeping as a safety (like chromium's ebuild does)
+		fma4 sse4a
+	)
+
 	# check if any known problematic -mno-* C(XX)FLAGS
 	if ! is-flagq "@($(IFS='|'; echo "${cpuflags[*]/#/-mno-}"))"; then
 		# check if qsimd_p.h (search for "enable all") will accept -march
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-06-23 17:33 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-06-23 17:33 UTC (permalink / raw
  To: gentoo-commits
commit:     5bdad9cd272ce0180c6afecf52637e241b1c6f9e
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sun Jun 23 16:26:20 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sun Jun 23 17:32:37 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=5bdad9cd
llvm.org.eclass: Add 19.0.0_pre20240623 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index 914a731a1768..af5ee26b652e 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -72,6 +72,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 			_LLVM_SOURCE_TYPE=snapshot
 
 			case ${PV} in
+				19.0.0_pre20240623)
+					EGIT_COMMIT=3ae6755719c6dfc07761b4e9bdac8c86bcb41734
+					;;
 				19.0.0_pre20240615)
 					EGIT_COMMIT=cddb9ce04e68d876de895d39d60b6af34d569012
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-06-24 11:58 Ulrich Müller
  0 siblings, 0 replies; 6663+ messages in thread
From: Ulrich Müller @ 2024-06-24 11:58 UTC (permalink / raw
  To: gentoo-commits
commit:     6933e6224a51125ef893b2e1c7e56b046373f7e6
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Sun Jun 23 10:02:08 2024 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Mon Jun 24 11:56:47 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=6933e622
common-lisp-3.eclass: Drop support for EAPI 6
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 eclass/common-lisp-3.eclass | 8 ++++----
 1 file changed, 4 insertions(+), 4 deletions(-)
diff --git a/eclass/common-lisp-3.eclass b/eclass/common-lisp-3.eclass
index 99825190f32e..cc906d0d5cca 100644
--- a/eclass/common-lisp-3.eclass
+++ b/eclass/common-lisp-3.eclass
@@ -4,14 +4,14 @@
 # @ECLASS: common-lisp-3.eclass
 # @MAINTAINER:
 # Common Lisp project <common-lisp@gentoo.org>
-# @SUPPORTED_EAPIS: 6 7 8
+# @SUPPORTED_EAPIS: 7 8
 # @BLURB: functions to support the installation of Common Lisp libraries
 # @DESCRIPTION:
 # Since Common Lisp libraries share similar structure, this eclass aims
 # to provide a simple way to write ebuilds with these characteristics.
 
 case ${EAPI} in
-	6|7|8) ;;
+	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
@@ -27,14 +27,14 @@ CLIMPLEMENTATIONS="sbcl clisp clozurecl cmucl ecl gcl abcl"
 # @DESCRIPTION:
 # Default path of Common Lisp libraries sources. Sources will
 # be installed into ${CLSOURCEROOT}/${CLPACKAGE}.
-CLSOURCEROOT="${ROOT%/}"/usr/share/common-lisp/source
+CLSOURCEROOT="${ROOT}"/usr/share/common-lisp/source
 
 # @ECLASS_VARIABLE: CLSYSTEMROOT
 # @DESCRIPTION:
 # Default path to find any asdf file. Any asdf files will be
 # symlinked in ${CLSYSTEMROOT}/${CLSYSTEM} as they may be in
 # an arbitrarily deeply nested directory under ${CLSOURCEROOT}/${CLPACKAGE}.
-CLSYSTEMROOT="${ROOT%/}"/usr/share/common-lisp/systems
+CLSYSTEMROOT="${ROOT}"/usr/share/common-lisp/systems
 
 # @ECLASS_VARIABLE: CLPACKAGE
 # @DESCRIPTION:
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-06-26  6:24 Florian Schmaus
  0 siblings, 0 replies; 6663+ messages in thread
From: Florian Schmaus @ 2024-06-26  6:24 UTC (permalink / raw
  To: gentoo-commits
commit:     67ffceb423d8517ad2911d289ec6e999862bd570
Author:     Florian Schmaus <flow <AT> gentoo <DOT> org>
AuthorDate: Tue Jun 25 09:08:47 2024 +0000
Commit:     Florian Schmaus <flow <AT> gentoo <DOT> org>
CommitDate: Wed Jun 26 06:23:12 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=67ffceb4
java-utils-2.eclass: add --runtime-only argument to java-pkg_getjars
Some packages only need the jar at runtime, not at compile time. For
example https://bugs.gentoo.org/934659#c2
Bug: https://bugs.gentoo.org/934659
Signed-off-by: Florian Schmaus <flow <AT> gentoo.org>
 eclass/java-utils-2.eclass | 10 +++++++---
 1 file changed, 7 insertions(+), 3 deletions(-)
diff --git a/eclass/java-utils-2.eclass b/eclass/java-utils-2.eclass
index adbc5242053a..3c2d190c4c15 100644
--- a/eclass/java-utils-2.eclass
+++ b/eclass/java-utils-2.eclass
@@ -1137,7 +1137,7 @@ java-pkg_jarfrom() {
 }
 
 # @FUNCTION: java-pkg_getjars
-# @USAGE: [--build-only] [--with-dependencies] <package1>[,<package2>...]
+# @USAGE: [--build-only] [--runtime-only] [--with-dependencies] <package1>[,<package2>...]
 # @DESCRIPTION:
 # Get the classpath provided by any number of packages
 # Among other things, this can be passed to 'javac -classpath' or 'ant -lib'.
@@ -1157,6 +1157,7 @@ java-pkg_jarfrom() {
 # Parameters:
 #	--build-only - makes the jar(s) not added into package.env DEPEND line.
 #	  (assumed automatically when called inside src_test)
+#	--runtime-only - marks the jar(s) not added into package.env RDEPEND line.
 #	--with-dependencies - get jars also from requested package's dependencies
 #	  transitively.
 # $1 - list of packages to get jars from
@@ -1165,6 +1166,7 @@ java-pkg_jarfrom() {
 java-pkg_getjars() {
 	debug-print-function ${FUNCNAME} $*
 
+	local dep_constraint
 	local build_only=""
 	local deep=""
 
@@ -1173,6 +1175,9 @@ java-pkg_getjars() {
 	while [[ "${1}" == --* ]]; do
 		if [[ "${1}" = "--build-only" ]]; then
 			build_only="build"
+			dep_constraint="build"
+		elif [[ "${1}" = "--runtime-only" ]]; then
+			dep_constraint="runtime"
 		elif [[ "${1}" = "--with-dependencies" ]]; then
 			deep="--with-dependencies"
 		else
@@ -1191,7 +1196,7 @@ java-pkg_getjars() {
 	debug-print "${pkgs}:${jars}"
 
 	for pkg in ${pkgs//,/ }; do
-		java-pkg_ensure-dep "${build_only}" "${pkg}"
+		java-pkg_ensure-dep "${dep_constraint}" "${pkg}"
 	done
 
 	for pkg in ${pkgs//,/ }; do
@@ -1808,7 +1813,6 @@ java-pkg_ant-tasks-depend() {
 	fi
 }
 
-
 # @FUNCTION: ejunit_
 # @INTERNAL
 # @DESCRIPTION:
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-06-27  7:33 Andrew Ammerlaan
  0 siblings, 0 replies; 6663+ messages in thread
From: Andrew Ammerlaan @ 2024-06-27  7:33 UTC (permalink / raw
  To: gentoo-commits
commit:     e47272c80b226d5c678158ed4bf0d03085367c80
Author:     Andrew Ammerlaan <andrewammerlaan <AT> gentoo <DOT> org>
AuthorDate: Mon Jun 24 20:18:46 2024 +0000
Commit:     Andrew Ammerlaan <andrewammerlaan <AT> gentoo <DOT> org>
CommitDate: Thu Jun 27 07:31:46 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=e47272c8
kernel-build.eclass: identify dist-kernels, and warn users
Many, many, new users at some point make the mistake of running "make ...."
in the source directory of a distribution kernel.
This returns a vague error due to the absence of the kernel source files:
make[2]: *** No rule to make target 'arch/x86/entry/syscalls/syscall_32.tbl', needed by 'arch/x86/include/generated/uapi/asm/unistd_32.h'.  Stop.
make[1]: *** [arch/x86/Makefile:248: archheaders] Error 2
make: *** [Makefile:234: __sub-make] Error 2
Here we append to the kernel Makefile a warning that should make it more clear
what is going wrong. "$(shell [ -t 0 ] && echo 1)" is a trick to show this
warning when an user is executing "make" from their shell, but not when they are
compiling out-of-tree kernel modules (which is the reason we need to install
these makefiles to begin with).
We also add a "dist-kernel" file containing the package atom of the ebuild that
installed this kernel. This makes it possible for ebuilds/eclasses or whatever
other tools to check if a kernel is a Gentoo distribution kernel. This
identifier will be overwritten in gentoo-kernel-bin.ebuild.
Signed-off-by: Andrew Ammerlaan <andrewammerlaan <AT> gentoo.org>
 eclass/kernel-build.eclass | 16 ++++++++++++++++
 1 file changed, 16 insertions(+)
diff --git a/eclass/kernel-build.eclass b/eclass/kernel-build.eclass
index 7922638be6e1..86c7cd4a172d 100644
--- a/eclass/kernel-build.eclass
+++ b/eclass/kernel-build.eclass
@@ -382,6 +382,22 @@ kernel-build_src_install() {
 	local module_ver
 	module_ver=$(<"${relfile}") || die
 
+	# warn when trying to "make" a dist-kernel
+	cat <<-EOF >> "${ED}${kernel_dir}/Makefile" || die
+
+		_GENTOO_IS_USER_SHELL:=\$(shell [ -t 0 ] && echo 1)
+		ifdef _GENTOO_IS_USER_SHELL
+		\$(warning !!!! WARNING !!!!)
+		\$(warning This kernel was configured and installed by the package manager.)
+		\$(warning "make" should not be run manually here.)
+		\$(warning See also: https://wiki.gentoo.org/wiki/Project:Distribution_Kernel)
+		\$(warning See also: https://wiki.gentoo.org/wiki/Kernel/Configuration)
+		\$(warning !!!! WARNING !!!!)
+		endif
+	EOF
+	# add a dist-kernel identifier file
+	echo "${CATEGORY}/${PF}:${SLOT}" > "${ED}${kernel_dir}/dist-kernel" || die
+
 	# fix source tree and build dir symlinks
 	dosym "../../../${kernel_dir}" "/lib/modules/${module_ver}/build"
 	dosym "../../../${kernel_dir}" "/lib/modules/${module_ver}/source"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-06-28  8:23 Miroslav Šulc
  0 siblings, 0 replies; 6663+ messages in thread
From: Miroslav Šulc @ 2024-06-28  8:23 UTC (permalink / raw
  To: gentoo-commits
commit:     f1fce6210d9d4104738e3fa35214b477486be534
Author:     Volkmar W. Pogatzki <gentoo <AT> pogatzki <DOT> net>
AuthorDate: Wed Jun  5 16:20:04 2024 +0000
Commit:     Miroslav Šulc <fordfrog <AT> gentoo <DOT> org>
CommitDate: Fri Jun 28 08:23:47 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=f1fce621
java-utils-2.eclass: allow eant without java-ant-2_src_configure
Packages which can build without BSFIX need not inherit java-ant-2.  To
allow using eant without inheriting java-ant-2 we enhance the eant function
with a condition which controls calling java-ant-2_src_configure.
Signed-off-by: Volkmar W. Pogatzki <gentoo <AT> pogatzki.net>
Closes: https://github.com/gentoo/gentoo/pull/37022/commits/6ebf29fc691b6e38c8bf263eec2313d611298d25
Signed-off-by: Miroslav Šulc <fordfrog <AT> gentoo.org>
 eclass/java-utils-2.eclass | 22 ++++++++++++++++------
 1 file changed, 16 insertions(+), 6 deletions(-)
diff --git a/eclass/java-utils-2.eclass b/eclass/java-utils-2.eclass
index 3c2d190c4c15..91f8fba8790b 100644
--- a/eclass/java-utils-2.eclass
+++ b/eclass/java-utils-2.eclass
@@ -2033,13 +2033,23 @@ java-utils-2_pkg_preinst() {
 eant() {
 	debug-print-function ${FUNCNAME} $*
 
-	if [[ ${EBUILD_PHASE} = compile ]]; then
-		java-ant-2_src_configure
-	fi
+	if [[ ${!JAVA_PKG_BSFIX*} ]] \
+		|| [[ ${JAVA_ANT_BSFIX_EXTRA_ARGS} ]] \
+		|| [[ ${JAVA_ANT_CLASSPATH_TAGS} ]] \
+		|| [[ ${JAVA_ANT_JAVADOC_INPUT_DIRS} ]] \
+		|| [[ ${JAVA_ANT_REWRITE_CLASSPATH} ]] \
+		|| [[ ${EANT_BUILD_XML} ]] \
+		|| [[ ${!EANT_GENTOO_CLASSPATH*} ]] \
+		|| [[ ${EANT_TEST_GENTOO_CLASSPATH} ]]
+	then
+		if [[ ${EBUILD_PHASE} = compile ]]; then
+			java-ant-2_src_configure
+		fi
 
-	if ! has java-ant-2 ${INHERITED}; then
-		local msg="You should inherit java-ant-2 when using eant"
-		java-pkg_announce-qa-violation "${msg}"
+		if ! has java-ant-2 ${INHERITED}; then
+			local msg="You should inherit java-ant-2 when using eant"
+			java-pkg_announce-qa-violation "${msg}"
+		fi
 	fi
 
 	local antflags="-Dnoget=true -Dmaven.mode.offline=true -Dbuild.sysclasspath=ignore"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-06-29  8:39 Andrew Ammerlaan
  0 siblings, 0 replies; 6663+ messages in thread
From: Andrew Ammerlaan @ 2024-06-29  8:39 UTC (permalink / raw
  To: gentoo-commits
commit:     e598ba3fe1f5b51c0f0e64cacd950d600b289852
Author:     Andrew Ammerlaan <andrewammerlaan <AT> gentoo <DOT> org>
AuthorDate: Tue Jun 25 13:08:49 2024 +0000
Commit:     Andrew Ammerlaan <andrewammerlaan <AT> gentoo <DOT> org>
CommitDate: Sat Jun 29 08:36:16 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=e598ba3f
mount-boot.eclass: check for ESP as well as /boot, split eclass
This eclass is used by when the dist-kernel has to re-installed.
Depending on the configuration of sys-kernel/installkernel, the files may be
installed to /boot or to the EFI System partition. Therefore, extend this eclass
to check if the ESP is mounted read-write as well on UEFI platforms.
Split off the main functions into a separate "inherit-safe" eclass so we can
safely use it in dist-kernel-utils.eclass and linux-mod-r1.eclass.
In the process we drop support for EAPI 6, since there are no EAPI 6 consumers
left in ::gentoo.
Signed-off-by: Andrew Ammerlaan <andrewammerlaan <AT> gentoo.org>
 eclass/mount-boot-utils.eclass | 109 +++++++++++++++++++++++++++++++++++++++++
 eclass/mount-boot.eclass       |  85 +++++---------------------------
 2 files changed, 120 insertions(+), 74 deletions(-)
diff --git a/eclass/mount-boot-utils.eclass b/eclass/mount-boot-utils.eclass
new file mode 100644
index 000000000000..39f8e94b84ec
--- /dev/null
+++ b/eclass/mount-boot-utils.eclass
@@ -0,0 +1,109 @@
+# Copyright 1999-2024 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+# @ECLASS: mount-boot-utils.eclass
+# @MAINTAINER:
+# base-system@gentoo.org
+# @SUPPORTED_EAPIS: 6 7 8
+# @BLURB: functions for packages that install files into /boot or the ESP
+# @DESCRIPTION:
+# This eclass is really only useful for bootloaders and kernel installation.
+#
+# If the live system has a separate /boot partition or ESP configured, then this
+# function tries to ensure that it's mounted in rw mode, exiting with an error
+# if it can't.  It does nothing if /boot and ESP isn't a separate partition.
+#
+# This eclass provides the functions used by mount-boot.eclass in an "inherit-
+# safe" way. This allows these functions to be used in other eclasses cleanly.
+
+case ${EAPI} in
+	7|8) ;;
+	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
+esac
+
+# @FUNCTION: mount-boot_is_disabled
+# @INTERNAL
+# @DESCRIPTION:
+# Detect whether the current environment/build settings are such that we do not
+# want to mess with any mounts.
+mount-boot_is_disabled() {
+	# Since this eclass only deals with /boot, skip things when EROOT is active.
+	if [[ -n ${EROOT} ]]; then
+		return 0
+	fi
+
+	# If we're only building a package, then there's no need to check things.
+	if [[ ${MERGE_TYPE} == buildonly ]]; then
+		return 0
+	fi
+
+	# The user wants us to leave things be.
+	if [[ -n ${DONT_MOUNT_BOOT} ]]; then
+		return 0
+	fi
+
+	# OK, we want to handle things ourselves.
+	return 1
+}
+
+# @FUNCTION: mount-boot_check_status
+# @INTERNAL
+# @DESCRIPTION:
+# Check if /boot and ESP is sane, i.e., mounted as read-write if on a separate
+# partition.  Die if conditions are not fulfilled.  If nonfatal is used,
+# the function will return a non-zero status instead.
+mount-boot_check_status() {
+	# Get out fast if possible.
+	mount-boot_is_disabled && return 0
+
+	local partition=
+	local part_is_not_mounted=
+	local part_is_read_only=
+	local candidates=( /boot )
+
+	# If system is booted with UEFI, check for ESP as well
+	if [[ -d /sys/firmware/efi ]]; then
+		# Use same candidates for ESP as installkernel and eclean-kernel
+		candidates+=( /efi /boot/efi /boot/EFI )
+	fi
+
+	for partition in ${candidates[@]}; do
+		# note that /dev/BOOT is in the Gentoo default /etc/fstab file
+		local fstabstate=$(awk "!/^[[:blank:]]*#|^\/dev\/BOOT/ && \$2 == \"${partition}\" \
+			{ print 1; exit }" /etc/fstab || die "awk failed")
+
+		if [[ -z ${fstabstate} ]]; then
+			einfo "Assuming you do not have a separate ${partition} partition."
+		else
+			local procstate=$(awk "\$2 == \"${partition}\" { split(\$4, a, \",\"); \
+				for (i in a) if (a[i] ~ /^r[ow]\$/) { print a[i]; break }; exit }" \
+				/proc/mounts || die "awk failed")
+
+			if [[ -z ${procstate} ]]; then
+				eerror "Your ${partition} partition is not mounted"
+				eerror "Please mount it and retry."
+				die -n "${partition} not mounted"
+				part_is_not_mounted=1
+			else
+				if [[ ${procstate} == ro ]]; then
+					eerror "Your ${partition} partition, was detected as being mounted," \
+						"but is mounted read-only."
+					eerror "Please remount it as read-write and retry."
+					die -n "${partition} mounted read-only"
+					part_is_read_only=1
+				else
+					einfo "Your ${partition} partition was detected as being mounted."
+					einfo "Files will be installed there for ${PN} to function correctly."
+				fi
+			fi
+		fi
+	done
+
+	if [[ -n ${part_is_not_mounted} ]]; then
+		return 1
+	elif [[ -n ${part_is_read_only} ]]; then
+		return 2
+	else
+		return 0
+	fi
+}
diff --git a/eclass/mount-boot.eclass b/eclass/mount-boot.eclass
index 73beb9adea67..ab02b39d6141 100644
--- a/eclass/mount-boot.eclass
+++ b/eclass/mount-boot.eclass
@@ -1,90 +1,27 @@
-# Copyright 1999-2023 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: mount-boot.eclass
 # @MAINTAINER:
 # base-system@gentoo.org
 # @SUPPORTED_EAPIS: 6 7 8
-# @BLURB: functions for packages that install files into /boot
+# @BLURB: eclass for packages that install files into /boot or the ESP
 # @DESCRIPTION:
-# This eclass is really only useful for bootloaders.
+# This eclass is really only useful for bootloaders and kernel installation.
 #
-# If the live system has a separate /boot partition configured, then this
-# function tries to ensure that it's mounted in rw mode, exiting with an
-# error if it can't.  It does nothing if /boot isn't a separate partition.
+# If the live system has a separate /boot partition or ESP configured, then this
+# function tries to ensure that it's mounted in rw mode, exiting with an error
+# if it can't.  It does nothing if /boot and ESP isn't a separate partition.
+#
+# This eclass exports the functions provided by mount-boot-utils.eclass to
+# the pkg_pretend and pkg_{pre,post}{inst,rm} phases.
 
 case ${EAPI} in
-	6|7|8) ;;
+	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
-# @FUNCTION: mount-boot_is_disabled
-# @INTERNAL
-# @DESCRIPTION:
-# Detect whether the current environment/build settings are such that we do not
-# want to mess with any mounts.
-mount-boot_is_disabled() {
-	# Since this eclass only deals with /boot, skip things when EROOT is active.
-	if [[ ${EROOT:-/} != / ]] ; then
-		return 0
-	fi
-
-	# If we're only building a package, then there's no need to check things.
-	if [[ ${MERGE_TYPE} == buildonly ]] ; then
-		return 0
-	fi
-
-	# The user wants us to leave things be.
-	if [[ -n ${DONT_MOUNT_BOOT} ]] ; then
-		return 0
-	fi
-
-	# OK, we want to handle things ourselves.
-	return 1
-}
-
-# @FUNCTION: mount-boot_check_status
-# @INTERNAL
-# @DESCRIPTION:
-# Check if /boot is sane, i.e., mounted as read-write if on a separate
-# partition.  Die if conditions are not fulfilled.  If nonfatal is used,
-# the function will return a non-zero status instead.
-mount-boot_check_status() {
-	# Get out fast if possible.
-	mount-boot_is_disabled && return 0
-
-	# note that /dev/BOOT is in the Gentoo default /etc/fstab file
-	local fstabstate=$(awk '!/^[[:blank:]]*#|^\/dev\/BOOT/ && $2 == "/boot" \
-		{ print 1; exit }' /etc/fstab || die "awk failed")
-
-	if [[ -z ${fstabstate} ]] ; then
-		einfo "Assuming you do not have a separate /boot partition."
-		return 0
-	fi
-
-	local procstate=$(awk '$2 == "/boot" { split($4, a, ","); \
-		for (i in a) if (a[i] ~ /^r[ow]$/) { print a[i]; break }; exit }' \
-		/proc/mounts || die "awk failed")
-
-	if [[ -z ${procstate} ]] ; then
-		eerror "Your boot partition is not mounted at /boot."
-		eerror "Please mount it and retry."
-		die -n "/boot not mounted"
-		return 1
-	fi
-
-	if [[ ${procstate} == ro ]] ; then
-		eerror "Your boot partition, detected as being mounted at /boot," \
-			"is read-only."
-		eerror "Please remount it as read-write and retry."
-		die -n "/boot mounted read-only"
-		return 2
-	fi
-
-	einfo "Your boot partition was detected as being mounted at /boot."
-	einfo "Files will be installed there for ${PN} to function correctly."
-	return 0
-}
+inherit mount-boot-utils
 
 mount-boot_pkg_pretend() {
 	mount-boot_check_status
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-06-29  8:39 Andrew Ammerlaan
  0 siblings, 0 replies; 6663+ messages in thread
From: Andrew Ammerlaan @ 2024-06-29  8:39 UTC (permalink / raw
  To: gentoo-commits
commit:     f477c32907afde160d20ebdea161ea202d9cfeac
Author:     Andrew Ammerlaan <andrewammerlaan <AT> gentoo <DOT> org>
AuthorDate: Tue Jun 25 14:12:39 2024 +0000
Commit:     Andrew Ammerlaan <andrewammerlaan <AT> gentoo <DOT> org>
CommitDate: Sat Jun 29 08:36:19 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=f477c329
kernel-install.eclass: move mount-boot check to dist-kernel-utils.eclass
ebuilds and eclasses using dist-kernel_reinstall_initramfs should also
have the check for mounted /boot and ESP. We can do this safely via
mount-boot-utils.eclass which does not export any phases.
Signed-off-by: Andrew Ammerlaan <andrewammerlaan <AT> gentoo.org>
 eclass/dist-kernel-utils.eclass | 39 ++++++++++++++++++++++++++++++------
 eclass/kernel-install.eclass    | 44 +++++++++--------------------------------
 2 files changed, 42 insertions(+), 41 deletions(-)
diff --git a/eclass/dist-kernel-utils.eclass b/eclass/dist-kernel-utils.eclass
index 13137f8c863c..4bc3fab44aae 100644
--- a/eclass/dist-kernel-utils.eclass
+++ b/eclass/dist-kernel-utils.eclass
@@ -26,7 +26,7 @@ case ${EAPI} in
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
-inherit toolchain-funcs
+inherit mount-boot-utils toolchain-funcs
 
 # @FUNCTION: dist-kernel_get_image_path
 # @DESCRIPTION:
@@ -79,11 +79,38 @@ dist-kernel_install_kernel() {
 	local image=${2}
 	local map=${3}
 
-	ebegin "Installing the kernel via installkernel"
-	# note: .config is taken relatively to System.map;
-	# initrd relatively to bzImage
-	ARCH=$(tc-arch-kernel) installkernel "${version}" "${image}" "${map}"
-	eend ${?} || die -n "Installing the kernel failed"
+	local success=
+	# not an actual loop but allows error handling with 'break'
+	while true; do
+		nonfatal mount-boot_check_status || break
+
+		ebegin "Installing the kernel via installkernel"
+		# note: .config is taken relatively to System.map;
+		# initrd relatively to bzImage
+		ARCH=$(tc-arch-kernel) installkernel "${version}" "${image}" "${map}" || break
+		eend ${?} || die -n "Installing the kernel failed"
+
+		success=1
+		break
+	done
+
+	if [[ ! ${success} ]]; then
+		# Fallback string, if the identifier file is not found
+		local kernel="<name of your kernel pakcage>:<kernel version>"
+		# Try to read dist-kernel identifier to more accurately instruct users
+		local k_id_file=${image%$(dist-kernel_get_image_path)}/dist-kernel
+		if [[ -f ${k_id_file} ]]; then
+			kernel=\'\=$(<${k_id_file})\'
+		fi
+
+		eerror
+		eerror "The kernel was not deployed successfully. Inspect the failure"
+		eerror "in the logs above and once you resolve the problems please"
+		eerror "run the equivalent of the following command to try again:"
+		eerror
+		eerror "    emerge --config ${kernel}"
+		die "Kernel install failed, please fix the problems and run emerge --config"
+	fi
 }
 
 # @FUNCTION: dist-kernel_reinstall_initramfs
diff --git a/eclass/kernel-install.eclass b/eclass/kernel-install.eclass
index f512d815fe09..77570a905ce1 100644
--- a/eclass/kernel-install.eclass
+++ b/eclass/kernel-install.eclass
@@ -17,9 +17,7 @@
 # /usr/src/linux-${PV} containing the kernel image in its standard
 # location and System.map.
 #
-# The eclass exports src_test, pkg_postinst and pkg_postrm.
-# Additionally, the inherited mount-boot eclass exports pkg_pretend.
-# It also stubs out pkg_preinst and pkg_prerm defined by mount-boot.
+# The eclass exports src_test, pkg_preinst, pkg_postinst and pkg_postrm.
 
 # @ECLASS_VARIABLE: KERNEL_IUSE_GENERIC_UKI
 # @PRE_INHERIT
@@ -50,7 +48,7 @@ case ${EAPI} in
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
-inherit dist-kernel-utils mount-boot multiprocessing toolchain-funcs
+inherit dist-kernel-utils mount-boot-utils multiprocessing toolchain-funcs
 
 SLOT="${PV}"
 IUSE="+initramfs test"
@@ -526,6 +524,10 @@ kernel-install_test() {
 kernel-install_pkg_pretend() {
 	debug-print-function ${FUNCNAME} "${@}"
 
+	# Check, but don't die because we can fix the problem and then
+	# emerge --config ... to re-run installation.
+	nonfatal mount-boot_check_status
+
 	if ! has_version -d sys-kernel/linux-firmware; then
 		ewarn "sys-kernel/linux-firmware not found installed on your system."
 		ewarn "This package provides various firmware files that may be needed"
@@ -665,27 +667,8 @@ kernel-install_install_all() {
 		fi
 	fi
 
-	local success=
-	# not an actual loop but allows error handling with 'break'
-	while :; do
-		nonfatal mount-boot_check_status || break
-
-		nonfatal dist-kernel_install_kernel "${module_ver}" \
-			"${kernel_dir}/${image_path}" "${kernel_dir}/System.map" || break
-
-		success=1
-		break
-	done
-
-	if [[ ! ${success} ]]; then
-		eerror
-		eerror "The kernel files were copied to disk successfully but the kernel"
-		eerror "was not deployed successfully.  Once you resolve the problems,"
-		eerror "please run the equivalent of the following command to try again:"
-		eerror
-		eerror "    emerge --config ${CATEGORY}/${PN}:${SLOT}"
-		die "Kernel install failed, please fix the problems and run emerge --config ${CATEGORY}/${PN}:${SLOT}"
-	fi
+	dist-kernel_install_kernel "${module_ver}" "${kernel_dir}/${image_path}" \
+		"${kernel_dir}/System.map"
 }
 
 # @FUNCTION: kernel-install_pkg_postinst
@@ -718,15 +701,6 @@ kernel-install_pkg_postinst() {
 	fi
 }
 
-# @FUNCTION: kernel-install_pkg_prerm
-# @DESCRIPTION:
-# Stub out mount-boot.eclass.
-kernel-install_pkg_prerm() {
-	debug-print-function ${FUNCNAME} "${@}"
-
-	# (no-op)
-}
-
 # @FUNCTION: kernel-install_pkg_postrm
 # @DESCRIPTION:
 # Clean up the generated initramfs from the removed kernel directory.
@@ -774,5 +748,5 @@ kernel-install_compress_modules() {
 
 fi
 
-EXPORT_FUNCTIONS src_test pkg_preinst pkg_postinst pkg_prerm pkg_postrm
+EXPORT_FUNCTIONS src_test pkg_preinst pkg_postinst pkg_postrm
 EXPORT_FUNCTIONS pkg_config pkg_pretend
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-06-29  8:39 Andrew Ammerlaan
  0 siblings, 0 replies; 6663+ messages in thread
From: Andrew Ammerlaan @ 2024-06-29  8:39 UTC (permalink / raw
  To: gentoo-commits
commit:     594a6613a4693a590ba8473a99ce1fd6c4d506d2
Author:     Andrew Ammerlaan <andrewammerlaan <AT> gentoo <DOT> org>
AuthorDate: Tue Jun 25 14:15:05 2024 +0000
Commit:     Andrew Ammerlaan <andrewammerlaan <AT> gentoo <DOT> org>
CommitDate: Sat Jun 29 08:36:20 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=594a6613
linux-mod-r1.eclass: check /boot if we are re-installing dist-kernel
Previous commit already adds the check when we call
dist-kernel_reinstall_initramfs, but lets do it a bit earlier as well.
As in dist-kernel-utils.eclass, make the check nonfatal because when users
notice the problem they can correct it and manually re-install the kernel via
emerge --config ...
We don't have a pkg_pretend phase in this eclass, so we use the pkg_setup
phase instead to avoid introducing a new phase here.
Signed-off-by: Andrew Ammerlaan <andrewammerlaan <AT> gentoo.org>
 eclass/linux-mod-r1.eclass | 13 ++++++++++++-
 1 file changed, 12 insertions(+), 1 deletion(-)
diff --git a/eclass/linux-mod-r1.eclass b/eclass/linux-mod-r1.eclass
index 43c5a7d7b140..9911a6ddee12 100644
--- a/eclass/linux-mod-r1.eclass
+++ b/eclass/linux-mod-r1.eclass
@@ -132,6 +132,7 @@ IDEPEND="
 "
 
 if [[ ${MODULES_INITRAMFS_IUSE} ]]; then
+	inherit mount-boot-utils
 	IUSE+=" ${MODULES_INITRAMFS_IUSE}"
 	IDEPEND+="
 		${MODULES_INITRAMFS_IUSE#+}? (
@@ -328,9 +329,19 @@ fi
 #  3. perform various sanity checks to fail early on issues
 linux-mod-r1_pkg_setup() {
 	debug-print-function ${FUNCNAME[0]} "${@}"
-	[[ ${MERGE_TYPE} != binary ]] || return 0
 	_MODULES_GLOBAL[ran:pkg_setup]=1
 	_modules_check_function ${#} 0 0 || return 0
+
+	if [[ -z ${ROOT} && ${MODULES_INITRAMFS_IUSE} ]] &&
+		use dist-kernel && use ${MODULES_INITRAMFS_IUSE#+}
+	then
+		# Check, but don't die because we can fix the problem and then
+		# emerge --config ... to re-run installation.
+		nonfatal mount-boot_check_status
+	fi
+
+	[[ ${MERGE_TYPE} != binary ]] || return 0
+
 	_modules_check_migration
 
 	_modules_prepare_kernel
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-06-30 18:27 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-06-30 18:27 UTC (permalink / raw
  To: gentoo-commits
commit:     d9691f1d5dd9a126804102572ac812d9c8a4ee16
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Jun 30 18:26:34 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Jun 30 18:27:44 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=d9691f1d
gstreamer-meson.eclass: fix handling meson-1.5's pretty-printed JSON
meson-1.5 pretty-prints its JSON which means the target JSON file here
spawns multiple lines. <$x> will only read one line, per
https://github.com/makamaka/JSON-PP/issues/85#issuecomment-1367719155.
Switch to reading the whole file like in https://stackoverflow.com/a/24959863.
Cloess: https://bugs.gentoo.org/935245
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/gstreamer-meson.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/gstreamer-meson.eclass b/eclass/gstreamer-meson.eclass
index a26b06ba4595..937c86a0f15b 100644
--- a/eclass/gstreamer-meson.eclass
+++ b/eclass/gstreamer-meson.eclass
@@ -393,7 +393,7 @@ use utf8;
 use JSON::PP;
 
 open(my $targets_file, '<:encoding(UTF-8)', 'meson-info/intro-targets.json') || die $!;
-my $data = decode_json <$targets_file>;
+my $data = decode_json (join '', <$targets_file>);
 close($targets_file) || die $!;
 
 if(!$ARGV[0]) {
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-02 17:49 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-07-02 17:49 UTC (permalink / raw
  To: gentoo-commits
commit:     b597cc4cb8832fcc447ae998d4dac6677e0b2918
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Jul  2 17:48:36 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jul  2 17:48:36 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=b597cc4c
qt5-build.eclass: try to avoid SSE2 where unavailable
Rather overdue, but we got there eventually.
Closes: https://bugs.gentoo.org/773199
Bug: https://bugs.gentoo.org/552942
Bug: https://bugs.gentoo.org/648004
Bug: https://bugs.gentoo.org/775650
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/qt5-build.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/qt5-build.eclass b/eclass/qt5-build.eclass
index ef4ea4ec1756..1a0335b9d2b6 100644
--- a/eclass/qt5-build.eclass
+++ b/eclass/qt5-build.eclass
@@ -623,6 +623,9 @@ qt5_base_configure() {
 		$(is-flagq -mno-dsp   && echo -no-mips_dsp)
 		$(is-flagq -mno-dspr2 && echo -no-mips_dspr2)
 
+		# bug #773199 and friends
+		$(tc-cpp-is-true "defined(__SSE2__)" ${CFLAGS} ${CXXFLAGS} || echo -no-feature-sse2)
+
 		# use pkg-config to detect include and library paths
 		-pkg-config
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-03  0:54 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-07-03  0:54 UTC (permalink / raw
  To: gentoo-commits
commit:     9b0fbdcf296c0bf013b58637f2a87a5bdc125e52
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Jul  3 00:53:20 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Jul  3 00:53:20 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=9b0fbdcf
Revert "cmake.eclass: Set FETCHCONTENT_FULLY_DISCONNECTED=ON"
This reverts commit ca877f01a331bd239db8b6878c7f92fa85e02dae.
Unfortunately, the CMake developers learned of Homebrew doing this
and decided to "block" this functionality because they felt it was abuse.
We now have to implement a "provider" instead...
Bug: https://bugs.gentoo.org/920846
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/cmake.eclass | 3 +--
 1 file changed, 1 insertion(+), 2 deletions(-)
diff --git a/eclass/cmake.eclass b/eclass/cmake.eclass
index 908e2356ead2..d7d45217e275 100644
--- a/eclass/cmake.eclass
+++ b/eclass/cmake.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2024 Gentoo Authors
+# Copyright 1999-2023 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: cmake.eclass
@@ -541,7 +541,6 @@ cmake_src_configure() {
 		set(CMAKE_INSTALL_DOCDIR "${EPREFIX}/usr/share/doc/${PF}" CACHE PATH "")
 		set(BUILD_SHARED_LIBS ON CACHE BOOL "")
 		set(Python3_FIND_UNVERSIONED_NAMES FIRST CACHE STRING "")
-		set(FETCHCONTENT_FULLY_DISCONNECTED ON CACHE BOOL "")
 		set(CMAKE_DISABLE_PRECOMPILE_HEADERS ON CACHE BOOL "")
 	_EOF_
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-03  0:59 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-07-03  0:59 UTC (permalink / raw
  To: gentoo-commits
commit:     4fc79e22daff1ee51cd861515daba7dca08c1e5a
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Jul  3 00:54:56 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Jul  3 00:54:56 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=4fc79e22
cmake.eclass: fix copyright
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/cmake.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/cmake.eclass b/eclass/cmake.eclass
index d7d45217e275..de43bd017768 100644
--- a/eclass/cmake.eclass
+++ b/eclass/cmake.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2023 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: cmake.eclass
^ permalink raw reply related	[flat|nested] 6663+ messages in thread
* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-03  5:30 Joonas Niilola
  0 siblings, 0 replies; 6663+ messages in thread
From: Joonas Niilola @ 2024-07-03  5:30 UTC (permalink / raw
  To: gentoo-commits
commit:     5760b894bd1e9638a56186330c3c0365dfec84f7
Author:     Martin Dummer <martin.dummer <AT> gmx <DOT> net>
AuthorDate: Sun Jun 23 06:13:43 2024 +0000
Commit:     Joonas Niilola <juippis <AT> gentoo <DOT> org>
CommitDate: Wed Jul  3 05:30:17 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=5760b894
vdr-plugin-2.eclass: fix behaviour with LINGUAS="en"
when LINGUAS="en" is defined, vdr-plugin-2_src_install() stops erroneously
Closes: https://bugs.gentoo.org/796731
Signed-off-by: Martin Dummer <martin.dummer <AT> gmx.net>
Closes: https://github.com/gentoo/gentoo/pull/37250
Signed-off-by: Joonas Niilola <juippis <AT> gentoo.org>
 eclass/vdr-plugin-2.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/vdr-plugin-2.eclass b/eclass/vdr-plugin-2.eclass
index 289c3d1a624a..dc70ca7c5761 100644
--- a/eclass/vdr-plugin-2.eclass
+++ b/eclass/vdr-plugin-2.eclass
@@ -286,7 +286,7 @@ vdr_linguas_support() {
 			|| die "sed failed for Linguas"
 	done
 
-	strip-linguas ${PLUGIN_LINGUAS} en
+	strip-linguas ${PLUGIN_LINGUAS}
 }
 
 # @FUNCTION: vdr_i18n
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-05 11:03 Arthur Zamarin
  0 siblings, 0 replies; 6663+ messages in thread
From: Arthur Zamarin @ 2024-07-05 11:03 UTC (permalink / raw
  To: gentoo-commits
commit:     f4d5509345750e68f3c8d76b360e9e26a1ccc35f
Author:     Arthur Zamarin <arthurzam <AT> gentoo <DOT> org>
AuthorDate: Wed Jun 12 07:09:33 2024 +0000
Commit:     Arthur Zamarin <arthurzam <AT> gentoo <DOT> org>
CommitDate: Fri Jul  5 10:55:38 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=f4d55093
tree-sitter-grammar.eclass: respect CC & AR
Closes: https://bugs.gentoo.org/932626
Signed-off-by: Arthur Zamarin <arthurzam <AT> gentoo.org>
Signed-off-by: Brahmajit Das <brahmajit.xyz <AT> gmail.com>
Closes: https://github.com/gentoo/gentoo/pull/37122
Signed-off-by: Arthur Zamarin <arthurzam <AT> gentoo.org>
 eclass/tree-sitter-grammar.eclass | 2 ++
 1 file changed, 2 insertions(+)
diff --git a/eclass/tree-sitter-grammar.eclass b/eclass/tree-sitter-grammar.eclass
index ff0c4cb979e6..1e83ff8c98b9 100644
--- a/eclass/tree-sitter-grammar.eclass
+++ b/eclass/tree-sitter-grammar.eclass
@@ -162,6 +162,8 @@ tree-sitter-grammar_src_compile() {
 	if [[ -f "${S}/pyproject.toml" ]]; then
 		sed -e "/SONAME_MINOR :=/s/:=.*$/:= $(_get_tsg_abi_ver)/" -i "${S}/Makefile" || die
 		emake \
+			CC="$(tc-getCC)" \
+			AR="$(tc-getAR)" \
 			STRIP="" \
 			PREFIX="${EPREFIX}/usr" \
 			LIBDIR="${EPREFIX}/usr/$(get_libdir)"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-05 11:03 Arthur Zamarin
  0 siblings, 0 replies; 6663+ messages in thread
From: Arthur Zamarin @ 2024-07-05 11:03 UTC (permalink / raw
  To: gentoo-commits
commit:     37f04decb3309838a9b6a3dbf6abfac400050a8f
Author:     Arthur Zamarin <arthurzam <AT> gentoo <DOT> org>
AuthorDate: Fri Jul  5 10:58:59 2024 +0000
Commit:     Arthur Zamarin <arthurzam <AT> gentoo <DOT> org>
CommitDate: Fri Jul  5 10:58:59 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=37f04dec
tree-sitter-grammar.eclass: enable py3.13 bindings
Signed-off-by: Arthur Zamarin <arthurzam <AT> gentoo.org>
 eclass/tree-sitter-grammar.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/tree-sitter-grammar.eclass b/eclass/tree-sitter-grammar.eclass
index 1e83ff8c98b9..e5797fca8a16 100644
--- a/eclass/tree-sitter-grammar.eclass
+++ b/eclass/tree-sitter-grammar.eclass
@@ -47,7 +47,7 @@ for _BINDING in "${TS_BINDINGS[@]}"; do
 			DISTUTILS_EXT=1
 			DISTUTILS_OPTIONAL=1
 			DISTUTILS_USE_PEP517=setuptools
-			PYTHON_COMPAT=( python3_{10..12} )
+			PYTHON_COMPAT=( python3_{10..13} )
 			inherit distutils-r1
 
 			IUSE+=" python"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-05 11:03 Arthur Zamarin
  0 siblings, 0 replies; 6663+ messages in thread
From: Arthur Zamarin @ 2024-07-05 11:03 UTC (permalink / raw
  To: gentoo-commits
commit:     fbe4bc7b9dc970271127a5f167c95da78e32e282
Author:     Vadim Misbakh-Soloviov <mva <AT> gentoo <DOT> org>
AuthorDate: Wed Feb 21 17:59:50 2024 +0000
Commit:     Arthur Zamarin <arthurzam <AT> gentoo <DOT> org>
CommitDate: Fri Jul  5 10:55:37 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=fbe4bc7b
tree-sitter-grammar.eclass: extended packaging
1) put grammar library to additional well-known path
2) also put queries
See-Also: https://pkgs.alpinelinux.org/contents?branch=edge&name=tree%2dsitter%2dlua&arch=x86_64&repo=community
See-Also: https://pkgs.alpinelinux.org/contents?branch=edge&name=tree%2dsitter%2dcss&arch=x86_64&repo=community
Refer: https://github.com/gentoo/gentoo/pull/35475
Closes: https://bugs.gentoo.org/933833
Closes: https://bugs.gentoo.org/922146
Signed-off-by: Vadim Misbakh-Soloviov <mva <AT> gentoo.org>
Signed-off-by: Brahmajit Das <brahmajit.xyz <AT> gmail.com>
Closes: https://github.com/gentoo/gentoo/pull/37122
Signed-off-by: Arthur Zamarin <arthurzam <AT> gentoo.org>
 eclass/tree-sitter-grammar.eclass | 13 +++++++++++++
 1 file changed, 13 insertions(+)
diff --git a/eclass/tree-sitter-grammar.eclass b/eclass/tree-sitter-grammar.eclass
index 24473fb98b1f..ff0c4cb979e6 100644
--- a/eclass/tree-sitter-grammar.eclass
+++ b/eclass/tree-sitter-grammar.eclass
@@ -205,6 +205,19 @@ tree-sitter-grammar_src_install() {
 
 		dolib.so "${WORKDIR}/${soname}"
 		dosym "${soname}" /usr/$(get_libdir)/lib${PN}$(get_libname)
+		# Install symlinks to grammars so that they can be found by NeoVim.
+		# /usr/$(get_libdir)/tree-sitter gets added to the NeoVim runtimepath.
+		# See neovim/runtime/doc/treesitter.txt for info.
+		keepdir /usr/$(get_libdir)/tree-sitter
+		dosym ../"${soname}" \
+			/usr/$(get_libdir)/tree-sitter/parser/${PN##tree-sitter-}$(get_libname)
+
+		# Install queries (e.g. highlight.scm) so that they can be found by NeoVim.
+		if [[ -d "${S}/../queries" ]]; then
+			keepdir /usr/share/tree-sitter
+			insinto /usr/share/tree-sitter
+			doins -r "${S}/../queries"
+		fi
 	fi
 
 	local binding
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-05 20:50 Luca Barbato
  0 siblings, 0 replies; 6663+ messages in thread
From: Luca Barbato @ 2024-07-05 20:50 UTC (permalink / raw
  To: gentoo-commits
commit:     2baeb8c8987f9214080ce2a8c94c0e93ee7af217
Author:     Luca Barbato <lu_zero <AT> gentoo <DOT> org>
AuthorDate: Fri Jul  5 09:31:57 2024 +0000
Commit:     Luca Barbato <lu_zero <AT> gentoo <DOT> org>
CommitDate: Fri Jul  5 20:49:09 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=2baeb8c8
flag-o-matic.eclass: allow -mstrict-align and -mvector-strict-align
It is needed to make sure vector unaligned load/store aren't inserted
when the riscv cpu does not allow them.
See https://gcc.gnu.org/bugzilla/show_bug.cgi?id=115789
Signed-off-by: Luca Barbato <lu_zero <AT> gentoo.org>
 eclass/flag-o-matic.eclass | 4 ++++
 1 file changed, 4 insertions(+)
diff --git a/eclass/flag-o-matic.eclass b/eclass/flag-o-matic.eclass
index ecac452aa0ef..c6b1ad80e12e 100644
--- a/eclass/flag-o-matic.eclass
+++ b/eclass/flag-o-matic.eclass
@@ -129,6 +129,10 @@ _setup-allowed-flags() {
 		# needed for arm64 (and in particular SCS)
 		-ffixed-x18
 
+		# needed for riscv (to prevent unaligned vector access)
+		# See https://gcc.gnu.org/bugzilla/show_bug.cgi?id=115789
+		-mstrict-align -mvector-strict-align
+
 		# gcc 4.5
 		-mno-fma4 -mno-movbe -mno-xop -mno-lwp
 		# gcc 4.6
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-06 11:19 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-07-06 11:19 UTC (permalink / raw
  To: gentoo-commits
commit:     cb9dfca11b7ce7ed4c038f49b1ba403276e7ebcf
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Jul  6 10:46:04 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat Jul  6 11:19:02 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=cb9dfca1
llvm.org.eclass: Add 19.0.0_pre20240706 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index a6a7b542e64b..6af260b2606b 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -72,6 +72,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 			_LLVM_SOURCE_TYPE=snapshot
 
 			case ${PV} in
+				19.0.0_pre20240706)
+					EGIT_COMMIT=0b9f2847da79298ed09c29493245113f02b32d9f
+					;;
 				19.0.0_pre20240630)
 					EGIT_COMMIT=022d15c0039fc1cfaa3cc2eb1a45b71bbb21fadd
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-07  6:45 Matthew Smith
  0 siblings, 0 replies; 6663+ messages in thread
From: Matthew Smith @ 2024-07-07  6:45 UTC (permalink / raw
  To: gentoo-commits
commit:     cd426afc7f32ac84206f4156fc8ed0d20bd79246
Author:     Matthew Smith <matthew <AT> gentoo <DOT> org>
AuthorDate: Sun Jul  7 06:42:17 2024 +0000
Commit:     Matthew Smith <matthew <AT> gentoo <DOT> org>
CommitDate: Sun Jul  7 06:45:07 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=cd426afc
Revert "tree-sitter-grammar.eclass: extended packaging"
This reverts commit fbe4bc7b9dc970271127a5f167c95da78e32e282.
The previous change does not install the NeoVim symlinks correctly as they
point to /usr/lib/tree-sitter/liblang.so instead of /usr/lib/liblang.so.
Also the query files are not installed in per-package directories and have
common names (e.g. highlight.scm) which is causing file collisions.
To be fixed in a follow up commit which will introduce
tree-sitter-grammar-r1.eclass, so that ebuilds can be rev-bumped so that
users can rebuild and get the changes.
Bug: https://bugs.gentoo.org/935631
Bug: https://bugs.gentoo.org/935641
Signed-off-by: Matthew Smith <matthew <AT> gentoo.org>
 eclass/tree-sitter-grammar.eclass | 13 -------------
 1 file changed, 13 deletions(-)
diff --git a/eclass/tree-sitter-grammar.eclass b/eclass/tree-sitter-grammar.eclass
index e5797fca8a16..10f29b8a0835 100644
--- a/eclass/tree-sitter-grammar.eclass
+++ b/eclass/tree-sitter-grammar.eclass
@@ -207,19 +207,6 @@ tree-sitter-grammar_src_install() {
 
 		dolib.so "${WORKDIR}/${soname}"
 		dosym "${soname}" /usr/$(get_libdir)/lib${PN}$(get_libname)
-		# Install symlinks to grammars so that they can be found by NeoVim.
-		# /usr/$(get_libdir)/tree-sitter gets added to the NeoVim runtimepath.
-		# See neovim/runtime/doc/treesitter.txt for info.
-		keepdir /usr/$(get_libdir)/tree-sitter
-		dosym ../"${soname}" \
-			/usr/$(get_libdir)/tree-sitter/parser/${PN##tree-sitter-}$(get_libname)
-
-		# Install queries (e.g. highlight.scm) so that they can be found by NeoVim.
-		if [[ -d "${S}/../queries" ]]; then
-			keepdir /usr/share/tree-sitter
-			insinto /usr/share/tree-sitter
-			doins -r "${S}/../queries"
-		fi
 	fi
 
 	local binding
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-08 10:03 Ulrich Müller
  0 siblings, 0 replies; 6663+ messages in thread
From: Ulrich Müller @ 2024-07-08 10:03 UTC (permalink / raw
  To: gentoo-commits
commit:     0dd34779b2205e553f55dd0464374949559b763c
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Wed Jul  3 15:40:53 2024 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Mon Jul  8 09:42:07 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=0dd34779
kernel-2.eclass: Drop reference to BUILD_FIXES variable
Undocumented, and not used by any ebuilds inheriting this eclass.
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 eclass/kernel-2.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/kernel-2.eclass b/eclass/kernel-2.eclass
index ffbe986f3e87..c60fcb04dd73 100644
--- a/eclass/kernel-2.eclass
+++ b/eclass/kernel-2.eclass
@@ -1332,7 +1332,7 @@ getfilevar() {
 		unset ARCH
 
 		echo -e "include ${basefname}\ne:\n\t@echo \$(${1})" |
-			make -C "${basedname}" ${BUILD_FIXES} -s -f - e 2>/dev/null
+			make -C "${basedname}" -s -f - e 2>/dev/null
 
 		ARCH=${xarch}
 	fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-08 10:03 Ulrich Müller
  0 siblings, 0 replies; 6663+ messages in thread
From: Ulrich Müller @ 2024-07-08 10:03 UTC (permalink / raw
  To: gentoo-commits
commit:     31c7e60f5cf2c3bc8251f2f13aa899c836f4b40b
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Sat Jun 22 17:06:32 2024 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Mon Jul  8 09:42:06 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=31c7e60f
linux-info.eclass: Drop temporary fix for powerpc
Apparently there is no reference to a .tmp_gas_check file or to a TOUT
variable in Linux sources any more.
Bug: https://bugs.gentoo.org/75034#c14
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 eclass/linux-info.eclass | 6 ------
 1 file changed, 6 deletions(-)
diff --git a/eclass/linux-info.eclass b/eclass/linux-info.eclass
index 9449a6359d2a..90982445fdab 100644
--- a/eclass/linux-info.eclass
+++ b/eclass/linux-info.eclass
@@ -170,12 +170,6 @@ KERNEL_DIR="${KERNEL_DIR:-${ROOT%/}/usr/src/linux}"
 inherit toolchain-funcs
 [[ ${EAPI} == 6 ]] && inherit eapi7-ver
 
-# bug #75034
-case ${ARCH} in
-	ppc)	BUILD_FIXES="${BUILD_FIXES} TOUT=${T}/.tmp_gas_check";;
-	ppc64)	BUILD_FIXES="${BUILD_FIXES} TOUT=${T}/.tmp_gas_check";;
-esac
-
 # @FUNCTION: set_arch_to_kernel
 # @DESCRIPTION:
 # Set the env ARCH to match what the kernel expects.
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-08 10:03 Ulrich Müller
  0 siblings, 0 replies; 6663+ messages in thread
From: Ulrich Müller @ 2024-07-08 10:03 UTC (permalink / raw
  To: gentoo-commits
commit:     032104fa600ef674c128d23fd7e0c4193de6eb7f
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Sat Jun 22 17:09:25 2024 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Mon Jul  8 09:42:06 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=032104fa
linux-info.eclass: Drop support for EAPI 6
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 eclass/linux-info.eclass | 20 ++++++++------------
 1 file changed, 8 insertions(+), 12 deletions(-)
diff --git a/eclass/linux-info.eclass b/eclass/linux-info.eclass
index 90982445fdab..154be2a46888 100644
--- a/eclass/linux-info.eclass
+++ b/eclass/linux-info.eclass
@@ -6,7 +6,7 @@
 # kernel@gentoo.org
 # @AUTHOR:
 # Original author: John Mylchreest <johnm@gentoo.org>
-# @SUPPORTED_EAPIS: 6 7 8
+# @SUPPORTED_EAPIS: 7 8
 # @BLURB: eclass used for accessing kernel related information
 # @DESCRIPTION:
 # This eclass is used as a central eclass for accessing kernel
@@ -28,7 +28,7 @@
 # get_running_version
 
 case ${EAPI} in
-	6|7|8) ;;
+	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
@@ -38,7 +38,6 @@ _LINUX_INFO_ECLASS=1
 # A Couple of env vars are available to effect usage of this eclass
 # These are as follows:
 
-
 # @ECLASS_VARIABLE: CHECKCONFIG_DONOTHING
 # @USER_VARIABLE
 # @DEFAULT_UNSET
@@ -51,7 +50,7 @@ _LINUX_INFO_ECLASS=1
 # @DESCRIPTION:
 # A string containing the directory of the target kernel sources. The default value is
 # "/usr/src/linux"
-KERNEL_DIR="${KERNEL_DIR:-${ROOT%/}/usr/src/linux}"
+KERNEL_DIR="${KERNEL_DIR:-${ROOT}/usr/src/linux}"
 
 # @ECLASS_VARIABLE: CONFIG_CHECK
 # @DEFAULT_UNSET
@@ -88,7 +87,6 @@ KERNEL_DIR="${KERNEL_DIR:-${ROOT%/}/usr/src/linux}"
 # CONFIG_CHECK="~CFG" with ERROR_<CFG>="Error Message" calls eerror without dying
 # CONFIG_CHECK="~CFG" with WARNING_<CFG>="Warning Message" calls ewarn without dying
 
-
 # @ECLASS_VARIABLE: KBUILD_OUTPUT
 # @DEFAULT_UNSET
 # @DESCRIPTION:
@@ -168,7 +166,6 @@ KERNEL_DIR="${KERNEL_DIR:-${ROOT%/}/usr/src/linux}"
 
 # And to ensure all the weirdness with crosscompile
 inherit toolchain-funcs
-[[ ${EAPI} == 6 ]] && inherit eapi7-ver
 
 # @FUNCTION: set_arch_to_kernel
 # @DESCRIPTION:
@@ -636,7 +633,7 @@ get_version() {
 	# caught before this if they are.
 	if [[ -z ${OUTPUT_DIR} ]] ; then
 		# Try to locate a kernel that is most relevant for us.
-		for OUTPUT_DIR in "${SYSROOT}" "${ROOT%/}" "" ; do
+		for OUTPUT_DIR in "${SYSROOT}" "${ROOT}" "" ; do
 			OUTPUT_DIR+="/lib/modules/${KV_MAJOR}.${KV_MINOR}.${KV_PATCH}${KV_EXTRA}${KV_LOCAL}/build"
 			if [[ -e ${OUTPUT_DIR} ]] ; then
 				break
@@ -664,10 +661,10 @@ get_running_version() {
 
 	local kv=$(uname -r)
 
-	if [[ -f ${ROOT%/}/lib/modules/${kv}/source/Makefile ]]; then
-		KERNEL_DIR=$(readlink -f "${ROOT%/}/lib/modules/${kv}/source")
-		if [[ -f ${ROOT%/}/lib/modules/${kv}/build/Makefile ]]; then
-			KBUILD_OUTPUT=$(readlink -f "${ROOT%/}/lib/modules/${kv}/build")
+	if [[ -f ${ROOT}/lib/modules/${kv}/source/Makefile ]]; then
+		KERNEL_DIR=$(readlink -f "${ROOT}/lib/modules/${kv}/source")
+		if [[ -f ${ROOT}/lib/modules/${kv}/build/Makefile ]]; then
+			KBUILD_OUTPUT=$(readlink -f "${ROOT}/lib/modules/${kv}/build")
 		fi
 		get_version && return 0
 	fi
@@ -712,7 +709,6 @@ linux-info_get_any_version() {
 	fi
 }
 
-
 # ebuild check functions
 # ---------------------------------------
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-08 10:03 Ulrich Müller
  0 siblings, 0 replies; 6663+ messages in thread
From: Ulrich Müller @ 2024-07-08 10:03 UTC (permalink / raw
  To: gentoo-commits
commit:     b5ddd6e28b8b368bd9e1a064484de95c03bf5445
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Wed Jul  3 15:40:26 2024 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Mon Jul  8 09:42:07 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=b5ddd6e2
linux-info.eclass: Drop reference to BUILD_FIXES variable
Undocumented, and not used by any ebuilds inheriting this eclass.
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 eclass/linux-info.eclass | 3 +--
 1 file changed, 1 insertion(+), 2 deletions(-)
diff --git a/eclass/linux-info.eclass b/eclass/linux-info.eclass
index 154be2a46888..0f6138150144 100644
--- a/eclass/linux-info.eclass
+++ b/eclass/linux-info.eclass
@@ -239,8 +239,7 @@ getfilevar() {
 		# Pass dot-config=0 to avoid the config check in kernels prior to 5.4.
 		echo -e "e:\\n\\t@echo \$(${1})\\ninclude ${basefname}" | \
 			nonfatal emake -C "${basedname}" --no-print-directory M="${T}" \
-			dot-config=0 need-config= need-compiler= \
-			${BUILD_FIXES} -s -f - 2>/dev/null
+			dot-config=0 need-config= need-compiler= -s -f - 2>/dev/null
 
 		ARCH=${myARCH}
 	fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-09 16:44 Ulrich Müller
  0 siblings, 0 replies; 6663+ messages in thread
From: Ulrich Müller @ 2024-07-09 16:44 UTC (permalink / raw
  To: gentoo-commits
commit:     aa9e9f6009a17b2ee0128109f69bbfc7ac975d3f
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Tue Jul  9 16:43:27 2024 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Tue Jul  9 16:44:40 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=aa9e9f60
bzr.eclass: Mark as dead
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 eclass/bzr.eclass | 1 +
 1 file changed, 1 insertion(+)
diff --git a/eclass/bzr.eclass b/eclass/bzr.eclass
index d522326773e1..b442381dc668 100644
--- a/eclass/bzr.eclass
+++ b/eclass/bzr.eclass
@@ -1,6 +1,7 @@
 # Copyright 1999-2023 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
+# @DEAD
 # @ECLASS: bzr.eclass
 # @MAINTAINER:
 # Ulrich Müller <ulm@gentoo.org>
^ permalink raw reply related	[flat|nested] 6663+ messages in thread
* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-11 14:35 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-07-11 14:35 UTC (permalink / raw
  To: gentoo-commits
commit:     4e733c42e1390939255a6ae506ab838e3d3d525c
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Thu Jul 11 12:04:59 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Thu Jul 11 14:35:16 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=4e733c42
kernel-build.eclass: Support python3.13
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/kernel-build.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/kernel-build.eclass b/eclass/kernel-build.eclass
index 86c7cd4a172d..1f0b07fdc3f9 100644
--- a/eclass/kernel-build.eclass
+++ b/eclass/kernel-build.eclass
@@ -28,7 +28,7 @@ esac
 if [[ ! ${_KERNEL_BUILD_ECLASS} ]]; then
 _KERNEL_BUILD_ECLASS=1
 
-PYTHON_COMPAT=( python3_{10..12} )
+PYTHON_COMPAT=( python3_{10..13} )
 if [[ ${KERNEL_IUSE_MODULES_SIGN} ]]; then
 	inherit secureboot
 fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-11 20:54 Ulrich Müller
  0 siblings, 0 replies; 6663+ messages in thread
From: Ulrich Müller @ 2024-07-11 20:54 UTC (permalink / raw
  To: gentoo-commits
commit:     e27f68c1a16993efd00c81145d33d792a0f870d9
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Mon Jul  8 17:44:49 2024 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Thu Jul 11 20:54:11 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=e27f68c1
git-r3.eclass: Drop support for EAPI 6
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 eclass/git-r3.eclass | 13 ++++---------
 1 file changed, 4 insertions(+), 9 deletions(-)
diff --git a/eclass/git-r3.eclass b/eclass/git-r3.eclass
index 565f6ada8382..35ad6afe8e88 100644
--- a/eclass/git-r3.eclass
+++ b/eclass/git-r3.eclass
@@ -4,7 +4,7 @@
 # @ECLASS: git-r3.eclass
 # @MAINTAINER:
 # Michał Górny <mgorny@gentoo.org>
-# @SUPPORTED_EAPIS: 6 7 8
+# @SUPPORTED_EAPIS: 7 8
 # @BLURB: Eclass for fetching and unpacking git repositories.
 # @DESCRIPTION:
 # Third generation eclass for easing maintenance of live ebuilds using
@@ -26,7 +26,7 @@
 # If non-empty, then the repo likely needs EGIT_LFS to clone properly.
 
 case ${EAPI} in
-	6|7|8) ;;
+	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
@@ -35,13 +35,8 @@ _GIT_R3_ECLASS=1
 
 PROPERTIES+=" live"
 
-if [[ ${EAPI} != 6 ]]; then
-	BDEPEND=">=dev-vcs/git-1.8.2.1[curl]"
-	[[ ${EGIT_LFS} ]] && BDEPEND+=" dev-vcs/git-lfs"
-else
-	DEPEND=">=dev-vcs/git-1.8.2.1[curl]"
-	[[ ${EGIT_LFS} ]] && DEPEND+=" dev-vcs/git-lfs"
-fi
+BDEPEND=">=dev-vcs/git-1.8.2.1[curl]"
+[[ ${EGIT_LFS} ]] && BDEPEND+=" dev-vcs/git-lfs"
 
 # @ECLASS_VARIABLE: EGIT_CLONE_TYPE
 # @USER_VARIABLE
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-11 20:54 Ulrich Müller
  0 siblings, 0 replies; 6663+ messages in thread
From: Ulrich Müller @ 2024-07-11 20:54 UTC (permalink / raw
  To: gentoo-commits
commit:     34858e23de6ac549ca662a1dcc7823173567a210
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Sun Jun 23 14:18:32 2024 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Thu Jul 11 20:54:11 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=34858e23
vcs-snapshot.eclass: Drop support for EAPI 6
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 eclass/vcs-snapshot.eclass | 16 ++++++----------
 1 file changed, 6 insertions(+), 10 deletions(-)
diff --git a/eclass/vcs-snapshot.eclass b/eclass/vcs-snapshot.eclass
index 1b7299b92a3b..0279e89ec3ab 100644
--- a/eclass/vcs-snapshot.eclass
+++ b/eclass/vcs-snapshot.eclass
@@ -1,10 +1,10 @@
-# Copyright 1999-2022 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: vcs-snapshot.eclass
 # @MAINTAINER:
 # mgorny@gentoo.org
-# @SUPPORTED_EAPIS: 6 7 8
+# @SUPPORTED_EAPIS: 7 8
 # @BLURB: support eclass for unpacking VCS snapshot tarballs
 # @DESCRIPTION:
 # THIS ECLASS IS NOT NECESSARY FOR MODERN GITHUB AND GITLAB SNAPSHOTS.
@@ -43,7 +43,6 @@
 # in ${WORKDIR}/${P} and ${WORKDIR}/${P}-otherstuff respectively.
 
 case ${EAPI} in
-	6) inherit eqawarn ;;
 	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
@@ -103,13 +102,10 @@ vcs-snapshot_src_unpack() {
 	done
 
 	if [[ ! ${renamed_any} ]]; then
-		local w=eerror
-		[[ ${EAPI} == 6 ]] && w=eqawarn
-		"${w}" "${FUNCNAME} did not find any archives that needed renaming."
-		"${w}" "Please verify that its usage is really necessary, and remove"
-		"${w}" "the inherit if it is not."
-
-		[[ ${w} == eerror ]] && die "${FUNCNAME}: Unnecessary usage detected"
+		eerror "${FUNCNAME} did not find any archives that needed renaming."
+		eerror "Please verify that its usage is really necessary, and remove"
+		eerror "the inherit if it is not."
+		die "${FUNCNAME}: Unnecessary usage detected"
 	fi
 }
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-12  6:27 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-07-12  6:27 UTC (permalink / raw
  To: gentoo-commits
commit:     9968732ec7b6deec53a472f54fc8f92ab9e849da
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Jul 12 06:26:32 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Jul 12 06:26:55 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=9968732e
autotools.eclass: add 1.17 to _LATEST_AUTOMAKE
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/autotools.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/autotools.eclass b/eclass/autotools.eclass
index a456e9b9f589..b932ff8bee90 100644
--- a/eclass/autotools.eclass
+++ b/eclass/autotools.eclass
@@ -94,7 +94,7 @@ _LATEST_AUTOCONF=( 2.72-r1:2.72 2.71-r6:2.71 )
 # Do NOT change this variable in your ebuilds!
 # If you want to force a newer minor version, you can specify the correct
 # WANT value by using a colon:  <PV>:<WANT_AUTOMAKE>
-_LATEST_AUTOMAKE=( 1.16.5:1.16 )
+_LATEST_AUTOMAKE=( 1.17:1.17 1.16.5:1.16 )
 
 _automake_atom="dev-build/automake"
 _autoconf_atom="dev-build/autoconf"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread
* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-12  7:38 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-07-12  7:38 UTC (permalink / raw
  To: gentoo-commits
commit:     91ea2b6d471406e56206278d0e97422f74028bde
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Jul 12 07:38:09 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Jul 12 07:38:09 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=91ea2b6d
autotools.eclass: crank _LATEST_AUTOMAKE to get fixed 1.17-r1
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/autotools.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/autotools.eclass b/eclass/autotools.eclass
index b932ff8bee90..3c9e89bda90e 100644
--- a/eclass/autotools.eclass
+++ b/eclass/autotools.eclass
@@ -94,7 +94,7 @@ _LATEST_AUTOCONF=( 2.72-r1:2.72 2.71-r6:2.71 )
 # Do NOT change this variable in your ebuilds!
 # If you want to force a newer minor version, you can specify the correct
 # WANT value by using a colon:  <PV>:<WANT_AUTOMAKE>
-_LATEST_AUTOMAKE=( 1.17:1.17 1.16.5:1.16 )
+_LATEST_AUTOMAKE=( 1.17-r1:1.17 1.16.5:1.16 )
 
 _automake_atom="dev-build/automake"
 _autoconf_atom="dev-build/autoconf"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread
* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-12 17:43 Ulrich Müller
  0 siblings, 0 replies; 6663+ messages in thread
From: Ulrich Müller @ 2024-07-12 17:43 UTC (permalink / raw
  To: gentoo-commits
commit:     0b5a61fc03b22036d38c7bc1dab15b7061277f85
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Fri Jul 12 17:43:15 2024 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Fri Jul 12 17:43:40 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=0b5a61fc
mount-boot{,-utils}.eclass: Update @SUPPORTED_EAPIS
It didn't agree with the case statement below.
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 eclass/mount-boot-utils.eclass | 2 +-
 eclass/mount-boot.eclass       | 2 +-
 2 files changed, 2 insertions(+), 2 deletions(-)
diff --git a/eclass/mount-boot-utils.eclass b/eclass/mount-boot-utils.eclass
index 39f8e94b84ec..e24b4e0c0826 100644
--- a/eclass/mount-boot-utils.eclass
+++ b/eclass/mount-boot-utils.eclass
@@ -4,7 +4,7 @@
 # @ECLASS: mount-boot-utils.eclass
 # @MAINTAINER:
 # base-system@gentoo.org
-# @SUPPORTED_EAPIS: 6 7 8
+# @SUPPORTED_EAPIS: 7 8
 # @BLURB: functions for packages that install files into /boot or the ESP
 # @DESCRIPTION:
 # This eclass is really only useful for bootloaders and kernel installation.
diff --git a/eclass/mount-boot.eclass b/eclass/mount-boot.eclass
index ab02b39d6141..ce17026ffd2b 100644
--- a/eclass/mount-boot.eclass
+++ b/eclass/mount-boot.eclass
@@ -4,7 +4,7 @@
 # @ECLASS: mount-boot.eclass
 # @MAINTAINER:
 # base-system@gentoo.org
-# @SUPPORTED_EAPIS: 6 7 8
+# @SUPPORTED_EAPIS: 7 8
 # @BLURB: eclass for packages that install files into /boot or the ESP
 # @DESCRIPTION:
 # This eclass is really only useful for bootloaders and kernel installation.
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-13  7:46 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-07-13  7:46 UTC (permalink / raw
  To: gentoo-commits
commit:     372b25ba641d3445487a4e9edc31bef614cd837f
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Jul 13 04:48:04 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat Jul 13 07:45:58 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=372b25ba
llvm.org.eclass: Remove old snapshot hashes
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 6 ------
 1 file changed, 6 deletions(-)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index 6af260b2606b..956a81b0b405 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -75,12 +75,6 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 				19.0.0_pre20240706)
 					EGIT_COMMIT=0b9f2847da79298ed09c29493245113f02b32d9f
 					;;
-				19.0.0_pre20240630)
-					EGIT_COMMIT=022d15c0039fc1cfaa3cc2eb1a45b71bbb21fadd
-					;;
-				19.0.0_pre20240623)
-					EGIT_COMMIT=3ae6755719c6dfc07761b4e9bdac8c86bcb41734
-					;;
 				*)
 					die "Unknown snapshot: ${PV}"
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-13 14:14 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-07-13 14:14 UTC (permalink / raw
  To: gentoo-commits
commit:     72fed566b6f19d3eddb2b1efe190fb2b4291f7ab
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Jul 13 12:55:08 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat Jul 13 14:14:40 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=72fed566
llvm.org.eclass: Add 19.0.0_pre20240712 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index 956a81b0b405..4fd4e8679c6a 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -72,6 +72,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 			_LLVM_SOURCE_TYPE=snapshot
 
 			case ${PV} in
+				19.0.0_pre20240712)
+					EGIT_COMMIT=1bad7024561bc64ed4bfda0772b16376b475eba5
+					;;
 				19.0.0_pre20240706)
 					EGIT_COMMIT=0b9f2847da79298ed09c29493245113f02b32d9f
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-14 17:45 Florian Schmaus
  0 siblings, 0 replies; 6663+ messages in thread
From: Florian Schmaus @ 2024-07-14 17:45 UTC (permalink / raw
  To: gentoo-commits
commit:     44050f01a5de42d7c329e8e358cd42c4c9e9aeb8
Author:     Florian Schmaus <flow <AT> gentoo <DOT> org>
AuthorDate: Tue Jul  9 17:06:12 2024 +0000
Commit:     Florian Schmaus <flow <AT> gentoo <DOT> org>
CommitDate: Sun Jul 14 17:44:38 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=44050f01
rebar.eclass: factor out common functions into rebar-utils.eclass
In preperation for rebar3.eclass, factor out common functions into rebar-utils.eclass.
Signed-off-by: Florian Schmaus <flow <AT> gentoo.org>
 eclass/{rebar.eclass => rebar-utils.eclass} | 120 +++-------------------------
 eclass/rebar.eclass                         | 112 +-------------------------
 2 files changed, 13 insertions(+), 219 deletions(-)
diff --git a/eclass/rebar.eclass b/eclass/rebar-utils.eclass
similarity index 58%
copy from eclass/rebar.eclass
copy to eclass/rebar-utils.eclass
index 97638c761814..5657908eb8e9 100644
--- a/eclass/rebar.eclass
+++ b/eclass/rebar-utils.eclass
@@ -1,43 +1,30 @@
 # Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
-# @ECLASS: rebar.eclass
+# @ECLASS: rebar-utils.eclass
 # @MAINTAINER:
-# maintainer-needed@gentoo.org
+# Florian Schmaus <flow@gentoo.org>
 # @AUTHOR:
 # Amadeusz Żołnowski <aidecoe@gentoo.org>
 # @SUPPORTED_EAPIS: 7 8
-# @BLURB: Build Erlang/OTP projects using dev-util/rebar.
+# @BLURB: Auxiliary functions for using dev-util/rebar.
 # @DESCRIPTION:
-# An eclass providing functions to build Erlang/OTP projects using
-# dev-util/rebar.
-#
-# rebar is a tool which tries to resolve dependencies itself which is by
-# cloning remote git repositories. Dependent projects are usually expected to
-# be in sub-directory 'deps' rather than looking at system Erlang lib
-# directory. Projects relying on rebar usually don't have 'install' make
-# targets. The eclass workarounds some of these problems. It handles
-# installation in a generic way for Erlang/OTP structured projects.
+# This eclass provides a set of axiliary functions commonly needed
+# when building Erlang/OTP packages with rebar.
 
 case ${EAPI} in
 	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
-if [[ -z ${_REBAR_ECLASS} ]]; then
-_REBAR_ECLASS=1
-
-RDEPEND="dev-lang/erlang:="
-DEPEND="${RDEPEND}"
-BDEPEND="
-	dev-util/rebar:0
-	>=sys-apps/gawk-4.1
-"
+if [[ -z ${_REBAR_UTILS_ECLASS} ]]; then
+_REBAR_UTILS_ECLASS=1
 
 # @ECLASS_VARIABLE: REBAR_APP_SRC
 # @DESCRIPTION:
-# Relative path to .app.src description file.
-REBAR_APP_SRC="${REBAR_APP_SRC-src/${PN}.app.src}"
+# Relative path to .app.src description file. Defaults to
+# 'src/${PN}.app.src'.
+: "${REBAR_APP_SRC:=src/${PN}.app.src}"
 
 # @FUNCTION: get_erl_libs
 # @RETURN: the path to Erlang lib directory
@@ -90,21 +77,6 @@ rebar_disable_coverage() {
 		|| die "failed to disable coverage in ${rebar_config}"
 }
 
-# @FUNCTION: erebar
-# @USAGE: <targets>
-# @DESCRIPTION:
-# Run rebar with verbose flag. Die on failure.
-erebar() {
-	debug-print-function ${FUNCNAME} "${@}"
-
-	(( $# > 0 )) || die "erebar: at least one target is required"
-
-	local -x ERL_LIBS="${EPREFIX}$(get_erl_libs)"
-	[[ ${1} == eunit ]] && local -x ERL_LIBS="."
-
-	rebar -v skip_deps=true "$@" || die -n "rebar $@ failed"
-}
-
 # @FUNCTION: rebar_fix_include_path
 # @USAGE: <project_name> [<rebar_config>]
 # @DESCRIPTION:
@@ -185,76 +157,4 @@ rebar_set_vsn() {
 		|| die "failed to set version in src/${PN}.app.src"
 }
 
-# @FUNCTION: rebar_src_prepare
-# @DESCRIPTION:
-# Prevent rebar from fetching and compiling dependencies. Set version in
-# project description file if it's not set.
-#
-# Existence of rebar.config is optional, but file description file must exist
-# at 'src/${PN}.app.src'.
-rebar_src_prepare() {
-	debug-print-function ${FUNCNAME} "${@}"
-
-	default
-	rebar_set_vsn
-	if [[ -f rebar.config ]]; then
-		rebar_disable_coverage
-		rebar_remove_deps
-	fi
-}
-
-# @FUNCTION: rebar_src_configure
-# @DESCRIPTION:
-# Configure with ERL_LIBS set.
-rebar_src_configure() {
-	debug-print-function ${FUNCNAME} "${@}"
-
-	local -x ERL_LIBS="${EPREFIX}$(get_erl_libs)"
-	default
-}
-
-# @FUNCTION: rebar_src_compile
-# @DESCRIPTION:
-# Compile project with rebar.
-rebar_src_compile() {
-	debug-print-function ${FUNCNAME} "${@}"
-
-	erebar compile
-}
-
-# @FUNCTION: rebar_src_test
-# @DESCRIPTION:
-# Run unit tests.
-rebar_src_test() {
-	debug-print-function ${FUNCNAME} "${@}"
-
-	erebar eunit
-}
-
-# @FUNCTION: rebar_src_install
-# @DESCRIPTION:
-# Install BEAM files, include headers, executables and native libraries.
-# Install standard docs like README or defined in DOCS variable.
-#
-# Function expects that project conforms to Erlang/OTP structure.
-rebar_src_install() {
-	debug-print-function ${FUNCNAME} "${@}"
-
-	local bin
-	local dest="$(get_erl_libs)/${P}"
-
-	insinto "${dest}"
-	doins -r ebin
-	[[ -d include ]] && doins -r include
-	[[ -d bin ]] && for bin in bin/*; do dobin "$bin"; done
-
-	if [[ -d priv ]]; then
-		cp -pR priv "${ED}${dest}/" || die "failed to install priv/"
-	fi
-
-	einstalldocs
-}
-
 fi
-
-EXPORT_FUNCTIONS src_prepare src_compile src_test src_install
diff --git a/eclass/rebar.eclass b/eclass/rebar.eclass
index 97638c761814..1e4e845a9adb 100644
--- a/eclass/rebar.eclass
+++ b/eclass/rebar.eclass
@@ -7,6 +7,7 @@
 # @AUTHOR:
 # Amadeusz Żołnowski <aidecoe@gentoo.org>
 # @SUPPORTED_EAPIS: 7 8
+# @PROVIDES: rebar-utils
 # @BLURB: Build Erlang/OTP projects using dev-util/rebar.
 # @DESCRIPTION:
 # An eclass providing functions to build Erlang/OTP projects using
@@ -27,6 +28,8 @@ esac
 if [[ -z ${_REBAR_ECLASS} ]]; then
 _REBAR_ECLASS=1
 
+inherit rebar-utils
+
 RDEPEND="dev-lang/erlang:="
 DEPEND="${RDEPEND}"
 BDEPEND="
@@ -34,19 +37,6 @@ BDEPEND="
 	>=sys-apps/gawk-4.1
 "
 
-# @ECLASS_VARIABLE: REBAR_APP_SRC
-# @DESCRIPTION:
-# Relative path to .app.src description file.
-REBAR_APP_SRC="${REBAR_APP_SRC-src/${PN}.app.src}"
-
-# @FUNCTION: get_erl_libs
-# @RETURN: the path to Erlang lib directory
-# @DESCRIPTION:
-# Get the full path without EPREFIX to Erlang lib directory.
-get_erl_libs() {
-	echo "/usr/$(get_libdir)/erlang/lib"
-}
-
 # @FUNCTION: _rebar_find_dep
 # @INTERNAL
 # @USAGE: <project_name>
@@ -74,22 +64,6 @@ _rebar_find_dep() {
 	echo "${result}"
 }
 
-# @FUNCTION: rebar_disable_coverage
-# @USAGE: [<rebar_config>]
-# @DESCRIPTION:
-# Disable coverage in rebar.config. This is a workaround for failing coverage.
-# Coverage is not relevant in this context, so there's no harm to disable it,
-# although the issue should be fixed.
-rebar_disable_coverage() {
-	debug-print-function ${FUNCNAME} "${@}"
-
-	local rebar_config="${1:-rebar.config}"
-
-	sed -e 's/{cover_enabled, true}/{cover_enabled, false}/' \
-		-i "${rebar_config}" \
-		|| die "failed to disable coverage in ${rebar_config}"
-}
-
 # @FUNCTION: erebar
 # @USAGE: <targets>
 # @DESCRIPTION:
@@ -105,86 +79,6 @@ erebar() {
 	rebar -v skip_deps=true "$@" || die -n "rebar $@ failed"
 }
 
-# @FUNCTION: rebar_fix_include_path
-# @USAGE: <project_name> [<rebar_config>]
-# @DESCRIPTION:
-# Fix path in rebar.config to 'include' directory of dependent project/package,
-# so it points to installation in system Erlang lib rather than relative 'deps'
-# directory.
-#
-# <rebar_config> is optional. Default is 'rebar.config'.
-#
-# The function dies on failure.
-rebar_fix_include_path() {
-	debug-print-function ${FUNCNAME} "${@}"
-
-	local pn="${1}"
-	local rebar_config="${2:-rebar.config}"
-	local erl_libs="${EPREFIX}$(get_erl_libs)"
-	local p
-
-	p="$(_rebar_find_dep "${pn}")" \
-		|| die "failed to unambiguously resolve dependency of '${pn}'"
-
-	gawk -i inplace \
-		-v erl_libs="${erl_libs}" -v pn="${pn}" -v p="${p}" '
-/^{[[:space:]]*erl_opts[[:space:]]*,/, /}[[:space:]]*\.$/ {
-	pattern = "\"(./)?deps/" pn "/include\"";
-	if (match($0, "{i,[[:space:]]*" pattern "[[:space:]]*}")) {
-		sub(pattern, "\"" erl_libs "/" p "/include\"");
-	}
-	print $0;
-	next;
-}
-1
-' "${rebar_config}" || die "failed to fix include paths in ${rebar_config} for '${pn}'"
-}
-
-# @FUNCTION: rebar_remove_deps
-# @USAGE: [<rebar_config>]
-# @DESCRIPTION:
-# Remove dependencies list from rebar.config and deceive build rules that any
-# dependencies are already fetched and built. Otherwise rebar tries to fetch
-# dependencies and compile them.
-#
-# <rebar_config> is optional. Default is 'rebar.config'.
-#
-# The function dies on failure.
-rebar_remove_deps() {
-	debug-print-function ${FUNCNAME} "${@}"
-
-	local rebar_config="${1:-rebar.config}"
-
-	mkdir -p "${S}/deps" && :>"${S}/deps/.got" && :>"${S}/deps/.built" || die
-	gawk -i inplace '
-/^{[[:space:]]*deps[[:space:]]*,/, /}[[:space:]]*\.$/ {
-	if ($0 ~ /}[[:space:]]*\.$/) {
-		print "{deps, []}.";
-	}
-	next;
-}
-1
-' "${rebar_config}" || die "failed to remove deps from ${rebar_config}"
-}
-
-# @FUNCTION: rebar_set_vsn
-# @USAGE: [<version>]
-# @DESCRIPTION:
-# Set version in project description file if it's not set.
-#
-# <version> is optional. Default is PV stripped from version suffix.
-#
-# The function dies on failure.
-rebar_set_vsn() {
-	debug-print-function ${FUNCNAME} "${@}"
-
-	local version="${1:-${PV%_*}}"
-
-	sed -e "s/vsn, git/vsn, \"${version}\"/" \
-		-i "${S}/${REBAR_APP_SRC}" \
-		|| die "failed to set version in src/${PN}.app.src"
-}
-
 # @FUNCTION: rebar_src_prepare
 # @DESCRIPTION:
 # Prevent rebar from fetching and compiling dependencies. Set version in
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-14 17:45 Florian Schmaus
  0 siblings, 0 replies; 6663+ messages in thread
From: Florian Schmaus @ 2024-07-14 17:45 UTC (permalink / raw
  To: gentoo-commits
commit:     932e9f9bc3c2d55a8ffc680d9146b2852148f4ba
Author:     Florian Schmaus <flow <AT> gentoo <DOT> org>
AuthorDate: Tue Jul  9 17:07:23 2024 +0000
Commit:     Florian Schmaus <flow <AT> gentoo <DOT> org>
CommitDate: Sun Jul 14 17:44:39 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=932e9f9b
rebar3.eclass: add new eclass
Add a new eclass for dev-util/rebar:3, based on the work of Anna
Vyalkova in ::guru (thanks!).
The Erlang/OTP ecosystem is moving to Rebar3. Upstreams start to drop
support for Rebar2, or at least consider it.
Signed-off-by: Florian Schmaus <flow <AT> gentoo.org>
 eclass/rebar3.eclass | 194 +++++++++++++++++++++++++++++++++++++++++++++++++++
 1 file changed, 194 insertions(+)
diff --git a/eclass/rebar3.eclass b/eclass/rebar3.eclass
new file mode 100644
index 000000000000..f6383b9c8cdd
--- /dev/null
+++ b/eclass/rebar3.eclass
@@ -0,0 +1,194 @@
+# Copyright 1999-2024 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+# @ECLASS: rebar3.eclass
+# @MAINTAINER:
+# Florian Schmaus <flow@gentoo.org>
+# @AUTHOR:
+# Amadeusz Żołnowski <aidecoe@gentoo.org>
+# Anna (cybertailor) Vyalkova <cyber+gentoo@sysrq.in>
+# @SUPPORTED_EAPIS: 8
+# @PROVIDES: rebar-utils
+# @BLURB: Build Erlang/OTP projects using dev-util/rebar:3.
+# @DESCRIPTION:
+# An eclass providing functions to build Erlang/OTP projects using
+# dev-util/rebar:3.
+#
+# rebar is a tool which tries to resolve dependencies itself which is by
+# cloning remote git repositories. Dependent projects are usually expected to
+# be in sub-directory 'deps' rather than looking at system Erlang lib
+# directory. Projects relying on rebar usually don't have 'install' make
+# targets. The eclass workarounds some of these problems. It handles
+# installation in a generic way for Erlang/OTP structured projects.
+
+case ${EAPI} in
+	8) ;;
+	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
+esac
+
+if [[ -z ${_REBAR3_ECLASS} ]]; then
+_REBAR3_ECLASS=1
+
+inherit edo rebar-utils
+
+RDEPEND="dev-lang/erlang:="
+DEPEND="${RDEPEND}"
+BDEPEND="
+	dev-util/rebar:3
+	>=sys-apps/gawk-4.1
+"
+
+# @ECLASS_VARIABLE: REBAR_PROFILE
+# @DESCRIPTION:
+# Rebar profile to use. Defaults to
+# 'default'.
+: "${REBAR_PROFILE:=default}"
+
+# @FUNCTION: _rebar_find_dep
+# @INTERNAL
+# @USAGE: <project_name>
+# @RETURN: 0 success, 1 dependency not found, 2 multiple versions found
+# @DESCRIPTION:
+# Find a Erlang package/project by name in Erlang lib directory. Project
+# directory is usually suffixed with version. It is matched to '<project_name>'
+# or '<project_name>-*'.
+_rebar_find_dep() {
+	local pn="${1}"
+	local p
+	local result
+
+	pushd "${EPREFIX}$(get_erl_libs)" >/dev/null || return 1
+	for p in ${pn} ${pn}-*; do
+		if [[ -d ${p} ]]; then
+			# Ensure there's at most one matching.
+			[[ ${result} ]] && return 2
+			result="${p}"
+		fi
+	done
+	popd >/dev/null || die
+
+	[[ ${result} ]] || return 1
+	echo "${result}"
+}
+
+# @FUNCTION: erebar3
+# @USAGE: <targets>
+# @DESCRIPTION:
+# Run rebar with verbose flag. Die on failure.
+erebar3() {
+	debug-print-function ${FUNCNAME} "${@}"
+
+	(( $# > 0 )) || die "${FUNCNAME}: at least one target is required"
+
+	case ${1} in
+		eunit|ct)
+			local -x ERL_LIBS="." ;;
+		*)
+			local -x ERL_LIBS="${EPREFIX}$(get_erl_libs)" ;;
+	esac
+
+	local -x HEX_OFFLINE=true
+	edo rebar3 "$@"
+}
+
+# @FUNCTION: rebar3_src_prepare
+# @DESCRIPTION:
+# Prevent rebar3 from fetching and compiling dependencies. Set version in
+# project description file if it's not set.
+#
+# Existence of rebar.config is optional, but file description file must exist
+# at 'src/${PN}.app.src'.
+rebar3_src_prepare() {
+	debug-print-function ${FUNCNAME} "${@}"
+
+	default
+	rebar_set_vsn
+
+	if [[ -f rebar.lock ]]; then
+		rm rebar.lock || die
+	fi
+
+	if [[ -f rebar.config ]]; then
+		rebar_disable_coverage
+		rebar_remove_deps
+	fi
+}
+
+# @FUNCTION: rebar3_src_configure
+# @DESCRIPTION:
+# Configure with ERL_LIBS set.
+rebar3_src_configure() {
+	debug-print-function ${FUNCNAME} "${@}"
+
+	local -x ERL_LIBS="${EPREFIX}$(get_erl_libs)"
+	default
+}
+
+# @FUNCTION: rebar3_src_compile
+# @DESCRIPTION:
+# Compile project with rebar3.
+rebar3_src_compile() {
+	debug-print-function ${FUNCNAME} "${@}"
+
+	erebar3 as "${REBAR_PROFILE}" release --all
+}
+
+# @FUNCTION: rebar3_src_test
+# @DESCRIPTION:
+# Run unit tests.
+rebar3_src_test() {
+	debug-print-function ${FUNCNAME} "${@}"
+
+	erebar3 eunit -v
+}
+
+# @FUNCTION: rebar3_install_lib
+# @USAGE: <dir>
+# @DESCRIPTION:
+# Install BEAM files, include headers and native libraries.
+#
+# Function expects that project conforms to Erlang/OTP structure.
+rebar3_install_lib() {
+	debug-print-function ${FUNCNAME} "${@}"
+
+	local dest="$(get_erl_libs)/${P}"
+	insinto "${dest}"
+
+	pushd "${1?}" >/dev/null || die
+	for dir in ebin include priv; do
+		if [[ -d ${dir} && ! -L ${dir} ]]; then
+			doins -r "${dir}"
+		fi
+	done
+	popd >/dev/null || die
+}
+
+# @FUNCTION: rebar3_src_install
+# @DESCRIPTION:
+# Install built release or library.
+#
+# Function expects that project conforms to Erlang/OTP structure.
+rebar3_src_install() {
+	debug-print-function ${FUNCNAME} "${@}"
+
+	pushd "_build/${REBAR_PROFILE}" >/dev/null || die
+	if [[ -d rel/${PN} ]]; then
+		if ! declare -f rebar3_install_release >/dev/null; then
+			die "${FUNCNAME}: a custom function named 'rebar3_install_release' is required to install a release"
+		fi
+		pushd rel/${PN} >/dev/null || die
+		rebar3_install_release || die
+		popd >/dev/null || die
+	elif [[ -d lib/${PN} ]]; then
+		rebar3_install_lib lib/${PN}
+	else
+		die "No releases or libraries to install"
+	fi
+	popd >/dev/null || die
+
+	einstalldocs
+}
+
+fi
+
+EXPORT_FUNCTIONS src_prepare src_compile src_test src_install
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-15  7:17 David Seifert
  0 siblings, 0 replies; 6663+ messages in thread
From: David Seifert @ 2024-07-15  7:17 UTC (permalink / raw
  To: gentoo-commits
commit:     c25d7587a0c8f7aeef7fb39f99abca0e34ea0f51
Author:     David Seifert <soap <AT> gentoo <DOT> org>
AuthorDate: Mon Jul 15 07:17:11 2024 +0000
Commit:     David Seifert <soap <AT> gentoo <DOT> org>
CommitDate: Mon Jul 15 07:17:11 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=c25d7587
gnome.org.eclass: remove EAPI 5 and 6
Signed-off-by: David Seifert <soap <AT> gentoo.org>
 eclass/gnome.org.eclass | 19 +++++--------------
 1 file changed, 5 insertions(+), 14 deletions(-)
diff --git a/eclass/gnome.org.eclass b/eclass/gnome.org.eclass
index 760dc2ba0b66..70884edefef7 100644
--- a/eclass/gnome.org.eclass
+++ b/eclass/gnome.org.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2023 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: gnome.org.eclass
@@ -7,22 +7,19 @@
 # @AUTHOR:
 # Authors: Spidler <spidler@gentoo.org> with help of carparski.
 # eclass variable additions and documentation: Gilles Dartiguelongue <eva@gentoo.org>
-# @SUPPORTED_EAPIS: 5 6 7 8
+# @SUPPORTED_EAPIS: 7 8
 # @BLURB: Helper eclass for gnome.org hosted archives
 # @DESCRIPTION:
 # Provide a default SRC_URI for tarball hosted on gnome.org mirrors.
 
 case ${EAPI} in
-	5|6|7|8) ;;
+	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
 if [[ -z ${_GNOME_ORG_ECLASS} ]] ; then
 _GNOME_ORG_ECLASS=1
 
-# versionator inherit kept for older EAPIs due to ebuilds (potentially) relying on it
-[[ ${EAPI} == [56] ]] && inherit eapi7-ver versionator
-
 # @ECLASS_VARIABLE: GNOME_TARBALL_SUFFIX
 # @PRE_INHERIT
 # @DESCRIPTION:
@@ -33,19 +30,13 @@ _GNOME_ORG_ECLASS=1
 
 # Even though xz-utils are in @system, they must still be added to BDEPEND; see
 # https://archives.gentoo.org/gentoo-dev/msg_a0d4833eb314d1be5d5802a3b710e0a4.xml
-if [[ ${GNOME_TARBALL_SUFFIX} == "xz" ]]; then
-	if [[ ${EAPI} != [56] ]]; then
-		BDEPEND="app-arch/xz-utils"
-	else
-		DEPEND="app-arch/xz-utils"
-	fi
-fi
+[[ ${GNOME_TARBALL_SUFFIX} == "xz" ]] && BDEPEND="app-arch/xz-utils"
 
 # @ECLASS_VARIABLE: GNOME_ORG_MODULE
 # @DESCRIPTION:
 # Name of the module as hosted on gnome.org mirrors.
 # Leave unset if package name matches module name.
-: "${GNOME_ORG_MODULE:=$PN}"
+: "${GNOME_ORG_MODULE:=${PN}}"
 
 # @ECLASS_VARIABLE: GNOME_ORG_RELEASE
 # @INTERNAL
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-15  7:17 David Seifert
  0 siblings, 0 replies; 6663+ messages in thread
From: David Seifert @ 2024-07-15  7:17 UTC (permalink / raw
  To: gentoo-commits
commit:     c217f7f5b128ab7af67fe085716dbcec993d6b7f
Author:     David Seifert <soap <AT> gentoo <DOT> org>
AuthorDate: Mon Jul 15 07:17:10 2024 +0000
Commit:     David Seifert <soap <AT> gentoo <DOT> org>
CommitDate: Mon Jul 15 07:17:10 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=c217f7f5
gnome2.eclass: remove EAPI 6
Signed-off-by: David Seifert <soap <AT> gentoo.org>
 eclass/gnome2.eclass | 38 +++++++++++---------------------------
 1 file changed, 11 insertions(+), 27 deletions(-)
diff --git a/eclass/gnome2.eclass b/eclass/gnome2.eclass
index 66de2df97f9f..9ef5d92a1c9e 100644
--- a/eclass/gnome2.eclass
+++ b/eclass/gnome2.eclass
@@ -4,7 +4,7 @@
 # @ECLASS: gnome2.eclass
 # @MAINTAINER:
 # gnome@gentoo.org
-# @SUPPORTED_EAPIS: 6 7 8
+# @SUPPORTED_EAPIS: 7 8
 # @PROVIDES: gnome2-utils
 # @BLURB: Provides phases for Gnome/Gtk+ based packages.
 # @DESCRIPTION:
@@ -12,7 +12,7 @@
 # GNOME framework. For additional functions, see gnome2-utils.eclass.
 
 case ${EAPI} in
-	6|7|8) ;;
+	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
@@ -22,11 +22,9 @@ _GNOME2_ECLASS=1
 # @ECLASS_VARIABLE: GNOME2_EAUTORECONF
 # @DEFAULT_UNSET
 # @DESCRIPTION:
-# Run eautoreconf instead of only elibtoolize
-GNOME2_EAUTORECONF=${GNOME2_EAUTORECONF:-""}
+# Run eautoreconf instead of only elibtoolize if set to "yes".
 
 [[ ${GNOME2_EAUTORECONF} == yes ]] && inherit autotools
-[[ ${EAPI} == 6 ]] && inherit ltprune
 
 inherit libtool gnome.org gnome2-utils xdg
 
@@ -34,7 +32,6 @@ inherit libtool gnome.org gnome2-utils xdg
 # @DEFAULT_UNSET
 # @DESCRIPTION:
 # Extra options passed to elibtoolize
-ELTCONF=${ELTCONF:-""}
 
 # @ECLASS_VARIABLE: GNOME2_ECLASS_GIO_MODULES
 # @INTERNAL
@@ -42,13 +39,10 @@ ELTCONF=${ELTCONF:-""}
 # Array containing glib GIO modules
 
 # @ECLASS_VARIABLE: GNOME2_LA_PUNT
+# @DEFAULT_UNSET
 # @DESCRIPTION:
-# In EAPI 6, it relies on prune_libtool_files (from ltprune.eclass) for
-# this. Later EAPIs use find ... -delete. Available values for GNOME2_LA_PUNT:
-# - "no": will not clean any .la files
-# - "yes": will run prune_libtool_files --modules
-# - If it is not set, it will run prune_libtool_files
-GNOME2_LA_PUNT=${GNOME2_LA_PUNT:-""}
+# If set to "no", no .la files will be cleaned, otherwise
+# will run "find ... -delete" in src_install.
 
 # @FUNCTION: gnome2_src_prepare
 # @DESCRIPTION:
@@ -141,8 +135,7 @@ gnome2_src_install() {
 	export GCONF_DISABLE_MAKEFILE_SCHEMA_INSTALL="1"
 
 	local sk_tmp_dir="/var/lib/scrollkeeper"
-	# scrollkeeper-update from rarian doesn't do anything. Then, since eapi6
-	# we stop taking care of it
+	# scrollkeeper-update from rarian doesn't do anything.
 	#
 	# if this is not present, scrollkeeper-update may segfault and
 	# create bogus directories in /var/lib/
@@ -150,9 +143,8 @@ gnome2_src_install() {
 
 	unset GCONF_DISABLE_MAKEFILE_SCHEMA_INSTALL
 
-	# Handle documentation as 'default' for eapi5, bug #373131
-	# Since eapi6 this is handled by default on its own plus MAINTAINERS and HACKING
-	# files that are really common in gnome packages (bug #573390)
+	# Install MAINTAINERS and HACKING which are really common
+	# in gnome packages (bug #573390)
 	local d
 	for d in HACKING MAINTAINERS; do
 		[[ -s ${d} ]] && dodoc "${d}"
@@ -170,16 +162,8 @@ gnome2_src_install() {
 	rm -rf "${ED}/usr/share/applications/mimeinfo.cache" || die
 
 	# Delete all .la files
-	if has ${EAPI} 6; then
-		case "${GNOME2_LA_PUNT}" in
-			yes)    prune_libtool_files --modules;;
-			no)     ;;
-			*)      prune_libtool_files;;
-		esac
-	else
-		if [[ ${GNOME2_LA_PUNT} != 'no' ]]; then
-			find "${ED}" -name '*.la' -delete || die
-		fi
+	if [[ ${GNOME2_LA_PUNT} != no ]]; then
+		find "${ED}" -type f -name '*.la' -delete || die
 	fi
 }
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-15  7:17 David Seifert
  0 siblings, 0 replies; 6663+ messages in thread
From: David Seifert @ 2024-07-15  7:17 UTC (permalink / raw
  To: gentoo-commits
commit:     522ff35dae0aa2ee48111d7c4ffad9e749e72cde
Author:     David Seifert <soap <AT> gentoo <DOT> org>
AuthorDate: Mon Jul 15 07:17:12 2024 +0000
Commit:     David Seifert <soap <AT> gentoo <DOT> org>
CommitDate: Mon Jul 15 07:17:12 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=522ff35d
gnome2-utils.eclass: remove EAPI 5 and 6
Closes: https://github.com/gentoo/gentoo/pull/37081
Signed-off-by: David Seifert <soap <AT> gentoo.org>
 eclass/gnome2-utils.eclass | 97 ++++++++++++++++------------------------------
 1 file changed, 34 insertions(+), 63 deletions(-)
diff --git a/eclass/gnome2-utils.eclass b/eclass/gnome2-utils.eclass
index bbee2a419dfc..dd4014c09bf7 100644
--- a/eclass/gnome2-utils.eclass
+++ b/eclass/gnome2-utils.eclass
@@ -4,7 +4,7 @@
 # @ECLASS: gnome2-utils.eclass
 # @MAINTAINER:
 # gnome@gentoo.org
-# @SUPPORTED_EAPIS: 5 6 7 8
+# @SUPPORTED_EAPIS: 7 8
 # @PROVIDES: xdg-utils
 # @BLURB: Auxiliary functions commonly used by Gnome packages.
 # @DESCRIPTION:
@@ -15,13 +15,12 @@
 #  * GConf schemas management
 #  * scrollkeeper (old Gnome help system) management
 
-[[ ${EAPI} == 5 ]] && inherit multilib
 # toolchain-funs.eclass: tc-is-cross-compiler
 # xdg-utils.eclass: xdg_environment_reset, xdg_icon_cache_update
 inherit toolchain-funcs xdg-utils
 
 case ${EAPI} in
-	5|6|7|8) ;;
+	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
@@ -100,7 +99,7 @@ gnome2_environment_reset() {
 	# Ensure we don't rely on dconf/gconf while building, bug #511946
 	export GSETTINGS_BACKEND="memory"
 
-	if has ${EAPI} 6 7; then
+	if [[ ${EAPI} == 7 ]]; then
 		# Try to cover the packages honoring this variable, bug #508124
 		export GST_INSPECT="$(type -P true)"
 
@@ -126,7 +125,7 @@ gnome2_gconf_savelist() {
 # using gconftool-2.
 # This function should be called from pkg_postinst.
 gnome2_gconf_install() {
-	local updater="${EROOT%/}${GCONFTOOL_BIN}"
+	local updater="${EROOT}${GCONFTOOL_BIN}"
 
 	if [[ -z "${GNOME2_ECLASS_SCHEMAS}" ]]; then
 		debug-print "No GNOME 2 GConf schemas found"
@@ -148,15 +147,15 @@ gnome2_gconf_install() {
 
 	# We are ready to install the GCONF Scheme now
 	unset GCONF_DISABLE_MAKEFILE_SCHEMA_INSTALL
-	export GCONF_CONFIG_SOURCE="$("${updater}" --get-default-source | sed "s;:/;:${ROOT%/}/;")"
+	export GCONF_CONFIG_SOURCE="$("${updater}" --get-default-source | sed "s;:/;:${ROOT}/;")"
 
 	einfo "Installing GNOME 2 GConf schemas"
 
 	local F
 	for F in ${GNOME2_ECLASS_SCHEMAS}; do
-		if [[ -e "${EROOT%/}/${F}" ]]; then
+		if [[ -e "${EROOT}/${F}" ]]; then
 			debug-print "Installing schema: ${F}"
-			"${updater}" --makefile-install-rule "${EROOT%/}/${F}" 1>/dev/null
+			"${updater}" --makefile-install-rule "${EROOT}/${F}" 1>/dev/null
 		fi
 	done
 
@@ -174,7 +173,7 @@ gnome2_gconf_install() {
 # Removes schema files previously installed by the current ebuild from Gconf's
 # database.
 gnome2_gconf_uninstall() {
-	local updater="${EROOT%/}${GCONFTOOL_BIN}"
+	local updater="${EROOT}${GCONFTOOL_BIN}"
 
 	if [[ -z "${GNOME2_ECLASS_SCHEMAS}" ]]; then
 		debug-print "No GNOME 2 GConf schemas found"
@@ -194,15 +193,15 @@ gnome2_gconf_uninstall() {
 	fi
 
 	unset GCONF_DISABLE_MAKEFILE_SCHEMA_INSTALL
-	export GCONF_CONFIG_SOURCE="$("${updater}" --get-default-source | sed "s;:/;:${ROOT%/}/;")"
+	export GCONF_CONFIG_SOURCE="$("${updater}" --get-default-source | sed "s;:/;:${ROOT}/;")"
 
 	einfo "Uninstalling GNOME 2 GConf schemas"
 
 	local F
 	for F in ${GNOME2_ECLASS_SCHEMAS}; do
-		if [[ -e "${EROOT%/}/${F}" ]]; then
+		if [[ -e "${EROOT}/${F}" ]]; then
 			debug-print "Uninstalling gconf schema: ${F}"
-			"${updater}" --makefile-uninstall-rule "${EROOT%/}/${F}" 1>/dev/null
+			"${updater}" --makefile-uninstall-rule "${EROOT}/${F}" 1>/dev/null
 		fi
 	done
 
@@ -221,31 +220,29 @@ gnome2_gconf_uninstall() {
 # calls to scrollkeeper-update and sandbox violations.
 # This function should be called from src_prepare.
 gnome2_omf_fix() {
-	local omf_makefiles filename
-
-	omf_makefiles="$@"
+	local omf_makefiles=( "$@" )
 
 	if [[ -f ${S}/omf.make ]] ; then
-		omf_makefiles="${omf_makefiles} ${S}/omf.make"
+		omf_makefiles+=( "${S}"/omf.make )
 	fi
 
 	if [[ -f ${S}/gnome-doc-utils.make ]] ; then
-		omf_makefiles="${omf_makefiles} ${S}/gnome-doc-utils.make"
+		omf_makefiles+=( "${S}"/gnome-doc-utils.make )
 	fi
 
 	# testing fixing of all makefiles found
 	# The sort is important to ensure .am is listed before the respective .in for
 	# maintainer mode regeneration not kicking in due to .am being newer than .in
-	for filename in $(find "${S}" -name "Makefile.in" -o -name "Makefile.am" |sort) ; do
-		omf_makefiles="${omf_makefiles} ${filename}"
-	done
+	local filename
+	while IFS="" read -r filename ; do
+		omf_makefiles+=( "${filename}" )
+	done < <(find "${S}" -name "Makefile.in" -o -name "Makefile.am" | sort)
 
 	ebegin "Fixing OMF Makefiles"
 
-	local retval=0
+	local omf retval=0
 	local fails=( )
-
-	for omf in ${omf_makefiles} ; do
+	for omf in "${omf_makefiles[@]}" ; do
 		sed -i -e 's:scrollkeeper-update:true:' "${omf}"
 		retval=$?
 
@@ -253,7 +250,7 @@ gnome2_omf_fix() {
 			debug-print "updating of ${omf} failed"
 
 			# Add to the list of failures
-			fails[$(( ${#fails[@]} + 1 ))]=$omf
+			fails+=( "${omf}" )
 
 			retval=2
 		fi
@@ -261,6 +258,7 @@ gnome2_omf_fix() {
 
 	eend $retval
 
+	local f
 	for f in "${fails[@]}" ; do
 		eerror "Failed to update OMF Makefile $f"
 	done
@@ -282,7 +280,7 @@ gnome2_scrollkeeper_savelist() {
 # Updates the global scrollkeeper database.
 # This function should be called from pkg_postinst and pkg_postrm.
 gnome2_scrollkeeper_update() {
-	local updater="${EROOT%/}${SCROLLKEEPER_UPDATE_BIN}"
+	local updater="${EROOT}${SCROLLKEEPER_UPDATE_BIN}"
 
 	if [[ -z "${GNOME2_ECLASS_SCROLLS}" ]]; then
 		debug-print "No scroll cache to update"
@@ -303,7 +301,7 @@ gnome2_scrollkeeper_update() {
 	fi
 
 	ebegin "Updating scrollkeeper database ..."
-	"${updater}" -q -p "${EROOT%/}${SCROLLKEEPER_DIR}"
+	"${updater}" -q -p "${EROOT}${SCROLLKEEPER_DIR}"
 	eend $?
 }
 
@@ -324,7 +322,7 @@ gnome2_schemas_savelist() {
 # Updates GSettings schemas.
 # This function should be called from pkg_postinst and pkg_postrm.
 gnome2_schemas_update() {
-	local updater="${EROOT%/}${GLIB_COMPILE_SCHEMAS}"
+	local updater="${EROOT}${GLIB_COMPILE_SCHEMAS}"
 
 	if tc-is-cross-compiler ; then
 		ewarn "Updating of GSettings schemas skipped due to cross-compilation."
@@ -340,7 +338,7 @@ gnome2_schemas_update() {
 	fi
 
 	ebegin "Updating GSettings schemas"
-	${updater} --allow-any-name "$@" "${EROOT%/}/usr/share/glib-2.0/schemas" &>/dev/null
+	${updater} --allow-any-name "$@" "${EROOT}/usr/share/glib-2.0/schemas" &>/dev/null
 	eend $?
 }
 
@@ -360,8 +358,8 @@ gnome2_gdk_pixbuf_savelist() {
 # Updates gdk-pixbuf loader cache if GNOME2_ECLASS_GDK_PIXBUF_LOADERS has some.
 # This function should be called from pkg_postinst and pkg_postrm.
 gnome2_gdk_pixbuf_update() {
-	local updater="${EROOT%/}/usr/bin/${CHOST}-gdk-pixbuf-query-loaders"
-	[[ -x ${updater} ]] || updater="${EROOT%/}/usr/bin/gdk-pixbuf-query-loaders"
+	local updater="${EROOT}/usr/bin/${CHOST}-gdk-pixbuf-query-loaders"
+	[[ -x ${updater} ]] || updater="${EROOT}/usr/bin/gdk-pixbuf-query-loaders"
 
 	if tc-is-cross-compiler ; then
 		ewarn "Updating of gdk-pixbuf loader cache skipped due to cross-compilation."
@@ -380,7 +378,7 @@ gnome2_gdk_pixbuf_update() {
 	local tmp_file=$(mktemp "${T}"/tmp.XXXXXXXXXX) || die "Failed to create temporary file"
 	${updater} 1> "${tmp_file}" &&
 	chmod 0644 "${tmp_file}" &&
-	cp -f "${tmp_file}" "${EROOT%/}/usr/$(get_libdir)/gdk-pixbuf-2.0/2.10.0/loaders.cache" &&
+	cp -f "${tmp_file}" "${EROOT}/usr/$(get_libdir)/gdk-pixbuf-2.0/2.10.0/loaders.cache" &&
 	rm "${tmp_file}" # don't replace this with mv, required for SELinux support
 	eend $?
 }
@@ -398,7 +396,7 @@ gnome2_query_immodules_gtk2() {
 	fi
 
 	ebegin "Updating gtk2 input method module cache"
-	GTK_IM_MODULE_FILE="${EROOT%/}/usr/$(get_libdir)/gtk-2.0/2.10.0/immodules.cache" \
+	GTK_IM_MODULE_FILE="${EROOT}/usr/$(get_libdir)/gtk-2.0/2.10.0/immodules.cache" \
 		"${updater}" --update-cache
 	eend $?
 }
@@ -416,7 +414,7 @@ gnome2_query_immodules_gtk3() {
 	fi
 
 	ebegin "Updating gtk3 input method module cache"
-	GTK_IM_MODULE_FILE="${EROOT%/}/usr/$(get_libdir)/gtk-3.0/3.0.0/immodules.cache" \
+	GTK_IM_MODULE_FILE="${EROOT}/usr/$(get_libdir)/gtk-3.0/3.0.0/immodules.cache" \
 		"${updater}" --update-cache
 	eend $?
 }
@@ -426,8 +424,8 @@ gnome2_query_immodules_gtk3() {
 # Updates glib's gio modules cache.
 # This function should be called from pkg_postinst and pkg_postrm.
 gnome2_giomodule_cache_update() {
-	local updater="${EROOT%/}/usr/bin/${CHOST}-gio-querymodules"
-	[[ -x ${updater} ]] || updater="${EROOT%/}/usr/bin/gio-querymodules"
+	local updater="${EROOT}/usr/bin/${CHOST}-gio-querymodules"
+	[[ -x ${updater} ]] || updater="${EROOT}/usr/bin/gio-querymodules"
 
 	if tc-is-cross-compiler ; then
 		ewarn "Updating of GIO modules cache skipped due to cross-compilation."
@@ -443,7 +441,7 @@ gnome2_giomodule_cache_update() {
 	fi
 
 	ebegin "Updating GIO modules cache"
-	${updater} "${EROOT%/}"/usr/$(get_libdir)/gio/modules
+	${updater} "${EROOT}"/usr/$(get_libdir)/gio/modules
 	eend $?
 }
 
@@ -486,30 +484,3 @@ gnome2_disable_deprecation_warning() {
 		ewarn "Failed to disable deprecation warnings in ${makefile}"
 	done
 }
-
-case ${EAPI} in
-5|6)
-
-# @FUNCTION: gnome2_icon_savelist
-# @DESCRIPTION:
-# Find the icons that are about to be installed and save their location
-# in the GNOME2_ECLASS_ICONS environment variable. This is only
-# necessary for eclass implementations that call
-# gnome2_icon_cache_update conditionally.
-# This function should be called from pkg_preinst.
-gnome2_icon_savelist() {
-	pushd "${ED}" > /dev/null || die
-	export GNOME2_ECLASS_ICONS=$(find 'usr/share/icons' -maxdepth 1 -mindepth 1 -type d 2> /dev/null)
-	popd > /dev/null || die
-}
-
-# @FUNCTION: gnome2_icon_cache_update
-# @DESCRIPTION:
-# Updates Gtk+ icon cache files under /usr/share/icons.
-# Deprecated. Please use xdg_icon_cache_update from xdg-utils.eclass
-gnome2_icon_cache_update() {
-	xdg_icon_cache_update
-}
-
-;;
-esac
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-15 19:18 Andrew Ammerlaan
  0 siblings, 0 replies; 6663+ messages in thread
From: Andrew Ammerlaan @ 2024-07-15 19:18 UTC (permalink / raw
  To: gentoo-commits
commit:     da6193c02d0f4d9b96ce9d231e32b564f33b18ee
Author:     James Calligeros <jcalligeros99 <AT> gmail <DOT> com>
AuthorDate: Thu Jun 27 05:56:44 2024 +0000
Commit:     Andrew Ammerlaan <andrewammerlaan <AT> gentoo <DOT> org>
CommitDate: Mon Jul 15 19:17:06 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=da6193c0
kernel-{build,install}.eclass: make kernel install paths match release
dist-kernel releases are required to match the package's version, with
'_' substituted for '-' as per kernel release format rules. Curiously,
we made no such substitution on the kernel install directory names.
The consequence of this is that Catalyst has technically only been
working with dist-kernels by pure coincidence - it had never been tested
with kernels containing '_' in ${PV}. When attempting to build install
media for the Gentoo Asahi project, which necessitates using kernels
versioned with '_p*', Catalyst's call to Dracut's --kver argument
passes in the name of the source directory while Dracut expects
the kernel release (module directory).
Make sure that all directories installed by the kernel match the
kernel's own idea of its version exactly. This fixes Catalyst,
makes directories like /usr/src/linux-* consistent with /lib/modules
For compatibility with existing bin kernels, KV_FULL will be
set to ${PV}${KV_LOCALVERSION} in kernel-install.eclass if it
has not been explicitly set elsewhere.
Signed-off-by: James Calligeros <jcalligeros99 <AT> gmail.com>
Signed-off-by: Andrew Ammerlaan <andrewammerlaan <AT> gentoo.org>
 eclass/kernel-build.eclass   | 46 ++++++++++++++++++----------------
 eclass/kernel-install.eclass | 59 ++++++++++++++++++++++++++------------------
 2 files changed, 60 insertions(+), 45 deletions(-)
diff --git a/eclass/kernel-build.eclass b/eclass/kernel-build.eclass
index 1f0b07fdc3f9..89167124802b 100644
--- a/eclass/kernel-build.eclass
+++ b/eclass/kernel-build.eclass
@@ -20,6 +20,14 @@
 # the kernel and installing it along with its modules and subset
 # of sources needed to build external modules.
 
+# @ECLASS_VARIABLE: KV_FULL
+# @DEFAULT_UNSET
+# @DESCRIPTION:
+# A string containing the full kernel release version, e.g.
+# '6.9.6-gentoo-dist'. This is used to ensure consistency between the
+# kernel's release version and Gentoo's tooling. This is set by
+# kernel-build_src_configure() once we have a kernel.release file.
+
 case ${EAPI} in
 	8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
@@ -225,6 +233,12 @@ kernel-build_src_configure() {
 	emake O="${WORKDIR}"/modprep "${MAKEARGS[@]}" olddefconfig
 	emake O="${WORKDIR}"/modprep "${MAKEARGS[@]}" modules_prepare
 	cp -pR "${WORKDIR}"/modprep "${WORKDIR}"/build || die
+
+	# Now that we have a release file, set KV_FULL
+	if [[ -z ${KV_FULL} ]]; then
+		local relfile=${WORKDIR}/build/include/config/kernel.release
+		KV_FULL=$(<"${relfile}") || die
+	fi
 }
 
 # @FUNCTION: kernel-build_src_compile
@@ -254,20 +268,15 @@ kernel-build_src_test() {
 		INSTALL_MOD_PATH="${T}" INSTALL_MOD_STRIP="${strip_args}" \
 		modules_install
 
-	local dir_ver=${PV}${KV_LOCALVERSION}
-	local relfile=${WORKDIR}/build/include/config/kernel.release
-	local module_ver
-	module_ver=$(<"${relfile}") || die
-
-	kernel-install_test "${module_ver}" \
+	kernel-install_test "${KV_FULL}" \
 		"${WORKDIR}/build/$(dist-kernel_get_image_path)" \
-		"${T}/lib/modules/${module_ver}"
+		"${T}/lib/modules/${KV_FULL}"
 }
 
 # @FUNCTION: kernel-build_src_install
 # @DESCRIPTION:
 # Install the built kernel along with subset of sources
-# into /usr/src/linux-${PV}.  Install the modules.  Save the config.
+# into /usr/src/linux-${KV_FULL}.  Install the modules.  Save the config.
 kernel-build_src_install() {
 	debug-print-function ${FUNCNAME} "${@}"
 
@@ -304,8 +313,7 @@ kernel-build_src_install() {
 	# note: we're using mv rather than doins to save space and time
 	# install main and arch-specific headers first, and scripts
 	local kern_arch=$(tc-arch-kernel)
-	local dir_ver=${PV}${KV_LOCALVERSION}
-	local kernel_dir=/usr/src/linux-${dir_ver}
+	local kernel_dir=/usr/src/linux-${KV_FULL}
 
 	if use sparc ; then
 		# We don't want tc-arch-kernel's sparc64, even though we do
@@ -378,10 +386,6 @@ kernel-build_src_install() {
 	# strip empty directories
 	find "${D}" -type d -empty -exec rmdir {} + || die
 
-	local relfile=${ED}${kernel_dir}/include/config/kernel.release
-	local module_ver
-	module_ver=$(<"${relfile}") || die
-
 	# warn when trying to "make" a dist-kernel
 	cat <<-EOF >> "${ED}${kernel_dir}/Makefile" || die
 
@@ -399,12 +403,12 @@ kernel-build_src_install() {
 	echo "${CATEGORY}/${PF}:${SLOT}" > "${ED}${kernel_dir}/dist-kernel" || die
 
 	# fix source tree and build dir symlinks
-	dosym "../../../${kernel_dir}" "/lib/modules/${module_ver}/build"
-	dosym "../../../${kernel_dir}" "/lib/modules/${module_ver}/source"
+	dosym "../../../${kernel_dir}" "/lib/modules/${KV_FULL}/build"
+	dosym "../../../${kernel_dir}" "/lib/modules/${KV_FULL}/source"
 	if [[ "${image_path}" == *vmlinux* ]]; then
-		dosym "../../../${kernel_dir}/${image_path}" "/lib/modules/${module_ver}/vmlinux"
+		dosym "../../../${kernel_dir}/${image_path}" "/lib/modules/${KV_FULL}/vmlinux"
 	else
-		dosym "../../../${kernel_dir}/${image_path}" "/lib/modules/${module_ver}/vmlinuz"
+		dosym "../../../${kernel_dir}/${image_path}" "/lib/modules/${KV_FULL}/vmlinuz"
 	fi
 
 	if [[ ${KERNEL_IUSE_MODULES_SIGN} ]]; then
@@ -435,7 +439,7 @@ kernel-build_src_install() {
 				--conf "${T}/empty-file"
 				--confdir "${T}/empty-directory"
 				--kernel-image "${image}"
-				--kmoddir "${ED}/lib/modules/${dir_ver}"
+				--kmoddir "${ED}/lib/modules/${KV_FULL}"
 				--kver "${dir_ver}"
 				--verbose
 				--compress="xz -9e --check=crc32"
@@ -462,7 +466,7 @@ kernel-build_src_install() {
 				--linux="${image}"
 				--initrd="${image%/*}/initrd"
 				--cmdline="${KERNEL_GENERIC_UKI_CMDLINE}"
-				--uname="${dir_ver}"
+				--uname="${KV_FULL}"
 				--output="${image%/*}/uki.efi"
 			)
 
@@ -520,7 +524,7 @@ kernel-build_pkg_postinst() {
 			ewarn
 			ewarn "MODULES_SIGN_KEY was not set, this means the kernel build system"
 			ewarn "automatically generated the signing key. This key was installed"
-			ewarn "in ${EROOT}/usr/src/linux-${PV}${KV_LOCALVERSION}/certs"
+			ewarn "in ${EROOT}/usr/src/linux-${KV_FULL}/certs"
 			ewarn "and will also be included in any binary packages."
 			ewarn "Please take appropriate action to protect the key!"
 			ewarn
diff --git a/eclass/kernel-install.eclass b/eclass/kernel-install.eclass
index 9698b6be3562..a90eae86123c 100644
--- a/eclass/kernel-install.eclass
+++ b/eclass/kernel-install.eclass
@@ -26,6 +26,15 @@
 # If set to a non-null value, adds IUSE=generic-uki and required
 # logic to install a generic unified kernel image.
 
+# @ECLASS_VARIABLE: KV_FULL
+# @DEFAULT_UNSET
+# @DESCRIPTION:
+# A string containing the full kernel release version, e.g.
+# '6.9.6-gentoo-dist'. Defaults to ${PV}${KV_LOCALVERSION},
+# but can be set by the ebuild when this default value does
+# not match the kernel release. kernel-build.eclass sets this
+# to whatever is in the built kernel's kernel.release file.
+
 # @ECLASS_VARIABLE: KV_LOCALVERSION
 # @DEFAULT_UNSET
 # @DESCRIPTION:
@@ -584,40 +593,40 @@ kernel-install_src_test() {
 kernel-install_pkg_preinst() {
 	debug-print-function ${FUNCNAME} "${@}"
 
-	local dir_ver=${PV}${KV_LOCALVERSION}
-	local kernel_dir=${ED}/usr/src/linux-${dir_ver}
-	local relfile=${kernel_dir}/include/config/kernel.release
+	# Set KV_FULL to ${PV}${KV_LOCALVERSION} if it hasn't
+	# been set elsewhere for backward compatibility with existing
+	# bin-kernel packages
+	if [[ -z ${KV_FULL} ]]; then
+		KV_FULL=${PV}${KV_LOCALVERSION}
+	fi
+
+	local kernel_dir=${ED}/usr/src/linux-${KV_FULL}
 	local image_path=$(dist-kernel_get_image_path)
 	[[ ! -d ${kernel_dir} ]] &&
 		die "Kernel directory ${kernel_dir} not installed!"
-	[[ ! -f ${relfile} ]] &&
-		die "Release file ${relfile} not installed!"
-	local release
-	release="$(<"${relfile}")" || die
-	DIST_KERNEL_RELEASE="${release}"
 
 	# perform the version check for release ebuilds only
 	if [[ ${PV} != *9999 ]]; then
 		local expected_ver=$(dist-kernel_PV_to_KV "${PV}")
 
-		if [[ ${release} != ${expected_ver}* ]]; then
+		if [[ ${KV_FULL} != ${expected_ver}* ]]; then
 			eerror "Kernel release mismatch!"
 			eerror "  expected (PV): ${expected_ver}*"
-			eerror "          found: ${release}"
+			eerror "          found: ${KV_FULL}"
 			eerror "Please verify that you are applying the correct patches."
-			die "Kernel release mismatch (${release} instead of ${expected_ver}*)"
+			die "Kernel release mismatch (${KV_FULL} instead of ${expected_ver}*)"
 		fi
 	fi
 
 	if [[ -L ${EROOT}/lib && ${EROOT}/lib -ef ${EROOT}/usr/lib ]]; then
 		# Adjust symlinks for merged-usr.
-		rm "${ED}/lib/modules/${release}"/{build,source} || die
-		dosym "../../../src/linux-${dir_ver}" "/usr/lib/modules/${release}/build"
-		dosym "../../../src/linux-${dir_ver}" "/usr/lib/modules/${release}/source"
+		rm "${ED}/lib/modules/${KV_FULL}"/{build,source} || die
+		dosym "../../../src/linux-${KV_FULL}" "/usr/lib/modules/${KV_FULL}/build"
+		dosym "../../../src/linux-${KV_FULL}" "/usr/lib/modules/${KV_FULL}/source"
 		for file in vmlinux vmlinuz; do
-			if [[ -L "${ED}/lib/modules/${release}/${file}" ]]; then
-				rm "${ED}/lib/modules/${release}/${file}" || die
-				dosym "../../../src/linux-${dir_ver}/${image_path}" "/usr/lib/modules/${release}/${file}"
+			if [[ -L "${ED}/lib/modules/${KV_FULL}/${file}" ]]; then
+				rm "${ED}/lib/modules/${KV_FULL}/${file}" || die
+				dosym "../../../src/linux-${KV_FULL}/${image_path}" "/usr/lib/modules/${KV_FULL}/${file}"
 			fi
 		done
 	fi
@@ -691,13 +700,12 @@ kernel-install_install_all() {
 kernel-install_pkg_postinst() {
 	debug-print-function ${FUNCNAME} "${@}"
 
-	local dir_ver=${PV}${KV_LOCALVERSION}
-	kernel-install_update_symlink "${EROOT}/usr/src/linux" "${dir_ver}"
+	kernel-install_update_symlink "${EROOT}/usr/src/linux" "${KV_FULL}"
 	dist-kernel_compressed_module_cleanup \
-		"${EROOT}/lib/modules/${DIST_KERNEL_RELEASE}"
+		"${EROOT}/lib/modules/${KV_FULL}"
 
 	if [[ -z ${ROOT} ]]; then
-		kernel-install_install_all "${dir_ver}"
+		kernel-install_install_all "${KV_FULL}"
 	fi
 
 	if [[ ${KERNEL_IUSE_GENERIC_UKI} ]] && use generic-uki; then
@@ -721,8 +729,7 @@ kernel-install_pkg_postrm() {
 	debug-print-function ${FUNCNAME} "${@}"
 
 	if [[ -z ${ROOT} && ! ${KERNEL_IUSE_GENERIC_UKI} ]]; then
-		local dir_ver=${PV}${KV_LOCALVERSION}
-		local kernel_dir=${EROOT}/usr/src/linux-${dir_ver}
+		local kernel_dir=${EROOT}/usr/src/linux-${KV_FULL}
 		local image_path=$(dist-kernel_get_image_path)
 		ebegin "Removing initramfs"
 		rm -f "${kernel_dir}/${image_path%/*}"/{initrd,uki.efi} &&
@@ -737,7 +744,11 @@ kernel-install_pkg_postrm() {
 kernel-install_pkg_config() {
 	[[ -z ${ROOT} ]] || die "ROOT!=/ not supported currently"
 
-	kernel-install_install_all "${PV}${KV_LOCALVERSION}"
+	if [[ -z ${KV_FULL} ]]; then
+		KV_FULL=${PV}${KV_LOCALVERSION}
+	fi
+
+	kernel-install_install_all "${KV_FULL}"
 }
 
 # @FUNCTION: kernel-install_compress_modules
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-15 19:18 Andrew Ammerlaan
  0 siblings, 0 replies; 6663+ messages in thread
From: Andrew Ammerlaan @ 2024-07-15 19:18 UTC (permalink / raw
  To: gentoo-commits
commit:     0fe5755c9ab6f76d50a6e6f74f91ac559d732668
Author:     Zen <z <AT> pyl <DOT> onl>
AuthorDate: Fri Jun 28 18:04:35 2024 +0000
Commit:     Andrew Ammerlaan <andrewammerlaan <AT> gentoo <DOT> org>
CommitDate: Mon Jul 15 19:15:06 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=0fe5755c
kernel-install: Improve warning, consider alternate initrd generators
Signed-off-by: Zen <z <AT> pyl.onl>
Signed-off-by: Andrew Ammerlaan <andrewammerlaan <AT> gentoo.org>
 eclass/kernel-install.eclass | 35 ++++++++++++++++++++++++-----------
 1 file changed, 24 insertions(+), 11 deletions(-)
diff --git a/eclass/kernel-install.eclass b/eclass/kernel-install.eclass
index 77570a905ce1..9698b6be3562 100644
--- a/eclass/kernel-install.eclass
+++ b/eclass/kernel-install.eclass
@@ -63,7 +63,10 @@ _IDEPEND_BASE="
 		>=sys-kernel/installkernel-14
 	)
 	initramfs? (
-		>=sys-kernel/installkernel-14[dracut(-)]
+		|| (
+			>=sys-kernel/installkernel-14[dracut(-)]
+			>=sys-kernel/installkernel-14[ugrd(-)]
+		)
 	)
 "
 
@@ -190,7 +193,7 @@ if [[ ${KERNEL_IUSE_GENERIC_UKI} ]]; then
 	"
 	IDEPEND="
 		generic-uki? (
-			>=sys-kernel/installkernel-14[-dracut(-),-ukify(-)]
+			>=sys-kernel/installkernel-14[-dracut(-),-ugrd(-),-ukify(-)]
 		)
 		!generic-uki? (
 			${_IDEPEND_BASE}
@@ -543,16 +546,26 @@ kernel-install_pkg_pretend() {
 
 	if ! use initramfs && ! has_version "${CATEGORY}/${PN}[-initramfs]"; then
 		ewarn
-		ewarn "WARNING: The standard configuration of the Gentoo distribution"
-		ewarn "kernels requires an initramfs! You have disabled the initramfs"
-		ewarn "USE flag and as a result dracut was not pulled in as a dependency."
-		ewarn "Please ensure that you are either overriding the standard"
-		ewarn "configuration or that an alternative initramfs generation plugin"
-		ewarn "is installed for your installkernel implementation!"
-		ewarn
-		ewarn "This is an advanced use case, you are on your own to ensure"
-		ewarn "that your system is bootable!"
+		ewarn "WARNING: The default distribution kernel configuration is designed"
+		ewarn "to be used with an initramfs! Although possible, there is no guarantee"
+		ewarn "that distribution kernels will boot without an initramfs."
 		ewarn
+		ewarn "You have disabled the initramfs USE flag, and as a result the package manager"
+        ewarn "will not enforce the configuration of an initramfs generator in"
+        ewarn "sys-kernel/installkernel."
+        ewarn
+		ewarn "If you wish to use a custom initramfs generator, then please ensure that" 
+        ewarn "/sbin/installkernel is capable of calling it via a kernel installation hook,"
+        ewarn "and is also configured to use it via /etc/kernel/install.conf."
+        ewarn
+        ewarn "If you wish to boot without an initramfs, then please ensure that"
+        ewarn "all kernel drivers required to boot your system are built into the"
+        ewarn "kernel by modifying the default distribution kernel configuration"
+        ewarn "using /etc/kernel/config.d"
+        ewarn
+		ewarn "Please refer to the installkernel and distribution kernel documentation:"
+		ewarn "    https://wiki.gentoo.org/wiki/Installkernel"
+        ewarn "    https://wiki.gentoo.org/wiki/Project:Distribution_Kernel"
 	fi
 }
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-15 19:18 Andrew Ammerlaan
  0 siblings, 0 replies; 6663+ messages in thread
From: Andrew Ammerlaan @ 2024-07-15 19:18 UTC (permalink / raw
  To: gentoo-commits
commit:     fa0ab4edb83c6e9ca7729ca847fdf60bfd051fb0
Author:     James Calligeros <jcalligeros99 <AT> gmail <DOT> com>
AuthorDate: Sat Jun 29 01:55:12 2024 +0000
Commit:     Andrew Ammerlaan <andrewammerlaan <AT> gentoo <DOT> org>
CommitDate: Mon Jul 15 19:17:07 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=fa0ab4ed
kernel-build.eclass: sanity check the prepared kernel's release string
Previously, this was only checked by kernel-install_pkg_preinst(). This
means that the entire kernel would have to be built and stripped before
we knew if we had built the correct kernel or not.
Duplicate this check in kernel-build_src_configure() so that we don't waste
time and energy building an incorrectly-versioned kernel.
Signed-off-by: James Calligeros <jcalligeros99 <AT> gmail.com>
Signed-off-by: Andrew Ammerlaan <andrewammerlaan <AT> gentoo.org>
 eclass/kernel-build.eclass | 13 +++++++++++++
 1 file changed, 13 insertions(+)
diff --git a/eclass/kernel-build.eclass b/eclass/kernel-build.eclass
index 89167124802b..9ddc7793d6e6 100644
--- a/eclass/kernel-build.eclass
+++ b/eclass/kernel-build.eclass
@@ -239,6 +239,19 @@ kernel-build_src_configure() {
 		local relfile=${WORKDIR}/build/include/config/kernel.release
 		KV_FULL=$(<"${relfile}") || die
 	fi
+
+	# Make sure we are about to build the correct kernel
+	if [[ ${PV} != *9999 ]]; then
+		local expected_ver=$(dist-kernel_PV_to_KV "${PV}")
+
+		if [[ ${KV_FULL} != ${expected_ver}* ]]; then
+			eerror "Kernel version does not match PV!"
+			eerror "Source version: ${KV_FULL}"
+			eerror "Expected (PV*): ${expected_ver}*"
+			eerror "Please ensure you are applying the correct patchset."
+			die "Kernel version mismatch: got ${KV_FULL}, expected ${expected_ver}*"
+		fi
+	fi
 }
 
 # @FUNCTION: kernel-build_src_compile
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-15 19:18 Andrew Ammerlaan
  0 siblings, 0 replies; 6663+ messages in thread
From: Andrew Ammerlaan @ 2024-07-15 19:18 UTC (permalink / raw
  To: gentoo-commits
commit:     419f11ba911c0136956fdb0aba3d59ff5c1799e1
Author:     James Calligeros <jcalligeros99 <AT> gmail <DOT> com>
AuthorDate: Sat Jun 29 03:44:38 2024 +0000
Commit:     Andrew Ammerlaan <andrewammerlaan <AT> gentoo <DOT> org>
CommitDate: Mon Jul 15 19:17:08 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=419f11ba
kernel-build.eclass: check that KV_FULL matches the kernel release
We want to ensure all our installed directories are consistent and
match the kernel's own idea of its release version. Do an extra
sanity check to ensure that KV_FULL is indeed what it is supposed
to be, and bail out if it isn't.
Signed-off-by: James Calligeros <jcalligeros99 <AT> gmail.com>
Signed-off-by: Andrew Ammerlaan <andrewammerlaan <AT> gentoo.org>
 eclass/kernel-build.eclass | 10 +++++++++-
 1 file changed, 9 insertions(+), 1 deletion(-)
diff --git a/eclass/kernel-build.eclass b/eclass/kernel-build.eclass
index 9ddc7793d6e6..d8e50e75812f 100644
--- a/eclass/kernel-build.eclass
+++ b/eclass/kernel-build.eclass
@@ -235,14 +235,22 @@ kernel-build_src_configure() {
 	cp -pR "${WORKDIR}"/modprep "${WORKDIR}"/build || die
 
 	# Now that we have a release file, set KV_FULL
+	local relfile=${WORKDIR}/build/include/config/kernel.release
 	if [[ -z ${KV_FULL} ]]; then
-		local relfile=${WORKDIR}/build/include/config/kernel.release
 		KV_FULL=$(<"${relfile}") || die
 	fi
 
 	# Make sure we are about to build the correct kernel
 	if [[ ${PV} != *9999 ]]; then
 		local expected_ver=$(dist-kernel_PV_to_KV "${PV}")
+		local expected_rel=$(<"${relfile}")
+
+		if [[ ${KV_FULL} != ${expected_rel} ]]; then
+			eerror "KV_FULL mismatch!"
+			eerror "KV_FULL:  ${KV_FULL}"
+			eerror "Expected: ${expected_rel}"
+			die "KV_FULL mismatch: got ${KV_FULL}, expected ${expected_rel}"
+		fi
 
 		if [[ ${KV_FULL} != ${expected_ver}* ]]; then
 			eerror "Kernel version does not match PV!"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-15 19:18 Andrew Ammerlaan
  0 siblings, 0 replies; 6663+ messages in thread
From: Andrew Ammerlaan @ 2024-07-15 19:18 UTC (permalink / raw
  To: gentoo-commits
commit:     f2ba59930f7c125a321b2de19d1e9b52158b06bd
Author:     James Calligeros <jcalligeros99 <AT> gmail <DOT> com>
AuthorDate: Sat Jul 13 12:47:33 2024 +0000
Commit:     Andrew Ammerlaan <andrewammerlaan <AT> gentoo <DOT> org>
CommitDate: Mon Jul 15 19:17:09 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=f2ba5993
kernel-install.eclass: improve kernel version check
Now that we have an improved version check in kernel-build.eclass,
copy it here so that the two eclasses match.
Signed-off-by: James Calligeros <jcalligeros99 <AT> gmail.com>
Closes: https://github.com/gentoo/gentoo/pull/37327
Signed-off-by: Andrew Ammerlaan <andrewammerlaan <AT> gentoo.org>
 eclass/kernel-install.eclass | 10 +++++-----
 1 file changed, 5 insertions(+), 5 deletions(-)
diff --git a/eclass/kernel-install.eclass b/eclass/kernel-install.eclass
index a90eae86123c..e6f0b404dcaa 100644
--- a/eclass/kernel-install.eclass
+++ b/eclass/kernel-install.eclass
@@ -610,11 +610,11 @@ kernel-install_pkg_preinst() {
 		local expected_ver=$(dist-kernel_PV_to_KV "${PV}")
 
 		if [[ ${KV_FULL} != ${expected_ver}* ]]; then
-			eerror "Kernel release mismatch!"
-			eerror "  expected (PV): ${expected_ver}*"
-			eerror "          found: ${KV_FULL}"
-			eerror "Please verify that you are applying the correct patches."
-			die "Kernel release mismatch (${KV_FULL} instead of ${expected_ver}*)"
+			eerror "Kernel version does not match PV!"
+			eerror "Source version: ${KV_FULL}"
+			eerror "Expected (PV*): ${expected_ver}*"
+			eerror "Please ensure you are applying the correct patchset."
+			die "Kernel version mismatch: got ${KV_FULL}, expected ${expected_ver}*"
 		fi
 	fi
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-16  9:16 James Le Cuirot
  0 siblings, 0 replies; 6663+ messages in thread
From: James Le Cuirot @ 2024-07-16  9:16 UTC (permalink / raw
  To: gentoo-commits
commit:     c481cf29fcea1af132e07064b91237353298d49b
Author:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
AuthorDate: Tue Jul  9 20:23:21 2024 +0000
Commit:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
CommitDate: Tue Jul 16 09:13:34 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=c481cf29
golang-vcs-snapshot.eclass: Drop support for EAPI 6
All such usage has gone.
Signed-off-by: James Le Cuirot <chewi <AT> gentoo.org>
 eclass/golang-vcs-snapshot.eclass | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/eclass/golang-vcs-snapshot.eclass b/eclass/golang-vcs-snapshot.eclass
index d34b8a6e913d..a91ddbbe3615 100644
--- a/eclass/golang-vcs-snapshot.eclass
+++ b/eclass/golang-vcs-snapshot.eclass
@@ -1,10 +1,10 @@
-# Copyright 1999-2023 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: golang-vcs-snapshot.eclass
 # @MAINTAINER:
 # William Hubbs <williamh@gentoo.org>
-# @SUPPORTED_EAPIS: 6 7
+# @SUPPORTED_EAPIS: 7
 # @PROVIDES: golang-base
 # @BLURB: eclass to unpack VCS snapshot tarballs for Go software
 # @DEPRECATED: go-module.eclass
@@ -45,7 +45,7 @@
 # and add the vendored tarballs to ${WORKDIR}/src/${EGO_PN}/vendor
 
 case ${EAPI} in
-	6|7) ;;
+	7) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-16  9:16 James Le Cuirot
  0 siblings, 0 replies; 6663+ messages in thread
From: James Le Cuirot @ 2024-07-16  9:16 UTC (permalink / raw
  To: gentoo-commits
commit:     f29b80d18d526a13af59af83e524902f8176bfdb
Author:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
AuthorDate: Tue Jul  9 20:22:38 2024 +0000
Commit:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
CommitDate: Tue Jul 16 09:13:30 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=f29b80d1
golang-vcs.eclass: Drop support for EAPI 6
All such usage has gone.
Signed-off-by: James Le Cuirot <chewi <AT> gentoo.org>
 eclass/golang-vcs.eclass | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/eclass/golang-vcs.eclass b/eclass/golang-vcs.eclass
index 6f7a837bc15f..dee040505d23 100644
--- a/eclass/golang-vcs.eclass
+++ b/eclass/golang-vcs.eclass
@@ -1,10 +1,10 @@
-# Copyright 1999-2023 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: golang-vcs.eclass
 # @MAINTAINER:
 # William Hubbs <williamh@gentoo.org>
-# @SUPPORTED_EAPIS: 6 7
+# @SUPPORTED_EAPIS: 7
 # @PROVIDES: golang-base
 # @BLURB: Eclass for fetching and unpacking go repositories.
 # @DEPRECATED: go-module.eclass
@@ -13,7 +13,7 @@
 # of software written in the Go programming language.
 
 case ${EAPI} in
-	6|7) ;;
+	7) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-16  9:16 James Le Cuirot
  0 siblings, 0 replies; 6663+ messages in thread
From: James Le Cuirot @ 2024-07-16  9:16 UTC (permalink / raw
  To: gentoo-commits
commit:     cbd596b7eb8b3ff070313a1311454b6b041021a9
Author:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
AuthorDate: Tue Jul  9 20:23:45 2024 +0000
Commit:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
CommitDate: Tue Jul 16 09:13:35 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=cbd596b7
golang-build.eclass: Drop support for EAPI 6
All such usage has gone.
Signed-off-by: James Le Cuirot <chewi <AT> gentoo.org>
 eclass/golang-build.eclass | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/eclass/golang-build.eclass b/eclass/golang-build.eclass
index 235313bd70f5..b5218ce36572 100644
--- a/eclass/golang-build.eclass
+++ b/eclass/golang-build.eclass
@@ -1,10 +1,10 @@
-# Copyright 1999-2023 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: golang-build.eclass
 # @MAINTAINER:
 # William Hubbs <williamh@gentoo.org>
-# @SUPPORTED_EAPIS: 6 7
+# @SUPPORTED_EAPIS: 7
 # @PROVIDES: golang-base
 # @BLURB: Eclass for compiling go packages.
 # @DEPRECATED: go-module.eclass
@@ -13,7 +13,7 @@
 # functions for software written in the Go programming language.
 
 case ${EAPI} in
-	6|7) ;;
+	7) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-16  9:16 James Le Cuirot
  0 siblings, 0 replies; 6663+ messages in thread
From: James Le Cuirot @ 2024-07-16  9:16 UTC (permalink / raw
  To: gentoo-commits
commit:     8c5f61cdc06d82e142913b14ec6236ab0b5ca950
Author:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
AuthorDate: Tue Jul  9 20:24:41 2024 +0000
Commit:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
CommitDate: Tue Jul 16 09:13:36 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=8c5f61cd
golang-base.eclass: Drop support for EAPI 5 and 6
All such usage has gone.
Signed-off-by: James Le Cuirot <chewi <AT> gentoo.org>
 eclass/golang-base.eclass | 13 +++++--------
 1 file changed, 5 insertions(+), 8 deletions(-)
diff --git a/eclass/golang-base.eclass b/eclass/golang-base.eclass
index 4bba00200cfc..a2996e3b0683 100644
--- a/eclass/golang-base.eclass
+++ b/eclass/golang-base.eclass
@@ -1,10 +1,10 @@
-# Copyright 1999-2022 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: golang-base.eclass
 # @MAINTAINER:
 # William Hubbs <williamh@gentoo.org>
-# @SUPPORTED_EAPIS: 5 6 7
+# @SUPPORTED_EAPIS: 7
 # @BLURB: Eclass that provides base functions for Go packages.
 # @DEPRECATED: go-module.eclass
 # @DESCRIPTION:
@@ -12,12 +12,9 @@
 # programming language; it also provides the build-time dependency on
 # dev-lang/go.
 
-case "${EAPI:-0}" in
-	5|6|7)
-		;;
-	*)
-		die "${ECLASS}: Unsupported EAPI (EAPI=${EAPI})"
-		;;
+case ${EAPI} in
+	7) ;;
+	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
 if [[ -z ${_GOLANG_BASE} ]]; then
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-16  9:16 James Le Cuirot
  0 siblings, 0 replies; 6663+ messages in thread
From: James Le Cuirot @ 2024-07-16  9:16 UTC (permalink / raw
  To: gentoo-commits
commit:     29f0721c4bc11ef3b9d94590016c25a190bc0f20
Author:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
AuthorDate: Tue Jul  9 20:39:11 2024 +0000
Commit:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
CommitDate: Tue Jul 16 09:15:59 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=29f0721c
go-env.eclass: Add the go-env_goos() helper function
This code is taken from dev-lang/go. No other packages have code like
this, but some erroneously call `go env GOOS`, which is bad for
cross-compiling. They should use this function instead.
Signed-off-by: James Le Cuirot <chewi <AT> gentoo.org>
 eclass/go-env.eclass | 18 ++++++++++++++++++
 1 file changed, 18 insertions(+)
diff --git a/eclass/go-env.eclass b/eclass/go-env.eclass
index c839c41be0d7..be131133113b 100644
--- a/eclass/go-env.eclass
+++ b/eclass/go-env.eclass
@@ -48,6 +48,24 @@ go-env_set_compile_environment() {
 	export CGO_LDFLAGS="${CGO_LDFLAGS:-$LDFLAGS}"
 }
 
+# @FUNCTION: go-env_goos
+# @USAGE: [toolchain prefix]
+# @DESCRIPTION:
+# Returns the appropriate GOOS setting for the target operating system.
+go-env_goos() {
+	local target=${1:-${CHOST}}
+	case "${target}" in
+		*-linux*) echo linux ;;
+		*-darwin*) echo darwin ;;
+		*-freebsd*) echo freebsd ;;
+		*-netbsd*) echo netbsd ;;
+		*-openbsd*) echo openbsd ;;
+		*-solaris*) echo solaris ;;
+		*-cygwin*|*-interix*|*-winnt*) echo windows ;;
+		*) die "unknown GOOS for ${target}" ;;
+	esac
+}
+
 # @FUNCTION: go-env_goarch
 # @USAGE: [toolchain prefix]
 # @DESCRIPTION:
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-16  9:16 James Le Cuirot
  0 siblings, 0 replies; 6663+ messages in thread
From: James Le Cuirot @ 2024-07-16  9:16 UTC (permalink / raw
  To: gentoo-commits
commit:     1cf828923e730d232df90a3a057777230bc7092c
Author:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
AuthorDate: Tue Jul  9 20:28:52 2024 +0000
Commit:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
CommitDate: Tue Jul 16 09:15:36 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=1cf82892
go-env.eclass: Rewrite the go-env_goarch() logic
The previous logic was flawed, incomplete, and needlessly made use of
USE flags. We can rely on the tuple instead. Tested against all the
tuples we have in our profiles.
Closes: https://bugs.gentoo.org/935414
Signed-off-by: James Le Cuirot <chewi <AT> gentoo.org>
 eclass/go-env.eclass | 32 +++++++++++++++++---------------
 1 file changed, 17 insertions(+), 15 deletions(-)
diff --git a/eclass/go-env.eclass b/eclass/go-env.eclass
index c34c634bb600..c839c41be0d7 100644
--- a/eclass/go-env.eclass
+++ b/eclass/go-env.eclass
@@ -53,21 +53,23 @@ go-env_set_compile_environment() {
 # @DESCRIPTION:
 # Returns the appropriate GOARCH setting for the target architecture.
 go-env_goarch() {
-	# By chance most portage arch names match Go
-	local tc_arch=$(tc-arch $@)
-	case "${tc_arch}" in
-		x86)	echo 386;;
-		x64-*)	echo amd64;;
-		loong)	echo loong64;;
-		mips) if use abi_mips_o32; then
-				[[ $(tc-endian $@) = big ]] && echo mips || echo mipsle
-			elif use abi_mips_n64; then
-				[[ $(tc-endian $@) = big ]] && echo mips64 || echo mips64le
-			fi ;;
-		ppc64) [[ $(tc-endian $@) = big ]] && echo ppc64 || echo ppc64le ;;
-		riscv) echo riscv64 ;;
-		s390) echo s390x ;;
-		*)		echo "${tc_arch}";;
+	local target=${1:-${CHOST}}
+	# Some Portage arch names match Go.
+	local arch=$(tc-arch "${target}") cpu=${target%%-*}
+	case "${arch}" in
+		x86)	echo 386 ;;
+		loong)	echo loong64 ;;
+		*)		case "${cpu}" in
+					aarch64*be) echo arm64be ;;
+					arm64) echo arm64 ;;
+					arm*b*) echo armbe ;;
+					mips64*l*) echo mips64le ;;
+					mips*l*) echo mipsle ;;
+					powerpc64le*) echo ppc64le ;;
+					arm64|s390x) echo "${cpu}" ;;
+					mips64*|riscv64*|sparc64*) echo "${arch}64" ;;
+					*) echo "${arch}" ;;
+				esac ;;
 	esac
 }
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-16  9:16 James Le Cuirot
  0 siblings, 0 replies; 6663+ messages in thread
From: James Le Cuirot @ 2024-07-16  9:16 UTC (permalink / raw
  To: gentoo-commits
commit:     cc012d4940f97e9262753e8f041c2cf8012a272d
Author:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
AuthorDate: Tue Jul  9 20:26:03 2024 +0000
Commit:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
CommitDate: Tue Jul 16 09:13:37 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=cc012d49
go-env.eclass: Establish EAPI 7 and 8 as supported
Signed-off-by: James Le Cuirot <chewi <AT> gentoo.org>
 eclass/go-env.eclass | 15 +++++++--------
 1 file changed, 7 insertions(+), 8 deletions(-)
diff --git a/eclass/go-env.eclass b/eclass/go-env.eclass
index 1a2c9787a146..c34c634bb600 100644
--- a/eclass/go-env.eclass
+++ b/eclass/go-env.eclass
@@ -6,11 +6,17 @@
 # Flatcar Linux Maintainers <infra@flatcar-linux.org>
 # @AUTHOR:
 # Flatcar Linux Maintainers <infra@flatcar-linux.org>
+# @SUPPORTED_EAPIS: 7 8
 # @BLURB: Helper eclass for setting the Go compile environment. Required for cross-compiling.
 # @DESCRIPTION:
 # This eclass includes helper functions for setting the compile environment for Go ebuilds.
 # Intended to be called by other Go eclasses in an early build stage, e.g. src_unpack.
 
+case ${EAPI} in
+	7|8) ;;
+	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
+esac
+
 if [[ -z ${_GO_ENV_ECLASS} ]]; then
 _GO_ENV_ECLASS=1
 
@@ -34,14 +40,7 @@ go-env_set_compile_environment() {
 	use x86 && export GO386=$(go-env_go386)
 
 	# XXX: Hack for checking ICE (bug #912152, gcc PR113204)
-	case ${EAPI} in
-		6)
-			has_version "sys-devel/gcc[debug]" && filter-lto
-			;;
-		*)
-			has_version -b "sys-devel/gcc[debug]" && filter-lto
-			;;
-	esac
+	has_version -b "sys-devel/gcc[debug]" && filter-lto
 
 	export CGO_CFLAGS="${CGO_CFLAGS:-$CFLAGS}"
 	export CGO_CPPFLAGS="${CGO_CPPFLAGS:-$CPPFLAGS}"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-18 16:15 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-07-18 16:15 UTC (permalink / raw
  To: gentoo-commits
commit:     16a996d29fa0854707cb72647fe9bef47ee4a963
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Thu Jul 18 13:30:42 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Thu Jul 18 16:15:42 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=16a996d2
kernel-build.eclass: Fix leftover dir_ver use
Fixes: da6193c02d0f (...make kernel install paths match release)
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/kernel-build.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/kernel-build.eclass b/eclass/kernel-build.eclass
index d8e50e75812f..cf060fa83766 100644
--- a/eclass/kernel-build.eclass
+++ b/eclass/kernel-build.eclass
@@ -461,7 +461,7 @@ kernel-build_src_install() {
 				--confdir "${T}/empty-directory"
 				--kernel-image "${image}"
 				--kmoddir "${ED}/lib/modules/${KV_FULL}"
-				--kver "${dir_ver}"
+				--kver "${KV_FULL}"
 				--verbose
 				--compress="xz -9e --check=crc32"
 				--no-hostonly
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-20 12:09 Ulrich Müller
  0 siblings, 0 replies; 6663+ messages in thread
From: Ulrich Müller @ 2024-07-20 12:09 UTC (permalink / raw
  To: gentoo-commits
commit:     bc6173b5fdeb051759254745f80ef539849a6cd0
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Sun Jun 23 11:01:49 2024 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Sat Jul 20 12:08:37 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=bc6173b5
unpacker.eclass: Drop support for EAPI 6
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 eclass/unpacker.eclass | 11 ++++-------
 1 file changed, 4 insertions(+), 7 deletions(-)
diff --git a/eclass/unpacker.eclass b/eclass/unpacker.eclass
index 2957ca02d3f4..91520a36d16a 100644
--- a/eclass/unpacker.eclass
+++ b/eclass/unpacker.eclass
@@ -4,7 +4,7 @@
 # @ECLASS: unpacker.eclass
 # @MAINTAINER:
 # base-system@gentoo.org
-# @SUPPORTED_EAPIS: 6 7 8
+# @SUPPORTED_EAPIS: 7 8
 # @BLURB: helpers for extraneous file formats and consistent behavior across EAPIs
 # @DESCRIPTION:
 # Some extraneous file formats are not part of PMS, or are only in certain
@@ -16,7 +16,7 @@
 #  - support partial unpacks?
 
 case ${EAPI} in
-	6|7|8) ;;
+	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
@@ -430,10 +430,7 @@ _unpacker_get_decompressor() {
 		echo "xz -T$(makeopts_jobs) -dc" ;;
 	*.lz)
 		find_lz_unpacker() {
-			local has_version_arg="-b"
-
-			[[ ${EAPI} == 6 ]] && has_version_arg="--host-root"
-			if has_version "${has_version_arg}" ">=app-arch/xz-utils-5.4.0" ; then
+			if has_version -b ">=app-arch/xz-utils-5.4.0" ; then
 				echo xz
 				return
 			fi
@@ -537,7 +534,7 @@ _unpacker() {
 	esac
 
 	# 7z, rar and lha/lzh are handled by package manager in EAPI < 8
-	if [[ ${EAPI} != [67] ]]; then
+	if [[ ${EAPI} != 7 ]]; then
 		case ${m} in
 		*.7z)
 			arch="unpack_7z" ;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-21 13:31 Andrew Ammerlaan
  0 siblings, 0 replies; 6663+ messages in thread
From: Andrew Ammerlaan @ 2024-07-21 13:31 UTC (permalink / raw
  To: gentoo-commits
commit:     f6642547cd274ab4edd7d34b71674d1aa04a2d74
Author:     Andrew Ammerlaan <andrewammerlaan <AT> gentoo <DOT> org>
AuthorDate: Sat Jul 20 18:10:37 2024 +0000
Commit:     Andrew Ammerlaan <andrewammerlaan <AT> gentoo <DOT> org>
CommitDate: Sun Jul 21 13:29:44 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=f6642547
secureboot.eclass: check and fail early if key or cert in DER format
Bug: https://bugs.gentoo.org/936402
Signed-off-by: Andrew Ammerlaan <andrewammerlaan <AT> gentoo.org>
 eclass/secureboot.eclass | 26 +++++++++++++++++++-------
 1 file changed, 19 insertions(+), 7 deletions(-)
diff --git a/eclass/secureboot.eclass b/eclass/secureboot.eclass
index a9ba514cb7a0..4459b0341845 100644
--- a/eclass/secureboot.eclass
+++ b/eclass/secureboot.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2023 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: secureboot.eclass
@@ -44,7 +44,12 @@ case ${EAPI} in
 esac
 
 IUSE="secureboot"
-BDEPEND="secureboot? ( app-crypt/sbsigntools )"
+BDEPEND="
+	secureboot? (
+		app-crypt/sbsigntools
+		dev-libs/openssl
+	)
+"
 
 # @ECLASS_VARIABLE: SECUREBOOT_SIGN_KEY
 # @USER_VARIABLE
@@ -75,12 +80,19 @@ _secureboot_die_if_unset() {
 	if [[ -z ${SECUREBOOT_SIGN_KEY} || -z ${SECUREBOOT_SIGN_CERT} ]]; then
 		die "USE=secureboot enabled but SECUREBOOT_SIGN_KEY and/or SECUREBOOT_SIGN_CERT not set."
 	fi
-	if [[ ! ${SECUREBOOT_SIGN_KEY} == pkcs11:* && ! -r ${SECUREBOOT_SIGN_KEY} ]]; then
-		die "SECUREBOOT_SIGN_KEY=${SECUREBOOT_SIGN_KEY} not found or not readable!"
-	fi
-	if [[ ! -r ${SECUREBOOT_SIGN_CERT} ]]; then
-		die "SECUREBOOT_SIGN_CERT=${SECUREBOOT_SIGN_CERT} not found or not readable!"
+
+	# Sanity check: fail early if key/cert in DER format or does not exist
+	local openssl_args=(
+		-inform PEM -in "${SECUREBOOT_SIGN_CERT}"
+		-noout -nocert
+	)
+	if [[ ${SECUREBOOT_SIGN_KEY} == pkcs11:* ]]; then
+		openssl_args+=( -engine pkcs11 -keyform ENGINE -key "${SECUREBOOT_SIGN_KEY}" )
+	else
+		openssl_args+=( -keyform PEM -key "${SECUREBOOT_SIGN_KEY}" )
 	fi
+	openssl x509 "${openssl_args[@]}" ||
+		die "Secure Boot signing certificate or key not found or not PEM format."
 }
 
 # @FUNCTION: secureboot_pkg_setup
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-21 13:31 Andrew Ammerlaan
  0 siblings, 0 replies; 6663+ messages in thread
From: Andrew Ammerlaan @ 2024-07-21 13:31 UTC (permalink / raw
  To: gentoo-commits
commit:     1b804fa3f3ec62aabeada773b15ca408e73735d6
Author:     Andrew Ammerlaan <andrewammerlaan <AT> gentoo <DOT> org>
AuthorDate: Sat Jul 20 18:59:04 2024 +0000
Commit:     Andrew Ammerlaan <andrewammerlaan <AT> gentoo <DOT> org>
CommitDate: Sun Jul 21 13:29:45 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=1b804fa3
kernel-build.eclass: check and fail early if key or cert in DER format
Bug: https://bugs.gentoo.org/936402
Signed-off-by: Andrew Ammerlaan <andrewammerlaan <AT> gentoo.org>
 eclass/kernel-build.eclass | 24 ++++++++++++++++++++++--
 1 file changed, 22 insertions(+), 2 deletions(-)
diff --git a/eclass/kernel-build.eclass b/eclass/kernel-build.eclass
index cf060fa83766..fa01be28723f 100644
--- a/eclass/kernel-build.eclass
+++ b/eclass/kernel-build.eclass
@@ -133,8 +133,28 @@ kernel-build_pkg_setup() {
 	python-any-r1_pkg_setup
 	if [[ ${KERNEL_IUSE_MODULES_SIGN} ]]; then
 		secureboot_pkg_setup
-		if [[ -e ${MODULES_SIGN_KEY} && ${MODULES_SIGN_KEY} != pkcs11:* ]]; then
-			if [[ -e ${MODULES_SIGN_CERT} && ${MODULES_SIGN_CERT} != ${MODULES_SIGN_KEY} ]]; then
+
+		# Sanity check: fail early if key/cert in DER format or does not exist
+		local openssl_args=(
+			-noout -nocert
+		)
+		if [[ -n ${MODULES_SIGN_CERT} ]]; then
+			openssl_args+=( -inform PEM -in "${MODULES_SIGN_CERT}" )
+		else
+			# If no cert specified, we assume the pem key also contains the cert
+			openssl_args+=( -inform PEM -in "${MODULES_SIGN_KEY}" )
+		fi
+		if [[ ${MODULES_SIGN_KEY} == pkcs11:* ]]; then
+			openssl_args+=( -engine pkcs11 -keyform ENGINE -key "${MODULES_SIGN_KEY}" )
+		else
+			openssl_args+=( -keyform PEM -key "${MODULES_SIGN_KEY}" )
+		fi
+
+		openssl x509 "${openssl_args[@]}" ||
+			die "Kernel module signing certificate or key not found or not PEM format."
+
+		if [[ ${MODULES_SIGN_KEY} != pkcs11:* ]]; then
+			if [[ ${MODULES_SIGN_CERT} != ${MODULES_SIGN_KEY} ]]; then
 				MODULES_SIGN_KEY_CONTENTS="$(cat "${MODULES_SIGN_CERT}" "${MODULES_SIGN_KEY}" || die)"
 			else
 				MODULES_SIGN_KEY_CONTENTS="$(< "${MODULES_SIGN_KEY}")"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-21 13:31 Andrew Ammerlaan
  0 siblings, 0 replies; 6663+ messages in thread
From: Andrew Ammerlaan @ 2024-07-21 13:31 UTC (permalink / raw
  To: gentoo-commits
commit:     55c2a7a949695e4e70d9246b8418453093f747e4
Author:     Andrew Ammerlaan <andrewammerlaan <AT> gentoo <DOT> org>
AuthorDate: Sun Jul 21 08:51:47 2024 +0000
Commit:     Andrew Ammerlaan <andrewammerlaan <AT> gentoo <DOT> org>
CommitDate: Sun Jul 21 13:29:46 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=55c2a7a9
kernel-build.eclass: don't check key/cert if merging binary
Signed-off-by: Andrew Ammerlaan <andrewammerlaan <AT> gentoo.org>
Closes: https://github.com/gentoo/gentoo/pull/37640
Signed-off-by: Andrew Ammerlaan <andrewammerlaan <AT> gentoo.org>
 eclass/kernel-build.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/kernel-build.eclass b/eclass/kernel-build.eclass
index fa01be28723f..aca387bb5abd 100644
--- a/eclass/kernel-build.eclass
+++ b/eclass/kernel-build.eclass
@@ -131,7 +131,7 @@ fi
 # Call python-any-r1 and secureboot pkg_setup
 kernel-build_pkg_setup() {
 	python-any-r1_pkg_setup
-	if [[ ${KERNEL_IUSE_MODULES_SIGN} ]]; then
+	if [[ ${KERNEL_IUSE_MODULES_SIGN} && ${MERGE_TYPE} != binary ]]; then
 		secureboot_pkg_setup
 
 		# Sanity check: fail early if key/cert in DER format or does not exist
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-21 15:14 Andrew Ammerlaan
  0 siblings, 0 replies; 6663+ messages in thread
From: Andrew Ammerlaan @ 2024-07-21 15:14 UTC (permalink / raw
  To: gentoo-commits
commit:     46f7840350a04cbe47a1e6902baca0d638f85e6d
Author:     Andrew Ammerlaan <andrewammerlaan <AT> gentoo <DOT> org>
AuthorDate: Sun Jul 21 15:12:55 2024 +0000
Commit:     Andrew Ammerlaan <andrewammerlaan <AT> gentoo <DOT> org>
CommitDate: Sun Jul 21 15:14:15 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=46f78403
kernel-build.eclass: add missing modules-sign conditional to cert/key check
Bug: https://bugs.gentoo.org/936402
Signed-off-by: Andrew Ammerlaan <andrewammerlaan <AT> gentoo.org>
 eclass/kernel-build.eclass | 46 ++++++++++++++++++++++++----------------------
 1 file changed, 24 insertions(+), 22 deletions(-)
diff --git a/eclass/kernel-build.eclass b/eclass/kernel-build.eclass
index aca387bb5abd..cbc80bddf6f7 100644
--- a/eclass/kernel-build.eclass
+++ b/eclass/kernel-build.eclass
@@ -134,30 +134,32 @@ kernel-build_pkg_setup() {
 	if [[ ${KERNEL_IUSE_MODULES_SIGN} && ${MERGE_TYPE} != binary ]]; then
 		secureboot_pkg_setup
 
-		# Sanity check: fail early if key/cert in DER format or does not exist
-		local openssl_args=(
-			-noout -nocert
-		)
-		if [[ -n ${MODULES_SIGN_CERT} ]]; then
-			openssl_args+=( -inform PEM -in "${MODULES_SIGN_CERT}" )
-		else
-			# If no cert specified, we assume the pem key also contains the cert
-			openssl_args+=( -inform PEM -in "${MODULES_SIGN_KEY}" )
-		fi
-		if [[ ${MODULES_SIGN_KEY} == pkcs11:* ]]; then
-			openssl_args+=( -engine pkcs11 -keyform ENGINE -key "${MODULES_SIGN_KEY}" )
-		else
-			openssl_args+=( -keyform PEM -key "${MODULES_SIGN_KEY}" )
-		fi
+		if use modules-sign; then
+			# Sanity check: fail early if key/cert in DER format or does not exist
+			local openssl_args=(
+				-noout -nocert
+			)
+			if [[ -n ${MODULES_SIGN_CERT} ]]; then
+				openssl_args+=( -inform PEM -in "${MODULES_SIGN_CERT}" )
+			else
+				# If no cert specified, we assume the pem key also contains the cert
+				openssl_args+=( -inform PEM -in "${MODULES_SIGN_KEY}" )
+			fi
+			if [[ ${MODULES_SIGN_KEY} == pkcs11:* ]]; then
+				openssl_args+=( -engine pkcs11 -keyform ENGINE -key "${MODULES_SIGN_KEY}" )
+			else
+				openssl_args+=( -keyform PEM -key "${MODULES_SIGN_KEY}" )
+			fi
 
-		openssl x509 "${openssl_args[@]}" ||
-			die "Kernel module signing certificate or key not found or not PEM format."
+			openssl x509 "${openssl_args[@]}" ||
+				die "Kernel module signing certificate or key not found or not PEM format."
 
-		if [[ ${MODULES_SIGN_KEY} != pkcs11:* ]]; then
-			if [[ ${MODULES_SIGN_CERT} != ${MODULES_SIGN_KEY} ]]; then
-				MODULES_SIGN_KEY_CONTENTS="$(cat "${MODULES_SIGN_CERT}" "${MODULES_SIGN_KEY}" || die)"
-			else
-				MODULES_SIGN_KEY_CONTENTS="$(< "${MODULES_SIGN_KEY}")"
+			if [[ ${MODULES_SIGN_KEY} != pkcs11:* ]]; then
+				if [[ ${MODULES_SIGN_CERT} != ${MODULES_SIGN_KEY} ]]; then
+					MODULES_SIGN_KEY_CONTENTS="$(cat "${MODULES_SIGN_CERT}" "${MODULES_SIGN_KEY}" || die)"
+				else
+					MODULES_SIGN_KEY_CONTENTS="$(< "${MODULES_SIGN_KEY}")"
+				fi
 			fi
 		fi
 	fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-21 15:45 Andrew Ammerlaan
  0 siblings, 0 replies; 6663+ messages in thread
From: Andrew Ammerlaan @ 2024-07-21 15:45 UTC (permalink / raw
  To: gentoo-commits
commit:     fa77d52a7ff39464c50707ca024725deab08b534
Author:     Andrew Ammerlaan <andrewammerlaan <AT> gentoo <DOT> org>
AuthorDate: Sun Jul 21 15:44:32 2024 +0000
Commit:     Andrew Ammerlaan <andrewammerlaan <AT> gentoo <DOT> org>
CommitDate: Sun Jul 21 15:45:23 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=fa77d52a
kernel-build.eclass: support unset MODULES_SIGN_{CERT,KEY}
the kernel build system generates a key if not set, so don't check anything
if the key is unset
Signed-off-by: Andrew Ammerlaan <andrewammerlaan <AT> gentoo.org>
 eclass/kernel-build.eclass | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/eclass/kernel-build.eclass b/eclass/kernel-build.eclass
index cbc80bddf6f7..be0256c21102 100644
--- a/eclass/kernel-build.eclass
+++ b/eclass/kernel-build.eclass
@@ -134,7 +134,7 @@ kernel-build_pkg_setup() {
 	if [[ ${KERNEL_IUSE_MODULES_SIGN} && ${MERGE_TYPE} != binary ]]; then
 		secureboot_pkg_setup
 
-		if use modules-sign; then
+		if use modules-sign && [[ -n ${MODULES_SIGN_KEY} ]]; then
 			# Sanity check: fail early if key/cert in DER format or does not exist
 			local openssl_args=(
 				-noout -nocert
@@ -155,7 +155,7 @@ kernel-build_pkg_setup() {
 				die "Kernel module signing certificate or key not found or not PEM format."
 
 			if [[ ${MODULES_SIGN_KEY} != pkcs11:* ]]; then
-				if [[ ${MODULES_SIGN_CERT} != ${MODULES_SIGN_KEY} ]]; then
+				if [[ -n ${MODULES_SIGN_CERT} && ${MODULES_SIGN_CERT} != ${MODULES_SIGN_KEY} ]]; then
 					MODULES_SIGN_KEY_CONTENTS="$(cat "${MODULES_SIGN_CERT}" "${MODULES_SIGN_KEY}" || die)"
 				else
 					MODULES_SIGN_KEY_CONTENTS="$(< "${MODULES_SIGN_KEY}")"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-22 15:09 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-07-22 15:09 UTC (permalink / raw
  To: gentoo-commits
commit:     605ea615713571431dd7d63d5c9533b63c9e0b76
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sun Jun 16 18:47:02 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Mon Jul 22 15:09:31 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=605ea615
distutils-r1.eclass: Fix QA to ignore non-generic "pure" wheels
Fix the QA check to match on `*py3-none-any.whl` to match the code
matching reusable wheels.  This avoids false positives over
`dev-python/backrefs` that creates separate pure Python wheels for every
Python version.
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/distutils-r1.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/distutils-r1.eclass b/eclass/distutils-r1.eclass
index 61c0a80323ec..8227466b4d4c 100644
--- a/eclass/distutils-r1.eclass
+++ b/eclass/distutils-r1.eclass
@@ -1933,7 +1933,7 @@ _distutils-r1_compare_installed_files() {
 	# Perform the check only if at least one potentially reusable wheel
 	# has been produced.  Nonpure packages (e.g. NumPy) may install
 	# interpreter configuration details into sitedir.
-	if [[ ${!DISTUTILS_WHEELS[*]} != *-none-any.whl* &&
+	if [[ ${!DISTUTILS_WHEELS[*]} != *py3-none-any.whl* &&
 			${!DISTUTILS_WHEELS[*]} != *-abi3-*.whl ]]; then
 		return
 	fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-22 15:09 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-07-22 15:09 UTC (permalink / raw
  To: gentoo-commits
commit:     191e1f16757e17e76fb31c93b2f4fb5cdbe49903
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sun Jun 16 18:49:19 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Mon Jul 22 15:09:32 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=191e1f16
distutils-r1.eclass: Allow wheel reuse by default
Enable wheel reuse by default, since no issues were revealed during
the testing so far.  The option to disable them remains available, as it
can be useful e.g. to verify that reproducible wheels are actually
produced across implementation.
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/distutils-r1.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/distutils-r1.eclass b/eclass/distutils-r1.eclass
index 8227466b4d4c..645b5df5a6e5 100644
--- a/eclass/distutils-r1.eclass
+++ b/eclass/distutils-r1.eclass
@@ -195,7 +195,6 @@ esac
 # @CODE
 
 # @ECLASS_VARIABLE: DISTUTILS_ALLOW_WHEEL_REUSE
-# @DEFAULT_UNSET
 # @USER_VARIABLE
 # @DESCRIPTION:
 # If set to a non-empty value, the eclass is allowed to reuse a wheel
@@ -205,6 +204,7 @@ esac
 # This is an optimization that can avoid the overhead of calling into
 # the build system in pure Python packages and packages using the stable
 # Python ABI.
+DISTUTILS_ALLOW_WHEEL_REUSE=1
 
 # @ECLASS_VARIABLE: BUILD_DIR
 # @OUTPUT_VARIABLE
^ permalink raw reply related	[flat|nested] 6663+ messages in thread
* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-22 15:09 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-07-22 15:09 UTC (permalink / raw
  To: gentoo-commits
commit:     80a7960b9faa73152efd81e316f1083644817a02
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Tue Jul 16 16:21:09 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Mon Jul 22 15:09:32 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=80a7960b
distutils-r1.eclass: Add distutils_enable_tests import-check
Add support for using the dev-python/pytest-import-check plugin to
test if all modules installed by the package can be imported.
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/distutils-r1.eclass | 12 +++++++++++-
 1 file changed, 11 insertions(+), 1 deletion(-)
diff --git a/eclass/distutils-r1.eclass b/eclass/distutils-r1.eclass
index 645b5df5a6e5..fa8edb5cdfb7 100644
--- a/eclass/distutils-r1.eclass
+++ b/eclass/distutils-r1.eclass
@@ -572,6 +572,9 @@ distutils_enable_sphinx() {
 # with the specified test runner.  Also copies the current value
 # of RDEPEND to test?-BDEPEND.  The test-runner argument must be one of:
 #
+# - import-check: `pytest --import-check` fallback (for use when there are
+#   no tests to run)
+#
 # - pytest: dev-python/pytest
 #
 # - setup.py: setup.py test (no deps included)
@@ -597,9 +600,13 @@ distutils_enable_tests() {
 	[[ ${#} -eq 1 ]] || die "${FUNCNAME} takes exactly one argument: test-runner"
 
 	local test_deps=${RDEPEND}
+	local test_pkgs=
 	case ${1} in
+		import-check)
+			test_pkgs+=' dev-python/pytest-import-check[${PYTHON_USEDEP}]'
+			;&
 		pytest)
-			local test_pkgs='>=dev-python/pytest-7.4.4[${PYTHON_USEDEP}]'
+			test_pkgs+=' >=dev-python/pytest-7.4.4[${PYTHON_USEDEP}]'
 			if [[ -n ${EPYTEST_TIMEOUT} ]]; then
 				test_pkgs+=' dev-python/pytest-timeout[${PYTHON_USEDEP}]'
 			fi
@@ -1560,6 +1567,9 @@ distutils-r1_python_test() {
 	_python_check_EPYTHON
 
 	case ${_DISTUTILS_TEST_RUNNER} in
+		import-check)
+			epytest --import-check "${BUILD_DIR}/install$(python_get_sitedir)"
+			;;
 		pytest)
 			epytest
 			;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-23 10:03 Miroslav Šulc
  0 siblings, 0 replies; 6663+ messages in thread
From: Miroslav Šulc @ 2024-07-23 10:03 UTC (permalink / raw
  To: gentoo-commits
commit:     bb707cd1f6b9ec3784789c71513657c02fdf1862
Author:     Volkmar W. Pogatzki <gentoo <AT> pogatzki <DOT> net>
AuthorDate: Thu Apr 25 13:34:18 2024 +0000
Commit:     Miroslav Šulc <fordfrog <AT> gentoo <DOT> org>
CommitDate: Tue Jul 23 10:03:45 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=bb707cd1
java-pkg-simple.eclass: allow java-pkg-opt-2
Presently, "java-pkg-simple eclass can only be inherited AFTER java-pkg-2".
This prevents packages with optional Java like dev-lang/cxprolog to be
built with java-pkg-simple. This patch allows to inherit java-pkg-simple
after any of java-pkg-2 and java-pkg-opt-2.
Poposed by Alfred Wingate on #gentoo-dev-help on 2024-04-25
Closes: https://bugs.gentoo.org/930550
Signed-off-by: Volkmar W. Pogatzki <gentoo <AT> pogatzki.net>
Closes: https://github.com/gentoo/gentoo/pull/37468/commits/6f27fbf4604d5504044a7eee3b765ce7efa83089
Signed-off-by: Miroslav Šulc <fordfrog <AT> gentoo.org>
 eclass/java-pkg-simple.eclass | 18 +++++++++++++++---
 1 file changed, 15 insertions(+), 3 deletions(-)
diff --git a/eclass/java-pkg-simple.eclass b/eclass/java-pkg-simple.eclass
index 6b473ed768ed..5ed7e3e5b78e 100644
--- a/eclass/java-pkg-simple.eclass
+++ b/eclass/java-pkg-simple.eclass
@@ -26,8 +26,12 @@ _JAVA_PKG_SIMPLE_ECLASS=1
 
 inherit java-utils-2
 
-if ! has java-pkg-2 ${INHERITED}; then
-	eerror "java-pkg-simple eclass can only be inherited AFTER java-pkg-2"
+if has java-pkg-2 ${INHERITED}; then
+	JAVA_PKG_OPT=0
+elif has java-pkg-opt-2 ${INHERITED}; then
+	JAVA_PKG_OPT=1
+else
+	eerror "java-pkg-simple eclass can only be inherited AFTER java-pkg-2 or java-pkg-opt-2"
 fi
 
 # We are only interested in finding all java source files, wherever they may be.
@@ -50,7 +54,12 @@ if has test ${JAVA_PKG_IUSE}; then
 					test_deps+=" dev-java/testng:0";;
 		esac
 	done
-	[[ ${test_deps} ]] && DEPEND="test? ( ${test_deps} )"
+	if [[ ${JAVA_PKG_OPT} == 1 ]]; then
+		[[ ${test_deps} ]] && DEPEND="test? ( ${JAVA_PKG_OPT_USE}? ( ${test_deps} ) )"
+	else
+		[[ ${test_deps} ]] && DEPEND="test? ( ${test_deps} )"
+	fi
+
 	unset test_deps
 fi
 
@@ -347,6 +356,7 @@ java-pkg-simple_prepend_resources() {
 # If USE FLAG 'binary' exists and is set, it will just copy
 # ${JAVA_BINJAR_FILENAME} to ${S} and skip the rest of src_compile.
 java-pkg-simple_src_compile() {
+	[[ ${JAVA_PKG_OPT} == 1 ]] && ! use ${JAVA_PKG_OPT_USE} && return
 	local sources=sources.lst classes=target/classes apidoc=target/api moduleinfo
 
 	# do not compile if we decide to install binary jar
@@ -461,6 +471,7 @@ java-pkg-simple_src_compile() {
 # ${JAVA_JAR_FILENAME}. It will also install a launcher if
 # ${JAVA_MAIN_CLASS} is set. Also invokes einstalldocs.
 java-pkg-simple_src_install() {
+	[[ ${JAVA_PKG_OPT} == 1 ]] && ! use ${JAVA_PKG_OPT_USE} && return
 	local sources=sources.lst classes=target/classes apidoc=target/api
 
 	# install the jar file that we need
@@ -503,6 +514,7 @@ java-pkg-simple_src_install() {
 # in the "generated-test" directory as content of this directory is preserved,
 # whereas content of target/test-classes is removed.
 java-pkg-simple_src_test() {
+	[[ ${JAVA_PKG_OPT} == 1 ]] && ! use ${JAVA_PKG_OPT_USE} && return
 	local test_sources=test_sources.lst classes=target/test-classes moduleinfo
 	local tests_to_run classpath
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-23 14:07 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-07-23 14:07 UTC (permalink / raw
  To: gentoo-commits
commit:     3365651fed541616d4d5c49f1e2b61f4ee636550
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Tue Jul 23 13:56:04 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Tue Jul 23 14:07:30 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=3365651f
llvm.org.eclass: main is now 20.x
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index 7aa1d0e2b0b8..d2797f46bb92 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -57,7 +57,7 @@ LLVM_VERSION=$(ver_cut 1-3)
 # @DESCRIPTION:
 # The major version of current LLVM trunk.  Used to determine
 # the correct branch to use.
-_LLVM_MAIN_MAJOR=19
+_LLVM_MAIN_MAJOR=20
 
 # @ECLASS_VARIABLE: _LLVM_SOURCE_TYPE
 # @INTERNAL
^ permalink raw reply related	[flat|nested] 6663+ messages in thread
* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-23 14:07 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-07-23 14:07 UTC (permalink / raw
  To: gentoo-commits
commit:     f7f7ff3fa2cd1c32b64d54fb155ee824cdd25928
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Tue Jul 23 14:05:15 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Tue Jul 23 14:07:51 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=f7f7ff3f
llvm-r1.eclass: LLVM 18 is now stable
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm-r1.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/llvm-r1.eclass b/eclass/llvm-r1.eclass
index 075df9218be8..620697e6e045 100644
--- a/eclass/llvm-r1.eclass
+++ b/eclass/llvm-r1.eclass
@@ -61,7 +61,7 @@ _LLVM_OLDEST_SLOT=15
 # @DESCRIPTION:
 # The newest stable LLVM version.  Versions newer than that won't
 # be automatically enabled via USE defaults.
-_LLVM_NEWEST_STABLE=17
+_LLVM_NEWEST_STABLE=18
 
 # == control variables ==
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread
* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-23 14:07 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-07-23 14:07 UTC (permalink / raw
  To: gentoo-commits
commit:     9f09b98ee6a5edce65e995c4701776e8e1c86d1d
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sun Jul  7 12:22:52 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Tue Jul 23 14:07:52 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=9f09b98e
llvm-r1.eclass: Do not default-enable unkeyworded slots
Change the IUSE defaults logic to default-enable the *oldest* ~arch
version rather than the newest one, when no stable slots are supported.
Since we only except a single ~arch version to exist, this effectively
prevents the eclass from default-enabling the unkeyworded snapshots.
Closes: https://bugs.gentoo.org/935681
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
Closes: https://github.com/gentoo/gentoo/pull/37473
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm-r1.eclass | 9 +++++++--
 1 file changed, 7 insertions(+), 2 deletions(-)
diff --git a/eclass/llvm-r1.eclass b/eclass/llvm-r1.eclass
index 620697e6e045..0a53b9a3cb5e 100644
--- a/eclass/llvm-r1.eclass
+++ b/eclass/llvm-r1.eclass
@@ -123,11 +123,16 @@ _llvm_set_globals() {
 	fi
 
 	if [[ ${stable[@]} ]]; then
+		# If there is at least one stable slot supported, then enable
+		# the newest stable slot by default.
 		IUSE="+llvm_slot_${stable[-1]}"
 		unset 'stable[-1]'
 	else
-		IUSE="+llvm_slot_${unstable[-1]}"
-		unset 'unstable[-1]'
+		# Otherwise, enable the "oldest" ~arch slot.  We really only
+		# expect a single ~arch version, so this primarily prevents
+		# defaulting to non-keyworded slots.
+		IUSE="+llvm_slot_${unstable[0]}"
+		unset 'unstable[0]'
 	fi
 	local nondefault=( "${stable[@]}" "${unstable[@]}" )
 	IUSE+=" ${nondefault[*]/#/llvm_slot_}"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-23 14:13 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-07-23 14:13 UTC (permalink / raw
  To: gentoo-commits
commit:     1ea788c223239a35ac94011200305b15bf2e7d3e
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Tue Jul 23 14:12:07 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Tue Jul 23 14:13:41 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=1ea788c2
llvm.eclass: Mark @DEPRECATED
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.eclass | 1 +
 1 file changed, 1 insertion(+)
diff --git a/eclass/llvm.eclass b/eclass/llvm.eclass
index e297fe992c9f..bb5ff5d78290 100644
--- a/eclass/llvm.eclass
+++ b/eclass/llvm.eclass
@@ -9,6 +9,7 @@
 # @SUPPORTED_EAPIS: 7 8
 # @PROVIDES: llvm-utils
 # @BLURB: Utility functions to build against slotted LLVM
+# @DEPRECATED: llvm-r1.eclass
 # @DESCRIPTION:
 # The llvm.eclass provides utility functions that can be used to build
 # against specific version of slotted LLVM (with fallback to :0 for old
^ permalink raw reply related	[flat|nested] 6663+ messages in thread
* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-24  8:58 Florian Schmaus
  0 siblings, 0 replies; 6663+ messages in thread
From: Florian Schmaus @ 2024-07-24  8:58 UTC (permalink / raw
  To: gentoo-commits
commit:     be38b2c896e463aa2fe3c9af095513f781e62aa3
Author:     Florian Schmaus <flow <AT> gentoo <DOT> org>
AuthorDate: Mon Jul 15 19:55:13 2024 +0000
Commit:     Florian Schmaus <flow <AT> gentoo <DOT> org>
CommitDate: Wed Jul 24 08:55:05 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=be38b2c8
texlive-common.eclass: Add TEXLIVE_SCRIPTS_W_FILE_EXT variable
Some scripts are supposed to be installed with file extensions [1, 2]. Add
support for declaring those scripts in a new elcass variable
TEXLIVE_SCRIPTS_W_FILE_EXT.
Also use pure-bash functions to retrieve the basename and strip the file
extensions. And use "declare -l" to lowercase the value of 'trg',
instead of 'tr' [3].
1: https://tug.org/pipermail/tldistro/2024q3/000485.html
2: https://github.com/TeX-Live/texlive-source/blob/c087bab35570b1d5cb0afd272611a7a4ec3c9e38/texk/texlive/linked_scripts/Makefile.am#L332-L333
3: https://github.com/TeX-Live/texlive-source/blob/c087bab35570b1d5cb0afd272611a7a4ec3c9e38/texk/texlive/linked_scripts/Makefile.am#L330
Bug: https://bugs.gentoo.org/934975
Signed-off-by: Florian Schmaus <flow <AT> gentoo.org>
 eclass/texlive-common.eclass | 20 ++++++++++++++++++--
 1 file changed, 18 insertions(+), 2 deletions(-)
diff --git a/eclass/texlive-common.eclass b/eclass/texlive-common.eclass
index 072581dde78e..36b90a327fde 100644
--- a/eclass/texlive-common.eclass
+++ b/eclass/texlive-common.eclass
@@ -42,6 +42,13 @@ _TEXLIVE_COMMON_ECLASS=1
 # @CODE
 : "${CTAN_MIRROR_URL:="https://mirrors.ctan.org"}"
 
+# @ECLASS_VARIABLE: TEXLIVE_SCRIPTS_W_FILE_EXT
+# @DEFAULT_UNSET
+# @DESCRIPTION:
+# If set, contains a space separated list of script names that should be
+# linked including their file extensions, i.e., without stripping
+# potentially existing filename extensions from the link's name.
+
 # @FUNCTION: texlive-common_handle_config_files
 # @DESCRIPTION:
 # Has to be called in src_install after having installed the files in ${D}
@@ -160,8 +167,17 @@ etexlinks() {
 # Called by app-text/epspdf and texlive-module.eclass.
 dobin_texmf_scripts() {
 	while [[ ${#} -gt 0 ]] ; do
-		local trg
-		trg=$(basename "${1}" | sed 's,\.[^/]*$,,' | tr '[:upper:]' '[:lower:]')
+		# -l: TexLive target links are always lowercase.
+		local -l trg
+
+		# Get the basename of the script.
+		trg="${1##*/}"
+
+		# Only strip the filename extensions if trg is not listed in TEXLIVE_SCRIPTS_W_FILE_EXT.
+		if ! has "${trg}" ${TEXLIVE_SCRIPTS_W_FILE_EXT}; then
+			trg="${trg%.*}"
+		fi
+
 		einfo "Installing ${1} as ${trg} bin wrapper"
 		[[ -x ${ED}/usr/share/${1} ]] || die "Trying to install a non existing or non executable symlink to /usr/bin: ${1}"
 		dosym "../share/${1}" "/usr/bin/${trg}"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-24  8:58 Florian Schmaus
  0 siblings, 0 replies; 6663+ messages in thread
From: Florian Schmaus @ 2024-07-24  8:58 UTC (permalink / raw
  To: gentoo-commits
commit:     6b00659e2a8da878326fa499419f97e9a3d7daf5
Author:     Florian Schmaus <flow <AT> gentoo <DOT> org>
AuthorDate: Thu Jun 13 07:48:40 2024 +0000
Commit:     Florian Schmaus <flow <AT> gentoo <DOT> org>
CommitDate: Wed Jul 24 08:55:04 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=6b00659e
greadme.eclass: new eclass
This new eclass includes various improvements over the existing
readme.gentoo-r1.eclass.
First, the content of README.gentoo will only be shown on new
installations or if it has changed between updates.
Second, it allows the composition of readme via bash's heredoc.
And finally, the eclass exports phase functions, which helps to reduce
the boilerplate code in many cases.
Signed-off-by: Florian Schmaus <flow <AT> gentoo.org>
 eclass/greadme.eclass | 251 ++++++++++++++++++++++++++++++++++++++++++++++++++
 1 file changed, 251 insertions(+)
diff --git a/eclass/greadme.eclass b/eclass/greadme.eclass
new file mode 100644
index 000000000000..38190becf91d
--- /dev/null
+++ b/eclass/greadme.eclass
@@ -0,0 +1,251 @@
+# Copyright 1999-2024 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+# @ECLASS: greadme.eclass
+# @MAINTAINER:
+# Florian Schmaus <flow@gentoo.org>
+# @SUPPORTED_EAPIS: 8
+# @BLURB: install a doc file, that will be conditionally shown via elog messages
+# @DESCRIPTION:
+# An eclass for installing a README.gentoo doc file with important
+# information for the user.  The content of README.gentoo will shown be
+# via elog messages either on fresh installations or if the contents of
+# the file have changed.  Furthermore, the README.gentoo file will be
+# installed under /usr/share/doc/${PF} for later consultation.
+#
+# This eclass was inspired by readme.gentoo-r1.eclass.  The main
+# differences are as follows.  Firstly, it only displays the doc file
+# contents if they have changed (unless GREADME_SHOW is set).
+# Secondly, it provides a convenient API to install the doc file via
+# stdin.
+#
+# @CODE
+# inherit greadme
+#
+# src_install() {
+#   ...
+#   greadme_stdin <<-EOF
+#   This is the content of the created readme doc file.
+#   EOF
+#   ...
+#   if use foo; then
+#     greadme_stdin --append <<-EOF
+#     This is conditional readme content, based on USE=foo.
+#     EOF
+#   fi
+# }
+# @CODE
+#
+# If the ebuild overrides the default pkg_preinst or respectively
+# pkg_postinst, then it must call greadme_pkg_preinst and
+# greadme_pkg_postinst explicitly.
+
+if [[ -z ${_GREADME_ECLASS} ]]; then
+_GREADME_ECLASS=1
+
+case ${EAPI} in
+	8) ;;
+	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
+esac
+
+_GREADME_TMP_FILE="${T}/README.gentoo"
+_GREADME_REL_PATH="/usr/share/doc/${PF}/README.gentoo"
+
+# @ECLASS_VARIABLE: GREADME_SHOW
+# @DEFAULT_UNSET
+# @DESCRIPTION:
+# If set to "yes" then unconditionally show the contents of the readme
+# file in pkg_postinst via elog. If set to "no", then do not show the
+# contents of the readme file, even if they have changed.
+
+# @ECLASS_VARIABLE: GREADME_DISABLE_AUTOFORMAT
+# @DEFAULT_UNSET
+# @DESCRIPTION:
+# If non-empty, the readme file will not be automatically formatted.
+
+# @FUNCTION: greadme_stdin
+# @USAGE: [--append]
+# @DESCRIPTION:
+# Create the readme doc via stdin.  You can use --append to append to an
+# existing readme doc.
+greadme_stdin() {
+	debug-print-function ${FUNCNAME} "${@}"
+
+	local append
+	if [[ ${1} = --append ]]; then
+		append=1
+		shift
+	fi
+
+	[[ $# -eq 0 ]] || die "${FUNCNAME[0]}: Bad parameters: $*"
+
+	if [[ -n ${append} ]]; then
+		if [[ ! -f ${_GREADME_TMP_FILE} ]]; then
+			die "Gentoo README does not exist when trying to append to it"
+		fi
+
+		cat >> "${_GREADME_TMP_FILE}" || die
+	else
+		cat > "${_GREADME_TMP_FILE}" || die
+	fi
+
+	_greadme_install_doc
+}
+
+# @FUNCTION: greadme_file
+# @USAGE: <file>
+# @DESCRIPTION:
+# Installs the provided file as readme doc.
+greadme_file() {
+	debug-print-function ${FUNCNAME} "${@}"
+
+	local input_doc_file="${1}"
+	if [[ -z ${input_doc_file} ]]; then
+		die "No file specified"
+	fi
+
+	cp "${input_doc_file}" "${_GREADME_TMP_FILE}" || die
+
+	_greadme_install_doc
+}
+
+# @FUNCTION: _greadme_install_doc
+# @INTERNAL
+# @DESCRIPTION:
+# Installs the readme file from the temp directory into the image.
+_greadme_install_doc() {
+	debug-print-function ${FUNCNAME} "${@}"
+
+	local greadme="${_GREADME_TMP_FILE}"
+	if [[ ! ${GREADME_DISABLE_AUTOFORMAT} ]]; then
+		greadme="${_GREADME_TMP_FILE}".formatted
+
+		# Use fold, followed by a sed to strip trailing whitespace.
+		# https://bugs.gentoo.org/460050#c7
+		fold -s -w 70 "${_GREADME_TMP_FILE}" |
+			sed 's/[[:space:]]*$//' > "${greadme}"
+		assert "failed to autoformat README.gentoo"
+	fi
+
+	# Subshell to avoid pollution of calling environment.
+	(
+		docinto .
+		newdoc "${greadme}" "README.gentoo"
+	)
+
+	# Exclude the readme file from compression, so that its contents can
+	# be easily compared.
+	docompress -x "${_GREADME_REL_PATH}"
+
+	# Save the contents of the of the readme. Unfortunately we have to
+	# do this in src_* phase, because FEATURES=nodoc is applied right
+	# after src_install and not after pkg_preinst.
+	_GREADME_CONTENT=$(< "${greadme}")
+}
+
+# @FUNCTION: greadme_pkg_preinst
+# @DESCRIPTION:
+# Performs checks like comparing the readme doc from the image with a
+# potentially existing one in the live system.
+greadme_pkg_preinst() {
+	debug-print-function ${FUNCNAME} "${@}"
+
+	if [[ -z ${REPLACING_VERSIONS} ]]; then
+		_GREADME_SHOW="fresh-install"
+		return
+	fi
+
+	if [[ -v GREADME_SHOW ]]; then
+		case ${GREADME_SHOW} in
+			yes)
+				_GREADME_SHOW="forced"
+				;;
+			no)
+				_GREADME_SHOW=""
+				;;
+			*)
+				die "Invalid argument of GREADME_SHOW: ${GREADME_SHOW}"
+				;;
+		esac
+		return
+	fi
+
+	local image_greadme_file="${ED}${_GREADME_REL_PATH}"
+	if [[ ! -f ${image_greadme_file} ]]; then
+		if [[ -v _GREADME_CONTENT ]]; then
+			# There is no greadme in the image but the ebuild created
+			# one. This is likely because FEATURES=nodoc is active.
+			# Unconditionally show greadme's contents.
+			_GREADME_SHOW="nodoc-active"
+		else
+			# No README file was created by the ebuild.
+			_GREADME_SHOW=""
+		fi
+
+		return
+	fi
+
+	check_live_doc_file() {
+		local cur_pvr=$1
+		local live_greadme_file="${EROOT}/usr/share/doc/${PN}-${cur_pvr}/README.gentoo"
+
+		if [[ ! -f ${live_greadme_file} ]]; then
+			_GREADME_SHOW="no-current-greadme"
+			return
+		fi
+
+		cmp -s "${live_greadme_file}" "${image_greadme_file}"
+		case $? in
+			0)
+				_GREADME_SHOW=""
+				;;
+			1)
+				_GREADME_SHOW="content-differs"
+				;;
+			*)
+				die "cmp failed with $?"
+				;;
+		esac
+	}
+
+	local replaced_version
+	for replaced_version in ${REPLACING_VERSIONS}; do
+		check_live_doc_file ${replaced_version}
+
+		# Once _GREADME_SHOW is non empty, we found a reason to show the
+		# readme and we can abort the loop.
+		if [[ -n ${_GREADME_SHOW} ]]; then
+			break
+		fi
+	done
+}
+
+# @FUNCTION: greadme_pkg_postinst
+# @DESCRIPTION:
+# Conditionally shows the contents of the readme doc via elog.
+greadme_pkg_postinst() {
+	debug-print-function ${FUNCNAME} "${@}"
+
+	if [[ ! -v _GREADME_SHOW ]]; then
+		die "_GREADME_SHOW not set. Did you call greadme_pkg_preinst?"
+	fi
+
+	if [[ -z ${_GREADME_SHOW} ]]; then
+		# If _GREADME_SHOW is empty, then there is no reason to show the contents.
+		return
+	fi
+
+	local line
+	printf '%s\n' "${_GREADME_CONTENT}" | while read -r line; do
+		elog "${line}"
+	done
+	elog ""
+	elog "NOTE: Above message is only printed the first time package is"
+	elog "installed or if the message changed. Please look at"
+	elog "${EPREFIX}${_GREADME_REL_PATH}"
+	elog "for future reference."
+}
+
+fi
+
+EXPORT_FUNCTIONS pkg_preinst pkg_postinst
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-24 17:18 Andrew Ammerlaan
  0 siblings, 0 replies; 6663+ messages in thread
From: Andrew Ammerlaan @ 2024-07-24 17:18 UTC (permalink / raw
  To: gentoo-commits
commit:     11b5c48af37beba23c803f6fba78a85879b2c794
Author:     Andrew Ammerlaan <andrewammerlaan <AT> gentoo <DOT> org>
AuthorDate: Tue Jul 23 09:49:10 2024 +0000
Commit:     Andrew Ammerlaan <andrewammerlaan <AT> gentoo <DOT> org>
CommitDate: Wed Jul 24 17:17:41 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=11b5c48a
eclass/kernel-{build,install}.eclass: link to config,Sys.map in moddir
The kernels 'make rpm-pkg' and 'make deb-pkg' install the config
and System.map into the modules directory for easy access. Let's
do the same here so our gpkg's are more symetric to rpm's and
deb's and tools that look for these files there can find it.
This also provides an easy location for the user to access the
config. Considering that /boot/config-x.y.z does not always
exist (the config instalation via /sbin/installkernel depends
on layout and +/-systemd configuration).
Signed-off-by: Andrew Ammerlaan <andrewammerlaan <AT> gentoo.org>
Closes: https://github.com/gentoo/gentoo/pull/37684
Signed-off-by: Andrew Ammerlaan <andrewammerlaan <AT> gentoo.org>
 eclass/kernel-build.eclass   | 2 ++
 eclass/kernel-install.eclass | 7 +++++++
 2 files changed, 9 insertions(+)
diff --git a/eclass/kernel-build.eclass b/eclass/kernel-build.eclass
index be0256c21102..29719609b912 100644
--- a/eclass/kernel-build.eclass
+++ b/eclass/kernel-build.eclass
@@ -448,6 +448,8 @@ kernel-build_src_install() {
 	# fix source tree and build dir symlinks
 	dosym "../../../${kernel_dir}" "/lib/modules/${KV_FULL}/build"
 	dosym "../../../${kernel_dir}" "/lib/modules/${KV_FULL}/source"
+	dosym "../../../${kernel_dir}/.config" "/lib/modules/${KV_FULL}/config"
+	dosym "../../../${kernel_dir}/System.map" "/lib/modules/${KV_FULL}/System.map"
 	if [[ "${image_path}" == *vmlinux* ]]; then
 		dosym "../../../${kernel_dir}/${image_path}" "/lib/modules/${KV_FULL}/vmlinux"
 	else
diff --git a/eclass/kernel-install.eclass b/eclass/kernel-install.eclass
index e6f0b404dcaa..0a85bfb8629d 100644
--- a/eclass/kernel-install.eclass
+++ b/eclass/kernel-install.eclass
@@ -623,6 +623,13 @@ kernel-install_pkg_preinst() {
 		rm "${ED}/lib/modules/${KV_FULL}"/{build,source} || die
 		dosym "../../../src/linux-${KV_FULL}" "/usr/lib/modules/${KV_FULL}/build"
 		dosym "../../../src/linux-${KV_FULL}" "/usr/lib/modules/${KV_FULL}/source"
+		local file
+		for file in .config System.map; do
+			if [[ -L "${ED}/lib/modules/${KV_FULL}/${file#.}" ]]; then
+				rm "${ED}/lib/modules/${KV_FULL}/${file#.}" || die
+				dosym "../../../src/linux-${KV_FULL}/${file}" "/usr/lib/modules/${KV_FULL}/${file#.}"
+			fi
+		done
 		for file in vmlinux vmlinuz; do
 			if [[ -L "${ED}/lib/modules/${KV_FULL}/${file}" ]]; then
 				rm "${ED}/lib/modules/${KV_FULL}/${file}" || die
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-24 17:18 Andrew Ammerlaan
  0 siblings, 0 replies; 6663+ messages in thread
From: Andrew Ammerlaan @ 2024-07-24 17:18 UTC (permalink / raw
  To: gentoo-commits
commit:     e19b3318171fe5482417c00e0ff198091080944b
Author:     Andrew Ammerlaan <andrewammerlaan <AT> gentoo <DOT> org>
AuthorDate: Tue Jul 23 20:17:50 2024 +0000
Commit:     Andrew Ammerlaan <andrewammerlaan <AT> gentoo <DOT> org>
CommitDate: Wed Jul 24 17:18:13 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=e19b3318
kernel-build.eclass: fix determining kernel release with MODULES=n
For module-less kernels 'make modules_prepare' does nothing, we only get
kernel.release after running src_compile. Luckily the kernel has the
"kernelrelease" target which we can use for this purpose.
Note, in kernel-install.eclass we still read the kernel release directly from
the file since a) kernel.release will always exist and b) calling make there
again would require duplicating (some subset off) ${MAKEARGS[@]}.
The "make help" page specifies that this target should be called with "-s".
The version check is moved up, before 'make modules_prepare' so we quit earlier
if the KV_FULL is wrong. Note it should be run after we have completed the
config in 'make olddefconfig'.
Signed-off-by: Andrew Ammerlaan <andrewammerlaan <AT> gentoo.org>
Closes: https://github.com/gentoo/gentoo/pull/37694
Signed-off-by: Andrew Ammerlaan <andrewammerlaan <AT> gentoo.org>
 eclass/kernel-build.eclass | 17 ++++++++---------
 1 file changed, 8 insertions(+), 9 deletions(-)
diff --git a/eclass/kernel-build.eclass b/eclass/kernel-build.eclass
index 29719609b912..f478cf636a27 100644
--- a/eclass/kernel-build.eclass
+++ b/eclass/kernel-build.eclass
@@ -253,25 +253,21 @@ kernel-build_src_configure() {
 	mkdir -p "${WORKDIR}"/modprep || die
 	mv .config "${WORKDIR}"/modprep/ || die
 	emake O="${WORKDIR}"/modprep "${MAKEARGS[@]}" olddefconfig
-	emake O="${WORKDIR}"/modprep "${MAKEARGS[@]}" modules_prepare
-	cp -pR "${WORKDIR}"/modprep "${WORKDIR}"/build || die
 
-	# Now that we have a release file, set KV_FULL
-	local relfile=${WORKDIR}/build/include/config/kernel.release
+	local k_release=$(emake -s O="${WORKDIR}"/modprep "${MAKEARGS[@]}" kernelrelease)
 	if [[ -z ${KV_FULL} ]]; then
-		KV_FULL=$(<"${relfile}") || die
+		KV_FULL=${k_release}
 	fi
 
 	# Make sure we are about to build the correct kernel
 	if [[ ${PV} != *9999 ]]; then
 		local expected_ver=$(dist-kernel_PV_to_KV "${PV}")
-		local expected_rel=$(<"${relfile}")
 
-		if [[ ${KV_FULL} != ${expected_rel} ]]; then
+		if [[ ${KV_FULL} != ${k_release} ]]; then
 			eerror "KV_FULL mismatch!"
 			eerror "KV_FULL:  ${KV_FULL}"
-			eerror "Expected: ${expected_rel}"
-			die "KV_FULL mismatch: got ${KV_FULL}, expected ${expected_rel}"
+			eerror "Expected: ${k_release}"
+			die "KV_FULL mismatch: got ${KV_FULL}, expected ${k_release}"
 		fi
 
 		if [[ ${KV_FULL} != ${expected_ver}* ]]; then
@@ -282,6 +278,9 @@ kernel-build_src_configure() {
 			die "Kernel version mismatch: got ${KV_FULL}, expected ${expected_ver}*"
 		fi
 	fi
+
+	emake O="${WORKDIR}"/modprep "${MAKEARGS[@]}" modules_prepare
+	cp -pR "${WORKDIR}"/modprep "${WORKDIR}"/build || die
 }
 
 # @FUNCTION: kernel-build_src_compile
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-24 17:18 Andrew Ammerlaan
  0 siblings, 0 replies; 6663+ messages in thread
From: Andrew Ammerlaan @ 2024-07-24 17:18 UTC (permalink / raw
  To: gentoo-commits
commit:     0edf1af9e3cd350ebe7476d283e0e05918899bd9
Author:     Alfred Wingate <parona <AT> protonmail <DOT> com>
AuthorDate: Tue Jul 23 14:11:41 2024 +0000
Commit:     Andrew Ammerlaan <andrewammerlaan <AT> gentoo <DOT> org>
CommitDate: Wed Jul 24 17:18:32 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=0edf1af9
kernel-build.eclass: set toolchain variables more comprehensibly
Building on llvm profiles is problematic if toolchain variables are not properly
set. So set HOSTLD and HOSTAR to match at least the kernels own LLVM=1 variable
to ensure a smoother build for end users.
For example an unset HOSTLD causes issues as it defaults to GNU ld
otherwise.
https://docs.kernel.org/kbuild/llvm.html#the-llvm-argument
Signed-off-by: Alfred Wingate <parona <AT> protonmail.com>
Closes: https://github.com/gentoo/gentoo/pull/37690
Signed-off-by: Andrew Ammerlaan <andrewammerlaan <AT> gentoo.org>
 eclass/kernel-build.eclass | 7 +++++++
 1 file changed, 7 insertions(+)
diff --git a/eclass/kernel-build.eclass b/eclass/kernel-build.eclass
index f478cf636a27..893a1bdb449c 100644
--- a/eclass/kernel-build.eclass
+++ b/eclass/kernel-build.eclass
@@ -187,6 +187,10 @@ kernel-build_src_configure() {
 	fi
 
 	# force ld.bfd if we can find it easily
+	local HOSTLD="$(tc-getBUILD_LD)"
+	if type -P "${HOSTLD}.bfd" &>/dev/null; then
+		HOSTLD+=.bfd
+	fi
 	local LD="$(tc-getLD)"
 	if type -P "${LD}.bfd" &>/dev/null; then
 		LD+=.bfd
@@ -198,6 +202,8 @@ kernel-build_src_configure() {
 
 		HOSTCC="$(tc-getBUILD_CC)"
 		HOSTCXX="$(tc-getBUILD_CXX)"
+		HOSTLD="${HOSTLD}"
+		HOSTAR="$(tc-getBUILD_AR)"
 		HOSTCFLAGS="${BUILD_CFLAGS}"
 		HOSTLDFLAGS="${BUILD_LDFLAGS}"
 
@@ -210,6 +216,7 @@ kernel-build_src_configure() {
 		STRIP="$(tc-getSTRIP)"
 		OBJCOPY="$(tc-getOBJCOPY)"
 		OBJDUMP="$(tc-getOBJDUMP)"
+		READELF="$(tc-getREADELF)"
 
 		# we need to pass it to override colliding Gentoo envvar
 		ARCH=$(tc-arch-kernel)
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-26  9:00 Miroslav Šulc
  0 siblings, 0 replies; 6663+ messages in thread
From: Miroslav Šulc @ 2024-07-26  9:00 UTC (permalink / raw
  To: gentoo-commits
commit:     bf0b78ed5ac69775135c0a1ecca7be8b16afc7e2
Author:     Volkmar W. Pogatzki <gentoo <AT> pogatzki <DOT> net>
AuthorDate: Thu Jul 25 10:17:45 2024 +0000
Commit:     Miroslav Šulc <fordfrog <AT> gentoo <DOT> org>
CommitDate: Fri Jul 26 08:59:50 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=bf0b78ed
java-utils-2.eclass: fix ejunit_(), java-pkg_getjars --build-only
Closes: https://bugs.gentoo.org/936557
Signed-off-by: Volkmar W. Pogatzki <gentoo <AT> pogatzki.net>
Closes: https://github.com/gentoo/gentoo/pull/37718
Signed-off-by: Miroslav Šulc <fordfrog <AT> gentoo.org>
 eclass/java-utils-2.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/java-utils-2.eclass b/eclass/java-utils-2.eclass
index 91f8fba8790b..8a062f2ad87e 100644
--- a/eclass/java-utils-2.eclass
+++ b/eclass/java-utils-2.eclass
@@ -1838,7 +1838,7 @@ ejunit_() {
 	local junit=${1}
 	shift 1
 
-	local cp=$(java-pkg_getjars --with-dependencies ${junit}${pkgs})
+	local cp=$(java-pkg_getjars --build-only --with-dependencies ${junit}${pkgs})
 	if [[ ${1} = -cp || ${1} = -classpath ]]; then
 		cp="${2}:${cp}"
 		shift 2
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-26 17:18 Ulrich Müller
  0 siblings, 0 replies; 6663+ messages in thread
From: Ulrich Müller @ 2024-07-26 17:18 UTC (permalink / raw
  To: gentoo-commits
commit:     a87aba49d142f55e1b8d6e78fd2f9e9875691e02
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Fri Jul 19 13:43:36 2024 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Fri Jul 26 17:17:33 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=a87aba49
savedconfig.eclass: Drop support for EAPI 6
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 eclass/savedconfig.eclass | 12 ++++++------
 1 file changed, 6 insertions(+), 6 deletions(-)
diff --git a/eclass/savedconfig.eclass b/eclass/savedconfig.eclass
index cc5748543078..65a1f3bfd800 100644
--- a/eclass/savedconfig.eclass
+++ b/eclass/savedconfig.eclass
@@ -1,10 +1,10 @@
-# Copyright 1999-2023 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: savedconfig.eclass
 # @MAINTAINER:
 # base-system@gentoo.org
-# @SUPPORTED_EAPIS: 6 7 8
+# @SUPPORTED_EAPIS: 7 8
 # @BLURB: common API for saving/restoring complex configuration files
 # @DESCRIPTION:
 # It is not uncommon to come across a package which has a very fine
@@ -31,7 +31,7 @@
 # build.
 
 case ${EAPI} in
-	6|7|8) ;;
+	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
@@ -60,12 +60,12 @@ save_config() {
 	if [[ $# -eq 1 && -f $1 ]] ; then
 		# Just one file, so have the ${configfile} be that config file
 		dodir "${configfile%/*}"
-		cp "$@" "${ED%/}/${configfile}" || die "failed to save $*"
+		cp "$@" "${ED}/${configfile}" || die "failed to save $*"
 	else
 		# A dir, or multiple files, so have the ${configfile} be a dir
 		# with all the saved stuff below it
 		dodir "${configfile}"
-		treecopy "$@" "${ED%/}/${configfile}" || die "failed to save $*"
+		treecopy "$@" "${ED}/${configfile}" || die "failed to save $*"
 	fi
 
 	elog "Your configuration for ${CATEGORY}/${PF} has been saved in "
@@ -150,7 +150,7 @@ savedconfig_pkg_postinst() {
 	# are worse :/.
 
 	if use savedconfig ; then
-		find "${EROOT%/}/etc/portage/savedconfig/${CATEGORY}/${PF}" \
+		find "${EROOT}/etc/portage/savedconfig/${CATEGORY}/${PF}" \
 			-exec touch {} + 2>/dev/null
 	fi
 }
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-27  7:27 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-07-27  7:27 UTC (permalink / raw
  To: gentoo-commits
commit:     1fc87de4b56fc3e009e1dfd606824fdadc3ce8fb
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Jul 27 07:22:25 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat Jul 27 07:22:25 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=1fc87de4
llvm.org.eclass: Remove old snapshot support
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 6 ------
 1 file changed, 6 deletions(-)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index bcbd22f94d0b..07b47d70a852 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -75,12 +75,6 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 				19.0.0_pre20240720)
 					EGIT_COMMIT=72d8c2737bb557af9d0c735b9fa30b1b03485627
 					;;
-				19.0.0_pre20240712)
-					EGIT_COMMIT=1bad7024561bc64ed4bfda0772b16376b475eba5
-					;;
-				19.0.0_pre20240706)
-					EGIT_COMMIT=0b9f2847da79298ed09c29493245113f02b32d9f
-					;;
 				*)
 					die "Unknown snapshot: ${PV}"
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-27 22:00 Andrew Ammerlaan
  0 siblings, 0 replies; 6663+ messages in thread
From: Andrew Ammerlaan @ 2024-07-27 22:00 UTC (permalink / raw
  To: gentoo-commits
commit:     1a493d13bde1f371113388d9bd13a7e609f7bf07
Author:     Andrew Ammerlaan <andrewammerlaan <AT> gentoo <DOT> org>
AuthorDate: Sat Jul 27 21:25:53 2024 +0000
Commit:     Andrew Ammerlaan <andrewammerlaan <AT> gentoo <DOT> org>
CommitDate: Sat Jul 27 22:00:36 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=1a493d13
kernel-build.eclass: fixup left-over KERNEL_IUSE_SECUREBOOT
This was merged with KERNEL_IUSE_MODULES_SIGN in
a42e98431e7538eadaee1df2b90f0e3174b22341, but this one was missed.
Signed-off-by: Andrew Ammerlaan <andrewammerlaan <AT> gentoo.org>
 eclass/kernel-build.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/kernel-build.eclass b/eclass/kernel-build.eclass
index 893a1bdb449c..c4f3db0028a9 100644
--- a/eclass/kernel-build.eclass
+++ b/eclass/kernel-build.eclass
@@ -521,7 +521,7 @@ kernel-build_src_install() {
 				--output="${image%/*}/uki.efi"
 			)
 
-			if [[ ${KERNEL_IUSE_SECUREBOOT} ]] && use secureboot; then
+			if [[ ${KERNEL_IUSE_MODULES_SIGN} ]] && use secureboot; then
 				ukify_args+=(
 					--signtool=sbsign
 					--secureboot-private-key="${SECUREBOOT_SIGN_KEY}"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-28 17:40 Florian Schmaus
  0 siblings, 0 replies; 6663+ messages in thread
From: Florian Schmaus @ 2024-07-28 17:40 UTC (permalink / raw
  To: gentoo-commits
commit:     7eddfd1f9b69da3a97fb5b6b3781a6a31feaa59a
Author:     Florian Schmaus <flow <AT> gentoo <DOT> org>
AuthorDate: Sat Jul 27 10:12:24 2024 +0000
Commit:     Florian Schmaus <flow <AT> gentoo <DOT> org>
CommitDate: Sun Jul 28 17:39:57 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=7eddfd1f
java-utils-2.eclass: select java-config binary, prefer java-config over java-config-2
This prepares the eclass for the transition from /usr/bin/java-config-2
to /usr/bin/java-config.
Starting with dev-java/java-config-2.3.3, the java-config utility is
installed as java-config and the java-config-2 compatibility symlink
will only be installed if the 'compat' USE flag is enabled (currently
the default).
Signed-off-by: Florian Schmaus <flow <AT> gentoo.org>
 eclass/java-utils-2.eclass | 8 +++++++-
 1 file changed, 7 insertions(+), 1 deletion(-)
diff --git a/eclass/java-utils-2.eclass b/eclass/java-utils-2.eclass
index 8a062f2ad87e..559342068cc0 100644
--- a/eclass/java-utils-2.eclass
+++ b/eclass/java-utils-2.eclass
@@ -2723,7 +2723,13 @@ java-pkg_build-vm-from-handle() {
 	fi
 
 	for vm in ${JAVA_PKG_WANT_BUILD_VM}; do
-		if java-config-2 --select-vm=${vm} 2>/dev/null; then
+		local java_config
+		for java_config in java-config{,-2}; do
+			type -p ${java_config} >/dev/null && break
+		done
+		[[ -z ${java_config} ]] && die "No java-config binary in PATH"
+
+		if ${java_config} --select-vm=${vm} 2>/dev/null; then
 			echo ${vm}
 			return 0
 		fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-07-31  0:02 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-07-31  0:02 UTC (permalink / raw
  To: gentoo-commits
commit:     18cf313474587d078b1520f03511433ead141de4
Author:     A. Wilcox <AWilcox <AT> Wilcox-Tech <DOT> com>
AuthorDate: Sun Jul 21 16:06:59 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Jul 31 00:01:47 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=18cf3134
toolchain.eclass: ppc64-musl: Disable libquadmath
* --disable-libquadmath is needed to avoid GCC PR 116007.
* --disable-libquadmath-support is needed for Fortran to build, as GCC
  upstream requires a weak header when float128 is available.
* --with-long-double-128=no explicitly disables all Float128 support.
[sam: Fix whitespace.]
Bug: https://bugs.gentoo.org/892874
Signed-off-by: A. Wilcox <AWilcox <AT> Wilcox-Tech.com>
Closes: https://github.com/gentoo/gentoo/pull/37689
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 9 ++++++++-
 1 file changed, 8 insertions(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index c7c366a37ad0..a60024c134c3 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1214,7 +1214,14 @@ toolchain_src_configure() {
 			# - https://git.musl-libc.org/cgit/musl/tree/INSTALL
 			# - bug #704784
 			# - https://gcc.gnu.org/PR93157
-			[[ ${CTARGET} == powerpc64-*-musl ]] && confgcc+=( --with-abi=elfv2 )
+			# musl additionally does not support libquadmath.  See:
+			# - https://gcc.gnu.org/PR116007
+			[[ ${CTARGET} == powerpc64-*-musl ]] && confgcc+=(
+				--with-abi=elfv2
+				--disable-libquadmath
+				--disable-libquadmath-support
+				--with-long-double-128=no
+			)
 
 			if in_iuse ieee-long-double; then
 				# musl requires 64-bit long double, not IBM double-double or IEEE quad.
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-01  7:32 Miroslav Šulc
  0 siblings, 0 replies; 6663+ messages in thread
From: Miroslav Šulc @ 2024-08-01  7:32 UTC (permalink / raw
  To: gentoo-commits
commit:     40069e31dfc02ce38c2b30ba0ed9544d386521bb
Author:     Volkmar W. Pogatzki <gentoo <AT> pogatzki <DOT> net>
AuthorDate: Sun Jul 28 19:26:59 2024 +0000
Commit:     Miroslav Šulc <fordfrog <AT> gentoo <DOT> org>
CommitDate: Thu Aug  1 07:32:11 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=40069e31
java-utils-2.eclass: etestng use java-pkg_getjars --build-only
Closes: https://bugs.gentoo.org/936812
Signed-off-by: Volkmar W. Pogatzki <gentoo <AT> pogatzki.net>
Closes: https://github.com/gentoo/gentoo/pull/37772/commits/513f82dafdb7874b77da408068e9b2e90bfe0c36
Signed-off-by: Miroslav Šulc <fordfrog <AT> gentoo.org>
 eclass/java-utils-2.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/java-utils-2.eclass b/eclass/java-utils-2.eclass
index 559342068cc0..9c657cc4c1f9 100644
--- a/eclass/java-utils-2.eclass
+++ b/eclass/java-utils-2.eclass
@@ -1926,7 +1926,7 @@ etestng() {
 
 	local runner=org.testng.TestNG
 	if [[ ${PN} != testng ]]; then
-		local cp=$(java-pkg_getjars --with-dependencies testng)
+		local cp=$(java-pkg_getjars --build-only --with-dependencies testng)
 	else
 		local cp=testng.jar
 	fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-01 20:20 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-08-01 20:20 UTC (permalink / raw
  To: gentoo-commits
commit:     4b2e1186050ea531da4a9062d8c40f9d8cd8c925
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Thu Aug  1 19:32:22 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Thu Aug  1 20:20:24 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=4b2e1186
llvm.org.eclass: Remove 19.x snapshot support
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 ---
 1 file changed, 3 deletions(-)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index dfe278fe94ac..d705947ce0d2 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -72,9 +72,6 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 			_LLVM_SOURCE_TYPE=snapshot
 
 			case ${PV} in
-				19.0.0_pre20240720)
-					EGIT_COMMIT=72d8c2737bb557af9d0c735b9fa30b1b03485627
-					;;
 				20.0.0_pre20240801)
 					EGIT_COMMIT=130c135689ec12ab78c53645808524a8d28f7cae
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-04  7:27 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-08-04  7:27 UTC (permalink / raw
  To: gentoo-commits
commit:     e7e43ef530436c353b5cfcf1e4ca24b60369d9ea
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Aug  4 07:26:00 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Aug  4 07:27:04 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=e7e43ef5
toolchain.eclass: drop -fno-harden-control-flow-redundancy append
This confuses things if e.g. using GDC from older GCC. Not worth it given
I'd only added it for a personal experiment.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 3 ---
 1 file changed, 3 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index a60024c134c3..7aa0f5a170f8 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1661,9 +1661,6 @@ gcc_do_filter_flags() {
 
 		# New in GCC 14.
 		filter-flags -Walloc-size
-	else
-		# Makes things painfully slow and no real benefit for the compiler.
-		append-flags $(test-flags-CC -fno-harden-control-flow-redundancy)
 	fi
 
 	# Please use USE=lto instead (bug #906007).
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-04  7:30 Andrew Ammerlaan
  0 siblings, 0 replies; 6663+ messages in thread
From: Andrew Ammerlaan @ 2024-08-04  7:30 UTC (permalink / raw
  To: gentoo-commits
commit:     4fe379b9898caba13ed8fdc8c4d829b32f43fa06
Author:     Andrew Ammerlaan <andrewammerlaan <AT> gentoo <DOT> org>
AuthorDate: Sun Aug  4 07:14:17 2024 +0000
Commit:     Andrew Ammerlaan <andrewammerlaan <AT> gentoo <DOT> org>
CommitDate: Sun Aug  4 07:30:04 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=4fe379b9
kernel-install.eclass: fixup indentation
Signed-off-by: Andrew Ammerlaan <andrewammerlaan <AT> gentoo.org>
 eclass/kernel-install.eclass | 24 ++++++++++++------------
 1 file changed, 12 insertions(+), 12 deletions(-)
diff --git a/eclass/kernel-install.eclass b/eclass/kernel-install.eclass
index 0a85bfb8629d..15b7cf739bc3 100644
--- a/eclass/kernel-install.eclass
+++ b/eclass/kernel-install.eclass
@@ -560,21 +560,21 @@ kernel-install_pkg_pretend() {
 		ewarn "that distribution kernels will boot without an initramfs."
 		ewarn
 		ewarn "You have disabled the initramfs USE flag, and as a result the package manager"
-        ewarn "will not enforce the configuration of an initramfs generator in"
-        ewarn "sys-kernel/installkernel."
-        ewarn
+		ewarn "will not enforce the configuration of an initramfs generator in"
+		ewarn "sys-kernel/installkernel."
+		ewarn
 		ewarn "If you wish to use a custom initramfs generator, then please ensure that" 
-        ewarn "/sbin/installkernel is capable of calling it via a kernel installation hook,"
-        ewarn "and is also configured to use it via /etc/kernel/install.conf."
-        ewarn
-        ewarn "If you wish to boot without an initramfs, then please ensure that"
-        ewarn "all kernel drivers required to boot your system are built into the"
-        ewarn "kernel by modifying the default distribution kernel configuration"
-        ewarn "using /etc/kernel/config.d"
-        ewarn
+		ewarn "/sbin/installkernel is capable of calling it via a kernel installation hook,"
+		ewarn "and is also configured to use it via /etc/kernel/install.conf."
+		ewarn
+		ewarn "If you wish to boot without an initramfs, then please ensure that"
+		ewarn "all kernel drivers required to boot your system are built into the"
+		ewarn "kernel by modifying the default distribution kernel configuration"
+		ewarn "using /etc/kernel/config.d"
+		ewarn
 		ewarn "Please refer to the installkernel and distribution kernel documentation:"
 		ewarn "    https://wiki.gentoo.org/wiki/Installkernel"
-        ewarn "    https://wiki.gentoo.org/wiki/Project:Distribution_Kernel"
+		ewarn "    https://wiki.gentoo.org/wiki/Project:Distribution_Kernel"
 	fi
 }
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-04  8:28 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-08-04  8:28 UTC (permalink / raw
  To: gentoo-commits
commit:     361c3758642891759b0ed60a8f96bc0776d19f15
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Aug  4 01:27:26 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Aug  4 08:26:41 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=361c3758
toolchain.eclass: use more conservative flags in src_test
For tests, we need to put some effort in to counteract our defaults
like -Wformat-security and -Wtrampolines (which we may want to revisit
at some point, but it is what it is for now).
Use a subshell so we can mangle the values within without affecting
the rest of the build.
I still get some failures with this (including some related to e.g.
-Wformat-security still) but far fewer, the flags don't get passed
everywhere so needs more poking or maybe just patching those tests
within the patch we use to change defaults.
See also the discussion on gcc-patches recently [0].
[0] https://inbox.sourceware.org/gcc-patches/ee9a8a6b11438f158933a21d7965b486987be5a8.1721454759.git.sam <AT> gentoo.org/
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 41 ++++++++++++++++++++++++++++++++++++++---
 1 file changed, 38 insertions(+), 3 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 7aa0f5a170f8..d2f42804301e 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1923,9 +1923,44 @@ toolchain_src_test() {
 	# Controls running expensive tests in e.g. the torture testsuite.
 	local -x GCC_TEST_RUN_EXPENSIVE=1
 
-	# nonfatal here as we die if the comparison below fails. Also, note that
-	# the exit code of targets other than 'check' may be unreliable.
-	nonfatal emake -C "${WORKDIR}"/build -k "${GCC_TESTS_CHECK_TARGET}" RUNTESTFLAGS="${GCC_TESTS_RUNTESTFLAGS}"
+	# Use a subshell to allow meddling with flags just for the testsuite
+	(
+		# Workaround our -Wformat-security default which breaks
+		# various tests as it adds unexpected warning output.
+		append-flags -Wno-format-security -Wno-format
+		# Workaround our -Wtrampolines default which breaks
+		# tests too.
+		append-flags -Wno-trampolines
+
+		# Issues with Ada tests:
+		# gnat.dg/align_max.adb
+		# gnat.dg/trampoline4.adb
+		#
+		# A handful of Ada tests use -fstack-check and conflict
+		# with -fstack-clash-protection.
+		#
+		# TODO: This isn't ideal given it obv. affects codegen
+		# and we want to be sure it works.
+		append-flags -fno-stack-clash-protection
+		# A handful of Ada (and objc++?) tests need an executable stack
+		append-ldflags -Wl,--no-warn-execstack
+
+		# Go doesn't support this and causes noisy warnings
+		filter-flags -Wbuiltin-declaration-mismatch
+
+		# nonfatal here as we die if the comparison below fails. Also, note that
+		# the exit code of targets other than 'check' may be unreliable.
+		nonfatal emake -C "${WORKDIR}"/build -k "${GCC_TESTS_CHECK_TARGET}" \
+			RUNTESTFLAGS="${GCC_TESTS_RUNTESTFLAGS}" \
+			CFLAGS_FOR_TARGET="${CFLAGS_FOR_TARGET:-${CFLAGS}}" \
+			CXXFLAGS_FOR_TARGET="${CXXFLAGS_FOR_TARGET:-${CXXFLAGS}}" \
+			LDFLAGS_FOR_TARGET="${LDFLAGS_FOR_TARGET:-${LDFLAGS}}" \
+			CFLAGS="${CFLAGS}" \
+			CXXFLAGS="${CXXFLAGS}" \
+			FCFLAGS="${FCFLAGS}" \
+			FFLAGS="${FFLAGS}" \
+			LDFLAGS="${LDFLAGS}"
+	)
 
 	# Produce an updated failure manifest.
 	einfo "Generating a new failure manifest ${T}/${CHOST}.xfail"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-06  1:46 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-08-06  1:46 UTC (permalink / raw
  To: gentoo-commits
commit:     f66787897a590b8c949d257e3a9107f8995f62ae
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Aug  6 01:44:15 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Aug  6 01:45:08 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=f6678789
toolchain.eclass: run tests for -m32 if multilib
TODO: Does this handle s390 (-m31) correctly?
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 4 +++-
 1 file changed, 3 insertions(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index d2f42804301e..9304800f09f7 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1898,7 +1898,6 @@ gcc_do_make() {
 #---->> src_test <<----
 
 # TODO: add JIT testing
-# TODO: add multilib testing
 toolchain_src_test() {
 	# GCC's testsuite is a special case.
 	#
@@ -1948,6 +1947,9 @@ toolchain_src_test() {
 		# Go doesn't support this and causes noisy warnings
 		filter-flags -Wbuiltin-declaration-mismatch
 
+		# TODO: Does this handle s390 (-m31) correctly?
+		is_multilib && GCC_TESTS_RUNTESTFLAGS+=" --target_board=unix\{,-m32\}"
+
 		# nonfatal here as we die if the comparison below fails. Also, note that
 		# the exit code of targets other than 'check' may be unreliable.
 		nonfatal emake -C "${WORKDIR}"/build -k "${GCC_TESTS_CHECK_TARGET}" \
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-06  8:47 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-08-06  8:47 UTC (permalink / raw
  To: gentoo-commits
commit:     625574f70212d097e82a1cfcc34ee09ca467306e
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Mon Aug  5 13:57:53 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Tue Aug  6 08:28:53 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=625574f7
toolchain-funcs.eclass: Fix tc-is-lto not to leave stray files in T
Fix tc-is-lto function to remove the temporary file after testing.
Besides being cleaner, this fixes a permission problem when using
Paludis and tc-is-lto is used both in pkg_setup() (which creates
the temporary file owned by root) and src_*() phase (which attempts
to rewrite it as a regular user).
Thanks to negril for the report!
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/toolchain-funcs.eclass | 8 +++++---
 1 file changed, 5 insertions(+), 3 deletions(-)
diff --git a/eclass/toolchain-funcs.eclass b/eclass/toolchain-funcs.eclass
index cde84e6f34c8..e73af9772938 100644
--- a/eclass/toolchain-funcs.eclass
+++ b/eclass/toolchain-funcs.eclass
@@ -1234,6 +1234,7 @@ tc-get-build-ptr-size() {
 # @RETURN: Shell true if we are using LTO, shell false otherwise
 tc-is-lto() {
 	local f="${T}/test-lto.o"
+	local ret=1
 
 	case $(tc-get-compiler-type) in
 		clang)
@@ -1241,14 +1242,15 @@ tc-is-lto() {
 			# If LTO is used, clang will output bytecode and llvm-bcanalyzer
 			# will run successfully.  Otherwise, it will output plain object
 			# file and llvm-bcanalyzer will exit with error.
-			llvm-bcanalyzer "${f}" &>/dev/null && return 0
+			llvm-bcanalyzer "${f}" &>/dev/null && ret=0
 			;;
 		gcc)
 			$(tc-getCC) ${CFLAGS} -c -o "${f}" -x c - <<<"" || die
-			[[ $($(tc-getREADELF) -S "${f}") == *.gnu.lto* ]] && return 0
+			[[ $($(tc-getREADELF) -S "${f}") == *.gnu.lto* ]] && ret=0
 			;;
 	esac
-	return 1
+	rm -f "${f}" || die
+	return "${ret}"
 }
 
 fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-06  8:47 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-08-06  8:47 UTC (permalink / raw
  To: gentoo-commits
commit:     9b1ccc14f4a6e9b6c614a4c5f5d6ec15f6339d64
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Wed Jul 31 07:46:21 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Tue Aug  6 08:30:08 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=9b1ccc14
python-utils-r1.eclass: Add a sanity check for PYTHONPATH
Add a sanity check that ensures that PYTHONPATH does not contain any
relative paths.  While at it, also explicitly warn about PYTHONPATH
being set, so we know about it in build logs.
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/distutils-r1.eclass     |  1 +
 eclass/python-any-r1.eclass    |  3 ++-
 eclass/python-r1.eclass        |  2 ++
 eclass/python-single-r1.eclass |  3 ++-
 eclass/python-utils-r1.eclass  | 34 ++++++++++++++++++++++++++++++++++
 5 files changed, 41 insertions(+), 2 deletions(-)
diff --git a/eclass/distutils-r1.eclass b/eclass/distutils-r1.eclass
index 4afee3d45b1c..5d9f97474b29 100644
--- a/eclass/distutils-r1.eclass
+++ b/eclass/distutils-r1.eclass
@@ -936,6 +936,7 @@ _distutils-r1_print_package_versions() {
 # distutils patches and/or quirks.
 distutils-r1_python_prepare_all() {
 	debug-print-function ${FUNCNAME} "${@}"
+	_python_sanity_checks
 	_distutils-r1_check_all_phase_mismatch
 
 	if [[ ! ${DISTUTILS_OPTIONAL} ]]; then
diff --git a/eclass/python-any-r1.eclass b/eclass/python-any-r1.eclass
index a21df8e89498..c1f27cfbac0d 100644
--- a/eclass/python-any-r1.eclass
+++ b/eclass/python-any-r1.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2023 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: python-any-r1.eclass
@@ -272,6 +272,7 @@ python_gen_any_dep() {
 # This function will call python_check_deps() if defined.
 python_setup() {
 	debug-print-function ${FUNCNAME} "${@}"
+	_python_sanity_checks
 
 	# support developer override
 	if [[ ${PYTHON_COMPAT_OVERRIDE} ]]; then
diff --git a/eclass/python-r1.eclass b/eclass/python-r1.eclass
index c5fa6770558f..adf87c2c52f7 100644
--- a/eclass/python-r1.eclass
+++ b/eclass/python-r1.eclass
@@ -617,6 +617,7 @@ _python_multibuild_wrapper() {
 # locally, and the former two are exported to the command environment.
 python_foreach_impl() {
 	debug-print-function ${FUNCNAME} "${@}"
+	_python_sanity_checks
 
 	if [[ ${_DISTUTILS_R1_ECLASS} ]]; then
 		if has "${EBUILD_PHASE}" prepare configure compile test install &&
@@ -708,6 +709,7 @@ python_foreach_impl() {
 # @CODE
 python_setup() {
 	debug-print-function ${FUNCNAME} "${@}"
+	_python_sanity_checks
 
 	local has_check_deps
 	declare -f python_check_deps >/dev/null && has_check_deps=1
diff --git a/eclass/python-single-r1.eclass b/eclass/python-single-r1.eclass
index 4d61f08c06f0..481b6cf91ba0 100644
--- a/eclass/python-single-r1.eclass
+++ b/eclass/python-single-r1.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2022 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: python-single-r1.eclass
@@ -393,6 +393,7 @@ python_gen_impl_dep() {
 # the Python build environment up for it.
 python_setup() {
 	debug-print-function ${FUNCNAME} "${@}"
+	_python_sanity_checks
 
 	unset EPYTHON
 
diff --git a/eclass/python-utils-r1.eclass b/eclass/python-utils-r1.eclass
index c47565fa1db2..cc33a1c1bffd 100644
--- a/eclass/python-utils-r1.eclass
+++ b/eclass/python-utils-r1.eclass
@@ -1544,4 +1544,38 @@ python_has_version() {
 	return 0
 }
 
+# @FUNCTION: _python_sanity_checks
+# @INTERNAL
+# @DESCRIPTION:
+# Perform additional environment sanity checks.
+_python_sanity_checks() {
+	debug-print-function ${FUNCNAME} "${@}"
+
+	[[ ${_PYTHON_SANITY_CHECKED} ]] && return
+
+	if [[ -v PYTHONPATH ]]; then
+		local x paths=()
+		mapfile -d ':' -t paths <<<${PYTHONPATH}
+
+		for x in "${paths[@]}"; do
+			if [[ ${x} != /* ]]; then
+				eerror "Relative path found in PYTHONPATH:"
+				eerror
+				eerror "  PYTHONPATH=${PYTHONPATH@Q}"
+				eerror
+				eerror "This is guaranteed to cause random breakage.  Please make sure that"
+				eerror "your PYTHONPATH contains absolute paths only (and only if necessary)."
+				eerror "Note that empty values (including ':' at either end and an empty"
+				eerror "PYTHONPATH) count as the current directory.  If no PYTHONPATH"
+				eerror "is intended, it needs to be unset instead."
+				die "Relative paths in PYTHONPATH are forbidden: ${x@Q}"
+			fi
+		done
+
+		elog "PYTHONPATH=${PYTHONPATH@Q}"
+	fi
+
+	_PYTHON_SANITY_CHECKED=1
+}
+
 fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-06  8:47 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-08-06  8:47 UTC (permalink / raw
  To: gentoo-commits
commit:     d57601effef63b266afe7df5c8cb7dae52fa44ac
Author:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
AuthorDate: Thu Jul 25 17:34:45 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Tue Aug  6 08:30:09 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=d57601ef
cargo.eclass: Use newer Cargo config file name
"config" is deprecated and "config.toml" has been valid for ages.
Signed-off-by: James Le Cuirot <chewi <AT> gentoo.org>
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/cargo.eclass | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/eclass/cargo.eclass b/eclass/cargo.eclass
index 7db34efb4e17..aab28dbbac16 100644
--- a/eclass/cargo.eclass
+++ b/eclass/cargo.eclass
@@ -248,7 +248,7 @@ cargo_crate_uris() {
 
 # @FUNCTION: cargo_gen_config
 # @DESCRIPTION:
-# Generate the $CARGO_HOME/config necessary to use our local registry and settings.
+# Generate the $CARGO_HOME/config.toml necessary to use our local registry and settings.
 # Cargo can also be configured through environment variables in addition to the TOML syntax below.
 # For each configuration key below of the form foo.bar the environment variable CARGO_FOO_BAR
 # can also be used to define the value.
@@ -261,7 +261,7 @@ cargo_gen_config() {
 
 	mkdir -p "${ECARGO_HOME}" || die
 
-	cat > "${ECARGO_HOME}/config" <<- _EOF_ || die "Failed to create cargo config"
+	cat > "${ECARGO_HOME}/config.toml" <<- _EOF_ || die "Failed to create cargo config"
 	[source.gentoo]
 	directory = "${ECARGO_VENDOR}"
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-06  8:47 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-08-06  8:47 UTC (permalink / raw
  To: gentoo-commits
commit:     7d7c5168294a4d90681c8d3ab6ac985c4eba1643
Author:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
AuthorDate: Wed Jul 24 21:59:16 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Tue Aug  6 08:30:11 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=7d7c5168
cargo.eclass: Explicitly tell rustc not to strip binaries
Most projects don't strip binaries in release mode by default, but there
are exceptions like app-misc/broot.
Signed-off-by: James Le Cuirot <chewi <AT> gentoo.org>
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/cargo.eclass | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/eclass/cargo.eclass b/eclass/cargo.eclass
index ef927aac50cd..99a7959b22e2 100644
--- a/eclass/cargo.eclass
+++ b/eclass/cargo.eclass
@@ -267,7 +267,7 @@ cargo_gen_config() {
 	# with USE=nightly. There is no simple way around this.
 	tc-export_build_env
 	local LD_A=( $(tc-getBUILD_CC) ${BUILD_LDFLAGS} )
-	local MY_BUILD_RUSTFLAGS="-C linker=${LD_A[0]}"
+	local MY_BUILD_RUSTFLAGS="-C strip=none -C linker=${LD_A[0]}"
 	[[ ${#LD_A[@]} -gt 1 ]] && MY_BUILD_RUSTFLAGS+="$(printf -- ' -C link-arg=%s' "${LD_A[@]:1}")"
 	MY_BUILD_RUSTFLAGS+=" ${RUSTFLAGS} ${BUILD_RUSTFLAGS}"
 	tc-is-cross-compiler || MY_BUILD_RUSTFLAGS+=" ${TARGET_RUSTFLAGS}"
@@ -564,7 +564,7 @@ cargo_env() {
 		local -x CARGO_BUILD_TARGET=$(rust_abi)
 		local TRIPLE=${CARGO_BUILD_TARGET//-/_}
 		local TRIPLE=${TRIPLE^^} LD_A=( $(tc-getCC) ${LDFLAGS} )
-		local -x CARGO_TARGET_"${TRIPLE}"_RUSTFLAGS="-C linker=${LD_A[0]}"
+		local -x CARGO_TARGET_"${TRIPLE}"_RUSTFLAGS="-C strip=none -C linker=${LD_A[0]}"
 		[[ ${#LD_A[@]} -gt 1 ]] && local CARGO_TARGET_"${TRIPLE}"_RUSTFLAGS+="$(printf -- ' -C link-arg=%s' "${LD_A[@]:1}")"
 		local CARGO_TARGET_"${TRIPLE}"_RUSTFLAGS+=" ${RUSTFLAGS} ${TARGET_RUSTFLAGS}"
 	fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-06  8:47 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-08-06  8:47 UTC (permalink / raw
  To: gentoo-commits
commit:     9c0708dcae5ef0792e2273968f6f6ff45d90b11f
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Thu Jun 13 15:17:07 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Tue Aug  6 08:29:01 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=9c0708dc
toolchain-funcs.eclass: Add tc-has-64bit-time_t
Add a helper function to check whether time_t is 64-bit.  This could
be used e.g. to deselect tests that rely on timestamps exceeding Y2k38.
It is meant to be more future-proof than hardcoding a list of 32-bit
architectures, given the necessity of switching to 64-bit time_t
in the future.
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/toolchain-funcs.eclass | 12 +++++++++++-
 1 file changed, 11 insertions(+), 1 deletion(-)
diff --git a/eclass/toolchain-funcs.eclass b/eclass/toolchain-funcs.eclass
index e73af9772938..9f0953c079e3 100644
--- a/eclass/toolchain-funcs.eclass
+++ b/eclass/toolchain-funcs.eclass
@@ -1,4 +1,4 @@
-# Copyright 2002-2023 Gentoo Authors
+# Copyright 2002-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: toolchain-funcs.eclass
@@ -1253,4 +1253,14 @@ tc-is-lto() {
 	return "${ret}"
 }
 
+# @FUNCTION: tc-has-64bit-time_t
+# @RETURN: Shell true if time_t is at least 64 bits long, false otherwise
+tc-has-64bit-time_t() {
+	$(tc-getCC) ${CFLAGS} ${CPPFLAGS} -c -x c - -o /dev/null <<-EOF &>/dev/null
+		#include <sys/types.h>
+		int test[sizeof(time_t) >= 8 ? 1 : -1];
+	EOF
+	return $?
+}
+
 fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-06  8:47 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-08-06  8:47 UTC (permalink / raw
  To: gentoo-commits
commit:     11e91de6642a4b329566bb21b3a58a083994745f
Author:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
AuthorDate: Wed Jul 24 14:26:34 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Tue Aug  6 08:30:10 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=11e91de6
cargo.eclass: Add cargo_env helper and use it in compile, test, install
Rust packages have a tendency to rebuild parts during test and install.
It is not clear whether this can be addressed. We were therefore relying
on some environment variables set during the compile phase for
cross-compiling to work in the later phases. This is not ideal,
especially if you need to build for multiple targets.
These environment variables can also be useful in other contexts, such
as the build runner in app-misc/anki.
This change moves the setting of these variables into a separate helper
that is now used in all these phases and can be used by ebuilds too. The
variables are now kept local to each invocation of this helper,
preventing leakage.
Signed-off-by: James Le Cuirot <chewi <AT> gentoo.org>
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/cargo.eclass | 37 +++++++++++++++++++++++--------------
 1 file changed, 23 insertions(+), 14 deletions(-)
diff --git a/eclass/cargo.eclass b/eclass/cargo.eclass
index aab28dbbac16..de4a012354ee 100644
--- a/eclass/cargo.eclass
+++ b/eclass/cargo.eclass
@@ -523,26 +523,23 @@ cargo_src_configure() {
 	[[ ${ECARGO_ARGS[@]} ]] && einfo "Configured with: ${ECARGO_ARGS[@]}"
 }
 
-# @FUNCTION: cargo_src_compile
+# @FUNCTION: cargo_env
+# @USAGE: Command with its arguments
 # @DESCRIPTION:
-# Build the package using cargo build.
-cargo_src_compile() {
-	debug-print-function ${FUNCNAME} "$@"
-
-	[[ ${_CARGO_GEN_CONFIG_HAS_RUN} ]] || \
-		die "FATAL: please call cargo_gen_config before using ${FUNCNAME}"
-
+# Run the given command under an environment needed for performing tasks with
+# Cargo such as building.
+cargo_env() {
 	filter-lto
 	tc-export AR CC CXX PKG_CONFIG
 
 	if tc-is-cross-compiler; then
-		export CARGO_BUILD_TARGET=$(rust_abi)
+		local -x CARGO_BUILD_TARGET=$(rust_abi)
 		local TRIPLE=${CARGO_BUILD_TARGET//-/_}
-		export CARGO_TARGET_"${TRIPLE^^}"_LINKER=$(tc-getCC)
+		local -x CARGO_TARGET_"${TRIPLE^^}"_LINKER=$(tc-getCC)
 
 		# Set vars for cc-rs crate.
 		tc-export_build_env
-		export \
+		local -x \
 			HOST_AR=$(tc-getBUILD_AR)
 			HOST_CC=$(tc-getBUILD_CC)
 			HOST_CXX=$(tc-getBUILD_CXX)
@@ -550,9 +547,21 @@ cargo_src_compile() {
 			HOST_CXXFLAGS=${BUILD_CXXFLAGS}
 	fi
 
+	"${@}"
+}
+
+# @FUNCTION: cargo_src_compile
+# @DESCRIPTION:
+# Build the package using cargo build.
+cargo_src_compile() {
+	debug-print-function ${FUNCNAME} "$@"
+
+	[[ ${_CARGO_GEN_CONFIG_HAS_RUN} ]] || \
+		die "FATAL: please call cargo_gen_config before using ${FUNCNAME}"
+
 	set -- cargo build $(usex debug "" --release) ${ECARGO_ARGS[@]} "$@"
 	einfo "${@}"
-	"${@}" || die "cargo build failed"
+	cargo_env "${@}" || die "cargo build failed"
 }
 
 # @FUNCTION: cargo_src_install
@@ -573,7 +582,7 @@ cargo_src_install() {
 		$(usex debug --debug "") \
 		${ECARGO_ARGS[@]} "$@"
 	einfo "${@}"
-	"${@}" || die "cargo install failed"
+	cargo_env "${@}" || die "cargo install failed"
 
 	rm -f "${ED}/usr/.crates.toml" || die
 	rm -f "${ED}/usr/.crates2.json" || die
@@ -590,7 +599,7 @@ cargo_src_test() {
 
 	set -- cargo test $(usex debug "" --release) ${ECARGO_ARGS[@]} "$@"
 	einfo "${@}"
-	"${@}" || die "cargo test failed"
+	cargo_env "${@}" || die "cargo test failed"
 }
 
 fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-06  8:47 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-08-06  8:47 UTC (permalink / raw
  To: gentoo-commits
commit:     9e9c222fe930f6369f2192e4de0175afc21e1e7f
Author:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
AuthorDate: Wed Jul 24 17:19:30 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Tue Aug  6 08:30:11 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=9e9c222f
cargo.eclass: Handle LDFLAGS and RUSTFLAGS better
LDFLAGS are not currently honoured by Cargo builds at all. It would be
particularly advantageous to honour -fuse-ld because alternative linkers
like mold are known to be significantly faster at handling Rust.
As things stand, the eclass sets the linker to CC when cross-compiling,
but it does so erroneously due to a shell quoting issue. If CC includes
arguments, an error occurs when setting the CARGO_TARGET_*_LINKER
variable. Even with the right quoting, Cargo still fails because this
variable is not allowed to include arguments. They have to be specified
via RUSTFLAGS instead.
The build host linker is frequently invoked due to the use of build
scripts by some crates. We would therefore also like to configure the
build host linker properly when cross-compiling, but unfortunately there
is currently no way to do this without using a Rust nightly feature.
The build host linker is now configured in the cargo_gen_config function
because this configuration is static. Conversely, the target host linker
is configured with environment variables in the cargo_env function
because the target may change.
Some ebuilds already set RUSTFLAGS, so some consideration was given to
how to handle these. When set, Cargo prioritises RUSTFLAGS and similar
over specific configuration for the build and target hosts, so these
must be unset. We can still include their contents in that configuration
for convenience though. BUILD_RUSTFLAGS can be used by ebuilds to
set flags only for the build host.
It should not be necessary for ebuilds to figure out which Rust ABI is
applicable in order to set flags only for the target host, so the helper
reads from a simple TARGET_RUSTFLAGS variable without the triple for
convenience.
Signed-off-by: James Le Cuirot <chewi <AT> gentoo.org>
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/cargo.eclass | 63 ++++++++++++++++++++++++++++++++++-------------------
 1 file changed, 41 insertions(+), 22 deletions(-)
diff --git a/eclass/cargo.eclass b/eclass/cargo.eclass
index de4a012354ee..ef927aac50cd 100644
--- a/eclass/cargo.eclass
+++ b/eclass/cargo.eclass
@@ -109,7 +109,7 @@ ECARGO_VENDOR="${ECARGO_HOME}/gentoo"
 #
 # If you enable CARGO_OPTIONAL, you have to set BDEPEND on virtual/rust
 # for your package and call at least cargo_gen_config manually before using
-# other src_functions of this eclass.
+# other src_functions or cargo_env of this eclass.
 # Note that cargo_gen_config is automatically called by cargo_src_unpack.
 
 # @ECLASS_VARIABLE: myfeatures
@@ -259,6 +259,19 @@ cargo_crate_uris() {
 cargo_gen_config() {
 	debug-print-function ${FUNCNAME} "$@"
 
+	# The default linker is "cc" so override by setting linker to CC in the
+	# RUSTFLAGS. The given linker cannot include any arguments, so split these
+	# into link-args along with LDFLAGS. Also include external RUSTFLAGS.
+	# Note that as of Rust 1.80, the build host RUSTFLAGS are ignored when
+	# cross-compiling unless you use the unstable host-config feature available
+	# with USE=nightly. There is no simple way around this.
+	tc-export_build_env
+	local LD_A=( $(tc-getBUILD_CC) ${BUILD_LDFLAGS} )
+	local MY_BUILD_RUSTFLAGS="-C linker=${LD_A[0]}"
+	[[ ${#LD_A[@]} -gt 1 ]] && MY_BUILD_RUSTFLAGS+="$(printf -- ' -C link-arg=%s' "${LD_A[@]:1}")"
+	MY_BUILD_RUSTFLAGS+=" ${RUSTFLAGS} ${BUILD_RUSTFLAGS}"
+	tc-is-cross-compiler || MY_BUILD_RUSTFLAGS+=" ${TARGET_RUSTFLAGS}"
+
 	mkdir -p "${ECARGO_HOME}" || die
 
 	cat > "${ECARGO_HOME}/config.toml" <<- _EOF_ || die "Failed to create cargo config"
@@ -273,6 +286,7 @@ cargo_gen_config() {
 	offline = true
 
 	[build]
+	rustflags = "${MY_BUILD_RUSTFLAGS}"
 	jobs = $(makeopts_jobs)
 	incremental = false
 
@@ -527,27 +541,41 @@ cargo_src_configure() {
 # @USAGE: Command with its arguments
 # @DESCRIPTION:
 # Run the given command under an environment needed for performing tasks with
-# Cargo such as building.
+# Cargo such as building. RUSTFLAGS is used for both the build and target host.
+# BUILD_RUSTFLAGS and TARGET_RUSTFLAGS are used for just the build host and
+# target host respectively. Ensure these are set consistently between Cargo
+# invocations, otherwise rebuilds will occur.
 cargo_env() {
+	[[ ${_CARGO_GEN_CONFIG_HAS_RUN} ]] || \
+		die "FATAL: please call cargo_gen_config before using ${FUNCNAME}"
+
 	filter-lto
 	tc-export AR CC CXX PKG_CONFIG
 
+	# Set vars for cc-rs crate.
+	local -x \
+		HOST_AR=$(tc-getBUILD_AR)
+		HOST_CC=$(tc-getBUILD_CC)
+		HOST_CXX=$(tc-getBUILD_CXX)
+		HOST_CFLAGS=${BUILD_CFLAGS}
+		HOST_CXXFLAGS=${BUILD_CXXFLAGS}
+
 	if tc-is-cross-compiler; then
 		local -x CARGO_BUILD_TARGET=$(rust_abi)
 		local TRIPLE=${CARGO_BUILD_TARGET//-/_}
-		local -x CARGO_TARGET_"${TRIPLE^^}"_LINKER=$(tc-getCC)
-
-		# Set vars for cc-rs crate.
-		tc-export_build_env
-		local -x \
-			HOST_AR=$(tc-getBUILD_AR)
-			HOST_CC=$(tc-getBUILD_CC)
-			HOST_CXX=$(tc-getBUILD_CXX)
-			HOST_CFLAGS=${BUILD_CFLAGS}
-			HOST_CXXFLAGS=${BUILD_CXXFLAGS}
+		local TRIPLE=${TRIPLE^^} LD_A=( $(tc-getCC) ${LDFLAGS} )
+		local -x CARGO_TARGET_"${TRIPLE}"_RUSTFLAGS="-C linker=${LD_A[0]}"
+		[[ ${#LD_A[@]} -gt 1 ]] && local CARGO_TARGET_"${TRIPLE}"_RUSTFLAGS+="$(printf -- ' -C link-arg=%s' "${LD_A[@]:1}")"
+		local CARGO_TARGET_"${TRIPLE}"_RUSTFLAGS+=" ${RUSTFLAGS} ${TARGET_RUSTFLAGS}"
 	fi
 
-	"${@}"
+	(
+		# These variables will override the above, even if empty, so unset them
+		# locally. Do this in a subshell so that they remain set afterwards.
+		unset CARGO_BUILD_RUSTFLAGS CARGO_ENCODED_RUSTFLAGS RUSTFLAGS
+
+		"${@}"
+	)
 }
 
 # @FUNCTION: cargo_src_compile
@@ -556,9 +584,6 @@ cargo_env() {
 cargo_src_compile() {
 	debug-print-function ${FUNCNAME} "$@"
 
-	[[ ${_CARGO_GEN_CONFIG_HAS_RUN} ]] || \
-		die "FATAL: please call cargo_gen_config before using ${FUNCNAME}"
-
 	set -- cargo build $(usex debug "" --release) ${ECARGO_ARGS[@]} "$@"
 	einfo "${@}"
 	cargo_env "${@}" || die "cargo build failed"
@@ -573,9 +598,6 @@ cargo_src_compile() {
 cargo_src_install() {
 	debug-print-function ${FUNCNAME} "$@"
 
-	[[ ${_CARGO_GEN_CONFIG_HAS_RUN} ]] || \
-		die "FATAL: please call cargo_gen_config before using ${FUNCNAME}"
-
 	set -- cargo install $(has --path ${@} || echo --path ./) \
 		--root "${ED}/usr" \
 		${GIT_CRATES[@]:+--frozen} \
@@ -594,9 +616,6 @@ cargo_src_install() {
 cargo_src_test() {
 	debug-print-function ${FUNCNAME} "$@"
 
-	[[ ${_CARGO_GEN_CONFIG_HAS_RUN} ]] || \
-		die "FATAL: please call cargo_gen_config before using ${FUNCNAME}"
-
 	set -- cargo test $(usex debug "" --release) ${ECARGO_ARGS[@]} "$@"
 	einfo "${@}"
 	cargo_env "${@}" || die "cargo test failed"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-06  8:47 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-08-06  8:47 UTC (permalink / raw
  To: gentoo-commits
commit:     9411d6eddbc9e1375542fd0058ee7dc9007d48ba
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Wed Jul 24 18:35:54 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Tue Aug  6 08:29:26 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=9411d6ed
distutils-r1.eclass: Fix disabling DISTUTILS_ALLOW_WHEEL_REUSE
Fix the declaration of DISTUTILS_ALLOW_WHEEL_REUSE to allow disabling it
via setting the variable to an empty value in the environment.
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/distutils-r1.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/distutils-r1.eclass b/eclass/distutils-r1.eclass
index fa8edb5cdfb7..4afee3d45b1c 100644
--- a/eclass/distutils-r1.eclass
+++ b/eclass/distutils-r1.eclass
@@ -204,7 +204,7 @@ esac
 # This is an optimization that can avoid the overhead of calling into
 # the build system in pure Python packages and packages using the stable
 # Python ABI.
-DISTUTILS_ALLOW_WHEEL_REUSE=1
+: ${DISTUTILS_ALLOW_WHEEL_REUSE=1}
 
 # @ECLASS_VARIABLE: BUILD_DIR
 # @OUTPUT_VARIABLE
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-06  8:47 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-08-06  8:47 UTC (permalink / raw
  To: gentoo-commits
commit:     068fd56ff572b83925acf159e4afcfd01f98f1c8
Author:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
AuthorDate: Thu Jul 25 21:18:03 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Tue Aug  6 08:30:14 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=068fd56f
python-utils-r1.eclass: Add python_get_stdlib helper function
This is just like python_get_sitedir, but it returns the stdlib
directory such as /usr/lib/python3.12. This is useful for locating the
sysconfigdata file.
Signed-off-by: James Le Cuirot <chewi <AT> gentoo.org>
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/python-utils-r1.eclass | 23 +++++++++++++++++++++++
 1 file changed, 23 insertions(+)
diff --git a/eclass/python-utils-r1.eclass b/eclass/python-utils-r1.eclass
index cc33a1c1bffd..45d3da6bb98c 100644
--- a/eclass/python-utils-r1.eclass
+++ b/eclass/python-utils-r1.eclass
@@ -332,6 +332,17 @@ _python_export() {
 				export PYTHON=${BROOT-${EPREFIX}}/usr/bin/${impl}
 				debug-print "${FUNCNAME}: PYTHON = ${PYTHON}"
 				;;
+			PYTHON_STDLIB)
+				[[ -n ${PYTHON} ]] || die "PYTHON needs to be set for ${var} to be exported, or requested before it"
+				PYTHON_STDLIB=$(
+					"${PYTHON}" - "${EPREFIX}/usr" <<-EOF || die
+						import sys, sysconfig
+						print(sysconfig.get_path("stdlib", vars={"installed_base": sys.argv[1]}))
+					EOF
+				)
+				export PYTHON_STDLIB
+				debug-print "${FUNCNAME}: PYTHON_STDLIB = ${PYTHON_STDLIB}"
+				;;
 			PYTHON_SITEDIR)
 				[[ -n ${PYTHON} ]] || die "PYTHON needs to be set for ${var} to be exported, or requested before it"
 				PYTHON_SITEDIR=$(
@@ -466,6 +477,18 @@ _python_export() {
 	done
 }
 
+# @FUNCTION: python_get_stdlib
+# @USAGE: [<impl>]
+# @DESCRIPTION:
+# Obtain and print the 'stdlib' path for the given implementation. If no
+# implementation is provided, ${EPYTHON} will be used.
+python_get_stdlib() {
+	debug-print-function ${FUNCNAME} "${@}"
+
+	_python_export "${@}" PYTHON_STDLIB
+	echo "${PYTHON_STDLIB}"
+}
+
 # @FUNCTION: python_get_sitedir
 # @USAGE: [<impl>]
 # @DESCRIPTION:
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-06  8:47 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-08-06  8:47 UTC (permalink / raw
  To: gentoo-commits
commit:     83739e9677a6835c9fa49c0c98e9d7bc1e331413
Author:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
AuthorDate: Thu Jul 25 21:20:02 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Tue Aug  6 08:30:15 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=83739e96
distutils-r1.eclass: Support cross-compiling with PyO3
Only one variable needs to be set. For details, see
https://pyo3.rs/latest/building-and-distribution.html#cross-compiling.
Signed-off-by: James Le Cuirot <chewi <AT> gentoo.org>
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
Closes: https://github.com/gentoo/gentoo/pull/37708
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/distutils-r1.eclass | 5 +++++
 1 file changed, 5 insertions(+)
diff --git a/eclass/distutils-r1.eclass b/eclass/distutils-r1.eclass
index 129ba21ab0d4..0f9dc8d14d5e 100644
--- a/eclass/distutils-r1.eclass
+++ b/eclass/distutils-r1.eclass
@@ -1391,6 +1391,11 @@ distutils_pep517_install() {
 			;;
 	esac
 
+	# https://pyo3.rs/latest/building-and-distribution.html#cross-compiling
+	if tc-is-cross-compiler; then
+		local -x PYO3_CROSS_LIB_DIR=${SYSROOT}/$(python_get_stdlib)
+	fi
+
 	local build_backend=$(_distutils-r1_get_backend)
 	einfo "  Building the wheel for ${PWD#${WORKDIR}/} via ${build_backend}"
 	cmd+=(
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-06  8:47 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-08-06  8:47 UTC (permalink / raw
  To: gentoo-commits
commit:     9b2def86a9c7fd8821a5b83df7d250fc4c73540f
Author:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
AuthorDate: Thu Jul 25 11:09:21 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Tue Aug  6 08:30:13 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=9b2def86
distutils-r1.eclass: Use cargo_env when appropriate for flag handling
cargo_env handles linker flags and enables cross-compiling. It also
handles LTO filtering, so we can remove that from this eclass.
Signed-off-by: James Le Cuirot <chewi <AT> gentoo.org>
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/distutils-r1.eclass | 16 ++++------------
 1 file changed, 4 insertions(+), 12 deletions(-)
diff --git a/eclass/distutils-r1.eclass b/eclass/distutils-r1.eclass
index 5d9f97474b29..129ba21ab0d4 100644
--- a/eclass/distutils-r1.eclass
+++ b/eclass/distutils-r1.eclass
@@ -1252,7 +1252,9 @@ distutils_pep517_install() {
 		die "mydistutilsargs are banned in PEP517 mode (use DISTUTILS_ARGS)"
 	fi
 
-	local config_settings=
+	local cmd=() config_settings=
+	has cargo ${INHERITED} && cmd+=( cargo_env )
+
 	case ${DISTUTILS_USE_PEP517} in
 		maturin)
 			# `maturin pep517 build-wheel --help` for options
@@ -1391,7 +1393,7 @@ distutils_pep517_install() {
 
 	local build_backend=$(_distutils-r1_get_backend)
 	einfo "  Building the wheel for ${PWD#${WORKDIR}/} via ${build_backend}"
-	local cmd=(
+	cmd+=(
 		"${EPYTHON}" -m gpep517 build-wheel
 			--prefix="${EPREFIX}/usr"
 			--backend "${build_backend}"
@@ -1793,16 +1795,6 @@ distutils-r1_run_phase() {
 		# bug fixes from Cython (this works only when setup.py is using
 		# cythonize() but it's better than nothing)
 		local -x CYTHON_FORCE_REGEN=1
-
-		# Rust extensions are incompatible with C/C++ LTO compiler
-		# see e.g. https://bugs.gentoo.org/910220
-		if has cargo ${INHERITED}; then
-			local x
-			for x in $(all-flag-vars); do
-				local -x "${x}=${!x}"
-			done
-			filter-lto
-		fi
 	fi
 
 	# silence warnings when pydevd is loaded on Python 3.11+
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-06  8:47 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-08-06  8:47 UTC (permalink / raw
  To: gentoo-commits
commit:     1792d3396dad606e254910619c13b8509998e7e5
Author:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
AuthorDate: Thu Jul 25 11:08:52 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Tue Aug  6 08:30:12 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=1792d339
cargo.eclass: Shadow flag variables so that LTO filtering remains local
This is currently done for Cargo by distutils-r1.eclass. The next commit
will remove that code, leaving cargo_env responsible for it.
Signed-off-by: James Le Cuirot <chewi <AT> gentoo.org>
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/cargo.eclass | 9 +++++++++
 1 file changed, 9 insertions(+)
diff --git a/eclass/cargo.eclass b/eclass/cargo.eclass
index 99a7959b22e2..c360c2a6c419 100644
--- a/eclass/cargo.eclass
+++ b/eclass/cargo.eclass
@@ -549,7 +549,16 @@ cargo_env() {
 	[[ ${_CARGO_GEN_CONFIG_HAS_RUN} ]] || \
 		die "FATAL: please call cargo_gen_config before using ${FUNCNAME}"
 
+	# Shadow flag variables so that filtering below remains local.
+	local flag
+	for flag in $(all-flag-vars); do
+		local -x "${flag}=${!flag}"
+	done
+
+	# Rust extensions are incompatible with C/C++ LTO compiler see e.g.
+	# https://bugs.gentoo.org/910220
 	filter-lto
+
 	tc-export AR CC CXX PKG_CONFIG
 
 	# Set vars for cc-rs crate.
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-06 16:39 Florian Schmaus
  0 siblings, 0 replies; 6663+ messages in thread
From: Florian Schmaus @ 2024-08-06 16:39 UTC (permalink / raw
  To: gentoo-commits
commit:     69065e361cae62a086d62c148e93a07d125f3e9b
Author:     Volkmar W. Pogatzki <gentoo <AT> pogatzki <DOT> net>
AuthorDate: Tue Aug  6 13:47:46 2024 +0000
Commit:     Florian Schmaus <flow <AT> gentoo <DOT> org>
CommitDate: Tue Aug  6 16:39:29 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=69065e36
java-vm-2.eclass: remove function set_java_env
Deprecated with commit 436dd062c on 2016-08-02
Signed-off-by: Volkmar W. Pogatzki <gentoo <AT> pogatzki.net>
Closes: https://github.com/gentoo/gentoo/pull/37995
Signed-off-by: Florian Schmaus <flow <AT> gentoo.org>
 eclass/java-vm-2.eclass | 52 -------------------------------------------------
 1 file changed, 52 deletions(-)
diff --git a/eclass/java-vm-2.eclass b/eclass/java-vm-2.eclass
index c7a207ae24f7..c90cd8664f30 100644
--- a/eclass/java-vm-2.eclass
+++ b/eclass/java-vm-2.eclass
@@ -164,58 +164,6 @@ get_system_arch() {
 }
 
 
-# @FUNCTION: set_java_env
-# @DESCRIPTION:
-# Installs a vm env file.
-# DEPRECATED, use java-vm_install-env instead.
-
-set_java_env() {
-	debug-print-function ${FUNCNAME} $*
-
-	local platform="$(get_system_arch)"
-	local env_file="${ED}${JAVA_VM_CONFIG_DIR}/${VMHANDLE}"
-
-	if [[ ${1} ]]; then
-		local source_env_file="${1}"
-	else
-		local source_env_file="${FILESDIR}/${VMHANDLE}.env"
-	fi
-
-	if [[ ! -f ${source_env_file} ]]; then
-		die "Unable to find the env file: ${source_env_file}"
-	fi
-
-	dodir ${JAVA_VM_CONFIG_DIR}
-	sed \
-		-e "s/@P@/${P}/g" \
-		-e "s/@PN@/${PN}/g" \
-		-e "s/@PV@/${PV}/g" \
-		-e "s/@PF@/${PF}/g" \
-		-e "s/@SLOT@/${SLOT}/g" \
-		-e "s/@PLATFORM@/${platform}/g" \
-		-e "s/@LIBDIR@/$(get_libdir)/g" \
-		-e "/^LDPATH=.*lib\\/\\\"/s|\"\\(.*\\)\"|\"\\1${platform}/:\\1${platform}/server/\"|" \
-		< "${source_env_file}" \
-		> "${env_file}" || die "sed failed"
-
-	(
-		echo "VMHANDLE=\"${VMHANDLE}\""
-		echo "BUILD_ONLY=\"${JAVA_VM_BUILD_ONLY}\""
-	) >> "${env_file}"
-
-	eprefixify ${env_file}
-
-	[[ -n ${JAVA_PROVIDE} ]] && echo "PROVIDES=\"${JAVA_PROVIDE}\"" >> ${env_file}
-
-	local java_home=$(source "${env_file}"; echo ${JAVA_HOME})
-	[[ -z ${java_home} ]] && die "No JAVA_HOME defined in ${env_file}"
-
-	# Make the symlink
-	dodir "${JAVA_VM_DIR}"
-	dosym "${java_home}" "${JAVA_VM_DIR}/${VMHANDLE}"
-}
-
-
 # @FUNCTION: java-vm_install-env
 # @DESCRIPTION:
 #
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-07  3:03 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-08-07  3:03 UTC (permalink / raw
  To: gentoo-commits
commit:     1a17266f16d4fbd2116611777a3c77f2db31bc8b
Author:     Piotr Kubaj <pkubaj <AT> anongoth <DOT> pl>
AuthorDate: Tue Aug  6 12:31:27 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Aug  7 03:03:18 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=1a17266f
rust-toolchain.eclass: add powerpc*musl support
Also adjust indentation.
[sam: Note that this is easier to review with `git diff -w`.]
Signed-off-by: Piotr Kubaj <pkubaj <AT> anongoth.pl>
Closes: https://github.com/gentoo/gentoo/pull/35928
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/rust-toolchain.eclass | 43 +++++++++++++++++++++++--------------------
 1 file changed, 23 insertions(+), 20 deletions(-)
diff --git a/eclass/rust-toolchain.eclass b/eclass/rust-toolchain.eclass
index 111aece796ce..469479b849b3 100644
--- a/eclass/rust-toolchain.eclass
+++ b/eclass/rust-toolchain.eclass
@@ -31,26 +31,29 @@ esac
 rust_abi() {
 	local CTARGET=${1:-${CHOST}}
 	case ${CTARGET%%*-} in
-		aarch64*gnu)  echo aarch64-unknown-linux-gnu;;
-		aarch64*musl) echo aarch64-unknown-linux-musl;;
-		armv6j*h*)    echo arm-unknown-linux-gnueabihf;;
-		armv6j*s*)    echo arm-unknown-linux-gnueabi;;
-		armv7a*h*)    echo armv7-unknown-linux-gnueabihf;;
-		i?86*)        echo i686-unknown-linux-gnu;;
-		loongarch64*) echo loongarch64-unknown-linux-gnu;;
-		mips64el*)    echo mips64el-unknown-linux-gnuabi64;;
-		mips64*)      echo mips64-unknown-linux-gnuabi64;;
-		mipsel*)      echo mipsel-unknown-linux-gnu;;
-		mips*)        echo mips-unknown-linux-gnu;;
-		powerpc64le*) echo powerpc64le-unknown-linux-gnu;;
-		powerpc64*)   echo powerpc64-unknown-linux-gnu;;
-		powerpc*)     echo powerpc-unknown-linux-gnu;;
-		riscv64*gnu)  echo riscv64gc-unknown-linux-gnu;;
-		riscv64*musl) echo riscv64gc-unknown-linux-musl;;
-		s390x*)       echo s390x-unknown-linux-gnu;;
-		x86_64*gnu)   echo x86_64-unknown-linux-gnu;;
-		x86_64*musl)  echo x86_64-unknown-linux-musl;;
-		*)            echo ${CTARGET};;
+		aarch64*gnu)      echo aarch64-unknown-linux-gnu;;
+		aarch64*musl)     echo aarch64-unknown-linux-musl;;
+		armv6j*h*)        echo arm-unknown-linux-gnueabihf;;
+		armv6j*s*)        echo arm-unknown-linux-gnueabi;;
+		armv7a*h*)        echo armv7-unknown-linux-gnueabihf;;
+		i?86*)            echo i686-unknown-linux-gnu;;
+		loongarch64*)     echo loongarch64-unknown-linux-gnu;;
+		mips64el*)        echo mips64el-unknown-linux-gnuabi64;;
+		mips64*)          echo mips64-unknown-linux-gnuabi64;;
+		mipsel*)          echo mipsel-unknown-linux-gnu;;
+		mips*)            echo mips-unknown-linux-gnu;;
+		powerpc64le*gnu)  echo powerpc64le-unknown-linux-gnu;;
+		powerpc64le*musl) echo powerpc64le-unknown-linux-musl;;
+		powerpc64*gnu)    echo powerpc64-unknown-linux-gnu;;
+		powerpc64*musl)   echo powerpc64-unknown-linux-musl;;
+		powerpc*gnu)      echo powerpc-unknown-linux-gnu;;
+		powerpc*musl)     echo powerpc-unknown-linux-musl;;
+		riscv64*gnu)      echo riscv64gc-unknown-linux-gnu;;
+		riscv64*musl)     echo riscv64gc-unknown-linux-musl;;
+		s390x*)           echo s390x-unknown-linux-gnu;;
+		x86_64*gnu)       echo x86_64-unknown-linux-gnu;;
+		x86_64*musl)      echo x86_64-unknown-linux-musl;;
+		*)                echo ${CTARGET};;
   esac
 }
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-07  8:58 Andrew Ammerlaan
  0 siblings, 0 replies; 6663+ messages in thread
From: Andrew Ammerlaan @ 2024-08-07  8:58 UTC (permalink / raw
  To: gentoo-commits
commit:     2073571d34ad5efcd6d4ec4db0914e774ca69a19
Author:     Andrew Ammerlaan <andrewammerlaan <AT> gentoo <DOT> org>
AuthorDate: Mon Aug  5 19:13:28 2024 +0000
Commit:     Andrew Ammerlaan <andrewammerlaan <AT> gentoo <DOT> org>
CommitDate: Wed Aug  7 08:58:39 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=2073571d
kernel-install.eclass: use dist-kernel_get_module_suffix to find compression
Adjusts kernel-install_compress_modules to use the new function
dist-kernel_get_module_suffix. This makes no functional difference
at the moment since gentoo-kernel-bin is the only consumer and it has
XZ compression in the config. Still this makes it possible to compile
alternate prebuilt kernels with alternate module compression support, and may
in the future help to support gzip and zstd module compression in
gentoo-kernel-bin.
Signed-off-by: Andrew Ammerlaan <andrewammerlaan <AT> gentoo.org>
 eclass/kernel-install.eclass | 36 +++++++++++++++++++++++++++++-------
 1 file changed, 29 insertions(+), 7 deletions(-)
diff --git a/eclass/kernel-install.eclass b/eclass/kernel-install.eclass
index 15b7cf739bc3..c64dd673084b 100644
--- a/eclass/kernel-install.eclass
+++ b/eclass/kernel-install.eclass
@@ -766,13 +766,35 @@ kernel-install_compress_modules() {
 
 	if use modules-compress; then
 		einfo "Compressing kernel modules ..."
-		# xz options taken from scripts/Makefile.modinst
-		# we don't do 'xz -T' because it applies multithreading per file,
-		# so it works only for big files, and we have lots of small files
-		# instead
-		find "${ED}/lib" -name '*.ko' -print0 |
-			xargs -0 -P "$(makeopts_jobs)" -n 128 \
-				xz --check=crc32 --lzma2=dict=1MiB
+		if [[ -z ${KV_FULL} ]]; then
+			KV_FULL=${PV}${KV_LOCALVERSION}
+		fi
+		local suffix=$(dist-kernel_get_module_suffix "${ED}/usr/src/linux-${KV_FULL}")
+		local compress=()
+		# Options taken from linux-mod-r1.eclass.
+		# We don't instruct the compressor to parallelize because it applies
+		# multithreading per file, so it works only for big files, and we have
+		# lots of small files instead.
+		case ${suffix} in
+			.ko)
+				return
+				;;
+			.ko.gz)
+				compress+=( gzip )
+				;;
+			.ko.xz)
+				compress+=( xz --check=crc32 --lzma2=dict=1MiB )
+				;;
+			.ko.zst)
+				compress+=( zstd -q --rm )
+				;;
+			*)
+				die "Unknown compressor: ${suffix}"
+				;;
+		esac
+
+		find "${ED}/lib/modules/${KV_FULL}" -name '*.ko' -print0 |
+			xargs -0 -P "$(makeopts_jobs)" -n 128 "${compress[@]}"
 		assert "Compressing kernel modules failed"
 	fi
 }
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-07  8:58 Andrew Ammerlaan
  0 siblings, 0 replies; 6663+ messages in thread
From: Andrew Ammerlaan @ 2024-08-07  8:58 UTC (permalink / raw
  To: gentoo-commits
commit:     facd2865e403fd295c955fff8d609bfc717aed24
Author:     Andrew Ammerlaan <andrewammerlaan <AT> gentoo <DOT> org>
AuthorDate: Mon Aug  5 19:13:06 2024 +0000
Commit:     Andrew Ammerlaan <andrewammerlaan <AT> gentoo <DOT> org>
CommitDate: Wed Aug  7 08:58:35 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=facd2865
dist-kernel-utils.eclass: fix module cleanup when using binpkgs
When installing a binpkg -nt is not a good check because the modules in the
binpkg we are installing may actually be older then what we have in root.
Instead introduce a new function dist-kernel_get_module_suffix to find the
desired compression based on USE=modules-sign and the kernel config. Then,
remove only those files that do not match our desired compression.
Signed-off-by: Andrew Ammerlaan <andrewammerlaan <AT> gentoo.org>
 eclass/dist-kernel-utils.eclass | 59 ++++++++++++++++++++++++++++++++++-------
 1 file changed, 49 insertions(+), 10 deletions(-)
diff --git a/eclass/dist-kernel-utils.eclass b/eclass/dist-kernel-utils.eclass
index 4bc3fab44aae..0b0eb0ec8818 100644
--- a/eclass/dist-kernel-utils.eclass
+++ b/eclass/dist-kernel-utils.eclass
@@ -1,4 +1,4 @@
-# Copyright 2020-2023 Gentoo Authors
+# Copyright 2020-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: dist-kernel-utils.eclass
@@ -159,6 +159,35 @@ dist-kernel_PV_to_KV() {
 	echo "${kv}"
 }
 
+# @FUNCTION: dist-kernel_get_module_suffix
+# @USAGE: <kernel_dir>
+# @DESCRIPTION:
+# Returns the suffix for kernel modules based on the CONFIG_MODULES_COMPESS_*
+# setting in the kernel config and USE=modules-compress.
+dist-kernel_get_module_suffix() {
+	debug-print-function ${FUNCNAME} "${@}"
+
+	[[ ${#} -eq 1 ]] || die "${FUNCNAME}: invalid arguments"
+
+	local config=${1}/.config
+
+	if ! in_iuse modules-compress || ! use modules-compress; then
+		echo .ko
+	elif [[ ! -r ${config} ]]; then
+		die "Cannot find kernel config ${config}"
+	elif grep -q "CONFIG_MODULE_COMPRESS_NONE=y" "${config}"; then
+		echo .ko
+	elif grep -q "CONFIG_MODULE_COMPRESS_GZIP=y" "${config}"; then
+		echo .ko.gz
+	elif grep -q "CONFIG_MODULE_COMPRESS_XZ=y" "${config}"; then
+		echo .ko.xz
+	elif grep -q "CONFIG_MODULE_COMPRESS_ZSTD=y" "${config}"; then
+		echo .ko.zst
+	else
+		die "Module compression is enabled, but compressor not known"
+	fi
+}
+
 # @FUNCTION: dist-kernel_compressed_module_cleanup
 # @USAGE: <path>
 # @DESCRIPTION:
@@ -169,20 +198,29 @@ dist-kernel_compressed_module_cleanup() {
 
 	[[ ${#} -ne 1 ]] && die "${FUNCNAME}: invalid arguments"
 	local path=${1}
-	local basename f
+	local preferred=$(dist-kernel_get_module_suffix "${path}/source")
+	local basename suffix
 
 	while read -r basename; do
 		local prev=
-		for f in "${path}/${basename}"{,.gz,.xz,.zst}; do
-			if [[ ! -e ${f} ]]; then
-				continue
+		for suffix in .ko .ko.gz .ko.xz .ko.zst; do
+			[[ ${suffix} == ${preferred} ]] && continue
+			local current=${path}/${basename}${suffix}
+			[[ -f ${current} ]] || continue
+
+			if [[ -f ${path}/${basename}${preferred} ]]; then
+				# If the module with the desired compression exists, remove
+				# all other variations.
+				rm -v "${current}" || die
 			elif [[ -z ${prev} ]]; then
-				prev=${f}
-			elif [[ ${f} -nt ${prev} ]]; then
+				# If not, then keep whichever of the duplicate modules is the
+				# newest. Normally you should not end up here.
+				prev=${current}
+			elif [[ ${current} -nt ${prev} ]]; then
 				rm -v "${prev}" || die
-				prev=${f}
+				prev=${current}
 			else
-				rm -v "${f}" || die
+				rm -v "${current}" || die
 			fi
 		done
 	done < <(
@@ -192,7 +230,8 @@ dist-kernel_compressed_module_cleanup() {
 			-o -name '*.ko.gz' \
 			-o -name '*.ko.xz' \
 			-o -name '*.ko.zst' \
-			\) | sed -e 's:[.]\(gz\|xz\|zst\)$::' | sort | uniq -d || die
+			\) | sed -e 's:[.]ko\(\|[.]gz\|[.]xz\|[.]zst\)$::' |
+				sort | uniq -d || die
 	)
 }
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-07  9:21 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-08-07  9:21 UTC (permalink / raw
  To: gentoo-commits
commit:     7eab20a224f411ef2660f4fecae22e28cad711e7
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Aug  7 09:19:29 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Aug  7 09:20:24 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=7eab20a2
toolchain.eclass: try harder to suppress -Wformat and friends
* Followup to f66787897a590b8c949d257e3a9107f8995f62ae
* See https://inbox.sourceware.org/gcc-patches/87v80cn24t.fsf <AT> gentoo.org/
Still not quite right though per link above.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 5 ++++-
 1 file changed, 4 insertions(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 9304800f09f7..591ca98d7467 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1947,8 +1947,11 @@ toolchain_src_test() {
 		# Go doesn't support this and causes noisy warnings
 		filter-flags -Wbuiltin-declaration-mismatch
 
+		local suppress_warn="/-Wno-format/-Wno-format-security/-Wno-trampolines"
+		RUNTESTFLAGS+=" --target_board=unix\{${suppress_warn}"
 		# TODO: Does this handle s390 (-m31) correctly?
-		is_multilib && GCC_TESTS_RUNTESTFLAGS+=" --target_board=unix\{,-m32\}"
+		is_multilib && GCC_TESTS_RUNTESTFLAGS+=" ,-m32/${suppress_warn}"
+		RUNTESTFLAGS+="\}"
 
 		# nonfatal here as we die if the comparison below fails. Also, note that
 		# the exit code of targets other than 'check' may be unreliable.
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-07  9:25 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-08-07  9:25 UTC (permalink / raw
  To: gentoo-commits
commit:     cad8e1e7e09bd33b53be59576f4adc6bb1420a12
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Aug  7 09:25:03 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Aug  7 09:25:03 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=cad8e1e7
toolchain.eclass: add link to upstream bug for manifests vs ABIs
Bug: https://gcc.gnu.org/PR116260
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 1 +
 1 file changed, 1 insertion(+)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 591ca98d7467..106939bfdeb5 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1968,6 +1968,7 @@ toolchain_src_test() {
 	)
 
 	# Produce an updated failure manifest.
+	# XXX: Manifests aren't ideal w/ multilib because of https://gcc.gnu.org/PR116260
 	einfo "Generating a new failure manifest ${T}/${CHOST}.xfail"
 	rm -f "${T}"/${CHOST}.xfail
 	edo "${T}"/validate_failures.py \
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-07  9:41 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-08-07  9:41 UTC (permalink / raw
  To: gentoo-commits
commit:     60bbe4613834d198e3969ce9ffb6124212b53c41
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Aug  7 09:40:27 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Aug  7 09:40:27 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=60bbe461
toolchain.eclass: fix typos w/ RUNTESTFLAGS
Fixes: 7eab20a224f411ef2660f4fecae22e28cad711e7
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 106939bfdeb5..e81116973c67 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1948,10 +1948,10 @@ toolchain_src_test() {
 		filter-flags -Wbuiltin-declaration-mismatch
 
 		local suppress_warn="/-Wno-format/-Wno-format-security/-Wno-trampolines"
-		RUNTESTFLAGS+=" --target_board=unix\{${suppress_warn}"
+		GCC_TESTS_RUNTESTFLAGS+=" --target_board=unix\{${suppress_warn}"
 		# TODO: Does this handle s390 (-m31) correctly?
-		is_multilib && GCC_TESTS_RUNTESTFLAGS+=" ,-m32/${suppress_warn}"
-		RUNTESTFLAGS+="\}"
+		is_multilib && GCC_TESTS_RUNTESTFLAGS+=",-m32/${suppress_warn}"
+		GCC_TESTS_RUNTESTFLAGS+="\}"
 
 		# nonfatal here as we die if the comparison below fails. Also, note that
 		# the exit code of targets other than 'check' may be unreliable.
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-07 15:13 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-08-07 15:13 UTC (permalink / raw
  To: gentoo-commits
commit:     5ca076594ad47b8347ebc9fd69b467a95846d005
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Aug  7 15:08:06 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Aug  7 15:13:01 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=5ca07659
toolchain.eclass: another attempt at flag filtering for tests
The previous method ends up confusing D because those flags don't work
there...
Try passing *FLAGS into RUNTESTFLAGS this time, like in
https://gcc.gnu.org/wiki/Testing_GCC#Testing_a_different_target_from_the_current_host.
This reverts commit 7eab20a224f411ef2660f4fecae22e28cad711e7 and
commit f66787897a590b8c949d257e3a9107f8995f62ae.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 27 ++++++++++++++-------------
 1 file changed, 14 insertions(+), 13 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index e81116973c67..550845b7dd47 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1947,24 +1947,25 @@ toolchain_src_test() {
 		# Go doesn't support this and causes noisy warnings
 		filter-flags -Wbuiltin-declaration-mismatch
 
-		local suppress_warn="/-Wno-format/-Wno-format-security/-Wno-trampolines"
-		GCC_TESTS_RUNTESTFLAGS+=" --target_board=unix\{${suppress_warn}"
 		# TODO: Does this handle s390 (-m31) correctly?
-		is_multilib && GCC_TESTS_RUNTESTFLAGS+=",-m32/${suppress_warn}"
-		GCC_TESTS_RUNTESTFLAGS+="\}"
+		is_multilib && GCC_TESTS_RUNTESTFLAGS+=" --target_board=unix\{,-m32\}"
+
+		GCC_TESTS_RUNTESTFLAGS=(
+			"${GCC_TESTS_RUNTESTFLAGS}"
+                        CFLAGS_FOR_TARGET="${CFLAGS_FOR_TARGET:-${CFLAGS}}"
+                        CXXFLAGS_FOR_TARGET="${CXXFLAGS_FOR_TARGET:-${CXXFLAGS}}"
+                        LDFLAGS_FOR_TARGET="${LDFLAGS_FOR_TARGET:-${LDFLAGS}}"
+                        CFLAGS="${CFLAGS}"
+                        CXXFLAGS="${CXXFLAGS}"
+                        FCFLAGS="${FCFLAGS}"
+                        FFLAGS="${FFLAGS}"
+                        LDFLAGS="${LDFLAGS}"
+		)
 
 		# nonfatal here as we die if the comparison below fails. Also, note that
 		# the exit code of targets other than 'check' may be unreliable.
 		nonfatal emake -C "${WORKDIR}"/build -k "${GCC_TESTS_CHECK_TARGET}" \
-			RUNTESTFLAGS="${GCC_TESTS_RUNTESTFLAGS}" \
-			CFLAGS_FOR_TARGET="${CFLAGS_FOR_TARGET:-${CFLAGS}}" \
-			CXXFLAGS_FOR_TARGET="${CXXFLAGS_FOR_TARGET:-${CXXFLAGS}}" \
-			LDFLAGS_FOR_TARGET="${LDFLAGS_FOR_TARGET:-${LDFLAGS}}" \
-			CFLAGS="${CFLAGS}" \
-			CXXFLAGS="${CXXFLAGS}" \
-			FCFLAGS="${FCFLAGS}" \
-			FFLAGS="${FFLAGS}" \
-			LDFLAGS="${LDFLAGS}"
+			RUNTESTFLAGS="${GCC_TESTS_RUNTESTFLAGS[*]}"
 	)
 
 	# Produce an updated failure manifest.
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-08  9:00 James Le Cuirot
  0 siblings, 0 replies; 6663+ messages in thread
From: James Le Cuirot @ 2024-08-08  9:00 UTC (permalink / raw
  To: gentoo-commits
commit:     27d469a2114b4ad0b3e682854c50c806753eb472
Author:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
AuthorDate: Wed Aug  7 14:27:36 2024 +0000
Commit:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
CommitDate: Thu Aug  8 09:00:08 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=27d469a2
cargo.eclass: Change RUSTFLAGS approach following recent build failures
Cargo turned out to be even worse at handling flags than I thought.
Target-specific flags set by projects were overriding our own, and Cargo
was bailing out when faced with merging a string of flags with an array
of flags.
After weighing up the poor set of options, I've found that it is better
to always set flags via a target-specific environment variable for
reasons set out in comments added here. This approach was previously
just used for cross-compiling, but now we do it unconditionally.
It has the downside of overriding generic [build] flags set by projects,
but these were already being overridden by users and ebuilds setting
RUSTFLAGS themselves.
Closes: https://bugs.gentoo.org/937453
Closes: https://bugs.gentoo.org/937470
Signed-off-by: James Le Cuirot <chewi <AT> gentoo.org>
 eclass/cargo.eclass | 65 ++++++++++++++++++++++++++++++++---------------------
 1 file changed, 39 insertions(+), 26 deletions(-)
diff --git a/eclass/cargo.eclass b/eclass/cargo.eclass
index c360c2a6c419..6d4cf1b425eb 100644
--- a/eclass/cargo.eclass
+++ b/eclass/cargo.eclass
@@ -259,19 +259,6 @@ cargo_crate_uris() {
 cargo_gen_config() {
 	debug-print-function ${FUNCNAME} "$@"
 
-	# The default linker is "cc" so override by setting linker to CC in the
-	# RUSTFLAGS. The given linker cannot include any arguments, so split these
-	# into link-args along with LDFLAGS. Also include external RUSTFLAGS.
-	# Note that as of Rust 1.80, the build host RUSTFLAGS are ignored when
-	# cross-compiling unless you use the unstable host-config feature available
-	# with USE=nightly. There is no simple way around this.
-	tc-export_build_env
-	local LD_A=( $(tc-getBUILD_CC) ${BUILD_LDFLAGS} )
-	local MY_BUILD_RUSTFLAGS="-C strip=none -C linker=${LD_A[0]}"
-	[[ ${#LD_A[@]} -gt 1 ]] && MY_BUILD_RUSTFLAGS+="$(printf -- ' -C link-arg=%s' "${LD_A[@]:1}")"
-	MY_BUILD_RUSTFLAGS+=" ${RUSTFLAGS} ${BUILD_RUSTFLAGS}"
-	tc-is-cross-compiler || MY_BUILD_RUSTFLAGS+=" ${TARGET_RUSTFLAGS}"
-
 	mkdir -p "${ECARGO_HOME}" || die
 
 	cat > "${ECARGO_HOME}/config.toml" <<- _EOF_ || die "Failed to create cargo config"
@@ -286,7 +273,6 @@ cargo_gen_config() {
 	offline = true
 
 	[build]
-	rustflags = "${MY_BUILD_RUSTFLAGS}"
 	jobs = $(makeopts_jobs)
 	incremental = false
 
@@ -541,10 +527,11 @@ cargo_src_configure() {
 # @USAGE: Command with its arguments
 # @DESCRIPTION:
 # Run the given command under an environment needed for performing tasks with
-# Cargo such as building. RUSTFLAGS is used for both the build and target host.
-# BUILD_RUSTFLAGS and TARGET_RUSTFLAGS are used for just the build host and
-# target host respectively. Ensure these are set consistently between Cargo
-# invocations, otherwise rebuilds will occur.
+# Cargo such as building. RUSTFLAGS are appended to additional flags set here.
+# Ensure these are set consistently between Cargo invocations, otherwise
+# rebuilds will occur. Project-specific rustflags set against [build] will not
+# take affect due to Cargo limitations, so add these to your ebuild's RUSTFLAGS
+# if they seem important.
 cargo_env() {
 	[[ ${_CARGO_GEN_CONFIG_HAS_RUN} ]] || \
 		die "FATAL: please call cargo_gen_config before using ${FUNCNAME}"
@@ -569,14 +556,40 @@ cargo_env() {
 		HOST_CFLAGS=${BUILD_CFLAGS}
 		HOST_CXXFLAGS=${BUILD_CXXFLAGS}
 
-	if tc-is-cross-compiler; then
-		local -x CARGO_BUILD_TARGET=$(rust_abi)
-		local TRIPLE=${CARGO_BUILD_TARGET//-/_}
-		local TRIPLE=${TRIPLE^^} LD_A=( $(tc-getCC) ${LDFLAGS} )
-		local -x CARGO_TARGET_"${TRIPLE}"_RUSTFLAGS="-C strip=none -C linker=${LD_A[0]}"
-		[[ ${#LD_A[@]} -gt 1 ]] && local CARGO_TARGET_"${TRIPLE}"_RUSTFLAGS+="$(printf -- ' -C link-arg=%s' "${LD_A[@]:1}")"
-		local CARGO_TARGET_"${TRIPLE}"_RUSTFLAGS+=" ${RUSTFLAGS} ${TARGET_RUSTFLAGS}"
-	fi
+	# Unfortunately, Cargo is *really* bad at handling flags. In short, it uses
+	# the first of the RUSTFLAGS env var, any target-specific config, and then
+	# any generic [build] config. It can merge within the latter two types from
+	# different sources, but it will not merge across these different types, so
+	# if a project sets flags under [target.'cfg(all())'], it will override any
+	# flags we set under [build] and vice-versa.
+	#
+	# It has been common for users and ebuilds to set RUSTFLAGS, which would
+	# have overridden whatever a project sets anyway, so the least-worst option
+	# is to include those RUSTFLAGS in target-specific config here, which will
+	# merge with any the project sets. Only flags in generic [build] config set
+	# by the project will be lost, and ebuilds will need to add those to
+	# RUSTFLAGS themselves if they are important.
+	#
+	# We could potentially inspect a project's generic [build] config and
+	# reapply those flags ourselves, but that would require a proper toml parser
+	# like tomlq, it might lead to confusion where projects also have
+	# target-specific config, and converting arrays to strings may not work
+	# well. Nightly features to inspect the config might help here in future.
+	#
+	# As of Rust 1.80, it is not possible to set separate flags for the build
+	# host and the target host when cross-compiling. The flags given are applied
+	# to the target host only with no flags being applied to the build host. The
+	# nightly host-config feature will improve this situation later.
+	#
+	# The default linker is "cc" so override by setting linker to CC in the
+	# RUSTFLAGS. The given linker cannot include any arguments, so split these
+	# into link-args along with LDFLAGS.
+	local -x CARGO_BUILD_TARGET=$(rust_abi)
+	local TRIPLE=${CARGO_BUILD_TARGET//-/_}
+	local TRIPLE=${TRIPLE^^} LD_A=( $(tc-getCC) ${LDFLAGS} )
+	local -x CARGO_TARGET_"${TRIPLE}"_RUSTFLAGS="-C strip=none -C linker=${LD_A[0]}"
+	[[ ${#LD_A[@]} -gt 1 ]] && local CARGO_TARGET_"${TRIPLE}"_RUSTFLAGS+="$(printf -- ' -C link-arg=%s' "${LD_A[@]:1}")"
+	local CARGO_TARGET_"${TRIPLE}"_RUSTFLAGS+=" ${RUSTFLAGS}"
 
 	(
 		# These variables will override the above, even if empty, so unset them
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-08 10:05 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-08-08 10:05 UTC (permalink / raw
  To: gentoo-commits
commit:     6df977928704e77d2f672d3890ceadc8ba837ab5
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Aug  8 10:04:02 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Aug  8 10:05:21 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=6df97792
toolchain.eclass: more src_test flag fixes
We ended up not running many tests because it got interpreted as '--Werror'
with the braces/splitting (e.g. rust and such got skipped entirely).
With this change, we seem to be nearly there although we have issues
with Fortran tests that have C for interop because we get the unsupported
arg warnings...
Fixes: 5ca076594ad47b8347ebc9fd69b467a95846d005
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 41 ++++++++++++++++++++++++++---------------
 1 file changed, 26 insertions(+), 15 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 550845b7dd47..86a29f5aacb8 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1924,9 +1924,14 @@ toolchain_src_test() {
 
 	# Use a subshell to allow meddling with flags just for the testsuite
 	(
+		# Unexpected warnings confuse the tests.
+		filter-flags -W*
+
 		# Workaround our -Wformat-security default which breaks
 		# various tests as it adds unexpected warning output.
-		append-flags -Wno-format-security -Wno-format
+		# (Only for C/C++ here to avoid noise for Fortran.)
+		append-cflags -Wno-format-security -Wno-format
+		append-cxxflags -Wno-format-security -Wno-format
 		# Workaround our -Wtrampolines default which breaks
 		# tests too.
 		append-flags -Wno-trampolines
@@ -1948,24 +1953,30 @@ toolchain_src_test() {
 		filter-flags -Wbuiltin-declaration-mismatch
 
 		# TODO: Does this handle s390 (-m31) correctly?
-		is_multilib && GCC_TESTS_RUNTESTFLAGS+=" --target_board=unix\{,-m32\}"
-
-		GCC_TESTS_RUNTESTFLAGS=(
-			"${GCC_TESTS_RUNTESTFLAGS}"
-                        CFLAGS_FOR_TARGET="${CFLAGS_FOR_TARGET:-${CFLAGS}}"
-                        CXXFLAGS_FOR_TARGET="${CXXFLAGS_FOR_TARGET:-${CXXFLAGS}}"
-                        LDFLAGS_FOR_TARGET="${LDFLAGS_FOR_TARGET:-${LDFLAGS}}"
-                        CFLAGS="${CFLAGS}"
-                        CXXFLAGS="${CXXFLAGS}"
-                        FCFLAGS="${FCFLAGS}"
-                        FFLAGS="${FFLAGS}"
-                        LDFLAGS="${LDFLAGS}"
-		)
+		is_multilib && GCC_TESTS_RUNTESTFLAGS+=" --target_board=unix{,-m32}"
 
 		# nonfatal here as we die if the comparison below fails. Also, note that
 		# the exit code of targets other than 'check' may be unreliable.
 		nonfatal emake -C "${WORKDIR}"/build -k "${GCC_TESTS_CHECK_TARGET}" \
-			RUNTESTFLAGS="${GCC_TESTS_RUNTESTFLAGS[*]}"
+			RUNTESTFLAGS=" \
+				${GCC_TESTS_RUNTESTFLAGS} \
+				CFLAGS_FOR_TARGET='${CFLAGS_FOR_TARGET:-${CFLAGS}}' \
+				CXXFLAGS_FOR_TARGET='${CXXFLAGS_FOR_TARGET:-${CXXFLAGS}}' \
+				LDFLAGS_FOR_TARGET='${LDFLAGS_FOR_TARGET:-${LDFLAGS}}' \
+				CFLAGS='${CFLAGS}' \
+				CXXFLAGS='${CXXFLAGS}' \
+				FCFLAGS='${FCFLAGS}' \
+				FFLAGS='${FFLAGS}' \
+				LDFLAGS='${LDFLAGS}' \
+			" \
+			CFLAGS_FOR_TARGET="${CFLAGS_FOR_TARGET:-${CFLAGS}}" \
+			CXXFLAGS_FOR_TARGET="${CXXFLAGS_FOR_TARGET:-${CXXFLAGS}}" \
+			LDFLAGS_FOR_TARGET="${LDFLAGS_FOR_TARGET:-${LDFLAGS}}" \
+			CFLAGS="${CFLAGS}" \
+			CXXFLAGS="${CXXFLAGS}" \
+			FCFLAGS="${FCFLAGS}" \
+			FFLAGS="${FFLAGS}" \
+			LDFLAGS="${LDFLAGS}"
 	)
 
 	# Produce an updated failure manifest.
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-08 10:30 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-08-08 10:30 UTC (permalink / raw
  To: gentoo-commits
commit:     d4c98533530d9478391b0593fd84cf37ac9c97cb
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Aug  8 10:17:24 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Aug  8 10:29:39 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=d4c98533
toolchain.eclass: try to silence remaining flag vs FE issues
This is the Fortran issue I mentioned in 6df977928704e77d2f672d3890ceadc8ba837ab5.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 4 ++++
 1 file changed, 4 insertions(+)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 37db6e0165f4..9bbe0cb7e0af 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1936,6 +1936,10 @@ toolchain_src_test() {
 		# tests too.
 		append-flags -Wno-trampolines
 
+		# Avoid confusing tests like Fortran/C interop ones where
+		# CFLAGS are used.
+		append-flags -Wno-complain-wrong-lang
+
 		# Issues with Ada tests:
 		# gnat.dg/align_max.adb
 		# gnat.dg/trampoline4.adb
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-08 10:30 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-08-08 10:30 UTC (permalink / raw
  To: gentoo-commits
commit:     ec6893633b15b218cddad2338eb43ffff36a1fe8
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Aug  8 10:17:13 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Aug  8 10:29:39 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=ec689363
toolchain.eclass: add note re (intended) duplication of CFLAGS et. al
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 86a29f5aacb8..37db6e0165f4 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1957,6 +1957,9 @@ toolchain_src_test() {
 
 		# nonfatal here as we die if the comparison below fails. Also, note that
 		# the exit code of targets other than 'check' may be unreliable.
+		#
+		# CFLAGS and so on are repeated here because of tests vs building test
+		# deps like libbacktrace.
 		nonfatal emake -C "${WORKDIR}"/build -k "${GCC_TESTS_CHECK_TARGET}" \
 			RUNTESTFLAGS=" \
 				${GCC_TESTS_RUNTESTFLAGS} \
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-08 10:49 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-08-08 10:49 UTC (permalink / raw
  To: gentoo-commits
commit:     7200aecb3db3b2dd91129e1530bcb75ce096af91
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Aug  8 10:48:00 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Aug  8 10:48:00 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=7200aecb
toolchain.eclass: add -g for tests
I haven't looked closely yet but I think this is the same as the
binutils issue from before.
Bug: https://bugs.gentoo.org/934149
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 4 ++++
 1 file changed, 4 insertions(+)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 9bbe0cb7e0af..491eea823af2 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1956,6 +1956,10 @@ toolchain_src_test() {
 		# Go doesn't support this and causes noisy warnings
 		filter-flags -Wbuiltin-declaration-mismatch
 
+		# configure defaults to '-O2 -g' and some tests expect it
+		# accordingly.
+		append-flags -g
+
 		# TODO: Does this handle s390 (-m31) correctly?
 		is_multilib && GCC_TESTS_RUNTESTFLAGS+=" --target_board=unix{,-m32}"
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-08 14:38 James Le Cuirot
  0 siblings, 0 replies; 6663+ messages in thread
From: James Le Cuirot @ 2024-08-08 14:38 UTC (permalink / raw
  To: gentoo-commits
commit:     5d7123c19965b4fee3ce79687cc15f251e998307
Author:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
AuthorDate: Thu Aug  8 14:36:52 2024 +0000
Commit:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
CommitDate: Thu Aug  8 14:36:52 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=5d7123c1
cargo.eclass: Fix cargo_target_dir helper following recent changes
We used to only set the Rust target when cross-compiling, but now we do
it unconditionally, which changes the target directory.
Closes: https://bugs.gentoo.org/937574
Signed-off-by: James Le Cuirot <chewi <AT> gentoo.org>
 eclass/cargo.eclass | 4 +---
 1 file changed, 1 insertion(+), 3 deletions(-)
diff --git a/eclass/cargo.eclass b/eclass/cargo.eclass
index 6d4cf1b425eb..3a63e5027250 100644
--- a/eclass/cargo.eclass
+++ b/eclass/cargo.eclass
@@ -324,9 +324,7 @@ _cargo_gen_git_config() {
 # Return the directory within target that contains the build, e.g.
 # target/aarch64-unknown-linux-gnu/release.
 cargo_target_dir() {
-	local abi
-	tc-is-cross-compiler && abi=/$(rust_abi)
-	echo "${CARGO_TARGET_DIR:-target}${abi}/$(usex debug debug release)"
+	echo "${CARGO_TARGET_DIR:-target}/$(rust_abi)/$(usex debug debug release)"
 }
 
 # @FUNCTION: cargo_src_unpack
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-08 16:46 Andrew Ammerlaan
  0 siblings, 0 replies; 6663+ messages in thread
From: Andrew Ammerlaan @ 2024-08-08 16:46 UTC (permalink / raw
  To: gentoo-commits
commit:     c75b6bf3c8b84eb3a674613cf054b54b053bbd7c
Author:     Andrew Ammerlaan <andrewammerlaan <AT> gentoo <DOT> org>
AuthorDate: Thu Aug  8 12:02:35 2024 +0000
Commit:     Andrew Ammerlaan <andrewammerlaan <AT> gentoo <DOT> org>
CommitDate: Thu Aug  8 16:44:27 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=c75b6bf3
(dist-)kernel-{install,utils}.eclass: fix finding config during cleanup
The source symlink does not exist on all systems.
If we can't find any config at all then there will be no preferred suffix
which means we fall back to the old '-nt' based cleaning.
Closes: https://bugs.gentoo.org/937569
Signed-off-by: Andrew Ammerlaan <andrewammerlaan <AT> gentoo.org>
Closes: https://github.com/gentoo/gentoo/pull/38016
Signed-off-by: Andrew Ammerlaan <andrewammerlaan <AT> gentoo.org>
 eclass/dist-kernel-utils.eclass | 18 +++++++++++++++---
 eclass/kernel-install.eclass    |  2 +-
 2 files changed, 16 insertions(+), 4 deletions(-)
diff --git a/eclass/dist-kernel-utils.eclass b/eclass/dist-kernel-utils.eclass
index 0b0eb0ec8818..bb058d488a13 100644
--- a/eclass/dist-kernel-utils.eclass
+++ b/eclass/dist-kernel-utils.eclass
@@ -160,7 +160,7 @@ dist-kernel_PV_to_KV() {
 }
 
 # @FUNCTION: dist-kernel_get_module_suffix
-# @USAGE: <kernel_dir>
+# @USAGE: <kernel_config>
 # @DESCRIPTION:
 # Returns the suffix for kernel modules based on the CONFIG_MODULES_COMPESS_*
 # setting in the kernel config and USE=modules-compress.
@@ -169,7 +169,7 @@ dist-kernel_get_module_suffix() {
 
 	[[ ${#} -eq 1 ]] || die "${FUNCNAME}: invalid arguments"
 
-	local config=${1}/.config
+	local config=${1}
 
 	if ! in_iuse modules-compress || ! use modules-compress; then
 		echo .ko
@@ -198,7 +198,19 @@ dist-kernel_compressed_module_cleanup() {
 
 	[[ ${#} -ne 1 ]] && die "${FUNCNAME}: invalid arguments"
 	local path=${1}
-	local preferred=$(dist-kernel_get_module_suffix "${path}/source")
+	local config_path=/usr/src/linux-${KV_FULL}/.config
+
+	local option
+	for option in config source/.config build/.config; do
+		if [[ -f ${path}/${option} ]]; then
+			config_path=${path}/${option}
+			break
+		fi
+	done
+
+	local preferred=
+	[[ -f ${config_path} ]] && preferred=$(dist-kernel_get_module_suffix "${config_path}")
+
 	local basename suffix
 
 	while read -r basename; do
diff --git a/eclass/kernel-install.eclass b/eclass/kernel-install.eclass
index c64dd673084b..496e258815d2 100644
--- a/eclass/kernel-install.eclass
+++ b/eclass/kernel-install.eclass
@@ -769,7 +769,7 @@ kernel-install_compress_modules() {
 		if [[ -z ${KV_FULL} ]]; then
 			KV_FULL=${PV}${KV_LOCALVERSION}
 		fi
-		local suffix=$(dist-kernel_get_module_suffix "${ED}/usr/src/linux-${KV_FULL}")
+		local suffix=$(dist-kernel_get_module_suffix "${ED}/usr/src/linux-${KV_FULL}/.config")
 		local compress=()
 		# Options taken from linux-mod-r1.eclass.
 		# We don't instruct the compressor to parallelize because it applies
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-08 19:26 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-08-08 19:26 UTC (permalink / raw
  To: gentoo-commits
commit:     a37a72cc9bf07ef495fd17a60ff5005914eb2c09
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Thu Aug  8 18:59:53 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Thu Aug  8 19:25:53 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=a37a72cc
llvm.org.eclass: Add 20.0.0_pre20240808 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index d705947ce0d2..d1c169264662 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -72,6 +72,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 			_LLVM_SOURCE_TYPE=snapshot
 
 			case ${PV} in
+				20.0.0_pre20240808)
+					EGIT_COMMIT=fd7d7882e7fa5a38d4bfde426120d4663718beb4
+					;;
 				20.0.0_pre20240801)
 					EGIT_COMMIT=130c135689ec12ab78c53645808524a8d28f7cae
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-09 11:39 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-08-09 11:39 UTC (permalink / raw
  To: gentoo-commits
commit:     c87ab053be64e6c9f7b9e4ab1cca3099e37471f0
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Aug  9 11:37:17 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Aug  9 11:38:00 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=c87ab053
toolchain.eclass: drop *_FOR_TARGET in src_test
We seem to fail way more tests like the gcov ones for this, I guess
it overrides the flags it adds somehow.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 6 ------
 1 file changed, 6 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 89af435dfbf6..1797fc59cf88 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1979,18 +1979,12 @@ toolchain_src_test() {
 		nonfatal emake -C "${WORKDIR}"/build -k "${GCC_TESTS_CHECK_TARGET}" \
 			RUNTESTFLAGS=" \
 				${GCC_TESTS_RUNTESTFLAGS} \
-				CFLAGS_FOR_TARGET='${CFLAGS_FOR_TARGET:-${CFLAGS}}' \
-				CXXFLAGS_FOR_TARGET='${CXXFLAGS_FOR_TARGET:-${CXXFLAGS}}' \
-				LDFLAGS_FOR_TARGET='${LDFLAGS_FOR_TARGET:-${LDFLAGS}}' \
 				CFLAGS='${CFLAGS}' \
 				CXXFLAGS='${CXXFLAGS}' \
 				FCFLAGS='${FCFLAGS}' \
 				FFLAGS='${FFLAGS}' \
 				LDFLAGS='${LDFLAGS}' \
 			" \
-			CFLAGS_FOR_TARGET="${CFLAGS_FOR_TARGET:-${CFLAGS}}" \
-			CXXFLAGS_FOR_TARGET="${CXXFLAGS_FOR_TARGET:-${CXXFLAGS}}" \
-			LDFLAGS_FOR_TARGET="${LDFLAGS_FOR_TARGET:-${LDFLAGS}}" \
 			CFLAGS="${CFLAGS}" \
 			CXXFLAGS="${CXXFLAGS}" \
 			FCFLAGS="${FCFLAGS}" \
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-09 11:50 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-08-09 11:50 UTC (permalink / raw
  To: gentoo-commits
commit:     7136d821f9c15695768bb9ecd0d62cf5ff824b6a
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Aug  9 11:49:35 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Aug  9 11:49:35 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=7136d821
Revert "toolchain.eclass: drop *_FOR_TARGET in src_test"
This reverts commit c87ab053be64e6c9f7b9e4ab1cca3099e37471f0.
I think I was wrong. Gah.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 6 ++++++
 1 file changed, 6 insertions(+)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 1797fc59cf88..89af435dfbf6 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1979,12 +1979,18 @@ toolchain_src_test() {
 		nonfatal emake -C "${WORKDIR}"/build -k "${GCC_TESTS_CHECK_TARGET}" \
 			RUNTESTFLAGS=" \
 				${GCC_TESTS_RUNTESTFLAGS} \
+				CFLAGS_FOR_TARGET='${CFLAGS_FOR_TARGET:-${CFLAGS}}' \
+				CXXFLAGS_FOR_TARGET='${CXXFLAGS_FOR_TARGET:-${CXXFLAGS}}' \
+				LDFLAGS_FOR_TARGET='${LDFLAGS_FOR_TARGET:-${LDFLAGS}}' \
 				CFLAGS='${CFLAGS}' \
 				CXXFLAGS='${CXXFLAGS}' \
 				FCFLAGS='${FCFLAGS}' \
 				FFLAGS='${FFLAGS}' \
 				LDFLAGS='${LDFLAGS}' \
 			" \
+			CFLAGS_FOR_TARGET="${CFLAGS_FOR_TARGET:-${CFLAGS}}" \
+			CXXFLAGS_FOR_TARGET="${CXXFLAGS_FOR_TARGET:-${CXXFLAGS}}" \
+			LDFLAGS_FOR_TARGET="${LDFLAGS_FOR_TARGET:-${LDFLAGS}}" \
 			CFLAGS="${CFLAGS}" \
 			CXXFLAGS="${CXXFLAGS}" \
 			FCFLAGS="${FCFLAGS}" \
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-09 14:30 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-08-09 14:30 UTC (permalink / raw
  To: gentoo-commits
commit:     c1d510a5f4fcd477e94fb429925321d65d3b80ed
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Aug  9 14:29:43 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Aug  9 14:29:43 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=c1d510a5
toolchain.eclass: tidy up src_test a bit more, another tweak
* Disable -fno-semantic-interposition for tests as ASAN + contract violation
  checks rely on it
* Consolidate the appends vs. filters
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 19 ++++++++-----------
 1 file changed, 8 insertions(+), 11 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 89af435dfbf6..2acade8e4ca8 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1926,23 +1926,25 @@ toolchain_src_test() {
 	(
 		# Unexpected warnings confuse the tests.
 		filter-flags -W*
-
 		# May break parsing.
 		filter-flags '-fdiagnostics-color=*' '-fdiagnostics-urls=*'
-
 		# Gentoo QA flags which don't belong in tests
 		filter-flags -frecord-gcc-switches
 		filter-flags '-Wl,--defsym=__gentoo_check_ldflags__=0'
+		# Go doesn't support this and causes noisy warnings
+		filter-flags -Wbuiltin-declaration-mismatch
+		# The ASAN tests at least need LD_PRELOAD and the contract
+		# tests.
+		filter-flags -fno-semantic-interposition
 
 		# Workaround our -Wformat-security default which breaks
 		# various tests as it adds unexpected warning output.
-		# (Only for C/C++ here to avoid noise for Fortran.)
-		append-cflags -Wno-format-security -Wno-format
-		append-cxxflags -Wno-format-security -Wno-format
+		append-flags -Wno-format-security -Wno-format
 		# Workaround our -Wtrampolines default which breaks
 		# tests too.
 		append-flags -Wno-trampolines
-
+		# A handful of Ada (and objc++?) tests need an executable stack
+		append-ldflags -Wl,--no-warn-execstack
 		# Avoid confusing tests like Fortran/C interop ones where
 		# CFLAGS are used.
 		append-flags -Wno-complain-wrong-lang
@@ -1957,11 +1959,6 @@ toolchain_src_test() {
 		# TODO: This isn't ideal given it obv. affects codegen
 		# and we want to be sure it works.
 		append-flags -fno-stack-clash-protection
-		# A handful of Ada (and objc++?) tests need an executable stack
-		append-ldflags -Wl,--no-warn-execstack
-
-		# Go doesn't support this and causes noisy warnings
-		filter-flags -Wbuiltin-declaration-mismatch
 
 		# configure defaults to '-O2 -g' and some tests expect it
 		# accordingly.
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-09 15:50 Andrew Ammerlaan
  0 siblings, 0 replies; 6663+ messages in thread
From: Andrew Ammerlaan @ 2024-08-09 15:50 UTC (permalink / raw
  To: gentoo-commits
commit:     5d6d7c6fbacf10a5fbb8d3ea1ab6ec2362ade6f9
Author:     Andrew Ammerlaan <andrewammerlaan <AT> gentoo <DOT> org>
AuthorDate: Fri Aug  9 15:46:39 2024 +0000
Commit:     Andrew Ammerlaan <andrewammerlaan <AT> gentoo <DOT> org>
CommitDate: Fri Aug  9 15:50:26 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=5d6d7c6f
kernel-install.eclass: run depmod after compressing modules
(de)compressing modules changes the path of the module files so we need to
run depmod to ensure that tools such as modprobe/modinfo work.
Note that depmod is often, but *not* always, run by sys-kernel/installkernel.
Systemd installs a hook to do this, but there is no equivalent on openrc
systems. So instead just ensure that the tree of modules we install is
consistent here in the eclass.
Signed-off-by: Andrew Ammerlaan <andrewammerlaan <AT> gentoo.org>
 eclass/kernel-install.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/kernel-install.eclass b/eclass/kernel-install.eclass
index 496e258815d2..930640188c26 100644
--- a/eclass/kernel-install.eclass
+++ b/eclass/kernel-install.eclass
@@ -796,6 +796,9 @@ kernel-install_compress_modules() {
 		find "${ED}/lib/modules/${KV_FULL}" -name '*.ko' -print0 |
 			xargs -0 -P "$(makeopts_jobs)" -n 128 "${compress[@]}"
 		assert "Compressing kernel modules failed"
+
+		# Module paths have changed, run depmod
+		depmod --all --basedir "${ED}" ${KV_FULL} || die
 	fi
 }
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-10 14:06 Fabian Groffen
  0 siblings, 0 replies; 6663+ messages in thread
From: Fabian Groffen @ 2024-08-10 14:06 UTC (permalink / raw
  To: gentoo-commits
commit:     c7f5ca73ddfab78834c5bf240cb544e07a6d61ab
Author:     Fabian Groffen <grobian <AT> gentoo <DOT> org>
AuthorDate: Sat Aug 10 14:02:39 2024 +0000
Commit:     Fabian Groffen <grobian <AT> gentoo <DOT> org>
CommitDate: Sat Aug 10 14:06:07 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=c7f5ca73
eclass/toolchain-funcs: add support for Prefix targets
- support Darwin
- support arm64 (Apple Silicon) Darwin
- skip gen_usr_ldscript on Prefix targets
Signed-off-by: Fabian Groffen <grobian <AT> gentoo.org>
 eclass/toolchain-funcs.eclass | 15 +++++++++++++--
 1 file changed, 13 insertions(+), 2 deletions(-)
diff --git a/eclass/toolchain-funcs.eclass b/eclass/toolchain-funcs.eclass
index 9f0953c079e3..50eb310b4bf1 100644
--- a/eclass/toolchain-funcs.eclass
+++ b/eclass/toolchain-funcs.eclass
@@ -251,7 +251,7 @@ tc-detect-is-softfloat() {
 
 	case ${CTARGET:-${CHOST}} in
 		# Avoid autodetection for bare-metal targets. bug #666896
-		*-newlib|*-elf|*-eabi)
+		*-newlib|*-elf|*-eabi|arm64-apple-darwin*)
 			return 1 ;;
 
 		# arm-unknown-linux-gnueabi is ambiguous. We used to treat it as
@@ -295,6 +295,8 @@ tc-tuple-is-softfloat() {
 		# bare-metal targets have their defaults. bug #666896
 		*-newlib|*-elf|*-eabi)
 			echo "no" ;;
+		arm64-apple-darwin*)
+			echo "no" ;;
 		arm*)
 			echo "yes" ;;
 		*)
@@ -626,7 +628,14 @@ tc-has-tls() {
 		-*) die "Usage: tc-has-tls [-c|-l] [toolchain prefix]";;
 	esac
 
-	: "${flags:=-fPIC -shared -Wl,-z,defs}"
+	case "${CHOST}" in
+		*-darwin*)
+			# bug #612370
+			: ${flags:=-dynamiclib}
+			;;
+		*)
+			: ${flags:=-fPIC -shared -Wl,-z,defs}
+	esac
 	[[ $1 == -* ]] && shift
 	$(tc-getCC "$@") ${flags} "${base}.c" -o "${base}" >&/dev/null
 	local ret=$?
@@ -645,6 +654,7 @@ tc-ninja_magic_to_arch() {
 	[[ -z ${host} ]] && host=${CTARGET:-${CHOST}}
 
 	case ${host} in
+		arm64*)		echo arm64;;
 		aarch64*)	echo arm64;;
 		alpha*)		echo alpha;;
 		arc*)		echo arc;;
@@ -1032,6 +1042,7 @@ gen_usr_ldscript() {
 	[[ -z ${ED+set} ]] && local ED=${D%/}${EPREFIX}/
 
 	tc-is-static-only && return
+	use prefix && return
 
 	# We only care about stuffing / for the native ABI, bug #479448
 	if [[ $(type -t multilib_is_native_abi) == "function" ]] ; then
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-10 17:24 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-08-10 17:24 UTC (permalink / raw
  To: gentoo-commits
commit:     af10cf7228656d9d2cc886f1fac51d46fb33a17a
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Aug 10 17:23:03 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Aug 10 17:23:49 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=af10cf72
toolchain.eclass: disable multilib tests for now
... until validate_failures.py can handle them properly, to avoid
trashing our test manifests.
Bug: https://gcc.gnu.org/PR116260
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 5 +++--
 1 file changed, 3 insertions(+), 2 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 2acade8e4ca8..bfb087146864 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1966,7 +1966,9 @@ toolchain_src_test() {
 
 		# TODO: Does this handle s390 (-m31) correctly?
 		# TODO: What if there are multiple ABIs like x32 too?
-		is_multilib && GCC_TESTS_RUNTESTFLAGS+=" --target_board=unix{,-m32}"
+		# XXX: Disabled until validate_failures.py can handle 'variants'
+		# XXX: https://gcc.gnu.org/PR116260
+		#is_multilib && GCC_TESTS_RUNTESTFLAGS+=" --target_board=unix{,-m32}"
 
 		# nonfatal here as we die if the comparison below fails. Also, note that
 		# the exit code of targets other than 'check' may be unreliable.
@@ -1996,7 +1998,6 @@ toolchain_src_test() {
 	)
 
 	# Produce an updated failure manifest.
-	# XXX: Manifests aren't ideal w/ multilib because of https://gcc.gnu.org/PR116260
 	einfo "Generating a new failure manifest ${T}/${CHOST}.xfail"
 	rm -f "${T}"/${CHOST}.xfail
 	edo "${T}"/validate_failures.py \
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-11 20:56 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-08-11 20:56 UTC (permalink / raw
  To: gentoo-commits
commit:     1e38f02f41e79e1fb15b1d418f0a792ce22c390d
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Aug 11 17:35:12 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Aug 11 20:53:44 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=1e38f02f
toolchain.eclass: style tweak
For consistency.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index bfb087146864..984c37a3fa73 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -2049,7 +2049,7 @@ toolchain_src_test() {
 			eerror "GCC_TESTS_IGNORE_NO_BASELINE is set, ignoring test result and creating a new baseline..."
 		elif [[ -n ${GCC_TESTS_REGEN_BASELINE} ]] ; then
 			eerror "GCC_TESTS_REGEN_BASELINE is set, ignoring test result and creating using a new baseline..."
-		elif [[ ${ret} != 0 ]]; then
+		elif [[ ${ret} != 0 ]] ; then
 			eerror "(Set GCC_TESTS_IGNORE_NO_BASELINE=1 to make this non-fatal and generate a baseline.)"
 			die "Tests failed (failures occurred with no reference data)"
 		fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-12  1:19 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-08-12  1:19 UTC (permalink / raw
  To: gentoo-commits
commit:     efff53996be8ae20f332867358fd1a3af83a1ee2
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Aug 12 01:10:10 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Aug 12 01:19:31 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=efff5399
toolchain.eclass: drop filter-flags from src_test
This no longer does anything after the previous commit to use
custom variables for flags for tests.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 13 -------------
 1 file changed, 13 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 326daf66586c..3cd3be676f9b 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1926,19 +1926,6 @@ toolchain_src_test() {
 
 	# Use a subshell to allow meddling with flags just for the testsuite
 	(
-		# Unexpected warnings confuse the tests.
-		filter-flags -W*
-		# May break parsing.
-		filter-flags '-fdiagnostics-color=*' '-fdiagnostics-urls=*'
-		# Gentoo QA flags which don't belong in tests
-		filter-flags -frecord-gcc-switches
-		filter-flags '-Wl,--defsym=__gentoo_check_ldflags__=0'
-		# Go doesn't support this and causes noisy warnings
-		filter-flags -Wbuiltin-declaration-mismatch
-		# The ASAN tests at least need LD_PRELOAD and the contract
-		# tests.
-		filter-flags -fno-semantic-interposition
-
 		# Workaround our -Wformat-security default which breaks
 		# various tests as it adds unexpected warning output.
 		GCC_TESTS_CFLAGS+=" -Wno-format-security -Wno-format"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-12  1:19 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-08-12  1:19 UTC (permalink / raw
  To: gentoo-commits
commit:     5ea011f3d6691b8093be519474d3303ea388f260
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Aug 12 01:05:33 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Aug 12 01:19:29 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=5ea011f3
toolchain.eclass: add comment re GCC_TEST_RUN_EXPENSIVE
Make clear it's not a typo as it comes from gcc's testsuite (could
look like an accidental 'TEST' instead of 'TESTS' like the eclassvars
we use for tests.)
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 2 ++
 1 file changed, 2 insertions(+)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 984c37a3fa73..b2d4692bc2e1 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1920,6 +1920,8 @@ toolchain_src_test() {
 	local -x LD_PRELOAD=
 
 	# Controls running expensive tests in e.g. the torture testsuite.
+	# Note that 'TEST', not 'TESTS', is correct here as it's a GCC
+	# testsuite variable, not ours.
 	local -x GCC_TEST_RUN_EXPENSIVE=1
 
 	# Use a subshell to allow meddling with flags just for the testsuite
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-12  1:19 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-08-12  1:19 UTC (permalink / raw
  To: gentoo-commits
commit:     15ce82749db7922e462f900df9b7edbda37f152b
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Aug 12 01:06:45 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Aug 12 01:19:30 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=15ce8274
toolchain.eclass: don't pass user flags in src_test
This is obvious in hindsight. The flags we were passing *precisely because*
we wanted e.g. -Wno-format to be passed to every test also included
-O2 or whatever from the user's flags which breaks tests that may require
no optimisation and so on.
Instead of trying to filter out options in a whack-a-mole game, let's
introduce special GCC_TESTS_* *FLAGS variables which we append
the needed -Wno-* to (etc.) which users can also specify if they really want
or need to.
Note that this isn't as scary or as weird as it sounds. We were only
trying to jam these flags in **purely** to counteract some defaults
we set, these tests really aren't supposed to be run with arbitrary
flags stuck in, but a workaround we added started to introduce way
more than intended.
The torture tests are fine with being run with various optimisation flags
but the rest of the testesuite isn't.
This fixes 361c3758642891759b0ed60a8f96bc0776d19f15 and some of the
attempts afterwards, although not everything in those commits was bad.
Fixes: 361c3758642891759b0ed60a8f96bc0776d19f15
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 49 +++++++++++++++++++++++++++----------------------
 1 file changed, 27 insertions(+), 22 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index b2d4692bc2e1..326daf66586c 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1941,15 +1941,19 @@ toolchain_src_test() {
 
 		# Workaround our -Wformat-security default which breaks
 		# various tests as it adds unexpected warning output.
-		append-flags -Wno-format-security -Wno-format
+		GCC_TESTS_CFLAGS+=" -Wno-format-security -Wno-format"
+		GCC_TESTS_CXXFLAGS+=" -Wno-format-security -Wno-format"
+
 		# Workaround our -Wtrampolines default which breaks
 		# tests too.
-		append-flags -Wno-trampolines
+		GCC_TESTS_CFLAGS+=" -Wno-trampolines"
+		GCC_TESTS_CXXFLAGS+=" -Wno-trampolines"
 		# A handful of Ada (and objc++?) tests need an executable stack
-		append-ldflags -Wl,--no-warn-execstack
+		GCC_TESTS_LDFLAGS+=" -Wl,--no-warn-execstack"
 		# Avoid confusing tests like Fortran/C interop ones where
 		# CFLAGS are used.
-		append-flags -Wno-complain-wrong-lang
+		GCC_TESTS_CFLAGS+=" -Wno-complain-wrong-lang"
+		GCC_TESTS_CXXFLAGS+=" -Wno-complain-wrong-lang"
 
 		# Issues with Ada tests:
 		# gnat.dg/align_max.adb
@@ -1960,11 +1964,12 @@ toolchain_src_test() {
 		#
 		# TODO: This isn't ideal given it obv. affects codegen
 		# and we want to be sure it works.
-		append-flags -fno-stack-clash-protection
+		GCC_TESTS_CFLAGS+=" -fno-stack-clash-protection"
+		GCC_TESTS_CXXFLAGS+=" -fno-stack-clash-protection"
 
 		# configure defaults to '-O2 -g' and some tests expect it
 		# accordingly.
-		append-flags -g
+		GCC_TESTS_CFLAGS+=" -g"
 
 		# TODO: Does this handle s390 (-m31) correctly?
 		# TODO: What if there are multiple ABIs like x32 too?
@@ -1980,23 +1985,23 @@ toolchain_src_test() {
 		nonfatal emake -C "${WORKDIR}"/build -k "${GCC_TESTS_CHECK_TARGET}" \
 			RUNTESTFLAGS=" \
 				${GCC_TESTS_RUNTESTFLAGS} \
-				CFLAGS_FOR_TARGET='${CFLAGS_FOR_TARGET:-${CFLAGS}}' \
-				CXXFLAGS_FOR_TARGET='${CXXFLAGS_FOR_TARGET:-${CXXFLAGS}}' \
-				LDFLAGS_FOR_TARGET='${LDFLAGS_FOR_TARGET:-${LDFLAGS}}' \
-				CFLAGS='${CFLAGS}' \
-				CXXFLAGS='${CXXFLAGS}' \
-				FCFLAGS='${FCFLAGS}' \
-				FFLAGS='${FFLAGS}' \
-				LDFLAGS='${LDFLAGS}' \
+				CFLAGS_FOR_TARGET='${GCC_TESTS_CFLAGS_FOR_TARGET:-${GCC_TESTS_CFLAGS}}' \
+				CXXFLAGS_FOR_TARGET='${GCC_TESTS_CXXFLAGS_FOR_TARGET:-${GCC_TESTS_CXXFLAGS}}' \
+				LDFLAGS_FOR_TARGET='${TEST_LDFLAGS_FOR_TARGET:-${GCC_TESTS_LDFLAGS}}' \
+				CFLAGS='${GCC_TESTS_CFLAGS}' \
+				CXXFLAGS='${GCC_TESTS_CXXFLAGS}' \
+				FCFLAGS='${GCC_TESTS_FCFLAGS}' \
+				FFLAGS='${GCC_TESTS_FFLAGS}' \
+				LDFLAGS='${GCC_TESTS_LDFLAGS}' \
 			" \
-			CFLAGS_FOR_TARGET="${CFLAGS_FOR_TARGET:-${CFLAGS}}" \
-			CXXFLAGS_FOR_TARGET="${CXXFLAGS_FOR_TARGET:-${CXXFLAGS}}" \
-			LDFLAGS_FOR_TARGET="${LDFLAGS_FOR_TARGET:-${LDFLAGS}}" \
-			CFLAGS="${CFLAGS}" \
-			CXXFLAGS="${CXXFLAGS}" \
-			FCFLAGS="${FCFLAGS}" \
-			FFLAGS="${FFLAGS}" \
-			LDFLAGS="${LDFLAGS}"
+			CFLAGS_FOR_TARGET="${GCC_TESTS_CFLAGS_FOR_TARGET:-${GCC_TESTS_CFLAGS}}" \
+			CXXFLAGS_FOR_TARGET="${GCC_TESTS_CXXFLAGS_FOR_TARGET:-${GCC_TESTS_CXXFLAGS}}" \
+			LDFLAGS_FOR_TARGET="${GCC_TESTS_LDFLAGS_FOR_TARGET:-${GCC_TESTS_LDFLAGS}}" \
+			CFLAGS="${GCC_TESTS_CFLAGS}" \
+			CXXFLAGS="${GCC_TESTS_CXXFLAGS}" \
+			FCFLAGS="${GCC_TESTS_FCFLAGS}" \
+			FFLAGS="${GCC_TESTS_FFLAGS}" \
+			LDFLAGS="${GCC_TESTS_LDFLAGS}"
 	)
 
 	# Produce an updated failure manifest.
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-12  1:19 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-08-12  1:19 UTC (permalink / raw
  To: gentoo-commits
commit:     eb9d324cb45589e287e6cce64f3110acccf1e47c
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Aug 12 01:18:07 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Aug 12 01:19:32 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=eb9d324c
toolchain.eclass: add TODO re flags for building deps in src_test
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 3cd3be676f9b..ac236f3127f9 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1969,6 +1969,9 @@ toolchain_src_test() {
 		#
 		# CFLAGS and so on are repeated here because of tests vs building test
 		# deps like libbacktrace.
+		#
+		# TODO: Should we try pass in the regular user flags for the non-RUNTESTFLAGS
+		# instances below for building e.g. libbacktrace?
 		nonfatal emake -C "${WORKDIR}"/build -k "${GCC_TESTS_CHECK_TARGET}" \
 			RUNTESTFLAGS=" \
 				${GCC_TESTS_RUNTESTFLAGS} \
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-12 19:02 Ulrich Müller
  0 siblings, 0 replies; 6663+ messages in thread
From: Ulrich Müller @ 2024-08-12 19:02 UTC (permalink / raw
  To: gentoo-commits
commit:     bcc4c0d2300712a5af55a6f6a9cab0472f13d1bf
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Mon Aug 12 19:02:05 2024 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Mon Aug 12 19:02:05 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=bcc4c0d2
bzr.eclass: Remove dead eclass
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 eclass/bzr.eclass | 258 ------------------------------------------------------
 1 file changed, 258 deletions(-)
diff --git a/eclass/bzr.eclass b/eclass/bzr.eclass
deleted file mode 100644
index b442381dc668..000000000000
--- a/eclass/bzr.eclass
+++ /dev/null
@@ -1,258 +0,0 @@
-# Copyright 1999-2023 Gentoo Authors
-# Distributed under the terms of the GNU General Public License v2
-
-# @DEAD
-# @ECLASS: bzr.eclass
-# @MAINTAINER:
-# Ulrich Müller <ulm@gentoo.org>
-# @AUTHOR:
-# Jorge Manuel B. S. Vicetto <jmbsvicetto@gentoo.org>
-# Mark Lee <bzr-gentoo-overlay@lazymalevolence.com>
-# Ulrich Müller <ulm@gentoo.org>
-# Christian Faulhammer <fauli@gentoo.org>
-# @SUPPORTED_EAPIS: 7 8
-# @BLURB: generic fetching functions for the Bazaar VCS
-# @DESCRIPTION:
-# The bzr.eclass provides functions to fetch and unpack sources from
-# repositories of the Bazaar distributed version control system.
-# The eclass was originally derived from git.eclass.
-#
-# Note: Just set EBZR_REPO_URI to the URI of the branch and src_unpack()
-# of this eclass will export the branch to ${WORKDIR}/${P}.
-
-case ${EAPI} in
-	7|8) ;;
-	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
-esac
-
-PROPERTIES+=" live"
-
-BDEPEND="dev-vcs/breezy"
-
-# @ECLASS_VARIABLE: EBZR_STORE_DIR
-# @USER_VARIABLE
-# @DESCRIPTION:
-# The directory to store all fetched Bazaar live sources.
-: "${EBZR_STORE_DIR:=${PORTAGE_ACTUAL_DISTDIR:-${DISTDIR}}/bzr-src}"
-
-# @ECLASS_VARIABLE: EBZR_UNPACK_DIR
-# @DESCRIPTION:
-# The working directory where the sources are copied to.
-: "${EBZR_UNPACK_DIR:=${WORKDIR}/${P}}"
-
-# @ECLASS_VARIABLE: EBZR_INIT_REPO_CMD
-# @DESCRIPTION:
-# The Bazaar command to initialise a shared repository.
-: "${EBZR_INIT_REPO_CMD:="brz init-shared-repository --no-trees"}"
-
-# @ECLASS_VARIABLE: EBZR_FETCH_CMD
-# @DESCRIPTION:
-# The Bazaar command to fetch the sources.
-: "${EBZR_FETCH_CMD:="brz branch --no-tree"}"
-
-# @ECLASS_VARIABLE: EBZR_UPDATE_CMD
-# @DESCRIPTION:
-# The Bazaar command to update the sources.
-: "${EBZR_UPDATE_CMD:="brz pull --overwrite-tags"}"
-
-# @ECLASS_VARIABLE: EBZR_EXPORT_CMD
-# @DESCRIPTION:
-# The Bazaar command to export a branch.
-: "${EBZR_EXPORT_CMD:="brz export"}"
-
-# @ECLASS_VARIABLE: EBZR_CHECKOUT_CMD
-# @DESCRIPTION:
-# The Bazaar command to checkout a branch.
-: "${EBZR_CHECKOUT_CMD:="brz checkout --lightweight -q"}"
-
-# @ECLASS_VARIABLE: EBZR_REVNO_CMD
-# @DESCRIPTION:
-# The Bazaar command to list a revision number of the branch.
-: "${EBZR_REVNO_CMD:="brz revno"}"
-
-# @ECLASS_VARIABLE: EBZR_OPTIONS
-# @DEFAULT_UNSET
-# @DESCRIPTION:
-# The options passed to the fetch and update commands.
-
-# @ECLASS_VARIABLE: EBZR_REPO_URI
-# @DEFAULT_UNSET
-# @REQUIRED
-# @DESCRIPTION:
-# The repository URI for the source package.
-
-# @ECLASS_VARIABLE: EBZR_PROJECT
-# @DESCRIPTION:
-# The project name of your ebuild.  Normally, the branch will be stored
-# in the ${EBZR_STORE_DIR}/${EBZR_PROJECT} directory.
-#
-# If EBZR_BRANCH is set (see below), then a shared repository will be
-# created in that directory, and the branch will be located in
-# ${EBZR_STORE_DIR}/${EBZR_PROJECT}/${EBZR_BRANCH}.
-: "${EBZR_PROJECT:=${PN}}"
-
-# @ECLASS_VARIABLE: EBZR_BRANCH
-# @DEFAULT_UNSET
-# @DESCRIPTION:
-# The directory where to store the branch within a shared repository,
-# relative to ${EBZR_STORE_DIR}/${EBZR_PROJECT}.
-#
-# This variable should be set if there are several live ebuilds for
-# different branches of the same upstream project.  The branches can
-# then share the same repository in EBZR_PROJECT, which will save both
-# data traffic volume and disk space.
-#
-# If there is only a live ebuild for one single branch, EBZR_BRANCH
-# needs not be set.  In this case, the branch will be stored in a
-# stand-alone repository directly in EBZR_PROJECT.
-
-# @ECLASS_VARIABLE: EBZR_REVISION
-# @DEFAULT_UNSET
-# @DESCRIPTION:
-# Revision to fetch, defaults to the latest (see brz help revisionspec).
-
-# @ECLASS_VARIABLE: EBZR_OFFLINE
-# @USER_VARIABLE
-# @DESCRIPTION:
-# Set this variable to a non-empty value to disable automatic updating
-# of a bzr source tree.  This is intended to be set outside the ebuild
-# by users.
-: "${EBZR_OFFLINE=${EVCS_OFFLINE}}"
-
-# @ECLASS_VARIABLE: EVCS_UMASK
-# @USER_VARIABLE
-# @DEFAULT_UNSET
-# @DESCRIPTION:
-# Set this variable to a custom umask.  This is intended to be set by
-# users.  By setting this to something like 002, it can make life easier
-# for people who do development as non-root (but are in the portage
-# group), and then switch over to building with FEATURES=userpriv.
-# Or vice-versa.  Shouldn't be a security issue here as anyone who has
-# portage group write access already can screw the system over in more
-# creative ways.
-
-# @ECLASS_VARIABLE: EBZR_WORKDIR_CHECKOUT
-# @DEFAULT_UNSET
-# @DESCRIPTION:
-# If this variable is set to a non-empty value, EBZR_CHECKOUT_CMD will
-# be used instead of EBZR_EXPORT_CMD to copy the sources to WORKDIR.
-
-# @FUNCTION: _bzr_initial_fetch
-# @USAGE: <repository URI> <branch directory>
-# @INTERNAL
-# @DESCRIPTION:
-# Internal function, retrieves the source code from a repository for the
-# first time, using ${EBZR_FETCH_CMD}.
-_bzr_initial_fetch() {
-	local repo_uri=$1 branch_dir=$2
-
-	if [[ -n ${EBZR_OFFLINE} ]]; then
-		die "EBZR_OFFLINE cannot be used when there is no local branch yet."
-	fi
-
-	# fetch branch
-	einfo "bzr branch start -->"
-	einfo "   repository: ${repo_uri} => ${branch_dir}"
-
-	${EBZR_FETCH_CMD} ${EBZR_OPTIONS} "${repo_uri}" "${branch_dir}" \
-		|| die "${ECLASS}: can't branch from ${repo_uri}"
-}
-
-# @FUNCTION: _bzr_update
-# @USAGE: <repository URI> <branch directory>
-# @INTERNAL
-# @DESCRIPTION:
-# Internal function, updates the source code from a repository, using
-# ${EBZR_UPDATE_CMD}.
-_bzr_update() {
-	local repo_uri=$1 branch_dir=$2
-
-	if [[ -n ${EBZR_OFFLINE} ]]; then
-		einfo "skipping bzr pull -->"
-		einfo "   repository: ${repo_uri}"
-	else
-		# update branch
-		einfo "bzr pull start -->"
-		einfo "   repository: ${repo_uri}"
-
-		pushd "${branch_dir}" > /dev/null \
-			|| die "${ECLASS}: can't chdir to ${branch_dir}"
-		${EBZR_UPDATE_CMD} ${EBZR_OPTIONS} "${repo_uri}" \
-			|| die "${ECLASS}: can't pull from ${repo_uri}"
-		popd > /dev/null || die "${ECLASS}: popd failed"
-	fi
-}
-
-# @FUNCTION: bzr_fetch
-# @DESCRIPTION:
-# Wrapper function to fetch sources from a Bazaar repository with
-# bzr branch or bzr pull, depending on whether there is an existing
-# working copy.
-bzr_fetch() {
-	local repo_dir branch_dir save_umask
-
-	[[ -n ${EBZR_REPO_URI} ]] || die "${ECLASS}: EBZR_REPO_URI is empty"
-
-	if [[ ! -d ${EBZR_STORE_DIR} ]]; then
-		(
-			addwrite /
-			mkdir -p "${EBZR_STORE_DIR}" \
-				|| die "${ECLASS}: can't mkdir ${EBZR_STORE_DIR}"
-		)
-	fi
-
-	pushd "${EBZR_STORE_DIR}" > /dev/null \
-		|| die "${ECLASS}: can't chdir to ${EBZR_STORE_DIR}"
-
-	repo_dir=${EBZR_STORE_DIR}/${EBZR_PROJECT}
-	branch_dir=${repo_dir}${EBZR_BRANCH:+/${EBZR_BRANCH}}
-
-	if [[ -n ${EVCS_UMASK} ]]; then
-		save_umask=$(umask) || die
-		umask "${EVCS_UMASK}" || die
-	fi
-	addwrite "${EBZR_STORE_DIR}"
-
-	if [[ ! -d ${branch_dir}/.bzr ]]; then
-		if [[ ${repo_dir} != "${branch_dir}" && ! -d ${repo_dir}/.bzr ]]; then
-			einfo "creating shared bzr repository: ${repo_dir}"
-			${EBZR_INIT_REPO_CMD} "${repo_dir}" \
-				|| die "${ECLASS}: can't create shared repository"
-		fi
-		_bzr_initial_fetch "${EBZR_REPO_URI}" "${branch_dir}"
-	else
-		_bzr_update "${EBZR_REPO_URI}" "${branch_dir}"
-	fi
-
-	if [[ -n ${save_umask} ]]; then
-		umask "${save_umask}" || die
-	fi
-
-	cd "${branch_dir}" || die "${ECLASS}: can't chdir to ${branch_dir}"
-
-	# Save revision number in environment. #311101
-	export EBZR_REVNO=$(${EBZR_REVNO_CMD})
-
-	if [[ -n ${EBZR_WORKDIR_CHECKOUT} ]]; then
-		einfo "checking out ..."
-		${EBZR_CHECKOUT_CMD} ${EBZR_REVISION:+-r ${EBZR_REVISION}} \
-			. "${EBZR_UNPACK_DIR}" || die "${ECLASS}: checkout failed"
-	else
-		einfo "exporting ..."
-		${EBZR_EXPORT_CMD} ${EBZR_REVISION:+-r ${EBZR_REVISION}} \
-			"${EBZR_UNPACK_DIR}" . || die "${ECLASS}: export failed"
-	fi
-	einfo \
-		"revision ${EBZR_REVISION:-${EBZR_REVNO}} is now in ${EBZR_UNPACK_DIR}"
-
-	popd > /dev/null || die "${ECLASS}: popd failed"
-}
-
-# @FUNCTION: bzr_src_unpack
-# @DESCRIPTION:
-# Default src_unpack(), calls bzr_fetch.
-bzr_src_unpack() {
-	bzr_fetch
-}
-
-EXPORT_FUNCTIONS src_unpack
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-12 19:02 Ulrich Müller
  0 siblings, 0 replies; 6663+ messages in thread
From: Ulrich Müller @ 2024-08-12 19:02 UTC (permalink / raw
  To: gentoo-commits
commit:     a2b06caae07eddf6ee4597f0dbe53a476a6005ce
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Mon Aug 12 19:01:57 2024 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Mon Aug 12 19:01:57 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=a2b06caa
ltprune.eclass: Remove dead eclass
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 eclass/ltprune.eclass | 177 --------------------------------------------------
 1 file changed, 177 deletions(-)
diff --git a/eclass/ltprune.eclass b/eclass/ltprune.eclass
deleted file mode 100644
index 51f5aaabfea7..000000000000
--- a/eclass/ltprune.eclass
+++ /dev/null
@@ -1,177 +0,0 @@
-# Copyright 1999-2024 Gentoo Authors
-# Distributed under the terms of the GNU General Public License v2
-
-# @DEAD
-# @ECLASS: ltprune.eclass
-# @MAINTAINER:
-# Michał Górny <mgorny@gentoo.org>
-# @SUPPORTED_EAPIS: 0 1 2 3 4 5 6
-# @BLURB: Smart .la file pruning
-# @DEPRECATED: none
-# @DESCRIPTION:
-# A function to locate and remove unnecessary .la files.
-#
-# Discouraged. Whenever possible, please use much simpler:
-# @CODE
-# find "${ED}" -type f -name '*.la' -delete || die
-# @CODE
-
-if [[ -z ${_LTPRUNE_ECLASS} ]]; then
-
-case ${EAPI:-0} in
-	0|1|2|3|4|5|6)
-		;;
-	*)
-		die "${ECLASS}: banned in EAPI=${EAPI}; use 'find' instead";;
-esac
-
-inherit toolchain-funcs
-
-# @FUNCTION: prune_libtool_files
-# @USAGE: [--all|--modules]
-# @DESCRIPTION:
-# Locate unnecessary libtool files (.la) and libtool static archives
-# (.a) and remove them from installation image.
-#
-# By default, .la files are removed whenever the static linkage can
-# either be performed using pkg-config or doesn't introduce additional
-# flags.
-#
-# If '--modules' argument is passed, .la files for modules (plugins) are
-# removed as well. This is usually useful when the package installs
-# plugins and the plugin loader does not use .la files.
-#
-# If '--all' argument is passed, all .la files are removed without
-# performing any heuristic on them. You shouldn't ever use that,
-# and instead report a bug in the algorithm instead.
-#
-# The .a files are only removed whenever corresponding .la files state
-# that they should not be linked to, i.e. whenever these files
-# correspond to plugins.
-#
-# Note: if your package installs both static libraries and .pc files
-# which use variable substitution for -l flags, you need to add
-# pkg-config to your DEPEND.
-prune_libtool_files() {
-	debug-print-function ${FUNCNAME} "$@"
-
-	local removing_all removing_modules opt
-	for opt; do
-		case "${opt}" in
-			--all)
-				removing_all=1
-				removing_modules=1
-				;;
-			--modules)
-				removing_modules=1
-				;;
-			*)
-				die "Invalid argument to ${FUNCNAME}(): ${opt}"
-		esac
-	done
-
-	local f
-	local queue=()
-	while IFS= read -r -d '' f; do # for all .la files
-		local archivefile=${f/%.la/.a}
-
-		# The following check is done by libtool itself.
-		# It helps us avoid removing random files which match '*.la',
-		# see bug #468380.
-		if ! sed -n -e '/^# Generated by .*libtool/q0;4q1' "${f}"; then
-			continue
-		fi
-
-		[[ ${f} != ${archivefile} ]] || die 'regex sanity check failed'
-		local reason= pkgconfig_scanned=
-		local snotlink=$(sed -n -e 's:^shouldnotlink=::p' "${f}")
-
-		if [[ ${snotlink} == yes ]]; then
-
-			# Remove static libs we're not supposed to link against.
-			if [[ -f ${archivefile} ]]; then
-				einfo "Removing unnecessary ${archivefile#${D%/}} (static plugin)"
-				queue+=( "${archivefile}" )
-			fi
-
-			# The .la file may be used by a module loader, so avoid removing it
-			# unless explicitly requested.
-			if [[ ${removing_modules} ]]; then
-				reason='module'
-			fi
-
-		else
-
-			# Remove .la files when:
-			# - user explicitly wants us to remove all .la files,
-			# - respective static archive doesn't exist,
-			# - they are covered by a .pc file already,
-			# - they don't provide any new information (no libs & no flags).
-
-			if [[ ${removing_all} ]]; then
-				reason='requested'
-			elif [[ ! -f ${archivefile} ]]; then
-				reason='no static archive'
-			elif [[ ! $(sed -nre \
-					"s/^(dependency_libs|inherited_linker_flags)='(.*)'$/\2/p" \
-					"${f}") ]]; then
-				reason='no libs & flags'
-			else
-				if [[ ! ${pkgconfig_scanned} ]]; then
-					# Create a list of all .pc-covered libs.
-					local pc_libs=()
-					if [[ ! ${removing_all} ]]; then
-						local pc
-						local tf=${T}/prune-lt-files.pc
-						local pkgconf=$(tc-getPKG_CONFIG)
-
-						while IFS= read -r -d '' pc; do # for all .pc files
-							local arg libs
-
-							# Use pkg-config if available (and works),
-							# fallback to sed.
-							if ${pkgconf} --exists "${pc}" &>/dev/null; then
-								sed -e '/^Requires:/d' "${pc}" > "${tf}"
-								libs=$(${pkgconf} --libs "${tf}")
-							else
-								libs=$(sed -ne 's/^Libs://p' "${pc}")
-							fi
-
-							for arg in ${libs}; do
-								if [[ ${arg} == -l* ]]; then
-									if [[ ${arg} == '*$*' ]]; then
-										eerror "${FUNCNAME}: variable substitution likely failed in ${pc}"
-										eerror "(arg: ${arg})"
-										eerror "Most likely, you need to add virtual/pkgconfig to DEPEND."
-										die "${FUNCNAME}: unsubstituted variable found in .pc"
-									fi
-
-									pc_libs+=( lib${arg#-l}.la )
-								fi
-							done
-						done < <(find "${D}" -type f -name '*.pc' -print0)
-
-						rm -f "${tf}"
-					fi
-
-					pkgconfig_scanned=1
-				fi # pkgconfig_scanned
-
-				has "${f##*/}" "${pc_libs[@]}" && reason='covered by .pc'
-			fi # removal due to .pc
-
-		fi # shouldnotlink==no
-
-		if [[ ${reason} ]]; then
-			einfo "Removing unnecessary ${f#${D%/}} (${reason})"
-			queue+=( "${f}" )
-		fi
-	done < <(find "${D}" -xtype f -name '*.la' -print0)
-
-	if [[ ${queue[@]} ]]; then
-		rm -f "${queue[@]}"
-	fi
-}
-
-_LTPRUNE_ECLASS=1
-fi #_LTPRUNE_ECLASS
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-15 17:48 Andreas Sturmlechner
  0 siblings, 0 replies; 6663+ messages in thread
From: Andreas Sturmlechner @ 2024-08-15 17:48 UTC (permalink / raw
  To: gentoo-commits
commit:     da715b976410cb437456272c921ccd4589b4fbe8
Author:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
AuthorDate: Mon Jun 24 20:53:44 2024 +0000
Commit:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
CommitDate: Thu Aug 15 17:46:37 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=da715b97
cmake.eclass: Set CMAKE_TLS_VERIFY=ON
Closes: https://bugs.gentoo.org/927160
Signed-off-by: Andreas Sturmlechner <asturm <AT> gentoo.org>
 eclass/cmake.eclass | 1 +
 1 file changed, 1 insertion(+)
diff --git a/eclass/cmake.eclass b/eclass/cmake.eclass
index b7852355b90b..db31320c339d 100644
--- a/eclass/cmake.eclass
+++ b/eclass/cmake.eclass
@@ -542,6 +542,7 @@ cmake_src_configure() {
 		set(BUILD_SHARED_LIBS ON CACHE BOOL "")
 		set(Python3_FIND_UNVERSIONED_NAMES FIRST CACHE STRING "")
 		set(CMAKE_DISABLE_PRECOMPILE_HEADERS ON CACHE BOOL "")
+		set(CMAKE_TLS_VERIFY ON CACHE BOOL "")
 	_EOF_
 
 	if [[ -n ${_ECM_ECLASS} ]]; then
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-15 17:48 Andreas Sturmlechner
  0 siblings, 0 replies; 6663+ messages in thread
From: Andreas Sturmlechner @ 2024-08-15 17:48 UTC (permalink / raw
  To: gentoo-commits
commit:     60a395b82ac3d490ea94fea3721fac9b041e3cd0
Author:     Nic Boet <nic <AT> boet <DOT> cc>
AuthorDate: Thu Feb  1 03:48:21 2024 +0000
Commit:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
CommitDate: Thu Aug 15 17:46:36 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=60a395b8
cmake.eclass: bug 811486 escape find patterns
Modify cmake_src_prepare to qoute escape filenames
within the find search patterns
This resolves build issues with some EAPI 7 packages,
i.e. sys-fs/dislocker via catalyst
Bug: https://bugs.gentoo.org/811486
Signed-off-by: Nic Boet <nic <AT> boet.cc>
Closes: https://github.com/gentoo/gentoo/pull/35125
Signed-off-by: Andreas Sturmlechner <asturm <AT> gentoo.org>
 eclass/cmake.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/cmake.eclass b/eclass/cmake.eclass
index de43bd017768..b7852355b90b 100644
--- a/eclass/cmake.eclass
+++ b/eclass/cmake.eclass
@@ -388,7 +388,7 @@ cmake_src_prepare() {
 	local name
 	for name in "${modules_list[@]}" ; do
 		if [[ ${EAPI} == 7 ]]; then
-			find "${S}" -name ${name}.cmake -exec rm -v {} + || die
+			find "${S}" -name "${name}.cmake" -exec rm -v {} + || die
 		else
 			find -name "${name}.cmake" -exec rm -v {} + || die
 		fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-15 17:48 Andreas Sturmlechner
  0 siblings, 0 replies; 6663+ messages in thread
From: Andreas Sturmlechner @ 2024-08-15 17:48 UTC (permalink / raw
  To: gentoo-commits
commit:     796a1fc61893f37aa9158ccb2ce4f038e1d1a4db
Author:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
AuthorDate: Tue Aug 13 20:18:36 2024 +0000
Commit:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
CommitDate: Thu Aug 15 17:46:50 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=796a1fc6
cmake.eclass: If inherited from ecm.eclass, set ECM_DISABLE_GIT
Signed-off-by: Andreas Sturmlechner <asturm <AT> gentoo.org>
 eclass/cmake.eclass | 1 +
 1 file changed, 1 insertion(+)
diff --git a/eclass/cmake.eclass b/eclass/cmake.eclass
index 8d60116f7a93..8079a5cb037b 100644
--- a/eclass/cmake.eclass
+++ b/eclass/cmake.eclass
@@ -550,6 +550,7 @@ cmake_src_configure() {
 		cat >> ${common_config} <<- _EOF_ || die
 			set(ECM_DISABLE_QMLPLUGINDUMP ON CACHE BOOL "")
 			set(ECM_DISABLE_APPSTREAMTEST ON CACHE BOOL "")
+			set(ECM_DISABLE_GIT ON CACHE BOOL "")
 		_EOF_
 	fi
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-15 17:48 Andreas Sturmlechner
  0 siblings, 0 replies; 6663+ messages in thread
From: Andreas Sturmlechner @ 2024-08-15 17:48 UTC (permalink / raw
  To: gentoo-commits
commit:     882d006f2a945587d25fc5e5b8cc520febfe7e9f
Author:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
AuthorDate: Tue Aug 13 20:39:06 2024 +0000
Commit:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
CommitDate: Thu Aug 15 17:46:50 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=882d006f
ecm.eclass: For kde.org projects, try to rename metainfo file real hard
- detect if we are inheriting kde.org.eclass
- detect if package name is not the same as upstream name (KDE_ORG_NAME)
- iterate through "${ED}"/usr/share/metainfo/
- if file contains KDE_ORG_NAME or similar, rename that to ${PN}${SLOT/0*/}
- otherwise, prepend "${PN}${SLOT/0*/}-" after ^org.kde.
Notably, this does not (yet?) trigger if a package ${PN} == ${KDE_ORG_NAME}
but different SLOTs. Should we just do that all the time?
Signed-off-by: Andreas Sturmlechner <asturm <AT> gentoo.org>
 eclass/ecm.eclass | 30 ++++++++++++++++++++++++++++++
 1 file changed, 30 insertions(+)
diff --git a/eclass/ecm.eclass b/eclass/ecm.eclass
index 3d3b9328269d..c8731b8c0cff 100644
--- a/eclass/ecm.eclass
+++ b/eclass/ecm.eclass
@@ -649,6 +649,9 @@ ecm_src_test() {
 # Wrapper for cmake_src_install. Drops executable bit from .desktop files
 # installed inside /usr/share/applications. This is set by cmake when install()
 # is called in PROGRAM form, as seen in many kde.org projects.
+# In case kde.org.eclass is detected, in case KDE_ORG_NAME != PN, tries real
+# hard to detect, then rename, metainfo.xml appdata files to something unique
+# including SLOT if else than "0" (basically KDE_ORG_NAME -> PN+SLOT).
 ecm_src_install() {
 	debug-print-function ${FUNCNAME} "$@"
 
@@ -664,6 +667,33 @@ ecm_src_install() {
 			fi
 		done
 	fi
+
+	mv_metainfo() {
+		if [[ -f ${1} ]]; then
+			mv -v ${1} ${1/${2}/${3}} || die
+		fi
+	}
+
+	if [[ -n ${_KDE_ORG_ECLASS} && -d "${ED}"/usr/share/metainfo/ ]]; then
+		if [[ ${KDE_ORG_NAME} != ${PN} ]]; then
+			local ecm_metainfo
+			pushd "${ED}"/usr/share/metainfo/ > /dev/null || die
+			for ecm_metainfo in find * -type f -iname "*metainfo.xml"; do
+				case ${ecm_metainfo} in
+					*${KDE_ORG_NAME}*)
+						mv_metainfo ${ecm_metainfo} ${KDE_ORG_NAME} ${PN}${SLOT/0*/}
+						;;
+					*${KDE_ORG_NAME/-/_}*)
+						mv_metainfo ${ecm_metainfo} ${KDE_ORG_NAME/-/_} ${PN}${SLOT/0*/}
+						;;
+					org.kde.*)
+						mv_metainfo ${ecm_metainfo} "org.kde." "org.kde.${PN}${SLOT/0*/}-"
+						;;
+				esac
+			done
+			popd > /dev/null || die
+		fi
+	fi
 }
 
 # @FUNCTION: ecm_pkg_preinst
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-15 17:48 Andreas Sturmlechner
  0 siblings, 0 replies; 6663+ messages in thread
From: Andreas Sturmlechner @ 2024-08-15 17:48 UTC (permalink / raw
  To: gentoo-commits
commit:     689be1a4afcc8222f7d10f822789d2e1676d0829
Author:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
AuthorDate: Mon Jun 24 20:59:33 2024 +0000
Commit:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
CommitDate: Thu Aug 15 17:46:44 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=689be1a4
cmake.eclass: Set CMAKE_COMPILE_WARNING_AS_ERROR=OFF
Closes: https://bugs.gentoo.org/926121
Signed-off-by: Andreas Sturmlechner <asturm <AT> gentoo.org>
 eclass/cmake.eclass | 1 +
 1 file changed, 1 insertion(+)
diff --git a/eclass/cmake.eclass b/eclass/cmake.eclass
index db31320c339d..c98608d7b5bb 100644
--- a/eclass/cmake.eclass
+++ b/eclass/cmake.eclass
@@ -543,6 +543,7 @@ cmake_src_configure() {
 		set(Python3_FIND_UNVERSIONED_NAMES FIRST CACHE STRING "")
 		set(CMAKE_DISABLE_PRECOMPILE_HEADERS ON CACHE BOOL "")
 		set(CMAKE_TLS_VERIFY ON CACHE BOOL "")
+		set(CMAKE_COMPILE_WARNING_AS_ERROR OFF CACHE BOOL "")
 	_EOF_
 
 	if [[ -n ${_ECM_ECLASS} ]]; then
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-15 17:48 Andreas Sturmlechner
  0 siblings, 0 replies; 6663+ messages in thread
From: Andreas Sturmlechner @ 2024-08-15 17:48 UTC (permalink / raw
  To: gentoo-commits
commit:     43ecd506f0393ce2cc5e2bb0c19961923ee35a6f
Author:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
AuthorDate: Tue Aug 13 20:06:40 2024 +0000
Commit:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
CommitDate: Thu Aug 15 17:46:49 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=43ecd506
cmake.eclass: If inherited from ecm.eclass, set ECM_DISABLE_APPSTREAMTEST
Signed-off-by: Andreas Sturmlechner <asturm <AT> gentoo.org>
 eclass/cmake.eclass | 5 ++++-
 1 file changed, 4 insertions(+), 1 deletion(-)
diff --git a/eclass/cmake.eclass b/eclass/cmake.eclass
index c98608d7b5bb..8d60116f7a93 100644
--- a/eclass/cmake.eclass
+++ b/eclass/cmake.eclass
@@ -547,7 +547,10 @@ cmake_src_configure() {
 	_EOF_
 
 	if [[ -n ${_ECM_ECLASS} ]]; then
-		echo 'set(ECM_DISABLE_QMLPLUGINDUMP ON CACHE BOOL "")' >> "${common_config}" || die
+		cat >> ${common_config} <<- _EOF_ || die
+			set(ECM_DISABLE_QMLPLUGINDUMP ON CACHE BOOL "")
+			set(ECM_DISABLE_APPSTREAMTEST ON CACHE BOOL "")
+		_EOF_
 	fi
 
 	# See bug 689410
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-15 17:48 Andreas Sturmlechner
  0 siblings, 0 replies; 6663+ messages in thread
From: Andreas Sturmlechner @ 2024-08-15 17:48 UTC (permalink / raw
  To: gentoo-commits
commit:     5fc62d4f396d20ed67cf8455f447f2b9ee03ff4a
Author:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
AuthorDate: Thu Aug 15 08:41:14 2024 +0000
Commit:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
CommitDate: Thu Aug 15 17:46:52 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=5fc62d4f
gear.kde.org.eclass: Add post-24.05 release SLOT=5 blocklist
Signed-off-by: Andreas Sturmlechner <asturm <AT> gentoo.org>
 eclass/gear.kde.org.eclass | 24 ++++++++++++++++++++++++
 1 file changed, 24 insertions(+)
diff --git a/eclass/gear.kde.org.eclass b/eclass/gear.kde.org.eclass
index c063ccc2d7c5..3f8126dd1c01 100644
--- a/eclass/gear.kde.org.eclass
+++ b/eclass/gear.kde.org.eclass
@@ -262,4 +262,28 @@ if $(ver_test -gt 24.04.75); then
 	esac
 fi
 
+# list of applications ported to KF6 post-24.05 in SLOT=6 having to block SLOT=5
+if $(ver_test -gt 24.07.75); then
+	case ${PN} in
+		k3b | \
+		kde-dev-scripts | \
+		kdesdk-thumbnailers | \
+		kdevelop | \
+		kdevelop-php | \
+		kdevelop-python | \
+		kgraphviewer | \
+		kimagemapeditor | \
+		kmplot | \
+		kompare | \
+		krdc | \
+		libkomparediff2 | \
+		lokalize | \
+		massif-visualizer | \
+		poxml | \
+		skanlite)
+			RDEPEND+=" !${CATEGORY}/${PN}:5" ;;
+		*) ;;
+	esac
+fi
+
 fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-15 17:48 Andreas Sturmlechner
  0 siblings, 0 replies; 6663+ messages in thread
From: Andreas Sturmlechner @ 2024-08-15 17:48 UTC (permalink / raw
  To: gentoo-commits
commit:     0e7a553e92f53af7aaf509101ba347c54858b75c
Author:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
AuthorDate: Thu Aug 15 08:23:53 2024 +0000
Commit:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
CommitDate: Thu Aug 15 17:46:51 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=0e7a553e
gear.kde.org.eclass: Cleanup >=24.01.75 SLOT 5 blocklist
Dropping kde-apps/kdegraphics-mobipocket, no file collision in the first place.
Dropping kde-apps/thumbnailers after it was turned into a metapackage.
Signed-off-by: Andreas Sturmlechner <asturm <AT> gentoo.org>
 eclass/gear.kde.org.eclass | 2 --
 1 file changed, 2 deletions(-)
diff --git a/eclass/gear.kde.org.eclass b/eclass/gear.kde.org.eclass
index e0d0a8640b5b..c063ccc2d7c5 100644
--- a/eclass/gear.kde.org.eclass
+++ b/eclass/gear.kde.org.eclass
@@ -132,7 +132,6 @@ if $(ver_test -gt 24.01.75); then
 		kde-dev-utils | \
 		kdebugsettings | \
 		kdeconnect | \
-		kdegraphics-mobipocket | \
 		kdenetwork-filesharing | \
 		kdenlive | \
 		kdepim-addons | \
@@ -243,7 +242,6 @@ if $(ver_test -gt 24.01.75); then
 		spectacle | \
 		svgpart | \
 		sweeper | \
-		thumbnailers | \
 		yakuake | \
 		zanshin)
 			RDEPEND+=" !${CATEGORY}/${PN}:5" ;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-15 20:01 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-08-15 20:01 UTC (permalink / raw
  To: gentoo-commits
commit:     740d0c3619f76e9b3a7beffc47861d48ae826012
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Thu Aug 15 19:16:28 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Thu Aug 15 20:01:29 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=740d0c36
llvm.org.eclass: Add 20.0.0_pre20240815 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index d1c169264662..4b49d35a542b 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -72,6 +72,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 			_LLVM_SOURCE_TYPE=snapshot
 
 			case ${PV} in
+				20.0.0_pre20240815)
+					EGIT_COMMIT=db8ef6188cbbe2125e6d60bdef77a535105772df
+					;;
 				20.0.0_pre20240808)
 					EGIT_COMMIT=fd7d7882e7fa5a38d4bfde426120d4663718beb4
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-15 21:18 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-08-15 21:18 UTC (permalink / raw
  To: gentoo-commits
commit:     116f54058abd4fa4a5b3c16ee49a99df11883a45
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Aug 15 21:13:28 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Aug 15 21:18:23 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=116f5405
go-env.eclass: workaround debug info issues
Go can't handle some DWARF produced by GCC but nobody's been able
to produce a simple testcase for it, so add a workaround where we replace
-g3 with -g and -ggdb3 with -ggdb for GCC, like Ionen did in Kitty.
Bug: https://bugs.gentoo.org/847991
Bug: https://bugs.gentoo.org/924436
Bug: https://bugs.gentoo.org/924496
Closes: https://bugs.gentoo.org/929219
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/go-env.eclass | 6 ++++++
 1 file changed, 6 insertions(+)
diff --git a/eclass/go-env.eclass b/eclass/go-env.eclass
index be131133113b..a4394161cb0b 100644
--- a/eclass/go-env.eclass
+++ b/eclass/go-env.eclass
@@ -42,6 +42,12 @@ go-env_set_compile_environment() {
 	# XXX: Hack for checking ICE (bug #912152, gcc PR113204)
 	has_version -b "sys-devel/gcc[debug]" && filter-lto
 
+	# bug #929219
+	if tc-is-gcc ; then
+		replace-flags -g3 -g
+		replace-flags -ggdb3 -ggdb
+	fi
+
 	export CGO_CFLAGS="${CGO_CFLAGS:-$CFLAGS}"
 	export CGO_CPPFLAGS="${CGO_CPPFLAGS:-$CPPFLAGS}"
 	export CGO_CXXFLAGS="${CGO_CXXFLAGS:-$CXXFLAGS}"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-15 21:24 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-08-15 21:24 UTC (permalink / raw
  To: gentoo-commits
commit:     1f754863ff91dc4dca11e6a5217ffd449f39c74c
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Aug 15 21:23:22 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Aug 15 21:24:05 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=1f754863
go-env.eclass: improve debug workaround
Use what Ionen did in x11-terms/kitty to avoid touching flags for
non-Go parts of the build.
Bug: https://bugs.gentoo.org/847991
Bug: https://bugs.gentoo.org/924436
Bug: https://bugs.gentoo.org/924496
Bug: https://bugs.gentoo.org/929219
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/go-env.eclass | 16 ++++++++++------
 1 file changed, 10 insertions(+), 6 deletions(-)
diff --git a/eclass/go-env.eclass b/eclass/go-env.eclass
index a4394161cb0b..11fdf943e774 100644
--- a/eclass/go-env.eclass
+++ b/eclass/go-env.eclass
@@ -42,16 +42,20 @@ go-env_set_compile_environment() {
 	# XXX: Hack for checking ICE (bug #912152, gcc PR113204)
 	has_version -b "sys-devel/gcc[debug]" && filter-lto
 
-	# bug #929219
-	if tc-is-gcc ; then
-		replace-flags -g3 -g
-		replace-flags -ggdb3 -ggdb
-	fi
-
 	export CGO_CFLAGS="${CGO_CFLAGS:-$CFLAGS}"
 	export CGO_CPPFLAGS="${CGO_CPPFLAGS:-$CPPFLAGS}"
 	export CGO_CXXFLAGS="${CGO_CXXFLAGS:-$CXXFLAGS}"
 	export CGO_LDFLAGS="${CGO_LDFLAGS:-$LDFLAGS}"
+
+	# bug #929219
+	if tc-is-gcc ; then
+		CGO_CFLAGS=$(
+			CFLAGS=${CGO_CFLAGS}
+			replace-flags -g3 -g
+			replace-flags -ggdb3 -ggdb
+			printf %s "${CFLAGS}"
+		)
+	fi
 }
 
 # @FUNCTION: go-env_goos
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-16  5:55 Arthur Zamarin
  0 siblings, 0 replies; 6663+ messages in thread
From: Arthur Zamarin @ 2024-08-16  5:55 UTC (permalink / raw
  To: gentoo-commits
commit:     1533b604e787b2dfdced75dd5b92b50755f54fb7
Author:     Arthur Zamarin <arthurzam <AT> gentoo <DOT> org>
AuthorDate: Thu Aug 15 17:56:32 2024 +0000
Commit:     Arthur Zamarin <arthurzam <AT> gentoo <DOT> org>
CommitDate: Fri Aug 16 05:55:35 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=1533b604
rust-toolchain.eclass: hide glibc bins behind elibc_glibc?
I'm starting to add various bootstrap binaries for musl, so might as
well protect all downloads of glibc only behind "elibc_glibc?" to be
safe just in case.
Signed-off-by: Arthur Zamarin <arthurzam <AT> gentoo.org>
 eclass/rust-toolchain.eclass | 20 +++++++++-----------
 1 file changed, 9 insertions(+), 11 deletions(-)
diff --git a/eclass/rust-toolchain.eclass b/eclass/rust-toolchain.eclass
index 469479b849b3..6ad5c811f6c0 100644
--- a/eclass/rust-toolchain.eclass
+++ b/eclass/rust-toolchain.eclass
@@ -91,29 +91,27 @@ rust_arch_uri() {
 rust_all_arch_uris()
 {
 	echo "
-	abi_x86_32? ( $(rust_arch_uri i686-unknown-linux-gnu "$@") )
+	abi_x86_32? ( elibc_glibc? ( $(rust_arch_uri i686-unknown-linux-gnu "$@") ) )
 	abi_x86_64? (
 		elibc_glibc? ( $(rust_arch_uri x86_64-unknown-linux-gnu  "$@") )
 		elibc_musl?  ( $(rust_arch_uri x86_64-unknown-linux-musl "$@") )
 	)
-	arm? (
+	arm? ( elibc_glibc? (
 		$(rust_arch_uri arm-unknown-linux-gnueabi     "$@")
 		$(rust_arch_uri arm-unknown-linux-gnueabihf   "$@")
 		$(rust_arch_uri armv7-unknown-linux-gnueabihf "$@")
-	)
+	) )
 	arm64? (
 		elibc_glibc? ( $(rust_arch_uri aarch64-unknown-linux-gnu  "$@") )
 		elibc_musl?  ( $(rust_arch_uri aarch64-unknown-linux-musl "$@") )
 	)
-	ppc? ( $(rust_arch_uri powerpc-unknown-linux-gnu "$@") )
+	ppc? ( elibc_glibc? ( $(rust_arch_uri powerpc-unknown-linux-gnu "$@") ) )
 	ppc64? (
-		big-endian?  ( $(rust_arch_uri powerpc64-unknown-linux-gnu   "$@") )
-		!big-endian? ( $(rust_arch_uri powerpc64le-unknown-linux-gnu "$@") )
-	)
-	riscv? (
-		elibc_glibc? ( $(rust_arch_uri riscv64gc-unknown-linux-gnu "$@") )
+		big-endian?  ( elibc_glibc? ( $(rust_arch_uri powerpc64-unknown-linux-gnu   "$@") ) )
+		!big-endian? ( elibc_glibc? ( $(rust_arch_uri powerpc64le-unknown-linux-gnu "$@") ) )
 	)
-	s390?  ( $(rust_arch_uri s390x-unknown-linux-gnu     "$@") )
+	riscv? ( elibc_glibc? ( $(rust_arch_uri riscv64gc-unknown-linux-gnu "$@") ) )
+	s390?  ( elibc_glibc? ( $(rust_arch_uri s390x-unknown-linux-gnu     "$@") ) )
 	"
 
 	# Upstream did not gain support for loong until v1.71.0.
@@ -122,7 +120,7 @@ rust_all_arch_uris()
 	local arg_version="${1##*-}"
 	arg_version="${arg_version:-$PV}"
 	if ver_test "${arg_version}" -ge 1.71.0; then
-		echo "loong? ( $(rust_arch_uri loongarch64-unknown-linux-gnu "$@") )"
+		echo "loong? ( elibc_glibc? ( $(rust_arch_uri loongarch64-unknown-linux-gnu "$@") ) )"
 	fi
 
 	# until https://github.com/rust-lang/rust/pull/113274 is resolved, there
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-16 10:15 Arthur Zamarin
  0 siblings, 0 replies; 6663+ messages in thread
From: Arthur Zamarin @ 2024-08-16 10:15 UTC (permalink / raw
  To: gentoo-commits
commit:     99889ce76e1f6ed0ec5cb4e3db3a09dce8de1f05
Author:     Arthur Zamarin <arthurzam <AT> gentoo <DOT> org>
AuthorDate: Fri Aug 16 10:04:42 2024 +0000
Commit:     Arthur Zamarin <arthurzam <AT> gentoo <DOT> org>
CommitDate: Fri Aug 16 10:14:35 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=99889ce7
rust-toolchain.eclass: transform sparc64 rust_abi
Signed-off-by: Arthur Zamarin <arthurzam <AT> gentoo.org>
 eclass/rust-toolchain.eclass | 1 +
 1 file changed, 1 insertion(+)
diff --git a/eclass/rust-toolchain.eclass b/eclass/rust-toolchain.eclass
index 6ad5c811f6c0..89bca88b9e6b 100644
--- a/eclass/rust-toolchain.eclass
+++ b/eclass/rust-toolchain.eclass
@@ -51,6 +51,7 @@ rust_abi() {
 		riscv64*gnu)      echo riscv64gc-unknown-linux-gnu;;
 		riscv64*musl)     echo riscv64gc-unknown-linux-musl;;
 		s390x*)           echo s390x-unknown-linux-gnu;;
+		sparc64*gnu)      echo sparc64-unknown-linux-gnu;;
 		x86_64*gnu)       echo x86_64-unknown-linux-gnu;;
 		x86_64*musl)      echo x86_64-unknown-linux-musl;;
 		*)                echo ${CTARGET};;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-16 17:21 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-08-16 17:21 UTC (permalink / raw
  To: gentoo-commits
commit:     83344561685a21cf36b2349b94f3a579537a506d
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Aug 16 16:42:19 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Aug 16 17:21:22 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=83344561
toolchain-funcs.eclass: tc-ld-force-bfd: mangle CFLAGS, CXXFLAGS too
This is kind of related to what Ionen mentioned at https://github.com/gentoo/gentoo/pull/28355#discussion_r1033001927
but a bit different.
Makefile rules are inconsistent, as are users, and -fuse-ld= might appear
in C{,XX}FLAGS, not just LDFLAGS.
Append -fuse-ld=bfd there too if asked to force bfd. This might
cause problems with Clang because the argument is unused. See the
mess in ddba1d149e82dba88b72f992729ad4158f640e32.
Not having flag-o-matic here makes things a bit awkward. Let's try
the naive approach first because it seemed OK for me with Clang
with a quick test.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain-funcs.eclass | 2 ++
 1 file changed, 2 insertions(+)
diff --git a/eclass/toolchain-funcs.eclass b/eclass/toolchain-funcs.eclass
index 5c15f4fb93a1..bc1fb064fc45 100644
--- a/eclass/toolchain-funcs.eclass
+++ b/eclass/toolchain-funcs.eclass
@@ -615,6 +615,8 @@ tc-ld-force-bfd() {
 
 	# Set up LDFLAGS to select bfd based on the gcc / clang version.
 	if tc-is-gcc || tc-is-clang ; then
+		export CFLAGS="${CFLAGS} -fuse-ld=bfd"
+		export CXXFLAGS="${CXXFLAGS} -fuse-ld=bfd"
 		export LDFLAGS="${LDFLAGS} -fuse-ld=bfd"
 	fi
 }
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-16 17:21 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-08-16 17:21 UTC (permalink / raw
  To: gentoo-commits
commit:     67d76384107dd15f3fa74e4773882fd581c81e40
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Nov 21 04:05:31 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Aug 16 17:21:18 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=67d76384
toolchain-funcs.eclass: add tc-ld-is-mold
For completeness.
Bug: https://bugs.gentoo.org/877539
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain-funcs.eclass | 34 ++++++++++++++++++++++++++++++++++
 1 file changed, 34 insertions(+)
diff --git a/eclass/toolchain-funcs.eclass b/eclass/toolchain-funcs.eclass
index 121280a7f11f..d54175cf992f 100644
--- a/eclass/toolchain-funcs.eclass
+++ b/eclass/toolchain-funcs.eclass
@@ -548,6 +548,40 @@ tc-ld-is-lld() {
 	return 1
 }
 
+
+# @FUNCTION: tc-ld-is-mold
+# @USAGE: [toolchain prefix]
+# @DESCRIPTION:
+# Return true if the current linker is set to mold.
+tc-ld-is-mold() {
+	local out
+
+	# Ensure ld output is in English.
+	local -x LC_ALL=C
+
+	# First check the linker directly.
+	out=$($(tc-getLD "$@") --version 2>&1)
+	if [[ ${out} == *"mold"* ]] ; then
+		return 0
+	fi
+
+	# Then see if they're selecting mold via compiler flags.
+	# Note: We're assuming they're using LDFLAGS to hold the
+	# options and not CFLAGS/CXXFLAGS.
+	local base="${T}/test-tc-mold"
+	cat <<-EOF > "${base}.c"
+	int main(void) { return 0; }
+	EOF
+	out=$($(tc-getCC "$@") ${CFLAGS} ${CPPFLAGS} ${LDFLAGS} -Wl,--version "${base}.c" -o "${base}" 2>&1)
+	rm -f "${base}"*
+	if [[ ${out} == *"mold"* ]] ; then
+		return 0
+	fi
+
+	# No mold here!
+	return 1
+}
+
 # @FUNCTION: tc-ld-disable-gold
 # @USAGE: [toolchain prefix]
 # @DESCRIPTION:
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-16 17:21 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-08-16 17:21 UTC (permalink / raw
  To: gentoo-commits
commit:     3c2c0e0c0e7630ff0df17728f40116a95c1f52d4
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Aug 16 16:18:39 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Aug 16 17:21:20 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=3c2c0e0c
toolchain-funcs.eclass: use generic filename for linker test
At https://github.com/gentoo/gentoo/pull/28355#discussion_r1089883885, juippis
points out that for mold, the test might be confused. Let's consistently
use 'linker' instead.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain-funcs.eclass | 8 ++++----
 1 file changed, 4 insertions(+), 4 deletions(-)
diff --git a/eclass/toolchain-funcs.eclass b/eclass/toolchain-funcs.eclass
index 2d65c3fdc146..563eb5e191cf 100644
--- a/eclass/toolchain-funcs.eclass
+++ b/eclass/toolchain-funcs.eclass
@@ -466,7 +466,7 @@ tc-ld-is-bfd() {
 	# Then see if they're selecting bfd via compiler flags.
 	# Note: We're assuming they're using LDFLAGS to hold the
 	# options and not CFLAGS/CXXFLAGS.
-	local base="${T}/test-tc-bfd"
+	local base="${T}/test-tc-linker"
 	cat <<-EOF > "${base}.c"
 	int main(void) { return 0; }
 	EOF
@@ -501,7 +501,7 @@ tc-ld-is-gold() {
 	# Then see if they're selecting gold via compiler flags.
 	# Note: We're assuming they're using LDFLAGS to hold the
 	# options and not CFLAGS/CXXFLAGS.
-	local base="${T}/test-tc-gold"
+	local base="${T}/test-tc-linker"
 	cat <<-EOF > "${base}.c"
 	int main(void) { return 0; }
 	EOF
@@ -534,7 +534,7 @@ tc-ld-is-lld() {
 	# Then see if they're selecting lld via compiler flags.
 	# Note: We're assuming they're using LDFLAGS to hold the
 	# options and not CFLAGS/CXXFLAGS.
-	local base="${T}/test-tc-lld"
+	local base="${T}/test-tc-linker"
 	cat <<-EOF > "${base}.c"
 	int main(void) { return 0; }
 	EOF
@@ -568,7 +568,7 @@ tc-ld-is-mold() {
 	# Then see if they're selecting mold via compiler flags.
 	# Note: We're assuming they're using LDFLAGS to hold the
 	# options and not CFLAGS/CXXFLAGS.
-	local base="${T}/test-tc-mold"
+	local base="${T}/test-tc-linker"
 	cat <<-EOF > "${base}.c"
 	int main(void) { return 0; }
 	EOF
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-16 17:21 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-08-16 17:21 UTC (permalink / raw
  To: gentoo-commits
commit:     2d141fdf8928615cb394cc7da03c2299a69c612e
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Nov 21 04:02:47 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Aug 16 17:21:19 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=2d141fdf
toolchain-funcs.eclass: fix tc-ld-force-bfd returning early for unknown linkers
For say, mold, until now tc-ld-force-bfd actually didn't work, because
it bailed early if not lld and not gold (assuming the linker was therefore bfd).
Closes: https://bugs.gentoo.org/877539
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain-funcs.eclass | 5 ++---
 1 file changed, 2 insertions(+), 3 deletions(-)
diff --git a/eclass/toolchain-funcs.eclass b/eclass/toolchain-funcs.eclass
index d54175cf992f..da8c24257ae0 100644
--- a/eclass/toolchain-funcs.eclass
+++ b/eclass/toolchain-funcs.eclass
@@ -594,11 +594,10 @@ tc-ld-disable-gold() {
 # @FUNCTION: tc-ld-force-bfd
 # @USAGE: [toolchain prefix]
 # @DESCRIPTION:
-# If the gold or lld linker is currently selected, configure the compilation
+# If a linker other than bfd is currently selected, configure the compilation
 # settings so that we use the bfd linker instead.
 tc-ld-force-bfd() {
-	if ! tc-ld-is-gold "$@" && ! tc-ld-is-lld "$@" ; then
-		# They aren't using gold or lld, so nothing to do!
+	if tc-ld-is-bfd "$@" ; then
 		return
 	fi
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-16 17:21 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-08-16 17:21 UTC (permalink / raw
  To: gentoo-commits
commit:     87168789d59316975dc42b65a198babfbe816192
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Aug 16 17:01:32 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Aug 16 17:21:21 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=87168789
toolchain-funcs.eclass: _tc-has-openmp: tweak style a bit
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain-funcs.eclass | 5 +++--
 1 file changed, 3 insertions(+), 2 deletions(-)
diff --git a/eclass/toolchain-funcs.eclass b/eclass/toolchain-funcs.eclass
index 563eb5e191cf..5c15f4fb93a1 100644
--- a/eclass/toolchain-funcs.eclass
+++ b/eclass/toolchain-funcs.eclass
@@ -632,8 +632,9 @@ _tc-has-openmp() {
 		int nthreads, tid, ret = 0;
 		#pragma omp parallel private(nthreads, tid)
 		{
-		tid = omp_get_thread_num();
-		nthreads = omp_get_num_threads(); ret += tid + nthreads;
+			tid = omp_get_thread_num();
+			nthreads = omp_get_num_threads();
+			ret += tid + nthreads;
 		}
 		return ret;
 	}
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-16 17:21 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-08-16 17:21 UTC (permalink / raw
  To: gentoo-commits
commit:     2283662d49266d652f171cd6b75798166a86335b
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Nov 21 03:59:08 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Aug 16 17:21:18 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=2283662d
toolchain-funcs.eclass: add tc-ld-is-bfd
This matches tc-ld-is-gold and tc-ld-is-lld.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain-funcs.eclass | 35 +++++++++++++++++++++++++++++++++++
 1 file changed, 35 insertions(+)
diff --git a/eclass/toolchain-funcs.eclass b/eclass/toolchain-funcs.eclass
index 50eb310b4bf1..121280a7f11f 100644
--- a/eclass/toolchain-funcs.eclass
+++ b/eclass/toolchain-funcs.eclass
@@ -447,6 +447,41 @@ econf_build() {
 	tc-env_build econf_env "$@"
 }
 
+# @FUNCTION: tc-ld-is-bfd
+# @USAGE: [toolchain prefix]
+# @DESCRIPTION:
+# Return true if the current linker is set to GNU bfd.
+tc-ld-is-bfd() {
+	local out
+
+	# Ensure ld output is in English.
+	local -x LC_ALL=C
+
+	# First check the linker directly.
+	out=$($(tc-getLD "$@") --version 2>&1)
+	if [[ ${out} != "GNU ld"* ]] ; then
+		return 1
+	fi
+
+	# Then see if they're selecting bfd via compiler flags.
+	# Note: We're assuming they're using LDFLAGS to hold the
+	# options and not CFLAGS/CXXFLAGS.
+	local base="${T}/test-tc-bfd"
+	cat <<-EOF > "${base}.c"
+	int main(void) { return 0; }
+	EOF
+	out=$($(tc-getCC "$@") ${CFLAGS} ${CPPFLAGS} ${LDFLAGS} -Wl,--version "${base}.c" -o "${base}" 2>&1)
+	rm -f "${base}"*
+	if [[ ${out} != "GNU ld"* ]] ; then
+		return 1
+	fi
+
+	# It's bfd!
+	# We use positive logic here unlike tc-ld-is-gold and tc-ld-is-mold
+	# because LD might be bfd even if *FLAGS isn't.
+	return 0
+}
+
 # @FUNCTION: tc-ld-is-gold
 # @USAGE: [toolchain prefix]
 # @DESCRIPTION:
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-16 17:21 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-08-16 17:21 UTC (permalink / raw
  To: gentoo-commits
commit:     20aa5cad2e8e11708e33fb679e760859cf808114
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Nov 21 04:18:44 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Aug 16 17:21:19 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=20aa5cad
toolchain-funcs.eclass: refine tc-ld-force-bfd description
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain-funcs.eclass | 4 +++-
 1 file changed, 3 insertions(+), 1 deletion(-)
diff --git a/eclass/toolchain-funcs.eclass b/eclass/toolchain-funcs.eclass
index da8c24257ae0..61170de616d7 100644
--- a/eclass/toolchain-funcs.eclass
+++ b/eclass/toolchain-funcs.eclass
@@ -595,7 +595,9 @@ tc-ld-disable-gold() {
 # @USAGE: [toolchain prefix]
 # @DESCRIPTION:
 # If a linker other than bfd is currently selected, configure the compilation
-# settings so that we use the bfd linker instead.
+# settings so that we use the bfd linker instead.  This function should not
+# be used for simple underlinking problems.  This function is intended for use
+# when a package is fragile and/or relies on bfd internals.
 tc-ld-force-bfd() {
 	if tc-ld-is-bfd "$@" ; then
 		return
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-16 17:21 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-08-16 17:21 UTC (permalink / raw
  To: gentoo-commits
commit:     65060aed1078b800684e8d39f2dcfac6acd7cf99
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Nov 21 04:13:01 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Aug 16 17:21:20 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=65060aed
toolchain-funcs.eclass: mark tc-ld-disable-gold as deprecated
I don't think this function makes sense in a world with lld and mold.
If there's a bug causing someone to reach for tc-ld-disable-gold,
it falls into one of the following:
1. there's bfdisms (like wine where there's no hope)
   => tc-ld-force-bfd is the correct solution
2. it's a generic problem like underlinking
   => patch the package please, but in extremis or as a temporary workaround,
      tc-ld-force-bfd could be used (but discouraged in this situation)
3. it's a gold bug (i.e. the package is definitely only broken with gold)
   => report the issue upstream or force bfd if the package is truly
      doing something a bit unusual ("the wine case"), but really, given
      gold seems to be rotting away, it doesn't appear likely any bugs
      would get fixed & users shouldn't be enabling it.
I also think tc-ld-disable-gold has been used hastily in the past
for cases like 2, so let's discourage that in deprecating this as well.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain-funcs.eclass | 1 +
 1 file changed, 1 insertion(+)
diff --git a/eclass/toolchain-funcs.eclass b/eclass/toolchain-funcs.eclass
index 61170de616d7..2d65c3fdc146 100644
--- a/eclass/toolchain-funcs.eclass
+++ b/eclass/toolchain-funcs.eclass
@@ -584,6 +584,7 @@ tc-ld-is-mold() {
 
 # @FUNCTION: tc-ld-disable-gold
 # @USAGE: [toolchain prefix]
+# @DEPRECATED: tc-ld-force-bfd
 # @DESCRIPTION:
 # If the gold linker is currently selected, configure the compilation
 # settings so that we use the older bfd linker instead.
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-18 17:44 Arsen Arsenović
  0 siblings, 0 replies; 6663+ messages in thread
From: Arsen Arsenović @ 2024-08-18 17:44 UTC (permalink / raw
  To: gentoo-commits
commit:     92aece1db30a92b83126d8e13dff1ae816cff5b1
Author:     Arsen Arsenović <arsen <AT> gentoo <DOT> org>
AuthorDate: Sun Apr  9 13:03:35 2023 +0000
Commit:     Arsen Arsenović <arsen <AT> gentoo <DOT> org>
CommitDate: Sun Aug 18 17:43:15 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=92aece1d
guile.eclass: new eclass, for guile multi-impl packages
Bug: https://bugs.gentoo.org/689408
Signed-off-by: Arsen Arsenović <arsen <AT> gentoo.org>
 eclass/guile.eclass | 358 ++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 file changed, 358 insertions(+)
diff --git a/eclass/guile.eclass b/eclass/guile.eclass
new file mode 100644
index 000000000000..d487d765e86a
--- /dev/null
+++ b/eclass/guile.eclass
@@ -0,0 +1,358 @@
+# Copyright 2023-2024 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+# @ECLASS: guile.eclass
+# @PROVIDES: guile-utils
+# @MAINTAINER:
+# Gentoo Scheme project <scheme@gentoo.org>
+# @AUTHOR:
+# Author: Arsen Arsenović <arsen@gentoo.org>
+# Inspired by prior work in the Gentoo Python ecosystem.
+# @SUPPORTED_EAPIS: 8
+# @BLURB: Utilities for packages multi-implementation Guile packages.
+# @DESCRIPTION:
+# This eclass facilitates building against many Guile implementations,
+# useful for Guile libraries.  Each ebuild must set GUILE_COMPAT to a
+# list of versions they support, which will be intersected with
+# GUILE_TARGETS to pick which versions to install.  The eclass will
+# generate a GUILE_DEPS based on the configured GUILE_COMPAT, as well as
+# a GUILE_REQUIRED_USE, that the user must use.
+#
+# If the user of the eclass needs some USE flag on Guile itself, they
+# should provide it via GUILE_REQ_USE.
+#
+# This ebuild provides multibuild functionality.  Use guile_foreach_impl
+# to run a given command for each enabled Guile version.  The command
+# provided will be ran in a modified environment, see the description of
+# that function for more details.
+#
+# This package provides some stage functions written assuming a
+# conventional GNU Build System-based Guile library and may or may not
+# work.
+#
+# For each Guile target, a Guile library should have at least compiled
+# .go files in the ccache or %site-ccache-dir.  It must also have
+# corresponding sources installed in %site-dir.
+#
+# If your package has some steps that should only happen for one
+# implementation (e.g. installing a program), you can utilize
+# guile_for_best_impl.
+#
+# Due to http://debbugs.gnu.org/cgi/bugreport.cgi?bug=38112, Guile
+# packages ought to bump their sources before building.  To this end,
+# the src_prepare this eclass provides will call guile_bump_sources of
+# the guile-utils eclass.
+#
+# When installing, the packages using this eclass ought to use
+# guile_foreach_impl and its SLOTTED_{,E}D, followed by merging roots
+# via guile_merge_roots and unstripping ccache objects via
+# guile_unstrip_ccache.  See descriptions of those functions for
+# details.
+#
+# Ebuild authors, please pay attention for potential conflicts between
+# slots.  As an example, dev-scheme/guile-lib installs a pkg-config file
+# that depends on the Guile version it is installed for.  This is not
+# acceptable, as it means revdeps will only ever see the version of the
+# file for the best Guile implementation in GUILE_TARGETS.
+#
+# @EXAMPLE:
+# The following example demonstrates a simple package relying entirely
+# on the setup of this eclass.  For each enabled, compatible target, the
+# ebuild will bump sources (see description), and run the default
+# configure, compile and test stages (per PMS, meaning GNU Build
+# System), and an install stage modified such that it installs each
+# variant into SLOTTED_D followed by merging roots and unstripping.
+#
+# @CODE
+# EAPI=8
+#
+# GUILE_COMPAT=( 2-2 3-0 )
+# inherit guile
+#
+# DESCRIPTION="iCalendar/vCard parser for GNU Guile"
+# HOMEPAGE="https://github.com/artyom-poptsov/guile-ics"
+# SRC_URI="https://github.com/artyom-poptsov/${PN}/releases/download/v${PV}/${P}.tar.gz"
+#
+# LICENSE="GPL-3+"
+# SLOT="0"
+# KEYWORDS="~amd64"
+# REQUIRED_USE="${GUILE_REQUIRED_USE}"
+#
+# RDEPEND="
+# 	${GUILE_DEPS}
+# 	dev-scheme/guile-smc[${GUILE_USEDEP}]
+# "
+# DEPEND="${RDEPEND}"
+# @CODE
+
+case "${EAPI}" in
+	8) ;;
+	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
+esac
+
+if [[ ! "${_GUILE_ECLASS}" ]]; then
+_GUILE_ECLASS=1
+
+inherit guile-utils multibuild
+
+# @ECLASS_VARIABLE: GUILE_USEDEP
+# @OUTPUT_VARIABLE
+# @DESCRIPTION:
+# USE dependency string that can be applied to Guile
+# multi-implementation dependencies.
+#
+# @EXAMPLE:
+# RDEPEND="
+# 	${GUILE_DEPS}
+# 	dev-scheme/bytestructures[${GUILE_USEDEP}]
+# 	>=dev-libs/libgit2-1:=
+# "
+# DEPEND="${RDEPEND}"
+
+# @ECLASS_VARIABLE: GUILE_COMPAT
+# @REQUIRED
+# @PRE_INHERIT
+# @DESCRIPTION:
+# List of acceptable versions of Guile.  For instance, setting this
+# variable like below will allow the package to be built against both
+# Guile 2.2 or 3.0:
+#
+# @CODE
+# GUILE_COMPAT=( 2-2 3-0 )
+# @CODE
+#
+# Please keep in ascending order.
+
+_guile_setup() {
+	debug-print-function ${FUNCNAME} "${@}"
+
+	guile_generate_depstrings guile_targets '||'
+}
+
+_guile_setup
+unset -f _guile_setup
+
+# @ECLASS_VARIABLE: GUILE_SELECTED_TARGETS
+# @INTERNAL
+# @DESCRIPTION:
+# Contains the intersection of GUILE_TARGETS and GUILE_COMPAT.
+# Generated in guile_pkg_setup.
+
+# @FUNCTION: guile_pkg_setup
+# @DESCRIPTION:
+# Sets up eclass-internal variables for this build.
+guile_pkg_setup() {
+	debug-print-function ${FUNCNAME} "${@}"
+
+	guile_set_common_vars
+	GUILE_SELECTED_TARGETS=()
+	for ver in "${GUILE_COMPAT[@]}"; do
+		debug-print "${FUNCNAME}: checking for ${ver}"
+		use "guile_targets_${ver}" || continue
+		GUILE_SELECTED_TARGETS+=("${ver/-/.}")
+	done
+	if [[ "${#GUILE_SELECTED_TARGETS[@]}" -eq 0 ]]; then
+		die "No GUILE_TARGETS specified."
+	fi
+}
+
+# @FUNCTION: guile_copy_sources
+# @DESCRIPTION:
+# Create a single copy of the package sources for each selected Guile
+# implementation.
+guile_copy_sources() {
+	debug-print-function ${FUNCNAME} "${@}"
+
+	local MULTIBUILD_VARIANTS
+	MULTIBUILD_VARIANTS=("${GUILE_SELECTED_TARGETS[@]}")
+
+	multibuild_copy_sources
+}
+
+# @FUNCTION: _guile_multibuild_wrapper
+# @USAGE: <command> [<argv>...]
+# @INTERNAL
+# @DESCRIPTION:
+# Initialize the environment for a single build variant.  See
+# guile_foreach_impl.
+_guile_multibuild_wrapper() {
+	local GUILE_CURRENT_VERSION="${MULTIBUILD_VARIANT}"
+	debug-print-function ${FUNCNAME} "${@}" "on ${MULTIBUILD_VARIANT}"
+
+	local -x PATH="${PATH}"
+	guile_create_temporary_config "${GUILE_CURRENT_VERSION}"
+	guile_export GUILE GUILD GUILESNARF
+
+	local -x PKG_CONFIG_PATH="${PKG_CONFIG_PATH}"
+	guile_filter_pkgconfig_path "${MULTIBUILD_VARIANT}"
+	local ECONF_SOURCE="${S}"
+	local -x SLOTTED_D="${T}/dests/image${MULTIBUILD_ID}"
+	local -x SLOTTED_ED="${SLOTTED_D}${EPREFIX}/"
+	local -x GUILE_EFFECTIVE_VERSION="${GUILE_CURRENT_VERSION}"
+	mkdir -p "${BUILD_DIR}" || die
+	cd "${BUILD_DIR}" || die
+	"$@"
+}
+
+# @VARIABLE: SLOTTED_D
+# @DESCRIPTION:
+# In functions ran by guile_foreach_impl, this variable is set to a new
+# ${D} value that the variant being installed should use.
+
+# @VARIABLE: SLOTTED_ED
+# @DESCRIPTION:
+# In functions ran by guile_foreach_impl, this variable is set to a new
+# ${ED} value that the variant being installed should use.  It is
+# equivalent to "${SLOTTED_D%/}${EPREFIX}/".
+
+# @VARIABLE: ECONF_SOURCE
+# @DESCRIPTION:
+# In functions ran by guile_foreach_impl, this variable is set to ${S},
+# for convenience.
+
+# @VARIABLE: PKG_CONFIG_PATH
+# @DESCRIPTION:
+# In functions ran by guile_foreach_impl, PKG_CONFIG_PATH is filtered to
+# contain only the current ${MULTIBUILD_VARIANT}.
+
+# @VARIABLE: BUILD_DIR
+# @DESCRIPTION:
+# In functions ran by guile_foreach_impl, this variable is set to a
+# newly-generated build directory for this variant.
+
+# @FUNCTION: guile_foreach_impl
+# @USAGE: <command> [<argv>...]
+# @DESCRIPTION:
+# Runs the given command for each of the selected Guile implementations.
+#
+# The function will return 0 status if all invocations succeed.
+# Otherwise, the return code from first failing invocation will
+# be returned.
+#
+# Each invocation will have PKG_CONFIG_DIR altered to contain only one
+# Guile implementation, as well as a SLOTTED_D, SLOTTED_ED for
+# installation purposes, and a new BUILD_DIR, in which the wrapped
+# function will be executed, with a pre-configured ECONF_SOURCE.  A
+# temporary program called 'guile-config' is generated and inserted into
+# the PATH.
+#
+# Also automatically exported are GUILE, GUILD, and GUILESNARF - see
+# guile_export for details - as well as GUILE_CURRENT_VERSION and
+# GUILE_EFFECTIVE_VERSION, which are set to the same value (the current
+# version).
+#
+# This combination should cover Guile detection of a large amount of
+# packages out of the box.
+guile_foreach_impl() {
+	debug-print-function ${FUNCNAME} "${@}"
+
+	local MULTIBUILD_VARIANTS
+	MULTIBUILD_VARIANTS=("${GUILE_SELECTED_TARGETS[@]}")
+
+	debug-print "${FUNCNAME}: Running for each of:" \
+				"${GUILE_SELECTED_TARGETS[@]}"
+
+	multibuild_foreach_variant _guile_multibuild_wrapper "${@}"
+}
+
+# @FUNCTION: _guile_merge_single_root
+# @INTERNAL
+# @DESCRIPTION:
+# Runs a single merge_root step for guile_merge_roots.
+_guile_merge_single_root() {
+	debug-print-function ${FUNCNAME} "${@}"
+
+	multibuild_merge_root "${SLOTTED_D}" "${D}"
+}
+
+# @FUNCTION: guile_merge_roots
+# @DESCRIPTION:
+# Merges install roots from all slots, diagnosing conflicts.
+guile_merge_roots() {
+	debug-print-function ${FUNCNAME} "${@}"
+
+	guile_foreach_impl _guile_merge_single_root
+}
+
+# @FUNCTION: guile_for_best_impl
+# @DESCRIPTION:
+# Runs the passed command once, for the best installed Guile
+# implementation.
+guile_for_best_impl() {
+	debug-print-function ${FUNCNAME} "${@}"
+
+	multibuild_for_best_variant _guile_multibuild_wrapper "${@}"
+}
+
+# Default implementations for a GNU Build System based Guile package.
+
+# @FUNCTION: guile_src_prepare
+# @DESCRIPTION:
+# Bumps SCM sources runs the default src_prepare and bumps all *.scm
+# files.  See guile_bump_sources of guile-utils.eclass.
+guile_src_prepare() {
+	debug-print-function ${FUNCNAME} "${@}"
+
+	default
+	guile_bump_sources
+}
+
+# @FUNCTION: guile_src_configure
+# @DESCRIPTION:
+# Runs the default src_configure for each selected variant target.
+guile_src_configure() {
+	debug-print-function ${FUNCNAME} "${@}"
+
+	guile_foreach_impl default
+}
+
+# @FUNCTION: guile_src_compile
+# @DESCRIPTION:
+# Runs the default src_compile for each selected variant target.
+guile_src_compile() {
+	debug-print-function ${FUNCNAME} "${@}"
+
+	guile_foreach_impl default
+}
+
+# @FUNCTION: guile_src_test
+# @DESCRIPTION:
+# Runs the default src_test phase for each implementation.
+guile_src_test() {
+	debug-print-function ${FUNCNAME} "${@}"
+
+	guile_foreach_impl default
+}
+
+# @FUNCTION: _guile_default_install_slot
+# @INTERNAL
+# @DESCRIPTION:
+# Imitates the default build system install "substep", but for a given
+# ${SLOTTED_D} rather than the usual ${D}.  See guile_src_install.
+_guile_default_install_slot() {
+	debug-print-function ${FUNCNAME} "${@}"
+
+	if [[ -f Makefile ]] || [[ -f GNUmakefile ]] || [[ -f makefile ]]; then
+		emake DESTDIR="${SLOTTED_D}" install
+	fi
+}
+
+# @FUNCTION: guile_src_install
+# @DESCRIPTION:
+# Runs the an imitation of the default src_install that does the right
+# thing for a GNU Build System based Guile package, for each selected
+# variant target.  Merges roots after completing the installs.
+guile_src_install() {
+	debug-print-function ${FUNCNAME} "${@}"
+
+	guile_foreach_impl _guile_default_install_slot
+	guile_merge_roots
+	guile_unstrip_ccache
+
+	einstalldocs
+}
+
+EXPORT_FUNCTIONS pkg_setup src_prepare src_configure src_compile \
+				 src_install src_test
+
+fi  # _GUILE_ECLASS
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-18 17:44 Arsen Arsenović
  0 siblings, 0 replies; 6663+ messages in thread
From: Arsen Arsenović @ 2024-08-18 17:44 UTC (permalink / raw
  To: gentoo-commits
commit:     4110a265b5a3b2fbacd85c024d8fc69631030d64
Author:     Arsen Arsenović <arsen <AT> gentoo <DOT> org>
AuthorDate: Sat Apr  8 22:08:10 2023 +0000
Commit:     Arsen Arsenović <arsen <AT> gentoo <DOT> org>
CommitDate: Sun Aug 18 17:43:15 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=4110a265
guile-single.eclass: new eclass, for single-impl guile packages
Bug: https://bugs.gentoo.org/689408
Signed-off-by: Arsen Arsenović <arsen <AT> gentoo.org>
 eclass/guile-single.eclass | 245 +++++++++++++++++++++++++++++++++++++++++++++
 1 file changed, 245 insertions(+)
diff --git a/eclass/guile-single.eclass b/eclass/guile-single.eclass
new file mode 100644
index 000000000000..41ede32928bc
--- /dev/null
+++ b/eclass/guile-single.eclass
@@ -0,0 +1,245 @@
+# Copyright 2024 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+# @ECLASS: guile-single.eclass
+# @PROVIDES: guile-utils
+# @MAINTAINER:
+# Gentoo Scheme project <scheme@gentoo.org>
+# @AUTHOR:
+# Author: Arsen Arsenović <arsen@gentoo.org>
+# Inspired by prior work in the Gentoo Python ecosystem.
+# @BLURB: Utilities for packages that build against a single Guile.
+# @SUPPORTED_EAPIS: 8
+# @PROVIDES: guile-utils
+# @DESCRIPTION:
+# This eclass facilitates packages building against a single slot of
+# Guile, which is normally something that uses Guile for extending, like
+# GNU Make, or for programs built in Guile, like Haunt.
+#
+# These packages should use guile_gen_cond_dep to generate a dependency
+# string for their Guile package dependencies (i.e. other Guile single-
+# and multi-implementation packages).  They should also utilize
+# GUILE_DEPS and GUILE_REQUIRED_USE to specify a dependency on their
+# Guile versions.
+#
+# They should also bump sources via guile_bump_sources during
+# src_prepare, and unstrip ccache via guile_unstrip_ccache during
+# src_install.
+#
+# If the user of the eclass needs some USE flag on Guile itself, they
+# should provide it via GUILE_REQ_USE.
+#
+# This eclass provides a guile-single_pkg_setup that sets up environment
+# variables needed for Guile and build systems using it.  See the
+# documentation for that function for more details.
+#
+# @EXAMPLE:
+# A Guile program:
+#
+# @CODE
+# # Copyright 2024 Gentoo Authors
+# # Distributed under the terms of the GNU General Public License v2
+#
+# EAPI=8
+#
+# GUILE_COMPAT=( 2-2 3-0 )
+# inherit guile-single
+#
+# DESCRIPTION="Haunt is a simple, functional, hackable static site generator"
+# HOMEPAGE="https://dthompson.us/projects/haunt.html"
+# SRC_URI="https://files.dthompson.us/releases/${PN}/${P}.tar.gz"
+#
+# LICENSE="GPL-3+"
+# SLOT="0"
+# KEYWORDS="~amd64"
+# REQUIRED_USE="${GUILE_REQUIRED_USE}"
+#
+# RDEPEND="
+# 	${GUILE_DEPS}
+# 	$(guile_gen_cond_dep '
+# 		dev-scheme/guile-reader[${GUILE_MULTI_USEDEP}]
+# 		dev-scheme/guile-commonmark[${GUILE_MULTI_USEDEP}]
+# 	')
+# "
+# DEPEND="${RDEPEND}"
+# @CODE
+#
+# A program utilizing Guile for extension (GNU make, irrelevant pieces
+# elided):
+# @CODE
+# GUILE_COMPAT=( 1-8 2-0 2-2 3-0 )
+# inherit flag-o-matic unpacker verify-sig guile-single
+# # ...
+# REQUIRED_USE="guile? ( ${GUILE_REQUIRED_USE} )"
+# DEPEND="
+# 	guile? ( ${GUILE_DEPS} )
+# "
+#
+# src_prepare() {
+# 	# ...
+# 	if use guile; then
+# 		guile-single_src_prepare
+# 	fi
+# }
+#
+# pkg_setup() {
+# 	if use guile; then
+# 		guile-single_pkg_setup
+# 	fi
+# }
+#
+# src_configure() {
+# 	# ...
+# 	local myeconfargs=(
+# 		$(use_with guile)
+# 	)
+# 	econf "${myeconfargs[@]}"
+# }
+#
+# src_install() {
+# 	# ...
+# 	if use guile; then
+# 		guile_unstrip_ccache
+# 	fi
+# }
+# @CODE
+
+case "${EAPI}" in
+	8) ;;
+	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
+esac
+
+if [[ ! "${_GUILE_SINGLE_ECLASS}" ]]; then
+_GUILE_SINGLE_ECLASS=1
+
+inherit guile-utils
+
+# @ECLASS_VARIABLE: GUILE_COMPAT
+# @REQUIRED
+# @PRE_INHERIT
+# @DESCRIPTION:
+# List of acceptable versions of Guile.  For instance, setting this
+# variable like below will allow the package to be built against either
+# Guile 2.2 or 3.0:
+#
+# @CODE
+# GUILE_COMPAT=( 2-2 3-0 )
+# @CODE
+#
+# Please keep in ascending order.
+
+_guile_setup() {
+	debug-print-function ${FUNCNAME} "${@}"
+
+	# Inhibit generating the GUILE_USEDEP.  This variable is not usable
+	# for single packages.
+	local GUILE_USEDEP
+	guile_generate_depstrings guile_single_target ^^
+}
+
+_guile_setup
+unset -f _guile_setup
+
+# @FUNCTION: guile_gen_cond_dep
+# @USAGE: <dependency> [<pattern>...]
+# @DESCRIPTION:
+# Takes a string that uses (quoted) ${GUILE_SINGLE_USEDEP} and
+# ${GUILE_MULTI_USEDEP} markers as placeholders for the correct USE
+# dependency strings for each compatible slot.
+#
+# If the pattern is provided, it is taken to be list of slots to
+# generate the dependency string for, otherwise, ${GUILE_COMPAT[@]} is
+# taken.
+#
+# @EXAMPLE:
+# Note that the "inner" dependency string is in single quotes!
+# @CODE
+# RDEPEND="
+#	$(guile_gen_cond_dep '
+#		dev-scheme/guile-zstd[${GUILE_MULTI_USEDEP}]
+#		dev-scheme/guile-config[${GUILE_SINGLE_USEDEP}]
+#	')
+# "
+# @CODE
+guile_gen_cond_dep() {
+	debug-print-function ${FUNCNAME} "${@}"
+
+	local deps="$1"
+	shift
+
+	local candidates=( "$@" )
+	if [[ ${#candidates[@]} -eq 0 ]]; then
+		candidates=( "${GUILE_COMPAT[@]}" )
+	fi
+
+	local candidate
+	for candidate in "${candidates[@]}"; do
+		local s="guile_single_target_${candidate}(-)" \
+			  m="guile_targets_${candidate}(-)" \
+			  subdeps=${deps//\$\{GUILE_SINGLE_USEDEP\}/${s}}
+		subdeps=${subdeps//\$\{GUILE_MULTI_USEDEP\}/${m}}
+		echo "
+		guile_single_target_${candidate}? (
+			${subdeps}
+		)
+		"
+	done
+}
+
+# @FUNCTION: guile-single_pkg_setup
+# @DESCRIPTION:
+# Sets up the PKG_CONFIG_PATH with the appropriate GUILE_SINGLE_TARGET,
+# as well as setting up a guile-config and the GUILE, GUILD and
+# GUILESNARF environment variables.  Also sets GUILE_EFFECTIVE_VERSION
+# to the same value as GUILE_SELECTED_TARGET, as build systems sometimes
+# check that variable.
+#
+# For details on the latter three, see guile_export.
+guile-single_pkg_setup() {
+	debug-print-function ${FUNCNAME} "${@}"
+
+	guile_set_common_vars
+
+	GUILE_SELECTED_TARGET=
+	for ver in "${GUILE_COMPAT[@]}"; do
+		debug-print "${FUNCNAME}: checking for ${ver}"
+		use "guile_single_target_${ver}" || continue
+		GUILE_SELECTED_TARGET="${ver/-/.}"
+		break
+	done
+
+	[[ ${GUILE_SELECTED_TARGET} ]] \
+		|| die "No GUILE_SINGLE_TARGET specified."
+
+	export PKG_CONFIG_PATH
+	guile_filter_pkgconfig_path "${GUILE_SELECTED_TARGET}"
+	guile_create_temporary_config "${GUILE_SELECTED_TARGET}"
+	local -x GUILE_EFFECTIVE_VERSION="${GUILE_SELECTED_TARGET}"
+	guile_export GUILE GUILD GUILESNARF
+}
+
+# @FUNCTION: guile-single_src_prepare
+# @DESCRIPTION:
+# Runs the default prepare stage, and then bumps Guile sources via
+# guile_bump_sources.
+guile-single_src_prepare() {
+	debug-print-function ${FUNCNAME} "${@}"
+
+	default
+	guile_bump_sources
+}
+
+# @FUNCTION: guile-single_src_install
+# @DESCRIPTION:
+# Runs the default install stage, and then marks ccache files not to be
+# stripped using guile_unstrip_ccache.
+guile-single_src_install() {
+	debug-print-function ${FUNCNAME} "${@}"
+
+	default
+	guile_unstrip_ccache
+}
+
+EXPORT_FUNCTIONS pkg_setup src_prepare src_install
+
+fi  # _GUILE_SINGLE_ECLASS
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-18 17:44 Arsen Arsenović
  0 siblings, 0 replies; 6663+ messages in thread
From: Arsen Arsenović @ 2024-08-18 17:44 UTC (permalink / raw
  To: gentoo-commits
commit:     944c392114cd791967cd722b7cd20a67b91f7165
Author:     Arsen Arsenović <arsen <AT> gentoo <DOT> org>
AuthorDate: Sat Apr  8 19:51:19 2023 +0000
Commit:     Arsen Arsenović <arsen <AT> gentoo <DOT> org>
CommitDate: Sun Aug 18 17:43:15 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=944c3921
guile-utils.eclass: new eclass, common code for guile packages
Bug: https://bugs.gentoo.org/689408
Signed-off-by: Arsen Arsenović <arsen <AT> gentoo.org>
 eclass/guile-utils.eclass | 275 ++++++++++++++++++++++++++++++++++++++++++++++
 1 file changed, 275 insertions(+)
diff --git a/eclass/guile-utils.eclass b/eclass/guile-utils.eclass
new file mode 100644
index 000000000000..3f122f63a36f
--- /dev/null
+++ b/eclass/guile-utils.eclass
@@ -0,0 +1,275 @@
+# Copyright 2023-2024 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+# @ECLASS: guile-utils.eclass
+# @MAINTAINER:
+# Gentoo Scheme project <scheme@gentoo.org>
+# @AUTHOR:
+# Author: Arsen Arsenović <arsen@gentoo.org>
+# Inspired by prior work in the Gentoo Python ecosystem.
+# @BLURB: Common code between GNU Guile-related eclasses and ebuilds.
+# @SUPPORTED_EAPIS: 8
+# @DESCRIPTION:
+# This eclass contains various bits of common code between
+# dev-scheme/guile, Guile multi-implementation ebuilds and Guile
+# single-implementation ebuilds.
+
+case "${EAPI}" in
+	8) ;;
+	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
+esac
+
+if [[ ! "${_GUILE_UTILS_ECLASS}" ]]; then
+_GUILE_UTILS_ECLASS=1
+
+inherit toolchain-funcs
+
+BDEPEND="virtual/pkgconfig"
+
+# @ECLASS_VARIABLE: GUILE_COMPAT
+# @REQUIRED
+# @PRE_INHERIT
+# @DESCRIPTION:
+# List of acceptable versions of Guile.  For instance, setting this
+# variable like below will allow the package to be built against either
+# Guile 2.2 or 3.0:
+#
+# @CODE
+# GUILE_COMPAT=( 2-2 3-0 )
+# @CODE
+#
+# Please keep in ascending order.
+
+# @FUNCTION: guile_check_compat
+# @DESCRIPTION:
+# Checks that GUILE_COMPAT is set to an array, and has no invalid
+# values.
+guile_check_compat() {
+	debug-print-function ${FUNCNAME} "${@}"
+
+	if ! [[ ${GUILE_COMPAT@a} == *a* ]]; then
+		die "GUILE_COMPAT not set to an array"
+	fi
+
+	if [[ ${#GUILE_COMPAT[@]} -eq 0 ]]; then
+		die "GUILE_COMPAT is empty"
+	fi
+}
+
+guile_check_compat
+
+# @ECLASS_VARIABLE: GUILE_REQ_USE
+# @PRE_INHERIT
+# @DEFAULT_UNSET
+# @DESCRIPTION:
+# Specifies a USE dependency string for all versions of Guile in
+# GUILE_COMPAT.
+#
+# @EXAMPLE:
+# GUILE_REQ_USE="deprecated"
+
+# @ECLASS_VARIABLE: GUILE_USEDEP
+# @OUTPUT_VARIABLE
+# @DESCRIPTION:
+# This variable is populated with a USE-dependency string which can be
+# used to depend on other Guile multi-implementation packages.
+# This variable is not usable from guile-single packages.
+
+# @ECLASS_VARIABLE: GUILE_DEPS
+# @OUTPUT_VARIABLE
+# @DESCRIPTION:
+# Contains the dependency string for the compatible Guile runtimes.
+
+# @FUNCTION: guile_set_common_vars
+# @DESCRIPTION:
+# Sets common variables that apply to all Guile packages, namely,
+# QA_PREBUILT.
+guile_set_common_vars() {
+	debug-print-function ${FUNCNAME} "${@}"
+
+	# These aren't strictly speaking prebuilt. but they do generated a
+	# nonstandard ELF object.
+	if [[ -z ${QA_PREBUILT} ]]; then
+		QA_PREBUILT="usr/$(get_libdir)/guile/*/site-ccache/*"
+	fi
+}
+
+# @FUNCTION: guile_filter_pkgconfig_path
+# @USAGE: <acceptable slots>...
+# @DESCRIPTION:
+# Alters ${PKG_CONFIG_PATH} such that it does not contain any Guile
+# slots besides the ones required by the caller.
+guile_filter_pkgconfig_path() {
+	debug-print-function ${FUNCNAME} "${@}"
+
+	local filtered_path= unfiltered_path path
+	IFS=: read -ra unfiltered_path <<<"${PKG_CONFIG_PATH}"
+	debug-print "Unfiltered PKG_CONFIG_PATH:" "${unfiltered_path[@]}"
+	for p in "${unfiltered_path[@]}"; do
+		for v in "$@"; do
+			debug-print "... considering '${p}' for ${v}"
+			# Exclude non-selected versions.
+			[[ ${p} == */usr/share/guile-data/${v}/pkgconfig* ]] \
+				|| continue
+			debug-print "... OK"
+
+			# Add separator, if some data already exists.
+			[[ "${filtered_path}" ]] && filtered_path+=:
+
+			filtered_path+="${p}"
+			break
+		done
+	done
+
+	debug-print "${FUNCNAME}: Constructed PKG_CONFIG_PATH: ${filtered_path}"
+	PKG_CONFIG_PATH="$filtered_path"
+}
+
+# @FUNCTION: guile_generate_depstrings
+# @USAGE: <prefix> <depop>
+# @DESCRIPTION:
+# Generates GUILE_REQUIRED_USE/GUILE_DEPS/GUILE_USEDEP based on
+# GUILE_COMPAT, and populates IUSE.
+guile_generate_depstrings() {
+	debug-print-function ${FUNCNAME} "${@}"
+
+	# Generate IUSE, REQUIRED_USE, GUILE_USEDEP
+	local prefix="$1" depop="$2"
+	GUILE_USEDEP=""
+	local ver uses=()
+	# TODO(arsen): enforce GUILE_COMPAT is in ascending order.
+	for ver in "${GUILE_COMPAT[@]}"; do
+		[[ -n ${GUILE_USEDEP} ]] && GUILE_USEDEP+=","
+		uses+=("${prefix}_${ver}")
+		GUILE_USEDEP+="${prefix}_${ver}"
+	done
+	GUILE_REQUIRED_USE="${depop} ( ${uses[@]} )"
+	IUSE="${uses[@]}"
+	debug-print "${FUNCNAME}: requse ${GUILE_REQUIRED_USE}"
+	debug-print "${FUNCNAME}: generated ${uses[*]}"
+	debug-print "${FUNCNAME}: iuse ${IUSE}"
+
+	# Generate GUILE_DEPS
+	local base_deps=()
+	local requse="${GUILE_REQ_USE+[}${GUILE_REQ_USE:-}${GUILE_REQ_USE+]}"
+	for ver in "${GUILE_COMPAT[@]}"; do
+		base_deps+="
+			${prefix}_${ver}? (
+				dev-scheme/guile:${ver/-/.}${requse}
+			)
+		"
+	done
+	GUILE_DEPS="${base_deps[*]}"
+	debug-print "${FUNCNAME}: GUILE_DEPS=${GUILE_DEPS}"
+	debug-print "${FUNCNAME}: GUILE_USEDEP=${GUILE_USEDEP}"
+}
+
+# @FUNCTION: guile_unstrip_ccache
+# @DESCRIPTION:
+# Marks site-ccache files not to be stripped.  Operates on ${D}.
+guile_unstrip_ccache() {
+	debug-print-function ${FUNCNAME} "${@}"
+
+	local ccache
+	while read -r -d $'\0' ccache; do
+		debug-print "${FUNCNAME}: ccache found: ${ccache#.}"
+		dostrip -x "${ccache#.}"
+	done < <(cd "${ED}" || die; \
+			 find . \
+				  -name '*.go' \
+				  -path "*/usr/$(get_libdir)/guile/*/site-ccache/*" \
+				  -print0 || die) || die
+}
+
+# @FUNCTION: guile_export
+# @USAGE: [GUILE|GUILD|GUILE_SITECCACHEDIR|GUILE_SITEDIR]...
+# @DESCRIPTION:
+# Exports a given variable for the selected Guile variant.
+#
+# Supported variables are:
+#
+# - GUILE - Path to the guile executable,
+# - GUILD - Path to the guild executable,
+# - GUILESNARF - Path to the guile-snarf executable
+# - GUILECONFIG - Path to the guile-config executable
+# - GUILE_SITECCACHEDIR - Path to the site-ccache directory,
+# - GUILE_SITEDIR - Path to the site Scheme directory
+guile_export() {
+	debug-print-function ${FUNCNAME} "${@}"
+
+	local gver
+	if [[ "${GUILE_CURRENT_VERSION}" ]]; then
+		gver="${GUILE_CURRENT_VERSION}"
+	elif [[ "${GUILE_SELECTED_TARGET}" ]]; then
+		gver="${GUILE_SELECTED_TARGET}"
+	else
+		die "Calling guile_export outside of a Guile build context?"
+	fi
+
+	_guile_pcvar() {
+		local tip="Did you source /etc/profile after an update?"
+		$(tc-getPKG_CONFIG) --variable="$1" guile-"${gver}" \
+			|| die "Could not get $1 out of guile-${gver}.  ${tip}"
+	}
+
+	for var; do
+		case "${var}" in
+			GUILE) export GUILE="$(_guile_pcvar guile)" ;;
+			GUILD) export GUILD="$(_guile_pcvar guild)" ;;
+			GUILESNARF)
+				GUILESNARF="${EPREFIX}/usr/bin/guile-snarf-${gver}"
+				export GUILESNARF
+				;;
+			GUILECONFIG)
+				GUILECONFIG="${EPREFIX}/usr/bin/guile-config-${gver}"
+				export GUILECONFIG
+				;;
+			GUILE_SITECCACHEDIR)
+				GUILE_SITECCACHEDIR="$(_guile_pcvar siteccachedir)"
+				export GUILE_SITECCACHEDIR
+				;;
+			GUILE_SITEDIR)
+				export GUILE_SITEDIR="$(_guile_pcvar sitedir)"
+				;;
+			*) die "Unknown variable '${var}'" ;;
+		esac
+	done
+}
+
+# @FUNCTION: guile_create_temporary_config
+# @USAGE: <version>
+# @DESCRIPTION:
+# Creates a guile-config executable for a given Guile version, and
+# inserts it into path.
+guile_create_temporary_config() {
+	debug-print-function ${FUNCNAME} "${@}"
+
+	[[ ${1} ]] || die "Must specify a Guile version"
+
+	local cdir="${T}/guiles/${1}/"
+	mkdir -p "${cdir}" || die
+
+	pushd "${cdir}" >/dev/null 2>&1 || die
+	cat >guile-config <<-EOF
+	#!/bin/sh
+	exec guile-config-${1} "\${@}"
+	EOF
+	chmod +x guile-config
+	popd >/dev/null 2>&1 || die
+	PATH="${cdir}:${PATH}"
+}
+
+# @FUNCTION: guile_bump_sources
+# @DESCRIPTION:
+# Searches over ${S} for .scm files and bumps them to avoid Guile using
+# the system ccache while trying to build packages.
+#
+# http://debbugs.gnu.org/cgi/bugreport.cgi?bug=38112
+guile_bump_sources() {
+	debug-print-function ${FUNCNAME} "${@}"
+
+	einfo "bumping *.scm source files..."
+	find "${S}" -name "*.scm" -exec touch {} + || die
+}
+
+fi  # _GUILE_UTILS_ECLASS
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-19  6:02 Viorel Munteanu
  0 siblings, 0 replies; 6663+ messages in thread
From: Viorel Munteanu @ 2024-08-19  6:02 UTC (permalink / raw
  To: gentoo-commits
commit:     b1619cb5f7d2fafae4adeaa9b25182eb6f658c17
Author:     Viorel Munteanu <ceamac <AT> gentoo <DOT> org>
AuthorDate: Mon Aug 19 05:53:15 2024 +0000
Commit:     Viorel Munteanu <ceamac <AT> gentoo <DOT> org>
CommitDate: Mon Aug 19 06:02:08 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=b1619cb5
toolchain-funcs.eclass: fix detecting ld.bfd
There is some more output from the compiler here.
We must use a regular expression to avoid a false positive from mold.
Acked-by: Sam James <sam <AT> gentoo.org>
Signed-off-by: Viorel Munteanu <ceamac <AT> gentoo.org>
 eclass/toolchain-funcs.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/toolchain-funcs.eclass b/eclass/toolchain-funcs.eclass
index bc1fb064fc45..5e36fa275dcd 100644
--- a/eclass/toolchain-funcs.eclass
+++ b/eclass/toolchain-funcs.eclass
@@ -472,7 +472,7 @@ tc-ld-is-bfd() {
 	EOF
 	out=$($(tc-getCC "$@") ${CFLAGS} ${CPPFLAGS} ${LDFLAGS} -Wl,--version "${base}.c" -o "${base}" 2>&1)
 	rm -f "${base}"*
-	if [[ ${out} != "GNU ld"* ]] ; then
+	if [[ ! ${out} =~ .*^"GNU ld".* ]] ; then
 		return 1
 	fi
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-19 18:17 Robin H. Johnson
  0 siblings, 0 replies; 6663+ messages in thread
From: Robin H. Johnson @ 2024-08-19 18:17 UTC (permalink / raw
  To: gentoo-commits
commit:     b341ff7d283ccc6186eeb29c21baaa22499baadc
Author:     Robin H. Johnson <robbat2 <AT> gentoo <DOT> org>
AuthorDate: Mon Aug 19 18:14:45 2024 +0000
Commit:     Robin H. Johnson <robbat2 <AT> gentoo <DOT> org>
CommitDate: Mon Aug 19 18:17:33 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=b341ff7d
virtualx.eclass: addpredict /dev/dri/ for Xvfb w/ mesa-24.2.0
Newer Mesa tries to access /dev/dri/ when used in Xvfb, and this
triggers a sandbox error; discovered and verified w/
sci-mathematics/fricas-1.3.11-r2.
Reference: https://public-inbox.gentoo.org/gentoo-dev/bb4927ba-5ced-3352-86bb-d87f37ceaab6 <AT> woodpecker.gentoo.org/T/#t
Signed-off-by: Robin H. Johnson <robbat2 <AT> gentoo.org>
 eclass/virtualx.eclass | 1 +
 1 file changed, 1 insertion(+)
diff --git a/eclass/virtualx.eclass b/eclass/virtualx.eclass
index 6e77cd662bdd..f7318eafc59e 100644
--- a/eclass/virtualx.eclass
+++ b/eclass/virtualx.eclass
@@ -113,6 +113,7 @@ virtx() {
 	export XAUTHORITY=
 
 	einfo "Starting Xvfb ..."
+	addpredict /dev/dri/ # Needed for Xvfb w/ >=mesa-24.2.0
 
 	debug-print "${FUNCNAME}: Xvfb -displayfd 1 ${xvfbargs[*]}"
 	local logfile=${T}/Xvfb.log
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-20 20:07 Mike Gilbert
  0 siblings, 0 replies; 6663+ messages in thread
From: Mike Gilbert @ 2024-08-20 20:07 UTC (permalink / raw
  To: gentoo-commits
commit:     e723fd6d0e2fe4cf134a6c6e064d3faaa77c8339
Author:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
AuthorDate: Sun Aug 18 18:19:23 2024 +0000
Commit:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
CommitDate: Tue Aug 20 20:06:06 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=e723fd6d
lua-utils.eclass: use BROOT or ESYSROOT where appropriate
The LUA variable points to a lua binary that is likely to be executed by
the build system. Use BROOT for this.
Use ESYSROOT for the pkg-config symlink, since this is likely used for
linking a library.
Signed-off-by: Mike Gilbert <floppym <AT> gentoo.org>
 eclass/lua-utils.eclass | 12 ++++++------
 1 file changed, 6 insertions(+), 6 deletions(-)
diff --git a/eclass/lua-utils.eclass b/eclass/lua-utils.eclass
index 0ff36734dc8f..c63ec369c1c2 100644
--- a/eclass/lua-utils.eclass
+++ b/eclass/lua-utils.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2023 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: lua-utils.eclass
@@ -144,18 +144,18 @@ _lua_wrapper_setup() {
 		_lua_export "${impl}" ELUA LUA
 
 		# Lua interpreter
-		ln -s "${EPREFIX}"/usr/bin/${ELUA} "${workdir}"/bin/lua || die
+		ln -s "${LUA}" "${workdir}"/bin/lua || die
 
 		# Lua compiler, or a stub for it in case of luajit
 		if [[ ${ELUA} == luajit ]]; then
 			# Just in case
-			ln -s "${EPREFIX}"/bin/true "${workdir}"/bin/luac || die
+			ln -s "${BROOT}"/bin/true "${workdir}"/bin/luac || die
 		else
-			ln -s "${EPREFIX}"/usr/bin/${ELUA/a/ac} "${workdir}"/bin/luac || die
+			ln -s "${BROOT}"/usr/bin/${ELUA/a/ac} "${workdir}"/bin/luac || die
 		fi
 
 		# pkg-config
-		ln -s "${EPREFIX}"/usr/$(get_libdir)/pkgconfig/${ELUA}.pc \
+		ln -s "${ESYSROOT}"/usr/$(get_libdir)/pkgconfig/${ELUA}.pc \
 			"${workdir}"/pkgconfig/lua.pc || die
 	fi
 
@@ -264,7 +264,7 @@ _lua_export() {
 				debug-print "${FUNCNAME}: ELUA = ${ELUA}"
 				;;
 			LUA)
-				export LUA="${EPREFIX}"/usr/bin/${impl}
+				export LUA="${BROOT}"/usr/bin/${impl}
 				debug-print "${FUNCNAME}: LUA = ${LUA}"
 				;;
 			LUA_CFLAGS)
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-20 20:17 Mike Gilbert
  0 siblings, 0 replies; 6663+ messages in thread
From: Mike Gilbert @ 2024-08-20 20:17 UTC (permalink / raw
  To: gentoo-commits
commit:     1f2079f01b0276fe5ac6f8d2270f3a2bad32de61
Author:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
AuthorDate: Tue Aug 20 20:16:58 2024 +0000
Commit:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
CommitDate: Tue Aug 20 20:16:58 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=1f2079f0
eclass: remove marecki from maintainers
Signed-off-by: Mike Gilbert <floppym <AT> gentoo.org>
 eclass/lua-single.eclass | 3 +--
 eclass/lua-utils.eclass  | 1 -
 eclass/lua.eclass        | 3 +--
 3 files changed, 2 insertions(+), 5 deletions(-)
diff --git a/eclass/lua-single.eclass b/eclass/lua-single.eclass
index 8432df0583bb..ad7075955153 100644
--- a/eclass/lua-single.eclass
+++ b/eclass/lua-single.eclass
@@ -1,10 +1,9 @@
-# Copyright 1999-2023 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: lua-single.eclass
 # @MAINTAINER:
 # William Hubbs <williamh@gentoo.org>
-# Marek Szuba <marecki@gentoo.org>
 # @AUTHOR:
 # Marek Szuba <marecki@gentoo.org>
 # Based on python-single-r1.eclass by Michał Górny <mgorny@gentoo.org> et al.
diff --git a/eclass/lua-utils.eclass b/eclass/lua-utils.eclass
index c63ec369c1c2..7272f80d0370 100644
--- a/eclass/lua-utils.eclass
+++ b/eclass/lua-utils.eclass
@@ -4,7 +4,6 @@
 # @ECLASS: lua-utils.eclass
 # @MAINTAINER:
 # William Hubbs <williamh@gentoo.org>
-# Marek Szuba <marecki@gentoo.org>
 # @AUTHOR:
 # Marek Szuba <marecki@gentoo.org>
 # Based on python-utils-r1.eclass by Michał Górny <mgorny@gentoo.org> et al.
diff --git a/eclass/lua.eclass b/eclass/lua.eclass
index bb2e41ef1061..380ec274167c 100644
--- a/eclass/lua.eclass
+++ b/eclass/lua.eclass
@@ -1,10 +1,9 @@
-# Copyright 1999-2023 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: lua.eclass
 # @MAINTAINER:
 # William Hubbs <williamh@gentoo.org>
-# Marek Szuba <marecki@gentoo.org>
 # @AUTHOR:
 # Marek Szuba <marecki@gentoo.org>
 # Based on python-r1.eclass by Michał Górny <mgorny@gentoo.org> et al.
^ permalink raw reply related	[flat|nested] 6663+ messages in thread
* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-21 21:51 Andreas Sturmlechner
  0 siblings, 0 replies; 6663+ messages in thread
From: Andreas Sturmlechner @ 2024-08-21 21:51 UTC (permalink / raw
  To: gentoo-commits
commit:     595921bcb8fb5914b4b9ffecd5e24f3c235bdb63
Author:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
AuthorDate: Tue Aug 20 15:34:54 2024 +0000
Commit:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
CommitDate: Wed Aug 21 21:16:31 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=595921bc
gear.kde.org.eclass: Drop obsolete SLOT 5 blockers
Signed-off-by: Andreas Sturmlechner <asturm <AT> gentoo.org>
 eclass/gear.kde.org.eclass | 2 --
 1 file changed, 2 deletions(-)
diff --git a/eclass/gear.kde.org.eclass b/eclass/gear.kde.org.eclass
index eb05b406a7ae..8089cbb53bf7 100644
--- a/eclass/gear.kde.org.eclass
+++ b/eclass/gear.kde.org.eclass
@@ -94,7 +94,6 @@ if $(ver_test -gt 24.01.75); then
 		dragon | \
 		elisa | \
 		eventviews | \
-		ffmpegthumbs | \
 		filelight | \
 		granatier | \
 		grantlee-editor | \
@@ -268,7 +267,6 @@ if $(ver_test -gt 24.07.75); then
 	case ${PN} in
 		k3b | \
 		kde-dev-scripts | \
-		kdesdk-thumbnailers | \
 		kdevelop | \
 		kdevelop-php | \
 		kdevelop-python | \
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-22 11:23 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-08-22 11:23 UTC (permalink / raw
  To: gentoo-commits
commit:     4e03f65e4c9db309db56bf5854e8cbf3d3d58696
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Thu Aug 22 11:15:54 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Thu Aug 22 11:23:32 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=4e03f65e
llvm.org.eclass: Add 20.0.0_pre20240822 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index 4b49d35a542b..b3a22634f2e1 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -72,6 +72,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 			_LLVM_SOURCE_TYPE=snapshot
 
 			case ${PV} in
+				20.0.0_pre20240822)
+					EGIT_COMMIT=503907dc505db1e439e7061113bf84dd105f2e35
+					;;
 				20.0.0_pre20240815)
 					EGIT_COMMIT=db8ef6188cbbe2125e6d60bdef77a535105772df
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-22 17:00 Andreas Sturmlechner
  0 siblings, 0 replies; 6663+ messages in thread
From: Andreas Sturmlechner @ 2024-08-22 17:00 UTC (permalink / raw
  To: gentoo-commits
commit:     62094b61a04d451e30bbc6e71351d6dab9592976
Author:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
AuthorDate: Thu Aug 22 16:59:35 2024 +0000
Commit:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
CommitDate: Thu Aug 22 16:59:35 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=62094b61
ecm-common.eclass: Fix inverted logic in pkg_setup() re KFMIN
Closes: https://bugs.gentoo.org/938312
Signed-off-by: Andreas Sturmlechner <asturm <AT> gentoo.org>
 eclass/ecm-common.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/ecm-common.eclass b/eclass/ecm-common.eclass
index 460d702dea1f..63a23878c6f5 100644
--- a/eclass/ecm-common.eclass
+++ b/eclass/ecm-common.eclass
@@ -325,7 +325,7 @@ ecm-common-check_deps() {
 # preferring KF6.  The result is stored in _KFSLOT, which is then handed
 # to CMakeLists.txt as KFSLOT var for further use.
 ecm-common_pkg_setup() {
-	$(ver_test ${KFMIN} -lt 5.240) && return
+	$(ver_test ${KFMIN} -ge 5.240) && return
 
 	if has_version -b "kde-frameworks/ki18n:6" && {
 		! in_iuse handbook || {
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-23 19:25 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-08-23 19:25 UTC (permalink / raw
  To: gentoo-commits
commit:     e290c3c78b7acb59393f46d1d15175d6dbfc77da
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Wed Aug 21 15:19:07 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Fri Aug 23 19:25:40 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=e290c3c7
kernel-build.eclass: Apply savedconfig on top of merged configs
Move applying savedconfig from src_configure() into
kernel-build_merge_configs(), in order to make it possible to override
saved config options.  Previously, the saved config would
unconditionally overwrite everything, which could be between
inconvenient and plain broken (particularly if savedconfig contained
signing key paths referring to ${T}).
The new logic applies saved config via merge method, on top
of the default config along with ebuild and eclass overrides.  However,
MODULES_SIGN_KEY* and user config snippets do override saved config
for convenience.
Closes: https://bugs.gentoo.org/938130
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/kernel-build.eclass | 30 +++++++++++++++++++++---------
 1 file changed, 21 insertions(+), 9 deletions(-)
diff --git a/eclass/kernel-build.eclass b/eclass/kernel-build.eclass
index c4f3db0028a9..1eac9433b65c 100644
--- a/eclass/kernel-build.eclass
+++ b/eclass/kernel-build.eclass
@@ -167,8 +167,8 @@ kernel-build_pkg_setup() {
 
 # @FUNCTION: kernel-build_src_configure
 # @DESCRIPTION:
-# Prepare the toolchain for building the kernel, get the default .config
-# or restore savedconfig, and get build tree configured for modprep.
+# Prepare the toolchain for building the kernel, get the .config file,
+# and get build tree configured for modprep.
 kernel-build_src_configure() {
 	debug-print-function ${FUNCNAME} "${@}"
 
@@ -243,7 +243,6 @@ kernel-build_src_configure() {
 		MAKEARGS+=( KBZIP2="lbzip2" )
 	fi
 
-	restore_config .config
 	[[ -f .config ]] || die "Ebuild error: please copy default config into .config"
 
 	if [[ -z "${KV_LOCALVERSION}" ]]; then
@@ -594,11 +593,15 @@ kernel-build_pkg_postinst() {
 # @FUNCTION: kernel-build_merge_configs
 # @USAGE: [distro.config...]
 # @DESCRIPTION:
-# Merge the config files specified as arguments (if any) into
-# the '.config' file in the current directory, then merge
-# any user-supplied configs from ${BROOT}/etc/kernel/config.d/*.config.
-# The '.config' file must exist already and contain the base
-# configuration.
+# Merge kernel config files.  The following is merged onto the '.config'
+# file in the current directory, in order:
+#
+# 1. Config files specified as arguments.
+# 2. Default module signing and compression configuration
+#    (if applicable).
+# 3. Config saved via USE=savedconfig (if applicable).
+# 4. Module signing key specified via MODULES_SIGN_KEY* variables.
+# 5. User-supplied configs from ${BROOT}/etc/kernel/config.d/*.config.
 kernel-build_merge_configs() {
 	debug-print-function ${FUNCNAME} "${@}"
 
@@ -631,7 +634,7 @@ kernel-build_merge_configs() {
 			fi
 			if [[ ${MODULES_SIGN_KEY} == pkcs11:* || -r ${MODULES_SIGN_KEY} ]]; then
 				echo "CONFIG_MODULE_SIG_KEY=\"${MODULES_SIGN_KEY}\"" \
-					>> "${WORKDIR}/modules-sign.config"
+					>> "${WORKDIR}/modules-sign-key.config"
 			elif [[ -n ${MODULES_SIGN_KEY} ]]; then
 				die "MODULES_SIGN_KEY=${MODULES_SIGN_KEY} not found or not readable!"
 			fi
@@ -650,6 +653,15 @@ kernel-build_merge_configs() {
 		merge_configs+=( "${WORKDIR}/module-compress.config" )
 	fi
 
+	restore_config "${WORKDIR}/savedconfig.config"
+	if [[ -f ${WORKDIR}/savedconfig.config ]]; then
+		merge_configs+=( "${WORKDIR}/savedconfig.config" )
+	fi
+
+	if [[ ${KERNEL_IUSE_MODULES_SIGN} ]] && use modules-sign; then
+		merge_configs+=( "${WORKDIR}/modules-sign-key.config" )
+	fi
+
 	if [[ ${#user_configs[@]} -gt 0 ]]; then
 		elog "User config files are being applied:"
 		local x
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-23 19:25 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-08-23 19:25 UTC (permalink / raw
  To: gentoo-commits
commit:     74140c80f76f27c6f3a67103914498f33a0da8ae
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Wed Aug 21 15:22:42 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Fri Aug 23 19:25:40 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=74140c80
kernel-build.eclass: Merge two ifs in kernel-build_merge_configs()
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/kernel-build.eclass | 44 +++++++++++++++++++++-----------------------
 1 file changed, 21 insertions(+), 23 deletions(-)
diff --git a/eclass/kernel-build.eclass b/eclass/kernel-build.eclass
index 1eac9433b65c..6406f5b3c0f3 100644
--- a/eclass/kernel-build.eclass
+++ b/eclass/kernel-build.eclass
@@ -616,30 +616,28 @@ kernel-build_merge_configs() {
 
 	local merge_configs=( "${@}" )
 
-	if [[ ${KERNEL_IUSE_MODULES_SIGN} ]]; then
-		if use modules-sign; then
-			: "${MODULES_SIGN_HASH:=sha512}"
-			cat <<-EOF > "${WORKDIR}/modules-sign.config" || die
-				## Enable module signing
-				CONFIG_MODULE_SIG=y
-				CONFIG_MODULE_SIG_ALL=y
-				CONFIG_MODULE_SIG_FORCE=y
-				CONFIG_MODULE_SIG_${MODULES_SIGN_HASH^^}=y
-			EOF
-			if [[ -n ${MODULES_SIGN_KEY_CONTENTS} ]]; then
-				(umask 066 && touch "${T}/kernel_key.pem" || die)
-				echo "${MODULES_SIGN_KEY_CONTENTS}" > "${T}/kernel_key.pem" || die
-				unset MODULES_SIGN_KEY_CONTENTS
-				export MODULES_SIGN_KEY="${T}/kernel_key.pem"
-			fi
-			if [[ ${MODULES_SIGN_KEY} == pkcs11:* || -r ${MODULES_SIGN_KEY} ]]; then
-				echo "CONFIG_MODULE_SIG_KEY=\"${MODULES_SIGN_KEY}\"" \
-					>> "${WORKDIR}/modules-sign-key.config"
-			elif [[ -n ${MODULES_SIGN_KEY} ]]; then
-				die "MODULES_SIGN_KEY=${MODULES_SIGN_KEY} not found or not readable!"
-			fi
-			merge_configs+=( "${WORKDIR}/modules-sign.config" )
+	if [[ ${KERNEL_IUSE_MODULES_SIGN} ]] && use modules-sign; then
+		: "${MODULES_SIGN_HASH:=sha512}"
+		cat <<-EOF > "${WORKDIR}/modules-sign.config" || die
+			## Enable module signing
+			CONFIG_MODULE_SIG=y
+			CONFIG_MODULE_SIG_ALL=y
+			CONFIG_MODULE_SIG_FORCE=y
+			CONFIG_MODULE_SIG_${MODULES_SIGN_HASH^^}=y
+		EOF
+		if [[ -n ${MODULES_SIGN_KEY_CONTENTS} ]]; then
+			(umask 066 && touch "${T}/kernel_key.pem" || die)
+			echo "${MODULES_SIGN_KEY_CONTENTS}" > "${T}/kernel_key.pem" || die
+			unset MODULES_SIGN_KEY_CONTENTS
+			export MODULES_SIGN_KEY="${T}/kernel_key.pem"
+		fi
+		if [[ ${MODULES_SIGN_KEY} == pkcs11:* || -r ${MODULES_SIGN_KEY} ]]; then
+			echo "CONFIG_MODULE_SIG_KEY=\"${MODULES_SIGN_KEY}\"" \
+				>> "${WORKDIR}/modules-sign-key.config"
+		elif [[ -n ${MODULES_SIGN_KEY} ]]; then
+			die "MODULES_SIGN_KEY=${MODULES_SIGN_KEY} not found or not readable!"
 		fi
+		merge_configs+=( "${WORKDIR}/modules-sign.config" )
 	fi
 
 	# Only semi-related but let's use that to avoid changing stable ebuilds.
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-25  0:49 Jason Zaman
  0 siblings, 0 replies; 6663+ messages in thread
From: Jason Zaman @ 2024-08-25  0:49 UTC (permalink / raw
  To: gentoo-commits
commit:     75d12a333e1866ad6affa62b95fe88be48f5b118
Author:     Rahul Sandhu <rahul <AT> sandhuservices <DOT> dev>
AuthorDate: Fri Aug  2 19:37:54 2024 +0000
Commit:     Jason Zaman <perfinion <AT> gentoo <DOT> org>
CommitDate: Sun Aug 25 00:48:19 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=75d12a33
selinux-policy-2.eclass: Load unconfined module for mcs/mls policy types
Currently, there doesn't seem to be a reason to block the loading of
the unconfined policy module on the mcs and mls policy types. Let's
ensure we load the unconfined policy module unconditionally in the
eclass.
The loading of the unconfined policy module was initially blocked in
82e30f21ab85b6de3ebc45ae10b28b9bd280e4a1, however as far as I can tell,
there is no longer a reason to do this. Considering there are use flags
for sec-policy/selinux-base and sec-policy/selinux-base-policy for the
unconfined policy module, and using the unconfined policy module is
supported for the mcs and mls policy types, it makes sense to no longer
block the loading of the policy module. It is also worth mentioning
that grabbing an selinux stage3 has the unconfined policy module
already loaded.
As the strict policy is effectively the targeted policy without support
for the unconfined domain, it makes sense to not load the unconfined
module for strict policy types. Let's keep a conitional check for the
strict policy to ensure we don't load the unconfined module in that
case.
Closes: https://bugs.gentoo.org/933709
Closes: https://github.com/gentoo/gentoo/pull/37931
Signed-off-by: Rahul Sandhu <rahul <AT> sandhuservices.dev>
Signed-off-by: Jason Zaman <perfinion <AT> gentoo.org>
 eclass/selinux-policy-2.eclass | 12 ++++--------
 1 file changed, 4 insertions(+), 8 deletions(-)
diff --git a/eclass/selinux-policy-2.eclass b/eclass/selinux-policy-2.eclass
index ad760673cab1..e7d6cd9a9e5f 100644
--- a/eclass/selinux-policy-2.eclass
+++ b/eclass/selinux-policy-2.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2023 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # Eclass for installing SELinux policy, and optionally
@@ -260,13 +260,9 @@ selinux-policy-2_pkg_postinst() {
 	local COMMAND
 
 	for i in ${POLICY_TYPES}; do
-		if [[ "${MODS}" = "unconfined" ]]; then
-			case ${i} in
-			strict|mcs|mls)
-				einfo "Ignoring loading of unconfined module in ${i} module store.";
-				continue
-				;;
-			esac
+		if [[ "${i}" == "strict" ]] && [[ "${MODS}" = "unconfined" ]]; then
+			einfo "Ignoring loading of unconfined module in strict module store.";
+			continue;
 		fi
 
 		einfo "Inserting the following modules into the $i module store: ${MODS}"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-25 15:37 Andrew Ammerlaan
  0 siblings, 0 replies; 6663+ messages in thread
From: Andrew Ammerlaan @ 2024-08-25 15:37 UTC (permalink / raw
  To: gentoo-commits
commit:     0dd42ac730fd855166651d81e3f3d0db671e7328
Author:     Andrew Ammerlaan <andrewammerlaan <AT> gentoo <DOT> org>
AuthorDate: Sun Aug 25 15:08:55 2024 +0000
Commit:     Andrew Ammerlaan <andrewammerlaan <AT> gentoo <DOT> org>
CommitDate: Sun Aug 25 15:36:53 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=0dd42ac7
kernel-build.eclass: fix module signing with unspecified key
MODULES_SIGN_KEY may be unset when using USE=modules-sign. Fix an issue
introduced in e290c3c78b7acb59393f46d1d15175d6dbfc77da that breaks this
configuration due to modules-sign-key.config not existing.
Signed-off-by: Andrew Ammerlaan <andrewammerlaan <AT> gentoo.org>
Closes: https://github.com/gentoo/gentoo/pull/38287
Signed-off-by: Andrew Ammerlaan <andrewammerlaan <AT> gentoo.org>
 eclass/kernel-build.eclass | 26 +++++++++++++-------------
 1 file changed, 13 insertions(+), 13 deletions(-)
diff --git a/eclass/kernel-build.eclass b/eclass/kernel-build.eclass
index 6406f5b3c0f3..be02920162f4 100644
--- a/eclass/kernel-build.eclass
+++ b/eclass/kernel-build.eclass
@@ -625,18 +625,6 @@ kernel-build_merge_configs() {
 			CONFIG_MODULE_SIG_FORCE=y
 			CONFIG_MODULE_SIG_${MODULES_SIGN_HASH^^}=y
 		EOF
-		if [[ -n ${MODULES_SIGN_KEY_CONTENTS} ]]; then
-			(umask 066 && touch "${T}/kernel_key.pem" || die)
-			echo "${MODULES_SIGN_KEY_CONTENTS}" > "${T}/kernel_key.pem" || die
-			unset MODULES_SIGN_KEY_CONTENTS
-			export MODULES_SIGN_KEY="${T}/kernel_key.pem"
-		fi
-		if [[ ${MODULES_SIGN_KEY} == pkcs11:* || -r ${MODULES_SIGN_KEY} ]]; then
-			echo "CONFIG_MODULE_SIG_KEY=\"${MODULES_SIGN_KEY}\"" \
-				>> "${WORKDIR}/modules-sign-key.config"
-		elif [[ -n ${MODULES_SIGN_KEY} ]]; then
-			die "MODULES_SIGN_KEY=${MODULES_SIGN_KEY} not found or not readable!"
-		fi
 		merge_configs+=( "${WORKDIR}/modules-sign.config" )
 	fi
 
@@ -657,7 +645,19 @@ kernel-build_merge_configs() {
 	fi
 
 	if [[ ${KERNEL_IUSE_MODULES_SIGN} ]] && use modules-sign; then
-		merge_configs+=( "${WORKDIR}/modules-sign-key.config" )
+		if [[ -n ${MODULES_SIGN_KEY_CONTENTS} ]]; then
+			(umask 066 && touch "${T}/kernel_key.pem" || die)
+			echo "${MODULES_SIGN_KEY_CONTENTS}" > "${T}/kernel_key.pem" || die
+			unset MODULES_SIGN_KEY_CONTENTS
+			export MODULES_SIGN_KEY="${T}/kernel_key.pem"
+		fi
+		if [[ ${MODULES_SIGN_KEY} == pkcs11:* || -r ${MODULES_SIGN_KEY} ]]; then
+			echo "CONFIG_MODULE_SIG_KEY=\"${MODULES_SIGN_KEY}\"" \
+				>> "${WORKDIR}/modules-sign-key.config"
+			merge_configs+=( "${WORKDIR}/modules-sign-key.config" )
+		elif [[ -n ${MODULES_SIGN_KEY} ]]; then
+			die "MODULES_SIGN_KEY=${MODULES_SIGN_KEY} not found or not readable!"
+		fi
 	fi
 
 	if [[ ${#user_configs[@]} -gt 0 ]]; then
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-26  6:34 Andreas Sturmlechner
  0 siblings, 0 replies; 6663+ messages in thread
From: Andreas Sturmlechner @ 2024-08-26  6:34 UTC (permalink / raw
  To: gentoo-commits
commit:     37f7986b816b46aaca8f96b49582c9c73bebaf5c
Author:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
AuthorDate: Sun Aug 25 22:29:07 2024 +0000
Commit:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
CommitDate: Mon Aug 26 06:33:46 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=37f7986b
ecm-common.eclass: Add _ecm-common-check_deps to simplify pkg_setup()
Bug: https://bugs.gentoo.org/938507
Signed-off-by: Andreas Sturmlechner <asturm <AT> gentoo.org>
 eclass/ecm-common.eclass | 43 ++++++++++++++++++++++++++++++++++---------
 1 file changed, 34 insertions(+), 9 deletions(-)
diff --git a/eclass/ecm-common.eclass b/eclass/ecm-common.eclass
index 63a23878c6f5..c0c2b4f7e644 100644
--- a/eclass/ecm-common.eclass
+++ b/eclass/ecm-common.eclass
@@ -309,6 +309,38 @@ _ecm-common_summary() {
 	_EOF_
 }
 
+# @FUNCTION: _ecm-common-check_deps
+# @INTERNAL
+# @DESCRIPTION:
+# Check existence of requested KF6 dependencies.
+_ecm-common-check_deps() {
+	local chk=0
+	case ${1} in
+		i18n)
+			if [[ ${ECM_I18N} ]]; then
+				chk=$(has_version -b "kde-frameworks/ki18n:6")
+			fi
+			;;
+		doctools)
+			if [[ ${ECM_HANDBOOK} ]] && in_iuse handbook; then
+				if use handbook; then
+					chk=$(has_version -b "kde-frameworks/kdoctools:6")
+				fi
+			fi
+			;;
+		kcmutils)
+			if [[ ${ECM_KCM_TARGETS} ]]; then
+				chk=$(has_version -b "kde-frameworks/kcmutils:6")
+			fi
+			;;
+		*)
+			eerror "Unknown value for _ecm-common-check_deps()"
+			die "Value ${1} is not supported"
+			;;
+	esac
+	return ${chk}
+}
+
 # @FUNCTION: ecm-common-check_deps
 # @DESCRIPTION:
 # Override this to add more KF6 has_version checks to pkg_setup(),
@@ -327,15 +359,8 @@ ecm-common-check_deps() {
 ecm-common_pkg_setup() {
 	$(ver_test ${KFMIN} -ge 5.240) && return
 
-	if has_version -b "kde-frameworks/ki18n:6" && {
-		! in_iuse handbook || {
-			in_iuse handbook && use handbook &&
-				has_version -b "kde-frameworks/kdoctools:6"
-			}
-		} && {
-			! [[ ${ECM_KCM_TARGETS} ]] ||
-				has_version -b "kde-frameworks/kcmutils:6"
-		} && ecm-common-check_deps
+	if _ecm-common-check_deps i18n && _ecm-common-check_deps doctools &&
+		_ecm-common-check_deps kcmutils && ecm-common-check_deps
 	then
 		_KFSLOT=6
 	else
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-26 13:04 Ulrich Müller
  0 siblings, 0 replies; 6663+ messages in thread
From: Ulrich Müller @ 2024-08-26 13:04 UTC (permalink / raw
  To: gentoo-commits
commit:     dc3043d2bcf8394e96d8f81ec6daf30641afe3d4
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Tue Aug 20 17:58:55 2024 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Mon Aug 26 13:04:24 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=dc3043d2
eqawarn.eclass: Mark as DEAD
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 eclass/eqawarn.eclass | 1 +
 1 file changed, 1 insertion(+)
diff --git a/eclass/eqawarn.eclass b/eclass/eqawarn.eclass
index 288976182fb3..df6b13151d74 100644
--- a/eclass/eqawarn.eclass
+++ b/eclass/eqawarn.eclass
@@ -1,6 +1,7 @@
 # Copyright 1999-2022 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
+# @DEAD
 # @ECLASS: eqawarn.eclass
 # @MAINTAINER:
 # base-system@gentoo.org
^ permalink raw reply related	[flat|nested] 6663+ messages in thread
* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-26 13:04 Ulrich Müller
  0 siblings, 0 replies; 6663+ messages in thread
From: Ulrich Müller @ 2024-08-26 13:04 UTC (permalink / raw
  To: gentoo-commits
commit:     17c11b3d8225ff68bf081488e0285ed117a3c1c6
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Mon Aug 26 12:23:04 2024 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Mon Aug 26 13:04:25 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=17c11b3d
plasma-mobile.kde.org.eclass: Mark as DEAD
Acked-by: Andreas Sturmlechner <asturm <AT> gentoo.org>
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 eclass/plasma-mobile.kde.org.eclass | 1 +
 1 file changed, 1 insertion(+)
diff --git a/eclass/plasma-mobile.kde.org.eclass b/eclass/plasma-mobile.kde.org.eclass
index 9fd54100d24e..3349f90745bd 100644
--- a/eclass/plasma-mobile.kde.org.eclass
+++ b/eclass/plasma-mobile.kde.org.eclass
@@ -1,6 +1,7 @@
 # Copyright 1999-2023 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
+# @DEAD
 # @ECLASS: plasma-mobile.kde.org.eclass
 # @MAINTAINER:
 # kde@gentoo.org
^ permalink raw reply related	[flat|nested] 6663+ messages in thread
* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-26 13:04 Ulrich Müller
  0 siblings, 0 replies; 6663+ messages in thread
From: Ulrich Müller @ 2024-08-26 13:04 UTC (permalink / raw
  To: gentoo-commits
commit:     d1d31339c50dceed5a453793a71298c29698aa3d
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Tue Aug 20 17:58:30 2024 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Mon Aug 26 13:04:23 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=d1d31339
versionator.eclass: Mark as DEAD
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 eclass/versionator.eclass | 1 +
 1 file changed, 1 insertion(+)
diff --git a/eclass/versionator.eclass b/eclass/versionator.eclass
index 8a1066a0fd30..1e491860b6ca 100644
--- a/eclass/versionator.eclass
+++ b/eclass/versionator.eclass
@@ -1,6 +1,7 @@
 # Copyright 1999-2020 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
+# @DEAD
 # @ECLASS: versionator.eclass
 # @MAINTAINER:
 # Jonathan Callen <jcallen@gentoo.org>
^ permalink raw reply related	[flat|nested] 6663+ messages in thread
* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-26 13:04 Ulrich Müller
  0 siblings, 0 replies; 6663+ messages in thread
From: Ulrich Müller @ 2024-08-26 13:04 UTC (permalink / raw
  To: gentoo-commits
commit:     1118079e4f7b3acb43fa8206a6c9f2f02187c44f
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Tue Aug 20 17:58:41 2024 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Mon Aug 26 13:04:23 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=1118079e
eapi7-ver.eclass: Mark as DEAD
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 eclass/eapi7-ver.eclass | 1 +
 1 file changed, 1 insertion(+)
diff --git a/eclass/eapi7-ver.eclass b/eclass/eapi7-ver.eclass
index a23e76ad3ee3..85c0856f73b3 100644
--- a/eclass/eapi7-ver.eclass
+++ b/eclass/eapi7-ver.eclass
@@ -1,6 +1,7 @@
 # Copyright 1999-2021 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
+# @DEAD
 # @ECLASS: eapi7-ver.eclass
 # @MAINTAINER:
 # PMS team <pms@gentoo.org>
^ permalink raw reply related	[flat|nested] 6663+ messages in thread
* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-30 19:10 Andrew Ammerlaan
  0 siblings, 0 replies; 6663+ messages in thread
From: Andrew Ammerlaan @ 2024-08-30 19:10 UTC (permalink / raw
  To: gentoo-commits
commit:     297e387c75abadc31502f37fd456a1f90b302ad4
Author:     Andrew Ammerlaan <andrewammerlaan <AT> gentoo <DOT> org>
AuthorDate: Fri Aug 30 13:01:53 2024 +0000
Commit:     Andrew Ammerlaan <andrewammerlaan <AT> gentoo <DOT> org>
CommitDate: Fri Aug 30 19:07:05 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=297e387c
kernel-build.eclass: adjust missing .config error messages
kernel-build_merge_configs should always be called first nowadays
because it applies the savedconfig.
Signed-off-by: Andrew Ammerlaan <andrewammerlaan <AT> gentoo.org>
Closes: https://github.com/gentoo/gentoo/pull/38345
Signed-off-by: Andrew Ammerlaan <andrewammerlaan <AT> gentoo.org>
 eclass/kernel-build.eclass | 7 +++++--
 1 file changed, 5 insertions(+), 2 deletions(-)
diff --git a/eclass/kernel-build.eclass b/eclass/kernel-build.eclass
index be02920162f4..d92076d61c04 100644
--- a/eclass/kernel-build.eclass
+++ b/eclass/kernel-build.eclass
@@ -243,7 +243,7 @@ kernel-build_src_configure() {
 		MAKEARGS+=( KBZIP2="lbzip2" )
 	fi
 
-	[[ -f .config ]] || die "Ebuild error: please copy default config into .config"
+	[[ -f .config ]] || die "Ebuild error: No .config, kernel-build_merge_configs was not called."
 
 	if [[ -z "${KV_LOCALVERSION}" ]]; then
 		KV_LOCALVERSION=$(sed -n -e 's#^CONFIG_LOCALVERSION="\(.*\)"$#\1#p' \
@@ -602,10 +602,13 @@ kernel-build_pkg_postinst() {
 # 3. Config saved via USE=savedconfig (if applicable).
 # 4. Module signing key specified via MODULES_SIGN_KEY* variables.
 # 5. User-supplied configs from ${BROOT}/etc/kernel/config.d/*.config.
+#
+# This function must be called by the ebuild in the src_prepare phase.
 kernel-build_merge_configs() {
 	debug-print-function ${FUNCNAME} "${@}"
 
-	[[ -f .config ]] || die "${FUNCNAME}: .config does not exist"
+	[[ -f .config ]] ||
+		die "${FUNCNAME}: No .config, please copy default config into .config"
 	has .config "${@}" &&
 		die "${FUNCNAME}: do not specify .config as parameter"
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-30 19:43 Andrew Ammerlaan
  0 siblings, 0 replies; 6663+ messages in thread
From: Andrew Ammerlaan @ 2024-08-30 19:43 UTC (permalink / raw
  To: gentoo-commits
commit:     660b9cf9f08fd27fca32f1bd1bd8e95ee7a635bc
Author:     Andrew Ammerlaan <andrewammerlaan <AT> gentoo <DOT> org>
AuthorDate: Fri Aug 30 19:41:18 2024 +0000
Commit:     Andrew Ammerlaan <andrewammerlaan <AT> gentoo <DOT> org>
CommitDate: Fri Aug 30 19:43:32 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=660b9cf9
kernel-build.eclass: BDEPEND on dev-lang/perl
Some config options (that we enable by default, e.g. CONFIG_CRYPTO_POLY1305)
cause perl scripts to be run during the build.
Closes: https://bugs.gentoo.org/930390
Signed-off-by: Andrew Ammerlaan <andrewammerlaan <AT> gentoo.org>
 eclass/kernel-build.eclass | 1 +
 1 file changed, 1 insertion(+)
diff --git a/eclass/kernel-build.eclass b/eclass/kernel-build.eclass
index d92076d61c04..10fd0cca2cc5 100644
--- a/eclass/kernel-build.eclass
+++ b/eclass/kernel-build.eclass
@@ -47,6 +47,7 @@ BDEPEND="
 	${PYTHON_DEPS}
 	app-alternatives/cpio
 	app-alternatives/bc
+	dev-lang/perl
 	sys-devel/bison
 	sys-devel/flex
 	virtual/libelf
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-08-31  8:33 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-08-31  8:33 UTC (permalink / raw
  To: gentoo-commits
commit:     b88061f78e9d212f4bbd9611cd4c0e41a8baf549
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Aug 31 08:29:18 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat Aug 31 08:32:48 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=b88061f7
llvm.org.eclass: Add 20.0.0_pre20240830 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index b3a22634f2e1..da943081b9bf 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -72,6 +72,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 			_LLVM_SOURCE_TYPE=snapshot
 
 			case ${PV} in
+				20.0.0_pre20240830)
+					EGIT_COMMIT=5500e21942f7047344b6fee62d3e08c0ba2f9182
+					;;
 				20.0.0_pre20240822)
 					EGIT_COMMIT=503907dc505db1e439e7061113bf84dd105f2e35
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-01  9:59 Miroslav Šulc
  0 siblings, 0 replies; 6663+ messages in thread
From: Miroslav Šulc @ 2024-09-01  9:59 UTC (permalink / raw
  To: gentoo-commits
commit:     a9f58305b8287641626535a315958a51e5ab34a5
Author:     Volkmar W. Pogatzki <gentoo <AT> pogatzki <DOT> net>
AuthorDate: Sat Aug 10 07:18:38 2024 +0000
Commit:     Miroslav Šulc <fordfrog <AT> gentoo <DOT> org>
CommitDate: Sun Sep  1 09:58:53 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=a9f58305
java-utils-2.eclass: remove 'ant -lib' from comment of java-pkg_jarfrom
since it is already advised to not use it
Signed-off-by: Volkmar W. Pogatzki <gentoo <AT> pogatzki.net>
Signed-off-by: Miroslav Šulc <fordfrog <AT> gentoo.org>
 eclass/java-utils-2.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/java-utils-2.eclass b/eclass/java-utils-2.eclass
index 9c657cc4c1f9..647f25e2c987 100644
--- a/eclass/java-utils-2.eclass
+++ b/eclass/java-utils-2.eclass
@@ -1140,7 +1140,7 @@ java-pkg_jarfrom() {
 # @USAGE: [--build-only] [--runtime-only] [--with-dependencies] <package1>[,<package2>...]
 # @DESCRIPTION:
 # Get the classpath provided by any number of packages
-# Among other things, this can be passed to 'javac -classpath' or 'ant -lib'.
+# Among other things, this can be passed to 'javac -classpath'.
 # The providing packages are recorded as dependencies into package.env DEPEND
 # line, unless "--build-only" is passed as the very first argument, for jars
 # that have to be present only at build time and are not needed on runtime
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-01  9:59 Miroslav Šulc
  0 siblings, 0 replies; 6663+ messages in thread
From: Miroslav Šulc @ 2024-09-01  9:59 UTC (permalink / raw
  To: gentoo-commits
commit:     199aa0b14194a2a17d43d396c9e341b15c33b719
Author:     Volkmar W. Pogatzki <gentoo <AT> pogatzki <DOT> net>
AuthorDate: Tue Aug  6 06:54:55 2024 +0000
Commit:     Miroslav Šulc <fordfrog <AT> gentoo <DOT> org>
CommitDate: Sun Sep  1 09:58:53 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=199aa0b1
java-pkg-2.eclass: mark functions as deprecated which depend on java-ant-2.eclass
Deprecating java-ant-2.eclass would be the next step.
Signed-off-by: Volkmar W. Pogatzki <gentoo <AT> pogatzki.net>
Signed-off-by: Miroslav Šulc <fordfrog <AT> gentoo.org>
 eclass/java-pkg-2.eclass | 4 +++-
 1 file changed, 3 insertions(+), 1 deletion(-)
diff --git a/eclass/java-pkg-2.eclass b/eclass/java-pkg-2.eclass
index c17a9db26b3b..0409a7c70e0e 100644
--- a/eclass/java-pkg-2.eclass
+++ b/eclass/java-pkg-2.eclass
@@ -1,4 +1,4 @@
-# Copyright 2004-2023 Gentoo Authors
+# Copyright 2004-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: java-pkg-2.eclass
@@ -63,6 +63,7 @@ java-pkg-2_src_prepare() {
 
 
 # @FUNCTION: java-pkg-2_src_compile
+# @DEPRECATED: none
 # @DESCRIPTION:
 # Default src_compile for java packages
 #
@@ -98,6 +99,7 @@ java-pkg-2_src_compile() {
 }
 
 # @FUNCTION: java-pkg-2_src_test
+# @DEPRECATED: none
 # @DESCRIPTION:
 # src_test, not exported.
 java-pkg-2_src_test() {
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-01  9:59 Miroslav Šulc
  0 siblings, 0 replies; 6663+ messages in thread
From: Miroslav Šulc @ 2024-09-01  9:59 UTC (permalink / raw
  To: gentoo-commits
commit:     f71821015ff790d630acbb54962d4674b9b8b4a6
Author:     Volkmar W. Pogatzki <gentoo <AT> pogatzki <DOT> net>
AuthorDate: Tue Aug 13 06:36:46 2024 +0000
Commit:     Miroslav Šulc <fordfrog <AT> gentoo <DOT> org>
CommitDate: Sun Sep  1 09:58:53 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=f7182101
java-pkg-2.eclass: remove unused for commons.apache.org packages
removes a condition which used to provide SRC_URI and HOMEPAGE for
packages from commons.apache.org but is completely unused due to not
providing verify-sig.
Signed-off-by: Volkmar W. Pogatzki <gentoo <AT> pogatzki.net>
Signed-off-by: Miroslav Šulc <fordfrog <AT> gentoo.org>
 eclass/java-pkg-2.eclass | 6 ------
 1 file changed, 6 deletions(-)
diff --git a/eclass/java-pkg-2.eclass b/eclass/java-pkg-2.eclass
index 0409a7c70e0e..df024bbadf51 100644
--- a/eclass/java-pkg-2.eclass
+++ b/eclass/java-pkg-2.eclass
@@ -39,12 +39,6 @@ DEPEND="${JAVA_PKG_E_DEPEND}"
 # Nothing special for RDEPEND... just the same as DEPEND.
 RDEPEND="${DEPEND}"
 
-# Commons packages follow the same rules so do it here
-if [[ ${CATEGORY} = dev-java && ${PN} = commons-* ]]; then
-	HOMEPAGE="http://commons.apache.org/${PN#commons-}/"
-	SRC_URI="mirror://apache/${PN/-///}/source/${P}-src.tar.gz"
-fi
-
 
 # @FUNCTION: java-pkg-2_pkg_setup
 # @DESCRIPTION:
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-01  9:59 Miroslav Šulc
  0 siblings, 0 replies; 6663+ messages in thread
From: Miroslav Šulc @ 2024-09-01  9:59 UTC (permalink / raw
  To: gentoo-commits
commit:     b4b2bc17326e87df2021805bbbc39b46e70e1b2b
Author:     Volkmar W. Pogatzki <gentoo <AT> pogatzki <DOT> net>
AuthorDate: Tue Aug  6 06:49:46 2024 +0000
Commit:     Miroslav Šulc <fordfrog <AT> gentoo <DOT> org>
CommitDate: Sun Sep  1 09:58:53 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=b4b2bc17
java-ant-2.eclass: mark java-ant-2 eclass as deprecated
Signed-off-by: Volkmar W. Pogatzki <gentoo <AT> pogatzki.net>
Closes: https://github.com/gentoo/gentoo/pull/38203
Signed-off-by: Miroslav Šulc <fordfrog <AT> gentoo.org>
 eclass/java-ant-2.eclass | 1 +
 1 file changed, 1 insertion(+)
diff --git a/eclass/java-ant-2.eclass b/eclass/java-ant-2.eclass
index b0d2fb216b10..1ed8b23ee6cd 100644
--- a/eclass/java-ant-2.eclass
+++ b/eclass/java-ant-2.eclass
@@ -2,6 +2,7 @@
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: java-ant-2.eclass
+# @DEPRECATED: none
 # @MAINTAINER:
 # java@gentoo.org
 # @AUTHOR:
^ permalink raw reply related	[flat|nested] 6663+ messages in thread
* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-01 11:05 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-01 11:05 UTC (permalink / raw
  To: gentoo-commits
commit:     a948d340bd94e480398c3b55a53bbddae77d1c9c
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Sep  1 10:59:49 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Sep  1 11:04:41 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=a948d340
guile-single.eclass: fix eclassdoc issues
eclass-to-manpage noticed these.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/guile-single.eclass | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/eclass/guile-single.eclass b/eclass/guile-single.eclass
index 41ede32928bc..91f6036139da 100644
--- a/eclass/guile-single.eclass
+++ b/eclass/guile-single.eclass
@@ -2,20 +2,20 @@
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: guile-single.eclass
-# @PROVIDES: guile-utils
 # @MAINTAINER:
 # Gentoo Scheme project <scheme@gentoo.org>
 # @AUTHOR:
 # Author: Arsen Arsenović <arsen@gentoo.org>
-# Inspired by prior work in the Gentoo Python ecosystem.
-# @BLURB: Utilities for packages that build against a single Guile.
 # @SUPPORTED_EAPIS: 8
 # @PROVIDES: guile-utils
+# @BLURB: Utilities for packages that build against a single Guile.
 # @DESCRIPTION:
 # This eclass facilitates packages building against a single slot of
 # Guile, which is normally something that uses Guile for extending, like
 # GNU Make, or for programs built in Guile, like Haunt.
 #
+# Inspired by prior work in the Gentoo Python ecosystem.
+#
 # These packages should use guile_gen_cond_dep to generate a dependency
 # string for their Guile package dependencies (i.e. other Guile single-
 # and multi-implementation packages).  They should also utilize
^ permalink raw reply related	[flat|nested] 6663+ messages in thread
* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-01 11:05 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-01 11:05 UTC (permalink / raw
  To: gentoo-commits
commit:     d2f9fd205167416d26858b2c5dd6be463389fdef
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Sep  1 11:01:51 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Sep  1 11:04:42 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=d2f9fd20
guile.eclass: fix eclassdoc issues
eclass-to-manpage noticed these.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/guile.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/guile.eclass b/eclass/guile.eclass
index d487d765e86a..9310cd060da9 100644
--- a/eclass/guile.eclass
+++ b/eclass/guile.eclass
@@ -2,13 +2,13 @@
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: guile.eclass
-# @PROVIDES: guile-utils
 # @MAINTAINER:
 # Gentoo Scheme project <scheme@gentoo.org>
 # @AUTHOR:
 # Author: Arsen Arsenović <arsen@gentoo.org>
 # Inspired by prior work in the Gentoo Python ecosystem.
 # @SUPPORTED_EAPIS: 8
+# @PROVIDES: guile-utils
 # @BLURB: Utilities for packages multi-implementation Guile packages.
 # @DESCRIPTION:
 # This eclass facilitates building against many Guile implementations,
^ permalink raw reply related	[flat|nested] 6663+ messages in thread
* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-01 11:05 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-01 11:05 UTC (permalink / raw
  To: gentoo-commits
commit:     ef76274515b2653756bf2122f4be03681e94a954
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Sep  1 11:01:13 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Sep  1 11:04:42 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=ef762745
guile-utils.eclass: fix eclassdoc issues
eclass-to-manpage noticed these.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/guile-utils.eclass | 5 +++--
 1 file changed, 3 insertions(+), 2 deletions(-)
diff --git a/eclass/guile-utils.eclass b/eclass/guile-utils.eclass
index 3f122f63a36f..09ca5aabe502 100644
--- a/eclass/guile-utils.eclass
+++ b/eclass/guile-utils.eclass
@@ -6,13 +6,14 @@
 # Gentoo Scheme project <scheme@gentoo.org>
 # @AUTHOR:
 # Author: Arsen Arsenović <arsen@gentoo.org>
-# Inspired by prior work in the Gentoo Python ecosystem.
-# @BLURB: Common code between GNU Guile-related eclasses and ebuilds.
 # @SUPPORTED_EAPIS: 8
+# @BLURB: Common code between GNU Guile-related eclasses and ebuilds.
 # @DESCRIPTION:
 # This eclass contains various bits of common code between
 # dev-scheme/guile, Guile multi-implementation ebuilds and Guile
 # single-implementation ebuilds.
+#
+# Inspired by prior work in the Gentoo Python ecosystem.
 
 case "${EAPI}" in
 	8) ;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-01 11:05 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-01 11:05 UTC (permalink / raw
  To: gentoo-commits
commit:     a5adc69b4bffaf47a520f16dad03472f2f21defc
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Sep  1 11:02:45 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Sep  1 11:04:43 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=a5adc69b
java-ant-2.eclass: fix eclassdoc issues
eclass-to-manpage noticed these.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/java-ant-2.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/java-ant-2.eclass b/eclass/java-ant-2.eclass
index 1ed8b23ee6cd..ef7d306dc9b1 100644
--- a/eclass/java-ant-2.eclass
+++ b/eclass/java-ant-2.eclass
@@ -2,7 +2,6 @@
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: java-ant-2.eclass
-# @DEPRECATED: none
 # @MAINTAINER:
 # java@gentoo.org
 # @AUTHOR:
@@ -11,6 +10,7 @@
 # @SUPPORTED_EAPIS: 7 8
 # @PROVIDES: java-utils-2
 # @BLURB: eclass for ant based Java packages
+# @DEPRECATED: none
 # @DESCRIPTION:
 # Eclass for Ant-based Java packages. Provides support for both automatic and
 # manual manipulation of build.xml files. Should be inherited after java-pkg-2
^ permalink raw reply related	[flat|nested] 6663+ messages in thread
* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-03  4:22 Ionen Wolkens
  0 siblings, 0 replies; 6663+ messages in thread
From: Ionen Wolkens @ 2024-09-03  4:22 UTC (permalink / raw
  To: gentoo-commits
commit:     94d87c3124305490189c803dccdd30b034466892
Author:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
AuthorDate: Tue Sep  3 00:42:16 2024 +0000
Commit:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
CommitDate: Tue Sep  3 04:20:22 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=94d87c31
qt6-build.eclass: force cmake's log level back to STATUS
Unless set -DQT_FEATURE_developer_build (which is more involved),
Qt changes the default log level to NOTICE and then, in current
6.8.9999, the configuration summaries were seemingly moved to STATUS
leaving them hidden as just:
-- Configuration summary has been written to ..._build/config.summary
Not new, but the NOTICE log level also hides the result of the various
tests such as:
-- Performing Test HAVE_egl_x11 - Success
Unclear if 6.8.x will keep summaries that way (feel this is a downside
for upstream as well, and perhaps is not intentional as part of some
refactoring), but either way STATUS makes the build.log a lot more
useful.
Signed-off-by: Ionen Wolkens <ionen <AT> gentoo.org>
 eclass/qt6-build.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/qt6-build.eclass b/eclass/qt6-build.eclass
index 24b857dab53f..3cd8b606c235 100644
--- a/eclass/qt6-build.eclass
+++ b/eclass/qt6-build.eclass
@@ -147,6 +147,9 @@ qt6-build_src_configure() {
 	fi
 
 	local defaultcmakeargs=(
+		# cmake defaults to "STATUS" but Qt changes that to "NOTICE" which
+		# hides a lot of information that is useful for bug reports
+		--log-level=STATUS
 		# see _qt6-build_create_user_facing_links
 		-DINSTALL_PUBLICBINDIR="${QT6_PREFIX}"/bin
 		# note that if qtbase was built with tests, this is default ON
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-03  8:58 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-03  8:58 UTC (permalink / raw
  To: gentoo-commits
commit:     074703d997f81d4632e8f69d88a113c81e3220d4
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Sep  3 06:50:38 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Sep  3 08:58:13 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=074703d9
kernel-build.eclass: handle CTF if enabled
genpatches will soon be adding optional CTF debug information support
via a patch. If it's enabled, we need to call a few special make targets
to create and install the CTF information. We also need to avoid stripping
the CTF archive.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/kernel-build.eclass | 13 ++++++++++++-
 1 file changed, 12 insertions(+), 1 deletion(-)
diff --git a/eclass/kernel-build.eclass b/eclass/kernel-build.eclass
index 10fd0cca2cc5..1fc86c4a2208 100644
--- a/eclass/kernel-build.eclass
+++ b/eclass/kernel-build.eclass
@@ -296,7 +296,13 @@ kernel-build_src_configure() {
 kernel-build_src_compile() {
 	debug-print-function ${FUNCNAME} "${@}"
 
-	emake O="${WORKDIR}"/build "${MAKEARGS[@]}" all
+	local targets=( all )
+
+	if grep -q "CONFIG_CTF=y" "${WORKDIR}/modprep/.config"; then
+		targets+=( ctf )
+	fi
+
+	emake O="${WORKDIR}"/build "${MAKEARGS[@]}" "${targets[@]}"
 }
 
 # @FUNCTION: kernel-build_src_test
@@ -337,6 +343,10 @@ kernel-build_src_install() {
 		targets+=( dtbs_install )
 	fi
 
+	if grep -q "CONFIG_CTF=y" "${WORKDIR}/modprep/.config"; then
+		targets+=( ctf_install )
+	fi
+
 	# Use the kernel build system to strip, this ensures the modules
 	# are stripped *before* they are signed or compressed.
 	local strip_args
@@ -430,6 +440,7 @@ kernel-build_src_install() {
 			mv "build/vmlinux" "${ED}${kernel_dir}/vmlinux" || die
 		fi
 		dostrip -x "${kernel_dir}/vmlinux"
+		dostrip -x "${kernel_dir}/vmlinux.ctfa"
 	fi
 
 	# strip empty directories
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-03  9:40 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-03  9:40 UTC (permalink / raw
  To: gentoo-commits
commit:     983fe336a7571f822655c25e0785f067de80c64c
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Sep  3 09:38:04 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Sep  3 09:40:45 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=983fe336
kernel-build.eclass: call ctf_install for tests too
As suggested by Andrew at https://github.com/gentoo/gentoo/pull/38392#discussion_r1741574357.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/kernel-build.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/kernel-build.eclass b/eclass/kernel-build.eclass
index 1fc86c4a2208..3836bef1276b 100644
--- a/eclass/kernel-build.eclass
+++ b/eclass/kernel-build.eclass
@@ -321,7 +321,7 @@ kernel-build_src_test() {
 
 	emake O="${WORKDIR}"/build "${MAKEARGS[@]}" \
 		INSTALL_MOD_PATH="${T}" INSTALL_MOD_STRIP="${strip_args}" \
-		modules_install
+		modules_install ctf_install
 
 	kernel-install_test "${KV_FULL}" \
 		"${WORKDIR}/build/$(dist-kernel_get_image_path)" \
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-04 20:33 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-09-04 20:33 UTC (permalink / raw
  To: gentoo-commits
commit:     ae9987ba9684a83a0310b42e28299c545e0e5468
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Sep  4 14:38:34 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Wed Sep  4 20:33:03 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=ae9987ba
kernel-build.eclass: fix src_test w/o CTF
Fixes: 983fe336a7571f822655c25e0785f067de80c64c
Signed-off-by: Sam James <sam <AT> gentoo.org>
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/kernel-build.eclass | 8 +++++++-
 1 file changed, 7 insertions(+), 1 deletion(-)
diff --git a/eclass/kernel-build.eclass b/eclass/kernel-build.eclass
index 3836bef1276b..91c962d671ab 100644
--- a/eclass/kernel-build.eclass
+++ b/eclass/kernel-build.eclass
@@ -312,6 +312,12 @@ kernel-build_src_compile() {
 kernel-build_src_test() {
 	debug-print-function ${FUNCNAME} "${@}"
 
+	local targets=( modules_install )
+
+	if grep -q "CONFIG_CTF=y" "${WORKDIR}/modprep/.config"; then
+		targets+=( ctf_install )
+	fi
+
 	# Use the kernel build system to strip, this ensures the modules
 	# are stripped *before* they are signed or compressed.
 	local strip_args
@@ -321,7 +327,7 @@ kernel-build_src_test() {
 
 	emake O="${WORKDIR}"/build "${MAKEARGS[@]}" \
 		INSTALL_MOD_PATH="${T}" INSTALL_MOD_STRIP="${strip_args}" \
-		modules_install ctf_install
+		"${targets[@]}"
 
 	kernel-install_test "${KV_FULL}" \
 		"${WORKDIR}/build/$(dist-kernel_get_image_path)" \
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-05 12:10 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-05 12:10 UTC (permalink / raw
  To: gentoo-commits
commit:     82f9bef4ed76f656a3d79b607eecff526b78b7ee
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Sep  5 11:48:02 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Sep  5 12:09:45 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=82f9bef4
linux-mod-r1.eclass: BDEPEND on dev-util/pahole
If the kernel is built with CONFIG_DEBUG_INFO_BTF_MODULES, external
kernel module builds will try to call `pahole` to generate BTF and
fail if it's not present.
pahole is a small dependency and we're likely to enable BTF by default
in more configurations going forward, so do it unconditionally.
The alternatives aren't great anyway, we would have to instead:
* RDEPEND in g-k-bin
* BDEPEND in g-k-bin and break the binpkg case
* Use an ewarn in the eclass if pahole isn't installed + config option is set
so this is the best option available to us.
Thanks-to: Ionen Wolkens <ionen <AT> gentoo.org>
Reported-by: Sebastian Engel <sighunter <AT> gmx.de>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/linux-mod-r1.eclass | 1 +
 1 file changed, 1 insertion(+)
diff --git a/eclass/linux-mod-r1.eclass b/eclass/linux-mod-r1.eclass
index 9911a6ddee12..120fb019d74a 100644
--- a/eclass/linux-mod-r1.eclass
+++ b/eclass/linux-mod-r1.eclass
@@ -121,6 +121,7 @@ DEPEND="
 	virtual/linux-sources
 "
 BDEPEND="
+	dev-util/pahole
 	sys-apps/kmod[tools]
 	modules-sign? (
 		dev-libs/openssl
^ permalink raw reply related	[flat|nested] 6663+ messages in thread
* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-07 18:21 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-07 18:21 UTC (permalink / raw
  To: gentoo-commits
commit:     c3f4e3f788e2d5973ce49293fe20354b20576426
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Sep  7 16:22:45 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Sep  7 18:21:32 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=c3f4e3f7
kernel-build.eclass: call ctf targets serially
Workaround for install + ctf_install not working in parallel for now
(have reported this).
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/kernel-build.eclass | 20 +++++++++++++-------
 1 file changed, 13 insertions(+), 7 deletions(-)
diff --git a/eclass/kernel-build.eclass b/eclass/kernel-build.eclass
index 91c962d671ab..93523629de41 100644
--- a/eclass/kernel-build.eclass
+++ b/eclass/kernel-build.eclass
@@ -302,7 +302,9 @@ kernel-build_src_compile() {
 		targets+=( ctf )
 	fi
 
-	emake O="${WORKDIR}"/build "${MAKEARGS[@]}" "${targets[@]}"
+	for target in "${targets[@]}" ; do
+		emake O="${WORKDIR}"/build "${MAKEARGS[@]}" "${target}"
+	done
 }
 
 # @FUNCTION: kernel-build_src_test
@@ -325,9 +327,11 @@ kernel-build_src_test() {
 		strip_args="--strip-unneeded"
 	fi
 
-	emake O="${WORKDIR}"/build "${MAKEARGS[@]}" \
-		INSTALL_MOD_PATH="${T}" INSTALL_MOD_STRIP="${strip_args}" \
-		"${targets[@]}"
+	for target in "${targets[@]}" ; do
+		emake O="${WORKDIR}"/build "${MAKEARGS[@]}" \
+			INSTALL_MOD_PATH="${T}" INSTALL_MOD_STRIP="${strip_args}" \
+			"${target}"
+	done
 
 	kernel-install_test "${KV_FULL}" \
 		"${WORKDIR}/build/$(dist-kernel_get_image_path)" \
@@ -371,9 +375,11 @@ kernel-build_src_install() {
 		)
 	fi
 
-	emake O="${WORKDIR}"/build "${MAKEARGS[@]}" \
-		INSTALL_MOD_PATH="${ED}" INSTALL_MOD_STRIP="${strip_args}" \
-		INSTALL_PATH="${ED}/boot" "${compress[@]}" "${targets[@]}"
+	for target in "${targets[@]}" ; do
+		emake O="${WORKDIR}"/build "${MAKEARGS[@]}" \
+			INSTALL_MOD_PATH="${ED}" INSTALL_MOD_STRIP="${strip_args}" \
+			INSTALL_PATH="${ED}/boot" "${compress[@]}" "${target}"
+	done
 
 	# note: we're using mv rather than doins to save space and time
 	# install main and arch-specific headers first, and scripts
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-07 18:23 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-07 18:23 UTC (permalink / raw
  To: gentoo-commits
commit:     19cfcafa125dbbe389fc84e4f89cc851df6baa46
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Sep  7 18:23:03 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Sep  7 18:23:03 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=19cfcafa
kernel-build.eclass: localise 'target'
Fixes: c3f4e3f788e2d5973ce49293fe20354b20576426
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/kernel-build.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/kernel-build.eclass b/eclass/kernel-build.eclass
index 93523629de41..ce87fd72acdd 100644
--- a/eclass/kernel-build.eclass
+++ b/eclass/kernel-build.eclass
@@ -302,6 +302,7 @@ kernel-build_src_compile() {
 		targets+=( ctf )
 	fi
 
+	local target
 	for target in "${targets[@]}" ; do
 		emake O="${WORKDIR}"/build "${MAKEARGS[@]}" "${target}"
 	done
@@ -327,6 +328,7 @@ kernel-build_src_test() {
 		strip_args="--strip-unneeded"
 	fi
 
+	local target
 	for target in "${targets[@]}" ; do
 		emake O="${WORKDIR}"/build "${MAKEARGS[@]}" \
 			INSTALL_MOD_PATH="${T}" INSTALL_MOD_STRIP="${strip_args}" \
@@ -375,6 +377,7 @@ kernel-build_src_install() {
 		)
 	fi
 
+	local target
 	for target in "${targets[@]}" ; do
 		emake O="${WORKDIR}"/build "${MAKEARGS[@]}" \
 			INSTALL_MOD_PATH="${ED}" INSTALL_MOD_STRIP="${strip_args}" \
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-08 18:21 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-08 18:21 UTC (permalink / raw
  To: gentoo-commits
commit:     107c548f56cfcfc133e10918dfc175bf6d9128c3
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Sep  7 21:37:48 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Sep  8 18:21:16 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=107c548f
php-pear-r2.eclass: add global-scope ewarn for deprecated < EAPI 7
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/php-pear-r2.eclass | 14 +++++++++-----
 1 file changed, 9 insertions(+), 5 deletions(-)
diff --git a/eclass/php-pear-r2.eclass b/eclass/php-pear-r2.eclass
index 9882c7dcc700..567aa9a8144f 100644
--- a/eclass/php-pear-r2.eclass
+++ b/eclass/php-pear-r2.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2023 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: php-pear-r2.eclass
@@ -14,14 +14,18 @@
 # Note that this eclass doesn't handle dependencies of PEAR packages
 # on purpose; please use (R)DEPEND to define them correctly!
 
+if [[ -z ${_PHP_PEAR_R2_ECLASS} ]]; then
+_PHP_PEAR_R2_ECLASS=1
+
 case ${EAPI} in
-	6|7|8) ;;
+	6)
+		ewarn "${CATEGORY}/${PF}: ebuild uses ${ECLASS} with deprecated EAPI ${EAPI}!"
+		ewarn "${CATEGORY}/${PF}: Support will be removed on 2024-10-08. Please port to newer EAPI."
+		;;
+	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
-if [[ -z ${_PHP_PEAR_R2_ECLASS} ]]; then
-_PHP_PEAR_R2_ECLASS=1
-
 RDEPEND=">=dev-php/pear-1.8.1"
 [[ ${EAPI} != [67] ]] && IDEPEND=">=dev-php/pear-1.8.1"
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-08 18:21 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-08 18:21 UTC (permalink / raw
  To: gentoo-commits
commit:     75c1c9c04acf63c2c7ed1d8bf62609a654754758
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Sep  7 21:37:43 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Sep  8 18:21:15 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=75c1c9c0
perl-functions.eclass: add global-scope ewarn for deprecated < EAPI 7
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/perl-functions.eclass | 11 ++++++-----
 1 file changed, 6 insertions(+), 5 deletions(-)
diff --git a/eclass/perl-functions.eclass b/eclass/perl-functions.eclass
index 142fdeb8cfbd..d2b6cfb85f73 100644
--- a/eclass/perl-functions.eclass
+++ b/eclass/perl-functions.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2022 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: perl-functions.eclass
@@ -17,11 +17,12 @@
 # global scope.
 
 case ${EAPI} in
-	7|8)
-		;;
-	*)
-		die "${ECLASS}: EAPI ${EAPI:-0} not supported"
+	6)
+		ewarn "${CATEGORY}/${PF}: ebuild uses ${ECLASS} with deprecated EAPI ${EAPI}!"
+		ewarn "${CATEGORY}/${PF}: Support will be removed on 2024-10-08. Please port to newer EAPI."
 		;;
+	7|8) ;;
+	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
 [[ ${CATEGORY} == "perl-core" ]] && inherit alternatives
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-08 18:21 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-08 18:21 UTC (permalink / raw
  To: gentoo-commits
commit:     e2bb16305d903272dcef1e902d0e7b3ec87dd87b
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Sep  7 21:37:59 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Sep  8 18:21:18 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=e2bb1630
preserve-libs.eclass: add global-scope ewarn for deprecated < EAPI 7
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/preserve-libs.eclass | 14 +++++++++-----
 1 file changed, 9 insertions(+), 5 deletions(-)
diff --git a/eclass/preserve-libs.eclass b/eclass/preserve-libs.eclass
index 35c65ef4436f..38571447b945 100644
--- a/eclass/preserve-libs.eclass
+++ b/eclass/preserve-libs.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2023 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: preserve-libs.eclass
@@ -7,14 +7,18 @@
 # @SUPPORTED_EAPIS: 5 6 7 8
 # @BLURB: preserve libraries after SONAME changes
 
+if [[ -z ${_PRESERVE_LIBS_ECLASS} ]]; then
+_PRESERVE_LIBS_ECLASS=1
+
 case ${EAPI} in
-	5|6|7|8) ;;
+	5|6)
+		ewarn "${CATEGORY}/${PF}: ebuild uses ${ECLASS} with deprecated EAPI ${EAPI}!"
+		ewarn "${CATEGORY}/${PF}: Support will be removed on 2024-10-08. Please port to newer EAPI."
+		;;
+	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
-if [[ -z ${_PRESERVE_LIBS_ECLASS} ]]; then
-_PRESERVE_LIBS_ECLASS=1
-
 # @FUNCTION: preserve_old_lib
 # @USAGE: <libs to preserve> [more libs]
 # @DESCRIPTION:
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-08 18:21 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-08 18:21 UTC (permalink / raw
  To: gentoo-commits
commit:     2580b25033cac0b63d1195449b2a7dfeb7d0d22d
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Sep  7 21:37:56 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Sep  8 18:21:17 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=2580b250
prefix.eclass: add global-scope ewarn for deprecated < EAPI 7
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/prefix.eclass | 16 ++++++++++------
 1 file changed, 10 insertions(+), 6 deletions(-)
diff --git a/eclass/prefix.eclass b/eclass/prefix.eclass
index 8d50d0ba7b6e..e968e8ae8bac 100644
--- a/eclass/prefix.eclass
+++ b/eclass/prefix.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2021 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: prefix.eclass
@@ -12,14 +12,18 @@
 # located somewhere in the filesystem.  Prefix ebuilds require
 # additional functions and variables which are defined by this eclass.
 
-case ${EAPI:-0} in
-	[5678]) ;;
-	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
-esac
-
 if [[ -z ${_PREFIX_ECLASS} ]]; then
 _PREFIX_ECLASS=1
 
+case ${EAPI} in
+	5|6)
+		ewarn "${CATEGORY}/${PF}: ebuild uses ${ECLASS} with deprecated EAPI ${EAPI}!"
+		ewarn "${CATEGORY}/${PF}: Support will be removed on 2024-10-08. Please port to newer EAPI."
+		;;
+	7|8) ;;
+	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
+esac
+
 # @ECLASS_VARIABLE: EPREFIX
 # @DESCRIPTION:
 # The offset prefix of a Gentoo Prefix installation.  When Gentoo Prefix
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-08 18:21 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-08 18:21 UTC (permalink / raw
  To: gentoo-commits
commit:     8e4a8408904a21168ed94c8ca7b7320c265e66ee
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Sep  7 21:38:14 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Sep  8 18:21:19 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=8e4a8408
ruby-fakegem.eclass: add global-scope ewarn for deprecated < EAPI 7
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/ruby-fakegem.eclass | 8 ++++++--
 1 file changed, 6 insertions(+), 2 deletions(-)
diff --git a/eclass/ruby-fakegem.eclass b/eclass/ruby-fakegem.eclass
index 40ff76ce900e..04099a82ef4f 100644
--- a/eclass/ruby-fakegem.eclass
+++ b/eclass/ruby-fakegem.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2023 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: ruby-fakegem.eclass
@@ -139,7 +139,11 @@ RUBY_FAKEGEM_BINDIR="${RUBY_FAKEGEM_BINDIR-bin}"
 RUBY_FAKEGEM_EXTENSION_LIBDIR="${RUBY_FAKEGEM_EXTENSION_LIBDIR-lib}"
 
 case ${EAPI} in
-	5|6|7|8) ;;
+	6)
+		ewarn "${CATEGORY}/${PF}: ebuild uses ${ECLASS} with deprecated EAPI ${EAPI}!"
+		ewarn "${CATEGORY}/${PF}: Support will be removed on 2024-10-08. Please port to newer EAPI."
+		;;
+	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-08 18:21 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-08 18:21 UTC (permalink / raw
  To: gentoo-commits
commit:     2adde4478398749f442fd67d72fd631b8138ea1a
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Sep  7 21:38:35 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Sep  8 18:21:21 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=2adde447
systemd.eclass: add global-scope ewarn for deprecated < EAPI 7
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/systemd.eclass | 8 ++++++--
 1 file changed, 6 insertions(+), 2 deletions(-)
diff --git a/eclass/systemd.eclass b/eclass/systemd.eclass
index 03d6a82fd310..a5f0decde1e3 100644
--- a/eclass/systemd.eclass
+++ b/eclass/systemd.eclass
@@ -1,4 +1,4 @@
-# Copyright 2011-2023 Gentoo Authors
+# Copyright 2011-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: systemd.eclass
@@ -25,7 +25,11 @@
 # @CODE
 
 case ${EAPI} in
-	5|6|7|8) ;;
+	6)
+		ewarn "${CATEGORY}/${PF}: ebuild uses ${ECLASS} with deprecated EAPI ${EAPI}!"
+		ewarn "${CATEGORY}/${PF}: Support will be removed on 2024-10-08. Please port to newer EAPI."
+		;;
+	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-08 18:21 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-08 18:21 UTC (permalink / raw
  To: gentoo-commits
commit:     cf14792ae9471b1d95ee93ecc5de35922654e5cc
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Sep  7 21:38:17 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Sep  8 18:21:19 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=cf14792a
ruby-ng.eclass: add global-scope ewarn for deprecated < EAPI 7
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/ruby-ng.eclass | 8 ++++++--
 1 file changed, 6 insertions(+), 2 deletions(-)
diff --git a/eclass/ruby-ng.eclass b/eclass/ruby-ng.eclass
index d80ae96dd40b..2ef6d2247435 100644
--- a/eclass/ruby-ng.eclass
+++ b/eclass/ruby-ng.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2023 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: ruby-ng.eclass
@@ -67,7 +67,11 @@
 # passed to "grep -E" to remove reporting of these shared objects.
 
 case ${EAPI} in
-	6|7|8) ;;
+	6)
+		ewarn "${CATEGORY}/${PF}: ebuild uses ${ECLASS} with deprecated EAPI ${EAPI}!"
+		ewarn "${CATEGORY}/${PF}: Support will be removed on 2024-10-08. Please port to newer EAPI."
+		;;
+	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-08 18:21 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-08 18:21 UTC (permalink / raw
  To: gentoo-commits
commit:     3a9d3b4238e7706d8f2f3d5d652faae69091a9ad
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Sep  7 21:38:42 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Sep  8 18:21:22 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=3a9d3b42
toolchain-funcs.eclass: add global-scope ewarn for deprecated < EAPI 7
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain-funcs.eclass | 12 ++++++++----
 1 file changed, 8 insertions(+), 4 deletions(-)
diff --git a/eclass/toolchain-funcs.eclass b/eclass/toolchain-funcs.eclass
index 5e36fa275dcd..66819996ea33 100644
--- a/eclass/toolchain-funcs.eclass
+++ b/eclass/toolchain-funcs.eclass
@@ -13,14 +13,18 @@
 # in such a way that you can rely on the function always returning
 # something sane.
 
+if [[ -z ${_TOOLCHAIN_FUNCS_ECLASS} ]]; then
+_TOOLCHAIN_FUNCS_ECLASS=1
+
 case ${EAPI} in
-	6|7|8) ;;
+	6)
+		ewarn "${CATEGORY}/${PF}: ebuild uses ${ECLASS} with deprecated EAPI ${EAPI}!"
+		ewarn "${CATEGORY}/${PF}: Support will be removed on 2024-10-08. Please port to newer EAPI."
+		;;
+	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
-if [[ -z ${_TOOLCHAIN_FUNCS_ECLASS} ]]; then
-_TOOLCHAIN_FUNCS_ECLASS=1
-
 inherit multilib
 
 # tc-getPROG <VAR [search vars]> <default> [tuple]
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-08 18:21 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-08 18:21 UTC (permalink / raw
  To: gentoo-commits
commit:     001d4ff8cf4b01897276841e706a78eeb119a4c5
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Sep  7 21:38:46 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Sep  8 18:21:23 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=001d4ff8
udev.eclass: add global-scope ewarn for deprecated < EAPI 7
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/udev.eclass | 14 +++++++++-----
 1 file changed, 9 insertions(+), 5 deletions(-)
diff --git a/eclass/udev.eclass b/eclass/udev.eclass
index ac94f98221aa..7fd99cbba8b0 100644
--- a/eclass/udev.eclass
+++ b/eclass/udev.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2022 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: udev.eclass
@@ -36,14 +36,18 @@
 # }
 # @CODE
 
+if [[ -z ${_UDEV_ECLASS} ]]; then
+_UDEV_ECLASS=1
+
 case ${EAPI} in
-	5|6|7|8) ;;
+	6)
+		ewarn "${CATEGORY}/${PF}: ebuild uses ${ECLASS} with deprecated EAPI ${EAPI}!"
+		ewarn "${CATEGORY}/${PF}: Support will be removed on 2024-10-08. Please port to newer EAPI."
+		;;
+	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
-if [[ -z ${_UDEV_ECLASS} ]]; then
-_UDEV_ECLASS=1
-
 inherit toolchain-funcs
 
 if [[ ${EAPI} == [56] ]]; then
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-08 18:21 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-08 18:21 UTC (permalink / raw
  To: gentoo-commits
commit:     4d90c2033b85e64c3b6be717a930be84f629f35c
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Sep  7 21:37:52 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Sep  8 18:21:16 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=4d90c203
portability.eclass: add global-scope ewarn for deprecated < EAPI 7
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/portability.eclass | 12 ++++++++----
 1 file changed, 8 insertions(+), 4 deletions(-)
diff --git a/eclass/portability.eclass b/eclass/portability.eclass
index 78da440e22dd..926ac8b8b825 100644
--- a/eclass/portability.eclass
+++ b/eclass/portability.eclass
@@ -9,14 +9,18 @@
 # @SUPPORTED_EAPIS: 6 7 8
 # @BLURB: This eclass is created to avoid using non-portable GNUisms inside ebuilds
 
+if [[ -z ${_PORTABILITY_ECLASS} ]]; then
+_PORTABILITY_ECLASS=1
+
 case ${EAPI} in
-	6|7|8) ;;
+	6)
+		ewarn "${CATEGORY}/${PF}: ebuild uses ${ECLASS} with deprecated EAPI ${EAPI}!"
+		ewarn "${CATEGORY}/${PF}: Support will be removed on 2024-10-08. Please port to newer EAPI."
+		;;
+	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
-if [[ -z ${_PORTABILITY_ECLASS} ]]; then
-_PORTABILITY_ECLASS=1
-
 # @FUNCTION: treecopy
 # @USAGE: <orig1> [orig2 orig3 ....] <dest>
 # @DESCRIPTION:
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-08 18:21 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-08 18:21 UTC (permalink / raw
  To: gentoo-commits
commit:     d654f219ea2fc0a26718ec9ee512c98216e1d99a
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Sep  7 21:38:51 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Sep  8 18:21:23 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=d654f219
vcs-clean.eclass: add global-scope ewarn for deprecated < EAPI 7
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/vcs-clean.eclass | 14 +++++++++-----
 1 file changed, 9 insertions(+), 5 deletions(-)
diff --git a/eclass/vcs-clean.eclass b/eclass/vcs-clean.eclass
index e4c61ac7164a..719bdec17676 100644
--- a/eclass/vcs-clean.eclass
+++ b/eclass/vcs-clean.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2022 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: vcs-clean.eclass
@@ -9,14 +9,18 @@
 # @SUPPORTED_EAPIS: 5 6 7 8
 # @BLURB: helper functions to remove VCS directories
 
+if [[ -z ${_VCS_CLEAN_ECLASS} ]] ; then
+_VCS_CLEAN_ECLASS=1
+
 case ${EAPI} in
-	5|6|7|8) ;;
+	5|6)
+		ewarn "${CATEGORY}/${PF}: ebuild uses ${ECLASS} with deprecated EAPI ${EAPI}!"
+		ewarn "${CATEGORY}/${PF}: Support will be removed on 2024-10-08. Please port to newer EAPI."
+		;;
+	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
-if [[ -z ${_VCS_CLEAN_ECLASS} ]] ; then
-_VCS_CLEAN_ECLASS=1
-
 # @FUNCTION: ecvs_clean
 # @USAGE: [list of dirs]
 # @DESCRIPTION:
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-08 18:21 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-08 18:21 UTC (permalink / raw
  To: gentoo-commits
commit:     f5ef210074c1b8c5ea29c8b4cb64ccab6f48628b
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Sep  7 21:38:32 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Sep  8 18:21:20 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=f5ef2100
strip-linguas.eclass: add global-scope ewarn for deprecated < EAPI 7
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/strip-linguas.eclass | 16 ++++++++++------
 1 file changed, 10 insertions(+), 6 deletions(-)
diff --git a/eclass/strip-linguas.eclass b/eclass/strip-linguas.eclass
index 718341b4a626..b31f414c87c3 100644
--- a/eclass/strip-linguas.eclass
+++ b/eclass/strip-linguas.eclass
@@ -1,4 +1,4 @@
-# Copyright 2004-2021 Gentoo Authors
+# Copyright 2004-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: strip-linguas.eclass
@@ -9,15 +9,19 @@
 # @SUPPORTED_EAPIS: 5 6 7 8
 # @BLURB: convenience function for LINGUAS support
 
+if [[ -z ${_STRIP_LINGUAS_ECLASS} ]]; then
+_STRIP_LINGUAS_ECLASS=1
+
 case ${EAPI} in
-	5|6|7|8) ;;
+	5|6)
+		ewarn "${CATEGORY}/${PF}: ebuild uses ${ECLASS} with deprecated EAPI ${EAPI}!"
+		ewarn "${CATEGORY}/${PF}: Support will be removed on 2024-10-08. Please port to newer EAPI."
+		;;
+	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
-if [[ -z ${_STRIP_LINGUAS_ECLASS} ]]; then
-_STRIP_LINGUAS_ECLASS=1
-
-# @FUNCTION: strip-linguas
+# FUNCTION: strip-linguas
 # @USAGE: [<allow LINGUAS>|<-i|-u> <directories of .po files>]
 # @DESCRIPTION:
 # Make sure that LINGUAS only contains languages that a package can
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-08 18:21 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-08 18:21 UTC (permalink / raw
  To: gentoo-commits
commit:     9624aabd7852cde30d5c4392c5b05d51921f1a7a
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Sep  7 21:38:39 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Sep  8 18:21:21 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=9624aabd
tmpfiles.eclass: add global-scope ewarn for deprecated < EAPI 7
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/tmpfiles.eclass | 12 ++++++++----
 1 file changed, 8 insertions(+), 4 deletions(-)
diff --git a/eclass/tmpfiles.eclass b/eclass/tmpfiles.eclass
index 39650401a6a0..63889a275fef 100644
--- a/eclass/tmpfiles.eclass
+++ b/eclass/tmpfiles.eclass
@@ -1,4 +1,4 @@
-# Copyright 2016-2022 Gentoo Authors
+# Copyright 2016-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: tmpfiles.eclass
@@ -55,9 +55,13 @@
 if [[ -z ${_TMPFILES_ECLASS} ]]; then
 _TMPFILES_ECLASS=1
 
-case "${EAPI}" in
-5|6|7|8) ;;
-*) die "API is undefined for EAPI ${EAPI}" ;;
+case ${EAPI} in
+	5|6)
+		ewarn "${CATEGORY}/${PF}: ebuild uses ${ECLASS} with deprecated EAPI ${EAPI}!"
+		ewarn "${CATEGORY}/${PF}: Support will be removed on 2024-10-08. Please port to newer EAPI."
+		;;
+	7|8) ;;
+	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
 # @ECLASS_VARIABLE: TMPFILES_OPTIONAL
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-08 18:21 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-08 18:21 UTC (permalink / raw
  To: gentoo-commits
commit:     1a99e837bd683a50583c7a6a83bae5ad918cec74
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Sep  7 21:38:08 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Sep  8 18:21:18 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=1a99e837
readme.gentoo-r1.eclass: add global-scope ewarn for deprecated < EAPI 7
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/readme.gentoo-r1.eclass | 6 +++++-
 1 file changed, 5 insertions(+), 1 deletion(-)
diff --git a/eclass/readme.gentoo-r1.eclass b/eclass/readme.gentoo-r1.eclass
index 48023d9c049f..3d2d8244687c 100644
--- a/eclass/readme.gentoo-r1.eclass
+++ b/eclass/readme.gentoo-r1.eclass
@@ -21,7 +21,11 @@ if [[ -z ${_README_GENTOO_ECLASS} ]]; then
 _README_GENTOO_ECLASS=1
 
 case ${EAPI} in
-	6|7|8) ;;
+	6)
+		ewarn "${CATEGORY}/${PF}: ebuild uses ${ECLASS} with deprecated EAPI ${EAPI}!"
+		ewarn "${CATEGORY}/${PF}: Support will be removed on 2024-10-08. Please port to newer EAPI."
+		;;
+	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-08 18:21 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-08 18:21 UTC (permalink / raw
  To: gentoo-commits
commit:     fabfe377fe7451c3a1f62d5e5cda837c63a583e2
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Sep  7 21:38:21 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Sep  8 18:21:20 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=fabfe377
ruby-utils.eclass: add global-scope ewarn for deprecated < EAPI 7
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/ruby-utils.eclass | 14 +++++++++-----
 1 file changed, 9 insertions(+), 5 deletions(-)
diff --git a/eclass/ruby-utils.eclass b/eclass/ruby-utils.eclass
index 789f57ce25f6..48a25114b396 100644
--- a/eclass/ruby-utils.eclass
+++ b/eclass/ruby-utils.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2023 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: ruby-utils.eclass
@@ -15,13 +15,17 @@
 # This eclass does not set any metadata variables nor export any phase
 # functions. It can be inherited safely.
 
-case ${EAPI:-0} in
-	[5678]) ;;
+if [[ ! ${_RUBY_UTILS} ]]; then
+
+case ${EAPI} in
+	5|6)
+		ewarn "${CATEGORY}/${PF}: ebuild uses ${ECLASS} with deprecated EAPI ${EAPI}!"
+		ewarn "${CATEGORY}/${PF}: Support will be removed on 2024-10-08. Please port to newer EAPI."
+		;;
+	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
-if [[ ! ${_RUBY_UTILS} ]]; then
-
 # @ECLASS_VARIABLE: RUBY_TARGETS_PREFERENCE
 # @INTERNAL
 # @DESCRIPTION:
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-08 18:21 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-08 18:21 UTC (permalink / raw
  To: gentoo-commits
commit:     2ba4a06b94b1b3c679c964eb4fc8ee5cdd47adaf
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Sep  7 21:38:59 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Sep  8 18:21:24 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=2ba4a06b
vim-plugin.eclass: add global-scope ewarn for deprecated < EAPI 7
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/vim-plugin.eclass | 14 +++++++++-----
 1 file changed, 9 insertions(+), 5 deletions(-)
diff --git a/eclass/vim-plugin.eclass b/eclass/vim-plugin.eclass
index ee4f1b6e0f81..b2ae0cb9e4c3 100644
--- a/eclass/vim-plugin.eclass
+++ b/eclass/vim-plugin.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2023 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: vim-plugin.eclass
@@ -12,14 +12,18 @@
 # which is read automatically by vim.  The only exception is
 # documentation, for which we make a special case via vim-doc.eclass.
 
+if [[ -z ${_VIM_PLUGIN_ECLASS} ]]; then
+_VIM_PLUGIN_ECLASS=1
+
 case ${EAPI} in
-	6|7|8) ;;
+	6)
+		ewarn "${CATEGORY}/${PF}: ebuild uses ${ECLASS} with deprecated EAPI ${EAPI}!"
+		ewarn "${CATEGORY}/${PF}: Support will be removed on 2024-10-08. Please port to newer EAPI."
+		;;
+	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
-if [[ -z ${_VIM_PLUGIN_ECLASS} ]]; then
-_VIM_PLUGIN_ECLASS=1
-
 inherit vim-doc
 
 [[ ${EAPI} != [67] ]] && _DEFINE_VIM_PLUGIN_SRC_PREPARE=true
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-08 18:21 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-08 18:21 UTC (permalink / raw
  To: gentoo-commits
commit:     47d7fb1a65af001085f973704dfeed320111ab6b
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Sep  7 21:39:15 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Sep  8 18:21:28 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=47d7fb1a
xdg-utils.eclass: add global-scope ewarn for deprecated < EAPI 7
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/xdg-utils.eclass | 8 ++++++--
 1 file changed, 6 insertions(+), 2 deletions(-)
diff --git a/eclass/xdg-utils.eclass b/eclass/xdg-utils.eclass
index 34535a129e33..84f88eee18fc 100644
--- a/eclass/xdg-utils.eclass
+++ b/eclass/xdg-utils.eclass
@@ -1,4 +1,4 @@
-# Copyright 2004-2023 Gentoo Authors
+# Copyright 2004-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: xdg-utils.eclass
@@ -18,7 +18,11 @@
 #  * XDG mime information database management
 
 case ${EAPI} in
-	5|6|7|8) ;;
+	5|6)
+		ewarn "${CATEGORY}/${PF}: ebuild uses ${ECLASS} with deprecated EAPI ${EAPI}!"
+		ewarn "${CATEGORY}/${PF}: Support will be removed on 2024-10-08. Please port to newer EAPI."
+		;;
+	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-08 18:21 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-08 18:21 UTC (permalink / raw
  To: gentoo-commits
commit:     1177526dad936922685cd77c0bd05474a8407462
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Sep  7 21:39:01 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Sep  8 18:21:25 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=1177526d
vim-spell.eclass: add global-scope ewarn for deprecated < EAPI 7
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/vim-spell.eclass | 12 ++++++++----
 1 file changed, 8 insertions(+), 4 deletions(-)
diff --git a/eclass/vim-spell.eclass b/eclass/vim-spell.eclass
index 607771ae8035..57bcb0dc8021 100644
--- a/eclass/vim-spell.eclass
+++ b/eclass/vim-spell.eclass
@@ -62,14 +62,18 @@
 # spell files. It's best to let upstream know if you've generated spell files
 # for another language rather than keeping them Gentoo-specific.
 
+if [[ -z ${_VIM_SPELL_ECLASS} ]] ; then
+_VIM_SPELL_ECLASS=1
+
 case ${EAPI} in
-	6|7|8) ;;
+	6)
+		ewarn "${CATEGORY}/${PF}: ebuild uses ${ECLASS} with deprecated EAPI ${EAPI}!"
+		ewarn "${CATEGORY}/${PF}: Support will be removed on 2024-10-08. Please port to newer EAPI."
+		;;
+	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
-if [[ -z ${_VIM_SPELL_ECLASS} ]] ; then
-_VIM_SPELL_ECLASS=1
-
 SRC_URI="mirror://gentoo/${P}.tar.bz2"
 SLOT="0"
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-08 18:21 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-08 18:21 UTC (permalink / raw
  To: gentoo-commits
commit:     93c765a9b349be736f86cb6ca823d8cf6220a335
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Sep  7 21:39:09 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Sep  8 18:21:27 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=93c765a9
wrapper.eclass: add global-scope ewarn for deprecated < EAPI 7
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/wrapper.eclass | 16 ++++++++++------
 1 file changed, 10 insertions(+), 6 deletions(-)
diff --git a/eclass/wrapper.eclass b/eclass/wrapper.eclass
index 8d3d273d81c6..a62bb51d0fe7 100644
--- a/eclass/wrapper.eclass
+++ b/eclass/wrapper.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2022 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: wrapper.eclass
@@ -7,15 +7,19 @@
 # @SUPPORTED_EAPIS: 5 6 7 8
 # @BLURB: create a shell wrapper script
 
+if [[ -z ${_WRAPPER_ECLASS} ]]; then
+_WRAPPER_ECLASS=1
+
 case ${EAPI} in
-	5|6|7|8) ;;
+	5|6)
+		ewarn "${CATEGORY}/${PF}: ebuild uses ${ECLASS} with deprecated EAPI ${EAPI}!"
+		ewarn "${CATEGORY}/${PF}: Support will be removed on 2024-10-08. Please port to newer EAPI."
+		;;
+	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
-if [[ -z ${_WRAPPER_ECLASS} ]]; then
-_WRAPPER_ECLASS=1
-
-# @FUNCTION: make_wrapper
+# FUNCTION: make_wrapper
 # @USAGE: <wrapper> <target> [chdir] [libpaths] [installpath]
 # @DESCRIPTION:
 # Create a shell wrapper script named wrapper in installpath
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-08 18:21 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-08 18:21 UTC (permalink / raw
  To: gentoo-commits
commit:     08cb1492fe62e8f15aa0d546db59ba27ec7a5ab3
Author:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
AuthorDate: Sat Aug 31 13:18:39 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Sep  8 18:21:29 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=08cb1492
distutils-r1.eclass: Don't run cargo_env unless cargo_gen_config has run
Normally, failing to run cargo_gen_config results in an error, but that
is unhelpful for ebuilds with optional Cargo support.
Closes: https://bugs.gentoo.org/938764
Signed-off-by: James Le Cuirot <chewi <AT> gentoo.org>
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
Closes: https://github.com/gentoo/gentoo/pull/38041
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/distutils-r1.eclass | 4 +++-
 1 file changed, 3 insertions(+), 1 deletion(-)
diff --git a/eclass/distutils-r1.eclass b/eclass/distutils-r1.eclass
index 39705c5c3c84..5a6ebdcede8a 100644
--- a/eclass/distutils-r1.eclass
+++ b/eclass/distutils-r1.eclass
@@ -1253,7 +1253,9 @@ distutils_pep517_install() {
 	fi
 
 	local cmd=() config_settings=
-	has cargo ${INHERITED} && cmd+=( cargo_env )
+	if has cargo ${INHERITED} && [[ ${_CARGO_GEN_CONFIG_HAS_RUN} ]]; then
+		cmd+=( cargo_env )
+	fi
 
 	case ${DISTUTILS_USE_PEP517} in
 		maturin)
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-08 18:21 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-08 18:21 UTC (permalink / raw
  To: gentoo-commits
commit:     31705da10b8165380b2eb7b21da4cffd7d3a1621
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Aug 10 05:33:33 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Sep  8 18:21:29 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=31705da1
distutils-r1.eclass: Allow .jar files in sitedir
Closes: https://bugs.gentoo.org/937642
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/distutils-r1.eclass | 2 ++
 1 file changed, 2 insertions(+)
diff --git a/eclass/distutils-r1.eclass b/eclass/distutils-r1.eclass
index 0f9dc8d14d5e..39705c5c3c84 100644
--- a/eclass/distutils-r1.eclass
+++ b/eclass/distutils-r1.eclass
@@ -2109,8 +2109,10 @@ _distutils-r1_post_python_install() {
 		local strays=()
 		local p
 		mapfile -d $'\0' -t strays < <(
+			# jar for jpype, https://bugs.gentoo.org/937642
 			find "${sitedir}" -maxdepth 1 -type f '!' '(' \
 					-name '*.egg-info' -o \
+					-name '*.jar' -o \
 					-name '*.pth' -o \
 					-name '*.py' -o \
 					-name '*.pyi' -o \
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-08 18:21 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-08 18:21 UTC (permalink / raw
  To: gentoo-commits
commit:     0641762abe1deeec8ff4802ac726a1ce63d786aa
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Sep  7 21:38:56 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Sep  8 18:21:24 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=0641762a
vim-doc.eclass: add global-scope ewarn for deprecated < EAPI 7
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/vim-doc.eclass | 12 ++++++++----
 1 file changed, 8 insertions(+), 4 deletions(-)
diff --git a/eclass/vim-doc.eclass b/eclass/vim-doc.eclass
index 119ce793071d..f20f7397cf65 100644
--- a/eclass/vim-doc.eclass
+++ b/eclass/vim-doc.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2022 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: vim-doc.eclass
@@ -16,13 +16,17 @@
 # DEPEND in vim-plugin or by whatever version of vim is being
 # installed by the eclass.
 
+if [[ ! ${_VIM_DOC_ECLASS} ]] ; then
+
 case ${EAPI} in
-	6|7|8) ;;
+	6)
+		ewarn "${CATEGORY}/${PF}: ebuild uses ${ECLASS} with deprecated EAPI ${EAPI}!"
+		ewarn "${CATEGORY}/${PF}: Support will be removed on 2024-10-08. Please port to newer EAPI."
+		;;
+	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
-if [[ ! ${_VIM_DOC_ECLASS} ]] ; then
-
 # @FUNCTION: update_vim_helptags
 # @USAGE:
 # @DESCRIPTION:
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-08 18:21 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-08 18:21 UTC (permalink / raw
  To: gentoo-commits
commit:     fda83fc0111193d3e82a6357e55a62de07b43635
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Sep  7 21:39:13 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Sep  8 18:21:27 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=fda83fc0
xdg.eclass: add global-scope ewarn for deprecated < EAPI 7
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/xdg.eclass | 14 +++++++++-----
 1 file changed, 9 insertions(+), 5 deletions(-)
diff --git a/eclass/xdg.eclass b/eclass/xdg.eclass
index 14c56047af45..6af4b91875fc 100644
--- a/eclass/xdg.eclass
+++ b/eclass/xdg.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2023 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: xdg.eclass
@@ -13,14 +13,18 @@
 # Utility eclass to update the desktop, icon and shared mime info as laid
 # out in the freedesktop specs & implementations
 
+if [[ -z ${_XDG_ECLASS} ]]; then
+_XDG_ECLASS=1
+
 case ${EAPI} in
-	6|7|8) ;;
+	6)
+		ewarn "${CATEGORY}/${PF}: ebuild uses ${ECLASS} with deprecated EAPI ${EAPI}!"
+		ewarn "${CATEGORY}/${PF}: Support will be removed on 2024-10-08. Please port to newer EAPI."
+		;;
+	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
-if [[ -z ${_XDG_ECLASS} ]]; then
-_XDG_ECLASS=1
-
 inherit xdg-utils
 
 # Avoid dependency loop as both depend on glib-2
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-08 18:21 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-08 18:21 UTC (permalink / raw
  To: gentoo-commits
commit:     d56d11bf193043adedcdc5bd3b837a8cc6c79255
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Sep  7 21:39:07 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Sep  8 18:21:26 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=d56d11bf
webapp.eclass: add global-scope ewarn for deprecated < EAPI 7
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/webapp.eclass | 14 +++++++++-----
 1 file changed, 9 insertions(+), 5 deletions(-)
diff --git a/eclass/webapp.eclass b/eclass/webapp.eclass
index 5b091c84851f..e8bc127e1b96 100644
--- a/eclass/webapp.eclass
+++ b/eclass/webapp.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2023 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: webapp.eclass
@@ -10,14 +10,18 @@
 # The webapp eclass contains functions to handle web applications with
 # webapp-config. Part of the implementation of GLEP #11
 
+if [[ -z ${_WEBAPP_ECLASS} ]]; then
+_WEBAPP_ECLASS=1
+
 case ${EAPI} in
-	6|7|8) ;;
+	6)
+		ewarn "${CATEGORY}/${PF}: ebuild uses ${ECLASS} with deprecated EAPI ${EAPI}!"
+		ewarn "${CATEGORY}/${PF}: Support will be removed on 2024-10-08. Please port to newer EAPI."
+		;;
+	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
-if [[ -z ${_WEBAPP_ECLASS} ]]; then
-_WEBAPP_ECLASS=1
-
 # @ECLASS_VARIABLE: WEBAPP_DEPEND
 # @DESCRIPTION:
 # An ebuild should use WEBAPP_DEPEND if a custom DEPEND needs to be built, most
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-08 18:21 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-08 18:21 UTC (permalink / raw
  To: gentoo-commits
commit:     9b9de22b1f07676b7501e320563841207a69db32
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Sep  7 21:39:04 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Sep  8 18:21:26 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=9b9de22b
virtualx.eclass: add global-scope ewarn for deprecated < EAPI 7
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/virtualx.eclass | 14 +++++++++-----
 1 file changed, 9 insertions(+), 5 deletions(-)
diff --git a/eclass/virtualx.eclass b/eclass/virtualx.eclass
index f7318eafc59e..07d303899582 100644
--- a/eclass/virtualx.eclass
+++ b/eclass/virtualx.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2023 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: virtualx.eclass
@@ -9,14 +9,18 @@
 # @SUPPORTED_EAPIS: 6 7 8
 # @BLURB: This eclass can be used for packages that need a working X environment to build.
 
+if [[ -z ${_VIRTUALX_ECLASS} ]]; then
+_VIRTUALX_ECLASS=1
+
 case ${EAPI} in
-	6|7|8) ;;
+	6)
+		ewarn "${CATEGORY}/${PF}: ebuild uses ${ECLASS} with deprecated EAPI ${EAPI}!"
+		ewarn "${CATEGORY}/${PF}: Support will be removed on 2024-10-08. Please port to newer EAPI."
+		;;
+	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
-if [[ -z ${_VIRTUALX_ECLASS} ]]; then
-_VIRTUALX_ECLASS=1
-
 # @ECLASS_VARIABLE: VIRTUALX_REQUIRED
 # @PRE_INHERIT
 # @DESCRIPTION:
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-09 18:20 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-09 18:20 UTC (permalink / raw
  To: gentoo-commits
commit:     e2c865d8b5507755d6ad9c63e3b4b8ccbb5d6cd7
Author:     Sv. Lockal <lockalsash <AT> gmail <DOT> com>
AuthorDate: Tue Jul 30 23:14:55 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Sep  9 18:15:10 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=e2c865d8
rocm.eclass: add rocm_use_hipcc function and update example accordingly
Bug: https://bugs.gentoo.org/936099
Signed-off-by: Sv. Lockal <lockalsash <AT> gmail.com>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/rocm.eclass | 40 ++++++++++++++++++++++++++++++++++------
 1 file changed, 34 insertions(+), 6 deletions(-)
diff --git a/eclass/rocm.eclass b/eclass/rocm.eclass
index 7039455dec6b..cf501d5a8861 100644
--- a/eclass/rocm.eclass
+++ b/eclass/rocm.eclass
@@ -15,9 +15,13 @@
 # edit USE flag to control which GPU architecture to compile. Using
 # ${ROCM_USEDEP} can ensure coherence among dependencies. Ebuilds can call the
 # function get_amdgpu_flag to translate activated target to GPU compile flags,
-# passing it to configuration. Function check_amdgpu can help ebuild ensure
+# passing it to configuration. Function rocm_use_hipcc switches active compiler
+# to hipcc and cleans incompatible flags (useful for users with gcc-only flags
+# in /etc/portage/make.conf). Function check_amdgpu can help ebuild ensure
 # read and write permissions to GPU device in src_test phase, throwing friendly
-# error message if unavailable.
+# error message if unavailable. However src_configure in general should not
+# access any AMDGPU devices. If it does, it usually means that CMakeLists.txt
+# ignores AMDGPU_TARGETS in favor of autodetected GPU, which is not desired.
 #
 # @EXAMPLE:
 # Example ebuild for ROCm library in https://github.com/ROCmSoftwarePlatform
@@ -39,14 +43,12 @@
 # "
 #
 # src_configure() {
-#     # avoid sandbox violation
-#     addpredict /dev/kfd
-#     addpredict /dev/dri/
+#     rocm_use_hipcc
 #     local mycmakeargs=(
 #         -DAMDGPU_TARGETS="$(get_amdgpu_flags)"
 #         -DBUILD_CLIENTS_TESTS=$(usex test ON OFF)
 #     )
-#     CXX=hipcc cmake_src_configure
+#     cmake_src_configure
 # }
 #
 # src_test() {
@@ -90,6 +92,8 @@ esac
 if [[ ! ${_ROCM_ECLASS} ]]; then
 _ROCM_ECLASS=1
 
+inherit flag-o-matic
+
 # @ECLASS_VARIABLE: ROCM_VERSION
 # @REQUIRED
 # @PRE_INHERIT
@@ -231,3 +235,27 @@ check_amdgpu() {
 }
 
 fi
+
+# @FUNCTION: rocm_use_hipcc
+# @USAGE: rocm_use_hipcc
+# @DESCRIPTION:
+# switch active C and C++ compilers to hipcc, clean unsupported flags and setup ROCM_TARGET_LST file.
+rocm_use_hipcc() {
+	# During the configuration stage, CMake tests whether the compiler is able to compile a simple program.
+	# Since CMake checker does not specify --offload-arch=, hipcc enumerates devices using four methods
+	# until it finds at least one device. Last way is by accessing them (via rocminfo).
+	# To prevent potential sandbox violations, we set the ROCM_TARGET_LST variable (which is checked first).
+	local target_lst="${T}"/gentoo_rocm_target.lst
+	if [[ "${AMDGPU_TARGETS[@]}" = "" ]]; then
+		# Expected no GPU code; still need to calm down sandbox
+		echo "gfx000" > "${target_lst}" || die
+	else
+		printf "%s\n" ${AMDGPU_TARGETS[@]} > "${target_lst}" || die
+	fi
+	export ROCM_TARGET_LST="${target_lst}"
+
+	# Export updated CC and CXX. Note that CC is needed even if no C code used,
+	# as CMake checks that C compiler can compile a simple test program.
+	export CC=hipcc CXX=hipcc
+	strip-unsupported-flags
+}
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-10  6:46 Miroslav Šulc
  0 siblings, 0 replies; 6663+ messages in thread
From: Miroslav Šulc @ 2024-09-10  6:46 UTC (permalink / raw
  To: gentoo-commits
commit:     d9c0273228e50613d354bdf6bf5a91caa8eb919f
Author:     Volkmar W. Pogatzki <gentoo <AT> pogatzki <DOT> net>
AuthorDate: Mon Sep  9 08:21:19 2024 +0000
Commit:     Miroslav Šulc <fordfrog <AT> gentoo <DOT> org>
CommitDate: Tue Sep 10 06:40:42 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=d9c02732
java-utils-2.eclass: mark function use_doc as deprecated
Signed-off-by: Volkmar W. Pogatzki <gentoo <AT> pogatzki.net>
Closes: https://github.com/gentoo/gentoo/pull/37338
Signed-off-by: Miroslav Šulc <fordfrog <AT> gentoo.org>
 eclass/java-utils-2.eclass | 1 +
 1 file changed, 1 insertion(+)
diff --git a/eclass/java-utils-2.eclass b/eclass/java-utils-2.eclass
index 6bf6b7788aa5..481c9b7df081 100644
--- a/eclass/java-utils-2.eclass
+++ b/eclass/java-utils-2.eclass
@@ -2255,6 +2255,7 @@ java-pkg_force-compiler() {
 }
 
 # @FUNCTION: use_doc
+# @DEPRECATED: none
 # @DESCRIPTION:
 #
 # Helper function for getting ant to build javadocs. If the user has USE=doc,
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-10  8:54 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-09-10  8:54 UTC (permalink / raw
  To: gentoo-commits
commit:     f362cfe39056fe0277b71b045d0a753fdaad82b7
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Tue Sep 10 07:12:27 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Tue Sep 10 08:54:21 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=f362cfe3
llvm.org.eclass: Remove old snapshot list
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 12 ------------
 1 file changed, 12 deletions(-)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index da943081b9bf..fe805382115b 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -75,18 +75,6 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 				20.0.0_pre20240830)
 					EGIT_COMMIT=5500e21942f7047344b6fee62d3e08c0ba2f9182
 					;;
-				20.0.0_pre20240822)
-					EGIT_COMMIT=503907dc505db1e439e7061113bf84dd105f2e35
-					;;
-				20.0.0_pre20240815)
-					EGIT_COMMIT=db8ef6188cbbe2125e6d60bdef77a535105772df
-					;;
-				20.0.0_pre20240808)
-					EGIT_COMMIT=fd7d7882e7fa5a38d4bfde426120d4663718beb4
-					;;
-				20.0.0_pre20240801)
-					EGIT_COMMIT=130c135689ec12ab78c53645808524a8d28f7cae
-					;;
 				*)
 					die "Unknown snapshot: ${PV}"
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-10 12:58 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-09-10 12:58 UTC (permalink / raw
  To: gentoo-commits
commit:     76e7b39353e5e726f4ecebf2e723f4dc071b94e9
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Tue Sep 10 11:45:08 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Tue Sep 10 12:58:41 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=76e7b393
llvm.org.eclass: Add 20.0.0_pre20240910 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index fe805382115b..f8953ec11826 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -72,6 +72,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 			_LLVM_SOURCE_TYPE=snapshot
 
 			case ${PV} in
+				20.0.0_pre20240910)
+					EGIT_COMMIT=bece0d7517bd0a036dc8a319514e4a8a5c497dee
+					;;
 				20.0.0_pre20240830)
 					EGIT_COMMIT=5500e21942f7047344b6fee62d3e08c0ba2f9182
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-10 19:11 Miroslav Šulc
  0 siblings, 0 replies; 6663+ messages in thread
From: Miroslav Šulc @ 2024-09-10 19:11 UTC (permalink / raw
  To: gentoo-commits
commit:     b4de2efc298df6cee8c443bb5a1b6ae999a19592
Author:     Volkmar W. Pogatzki <gentoo <AT> pogatzki <DOT> net>
AuthorDate: Tue Sep 10 07:59:21 2024 +0000
Commit:     Miroslav Šulc <fordfrog <AT> gentoo <DOT> org>
CommitDate: Tue Sep 10 19:11:19 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=b4de2efc
java-utils-2.eclass: remove unused eclass fuction use_doc
Signed-off-by: Volkmar W. Pogatzki <gentoo <AT> pogatzki.net>
Closes: https://github.com/gentoo/gentoo/pull/38544
Signed-off-by: Miroslav Šulc <fordfrog <AT> gentoo.org>
 eclass/java-utils-2.eclass | 24 ------------------------
 1 file changed, 24 deletions(-)
diff --git a/eclass/java-utils-2.eclass b/eclass/java-utils-2.eclass
index 481c9b7df081..43d9b749ba3d 100644
--- a/eclass/java-utils-2.eclass
+++ b/eclass/java-utils-2.eclass
@@ -2254,30 +2254,6 @@ java-pkg_force-compiler() {
 	JAVA_PKG_FORCE_COMPILER="$@"
 }
 
-# @FUNCTION: use_doc
-# @DEPRECATED: none
-# @DESCRIPTION:
-#
-# Helper function for getting ant to build javadocs. If the user has USE=doc,
-# then 'javadoc' or the argument are returned. Otherwise, there is no return.
-#
-# The output of this should be passed to ant.
-# @CODE
-# Parameters:
-# $@ - Option value to return. Defaults to 'javadoc'
-#
-# Examples:
-# build javadocs by calling 'javadoc' target
-#	eant $(use_doc)
-#
-# build javadocs by calling 'apidoc' target
-#	eant $(use_doc apidoc)
-# @CODE
-# @RETURN string - Name of the target to create javadocs
-use_doc() {
-	use doc && echo ${@:-javadoc}
-}
-
 
 # @FUNCTION: java-pkg_init
 # @INTERNAL
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-11 22:21 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-11 22:21 UTC (permalink / raw
  To: gentoo-commits
commit:     d99053c9327d72eb0e13de964b0b79355caebc5b
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Sep 11 22:17:22 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Sep 11 22:20:19 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=d99053c9
toolchain.eclass: depend on sys-devel/binutils:*
GCC doesn't build in Gentoo at least without GNU Binutils. It is possible
but it requires some work. It's not clear to me if some of that work
needs to happen in LLVM upstream too (see below).
In commits 7011340a0f13dcada6f3be48054957035bc6e01a and
a7c27596827072f586dc07e6d53531ecb2c7cd6e, I tried to get things building
with Clang's assembler but didn't get it over the line. I think I remember
Arfrever and I coming up with a few later drafts (?) on IRC in #gentoo-hardened
but I didn't commit any of it as it didn't work in the end anyway.
But see https://briancallahan.net/blog/20240122.html which tackles at least
one of the issues I ended up hitting before.
In any case, add the dependency for now to keep things working.
Closes: https://bugs.gentoo.org/936271
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 1 +
 1 file changed, 1 insertion(+)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index ac236f3127f9..c03312be43ad 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -353,6 +353,7 @@ fi
 
 BDEPEND="
 	app-alternatives/yacc
+	sys-devel/binutils:*
 	>=sys-devel/flex-2.5.4
 	nls? ( sys-devel/gettext )
 	test? (
^ permalink raw reply related	[flat|nested] 6663+ messages in thread
* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-12 22:08 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-12 22:08 UTC (permalink / raw
  To: gentoo-commits
commit:     1aa40c5365c0333421d0187a2d9896e910662159
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Sep 12 22:05:41 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Sep 12 22:08:10 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=1aa40c53
mozcoreconf-v6.eclass: drop ia64 support
For toolchain eclasses we usually keep generic stuff like this
for e.g. cross but there's no benefit to leaving it in non-toolchain
eclasses like this.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/mozcoreconf-v6.eclass | 8 ++------
 1 file changed, 2 insertions(+), 6 deletions(-)
diff --git a/eclass/mozcoreconf-v6.eclass b/eclass/mozcoreconf-v6.eclass
index 71dbc6802d71..e7cf85fca24a 100644
--- a/eclass/mozcoreconf-v6.eclass
+++ b/eclass/mozcoreconf-v6.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2023 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: mozcoreconf-v6.eclass
@@ -157,7 +157,7 @@ mozconfig_init() {
 		mozconfig_annotate "less than -O2 causes a segfault on x86" --enable-optimize=-O2
 	elif [[ ${ARCH} == arm ]] && [[ $(gcc-major-version) -ge 6 ]]; then
 		mozconfig_annotate "less than -O2 causes a breakage on arm with gcc-6" --enable-optimize=-O2
-	elif use custom-optimization || [[ ${ARCH} =~ (alpha|ia64) ]]; then
+	elif use custom-optimization || [[ ${ARCH} == alpha ]]; then
 		# Set optimization level based on CFLAGS
 		if is-flag -O0; then
 			mozconfig_annotate "from CFLAGS" --enable-optimize=-O0
@@ -204,10 +204,6 @@ mozconfig_init() {
 		# operation
 		append-flags -fPIC -mieee
 		;;
-	ia64)
-		# Historically we have needed to add this manually for 64-bit
-		append-flags -fPIC
-		;;
 	esac
 
 	# We need to append flags for gcc-6 support
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-17 11:58 Andrew Ammerlaan
  0 siblings, 0 replies; 6663+ messages in thread
From: Andrew Ammerlaan @ 2024-09-17 11:58 UTC (permalink / raw
  To: gentoo-commits
commit:     d50ed41dd6702054d5c8fd7ae86722e9c410f84c
Author:     Andrew Ammerlaan <andrewammerlaan <AT> gentoo <DOT> org>
AuthorDate: Tue Sep 17 10:45:55 2024 +0000
Commit:     Andrew Ammerlaan <andrewammerlaan <AT> gentoo <DOT> org>
CommitDate: Tue Sep 17 11:51:22 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=d50ed41d
kernel-install.eclass: fix gentoo-kernel-bin with llvm-objcopy
We ship the kernel in gentoo-kernel-bin in the form of an UKI, using
objcopy we extract from this the kernel image (and if desired the
generic initramfs).
However, llvm-objcopy does not properly handle the -O argument and as a
result the extracted kernel image is of the same file type as the UKI
(i.e. a PE32+ executable) instead of a regular kernel image. This causes
issues in bootloader such as grub which differentiate between loading
a normal kernel image and loading an EFI executable (such as an UKI).
And also causes the signature verification to fail since the kernel
image is bigger then it should be due to the additional headers.
Using the --dump-section argument instead resolves this problem.
See-also: https://github.com/llvm/llvm-project/issues/108946
Signed-off-by: Andrew Ammerlaan <andrewammerlaan <AT> gentoo.org>
Closes: https://github.com/gentoo/gentoo/pull/38643
Signed-off-by: Andrew Ammerlaan <andrewammerlaan <AT> gentoo.org>
 eclass/kernel-install.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/kernel-install.eclass b/eclass/kernel-install.eclass
index 930640188c26..dc337c7862fd 100644
--- a/eclass/kernel-install.eclass
+++ b/eclass/kernel-install.eclass
@@ -650,7 +650,7 @@ kernel-install_extract_from_uki() {
 	local uki=${2}
 	local out=${3}
 
-	$(tc-getOBJCOPY) -O binary "-j.${extract_type}" "${uki}" "${out}" ||
+	$(tc-getOBJCOPY) "${uki}" --dump-section ".${extract_type}=${out}" ||
 		die "Failed to extract ${extract_type}"
 	chmod 644 "${out}" || die
 }
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-17 12:13 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-09-17 12:13 UTC (permalink / raw
  To: gentoo-commits
commit:     2b795499a41a01b1c06190d4f537693c01d43c04
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Tue Sep 17 09:56:36 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Tue Sep 17 12:12:46 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=2b795499
llvm.org.eclass: Add 20.0.0_pre20240917 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index f8953ec11826..7f7edd6fb652 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -72,6 +72,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 			_LLVM_SOURCE_TYPE=snapshot
 
 			case ${PV} in
+				20.0.0_pre20240917)
+					EGIT_COMMIT=41f1b467a29d2ca4e35df37c3aa79a0a8c04bc4f
+					;;
 				20.0.0_pre20240910)
 					EGIT_COMMIT=bece0d7517bd0a036dc8a319514e4a8a5c497dee
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-18 15:51 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-18 15:51 UTC (permalink / raw
  To: gentoo-commits
commit:     e9971cf188e6578ebdd68af6785a59ab5615abbf
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Sep 18 15:42:39 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Sep 18 15:49:26 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=e9971cf1
toolchain.eclass: make tests opt-in per-ebuild
In 1d93a491096f1cc0234fcf44458bfec142c213bb, we kind of introduced a
timebomb to all GCC ebuilds.
Switch to making it opt-in by setting TOOLCHAIN_HAS_TESTS in ebuilds
which want to use validate_failures.py. It hasn't been tested and may
not even work with gnat-gpl and kgcc64 so it doesn't make sense
to have it by default, especially for gnat-gpl which is now just
a bootstrap package anyway.
Bug: https://bugs.gentoo.org/934124
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 22 ++++++++++++++++------
 1 file changed, 16 insertions(+), 6 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index c03312be43ad..a545f730ada7 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -22,7 +22,9 @@ _TOOLCHAIN_ECLASS=1
 DESCRIPTION="The GNU Compiler Collection"
 HOMEPAGE="https://gcc.gnu.org/"
 
-inherit edo flag-o-matic gnuconfig libtool multilib pax-utils python-any-r1 toolchain-funcs prefix
+inherit edo flag-o-matic gnuconfig libtool multilib pax-utils toolchain-funcs prefix
+
+[[ -n ${TOOLCHAIN_HAS_TESTS} ]] && inherit python-any-r1
 
 tc_is_live() {
 	[[ ${PV} == *9999* ]]
@@ -143,6 +145,12 @@ tc_version_is_between() {
 # @DESCRIPTION:
 # Indicate the developer who hosts the patchset for an ebuild.
 
+# @ECLASS_VARIABLE: TOOLCHAIN_HAS_TESTS
+# @DEFAULT_UNSET
+# @DESCRIPTION:
+# Controls whether python-any-r1 is inherited and validate_failures.py
+# is used.
+
 # @ECLASS_VARIABLE: GCC_PV
 # @INTERNAL
 # @DESCRIPTION:
@@ -273,6 +281,7 @@ STDCXX_INCDIR=${TOOLCHAIN_STDCXX_INCDIR:-${LIBPATH}/include/g++-v${GCC_BRANCH_VE
 LICENSE="GPL-3+ LGPL-3+ || ( GPL-3+ libgcc libstdc++ gcc-runtime-library-exception-3.1 ) FDL-1.3+"
 IUSE="test vanilla +nls"
 RESTRICT="!test? ( test )"
+[[ -z ${TOOLCHAIN_HAS_TESTS} ]] && RESTRICT+=" test"
 
 TC_FEATURES=()
 
@@ -537,7 +546,8 @@ get_gcc_src_uri() {
 	[[ -n ${MUSL_VER} ]] && \
 		GCC_SRC_URI+=" $(gentoo_urls gcc-${MUSL_GCC_VER}-musl-patches-${MUSL_VER}.tar.${TOOLCHAIN_PATCH_SUFFIX})"
 
-	GCC_SRC_URI+=" test? ( https://gitweb.gentoo.org/proj/gcc-patches.git/plain/scripts/testsuite-management/validate_failures.py?id=${GCC_VALIDATE_FAILURES_VERSION} -> gcc-validate-failures-${GCC_VALIDATE_FAILURES_VERSION}.py )"
+	[[ -n ${TOOLCHAIN_HAS_TESTS} ]] && \
+		GCC_SRC_URI+=" test? ( https://gitweb.gentoo.org/proj/gcc-patches.git/plain/scripts/testsuite-management/validate_failures.py?id=${GCC_VALIDATE_FAILURES_VERSION} -> gcc-validate-failures-${GCC_VALIDATE_FAILURES_VERSION}.py )"
 
 	echo "${GCC_SRC_URI}"
 }
@@ -569,7 +579,7 @@ toolchain_pkg_setup() {
 	# more legible.
 	MAKEOPTS="--output-sync=line ${MAKEOPTS}"
 
-	use test && python-any-r1_pkg_setup
+	[[ -n ${TOOLCHAIN_HAS_TESTS} ]] && use test && python-any-r1_pkg_setup
 }
 
 #---->> src_unpack <<----
@@ -633,7 +643,7 @@ toolchain_src_prepare() {
 		tc_enable_hardened_gcc
 	fi
 
-	if use test ; then
+	if [[ -n ${TOOLCHAIN_HAS_TESTS} ]] && use test ; then
 		cp "${DISTDIR}"/gcc-validate-failures-${GCC_VALIDATE_FAILURES_VERSION}.py "${T}"/validate_failures.py || die
 		chmod +x "${T}"/validate_failures.py || die
 	fi
@@ -2275,7 +2285,7 @@ toolchain_src_install() {
 	pax-mark -r "${ED}/libexec/gcc/${CTARGET}/${GCC_CONFIG_VER}/cc1"
 	pax-mark -r "${ED}/libexec/gcc/${CTARGET}/${GCC_CONFIG_VER}/cc1plus"
 
-	if use test ; then
+	if [[ -n ${TOOLCHAIN_HAS_TESTS} ]] && use test ; then
 		mkdir "${T}"/test-results || die
 		cd "${WORKDIR}"/build || die
 		find . -name \*.sum -exec cp --parents -v {} "${T}"/test-results \; || die
@@ -2434,7 +2444,7 @@ create_revdep_rebuild_entry() {
 #---->> pkg_pre* <<----
 
 toolchain_pkg_preinst() {
-	if [[ ${MERGE_TYPE} != binary ]] && use test ; then
+	if [[ -n ${TOOLCHAIN_HAS_TESTS} && ${MERGE_TYPE} != binary ]] && use test ; then
 		# Install as orphaned to allow comparison across more versions even
 		# after unmerged. Also useful for historical records and tracking
 		# down regressions a while after they first appeared, but were only
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-19 22:57 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-19 22:57 UTC (permalink / raw
  To: gentoo-commits
commit:     d56d8f8e35fa4f7b8d65dbd6cd535ad6ac69cc9c
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Sep 19 22:55:44 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Sep 19 22:57:19 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=d56d8f8e
toolchain.eclass: disable automagic CET for x86
It's not supported on 32-bit kernels anyway.
This got lost in b6bf005b843e3d6ee10aa1f088d93c4f89055cc6 when wiring
up arm64.
Bug: https://bugs.gentoo.org/916381
Closes: https://bugs.gentoo.org/939874
Fixes: b6bf005b843e3d6ee10aa1f088d93c4f89055cc6
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 4 +++-
 1 file changed, 3 insertions(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index a545f730ada7..0557db974035 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1310,7 +1310,9 @@ toolchain_src_configure() {
 	fi
 
 	if in_iuse cet ; then
-		[[ ${CTARGET} == x86_64-*-gnu* ]] && confgcc+=( $(use_enable cet) )
+		if [[ ${CTARGET} == i[[34567]]86-*-linux* || ${CTARGET} == x86_64-*-gnu* ]] ; then
+			confgcc+=( $(use_enable cet) )
+		fi
 		[[ ${CTARGET} == aarch64-*-gnu* ]] && confgcc+=( $(use_enable cet standard-branch-protection) )
 	fi
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-23 12:06 Ulrich Müller
  0 siblings, 0 replies; 6663+ messages in thread
From: Ulrich Müller @ 2024-09-23 12:06 UTC (permalink / raw
  To: gentoo-commits
commit:     452c39b1b97dd8e472c381c90814ca7151bbd80d
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Mon Sep  2 15:18:17 2024 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Mon Sep 23 12:05:36 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=452c39b1
elisp.eclass: Add pkg_info
Sync from Emacs overlay.
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 eclass/elisp.eclass | 10 ++++++++--
 1 file changed, 8 insertions(+), 2 deletions(-)
diff --git a/eclass/elisp.eclass b/eclass/elisp.eclass
index 20139491c976..1fa8aab29753 100644
--- a/eclass/elisp.eclass
+++ b/eclass/elisp.eclass
@@ -1,4 +1,4 @@
-# Copyright 2002-2023 Gentoo Authors
+# Copyright 2002-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: elisp.eclass
@@ -205,5 +205,11 @@ elisp_pkg_postrm() {
 	elisp-site-regen
 }
 
+elisp_pkg_info() {
+	if [[ -n ${_ELISP_EMACS_VERSION} ]]; then
+		echo "Built with Emacs version: ${_ELISP_EMACS_VERSION}"
+	fi
+}
+
 EXPORT_FUNCTIONS src_{unpack,prepare,configure,compile,test,install} \
-	pkg_{setup,postinst,postrm}
+	pkg_{setup,postinst,postrm,info}
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-23 15:11 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-09-23 15:11 UTC (permalink / raw
  To: gentoo-commits
commit:     f0877c745f598b59edcb3e9b5395259f16df8611
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Mon Sep 23 14:41:17 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Mon Sep 23 15:11:41 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=f0877c74
llvm.org.eclass: Enable prebuilt manpages for 19
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index 7f7edd6fb652..3050fd1e471e 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -300,6 +300,9 @@ llvm.org_set_globals() {
 				18*)
 					LLVM_MANPAGE_DIST="llvm-18.1.0-manpages.tar.bz2"
 					;;
+				19*)
+					LLVM_MANPAGE_DIST="llvm-19.1.0-manpages.tar.bz2"
+					;;
 			esac
 		fi
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-24  6:41 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-09-24  6:41 UTC (permalink / raw
  To: gentoo-commits
commit:     0be38fc6bebba7f193d243a35915f6d393319fd3
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Tue Sep 24 06:12:34 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Tue Sep 24 06:41:39 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=0be38fc6
distutils-r1.eclasS: Switch scikit-build-core to build.verbose
Replace `cmake.verbose` with `build.verbose`, following the change
in scikit-build-core 0.10.
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/distutils-r1.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/distutils-r1.eclass b/eclass/distutils-r1.eclass
index 5a6ebdcede8a..53b40163c216 100644
--- a/eclass/distutils-r1.eclass
+++ b/eclass/distutils-r1.eclass
@@ -1339,9 +1339,9 @@ distutils_pep517_install() {
 					ninjaopts = shlex.split(os.environ["NINJAOPTS"])
 					print(json.dumps({
 						"build.tool-args": ninjaopts,
+						"build.verbose": True,
 						"cmake.args": ";".join(sys.argv[1:]),
 						"cmake.build-type": "${CMAKE_BUILD_TYPE}",
-						"cmake.verbose": True,
 						"install.strip": False,
 					}))
 				EOF
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-24 11:52 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-24 11:52 UTC (permalink / raw
  To: gentoo-commits
commit:     5ff4a902b3706209c6fe148d9e3c621f6cc53ba4
Author:     YiFei Zhu <zhuyifei1999 <AT> gmail <DOT> com>
AuthorDate: Fri Sep 13 04:38:04 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Sep 24 11:51:20 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=5ff4a902
autotools.eclass: Run eautoheader with --force
To quote Eli [1] (I can't explain it better than this):
  autotools.eclass runs autoheader without options (and in
  particular without --force). This will only remake config.h.in
  if there are actual changes to the content, which in turn means
  that it will be out of date compared to aclocal.m4 (which we very
  much expect to have changes).
  So `make` sees that the header is out of date, and runs autoheader
  yet again, this time updating the timestamp for `make` purposes.
This causes QA warning that "maintainer mode" is detected.
autoheader and autoconf added --force option at the same time [2],
so no reason only autoconf has that option in the eclass and not
autoheader.
Like, autoconf, a check on WANT_AUTOCONF != 2.1 is added because the
feature was added in autoconf 2.52.
[1] https://bugs.gentoo.org/939468#c6
[2] https://git.savannah.gnu.org/gitweb/?p=autoconf.git;a=commitdiff;h=dbf7fc61
Closes: https://bugs.gentoo.org/939468
Closes: https://bugs.gentoo.org/939535
Signed-off-by: YiFei Zhu <zhuyifei1999 <AT> gmail.com>
Closes: https://github.com/gentoo/gentoo/pull/38588
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/autotools.eclass | 8 +++++++-
 1 file changed, 7 insertions(+), 1 deletion(-)
diff --git a/eclass/autotools.eclass b/eclass/autotools.eclass
index 0571b18ba525..641612f37193 100644
--- a/eclass/autotools.eclass
+++ b/eclass/autotools.eclass
@@ -312,7 +312,13 @@ eautoreconf() {
 	else
 		eautoconf --force
 	fi
-	[[ ${AT_NOEAUTOHEADER} != "yes" ]] && eautoheader
+	if [[ ${AT_NOEAUTOHEADER} != "yes" ]] ; then
+		if [[ ${WANT_AUTOCONF} == "2.1" ]] ; then
+			eautoheader
+		else
+			eautoheader --force
+		fi
+	fi
 	[[ ${AT_NOEAUTOMAKE} != "yes" ]] && FROM_EAUTORECONF="yes" eautomake ${AM_OPTS}
 
 	if [[ ${AT_NOELIBTOOLIZE} != "yes" ]] ; then
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-24 18:02 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-09-24 18:02 UTC (permalink / raw
  To: gentoo-commits
commit:     e9d99a93456b6dc99cdefe280506a2384a6ef031
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Tue Sep 24 17:36:02 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Tue Sep 24 18:02:40 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=e9d99a93
llvm.org.eclass: Remove old snapshots
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 6 ------
 1 file changed, 6 deletions(-)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index 5b58209b70ce..2338c3f2cc53 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -78,12 +78,6 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 				20.0.0_pre20240917)
 					EGIT_COMMIT=41f1b467a29d2ca4e35df37c3aa79a0a8c04bc4f
 					;;
-				20.0.0_pre20240910)
-					EGIT_COMMIT=bece0d7517bd0a036dc8a319514e4a8a5c497dee
-					;;
-				20.0.0_pre20240830)
-					EGIT_COMMIT=5500e21942f7047344b6fee62d3e08c0ba2f9182
-					;;
 				*)
 					die "Unknown snapshot: ${PV}"
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-24 18:02 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-09-24 18:02 UTC (permalink / raw
  To: gentoo-commits
commit:     af6c5d43495b66c3d450f9b9072d653a222fd5ad
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Tue Sep 24 17:35:44 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Tue Sep 24 18:02:39 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=af6c5d43
llvm.org.eclass: Add 20.0.0_pre20240924 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index 3050fd1e471e..5b58209b70ce 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -72,6 +72,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 			_LLVM_SOURCE_TYPE=snapshot
 
 			case ${PV} in
+				20.0.0_pre20240924)
+					EGIT_COMMIT=cde7b30268a85a3e7900a31534a97e7eb4de9236
+					;;
 				20.0.0_pre20240917)
 					EGIT_COMMIT=41f1b467a29d2ca4e35df37c3aa79a0a8c04bc4f
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-25  4:39 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-09-25  4:39 UTC (permalink / raw
  To: gentoo-commits
commit:     d8d5d91d4f63eff646ed7cd25138a02ffec1b1b3
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Wed Sep 25 04:18:51 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Wed Sep 25 04:39:05 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=d8d5d91d
distutils-r1.eclass: Revert "Switch scikit-build-core to build.verbose"
This change broke all packages using a lower minimum-version.  Sigh.
Reverts: 0be38fc6bebba7f193d243a35915f6d393319fd3
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/distutils-r1.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/distutils-r1.eclass b/eclass/distutils-r1.eclass
index 53b40163c216..5a6ebdcede8a 100644
--- a/eclass/distutils-r1.eclass
+++ b/eclass/distutils-r1.eclass
@@ -1339,9 +1339,9 @@ distutils_pep517_install() {
 					ninjaopts = shlex.split(os.environ["NINJAOPTS"])
 					print(json.dumps({
 						"build.tool-args": ninjaopts,
-						"build.verbose": True,
 						"cmake.args": ";".join(sys.argv[1:]),
 						"cmake.build-type": "${CMAKE_BUILD_TYPE}",
+						"cmake.verbose": True,
 						"install.strip": False,
 					}))
 				EOF
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-25  4:51 Ulrich Müller
  0 siblings, 0 replies; 6663+ messages in thread
From: Ulrich Müller @ 2024-09-25  4:51 UTC (permalink / raw
  To: gentoo-commits
commit:     b427795a254820cc188cad8c88d47eaf7078c7f4
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Mon Aug 26 12:23:35 2024 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Wed Sep 25 04:51:03 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=b427795a
plasma-mobile.kde.org.eclass: Remove dead eclass
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 eclass/plasma-mobile.kde.org.eclass | 49 -------------------------------------
 1 file changed, 49 deletions(-)
diff --git a/eclass/plasma-mobile.kde.org.eclass b/eclass/plasma-mobile.kde.org.eclass
deleted file mode 100644
index 3349f90745bd..000000000000
--- a/eclass/plasma-mobile.kde.org.eclass
+++ /dev/null
@@ -1,49 +0,0 @@
-# Copyright 1999-2023 Gentoo Authors
-# Distributed under the terms of the GNU General Public License v2
-
-# @DEAD
-# @ECLASS: plasma-mobile.kde.org.eclass
-# @MAINTAINER:
-# kde@gentoo.org
-# @SUPPORTED_EAPIS: 8
-# @PROVIDES: kde.org
-# @BLURB: Support eclass for KDE Plasma Mobile packages.
-# @DESCRIPTION:
-# This eclass extends kde.org.eclass for Plasma Mobile release group to assemble
-# default SRC_URI for tarballs, set up git-r3.eclass for stable/master branch
-# versions or restrict access to unreleased (packager access only) tarballs
-# in Gentoo KDE overlay.
-#
-# This eclass unconditionally inherits kde.org.eclass and all its public
-# variables and helper functions (not phase functions) may be considered as
-# part of this eclass's API.
-
-case ${EAPI} in
-	8) ;;
-	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
-esac
-
-if [[ -z ${_PLASMA_MOBILE_KDE_ORG_ECLASS} ]]; then
-_PLASMA_MOBILE_KDE_ORG_ECLASS=1
-
-# @ECLASS_VARIABLE: KDE_ORG_CATEGORY
-# @PRE_INHERIT
-# @DESCRIPTION:
-# For proper description see kde.org.eclass manpage.
-: "${KDE_ORG_CATEGORY:=plasma-mobile}"
-
-inherit kde.org
-
-HOMEPAGE="https://plasma-mobile.org/"
-
-# @ECLASS_VARIABLE: KDE_ORG_SCHEDULE_URI
-# @INTERNAL
-# @DESCRIPTION:
-# For proper description see kde.org.eclass manpage.
-KDE_ORG_SCHEDULE_URI="https://invent.kde.org/plasma/plasma-mobile/-/wikis/Release-Schedule"
-
-if [[ ${KDE_BUILD_TYPE} != live && -z ${KDE_ORG_COMMIT} ]]; then
-	SRC_URI="mirror://kde/stable/plasma-mobile/$(ver_cut 1-2)/${KDE_ORG_NAME}-${PV}.tar.xz"
-fi
-
-fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-25 11:12 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-25 11:12 UTC (permalink / raw
  To: gentoo-commits
commit:     c99c693ff970d9c5cf5204466d791b9a3d4499fa
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Sep 25 11:12:05 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Sep 25 11:12:05 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=c99c693f
guile.eclass: fix EclassExportFuncsBeforeInherit
Bug: https://github.com/pkgcore/pkgcheck/issues/702
Bug: https://github.com/pkgcore/pkgcheck/issues/703
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/guile.eclass | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/eclass/guile.eclass b/eclass/guile.eclass
index 323d04ef1152..e8fde64266e5 100644
--- a/eclass/guile.eclass
+++ b/eclass/guile.eclass
@@ -353,7 +353,7 @@ guile_src_install() {
 	einstalldocs
 }
 
-EXPORT_FUNCTIONS pkg_setup src_prepare src_configure src_compile \
-				 src_install src_test
-
 fi  # _GUILE_ECLASS
+
+EXPORT_FUNCTIONS pkg_setup src_prepare src_configure src_compile \
+				src_install src_test
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-25 11:12 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-25 11:12 UTC (permalink / raw
  To: gentoo-commits
commit:     439ef0b575ddeda03f92542339cff14e84b21604
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Sep 25 11:11:26 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Sep 25 11:11:26 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=439ef0b5
guile-single.eclass: fix EclassExportFuncsBeforeInherit
Bug: https://github.com/pkgcore/pkgcheck/issues/702
Bug: https://github.com/pkgcore/pkgcheck/issues/703
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/guile-single.eclass | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/eclass/guile-single.eclass b/eclass/guile-single.eclass
index 91f6036139da..66898504a6c4 100644
--- a/eclass/guile-single.eclass
+++ b/eclass/guile-single.eclass
@@ -240,6 +240,6 @@ guile-single_src_install() {
 	guile_unstrip_ccache
 }
 
-EXPORT_FUNCTIONS pkg_setup src_prepare src_install
-
 fi  # _GUILE_SINGLE_ECLASS
+
+EXPORT_FUNCTIONS pkg_setup src_prepare src_install
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-25 11:12 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-25 11:12 UTC (permalink / raw
  To: gentoo-commits
commit:     4c3f798d2394f8c4b6e7e8fc5e8cc4a35c0f8ed5
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Sep 25 11:12:12 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Sep 25 11:12:12 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=4c3f798d
xdg.eclass: fix EclassExportFuncsBeforeInherit
Bug: https://github.com/pkgcore/pkgcheck/issues/702
Bug: https://github.com/pkgcore/pkgcheck/issues/703
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/xdg.eclass | 10 ++++++++--
 1 file changed, 8 insertions(+), 2 deletions(-)
diff --git a/eclass/xdg.eclass b/eclass/xdg.eclass
index 6af4b91875fc..2e16a438d840 100644
--- a/eclass/xdg.eclass
+++ b/eclass/xdg.eclass
@@ -45,8 +45,6 @@ case ${EAPI} in
 			default
 		}
 
-		EXPORT_FUNCTIONS src_prepare
-
 		DEPEND="${_XDG_DEPEND}"
 		;;
 	*)
@@ -131,4 +129,12 @@ xdg_pkg_postrm() {
 
 fi
 
+case ${EAPI} in
+	6|7)
+		EXPORT_FUNCTIONS src_prepare
+		;;
+	*)
+		;;
+esac
+
 EXPORT_FUNCTIONS pkg_preinst pkg_postinst pkg_postrm
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-25 19:29 Eli Schwartz
  0 siblings, 0 replies; 6663+ messages in thread
From: Eli Schwartz @ 2024-09-25 19:29 UTC (permalink / raw
  To: gentoo-commits
commit:     58128e2701881192e5d551d6b1d27bac3f6cde58
Author:     Eli Schwartz <eschwartz <AT> gentoo <DOT> org>
AuthorDate: Wed Sep 25 17:51:52 2024 +0000
Commit:     Eli Schwartz <eschwartz <AT> gentoo <DOT> org>
CommitDate: Wed Sep 25 18:22:23 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=58128e27
toolchain.eclass: ban the use of rlibtool
dev-build/slibtool provides an alternative implementation of libtool
which is intended to hook itself into and replace the ltmain.sh-based
./libtool shell scripts installed into an autotools build system.
It has some interesting quirks. In particular, it takes the idea of
"packagers don't want to install libtool archives for random libraries
because nobody uses them and pkg-config is better" and runs with it. It
runs quite far with it, as it doesn't install them at all without a new
flag passed to slibtool. This is redundant with our existing approach of
deleting them in src_install when we know they are useless, and is
downright broken in cases such as GCC, where the libtool archives are
load-bearing and the resultant compiler is, in their absence,
nonfunctional.
slibtool supports a variety of wrappers to enable reasonable
functionality which it by default disabled. The official recommendation
is you are supposed to use "rlibtool" to replace ./libtool as it
performs heuristics based on the generated config. But we actually need
"rclibtool", which both respects the generated config and also generates
the *.la archives and leaves it up to ebuilds to decide whether they
should be removed.
Raise a fatal error if the user has misconfigured slibtool. This
prevents the user from building a broken and malformed GCC.
Closes: https://bugs.gentoo.org/932245
Closes: https://bugs.gentoo.org/924150
Closes: https://bugs.gentoo.org/931268
Closes: https://bugs.gentoo.org/931279
Signed-off-by: Eli Schwartz <eschwartz <AT> gentoo.org>
Reviewed-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 0557db974035..53b64a470e37 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -574,6 +574,9 @@ toolchain_pkg_setup() {
 	# bug #265283
 	unset LANGUAGES
 
+	# bug #932245
+	[[ ${LIBTOOL} = rlibtool ]] && die "\$LIBTOOL is using rlibtool from dev-build/slibtool. You must not use rlibtool, only rclibtool."
+
 	# See https://www.gnu.org/software/make/manual/html_node/Parallel-Output.html
 	# Avoid really confusing logs from subconfigure spam, makes logs far
 	# more legible.
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-29  0:18 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-29  0:18 UTC (permalink / raw
  To: gentoo-commits
commit:     687e6b6f1b665dbc5b37f470d4984c9c34eabad3
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Aug  3 02:10:34 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Sep 29 00:18:07 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=687e6b6f
toolchain.eclass: enable libada with USE=ada
This was added in d6d640106d59381bf34fea26b80c31e1de8c9e6b but it's not
clear to me why.
Noticed because it causes loads of Ada test failures as UNRESOLVED,
failing with:
```
gnatmake: RTS path "/var/tmp/portage/sys-devel/gcc-15.0.9999/work/build/x86_64-pc-linux-gnu/./libada" not valid: missing adainclude and adalib directories
compiler exited with status 1
```
Fixes: d6d640106d59381bf34fea26b80c31e1de8c9e6b
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 53b64a470e37..e9ee095d772e 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1309,7 +1309,7 @@ toolchain_src_configure() {
 	fi
 
 	if in_iuse ada ; then
-		confgcc+=( --disable-libada )
+		confgcc+=( $(use_enable ada libada) )
 	fi
 
 	if in_iuse cet ; then
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-29  0:18 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-29  0:18 UTC (permalink / raw
  To: gentoo-commits
commit:     1381eb9987c440618861c7d22df04871a235233c
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Aug  4 01:27:16 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Sep 29 00:18:08 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=1381eb99
toolchain.eclass: more Ada cleanup
Breaks w/ pic linking and unnecessary. Use the regular build system route.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 12 ------------
 1 file changed, 12 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index e9ee095d772e..f8c290bf4a07 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1878,18 +1878,6 @@ gcc_do_make() {
 	pushd "${WORKDIR}"/build >/dev/null || die
 	emake "${emakeargs[@]}" ${GCC_MAKE_TARGET}
 
-	if is_ada; then
-		# Without these links, it is not getting the good compiler
-		# TODO: Need to check why
-		ln -s gcc ../build/prev-gcc || die
-		ln -s ${CHOST} ../build/prev-${CHOST} || die
-
-		# Building standard ada library
-		emake -C gcc gnatlib-shared
-		# Building gnat toold
-		emake -C gcc gnattools
-	fi
-
 	if ! is_crosscompile && _tc_use_if_iuse cxx && _tc_use_if_iuse doc ; then
 		if type -p doxygen > /dev/null ; then
 			cd "${CTARGET}"/libstdc++-v3/doc || die
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-29  0:18 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-29  0:18 UTC (permalink / raw
  To: gentoo-commits
commit:     799693623d76c89e8b04d2434d0dfece44bb49f9
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Aug  3 02:27:51 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Sep 29 00:18:08 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=79969362
toolchain.eclass: Ada rework
Look hard for an existing GNAT for use for bootstrapping without requiring
users to run `gcc-config` / switch their system copy of GCC, which is both
brittle in that it requires manual intervention, and also unclean.
Started looking at this after https://public-inbox.gentoo.org/gentoo-dev/2a700166-f01a-4807-bd76-7b0cce72af0b <AT> archeia.com/
although the approach is different. I did use it as a base although not
much of it remains.
We take the following approach:
* Iterate over installed GCC slots (preferring ${SLOT}, then iterating
  from the latest version installed down to GCC 10) to find a copy of
  GNAT;
* Create wrappers for gnat* to redirect calls when building GCC to
  our found bootstrap copy of GNAT;
* Use an extracted spec file to redirect gnat1 calls to that bootstrap
  copy too, as the build system doesn't allow saying "just use this copy
  of gnat" (it always wants $(CC) to support it).
  The real nasty part here is that GCC's build system doesn't seem to have
  a way to point to 'ADACC' or similar (it looks like it did have 'ADAC' years ago).
Remaining bits to be done:
* Adapting/replacing/supplementing dev-lang/gnat-gpl with a version that
  can be installed in parallel to sys-devel/gcc:10 so it can be pulled
  in transparently for bootstrapping;
* Build our own, or source some other copy (e.g. from Alire), of a newer
  bootstrap GNAT. https://github.com/alire-project/GNAT-FSF-builds is
  a likely candidate.
I also hope that we can ultimately do the same for D.
Bug: https://gcc.gnu.org/PR864
Bug: https://gcc.gnu.org/PR108909
Bug: https://bugs.gentoo.org/137268
Bug: https://bugs.gentoo.org/547358
Bug: https://bugs.gentoo.org/919667
Closes: https://bugs.gentoo.org/937774
Link: https://lists.fedorahosted.org/archives/list/epel-devel <AT> lists.fedoraproject.org/thread/CVQ3JIOZI5ODYDZU2DZLA37JWSLMCIN7/
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 143 +++++++++++++++++++++++++++++++++++++++++++++++-
 1 file changed, 141 insertions(+), 2 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index f8c290bf4a07..cfddba99a1a8 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -401,8 +401,6 @@ if tc_has_feature valgrind ; then
 	BDEPEND+=" valgrind? ( dev-debug/valgrind )"
 fi
 
-# TODO: Add a pkg_setup & pkg_pretend check for whether the active compiler
-# supports Ada.
 if [[ ${PN} != gnat-gpl ]] && tc_has_feature ada ; then
 	BDEPEND+=" ada? ( || ( sys-devel/gcc[ada] dev-lang/gnat-gpl[ada] ) )"
 fi
@@ -558,6 +556,8 @@ SRC_URI=$(get_gcc_src_uri)
 
 toolchain_pkg_pretend() {
 	if ! _tc_use_if_iuse cxx ; then
+		_tc_use_if_iuse ada && \
+			ewarn 'Ada requires a C++ compiler, disabled due to USE="-cxx"'
 		_tc_use_if_iuse go && \
 			ewarn 'Go requires a C++ compiler, disabled due to USE="-cxx"'
 		_tc_use_if_iuse objc++ && \
@@ -854,6 +854,143 @@ toolchain_src_configure() {
 	fi
 	[[ -n ${CBUILD} ]] && confgcc+=( --build=${CBUILD} )
 
+	_need_ada_bootstrap_mangling() {
+		if [[ ${CATEGORY}/${PN} == dev-lang/gnat-gpl ]] ; then
+			_tc_use_if_iuse system-bootstrap && return 0
+			return 1
+		fi
+
+		_tc_use_if_iuse ada
+	}
+
+	if _need_ada_bootstrap_mangling ; then
+		local latest_gcc=$(best_version -b "sys-devel/gcc")
+		latest_gcc="${latest_gcc#sys-devel/gcc-}"
+		latest_gcc=$(ver_cut 1 ${latest_gcc})
+
+		local ada_bootstrap
+		local ada_candidate
+		# We always prefer the version being built if possible
+		# as it has the greatest chance of success. Failing that,
+		# try the latest installed GCC and iterate downwards.
+		for ada_candidate in ${SLOT} $(seq ${latest_gcc} -1 10) ; do
+			has_version -b "sys-devel/gcc:${ada_candidate}" || continue
+
+			ebegin "Testing sys-devel/gcc:${ada_candidate} for Ada"
+			if has_version -b "sys-devel/gcc:${ada_candidate}[ada(-)]" ; then
+				# Make sure we set a path to the Ada bootstrap if gcc[ada] is not already
+				# installed. GNAT can usually be built using the last major version and
+				# the current version, at least.
+				ada_bootstrap=${ada_candidate}
+
+				eend 0
+				break
+			fi
+			eend 1
+		done
+
+		# As a last resort, use dev-lang/gnat-gpl.
+		# TODO: Make gnat-gpl coinstallable with gcc:10.
+		if [[ -z ${ada_bootstrap} ]] ; then
+			ebegin "Testing dev-lang/gnat-gpl for Ada"
+			if has_version -b "dev-lang/gnat-gpl" ; then
+				ada_bootstrap=10
+				eend 0
+			else
+				eend 1
+			fi
+		fi
+
+		# OK, even gnat-gpl didn't work. Give up for now.
+		# TODO: Source a newer, or build our own, bootstrap tarball.
+		if [[ -z ${ada_bootstrap} ]] ; then
+			die "Fallback ada-bootstrap path not yet implemented!"
+
+			#einfo "Using bootstrap GNAT compiler..."
+			#export PATH="${BROOT}/opt/ada-bootstrap-${GCCMAJOR}/bin:${PATH}"
+		fi
+
+		cat <<-"EOF" > "${T}"/ada.spec || die
+		# Extracted from gcc/ada/gcc-interface/lang-specs.h
+		.adb:
+		@ada
+
+		.ads:
+		@ada
+
+		# TODO: ADA_DUMPS_OPTIONS
+		@ada:
+		%{pg:%{fomit-frame-pointer:%e-pg and -fomit-frame-pointer are incompatible}} \
+			%{!S:%{!c:%e-c or -S required for Ada}} \
+			${BROOT}/usr/libexec/gcc/${CBUILD}/${ada_bootstrap}/gnat1 %{I*} %{k8:-gnatk8} %{!Q:-quiet} \
+			%{nostdinc*} %{nostdlib*} \
+			%{fcompare-debug-second:-gnatd_A} \
+			%{O*} %{W*} %{w} %{p} %{pg:-p} \
+			%{coverage:-fprofile-arcs -ftest-coverage} \
+			%{Wall:-gnatwa} %{Werror:-gnatwe} %{w:-gnatws} \
+			%{gnatea:-gnatez} %{g*&m*&f*} \
+			%1 %{!S:%{o*:%w%*-gnatO}} \
+			%i %{S:%W{o*}%{!o*:-o %w%b.s}} \
+			%{gnatc*|gnats*: -o %j} %{-param*} \
+			%{!gnatc*:%{!gnats*:%(invoke_as)}}
+
+		@adawhy:
+			%{!c:%e-c required for gnat2why} \
+			gnat1why %{I*} %{k8:-gnatk8} %{!Q:-quiet} \
+			%{nostdinc*} %{nostdlib*} \
+			%{a} \
+			%{gnatea:-gnatez} %{g*&m*&f*} \
+			%1 %{o*:%w%*-gnatO} \
+			%i \
+			%{gnatc*|gnats*: -o %j} %{-param*}
+
+		@adascil:
+			%{!c:%e-c required for gnat2scil} \
+			gnat1scil %{I*} %{k8:-gnatk8} %{!Q:-quiet} \
+			%{nostdinc*} %{nostdlib*} \
+			%{a} \
+			%{gnatea:-gnatez} %{g*&m*&f*} \
+			%1 %{o*:%w%*-gnatO} \
+			%i \
+			%{gnatc*|gnats*: -o %j} %{-param*}
+		EOF
+
+		# Easier to substitute these values in rather than escape
+		# lots of bits above in heredoc.
+		sed -i \
+			-e "s:\${BROOT}:${BROOT}:" \
+			-e "s:\${CBUILD}:${CBUILD}:" \
+			-e "s:\${ada_bootstrap}:${ada_bootstrap}:" \
+			"${T}"/ada.spec || die
+
+		# The Makefile tries to find libgnat by querying $(CC) which
+		# won't work for us as the stage1 compiler doesn't necessarily
+		# have Ada support. Substitute the Ada compiler we found earlier.
+		local adalib
+		adalib=$(${CBUILD}-gcc-${ada_bootstrap} -print-libgcc-file-name || die "Finding adalib dir failed")
+		adalib="${adalib%/*}/adalib"
+		sed -i \
+			-e "s:adalib=.*:adalib=${adalib}:" \
+			"${S}"/gcc/ada/gcc-interface/Make-lang.in || die
+
+		# Create bin wrappers because not all of the build system
+		# respects GNATBIND or GNATMAKE.
+		mkdir "${T}"/ada-wrappers || die
+		local tool
+		for tool in gnat{,bind,chop,clean,kr,link,ls,make,name,prep} ; do
+			cat <<-EOF > "${T}"/ada-wrappers/${tool} || die
+			#!/bin/bash
+			exec $(type -P ${CBUILD}-${tool}-${ada_bootstrap}) -specs=${T}/ada.spec "\$@"
+			EOF
+			chmod +x "${T}"/ada-wrappers/${tool} || die
+
+			export "${tool^^}"=${CBUILD}-${tool}-${ada_bootstrap}
+		done
+
+		export PATH="${T}/ada-wrappers:${PATH}"
+		export CC="$(tc-getCC) -specs=${T}/ada.spec"
+	fi
+
 	confgcc+=(
 		--prefix="${PREFIX}"
 		--bindir="${BINPATH}"
@@ -1438,6 +1575,8 @@ toolchain_src_configure() {
 	einfo "DATAPATH:        ${DATAPATH}"
 	einfo "STDCXX_INCDIR:   ${STDCXX_INCDIR}"
 	einfo "Languages:       ${GCC_LANG}"
+	einfo "GCC version:     $($(tc-getCC) -v 2>&1 | grep ' version ' | awk '{ print $3 }')"
+	is_ada && einfo "GNAT version:    $(gnat 2>&1 | grep GNAT | awk '{ print $2 }')"
 	echo
 
 	# Build in a separate build tree
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-29  1:07 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-29  1:07 UTC (permalink / raw
  To: gentoo-commits
commit:     3355cb0ab6d92d84eeff44163da5309d114726b3
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Sep 29 01:04:44 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Sep 29 01:04:44 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=3355cb0a
toolchain.eclass: rework D handling
The recent work for Ada makes things easier here because you don't
have to try juggle both GNAT and GDC at the same time.
Anyway, let's do something similar: iterate over installed GCCs
and try to use the best GDC available for bootstrapping, so users
don't have to manually select it with `gcc-config`. More mangling
may be needed than setting GDC down the line.
Bug: https://bugs.gentoo.org/868228
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 26 ++++++++++++++++++++++++++
 1 file changed, 26 insertions(+)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index cfddba99a1a8..30d96f25aaa8 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -991,6 +991,32 @@ toolchain_src_configure() {
 		export CC="$(tc-getCC) -specs=${T}/ada.spec"
 	fi
 
+	if _tc_use_if_iuse d ; then
+		local latest_gcc=$(best_version -b "sys-devel/gcc")
+		latest_gcc="${latest_gcc#sys-devel/gcc-}"
+		latest_gcc=$(ver_cut 1 ${latest_gcc})
+
+		local d_bootstrap
+		local d_candidate
+		# We always prefer the version being built if possible
+		# as it has the greatest chance of success. Failing that,
+		# try the latest installed GCC and iterate downwards.
+		for d_candidate in ${SLOT} $(seq ${latest_gcc} -1 10) ; do
+			has_version -b "sys-devel/gcc:${d_candidate}" || continue
+
+			ebegin "Testing sys-devel/gcc:${d_candidate} for D"
+			if has_version -b "sys-devel/gcc:${d_candidate}[d(-)]" ; then
+				d_bootstrap=${d_candidate}
+
+				eend 0
+				break
+			fi
+			eend 1
+		done
+
+		export GDC="${BROOT}/usr/${CTARGET}/gcc-bin/${d_bootstrap}/gdc"
+	fi
+
 	confgcc+=(
 		--prefix="${PREFIX}"
 		--bindir="${BINPATH}"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-29  1:07 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-29  1:07 UTC (permalink / raw
  To: gentoo-commits
commit:     b9c70336a7a58e03dc59f8f9f71397c090e657a7
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Sep 29 01:06:19 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Sep 29 01:06:19 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=b9c70336
toolchain.eclass: install gdc symlink too
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 30d96f25aaa8..9c0e38519b29 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -2303,7 +2303,7 @@ toolchain_src_install() {
 	cd "${D}"${BINPATH} || die
 	# Ugh: we really need to auto-detect this list.
 	#      It's constantly out of date.
-	for x in cpp gcc gccrs g++ c++ gcov g77 gfortran gccgo gnat* ; do
+	for x in cpp gcc gccrs g++ c++ gcov gdc g77 gfortran gccgo gnat* ; do
 		# For some reason, g77 gets made instead of ${CTARGET}-g77...
 		# this should take care of that
 		if [[ -f ${x} ]] ; then
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-29  1:13 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-29  1:13 UTC (permalink / raw
  To: gentoo-commits
commit:     8b286cd2cbe5be93c91115080340157047ac05a9
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Sep 29 01:11:19 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Sep 29 01:11:19 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=8b286cd2
toolchain.eclass: print GDC version used
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 2 ++
 1 file changed, 2 insertions(+)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 9c0e38519b29..15fe4dfb60bc 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1603,6 +1603,8 @@ toolchain_src_configure() {
 	einfo "Languages:       ${GCC_LANG}"
 	einfo "GCC version:     $($(tc-getCC) -v 2>&1 | grep ' version ' | awk '{ print $3 }')"
 	is_ada && einfo "GNAT version:    $(gnat 2>&1 | grep GNAT | awk '{ print $2 }')"
+	is_d && einfo "GDC version:     $(${GDC} -v 2>&1 | grep ' version ' | awk '{ print $3 }')"
+
 	echo
 
 	# Build in a separate build tree
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-29  1:13 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-29  1:13 UTC (permalink / raw
  To: gentoo-commits
commit:     53173d7420d926eb94cf94135350b124345cfa7a
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Sep 29 01:12:29 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Sep 29 01:12:54 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=53173d74
toolchain.eclass: use ${GNAT} for GNAT version print
It shouldn't matter as we set PATH but let's do it anyway for consistency.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 15fe4dfb60bc..f941f08d4198 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1602,7 +1602,7 @@ toolchain_src_configure() {
 	einfo "STDCXX_INCDIR:   ${STDCXX_INCDIR}"
 	einfo "Languages:       ${GCC_LANG}"
 	einfo "GCC version:     $($(tc-getCC) -v 2>&1 | grep ' version ' | awk '{ print $3 }')"
-	is_ada && einfo "GNAT version:    $(gnat 2>&1 | grep GNAT | awk '{ print $2 }')"
+	is_ada && einfo "GNAT version:    $(${GNAT} 2>&1 | grep GNAT | awk '{ print $2 }')"
 	is_d && einfo "GDC version:     $(${GDC} -v 2>&1 | grep ' version ' | awk '{ print $3 }')"
 
 	echo
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-29 11:22 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-29 11:22 UTC (permalink / raw
  To: gentoo-commits
commit:     d1aa56b6e39f07490021e594920f4a965a968c07
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Sep 29 11:20:08 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Sep 29 11:21:26 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=d1aa56b6
toolchain.eclass: start with oldest GDC and work upwards instead
Per https://gcc.gnu.org/install/prerequisites.html
"""
It is strongly recommended to use an older version of GDC to build GDC.
More recent versions of GDC than the version built are not guaranteed to work
and will often fail during the build with compilation errors relating to
deprecations or removed features.
"""
... so do as I just did for GNAT.
Bug: https://bugs.gentoo.org/940470
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index d68055f909fd..62ff83feed28 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1000,8 +1000,8 @@ toolchain_src_configure() {
 		local d_candidate
 		# We always prefer the version being built if possible
 		# as it has the greatest chance of success. Failing that,
-		# try the latest installed GCC and iterate downwards.
-		for d_candidate in ${SLOT} $(seq ${latest_gcc} -1 10) ; do
+		# try GCC 10 and iterate upwards.
+		for d_candidate in ${SLOT} $(seq 10 ${latest_gcc}) ; do
 			has_version -b "sys-devel/gcc:${d_candidate}" || continue
 
 			ebegin "Testing sys-devel/gcc:${d_candidate} for D"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-29 11:22 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-29 11:22 UTC (permalink / raw
  To: gentoo-commits
commit:     9bb87839a6ad66ee7c89837a546fbf2e7f69b577
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Sep 29 11:17:33 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Sep 29 11:21:25 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=9bb87839
toolchain.eclass: start with oldest GNAT and work upwards instead
Per https://gcc.gnu.org/install/prerequisites.html
"""
Similarly, it is strongly recommended to use an older version of GNAT to build GNAT.
More recent versions of GNAT than the version built are not guaranteed to work
and will often fail during the build with compilation errors.
"""
Bug: https://gcc.gnu.org/PR103357
Bug: https://bugs.gentoo.org/880825
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index f941f08d4198..759d871fde62 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -872,8 +872,8 @@ toolchain_src_configure() {
 		local ada_candidate
 		# We always prefer the version being built if possible
 		# as it has the greatest chance of success. Failing that,
-		# try the latest installed GCC and iterate downwards.
-		for ada_candidate in ${SLOT} $(seq ${latest_gcc} -1 10) ; do
+		# try GCC 10 and iterate upwards.
+		for ada_candidate in ${SLOT} $(seq 10 ${latest_gcc}) ; do
 			has_version -b "sys-devel/gcc:${ada_candidate}" || continue
 
 			ebegin "Testing sys-devel/gcc:${ada_candidate} for Ada"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-29 11:22 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-29 11:22 UTC (permalink / raw
  To: gentoo-commits
commit:     28fd52a103787d2bffa9136cb3bf5418beeb3ea9
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Sep 29 11:18:39 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Sep 29 11:21:26 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=28fd52a1
toolchain.eclass: don't set GDC if we couldn't find anything
This avoids wrongly/unnecessarily setting GDC for < GCC 12.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 4 +++-
 1 file changed, 3 insertions(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 759d871fde62..d68055f909fd 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1014,7 +1014,9 @@ toolchain_src_configure() {
 			eend 1
 		done
 
-		export GDC="${BROOT}/usr/${CTARGET}/gcc-bin/${d_bootstrap}/gdc"
+		if [[ -n ${d_bootstrap} ]] ; then
+			export GDC="${BROOT}/usr/${CTARGET}/gcc-bin/${d_bootstrap}/gdc"
+		fi
 	fi
 
 	confgcc+=(
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-29 11:28 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-29 11:28 UTC (permalink / raw
  To: gentoo-commits
commit:     6c118fbbefc7ab5340c98179908fab2e6fca6b8a
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Sep 29 11:27:39 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Sep 29 11:27:39 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=6c118fbb
toolchain.eclass: attempt to use gnat-gpl if the bootstrap GNAT is too new
Bug: https://bugs.gentoo.org/880825
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 62ff83feed28..138925777dd6 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -891,7 +891,7 @@ toolchain_src_configure() {
 
 		# As a last resort, use dev-lang/gnat-gpl.
 		# TODO: Make gnat-gpl coinstallable with gcc:10.
-		if [[ -z ${ada_bootstrap} ]] ; then
+		if ver_test ${ada_bootstrap} -gt ${PV} || [[ -z ${ada_bootstrap} ]] ; then
 			ebegin "Testing dev-lang/gnat-gpl for Ada"
 			if has_version -b "dev-lang/gnat-gpl" ; then
 				ada_bootstrap=10
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-30  1:52 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-30  1:52 UTC (permalink / raw
  To: gentoo-commits
commit:     c965c2d0a66b0827add2ac7708c69589491c5e8b
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Sep 30 01:20:59 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Sep 30 01:51:43 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=c965c2d0
toolchain.eclass: drop whitespace at end of function
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 1 -
 1 file changed, 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 7dc905ecd7d8..616bc01a840a 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -775,7 +775,6 @@ tc_enable_hardened_gcc() {
 	sed -i \
 		-e "/^HARD_CFLAGS = /s|=|= ${hardened_gcc_flags} |" \
 		"${S}"/gcc/Makefile.in || die
-
 }
 
 # This is a historical wart.  The original Gentoo/amd64 port used:
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-30  1:52 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-30  1:52 UTC (permalink / raw
  To: gentoo-commits
commit:     a9156e205ca667cf40f43329b5bc22749f166501
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Sep 30 01:19:35 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Sep 30 01:51:42 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=a9156e20
toolchain.eclass: pass STAGE1_CXXFLAGS
Note that we're reusing get_abi_CFLAGS here as multilib.eclass doesn't
have get_abi_CXXFLAGS yet (bug #940501).
Adding this for the benefit of some GDC hackery we're doing (bug #940470).
Bug: https://bugs.gentoo.org/940501
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 138925777dd6..7dc905ecd7d8 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -2023,6 +2023,8 @@ gcc_do_make() {
 		# We only want to use the system's CFLAGS if not building a
 		# cross-compiler.
 		STAGE1_CFLAGS=${STAGE1_CFLAGS-"$(get_abi_CFLAGS ${TARGET_DEFAULT_ABI}) ${CFLAGS}"}
+		# multilib.eclass lacks get_abi_CXXFLAGS (bug #940501)
+		STAGE1_CXXFLAGS=${STAGE1_CXXFLAGS-"$(get_abi_CFLAGS ${TARGET_DEFAULT_ABI}) ${CXXFLAGS}"}
 		STAGE1_LDFLAGS=${STAGE1_LDFLAGS-"${abi_ldflags} ${LDFLAGS}"}
 		BOOT_CFLAGS=${BOOT_CFLAGS-"$(get_abi_CFLAGS ${TARGET_DEFAULT_ABI}) ${CFLAGS}"}
 		BOOT_LDFLAGS=${BOOT_LDFLAGS-"${abi_ldflags} ${LDFLAGS}"}
@@ -2030,6 +2032,7 @@ gcc_do_make() {
 
 		emakeargs+=(
 			STAGE1_CFLAGS="${STAGE1_CFLAGS}"
+			STAGE1_CXXFLAGS="${STAGE1_CXXFLAGS}"
 			STAGE1_LDFLAGS="${STAGE1_LDFLAGS}"
 			BOOT_CFLAGS="${BOOT_CFLAGS}"
 			BOOT_LDFLAGS="${BOOT_LDFLAGS}"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-30  1:52 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-30  1:52 UTC (permalink / raw
  To: gentoo-commits
commit:     ea474da34fe1f904936f0f6b6e52d91364c36c95
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Sep 30 01:25:23 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Sep 30 01:51:44 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=ea474da3
toolchain.eclass: unset _GLIBCXX_ASSERTIONS for stage1 with D bootstrap
When bootstrapping D for >= GCC 12 - where we enable _GLIBCXX_ASSERTIONS
by default for USE=hardened - using GCC 11, we run into trouble where
an implementation detail of _GLIBCXX_ASSERTIONS changed: see PR104807,
r12-7504-gd3a757af21ac33, and r12-7522-g4cb935cb69f120.
Workaround this by just disabling _GLIBCXX_ASSERTIONS for the stage 1
compiler (where it's not particularly important anyway) when USE=hardened
and we're building D. We could make this more conditional if needed
but I don't think it's worth it. In fact, maybe we should do this
unconditionally for a minor speed boost in building.
Bug: https://gcc.gnu.org/PR104807
Bug: https://bugs.gentoo.org/940470
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 9 +++++++++
 1 file changed, 9 insertions(+)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index d6445ea3227e..b563277e90b1 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -2029,6 +2029,15 @@ gcc_do_make() {
 		BOOT_LDFLAGS=${BOOT_LDFLAGS-"${abi_ldflags} ${LDFLAGS}"}
 		LDFLAGS_FOR_TARGET="${LDFLAGS_FOR_TARGET:-${LDFLAGS}}"
 
+		# If we need to in future, we could really simplify this
+		# to just be unconditional for stage1. It doesn't really
+		# matter there. If we want to go in the other direction
+		# and make this more conditional, we could check if
+		# the bootstrap compiler is < GCC 12. See bug #940470.
+		if _tc_use_if_iuse d && use hardened ; then
+			STAGE1_CXXFLAGS+=" -U_GLIBCXX_ASSERTIONS"
+		fi
+
 		emakeargs+=(
 			STAGE1_CFLAGS="${STAGE1_CFLAGS}"
 			STAGE1_CXXFLAGS="${STAGE1_CXXFLAGS}"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-30  1:52 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-30  1:52 UTC (permalink / raw
  To: gentoo-commits
commit:     d0d87a54bb3bb7b077c75b44ff419177fc03ebb8
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Sep 30 01:22:34 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Sep 30 01:51:43 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=d0d87a54
toolchain.eclass: check CXXFLAGS too in -march=native sanity check
Bug: https://bugs.gentoo.org/904426
Thanks-to: Pacho Ramos <pacho <AT> gentoo.org>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 616bc01a840a..d6445ea3227e 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1812,7 +1812,7 @@ gcc_do_filter_flags() {
 	declare -A l1_cache_sizes=()
 	# Workaround for inconsistent cache sizes on hybrid P/E cores
 	# See PR111768 (and bug #904426, bug #908523, and bug #915389)
-	if [[ ${CBUILD} == @(x86_64|i?86)* ]] && [[ ${CFLAGS} == *-march=native* ]] && tc-is-gcc ; then
+	if [[ ${CBUILD} == @(x86_64|i?86)* ]] && [[ "${CFLAGS}${CXXFLAGS}" == *-march=native* ]] && tc-is-gcc ; then
 		local x
 		local l1_cache_size
 		# Iterate over all cores and find their L1 cache size
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-30  2:02 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-30  2:02 UTC (permalink / raw
  To: gentoo-commits
commit:     a90f7ff581cae6ab4d92a73ba734dc5377288616
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Sep 30 02:01:53 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Sep 30 02:01:53 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=a90f7ff5
toolchain.eclass: move GNAT comment
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index dfa46f094e45..7800681a6fb8 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -869,6 +869,9 @@ toolchain_src_configure() {
 
 		local ada_bootstrap
 		local ada_candidate
+		# GNAT can usually be built using the last major version and
+		# the current version, at least.
+		#
 		# We always prefer the version being built if possible
 		# as it has the greatest chance of success. Failing that,
 		# try GCC 10 and iterate upwards.
@@ -877,9 +880,6 @@ toolchain_src_configure() {
 
 			ebegin "Testing sys-devel/gcc:${ada_candidate} for Ada"
 			if has_version -b "sys-devel/gcc:${ada_candidate}[ada(-)]" ; then
-				# Make sure we set a path to the Ada bootstrap if gcc[ada] is not already
-				# installed. GNAT can usually be built using the last major version and
-				# the current version, at least.
 				ada_bootstrap=${ada_candidate}
 
 				eend 0
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-30  2:02 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-30  2:02 UTC (permalink / raw
  To: gentoo-commits
commit:     579c67b21758fbacff3527a01a12f00ed90f931d
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Sep 30 01:58:41 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Sep 30 01:58:41 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=579c67b2
toolchain.eclass: add explanation for 'sorry' on fallback Ada path
Give a nicer message to users in case they hit the 'sorry' fallback
Ada path.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index b563277e90b1..b2ada2190328 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -903,6 +903,9 @@ toolchain_src_configure() {
 		# OK, even gnat-gpl didn't work. Give up for now.
 		# TODO: Source a newer, or build our own, bootstrap tarball.
 		if [[ -z ${ada_bootstrap} ]] ; then
+			eerror "Couldn't find a suitable GNAT compiler for Ada!"
+			eerror "Please try installing dev-lang/gnat-gpl."
+			eerror "For other platforms, you may need to use crossdev."
 			die "Fallback ada-bootstrap path not yet implemented!"
 
 			#einfo "Using bootstrap GNAT compiler..."
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-30  2:02 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-30  2:02 UTC (permalink / raw
  To: gentoo-commits
commit:     1ce76a16c8f6e283f277190e4b86dfea8fc38cb3
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Sep 30 01:59:37 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Sep 30 02:00:49 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=1ce76a16
toolchain.eclass: add bug reference to ada-bootstrap comment
Bug: https://bugs.gentoo.org/940471
Bug: https://bugs.gentoo.org/940472
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index b2ada2190328..dfa46f094e45 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -889,7 +889,7 @@ toolchain_src_configure() {
 		done
 
 		# As a last resort, use dev-lang/gnat-gpl.
-		# TODO: Make gnat-gpl coinstallable with gcc:10.
+		# TODO: Make gnat-gpl coinstallable with gcc:10 (bug #940471).
 		if ver_test ${ada_bootstrap} -gt ${PV} || [[ -z ${ada_bootstrap} ]] ; then
 			ebegin "Testing dev-lang/gnat-gpl for Ada"
 			if has_version -b "dev-lang/gnat-gpl" ; then
@@ -901,7 +901,7 @@ toolchain_src_configure() {
 		fi
 
 		# OK, even gnat-gpl didn't work. Give up for now.
-		# TODO: Source a newer, or build our own, bootstrap tarball.
+		# TODO: Source a newer, or build our own, bootstrap tarball (bug #940472).
 		if [[ -z ${ada_bootstrap} ]] ; then
 			eerror "Couldn't find a suitable GNAT compiler for Ada!"
 			eerror "Please try installing dev-lang/gnat-gpl."
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-30  2:15 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-30  2:15 UTC (permalink / raw
  To: gentoo-commits
commit:     cd4189a259b3f34d0da39851931dc1a6a6a631f2
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Sep 30 02:14:13 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Sep 30 02:14:13 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=cd4189a2
toolchain.eclass: move Ada and D logic into their own functions
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 285 +++++++++++++++++++++++++-----------------------
 1 file changed, 149 insertions(+), 136 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index f64128baef48..41f51b1bb747 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -819,100 +819,62 @@ setup_multilib_osdirnames() {
 	sed -i "${sed_args[@]}" "${S}"/gcc/config/${config} || die
 }
 
-#---->> src_configure <<----
-
-toolchain_src_configure() {
-	BUILD_CONFIG_TARGETS=()
-	is-flagq '-O3' && BUILD_CONFIG_TARGETS+=( bootstrap-O3 )
-
-	downgrade_arch_flags
-	gcc_do_filter_flags
-
-	if ! tc_version_is_at_least 11 && [[ $(gcc-major-version) -ge 12 ]] ; then
-		# https://gcc.gnu.org/PR105695
-		# bug #849359
-		export ac_cv_std_swap_in_utility=no
-	fi
-
-	einfo "CFLAGS=\"${CFLAGS}\""
-	einfo "CXXFLAGS=\"${CXXFLAGS}\""
-	einfo "LDFLAGS=\"${LDFLAGS}\""
-
-	# Force internal zip based jar script to avoid random
-	# issues with 3rd party jar implementations. bug #384291
-	export JAR=no
+# @FUNCTION: toolchain_setup_ada
+# @INTERNAL
+# @DESCRIPTION:
+# Determine the most suitable GNAT (Ada compiler) for bootstrapping
+# and setup the environment, including wrappers, for building.
+toolchain_setup_ada() {
+	local latest_gcc=$(best_version -b "sys-devel/gcc")
+	latest_gcc="${latest_gcc#sys-devel/gcc-}"
+	latest_gcc=$(ver_cut 1 ${latest_gcc})
+
+	local ada_bootstrap
+	local ada_candidate
+	# GNAT can usually be built using the last major version and
+	# the current version, at least.
+	#
+	# We always prefer the version being built if possible
+	# as it has the greatest chance of success. Failing that,
+	# try GCC 10 and iterate upwards.
+	for ada_candidate in ${SLOT} $(seq 10 ${latest_gcc}) ; do
+		has_version -b "sys-devel/gcc:${ada_candidate}" || continue
 
-	local confgcc=( --host=${CHOST} )
+		ebegin "Testing sys-devel/gcc:${ada_candidate} for Ada"
+		if has_version -b "sys-devel/gcc:${ada_candidate}[ada(-)]" ; then
+			ada_bootstrap=${ada_candidate}
 
-	if is_crosscompile || tc-is-cross-compiler ; then
-		# Straight from the GCC install doc:
-		# "GCC has code to correctly determine the correct value for target
-		# for nearly all native systems. Therefore, we highly recommend you
-		# not provide a configure target when configuring a native compiler."
-		confgcc+=( --target=${CTARGET} )
-	fi
-	[[ -n ${CBUILD} ]] && confgcc+=( --build=${CBUILD} )
-
-	_need_ada_bootstrap_mangling() {
-		if [[ ${CATEGORY}/${PN} == dev-lang/gnat-gpl ]] ; then
-			_tc_use_if_iuse system-bootstrap && return 0
-			return 1
+			eend 0
+			break
 		fi
+		eend 1
+	done
 
-		_tc_use_if_iuse ada
-	}
-
-	if _need_ada_bootstrap_mangling ; then
-		local latest_gcc=$(best_version -b "sys-devel/gcc")
-		latest_gcc="${latest_gcc#sys-devel/gcc-}"
-		latest_gcc=$(ver_cut 1 ${latest_gcc})
-
-		local ada_bootstrap
-		local ada_candidate
-		# GNAT can usually be built using the last major version and
-		# the current version, at least.
-		#
-		# We always prefer the version being built if possible
-		# as it has the greatest chance of success. Failing that,
-		# try GCC 10 and iterate upwards.
-		for ada_candidate in ${SLOT} $(seq 10 ${latest_gcc}) ; do
-			has_version -b "sys-devel/gcc:${ada_candidate}" || continue
-
-			ebegin "Testing sys-devel/gcc:${ada_candidate} for Ada"
-			if has_version -b "sys-devel/gcc:${ada_candidate}[ada(-)]" ; then
-				ada_bootstrap=${ada_candidate}
-
-				eend 0
-				break
-			fi
+	# As a last resort, use dev-lang/gnat-gpl.
+	# TODO: Make gnat-gpl coinstallable with gcc:10 (bug #940471).
+	if ver_test ${ada_bootstrap} -gt ${PV} || [[ -z ${ada_bootstrap} ]] ; then
+		ebegin "Testing dev-lang/gnat-gpl for Ada"
+		if has_version -b "dev-lang/gnat-gpl" ; then
+			ada_bootstrap=10
+			eend 0
+		else
 			eend 1
-		done
-
-		# As a last resort, use dev-lang/gnat-gpl.
-		# TODO: Make gnat-gpl coinstallable with gcc:10 (bug #940471).
-		if ver_test ${ada_bootstrap} -gt ${PV} || [[ -z ${ada_bootstrap} ]] ; then
-			ebegin "Testing dev-lang/gnat-gpl for Ada"
-			if has_version -b "dev-lang/gnat-gpl" ; then
-				ada_bootstrap=10
-				eend 0
-			else
-				eend 1
-			fi
 		fi
+	fi
 
-		# OK, even gnat-gpl didn't work. Give up for now.
-		# TODO: Source a newer, or build our own, bootstrap tarball (bug #940472).
-		if [[ -z ${ada_bootstrap} ]] ; then
-			eerror "Couldn't find a suitable GNAT compiler for Ada!"
-			eerror "Please try installing dev-lang/gnat-gpl."
-			eerror "For other platforms, you may need to use crossdev."
-			die "Fallback ada-bootstrap path not yet implemented!"
+	# OK, even gnat-gpl didn't work. Give up for now.
+	# TODO: Source a newer, or build our own, bootstrap tarball (bug #940472).
+	if [[ -z ${ada_bootstrap} ]] ; then
+		eerror "Couldn't find a suitable GNAT compiler for Ada!"
+		eerror "Please try installing dev-lang/gnat-gpl."
+		eerror "For other platforms, you may need to use crossdev."
+		die "Fallback ada-bootstrap path not yet implemented!"
 
-			#einfo "Using bootstrap GNAT compiler..."
-			#export PATH="${BROOT}/opt/ada-bootstrap-${GCCMAJOR}/bin:${PATH}"
-		fi
+		#einfo "Using bootstrap GNAT compiler..."
+		#export PATH="${BROOT}/opt/ada-bootstrap-${GCCMAJOR}/bin:${PATH}"
+	fi
 
-		cat <<-"EOF" > "${T}"/ada.spec || die
+	cat <<-"EOF" > "${T}"/ada.spec || die
 		# Extracted from gcc/ada/gcc-interface/lang-specs.h
 		.adb:
 		@ada
@@ -957,69 +919,120 @@ toolchain_src_configure() {
 			%{gnatc*|gnats*: -o %j} %{-param*}
 		EOF
 
-		# Easier to substitute these values in rather than escape
-		# lots of bits above in heredoc.
-		sed -i \
-			-e "s:\${BROOT}:${BROOT}:" \
-			-e "s:\${CBUILD}:${CBUILD}:" \
-			-e "s:\${ada_bootstrap}:${ada_bootstrap}:" \
-			"${T}"/ada.spec || die
-
-		# The Makefile tries to find libgnat by querying $(CC) which
-		# won't work for us as the stage1 compiler doesn't necessarily
-		# have Ada support. Substitute the Ada compiler we found earlier.
-		local adalib
-		adalib=$(${CBUILD}-gcc-${ada_bootstrap} -print-libgcc-file-name || die "Finding adalib dir failed")
-		adalib="${adalib%/*}/adalib"
-		sed -i \
-			-e "s:adalib=.*:adalib=${adalib}:" \
-			"${S}"/gcc/ada/gcc-interface/Make-lang.in || die
-
-		# Create bin wrappers because not all of the build system
-		# respects GNATBIND or GNATMAKE.
-		mkdir "${T}"/ada-wrappers || die
-		local tool
-		for tool in gnat{,bind,chop,clean,kr,link,ls,make,name,prep} ; do
-			cat <<-EOF > "${T}"/ada-wrappers/${tool} || die
+	# Easier to substitute these values in rather than escape
+	# lots of bits above in heredoc.
+	sed -i \
+		-e "s:\${BROOT}:${BROOT}:" \
+		-e "s:\${CBUILD}:${CBUILD}:" \
+		-e "s:\${ada_bootstrap}:${ada_bootstrap}:" \
+		"${T}"/ada.spec || die
+
+	# The Makefile tries to find libgnat by querying $(CC) which
+	# won't work for us as the stage1 compiler doesn't necessarily
+	# have Ada support. Substitute the Ada compiler we found earlier.
+	local adalib
+	adalib=$(${CBUILD}-gcc-${ada_bootstrap} -print-libgcc-file-name || die "Finding adalib dir failed")
+	adalib="${adalib%/*}/adalib"
+	sed -i \
+		-e "s:adalib=.*:adalib=${adalib}:" \
+		"${S}"/gcc/ada/gcc-interface/Make-lang.in || die
+
+	# Create bin wrappers because not all of the build system
+	# respects GNATBIND or GNATMAKE.
+	mkdir "${T}"/ada-wrappers || die
+	local tool
+	for tool in gnat{,bind,chop,clean,kr,link,ls,make,name,prep} ; do
+		cat <<-EOF > "${T}"/ada-wrappers/${tool} || die
 			#!/bin/sh
 			exec $(type -P ${CBUILD}-${tool}-${ada_bootstrap}) -specs=${T}/ada.spec "\$@"
 			EOF
-			chmod +x "${T}"/ada-wrappers/${tool} || die
+		chmod +x "${T}"/ada-wrappers/${tool} || die
 
-			export "${tool^^}"=${CBUILD}-${tool}-${ada_bootstrap}
-		done
+		export "${tool^^}"=${CBUILD}-${tool}-${ada_bootstrap}
+	done
+
+	export PATH="${T}/ada-wrappers:${PATH}"
+	export CC="$(tc-getCC) -specs=${T}/ada.spec"
+}
+
+# @FUNCTION: toolchain_setup_d
+# @INTERNAL
+# @DESCRIPTION:
+# Determine the most suitable GDC (D compiler) for bootstrapping
+# and setup the environment for building.
+toolchain_setup_d() {
+	local latest_gcc=$(best_version -b "sys-devel/gcc")
+	latest_gcc="${latest_gcc#sys-devel/gcc-}"
+	latest_gcc=$(ver_cut 1 ${latest_gcc})
+
+	local d_bootstrap
+	local d_candidate
+	# We always prefer the version being built if possible
+	# as it has the greatest chance of success. Failing that,
+	# try GCC 10 and iterate upwards.
+	for d_candidate in ${SLOT} $(seq 10 ${latest_gcc}) ; do
+		has_version -b "sys-devel/gcc:${d_candidate}" || continue
+
+		ebegin "Testing sys-devel/gcc:${d_candidate} for D"
+		if has_version -b "sys-devel/gcc:${d_candidate}[d(-)]" ; then
+			d_bootstrap=${d_candidate}
+
+			eend 0
+			break
+		fi
+		eend 1
+	done
 
-		export PATH="${T}/ada-wrappers:${PATH}"
-		export CC="$(tc-getCC) -specs=${T}/ada.spec"
+	if [[ -n ${d_bootstrap} ]] ; then
+		export GDC="${BROOT}/usr/${CTARGET}/gcc-bin/${d_bootstrap}/gdc"
 	fi
+}
 
-	if _tc_use_if_iuse d ; then
-		local latest_gcc=$(best_version -b "sys-devel/gcc")
-		latest_gcc="${latest_gcc#sys-devel/gcc-}"
-		latest_gcc=$(ver_cut 1 ${latest_gcc})
+#---->> src_configure <<----
 
-		local d_bootstrap
-		local d_candidate
-		# We always prefer the version being built if possible
-		# as it has the greatest chance of success. Failing that,
-		# try GCC 10 and iterate upwards.
-		for d_candidate in ${SLOT} $(seq 10 ${latest_gcc}) ; do
-			has_version -b "sys-devel/gcc:${d_candidate}" || continue
+toolchain_src_configure() {
+	BUILD_CONFIG_TARGETS=()
+	is-flagq '-O3' && BUILD_CONFIG_TARGETS+=( bootstrap-O3 )
 
-			ebegin "Testing sys-devel/gcc:${d_candidate} for D"
-			if has_version -b "sys-devel/gcc:${d_candidate}[d(-)]" ; then
-				d_bootstrap=${d_candidate}
+	downgrade_arch_flags
+	gcc_do_filter_flags
 
-				eend 0
-				break
-			fi
-			eend 1
-		done
+	if ! tc_version_is_at_least 11 && [[ $(gcc-major-version) -ge 12 ]] ; then
+		# https://gcc.gnu.org/PR105695
+		# bug #849359
+		export ac_cv_std_swap_in_utility=no
+	fi
 
-		if [[ -n ${d_bootstrap} ]] ; then
-			export GDC="${BROOT}/usr/${CTARGET}/gcc-bin/${d_bootstrap}/gdc"
-		fi
+	einfo "CFLAGS=\"${CFLAGS}\""
+	einfo "CXXFLAGS=\"${CXXFLAGS}\""
+	einfo "LDFLAGS=\"${LDFLAGS}\""
+
+	# Force internal zip based jar script to avoid random
+	# issues with 3rd party jar implementations. bug #384291
+	export JAR=no
+
+	local confgcc=( --host=${CHOST} )
+
+	if is_crosscompile || tc-is-cross-compiler ; then
+		# Straight from the GCC install doc:
+		# "GCC has code to correctly determine the correct value for target
+		# for nearly all native systems. Therefore, we highly recommend you
+		# not provide a configure target when configuring a native compiler."
+		confgcc+=( --target=${CTARGET} )
 	fi
+	[[ -n ${CBUILD} ]] && confgcc+=( --build=${CBUILD} )
+
+	_need_ada_bootstrap_mangling() {
+		if [[ ${CATEGORY}/${PN} == dev-lang/gnat-gpl ]] ; then
+			_tc_use_if_iuse system-bootstrap && return 0
+			return 1
+		fi
+
+		_tc_use_if_iuse ada
+	}
+
+	_need_ada_bootstrap_mangling && toolchain_setup_ada
+	_tc_use_if_iuse d && toolchain_setup_d
 
 	confgcc+=(
 		--prefix="${PREFIX}"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-30  2:15 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-30  2:15 UTC (permalink / raw
  To: gentoo-commits
commit:     4f9c576ac91e273b0023084d4be134c94c65f7df
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Sep 30 02:04:48 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Sep 30 02:05:23 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=4f9c576a
toolchain.eclass: switch to /bin/sh shebang for Ada wrappers
type -P is used in ebuild context, not in the script itself (it is expanded
in the heredoc), so we can use POSIX shell. It might make things slightly
faster given these tools get invoked a lot during the build.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 7800681a6fb8..f64128baef48 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -981,7 +981,7 @@ toolchain_src_configure() {
 		local tool
 		for tool in gnat{,bind,chop,clean,kr,link,ls,make,name,prep} ; do
 			cat <<-EOF > "${T}"/ada-wrappers/${tool} || die
-			#!/bin/bash
+			#!/bin/sh
 			exec $(type -P ${CBUILD}-${tool}-${ada_bootstrap}) -specs=${T}/ada.spec "\$@"
 			EOF
 			chmod +x "${T}"/ada-wrappers/${tool} || die
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-30  2:20 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-30  2:20 UTC (permalink / raw
  To: gentoo-commits
commit:     9cfe1db9d69d0363f7591734822d4ba527d538fd
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Sep 30 02:17:50 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Sep 30 02:17:50 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=9cfe1db9
toolchain.eclass: consolidate language configure options
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 24 ++++++++++++------------
 1 file changed, 12 insertions(+), 12 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 41f51b1bb747..9900b2989abf 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1022,18 +1022,6 @@ toolchain_src_configure() {
 	fi
 	[[ -n ${CBUILD} ]] && confgcc+=( --build=${CBUILD} )
 
-	_need_ada_bootstrap_mangling() {
-		if [[ ${CATEGORY}/${PN} == dev-lang/gnat-gpl ]] ; then
-			_tc_use_if_iuse system-bootstrap && return 0
-			return 1
-		fi
-
-		_tc_use_if_iuse ada
-	}
-
-	_need_ada_bootstrap_mangling && toolchain_setup_ada
-	_tc_use_if_iuse d && toolchain_setup_d
-
 	confgcc+=(
 		--prefix="${PREFIX}"
 		--bindir="${BINPATH}"
@@ -1088,6 +1076,18 @@ toolchain_src_configure() {
 	is_modula2 && GCC_LANG+=",m2"
 	is_rust && GCC_LANG+=",rust"
 
+	_need_ada_bootstrap_mangling() {
+		if [[ ${CATEGORY}/${PN} == dev-lang/gnat-gpl ]] ; then
+			_tc_use_if_iuse system-bootstrap && return 0
+			return 1
+		fi
+
+		_tc_use_if_iuse ada
+	}
+
+	_need_ada_bootstrap_mangling && toolchain_setup_ada
+	_tc_use_if_iuse d && toolchain_setup_d
+
 	confgcc+=( --enable-languages=${GCC_LANG} )
 
 	### general options
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-30  3:02 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-30  3:02 UTC (permalink / raw
  To: gentoo-commits
commit:     d8160b8b90c6c752640af9db65061bb76c05d0c4
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Sep 30 02:58:25 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Sep 30 02:58:25 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=d8160b8b
toolchain.eclass: consolidate a comment
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 3 +--
 1 file changed, 1 insertion(+), 2 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 9900b2989abf..2950eaa3ccf2 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -998,8 +998,7 @@ toolchain_src_configure() {
 	gcc_do_filter_flags
 
 	if ! tc_version_is_at_least 11 && [[ $(gcc-major-version) -ge 12 ]] ; then
-		# https://gcc.gnu.org/PR105695
-		# bug #849359
+		# https://gcc.gnu.org/PR105695 (bug #849359)
 		export ac_cv_std_swap_in_utility=no
 	fi
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-30  3:03 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-30  3:03 UTC (permalink / raw
  To: gentoo-commits
commit:     f24f34cb062fce22d27296d989ec85a8e3cc106c
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Sep 30 02:59:13 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Sep 30 02:59:13 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=f24f34cb
toolchain.eclass: drop obsolete Java workaround
toolchain.eclass hasn't supported versions of GCC that included GCJ
for a while (see ::toolchain and toolchain-legacy.eclass if interested
in that), so drop an obsolete Java workaround we forgot to remove
when cleaning up the rest.
Bug: https://bugs.gentoo.org/384291
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 4 ----
 1 file changed, 4 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 2950eaa3ccf2..d29d07080582 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1006,10 +1006,6 @@ toolchain_src_configure() {
 	einfo "CXXFLAGS=\"${CXXFLAGS}\""
 	einfo "LDFLAGS=\"${LDFLAGS}\""
 
-	# Force internal zip based jar script to avoid random
-	# issues with 3rd party jar implementations. bug #384291
-	export JAR=no
-
 	local confgcc=( --host=${CHOST} )
 
 	if is_crosscompile || tc-is-cross-compiler ; then
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-09-30  5:57 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-09-30  5:57 UTC (permalink / raw
  To: gentoo-commits
commit:     1bc16717ffb9819d1f5f03c1fe413be04d378246
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Sep 30 05:54:07 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Sep 30 05:57:22 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=1bc16717
toolchain.eclass: tweak Ada, D deps
Without this, we can end up with something like:
```
[ebuild  NS    ] sys-devel/gcc-11.5.0:11::gentoo [13.3.1_p20240614:13::gentoo] USE="(ada*) cet (cxx) (d*) [...]"
[ebuild   R    ]  sys-devel/gcc-13.3.1_p20240614:13::gentoo  USE="(ada*) cet (cxx) (d*) [...]"
Total: 2 packages (1 in new slot, 1 reinstall), Size of downloads: 0 KiB
 * Error: circular dependencies:
(sys-devel/gcc-13.3.1_p20240614:13/13::gentoo, ebuild scheduled for merge) depends on
 (sys-devel/gcc-11.5.0:11/11::gentoo, ebuild scheduled for merge) (buildtime)
  (sys-devel/gcc-13.3.1_p20240614:13/13::gentoo, ebuild scheduled for merge) (buildtime)
```
Portage sees sys-devel/gcc[ada] is queued and tries to use it to satisfy
the dep for 11, which pulls in 13, which pulls in 11 for D.
We can workaround this by depending on older GCC for whatever slot we're
in. This matches upstream documentation and also reality as you usually
need an older version anyway.
See also 370253f008a8922c9aebe8099ab9c34bd6947f66 in binhost.git.
Bug: https://bugs.gentoo.org/880825
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index d29d07080582..939c68113188 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -402,7 +402,7 @@ if tc_has_feature valgrind ; then
 fi
 
 if [[ ${PN} != gnat-gpl ]] && tc_has_feature ada ; then
-	BDEPEND+=" ada? ( || ( sys-devel/gcc[ada] dev-lang/gnat-gpl[ada] ) )"
+	BDEPEND+=" ada? ( || ( sys-devel/gcc:${SLOT}[ada] <sys-devel/gcc-${SLOT}[ada] dev-lang/gnat-gpl[ada] ) )"
 fi
 
 # TODO: Add a pkg_setup & pkg_pretend check for whether the active compiler
@@ -411,7 +411,7 @@ if tc_has_feature d && tc_version_is_at_least 12.0 ; then
 	# D in 12+ is self-hosting and needs D to bootstrap.
 	# TODO: package some binary we can use, like for Ada
 	# bug #840182
-	BDEPEND+=" d? ( || ( sys-devel/gcc[d(-)] <sys-devel/gcc-12[d(-)] ) )"
+	BDEPEND+=" d? ( || ( sys-devel/gcc:${SLOT}[d(-)] <sys-devel/gcc-${SLOT}[d(-)] <sys-devel/gcc-12[d(-)] ) )"
 fi
 
 if tc_has_feature rust && tc_version_is_at_least 14.0.0_pre20230421 ; then
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-01  1:11 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-10-01  1:11 UTC (permalink / raw
  To: gentoo-commits
commit:     e6a69ea10ed74a0ce49e979bbc4bbce139949259
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Oct  1 01:02:17 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Oct  1 01:10:28 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=e6a69ea1
toolchain.eclass: support dev-lang/ada-bootstrap
Bug: https://bugs.gentoo.org/547358
Bug: https://bugs.gentoo.org/919667
Bug: https://bugs.gentoo.org/940472
Closes: https://bugs.gentoo.org/940471
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 42 +++++++++++++++++++++++++++++++++---------
 1 file changed, 33 insertions(+), 9 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 939c68113188..648e67b9493b 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -402,7 +402,16 @@ if tc_has_feature valgrind ; then
 fi
 
 if [[ ${PN} != gnat-gpl ]] && tc_has_feature ada ; then
-	BDEPEND+=" ada? ( || ( sys-devel/gcc:${SLOT}[ada] <sys-devel/gcc-${SLOT}[ada] dev-lang/gnat-gpl[ada] ) )"
+	BDEPEND+="
+		ada? (
+			|| (
+				sys-devel/gcc:${SLOT}[ada]
+				<sys-devel/gcc-${SLOT}[ada]
+				<dev-lang/ada-bootstrap-${SLOT}
+				dev-lang/gnat-gpl[ada]
+			)
+		)
+	"
 fi
 
 # TODO: Add a pkg_setup & pkg_pretend check for whether the active compiler
@@ -850,10 +859,28 @@ toolchain_setup_ada() {
 		eend 1
 	done
 
-	# As a last resort, use dev-lang/gnat-gpl.
-	# TODO: Make gnat-gpl coinstallable with gcc:10 (bug #940471).
+	# As a penultimate resort, try dev-lang/ada-bootstrap.
+	if ver_test ${ada_bootstrap} -gt ${PV} || [[ -z ${ada_bootstrap} ]] ; then
+		ebegin "Testing fallback dev-lang/ada-bootstrap for Ada"
+		if has_version -b "<dev-lang/ada-bootstrap-${SLOT}" ; then
+			local latest_ada_bootstrap=$(best_version -b "<dev-lang/ada-bootstrap-${SLOT}")
+			latest_ada_bootstrap="${latest_ada_bootstrap#dev-lang/ada-bootstrap-}"
+			latest_ada_bootstrap=$(ver_cut 1 ${latest_ada_bootstrap})
+			ada_bootstrap=${latest_ada_bootstrap}
+
+			# TODO: Figure out ada-bootstrap versioning/slots
+			export PATH="${BROOT}/usr/lib/ada-bootstrap/bin:${PATH}"
+
+			eend 0
+			break
+		else
+			eend 1
+		fi
+	fi
+
+	# As a last resort, try dev-lang/gnat-gpl.
 	if ver_test ${ada_bootstrap} -gt ${PV} || [[ -z ${ada_bootstrap} ]] ; then
-		ebegin "Testing dev-lang/gnat-gpl for Ada"
+		ebegin "Testing fallback dev-lang/gnat-gpl for Ada"
 		if has_version -b "dev-lang/gnat-gpl" ; then
 			ada_bootstrap=10
 			eend 0
@@ -866,12 +893,9 @@ toolchain_setup_ada() {
 	# TODO: Source a newer, or build our own, bootstrap tarball (bug #940472).
 	if [[ -z ${ada_bootstrap} ]] ; then
 		eerror "Couldn't find a suitable GNAT compiler for Ada!"
-		eerror "Please try installing dev-lang/gnat-gpl."
+		eerror "Please try installing dev-lang/ada-bootstrap or failing that, dev-lang/gnat-gpl."
 		eerror "For other platforms, you may need to use crossdev."
-		die "Fallback ada-bootstrap path not yet implemented!"
-
-		#einfo "Using bootstrap GNAT compiler..."
-		#export PATH="${BROOT}/opt/ada-bootstrap-${GCCMAJOR}/bin:${PATH}"
+		die "Couldn't find an Ada bootstrap compiler!"
 	fi
 
 	cat <<-"EOF" > "${T}"/ada.spec || die
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-01  1:46 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-10-01  1:46 UTC (permalink / raw
  To: gentoo-commits
commit:     7a6f738a6e505b65bf7d9032810adccc419e9467
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Oct  1 01:45:16 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Oct  1 01:45:45 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=7a6f738a
toolchain.eclass: further adaptations to dev-lang/ada-bootstrap
This needs prettifying, which I'll do shortly.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 42 +++++++++++++++++++++++++++++++-----------
 1 file changed, 31 insertions(+), 11 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 648e67b9493b..f52ff0e6bb60 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -840,6 +840,7 @@ toolchain_setup_ada() {
 
 	local ada_bootstrap
 	local ada_candidate
+	local ada_bootstrap_type
 	# GNAT can usually be built using the last major version and
 	# the current version, at least.
 	#
@@ -852,6 +853,7 @@ toolchain_setup_ada() {
 		ebegin "Testing sys-devel/gcc:${ada_candidate} for Ada"
 		if has_version -b "sys-devel/gcc:${ada_candidate}[ada(-)]" ; then
 			ada_bootstrap=${ada_candidate}
+			ada_bootstrap_type=gcc
 
 			eend 0
 			break
@@ -863,16 +865,15 @@ toolchain_setup_ada() {
 	if ver_test ${ada_bootstrap} -gt ${PV} || [[ -z ${ada_bootstrap} ]] ; then
 		ebegin "Testing fallback dev-lang/ada-bootstrap for Ada"
 		if has_version -b "<dev-lang/ada-bootstrap-${SLOT}" ; then
-			local latest_ada_bootstrap=$(best_version -b "<dev-lang/ada-bootstrap-${SLOT}")
-			latest_ada_bootstrap="${latest_ada_bootstrap#dev-lang/ada-bootstrap-}"
-			latest_ada_bootstrap=$(ver_cut 1 ${latest_ada_bootstrap})
-			ada_bootstrap=${latest_ada_bootstrap}
-
 			# TODO: Figure out ada-bootstrap versioning/slots
-			export PATH="${BROOT}/usr/lib/ada-bootstrap/bin:${PATH}"
+
+			#local latest_ada_bootstrap=$(best_version -b "<dev-lang/ada-bootstrap-${SLOT}")
+			#latest_ada_bootstrap="${latest_ada_bootstrap#dev-lang/ada-bootstrap-}"
+			#latest_ada_bootstrap=$(ver_cut 1 ${latest_ada_bootstrap})
+			ada_bootstrap="10"
+			ada_bootstrap_type=ada-bootstrap
 
 			eend 0
-			break
 		else
 			eend 1
 		fi
@@ -883,6 +884,7 @@ toolchain_setup_ada() {
 		ebegin "Testing fallback dev-lang/gnat-gpl for Ada"
 		if has_version -b "dev-lang/gnat-gpl" ; then
 			ada_bootstrap=10
+			ada_bootstrap=gcc
 			eend 0
 		else
 			eend 1
@@ -910,7 +912,7 @@ toolchain_setup_ada() {
 		@ada:
 		%{pg:%{fomit-frame-pointer:%e-pg and -fomit-frame-pointer are incompatible}} \
 			%{!S:%{!c:%e-c or -S required for Ada}} \
-			${BROOT}/usr/libexec/gcc/${CBUILD}/${ada_bootstrap}/gnat1 %{I*} %{k8:-gnatk8} %{!Q:-quiet} \
+			${gnat1_path} %{I*} %{k8:-gnatk8} %{!Q:-quiet} \
 			%{nostdinc*} %{nostdlib*} \
 			%{fcompare-debug-second:-gnatd_A} \
 			%{O*} %{W*} %{w} %{p} %{pg:-p} \
@@ -943,11 +945,19 @@ toolchain_setup_ada() {
 			%{gnatc*|gnats*: -o %j} %{-param*}
 		EOF
 
+	# XXX: Hack for now
+	if [[ ${ada_bootstrap_type} == ada-bootstrap ]] ; then
+		sed -i \
+			-e "s:\${gnat1_path}:${BROOT}/usr/lib/ada-bootstrap/libexec/gcc/x86_64-pc-linux-gnu/10/gnat1:" \
+			"${T}"/ada.spec || die
+	fi
+
 	# Easier to substitute these values in rather than escape
 	# lots of bits above in heredoc.
 	sed -i \
 		-e "s:\${BROOT}:${BROOT}:" \
 		-e "s:\${CBUILD}:${CBUILD}:" \
+		-e "s:\${gnat1_path}:${BROOT}/usr/libexec/gcc/${CBUILD}/${ada_bootstrap}/gnat1:" \
 		-e "s:\${ada_bootstrap}:${ada_bootstrap}:" \
 		"${T}"/ada.spec || die
 
@@ -955,7 +965,13 @@ toolchain_setup_ada() {
 	# won't work for us as the stage1 compiler doesn't necessarily
 	# have Ada support. Substitute the Ada compiler we found earlier.
 	local adalib
-	adalib=$(${CBUILD}-gcc-${ada_bootstrap} -print-libgcc-file-name || die "Finding adalib dir failed")
+	if [[ ${ada_bootstrap_type} == ada-bootstrap ]] ; then
+		old_path="${PATH}"
+		export PATH="${BROOT}/usr/lib/ada-bootstrap/bin:${PATH}"
+		adalib=$(${BROOT}/usr/lib/ada-bootstrap/bin/${CBUILD}-gcc -print-libgcc-file-name || die "Finding adalib dir failed")
+	else
+		adalib=$(${CBUILD}-gcc-${ada_bootstrap} -print-libgcc-file-name || die "Finding adalib dir failed")
+	fi
 	adalib="${adalib%/*}/adalib"
 	sed -i \
 		-e "s:adalib=.*:adalib=${adalib}:" \
@@ -966,16 +982,20 @@ toolchain_setup_ada() {
 	mkdir "${T}"/ada-wrappers || die
 	local tool
 	for tool in gnat{,bind,chop,clean,kr,link,ls,make,name,prep} ; do
+		if [[ ${ada_bootstrap_type} == ada-bootstrap ]] ; then
+			ln -s "${BROOT}"/usr/lib/ada-bootstrap/bin/${tool} "${T}"/ada-wrappers/${CBUILD}-${tool}-${ada_bootstrap} || die
+		fi
+
 		cat <<-EOF > "${T}"/ada-wrappers/${tool} || die
 			#!/bin/sh
 			exec $(type -P ${CBUILD}-${tool}-${ada_bootstrap}) -specs=${T}/ada.spec "\$@"
 			EOF
 		chmod +x "${T}"/ada-wrappers/${tool} || die
 
-		export "${tool^^}"=${CBUILD}-${tool}-${ada_bootstrap}
+		export "${tool^^}"="${T}"/ada-wrappers/${tool}
 	done
 
-	export PATH="${T}/ada-wrappers:${PATH}"
+	export PATH="${T}/ada-wrappers:${old_path}"
 	export CC="$(tc-getCC) -specs=${T}/ada.spec"
 }
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-01  1:58 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-10-01  1:58 UTC (permalink / raw
  To: gentoo-commits
commit:     409fcc75caaa1c29188227011638873bda6a5ef5
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Oct  1 01:47:22 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Oct  1 01:47:22 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=409fcc75
toolchain.eclass: quote BROOT
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index f52ff0e6bb60..7a67951fb7ab 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -968,7 +968,7 @@ toolchain_setup_ada() {
 	if [[ ${ada_bootstrap_type} == ada-bootstrap ]] ; then
 		old_path="${PATH}"
 		export PATH="${BROOT}/usr/lib/ada-bootstrap/bin:${PATH}"
-		adalib=$(${BROOT}/usr/lib/ada-bootstrap/bin/${CBUILD}-gcc -print-libgcc-file-name || die "Finding adalib dir failed")
+		adalib=$("${BROOT}"/usr/lib/ada-bootstrap/bin/${CBUILD}-gcc -print-libgcc-file-name || die "Finding adalib dir failed")
 	else
 		adalib=$(${CBUILD}-gcc-${ada_bootstrap} -print-libgcc-file-name || die "Finding adalib dir failed")
 	fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-01  1:58 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-10-01  1:58 UTC (permalink / raw
  To: gentoo-commits
commit:     23575e7311a21db0aa2dac9b29c5baa4f172658d
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Oct  1 01:49:19 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Oct  1 01:57:31 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=23575e73
toolchain.eclass: small ada-bootstrap tweaks
* Don't try to do a PATH lookup for the wrappers for now; need to install
  more symlinks in ada-bootstrap, I think
* Style tweaks
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 11 ++++++-----
 1 file changed, 6 insertions(+), 5 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 7a67951fb7ab..355d5e12b4b5 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -983,17 +983,18 @@ toolchain_setup_ada() {
 	local tool
 	for tool in gnat{,bind,chop,clean,kr,link,ls,make,name,prep} ; do
 		if [[ ${ada_bootstrap_type} == ada-bootstrap ]] ; then
-			ln -s "${BROOT}"/usr/lib/ada-bootstrap/bin/${tool} "${T}"/ada-wrappers/${CBUILD}-${tool}-${ada_bootstrap} || die
+			ln -s "${BROOT}"/usr/lib/ada-bootstrap/bin/${tool} \
+				"${T}"/ada-wrappers/${CBUILD}-${tool}-${ada_bootstrap} || die
 		fi
 
 		cat <<-EOF > "${T}"/ada-wrappers/${tool} || die
-			#!/bin/sh
-			exec $(type -P ${CBUILD}-${tool}-${ada_bootstrap}) -specs=${T}/ada.spec "\$@"
-			EOF
-		chmod +x "${T}"/ada-wrappers/${tool} || die
+		#!/bin/sh
+		exec ${CBUILD}-${tool}-${ada_bootstrap} --specs=${T}/ada.spec "\$@"
+		EOF
 
 		export "${tool^^}"="${T}"/ada-wrappers/${tool}
 	done
+	chmod +x "${T}"/ada-wrappers/gnat{,bind,chop,clean,kr,link,ls,make,name,prep} || die
 
 	export PATH="${T}/ada-wrappers:${old_path}"
 	export CC="$(tc-getCC) -specs=${T}/ada.spec"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-01  2:06 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-10-01  2:06 UTC (permalink / raw
  To: gentoo-commits
commit:     6971e384576057adda25bb49a45f898fa13f83b1
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Oct  1 02:04:41 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Oct  1 02:04:41 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=6971e384
toolchain.eclass: go back to PATH lookup for Ada wrappers
This should work now that we install gcc-config-style symlinks in
ada-bootstrap.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 355d5e12b4b5..f9c5f58bf7d4 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -989,7 +989,7 @@ toolchain_setup_ada() {
 
 		cat <<-EOF > "${T}"/ada-wrappers/${tool} || die
 		#!/bin/sh
-		exec ${CBUILD}-${tool}-${ada_bootstrap} --specs=${T}/ada.spec "\$@"
+		exec $(type -P ${CBUILD}-${tool}-${ada_bootstrap}) --specs=${T}/ada.spec "\$@"
 		EOF
 
 		export "${tool^^}"="${T}"/ada-wrappers/${tool}
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-01  2:14 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-10-01  2:14 UTC (permalink / raw
  To: gentoo-commits
commit:     e560bd7b70ae2d64ab1d86a716756c320b6d2f70
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Oct  1 02:13:31 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Oct  1 02:13:31 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=e560bd7b
toolchain.eclass: further special-case dropping for ada-bootstrap
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 31 ++++++++++++-------------------
 1 file changed, 12 insertions(+), 19 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index f9c5f58bf7d4..a5c7d5df47d5 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -945,19 +945,23 @@ toolchain_setup_ada() {
 			%{gnatc*|gnats*: -o %j} %{-param*}
 		EOF
 
-	# XXX: Hack for now
-	if [[ ${ada_bootstrap_type} == ada-bootstrap ]] ; then
-		sed -i \
-			-e "s:\${gnat1_path}:${BROOT}/usr/lib/ada-bootstrap/libexec/gcc/x86_64-pc-linux-gnu/10/gnat1:" \
-			"${T}"/ada.spec || die
-	fi
+	old_path="${PATH}"
+	case ${ada_bootstrap_type} in
+		ada-bootstrap)
+			export PATH="${BROOT}/usr/lib/ada-bootstrap/bin:${PATH}"
+			gnat1_path=${BROOT}/usr/lib/ada-bootstrap/libexec/gcc/${CBUILD}/${ada_bootstrap}/gnat1
+			;;
+		*)
+			gnat1_path=${BROOT}/usr/libexec/gcc/${CBUILD}/${ada_bootstrap}/gnat1
+			;;
+	esac
 
 	# Easier to substitute these values in rather than escape
 	# lots of bits above in heredoc.
 	sed -i \
 		-e "s:\${BROOT}:${BROOT}:" \
 		-e "s:\${CBUILD}:${CBUILD}:" \
-		-e "s:\${gnat1_path}:${BROOT}/usr/libexec/gcc/${CBUILD}/${ada_bootstrap}/gnat1:" \
+		-e "s:\${gnat1_path}:${gnat1_path}:" \
 		-e "s:\${ada_bootstrap}:${ada_bootstrap}:" \
 		"${T}"/ada.spec || die
 
@@ -965,13 +969,7 @@ toolchain_setup_ada() {
 	# won't work for us as the stage1 compiler doesn't necessarily
 	# have Ada support. Substitute the Ada compiler we found earlier.
 	local adalib
-	if [[ ${ada_bootstrap_type} == ada-bootstrap ]] ; then
-		old_path="${PATH}"
-		export PATH="${BROOT}/usr/lib/ada-bootstrap/bin:${PATH}"
-		adalib=$("${BROOT}"/usr/lib/ada-bootstrap/bin/${CBUILD}-gcc -print-libgcc-file-name || die "Finding adalib dir failed")
-	else
-		adalib=$(${CBUILD}-gcc-${ada_bootstrap} -print-libgcc-file-name || die "Finding adalib dir failed")
-	fi
+	adalib=$(${CBUILD}-gcc-${ada_bootstrap} -print-libgcc-file-name || die "Finding adalib dir failed")
 	adalib="${adalib%/*}/adalib"
 	sed -i \
 		-e "s:adalib=.*:adalib=${adalib}:" \
@@ -982,11 +980,6 @@ toolchain_setup_ada() {
 	mkdir "${T}"/ada-wrappers || die
 	local tool
 	for tool in gnat{,bind,chop,clean,kr,link,ls,make,name,prep} ; do
-		if [[ ${ada_bootstrap_type} == ada-bootstrap ]] ; then
-			ln -s "${BROOT}"/usr/lib/ada-bootstrap/bin/${tool} \
-				"${T}"/ada-wrappers/${CBUILD}-${tool}-${ada_bootstrap} || die
-		fi
-
 		cat <<-EOF > "${T}"/ada-wrappers/${tool} || die
 		#!/bin/sh
 		exec $(type -P ${CBUILD}-${tool}-${ada_bootstrap}) --specs=${T}/ada.spec "\$@"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-01  2:16 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-10-01  2:16 UTC (permalink / raw
  To: gentoo-commits
commit:     2492e4efc220c6f50eb2cfa01addcd1aaf198063
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Oct  1 02:15:04 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Oct  1 02:15:04 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=2492e4ef
toolchain.eclass: reflow comments slightly
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 14 +++++++-------
 1 file changed, 7 insertions(+), 7 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index a5c7d5df47d5..65523041302e 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -956,8 +956,8 @@ toolchain_setup_ada() {
 			;;
 	esac
 
-	# Easier to substitute these values in rather than escape
-	# lots of bits above in heredoc.
+	# Easier to substitute these values in rather than escape lots of
+	# bits above in the heredoc.
 	sed -i \
 		-e "s:\${BROOT}:${BROOT}:" \
 		-e "s:\${CBUILD}:${CBUILD}:" \
@@ -965,9 +965,9 @@ toolchain_setup_ada() {
 		-e "s:\${ada_bootstrap}:${ada_bootstrap}:" \
 		"${T}"/ada.spec || die
 
-	# The Makefile tries to find libgnat by querying $(CC) which
-	# won't work for us as the stage1 compiler doesn't necessarily
-	# have Ada support. Substitute the Ada compiler we found earlier.
+	# The Makefile tries to find libgnat by querying $(CC) which won't
+	# work for us as the stage1 compiler doesn't necessarily have Ada
+	# support. Substitute the Ada compiler we found earlier.
 	local adalib
 	adalib=$(${CBUILD}-gcc-${ada_bootstrap} -print-libgcc-file-name || die "Finding adalib dir failed")
 	adalib="${adalib%/*}/adalib"
@@ -975,8 +975,8 @@ toolchain_setup_ada() {
 		-e "s:adalib=.*:adalib=${adalib}:" \
 		"${S}"/gcc/ada/gcc-interface/Make-lang.in || die
 
-	# Create bin wrappers because not all of the build system
-	# respects GNATBIND or GNATMAKE.
+	# Create bin wrappers because not all of the build system respects
+	# GNATBIND or GNATMAKE.
 	mkdir "${T}"/ada-wrappers || die
 	local tool
 	for tool in gnat{,bind,chop,clean,kr,link,ls,make,name,prep} ; do
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-01  6:59 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-10-01  6:59 UTC (permalink / raw
  To: gentoo-commits
commit:     c52997d9b125de280d75b169b8bc6f3964d5d051
Author:     Andrei Horodniceanu <a.horodniceanu <AT> proton <DOT> me>
AuthorDate: Mon Sep 30 16:32:52 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Oct  1 06:59:28 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=c52997d9
toolchain.eclass: Try harder to disable cet automagic
On arches that support USE=cet (those being amd64, arm64, and, x86)
always pass --enable-cet or --disable-cet (or aarch64
standard-branch-protection equivalent) to prevent any configure automagic
from happening.
Preserve the same CTARGET logic so only pass --enable-cet if the
target environment supports it and if `use cet`.
Also fix the regex `i[[34567]]86` as that matches an i, followed by any
of the digits from 3 to 7 or the [ character, followed by ], followed by
8, followed by 6. The regex originated in config/cet.m4 which uses []
for quotes.
The automatic specifically breaks gcc[d] on musl because it prevents the
code from using an internal assembly implementation for a function and
deferring to using an implementation that would be provided by
sys-libs/libucontext which results in undefined symbol errors:
```
/usr/lib/gcc/x86_64-pc-linux-musl/11/../../../../x86_64-pc-linux-musl/bin/ld:
/usr/lib/gcc/x86_64-pc-linux-musl/11/libgphobos.a(fiber.o): in function `_D4core6thread5fiber5Fiber9initStackMFNbNiZv':
(.text._D4core6thread5fiber5Fiber9initStackMFNbNiZv+0x2e): undefined reference to `getcontext'
/usr/lib/gcc/x86_64-pc-linux-musl/11/../../../../x86_64-pc-linux-musl/bin/ld: (.text._D4core6thread5fiber5Fiber9initStackMFNbNiZv+0x5f): undefined reference to `makecontext'
/usr/lib/gcc/x86_64-pc-linux-musl/11/../../../../x86_64-pc-linux-musl/bin/ld: /usr/lib/gcc/x86_64-pc-linux-musl/11/libgphobos.a(fiber.o): in function `_D4core6thread5fiber5Fiber12_staticCtor1FZv':
(.text._D4core6thread5fiber5Fiber12_staticCtor1FZv+0x1c): undefined reference to `getcontext'
```
Bug: https://bugs.gentoo.org/939874
Closes: https://bugs.gentoo.org/918692
Signed-off-by: Andrei Horodniceanu <a.horodniceanu <AT> proton.me>
Closes: https://github.com/gentoo/gentoo/pull/38830
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 18 ++++++++++++++----
 1 file changed, 14 insertions(+), 4 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 65523041302e..a9f02d6d6a46 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1526,10 +1526,20 @@ toolchain_src_configure() {
 	fi
 
 	if in_iuse cet ; then
-		if [[ ${CTARGET} == i[[34567]]86-*-linux* || ${CTARGET} == x86_64-*-gnu* ]] ; then
-			confgcc+=( $(use_enable cet) )
-		fi
-		[[ ${CTARGET} == aarch64-*-gnu* ]] && confgcc+=( $(use_enable cet standard-branch-protection) )
+		# Usage: triple_arch triple_env cet_name
+		enable_cet_for() {
+			if [[ ${CTARGET} == ${1}-* ]] ; then
+				if use cet && [[ ${CTARGET} == *-${2}* ]]; then
+					confgcc+=( --enable-${3} )
+				else
+					confgcc+=( --disable-${3} )
+				fi
+			fi
+		}
+
+		enable_cet_for 'i[34567]86' 'linux' 'cet'
+		enable_cet_for 'x86_64' 'gnu' 'cet'
+		enable_cet_for 'aarch64' 'gnu' 'standard-branch-protection'
 	fi
 
 	if in_iuse systemtap ; then
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-01  7:47 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-10-01  7:47 UTC (permalink / raw
  To: gentoo-commits
commit:     80f7aebfa94401e62f9f8132cf2fe16b51d9be40
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Oct  1 07:46:22 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Oct  1 07:46:22 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=80f7aebf
toolchain.eclass: don't pass --specs= to gnat* tools
The gnat* tools don't understand --specs=* and we only need to do that
to ensure the compiler driver (gcc) calls the right things anyway.
What we might have to do in future however is force --gcc and --link...
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index a9f02d6d6a46..7b302afdf5cc 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -982,7 +982,7 @@ toolchain_setup_ada() {
 	for tool in gnat{,bind,chop,clean,kr,link,ls,make,name,prep} ; do
 		cat <<-EOF > "${T}"/ada-wrappers/${tool} || die
 		#!/bin/sh
-		exec $(type -P ${CBUILD}-${tool}-${ada_bootstrap}) --specs=${T}/ada.spec "\$@"
+		exec $(type -P ${CBUILD}-${tool}-${ada_bootstrap}) "\$@"
 		EOF
 
 		export "${tool^^}"="${T}"/ada-wrappers/${tool}
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-01 10:18 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-10-01 10:18 UTC (permalink / raw
  To: gentoo-commits
commit:     ddc2dc1bbb001d95bdf0ece36f379481c97156be
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Oct  1 10:16:58 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Oct  1 10:16:58 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=ddc2dc1b
toolchain.eclass: conditionally pass -Wno-complain-wrong-lang for >= GCC 13
... ditto for -Wno-format-security and so on. It causes far more noise
than test cases it helps with. Of course, when we have -Wno-complain-wrong-lang
available (in >= GCC 13), then it's worth it.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 12 ++++++++----
 1 file changed, 8 insertions(+), 4 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 7b302afdf5cc..e253cffa777b 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -2171,8 +2171,10 @@ toolchain_src_test() {
 	(
 		# Workaround our -Wformat-security default which breaks
 		# various tests as it adds unexpected warning output.
-		GCC_TESTS_CFLAGS+=" -Wno-format-security -Wno-format"
-		GCC_TESTS_CXXFLAGS+=" -Wno-format-security -Wno-format"
+		if tc_version_is_at_least 13 ; then
+			GCC_TESTS_CFLAGS+=" -Wno-format-security -Wno-format"
+			GCC_TESTS_CXXFLAGS+=" -Wno-format-security -Wno-format"
+		fi
 
 		# Workaround our -Wtrampolines default which breaks
 		# tests too.
@@ -2182,8 +2184,10 @@ toolchain_src_test() {
 		GCC_TESTS_LDFLAGS+=" -Wl,--no-warn-execstack"
 		# Avoid confusing tests like Fortran/C interop ones where
 		# CFLAGS are used.
-		GCC_TESTS_CFLAGS+=" -Wno-complain-wrong-lang"
-		GCC_TESTS_CXXFLAGS+=" -Wno-complain-wrong-lang"
+		if tc_version_is_at_least 13 ; then
+			GCC_TESTS_CFLAGS+=" -Wno-complain-wrong-lang"
+			GCC_TESTS_CXXFLAGS+=" -Wno-complain-wrong-lang"
+		fi
 
 		# Issues with Ada tests:
 		# gnat.dg/align_max.adb
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-01 19:38 Eli Schwartz
  0 siblings, 0 replies; 6663+ messages in thread
From: Eli Schwartz @ 2024-10-01 19:38 UTC (permalink / raw
  To: gentoo-commits
commit:     8c195224ab8d8a499d120cb0b44371d7d7c0511c
Author:     Eli Schwartz <eschwartz <AT> gentoo <DOT> org>
AuthorDate: Tue Oct  1 15:26:00 2024 +0000
Commit:     Eli Schwartz <eschwartz <AT> gentoo <DOT> org>
CommitDate: Tue Oct  1 19:38:24 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=8c195224
toolchain.eclass: fix typo that prevented configuring with USE=ada
We need a bootstrap (version) and a bootstrap_type (value irrelevant for
now except to flag whether it is ada-bootstrap).
Due to a typo, we set the former first to the detected slot and then
immediately to the value "gcc", which made no sense since "gcc" isn't a
valid SLOT version of gcc. Hence we tried to run ${triplet}-gcc-gcc
instead of running ${triplet}-gcc-${SLOT}.
Only reproducible when using gnat-gpl itself as the gcc edition.
Signed-off-by: Eli Schwartz <eschwartz <AT> gentoo.org>
Reviewed-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index e253cffa777b..3547549b1a12 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -884,7 +884,7 @@ toolchain_setup_ada() {
 		ebegin "Testing fallback dev-lang/gnat-gpl for Ada"
 		if has_version -b "dev-lang/gnat-gpl" ; then
 			ada_bootstrap=10
-			ada_bootstrap=gcc
+			ada_bootstrap_type=gcc
 			eend 0
 		else
 			eend 1
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-01 20:40 James Le Cuirot
  0 siblings, 0 replies; 6663+ messages in thread
From: James Le Cuirot @ 2024-10-01 20:40 UTC (permalink / raw
  To: gentoo-commits
commit:     b4ca7760f8bb83e8d6180d6be48dcbd7af8b3498
Author:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
AuthorDate: Tue Oct  1 20:37:51 2024 +0000
Commit:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
CommitDate: Tue Oct  1 20:37:51 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=b4ca7760
cargo.eclass: Respect existing CARGO_TARGET_${TRIPLE}_RUSTFLAGS
This variable is used to disable crt-static with musl.
Closes: https://bugs.gentoo.org/940197
Signed-off-by: James Le Cuirot <chewi <AT> gentoo.org>
 eclass/cargo.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/cargo.eclass b/eclass/cargo.eclass
index 3a63e5027250..499fe5498c96 100644
--- a/eclass/cargo.eclass
+++ b/eclass/cargo.eclass
@@ -585,7 +585,7 @@ cargo_env() {
 	local -x CARGO_BUILD_TARGET=$(rust_abi)
 	local TRIPLE=${CARGO_BUILD_TARGET//-/_}
 	local TRIPLE=${TRIPLE^^} LD_A=( $(tc-getCC) ${LDFLAGS} )
-	local -x CARGO_TARGET_"${TRIPLE}"_RUSTFLAGS="-C strip=none -C linker=${LD_A[0]}"
+	local -Ix CARGO_TARGET_"${TRIPLE}"_RUSTFLAGS+=" -C strip=none -C linker=${LD_A[0]}"
 	[[ ${#LD_A[@]} -gt 1 ]] && local CARGO_TARGET_"${TRIPLE}"_RUSTFLAGS+="$(printf -- ' -C link-arg=%s' "${LD_A[@]:1}")"
 	local CARGO_TARGET_"${TRIPLE}"_RUSTFLAGS+=" ${RUSTFLAGS}"
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-01 23:13 Eli Schwartz
  0 siblings, 0 replies; 6663+ messages in thread
From: Eli Schwartz @ 2024-10-01 23:13 UTC (permalink / raw
  To: gentoo-commits
commit:     50a9e89135f0e924fa0fe7c4482791c8056d9d75
Author:     Eli Schwartz <eschwartz <AT> gentoo <DOT> org>
AuthorDate: Tue Oct  1 19:46:56 2024 +0000
Commit:     Eli Schwartz <eschwartz <AT> gentoo <DOT> org>
CommitDate: Tue Oct  1 23:03:47 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=50a9e891
toolchain.eclass: also reset STAGE1_CXXFLAGS for old compilers
Since commit a9156e205ca667cf40f43329b5bc22749f166501 we pass CXXFLAGS
as well, but it didn't include the existing logic we have for checking if
you have a really old compiler and taking precautions to avoid garbage
codegen breaking the stage1 compiler.
Signed-off-by: Eli Schwartz <eschwartz <AT> gentoo.org>
Reviewed-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 1 +
 1 file changed, 1 insertion(+)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 3547549b1a12..d5570a746a2e 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -2076,6 +2076,7 @@ gcc_do_make() {
 		# using not-O0 is just a build-time speed improvement anyway.
 		if ! tc-is-gcc || ver_test $(gcc-fullversion) -lt 10 ; then
 			STAGE1_CFLAGS="-O0"
+			STAGE1_CXXFLAGS="-O0"
 		fi
 
 		# We only want to use the system's CFLAGS if not building a
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-01 23:13 Eli Schwartz
  0 siblings, 0 replies; 6663+ messages in thread
From: Eli Schwartz @ 2024-10-01 23:13 UTC (permalink / raw
  To: gentoo-commits
commit:     9a089ae37edf29aa5956932209751379a1bceb21
Author:     Eli Schwartz <eschwartz <AT> gentoo <DOT> org>
AuthorDate: Tue Oct  1 20:07:21 2024 +0000
Commit:     Eli Schwartz <eschwartz <AT> gentoo <DOT> org>
CommitDate: Tue Oct  1 23:04:04 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=9a089ae3
toolchain.eclass: restrict *FLAGS for stage1 compiler when bootstrapping
e.g. if gnat1 from a bootstrap compiler is older than the host compiler
itself, we are going to end up passing flags that the host compiler does
understand, but gnat1 does not. This is trivially broken with
-march=native (passes loads of flags) and also more plebeian things such
as -march=x86-64-v3 which is sadly too new for gnat-10
Signed-off-by: Eli Schwartz <eschwartz <AT> gentoo.org>
Reviewed-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 7 +++++++
 1 file changed, 7 insertions(+)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index d5570a746a2e..6a816a66275d 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -2077,6 +2077,13 @@ gcc_do_make() {
 		if ! tc-is-gcc || ver_test $(gcc-fullversion) -lt 10 ; then
 			STAGE1_CFLAGS="-O0"
 			STAGE1_CXXFLAGS="-O0"
+		# We have a very good host compiler but it may be a bit too good, and
+		# know about flags that the version we are compiling does not know
+		# about. In principle we could check e.g. which gnat1 we are using as
+		# a bootstrap. It's simpler to do it unconditionally for now.
+		elif _tc_use_if_iuse ada || _tc_use_if_iuse d; then
+			STAGE1_CFLAGS="-O2"
+			STAGE1_CXXFLAGS="-O2"
 		fi
 
 		# We only want to use the system's CFLAGS if not building a
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-02  0:57 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-10-02  0:57 UTC (permalink / raw
  To: gentoo-commits
commit:     6ef120e9895172dd7b2c6a1c9f5b14ef56c75ea7
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Oct  2 00:57:30 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Oct  2 00:57:30 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=6ef120e9
toolchain.eclass: print all relevant flags, not just C{,XX}FLAGS + LDFLAGS
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 7 ++++---
 1 file changed, 4 insertions(+), 3 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 6a816a66275d..1c990f1f1114 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1040,9 +1040,10 @@ toolchain_src_configure() {
 		export ac_cv_std_swap_in_utility=no
 	fi
 
-	einfo "CFLAGS=\"${CFLAGS}\""
-	einfo "CXXFLAGS=\"${CXXFLAGS}\""
-	einfo "LDFLAGS=\"${LDFLAGS}\""
+	local flag
+	for flag in $(all-flag-vars) ; do
+		einfo "${flag}=\"${!flag}\""
+	done
 
 	local confgcc=( --host=${CHOST} )
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-02  9:01 Miroslav Šulc
  0 siblings, 0 replies; 6663+ messages in thread
From: Miroslav Šulc @ 2024-10-02  9:01 UTC (permalink / raw
  To: gentoo-commits
commit:     cb2cde8fccc89412e914986153bf706e3c16a63a
Author:     Volkmar W. Pogatzki <gentoo <AT> pogatzki <DOT> net>
AuthorDate: Wed Sep 11 05:55:59 2024 +0000
Commit:     Miroslav Šulc <fordfrog <AT> gentoo <DOT> org>
CommitDate: Wed Oct  2 09:01:39 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=cb2cde8f
java-pkg-2.eclass: remove unused eclass functions java-pkg-2_src_{compile,test}
The last ebuild using these functions was net-vpn/i2p-2.5.2-r1
Closes: https://bugs.gentoo.org/940526
Signed-off-by: Volkmar W. Pogatzki <gentoo <AT> pogatzki.net>
Signed-off-by: Miroslav Šulc <fordfrog <AT> gentoo.org>
 eclass/java-pkg-2.eclass | 92 +-----------------------------------------------
 1 file changed, 1 insertion(+), 91 deletions(-)
diff --git a/eclass/java-pkg-2.eclass b/eclass/java-pkg-2.eclass
index 6da4efd222c2..2b2a298cfe74 100644
--- a/eclass/java-pkg-2.eclass
+++ b/eclass/java-pkg-2.eclass
@@ -59,96 +59,6 @@ java-pkg-2_src_prepare() {
 	java-utils-2_src_prepare
 }
 
-
-# @FUNCTION: java-pkg-2_src_compile
-# @DEPRECATED: none
-# @DESCRIPTION:
-# Default src_compile for java packages
-#
-# @CODE
-# Variables:
-#   EANT_BUILD_XML - controls the location of the build.xml (default: ./build.xml)
-#   EANT_FILTER_COMPILER - Calls java-pkg_filter-compiler with the value
-#   EANT_BUILD_TARGET - the ant target/targets to execute (default: jar)
-#   EANT_DOC_TARGET - the target to build extra docs under the doc use flag
-#                     (default: javadoc; declare empty to disable completely)
-#   EANT_GENTOO_CLASSPATH - @see eant documentation in java-utils-2.eclass
-#   EANT_EXTRA_ARGS - extra arguments to pass to eant
-#   EANT_ANT_TASKS - modifies the ANT_TASKS variable in the eant environment
-# @CODE
-java-pkg-2_src_compile() {
-	if [[ -e "${EANT_BUILD_XML:=build.xml}" ]]; then
-		# auto generate classpath
-		java-pkg_gen-cp EANT_GENTOO_CLASSPATH
-
-		[[ "${EANT_FILTER_COMPILER}" ]] && \
-			java-pkg_filter-compiler ${EANT_FILTER_COMPILER}
-		local antflags="${EANT_BUILD_TARGET:=jar}"
-		if has doc ${IUSE} && [[ -n "${EANT_DOC_TARGET=javadoc}" ]]; then
-			antflags="${antflags} $(use_doc ${EANT_DOC_TARGET})"
-		fi
-		local tasks
-		[[ ${EANT_ANT_TASKS} ]] && tasks="${ANT_TASKS} ${EANT_ANT_TASKS}"
-		ANT_TASKS="${tasks:-${ANT_TASKS}}" \
-			eant ${antflags} -f "${EANT_BUILD_XML}" ${EANT_EXTRA_ARGS} "${@}"
-	else
-		echo "${FUNCNAME}: ${EANT_BUILD_XML} not found so nothing to do."
-	fi
-}
-
-# @FUNCTION: java-pkg-2_src_test
-# @DEPRECATED: none
-# @DESCRIPTION:
-# src_test, not exported.
-java-pkg-2_src_test() {
-	[[ -e "${EANT_BUILD_XML:=build.xml}" ]] || return
-
-	if [[ ${EANT_TEST_TARGET} ]] || < "${EANT_BUILD_XML}" tr -d "\n" | grep -Eq "<target\b[^>]*\bname=[\"']test[\"']"; then
-		local opts task_re junit_re pkg
-
-		if [[ ${EANT_TEST_JUNIT_INTO} ]]; then
-			java-pkg_jar-from --into "${EANT_TEST_JUNIT_INTO}" junit
-		fi
-
-		if [[ ${EANT_TEST_GENTOO_CLASSPATH} ]]; then
-			EANT_GENTOO_CLASSPATH="${EANT_TEST_GENTOO_CLASSPATH}"
-		fi
-
-		ANT_TASKS=${EANT_TEST_ANT_TASKS:-${ANT_TASKS:-${EANT_ANT_TASKS}}}
-
-		task_re="\bdev-java/ant-junit(4)?(-[^:]+)?(:\S+)\b"
-		junit_re="\bdev-java/junit(-[^:]+)?(:\S+)\b"
-
-		if [[ ${DEPEND} =~ ${task_re} ]]; then
-			pkg="ant-junit${BASH_REMATCH[1]}${BASH_REMATCH[3]}"
-			pkg="${pkg%:0}"
-
-			if [[ ${ANT_TASKS} && "${ANT_TASKS}" != none ]]; then
-				ANT_TASKS="${ANT_TASKS} ${pkg}"
-			else
-				ANT_TASKS="${pkg}"
-			fi
-		elif [[ ${DEPEND} =~ ${junit_re} ]]; then
-			pkg="junit${BASH_REMATCH[2]}"
-			pkg="${pkg%:0}"
-
-			opts="-Djunit.jar=\"$(java-pkg_getjar ${pkg} junit.jar)\""
-
-			if [[ ${EANT_GENTOO_CLASSPATH} ]]; then
-				EANT_GENTOO_CLASSPATH+=",${pkg}"
-			else
-				EANT_GENTOO_CLASSPATH="${pkg}"
-			fi
-		fi
-
-		eant ${opts} -f "${EANT_BUILD_XML}" \
-			${EANT_EXTRA_ARGS} ${EANT_TEST_EXTRA_ARGS} ${EANT_TEST_TARGET:-test}
-
-	else
-		echo "${FUNCNAME}: No test target in ${EANT_BUILD_XML}"
-	fi
-}
-
 # @FUNCTION: java-pkg-2_pkg_preinst
 # @DESCRIPTION:
 # wrapper for java-utils-2_pkg_preinst
@@ -158,4 +68,4 @@ java-pkg-2_pkg_preinst() {
 
 fi
 
-EXPORT_FUNCTIONS pkg_setup src_prepare src_compile pkg_preinst
+EXPORT_FUNCTIONS pkg_setup src_prepare pkg_preinst
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-02  9:01 Miroslav Šulc
  0 siblings, 0 replies; 6663+ messages in thread
From: Miroslav Šulc @ 2024-10-02  9:01 UTC (permalink / raw
  To: gentoo-commits
commit:     34b685bb7d76a897630091e2b45745f34499bb66
Author:     Volkmar W. Pogatzki <gentoo <AT> pogatzki <DOT> net>
AuthorDate: Sun Sep  8 07:52:01 2024 +0000
Commit:     Miroslav Šulc <fordfrog <AT> gentoo <DOT> org>
CommitDate: Wed Oct  2 09:01:44 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=34b685bb
java-utils-2.eclass: remove java-pkg_check-jikes
Signed-off-by: Volkmar W. Pogatzki <gentoo <AT> pogatzki.net>
Signed-off-by: Miroslav Šulc <fordfrog <AT> gentoo.org>
 eclass/java-utils-2.eclass | 13 ++-----------
 1 file changed, 2 insertions(+), 11 deletions(-)
diff --git a/eclass/java-utils-2.eclass b/eclass/java-utils-2.eclass
index 43d9b749ba3d..98426e1851eb 100644
--- a/eclass/java-utils-2.eclass
+++ b/eclass/java-utils-2.eclass
@@ -204,9 +204,9 @@ JAVA_PKG_COMPILERS_CONF=${JAVA_PKG_COMPILERS_CONF:="/etc/java-config-2/build/com
 #
 # Useful for local testing.
 #
-# Use jikes and javac, in that order
+# Use <other compiler> and javac, in that order
 # @CODE
-#	JAVA_PKG_FORCE_COMPILER="jikes javac"
+#	JAVA_PKG_FORCE_COMPILER="<other compiler> javac"
 # @CODE
 
 # @ECLASS_VARIABLE: JAVA_PKG_FORCE_ANT_TASKS
@@ -2307,9 +2307,6 @@ java-pkg_init() {
 
 	# TODO we will probably want to set JAVAC and JAVACFLAGS
 
-	# Do some QA checks
-	java-pkg_check-jikes
-
 	# Can't use unset here because Portage does not save the unset
 	# see https://bugs.gentoo.org/show_bug.cgi?id=189417#c11
 
@@ -2967,12 +2964,6 @@ java-pkg_check-versioned-jar() {
 	fi
 }
 
-java-pkg_check-jikes() {
-	if has jikes ${IUSE}; then
-		java-pkg_announce-qa-violation "deprecated USE flag 'jikes' in IUSE"
-	fi
-}
-
 java-pkg_announce-qa-violation() {
 	local nodie
 	if [[ ${1} == "--nodie" ]]; then
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-02  9:01 Miroslav Šulc
  0 siblings, 0 replies; 6663+ messages in thread
From: Miroslav Šulc @ 2024-10-02  9:01 UTC (permalink / raw
  To: gentoo-commits
commit:     834ed97a952c011c5e86d893cc6a329dd88bf9ac
Author:     Volkmar W. Pogatzki <gentoo <AT> pogatzki <DOT> net>
AuthorDate: Sun Sep  8 07:37:22 2024 +0000
Commit:     Miroslav Šulc <fordfrog <AT> gentoo <DOT> org>
CommitDate: Wed Oct  2 09:01:44 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=834ed97a
java-utils-2.eclass: stop mentioning java-ant-2 eclass
Signed-off-by: Volkmar W. Pogatzki <gentoo <AT> pogatzki.net>
Signed-off-by: Miroslav Šulc <fordfrog <AT> gentoo.org>
 eclass/java-utils-2.eclass | 9 ++++-----
 1 file changed, 4 insertions(+), 5 deletions(-)
diff --git a/eclass/java-utils-2.eclass b/eclass/java-utils-2.eclass
index 98426e1851eb..aa69cce14cae 100644
--- a/eclass/java-utils-2.eclass
+++ b/eclass/java-utils-2.eclass
@@ -9,13 +9,12 @@
 # @SUPPORTED_EAPIS: 6 7 8
 # @BLURB: Base eclass for Java packages
 # @DESCRIPTION:
-# This eclass provides functionality which is used by java-pkg-2.eclass,
-# java-pkg-opt-2.eclass and java-ant-2 eclass, as well as from ebuilds.
+# This eclass provides functionality which is used by java-pkg-2.eclass and
+# java-pkg-opt-2.eclass as well as from ebuilds.
 #
 # This eclass should not be inherited this directly from an ebuild. Instead,
 # you should inherit java-pkg-2 for Java packages or java-pkg-opt-2 for packages
-# that have optional Java support. In addition you can inherit java-ant-2 for
-# Ant-based packages.
+# that have optional Java support.
 
 if [[ -z ${_JAVA_UTILS_2_ECLASS} ]] ; then
 _JAVA_UTILS_2_ECLASS=1
@@ -101,7 +100,7 @@ JAVA_PKG_ALLOW_VM_CHANGE=${JAVA_PKG_ALLOW_VM_CHANGE:="yes"}
 # @DEFAULT_UNSET
 # @DESCRIPTION:
 # Specify a non-standard Java source version for compilation (via javac -source
-# parameter or Ant equivalent via build.xml rewriting done by java-ant-2 eclass).
+# parameter).
 # Normally this is determined from the jdk version specified in DEPEND.
 # See java-pkg_get-source function below.
 #
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-02  9:01 Miroslav Šulc
  0 siblings, 0 replies; 6663+ messages in thread
From: Miroslav Šulc @ 2024-10-02  9:01 UTC (permalink / raw
  To: gentoo-commits
commit:     c1a63f395cae95a5603715ef7d43f58253252a97
Author:     Volkmar W. Pogatzki <gentoo <AT> pogatzki <DOT> net>
AuthorDate: Wed Sep 11 11:27:39 2024 +0000
Commit:     Miroslav Šulc <fordfrog <AT> gentoo <DOT> org>
CommitDate: Wed Oct  2 09:01:44 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=c1a63f39
java-utils-2.eclass: add some missing function descriptions
Signed-off-by: Volkmar W. Pogatzki <gentoo <AT> pogatzki.net>
Closes: https://github.com/gentoo/gentoo/pull/38559
Signed-off-by: Miroslav Šulc <fordfrog <AT> gentoo.org>
 eclass/java-utils-2.eclass | 32 ++++++++++++++++++++++++++++----
 1 file changed, 28 insertions(+), 4 deletions(-)
diff --git a/eclass/java-utils-2.eclass b/eclass/java-utils-2.eclass
index aa69cce14cae..1e9c28d5868f 100644
--- a/eclass/java-utils-2.eclass
+++ b/eclass/java-utils-2.eclass
@@ -1648,6 +1648,10 @@ java-pkg_set-current-vm() {
 	export GENTOO_VM=${1}
 }
 
+# @FUNCTION: java-pkg_current-vm-matches
+# @USAGE: <vm_string1> [<vm_string2> [<vm_string3>...]]
+# @RETURN: 0: the current vm matches any of the provided strings
+# @RETURN: 1: the current vm does not match any of the provided strings
 java-pkg_current-vm-matches() {
 	has $(java-pkg_get-current-vm) ${@}
 	return $?
@@ -2321,7 +2325,7 @@ java-pkg_init() {
 	export ANT_RESPECT_JAVA_HOME=
 }
 
-# @FUNCTION: java-pkg-init-compiler_
+# @FUNCTION: java-pkg_init-compiler_
 # @INTERNAL
 # @DESCRIPTION:
 # This function attempts to figure out what compiler should be used. It does
@@ -2342,9 +2346,7 @@ java-pkg_init() {
 # If the user doesn't defined anything in JAVA_PKG_COMPILERS_CONF, or no
 # suitable compiler was found there, then the default is to use javac provided
 # by the current VM.
-#
-#
-# @RETURN name of the compiler to use
+# @RETURN: name of the compiler to use
 java-pkg_init-compiler_() {
 	debug-print-function ${FUNCNAME} $*
 
@@ -2946,6 +2948,12 @@ java-pkg_ensure-dep() {
 	fi
 }
 
+# @FUNCTION: java-pkg_check-phase
+# @INTERNAL
+# @USAGE: <phase_name>
+# @DESCRIPTION:
+# Checks whether the phase specified in $1 is the current active phase. If not,
+# a helpful QA message is displayed
 java-pkg_check-phase() {
 	local phase=${1}
 	local funcname=${FUNCNAME[1]}
@@ -2955,6 +2963,12 @@ java-pkg_check-phase() {
 	fi
 }
 
+# @FUNCTION: java-pkg_check-versioned-jar
+# @INTERNAL
+# @USAGE: <jar_filename>
+# @DESCRIPTION:
+# Checks whether the jar specified in $1 contains ${PV}. If it does, a helpful
+# QA message is displayed
 java-pkg_check-versioned-jar() {
 	local jar=${1}
 
@@ -2963,6 +2977,12 @@ java-pkg_check-versioned-jar() {
 	fi
 }
 
+# @FUNCTION: java-pkg_announce-qa-violation
+# @INTERNAL
+# @USAGE: [--nodie] <msg>
+# @DESCRIPTION:
+# Prints out the <msg> as a QA message. If ${JAVA_PKG_STRICT} is set, then die
+# is called. This can be overridden by providing --nodie
 java-pkg_announce-qa-violation() {
 	local nodie
 	if [[ ${1} == "--nodie" ]]; then
@@ -2979,6 +2999,10 @@ increment-qa-violations() {
 	export JAVA_PKG_QA_VIOLATIONS
 }
 
+# @FUNCTION: is-java-strict
+# @INTERNAL
+# @RETURN: 0: JAVA_PKG_STRICT is set
+# @RETURN: 1: JAVA_PKG_STRICT is not set
 is-java-strict() {
 	[[ -n ${JAVA_PKG_STRICT} ]]
 	return $?
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-03  3:43 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-10-03  3:43 UTC (permalink / raw
  To: gentoo-commits
commit:     c9f79ed713758a95abea32d9c41f4f2a49f999b2
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Oct  3 03:41:14 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Oct  3 03:43:15 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=c9f79ed7
toolchain.eclass: change iteration strategy for GNAT and GDC
This improves upon the strategy from 9bb87839a6ad66ee7c89837a546fbf2e7f69b577
and d1aa56b6e39f07490021e594920f4a965a968c07.
Earlier, I saw building GCC 15's gdc fail w/ bootstrap from 10, even
though we had 11/12/13/14 installed.
The new logic is as follows, with descending order of preference:
1) Match the version being built;
2) Iterate downwards from the version being built;
3) Iterate upwards from the version being built to the greatest version installed.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 18 ++++++++++--------
 1 file changed, 10 insertions(+), 8 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 1c990f1f1114..3cacc2da31b7 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -844,10 +844,11 @@ toolchain_setup_ada() {
 	# GNAT can usually be built using the last major version and
 	# the current version, at least.
 	#
-	# We always prefer the version being built if possible
-	# as it has the greatest chance of success. Failing that,
-	# try GCC 10 and iterate upwards.
-	for ada_candidate in ${SLOT} $(seq 10 ${latest_gcc}) ; do
+	# Order of preference (descending):
+	# 1) Match the version being built;
+	# 2) Iterate downwards from the version being built;
+	# 3) Iterate upwards from the version being built to the greatest version installed.
+	for ada_candidate in ${SLOT} $(seq -1 $((${SLOT} - 1)) 10) $(seq $((${SLOT} + 1)) ${latest_gcc}) ; do
 		has_version -b "sys-devel/gcc:${ada_candidate}" || continue
 
 		ebegin "Testing sys-devel/gcc:${ada_candidate} for Ada"
@@ -1005,10 +1006,11 @@ toolchain_setup_d() {
 
 	local d_bootstrap
 	local d_candidate
-	# We always prefer the version being built if possible
-	# as it has the greatest chance of success. Failing that,
-	# try GCC 10 and iterate upwards.
-	for d_candidate in ${SLOT} $(seq 10 ${latest_gcc}) ; do
+	# Order of preference (descending):
+	# 1) Match the version being built;
+	# 2) Iterate downwards from the version being built;
+	# 3) Iterate upwards from the version being built to the greatest version installed.
+	for d_candidate in ${SLOT} $(seq -1 $((${SLOT} - 1)) 10) $(seq $((${SLOT} + 1)) ${latest_gcc}) ; do
 		has_version -b "sys-devel/gcc:${d_candidate}" || continue
 
 		ebegin "Testing sys-devel/gcc:${d_candidate} for D"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-03  4:02 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-10-03  4:02 UTC (permalink / raw
  To: gentoo-commits
commit:     8d90f4f76448e89de32e6cd4338e953d673c4f72
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Oct  3 04:01:39 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Oct  3 04:01:39 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=8d90f4f7
toolchain.eclass: fix seq params
I didn't notice as I tested on a machine with ${SLOT} available.
Fixes: c9f79ed713758a95abea32d9c41f4f2a49f999b2
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 3cacc2da31b7..a2eba0a9297e 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -848,7 +848,7 @@ toolchain_setup_ada() {
 	# 1) Match the version being built;
 	# 2) Iterate downwards from the version being built;
 	# 3) Iterate upwards from the version being built to the greatest version installed.
-	for ada_candidate in ${SLOT} $(seq -1 $((${SLOT} - 1)) 10) $(seq $((${SLOT} + 1)) ${latest_gcc}) ; do
+	for ada_candidate in ${SLOT} $(seq $((${SLOT} - 1)) -1 10) $(seq $((${SLOT} + 1)) ${latest_gcc}) ; do
 		has_version -b "sys-devel/gcc:${ada_candidate}" || continue
 
 		ebegin "Testing sys-devel/gcc:${ada_candidate} for Ada"
@@ -1010,7 +1010,7 @@ toolchain_setup_d() {
 	# 1) Match the version being built;
 	# 2) Iterate downwards from the version being built;
 	# 3) Iterate upwards from the version being built to the greatest version installed.
-	for d_candidate in ${SLOT} $(seq -1 $((${SLOT} - 1)) 10) $(seq $((${SLOT} + 1)) ${latest_gcc}) ; do
+	for d_candidate in ${SLOT} $(seq $((${SLOT} - 1)) -1 10) $(seq $((${SLOT} + 1)) ${latest_gcc}) ; do
 		has_version -b "sys-devel/gcc:${d_candidate}" || continue
 
 		ebegin "Testing sys-devel/gcc:${d_candidate} for D"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-04 11:49 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-10-04 11:49 UTC (permalink / raw
  To: gentoo-commits
commit:     70a43aaf58504bb01c77faf58c96abe0b0ca856d
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Oct  4 11:11:22 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Oct  4 11:49:01 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=70a43aaf
toolchain.eclass: add ewarns to explain USE=-debug behaviour w/ unreleased GCC
We sometimes have people surprised by the behaviour with USE=-debug for
unreleased versions of GCC.
For more detail on that & context, see:
* 564b130fd1bc8a35ac4d673d5211654c49af3fda
* 85db50a7c626a1844c8eb2d03051c8c5d320c205
* 3f9a5248fb796417d63ae1c1234b534a88f22f14
Add some ewarns to explain the situation to users so they understand
their options and also don't wrongly think GCC will be slow when released.
Bug: https://bugs.gentoo.org/904481
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 10 +++++++++-
 1 file changed, 9 insertions(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index a2eba0a9297e..5b978f6871db 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1148,7 +1148,15 @@ toolchain_src_configure() {
 		# unless USE=debug. Note that snapshots on stable branches don't count as "non-released"
 		# for these purposes.
 		if grep -q "experimental" gcc/DEV-PHASE ; then
-			# - USE=debug for pre-releases: yes,extra,rtl
+			# Tell users about the non-obvious behavior here so they don't think
+			# e.g. the next GCC release is super slow to compile things.
+			ewarn "Unreleased GCCs default to extra runtime checks even with USE=-debug,"
+			ewarn "matching upstream default behavior. We recommend keeping these enabled."
+			ewarn "The checks (sometimes substantially) increase build time but provide important protection"
+			ewarn "from potential miscompilations (wrong code) by turning them into build-time errors."
+			ewarn "To override (not recommended), set: GCC_CHECKS_LIST=\"release\"."
+
+			# - USE=debug for pre-releases: yes,extra,rtl (stornger than USE=debug for releases)
 			# - USE=-debug for pre-releases: yes,extra (following upstream default)
 			confgcc+=( --enable-checking="${GCC_CHECKS_LIST:-$(usex debug yes,extra,rtl yes,extra)}" )
 		else
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-07  2:40 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-10-07  2:40 UTC (permalink / raw
  To: gentoo-commits
commit:     de9d78a1f4fc90d54dd2c3c5c6b61acfb1c49d10
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Oct  6 15:26:10 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Oct  7 02:39:27 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=de9d78a1
ruby-utils.eclass: update RUBY_TARGETS_PREFERENCE for ruby32
As we did before in 780a29cd9228988031ed0243d764d478d0482045. I think
this shows up as a problem after 60910451d576803cc2cdfdbaad7fe70a7b41f55d,
but not completely sure.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/ruby-utils.eclass | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/eclass/ruby-utils.eclass b/eclass/ruby-utils.eclass
index 48a25114b396..81bda3abfb36 100644
--- a/eclass/ruby-utils.eclass
+++ b/eclass/ruby-utils.eclass
@@ -36,10 +36,10 @@ esac
 # provide for a better first installation experience.
 
 # All stable RUBY_TARGETS
-RUBY_TARGETS_PREFERENCE="ruby31 "
+RUBY_TARGETS_PREFERENCE="ruby32 ruby31 "
 
 # All other active ruby targets
-RUBY_TARGETS_PREFERENCE+="ruby32 ruby33"
+RUBY_TARGETS_PREFERENCE+="ruby33"
 
 _ruby_implementation_depend() {
 	local rubypn=
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-07  4:13 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-10-07  4:13 UTC (permalink / raw
  To: gentoo-commits
commit:     258a44f3500383f7948781d463652b6d79aa7c06
Author:     Andrei Horodniceanu <a.horodniceanu <AT> proton <DOT> me>
AuthorDate: Fri Oct  4 05:04:47 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Oct  7 04:12:41 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=258a44f3
toolchain.eclass: Print an error message and die if GDC isn't found
When cross compiling sys-devel/gcc[d] one would need
cross-${CHOST}/gcc[d] installed. We can't enforce this dependency so
defer to printing an error message if it can't be found prompting the
user to install the package.
Signed-off-by: Andrei Horodniceanu <a.horodniceanu <AT> proton.me>
Closes: https://github.com/gentoo/gentoo/pull/38894
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 19 +++++++++++++++++--
 1 file changed, 17 insertions(+), 2 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index ff02723e2d90..34f595bcd1bc 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1032,9 +1032,24 @@ toolchain_setup_d() {
 		eend 1
 	done
 
-	if [[ -n ${d_bootstrap} ]] ; then
-		export GDC=${gcc_bin_base}/${d_bootstrap}/${CHOST}-gdc
+	if [[ -z ${d_bootstrap} ]] ; then
+		if tc-is-cross-compiler ; then
+			# We can't add cross-${CHOST}/gcc[d] to BDEPEND but we can
+			# print a useful message to the user.
+			eerror "No ${gcc_pkg}[d] was found installed."
+			eerror "When cross-compiling GDC a bootstrap GDC is required."
+			eerror "Either disable the d USE flag or add:"
+			eerror ""
+			eerror "    ${gcc_pkg} d"
+			eerror ""
+			eerror "In your package.use and re-emerge it."
+			eerror ""
+		fi
+
+		die "Did not find any appropriate GDC compiler installed"
 	fi
+
+	export GDC=${gcc_bin_base}/${d_bootstrap}/${CHOST}-gdc
 }
 
 #---->> src_configure <<----
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-07  4:13 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-10-07  4:13 UTC (permalink / raw
  To: gentoo-commits
commit:     fd01685ece15afd0a2f85471637a719002d46495
Author:     Andrei Horodniceanu <a.horodniceanu <AT> proton <DOT> me>
AuthorDate: Fri Oct  4 03:57:10 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Oct  7 04:12:41 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=fd01685e
toolchain.eclass: also clear GDCFLAGS when cross-compiling
sys-devel/gcc[d] uses GDCFLAGS when compiling the D parts. GDCFLAGS is
also used by ::dlang in a similar manner. The overlay suggests putting
in the variable similar values to CFLAGS so it's possible that it will
contain -march=native.
Because of this, add GDCFLAGS to the list of *FLAGS that are reset to
something that is understood by both the build and the host system when
cross-compiling.
Signed-off-by: Andrei Horodniceanu <a.horodniceanu <AT> proton.me>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 1 +
 1 file changed, 1 insertion(+)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 5b978f6871db..0d46d6f3a799 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1948,6 +1948,7 @@ gcc_do_filter_flags() {
 		CFLAGS="-O2 -pipe"
 		FFLAGS=${CFLAGS}
 		FCFLAGS=${CFLAGS}
+		GDCFLAGS=${CFLAGS}
 
 		# "hppa2.0-unknown-linux-gnu" -> hppa2_0_unknown_linux_gnu
 		local VAR="CFLAGS_"${CTARGET//[-.]/_}
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-07  4:13 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-10-07  4:13 UTC (permalink / raw
  To: gentoo-commits
commit:     75f0421f54035bd364f3b58de94887831302b02f
Author:     Andrei Horodniceanu <a.horodniceanu <AT> proton <DOT> me>
AuthorDate: Fri Oct  4 08:12:22 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Oct  7 04:12:41 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=75f0421f
toolchain.eclass: Only search for a D installation if D bootstrapping is needed
<=gcc-11 doesn't need another gdc to build so don't search for one
during the setup.
Signed-off-by: Andrei Horodniceanu <a.horodniceanu <AT> proton.me>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 5 ++++-
 1 file changed, 4 insertions(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 19357b4dfb2d..ff02723e2d90 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1129,9 +1129,12 @@ toolchain_src_configure() {
 
 		_tc_use_if_iuse ada
 	}
+	_need_d_bootstrap() {
+		_tc_use_if_iuse d && [[ ${GCCMAJOR} -ge 12 ]]
+	}
 
 	_need_ada_bootstrap_mangling && toolchain_setup_ada
-	_tc_use_if_iuse d && toolchain_setup_d
+	_need_d_bootstrap && toolchain_setup_d
 
 	confgcc+=( --enable-languages=${GCC_LANG} )
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-07  4:13 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-10-07  4:13 UTC (permalink / raw
  To: gentoo-commits
commit:     434a6775ce93a15ef517478565a938aa73d1d528
Author:     Andrei Horodniceanu <a.horodniceanu <AT> proton <DOT> me>
AuthorDate: Fri Oct  4 04:10:04 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Oct  7 04:12:41 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=434a6775
toolchain.eclass: Support cross GDC
While the D use flags is masked by crossdev the build used to work, on
my limited number of machines, up until recently with the D code
refactors.
When building sys-devel/gcc or cross-${TARGET}/gcc natively the
appropriate gdc compiler is installed under /usr/${CHOST}/gcc-bin and is
provided by sys-devel/gcc[d].
When building sys-devel/gcc or cross-${CTARGET}/gcc for another system
the appropriate gdc binary is under /usr/${CBUILD}/${CHOST}/gcc-bin and
is provided by cross-${CHOST}/gcc[d].
Also use the full ${CHOST}-gdc executable names since plain gdc is only
present on native builds.
Signed-off-by: Andrei Horodniceanu <a.horodniceanu <AT> proton.me>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 21 +++++++++++++++------
 1 file changed, 15 insertions(+), 6 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 0d46d6f3a799..19357b4dfb2d 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1000,8 +1000,17 @@ toolchain_setup_ada() {
 # Determine the most suitable GDC (D compiler) for bootstrapping
 # and setup the environment for building.
 toolchain_setup_d() {
-	local latest_gcc=$(best_version -b "sys-devel/gcc")
-	latest_gcc="${latest_gcc#sys-devel/gcc-}"
+	local gcc_pkg gcc_bin_base
+	if tc-is-cross-compiler ; then
+		gcc_pkg=cross-${CHOST}/gcc
+		gcc_bin_base=${BROOT}/usr/${CBUILD}/${CHOST}/gcc-bin
+	else
+		gcc_pkg=sys-devel/gcc
+		gcc_bin_base=${BROOT}/usr/${CHOST}/gcc-bin
+	fi
+
+	local latest_gcc=$(best_version -b "${gcc_pkg}")
+	latest_gcc="${latest_gcc#${gcc_pkg}-}"
 	latest_gcc=$(ver_cut 1 ${latest_gcc})
 
 	local d_bootstrap
@@ -1011,10 +1020,10 @@ toolchain_setup_d() {
 	# 2) Iterate downwards from the version being built;
 	# 3) Iterate upwards from the version being built to the greatest version installed.
 	for d_candidate in ${SLOT} $(seq $((${SLOT} - 1)) -1 10) $(seq $((${SLOT} + 1)) ${latest_gcc}) ; do
-		has_version -b "sys-devel/gcc:${d_candidate}" || continue
+		has_version -b "${gcc_pkg}:${d_candidate}" || continue
 
-		ebegin "Testing sys-devel/gcc:${d_candidate} for D"
-		if has_version -b "sys-devel/gcc:${d_candidate}[d(-)]" ; then
+		ebegin "Testing ${gcc_pkg}:${d_candidate} for D"
+		if has_version -b "${gcc_pkg}:${d_candidate}[d(-)]" ; then
 			d_bootstrap=${d_candidate}
 
 			eend 0
@@ -1024,7 +1033,7 @@ toolchain_setup_d() {
 	done
 
 	if [[ -n ${d_bootstrap} ]] ; then
-		export GDC="${BROOT}/usr/${CTARGET}/gcc-bin/${d_bootstrap}/gdc"
+		export GDC=${gcc_bin_base}/${d_bootstrap}/${CHOST}-gdc
 	fi
 }
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-08  7:09 Florian Schmaus
  0 siblings, 0 replies; 6663+ messages in thread
From: Florian Schmaus @ 2024-10-08  7:09 UTC (permalink / raw
  To: gentoo-commits
commit:     5186af37046684bdb34b09f4092d455789d86219
Author:     Volkmar W. Pogatzki <gentoo <AT> pogatzki <DOT> net>
AuthorDate: Wed Oct  2 14:38:14 2024 +0000
Commit:     Florian Schmaus <flow <AT> gentoo <DOT> org>
CommitDate: Tue Oct  8 07:09:38 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=5186af37
java-ant-2.eclass: Mark as dead
The last ebuilds using it were media-libs/opencv-{4.8.1-r2,4.9.0-r1}
Bug: https://bugs.gentoo.org/268313
Bug: https://bugs.gentoo.org/318625
Bug: https://bugs.gentoo.org/539958
Signed-off-by: Volkmar W. Pogatzki <gentoo <AT> pogatzki.net>
Closes: https://github.com/gentoo/gentoo/pull/38851
Signed-off-by: Florian Schmaus <flow <AT> gentoo.org>
 eclass/java-ant-2.eclass | 1 +
 1 file changed, 1 insertion(+)
diff --git a/eclass/java-ant-2.eclass b/eclass/java-ant-2.eclass
index ef7d306dc9b1..c34c81331998 100644
--- a/eclass/java-ant-2.eclass
+++ b/eclass/java-ant-2.eclass
@@ -1,6 +1,7 @@
 # Copyright 2004-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
+# @DEAD
 # @ECLASS: java-ant-2.eclass
 # @MAINTAINER:
 # java@gentoo.org
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-08 15:29 Ulrich Müller
  0 siblings, 0 replies; 6663+ messages in thread
From: Ulrich Müller @ 2024-10-08 15:29 UTC (permalink / raw
  To: gentoo-commits
commit:     5dce92bed22f52a4526a8ef9e708f95271d9dc64
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Tue Aug 20 18:02:59 2024 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Tue Oct  8 15:22:41 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=5dce92be
eqawarn.eclass: Remove dead eclass
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 eclass/eqawarn.eclass | 27 ---------------------------
 1 file changed, 27 deletions(-)
diff --git a/eclass/eqawarn.eclass b/eclass/eqawarn.eclass
deleted file mode 100644
index df6b13151d74..000000000000
--- a/eclass/eqawarn.eclass
+++ /dev/null
@@ -1,27 +0,0 @@
-# Copyright 1999-2022 Gentoo Authors
-# Distributed under the terms of the GNU General Public License v2
-
-# @DEAD
-# @ECLASS: eqawarn.eclass
-# @MAINTAINER:
-# base-system@gentoo.org
-# @SUPPORTED_EAPIS: 6
-# @BLURB: output a QA warning
-
-case ${EAPI} in
-	6) ;;
-	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
-esac
-
-# @FUNCTION: eqawarn
-# @USAGE: [message]
-# @DESCRIPTION:
-# Proxy to ewarn for package managers that don't provide eqawarn and
-# use the PM implementation if available.  Reuses PORTAGE_ELOG_CLASSES
-# as set by the dev profile.
-if ! declare -F eqawarn >/dev/null ; then
-	eqawarn() {
-		has qa ${PORTAGE_ELOG_CLASSES} && ewarn "$@"
-		:
-	}
-fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-08 15:29 Ulrich Müller
  0 siblings, 0 replies; 6663+ messages in thread
From: Ulrich Müller @ 2024-10-08 15:29 UTC (permalink / raw
  To: gentoo-commits
commit:     99bfe5fc6f7cea4dbf7764628cbde4187959d66b
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Tue Aug 20 18:02:49 2024 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Tue Oct  8 15:22:40 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=99bfe5fc
eapi7-ver.eclass: Remove dead eclass
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 eclass/eapi7-ver.eclass | 309 ------------------------------------------------
 1 file changed, 309 deletions(-)
diff --git a/eclass/eapi7-ver.eclass b/eclass/eapi7-ver.eclass
deleted file mode 100644
index 85c0856f73b3..000000000000
--- a/eclass/eapi7-ver.eclass
+++ /dev/null
@@ -1,309 +0,0 @@
-# Copyright 1999-2021 Gentoo Authors
-# Distributed under the terms of the GNU General Public License v2
-
-# @DEAD
-# @ECLASS: eapi7-ver.eclass
-# @MAINTAINER:
-# PMS team <pms@gentoo.org>
-# @AUTHOR:
-# Ulrich Müller <ulm@gentoo.org>
-# Michał Górny <mgorny@gentoo.org>
-# @SUPPORTED_EAPIS: 0 1 2 3 4 5 6
-# @BLURB: Testing implementation of EAPI 7 version manipulators
-# @DESCRIPTION:
-# A stand-alone implementation of the version manipulation functions
-# aimed for EAPI 7.  Intended to be used for wider testing of
-# the proposed functions and to allow ebuilds to switch to the new
-# model early, with minimal change needed for actual EAPI 7.
-#
-# https://bugs.gentoo.org/482170
-#
-# @SUBSECTION Version strings
-#
-# The functions support arbitrary version strings consisting of version
-# components interspersed with (possibly empty) version separators.
-#
-# A version component can either consist purely of digits ([0-9]+)
-# or purely of uppercase and lowercase letters ([A-Za-z]+).  A version
-# separator is either a string of any other characters ([^A-Za-z0-9]+),
-# or it occurs at the transition between a sequence of letters
-# and a sequence of digits, or vice versa.  In the latter case,
-# the version separator is an empty string.
-#
-# The version is processed left-to-right, and each successive component
-# is assigned numbers starting with 1.  The components are either split
-# on version separators or on boundaries between digits and letters
-# (in which case the separator between the components is empty).
-# Version separators are assigned numbers starting with 1 for
-# the separator between 1st and 2nd components.  As a special case,
-# if the version string starts with a separator, it is assigned index 0.
-#
-# Examples:
-#
-# @CODE
-#   1.2b-alpha4 -> 1 . 2 '' b - alpha '' 4
-#                  c s c s  c s c     s  c
-#                  1 1 2 2  3 3 4     4  5
-#
-#   .11.        -> . 11 .
-#                  s c  s
-#                  0 1  1
-# @CODE
-#
-# @SUBSECTION Ranges
-#
-# A range can be specified as 'm' for m-th version component, 'm-'
-# for all components starting with m-th or 'm-n' for components starting
-# at m-th and ending at n-th (inclusive).  If the range spans outside
-# the version string, it is truncated silently.
-
-case ${EAPI:-0} in
-	0|1|2|3|4|5|6) ;;
-	7|8) die "${ECLASS}: EAPI=${EAPI} includes all functions from this eclass" ;;
-	*) die "${ECLASS}: EAPI=${EAPI} unknown" ;;
-esac
-
-# @FUNCTION: _ver_parse_range
-# @USAGE: <range> <max>
-# @INTERNAL
-# @DESCRIPTION:
-# Parse the range string <range>, setting 'start' and 'end' variables
-# to the appropriate bounds.  <max> specifies the appropriate upper
-# bound for the range; the user-specified value is truncated to this.
-_ver_parse_range() {
-	local range=${1}
-	local max=${2}
-
-	[[ ${range} == [0-9]* ]] \
-		|| die "${FUNCNAME}: range must start with a number"
-	start=${range%-*}
-	[[ ${range} == *-* ]] && end=${range#*-} || end=${start}
-	if [[ ${end} ]]; then
-		[[ ${start} -le ${end} ]] \
-			|| die "${FUNCNAME}: end of range must be >= start"
-		[[ ${end} -le ${max} ]] || end=${max}
-	else
-		end=${max}
-	fi
-}
-
-# @FUNCTION: _ver_split
-# @USAGE: <version>
-# @INTERNAL
-# @DESCRIPTION:
-# Split the version string <version> into separator-component array.
-# Sets 'comp' to an array of the form: ( s_0 c_1 s_1 c_2 s_2 c_3... )
-# where s_i are separators and c_i are components.
-_ver_split() {
-	local v=${1} LC_ALL=C
-
-	comp=()
-
-	# get separators and components
-	local s c
-	while [[ ${v} ]]; do
-		# cut the separator
-		s=${v%%[a-zA-Z0-9]*}
-		v=${v:${#s}}
-		# cut the next component; it can be either digits or letters
-		[[ ${v} == [0-9]* ]] && c=${v%%[^0-9]*} || c=${v%%[^a-zA-Z]*}
-		v=${v:${#c}}
-
-		comp+=( "${s}" "${c}" )
-	done
-}
-
-# @FUNCTION: ver_cut
-# @USAGE: <range> [<version>]
-# @DESCRIPTION:
-# Print the substring of the version string containing components
-# defined by the <range> and the version separators between them.
-# Processes <version> if specified, ${PV} otherwise.
-#
-# For the syntax of versions and ranges, please see the eclass
-# description.
-ver_cut() {
-	local range=${1}
-	local v=${2:-${PV}}
-	local start end
-	local -a comp
-
-	_ver_split "${v}"
-	local max=$((${#comp[@]}/2))
-	_ver_parse_range "${range}" "${max}"
-
-	if [[ ${start} -gt 0 ]]; then
-		start=$(( start*2 - 1 ))
-	fi
-	# Work around a bug in bash-3.2, where "${comp[*]:start:end*2-start}"
-	# inserts stray 0x7f characters for empty array elements
-	printf "%s" "${comp[@]:start:end*2-start}" $'\n'
-}
-
-# @FUNCTION: ver_rs
-# @USAGE: <range> <repl> [<range> <repl>...] [<version>]
-# @DESCRIPTION:
-# Print the version string after substituting the specified version
-# separators at <range> with <repl> (string).  Multiple '<range> <repl>'
-# pairs can be specified.  Processes <version> if specified,
-# ${PV} otherwise.
-#
-# For the syntax of versions and ranges, please see the eclass
-# description.
-ver_rs() {
-	local v
-	(( ${#} & 1 )) && v=${@: -1} || v=${PV}
-	local start end i
-	local -a comp
-
-	_ver_split "${v}"
-	local max=$((${#comp[@]}/2 - 1))
-
-	while [[ ${#} -ge 2 ]]; do
-		_ver_parse_range "${1}" "${max}"
-		for (( i = start*2; i <= end*2; i+=2 )); do
-			[[ ${i} -eq 0 && -z ${comp[i]} ]] && continue
-			comp[i]=${2}
-		done
-		shift 2
-	done
-
-	local IFS=
-	echo "${comp[*]}"
-}
-
-# @FUNCTION: _ver_compare_int
-# @USAGE: <a> <b>
-# @RETURN: 0 if <a> -eq <b>, 1 if <a> -lt <b>, 3 if <a> -gt <b>
-# @INTERNAL
-# @DESCRIPTION:
-# Compare two non-negative integers <a> and <b>, of arbitrary length.
-# If <a> is equal to, less than, or greater than <b>, return 0, 1, or 3
-# as exit status, respectively.
-_ver_compare_int() {
-	local a=$1 b=$2 d=$(( ${#1}-${#2} ))
-
-	# Zero-pad to equal length if necessary.
-	if [[ ${d} -gt 0 ]]; then
-		printf -v b "%0${d}d%s" 0 "${b}"
-	elif [[ ${d} -lt 0 ]]; then
-		printf -v a "%0$(( -d ))d%s" 0 "${a}"
-	fi
-
-	[[ ${a} > ${b} ]] && return 3
-	[[ ${a} == "${b}" ]]
-}
-
-# @FUNCTION: _ver_compare
-# @USAGE: <va> <vb>
-# @RETURN: 1 if <va> < <vb>, 2 if <va> = <vb>, 3 if <va> > <vb>
-# @INTERNAL
-# @DESCRIPTION:
-# Compare two versions <va> and <vb>.  If <va> is less than, equal to,
-# or greater than <vb>, return 1, 2, or 3 as exit status, respectively.
-_ver_compare() {
-	local va=${1} vb=${2} a an al as ar b bn bl bs br re LC_ALL=C
-
-	re="^([0-9]+(\.[0-9]+)*)([a-z]?)((_(alpha|beta|pre|rc|p)[0-9]*)*)(-r[0-9]+)?$"
-
-	[[ ${va} =~ ${re} ]] || die "${FUNCNAME}: invalid version: ${va}"
-	an=${BASH_REMATCH[1]}
-	al=${BASH_REMATCH[3]}
-	as=${BASH_REMATCH[4]}
-	ar=${BASH_REMATCH[7]}
-
-	[[ ${vb} =~ ${re} ]] || die "${FUNCNAME}: invalid version: ${vb}"
-	bn=${BASH_REMATCH[1]}
-	bl=${BASH_REMATCH[3]}
-	bs=${BASH_REMATCH[4]}
-	br=${BASH_REMATCH[7]}
-
-	# Compare numeric components (PMS algorithm 3.2)
-	# First component
-	_ver_compare_int "${an%%.*}" "${bn%%.*}" || return
-
-	while [[ ${an} == *.* && ${bn} == *.* ]]; do
-		# Other components (PMS algorithm 3.3)
-		an=${an#*.}
-		bn=${bn#*.}
-		a=${an%%.*}
-		b=${bn%%.*}
-		if [[ ${a} == 0* || ${b} == 0* ]]; then
-			# Remove any trailing zeros
-			[[ ${a} =~ 0+$ ]] && a=${a%"${BASH_REMATCH[0]}"}
-			[[ ${b} =~ 0+$ ]] && b=${b%"${BASH_REMATCH[0]}"}
-			[[ ${a} > ${b} ]] && return 3
-			[[ ${a} < ${b} ]] && return 1
-		else
-			_ver_compare_int "${a}" "${b}" || return
-		fi
-	done
-	[[ ${an} == *.* ]] && return 3
-	[[ ${bn} == *.* ]] && return 1
-
-	# Compare letter components (PMS algorithm 3.4)
-	[[ ${al} > ${bl} ]] && return 3
-	[[ ${al} < ${bl} ]] && return 1
-
-	# Compare suffixes (PMS algorithm 3.5)
-	as=${as#_}${as:+_}
-	bs=${bs#_}${bs:+_}
-	while [[ -n ${as} && -n ${bs} ]]; do
-		# Compare each suffix (PMS algorithm 3.6)
-		a=${as%%_*}
-		b=${bs%%_*}
-		if [[ ${a%%[0-9]*} == "${b%%[0-9]*}" ]]; then
-			_ver_compare_int "${a##*[a-z]}" "${b##*[a-z]}" || return
-		else
-			# Check for p first
-			[[ ${a%%[0-9]*} == p ]] && return 3
-			[[ ${b%%[0-9]*} == p ]] && return 1
-			# Hack: Use that alpha < beta < pre < rc alphabetically
-			[[ ${a} > ${b} ]] && return 3 || return 1
-		fi
-		as=${as#*_}
-		bs=${bs#*_}
-	done
-	if [[ -n ${as} ]]; then
-		[[ ${as} == p[_0-9]* ]] && return 3 || return 1
-	elif [[ -n ${bs} ]]; then
-		[[ ${bs} == p[_0-9]* ]] && return 1 || return 3
-	fi
-
-	# Compare revision components (PMS algorithm 3.7)
-	_ver_compare_int "${ar#-r}" "${br#-r}" || return
-
-	return 2
-}
-
-# @FUNCTION: ver_test
-# @USAGE: [<v1>] <op> <v2>
-# @DESCRIPTION:
-# Check if the relation <v1> <op> <v2> is true.  If <v1> is not specified,
-# default to ${PVR}.  <op> can be -gt, -ge, -eq, -ne, -le, -lt.
-# Both versions must conform to the PMS version syntax (with optional
-# revision parts), and the comparison is performed according to
-# the algorithm specified in the PMS.
-ver_test() {
-	local va op vb
-
-	if [[ $# -eq 3 ]]; then
-		va=${1}
-		shift
-	else
-		va=${PVR}
-	fi
-
-	[[ $# -eq 2 ]] || die "${FUNCNAME}: bad number of arguments"
-
-	op=${1}
-	vb=${2}
-
-	case ${op} in
-		-eq|-ne|-lt|-le|-gt|-ge) ;;
-		*) die "${FUNCNAME}: invalid operator: ${op}" ;;
-	esac
-
-	_ver_compare "${va}" "${vb}"
-	test $? "${op}" 2
-}
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-08 15:32 David Seifert
  0 siblings, 0 replies; 6663+ messages in thread
From: David Seifert @ 2024-10-08 15:32 UTC (permalink / raw
  To: gentoo-commits
commit:     c274ff15c3daa526f567c4cb6e500b9a50214db6
Author:     David Seifert <soap <AT> gentoo <DOT> org>
AuthorDate: Tue Oct  8 15:31:28 2024 +0000
Commit:     David Seifert <soap <AT> gentoo <DOT> org>
CommitDate: Tue Oct  8 15:31:28 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=c274ff15
python-r1.eclass: drop support for EAPI 6
Signed-off-by: David Seifert <soap <AT> gentoo.org>
 eclass/python-r1.eclass | 8 ++++----
 1 file changed, 4 insertions(+), 4 deletions(-)
diff --git a/eclass/python-r1.eclass b/eclass/python-r1.eclass
index adf87c2c52f7..28daaed1b463 100644
--- a/eclass/python-r1.eclass
+++ b/eclass/python-r1.eclass
@@ -30,14 +30,14 @@
 # For more information, please see the Python Guide:
 # https://projects.gentoo.org/python/guide/
 
+if [[ -z ${_PYTHON_R1_ECLASS} ]]; then
+_PYTHON_R1_ECLASS=1
+
 case ${EAPI} in
 	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
-if [[ -z ${_PYTHON_R1_ECLASS} ]]; then
-_PYTHON_R1_ECLASS=1
-
 if [[ ${_PYTHON_SINGLE_R1_ECLASS} ]]; then
 	die 'python-r1.eclass can not be used with python-single-r1.eclass.'
 elif [[ ${_PYTHON_ANY_R1_ECLASS} ]]; then
@@ -789,7 +789,7 @@ python_replicate_script() {
 		)
 
 		python_fix_shebang -q \
-			"${files[@]/*\//${D%/}/${PYTHON_SCRIPTDIR}/}"
+			"${files[@]/*\//${D}${PYTHON_SCRIPTDIR}/}"
 	}
 
 	local files=( "${@}" )
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-08 15:32 David Seifert
  0 siblings, 0 replies; 6663+ messages in thread
From: David Seifert @ 2024-10-08 15:32 UTC (permalink / raw
  To: gentoo-commits
commit:     aa6fbc2d4e3ffbfd33fc6a9d6b9787a477bf9da3
Author:     David Seifert <soap <AT> gentoo <DOT> org>
AuthorDate: Tue Oct  8 15:31:30 2024 +0000
Commit:     David Seifert <soap <AT> gentoo <DOT> org>
CommitDate: Tue Oct  8 15:31:30 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=aa6fbc2d
readme.gentoo-r1.eclass: drop support for EAPI 6
Signed-off-by: David Seifert <soap <AT> gentoo.org>
 eclass/readme.gentoo-r1.eclass | 8 ++------
 1 file changed, 2 insertions(+), 6 deletions(-)
diff --git a/eclass/readme.gentoo-r1.eclass b/eclass/readme.gentoo-r1.eclass
index 3d2d8244687c..4f1728da5b6f 100644
--- a/eclass/readme.gentoo-r1.eclass
+++ b/eclass/readme.gentoo-r1.eclass
@@ -6,7 +6,7 @@
 # Pacho Ramos <pacho@gentoo.org>
 # @AUTHOR:
 # Author: Pacho Ramos <pacho@gentoo.org>
-# @SUPPORTED_EAPIS: 6 7 8
+# @SUPPORTED_EAPIS: 7 8
 # @BLURB: install a doc file shown via elog messages
 # @DESCRIPTION:
 # An eclass for installing a README.gentoo doc file recording tips
@@ -21,10 +21,6 @@ if [[ -z ${_README_GENTOO_ECLASS} ]]; then
 _README_GENTOO_ECLASS=1
 
 case ${EAPI} in
-	6)
-		ewarn "${CATEGORY}/${PF}: ebuild uses ${ECLASS} with deprecated EAPI ${EAPI}!"
-		ewarn "${CATEGORY}/${PF}: Support will be removed on 2024-10-08. Please port to newer EAPI."
-		;;
 	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
@@ -82,7 +78,7 @@ readme.gentoo_create_doc() {
 	( # subshell to avoid pollution of calling environment
 		docinto .
 		dodoc "${T}"/README.gentoo
-	) || die
+	)
 	README_GENTOO_DOC_VALUE=$(< "${T}/README.gentoo")
 }
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-08 15:32 David Seifert
  0 siblings, 0 replies; 6663+ messages in thread
From: David Seifert @ 2024-10-08 15:32 UTC (permalink / raw
  To: gentoo-commits
commit:     1040ec9c3f79e00f688490cfaf91ee6926002ab2
Author:     David Seifert <soap <AT> gentoo <DOT> org>
AuthorDate: Tue Oct  8 15:31:33 2024 +0000
Commit:     David Seifert <soap <AT> gentoo <DOT> org>
CommitDate: Tue Oct  8 15:31:33 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=1040ec9c
ruby-utils.eclass: drop support for EAPI 5 and 6
Signed-off-by: David Seifert <soap <AT> gentoo.org>
 eclass/ruby-utils.eclass | 10 +++-------
 1 file changed, 3 insertions(+), 7 deletions(-)
diff --git a/eclass/ruby-utils.eclass b/eclass/ruby-utils.eclass
index 81bda3abfb36..29b9ab396b87 100644
--- a/eclass/ruby-utils.eclass
+++ b/eclass/ruby-utils.eclass
@@ -6,7 +6,7 @@
 # Ruby team <ruby@gentoo.org>
 # @AUTHOR:
 # Author: Hans de Graaff <graaff@gentoo.org>
-# @SUPPORTED_EAPIS: 5 6 7 8
+# @SUPPORTED_EAPIS: 7 8
 # @BLURB: An eclass for supporting ruby scripts and bindings in non-ruby packages
 # @DESCRIPTION:
 # The ruby-utils eclass is designed to allow an easier installation of
@@ -15,13 +15,10 @@
 # This eclass does not set any metadata variables nor export any phase
 # functions. It can be inherited safely.
 
-if [[ ! ${_RUBY_UTILS} ]]; then
+if [[ -z ${_RUBY_UTILS_ECLASS} ]] ; then
+_RUBY_UTILS_ECLASS=1
 
 case ${EAPI} in
-	5|6)
-		ewarn "${CATEGORY}/${PF}: ebuild uses ${ECLASS} with deprecated EAPI ${EAPI}!"
-		ewarn "${CATEGORY}/${PF}: Support will be removed on 2024-10-08. Please port to newer EAPI."
-		;;
 	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
@@ -68,5 +65,4 @@ _ruby_implementation_depend() {
 	echo "$2${rubypn}$3${rubyslot}"
 }
 
-_RUBY_UTILS=1
 fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-08 15:32 David Seifert
  0 siblings, 0 replies; 6663+ messages in thread
From: David Seifert @ 2024-10-08 15:32 UTC (permalink / raw
  To: gentoo-commits
commit:     177a7f4ab73cddf91f2e9f19d97510bf027e0d0c
Author:     David Seifert <soap <AT> gentoo <DOT> org>
AuthorDate: Tue Oct  8 15:31:32 2024 +0000
Commit:     David Seifert <soap <AT> gentoo <DOT> org>
CommitDate: Tue Oct  8 15:31:32 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=177a7f4a
ruby-ng.eclass: drop support for EAPI 6
Signed-off-by: David Seifert <soap <AT> gentoo.org>
 eclass/ruby-ng.eclass | 81 +++++++++++----------------------------------------
 1 file changed, 17 insertions(+), 64 deletions(-)
diff --git a/eclass/ruby-ng.eclass b/eclass/ruby-ng.eclass
index 2ef6d2247435..2a552094f60f 100644
--- a/eclass/ruby-ng.eclass
+++ b/eclass/ruby-ng.eclass
@@ -8,7 +8,7 @@
 # Author: Diego E. Pettenò <flameeyes@gentoo.org>
 # Author: Alex Legler <a3li@gentoo.org>
 # Author: Hans de Graaff <graaff@gentoo.org>
-# @SUPPORTED_EAPIS: 6 7 8
+# @SUPPORTED_EAPIS: 7 8
 # @BLURB: An eclass for installing Ruby packages with proper support for multiple Ruby slots.
 # @DESCRIPTION:
 # The Ruby eclass is designed to allow an easier installation of Ruby packages
@@ -66,19 +66,14 @@
 # (e.g. selenium's firefox driver extension). When set this argument is
 # passed to "grep -E" to remove reporting of these shared objects.
 
+if [[ -z ${_RUBY_NG_ECLASS} ]]; then
+_RUBY_NG_ECLASS=1
+
 case ${EAPI} in
-	6)
-		ewarn "${CATEGORY}/${PF}: ebuild uses ${ECLASS} with deprecated EAPI ${EAPI}!"
-		ewarn "${CATEGORY}/${PF}: Support will be removed on 2024-10-08. Please port to newer EAPI."
-		;;
 	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
-if [[ -z ${_RUBY_NG_ECLASS} ]]; then
-_RUBY_NG_ECLASS=1
-
-[[ ${EAPI} == 6 ]] && inherit eqawarn toolchain-funcs
 inherit multilib ruby-utils
 
 # S is no longer automatically assigned when it doesn't exist.
@@ -222,16 +217,7 @@ ruby_add_rdepend() {
 	case $# in
 		1) ;;
 		2)
-			case ${EAPI} in
-				6)
-					[[ "${GENTOO_DEV}" == "yes" ]] && eqawarn "You can now use the usual syntax in ruby_add_rdepend for $CATEGORY/$PF"
-					ruby_add_rdepend "$(_ruby_wrap_conditions "$1" "$2")"
-					return
-					;;
-				*)
-					die "Use the usual depend syntax with a single argument in ruby_add_rdepend"
-					;;
-			esac
+			die "Use the usual depend syntax with a single argument in ruby_add_rdepend"
 			;;
 		*)
 			die "bad number of arguments to $0"
@@ -245,10 +231,7 @@ ruby_add_rdepend() {
 
 	# Add the dependency as a test-dependency since we're going to
 	# execute the code during test phase.
-	case ${EAPI} in
-		6) DEPEND+=" test? ( ${_RUBY_ATOMS_SAMELIB_RESULT} )" ;;
-		*) BDEPEND+=" test? ( ${_RUBY_ATOMS_SAMELIB_RESULT} )" ;;
-	esac
+	BDEPEND+=" test? ( ${_RUBY_ATOMS_SAMELIB_RESULT} )"
 	if ! has test "$IUSE"; then
 		IUSE+=" test"
 		RESTRICT+=" !test? ( test )"
@@ -258,8 +241,8 @@ ruby_add_rdepend() {
 # @FUNCTION: ruby_add_bdepend
 # @USAGE: dependencies
 # @DESCRIPTION:
-# Adds the specified dependencies, with use condition(s) to DEPEND (or
-# BDEPEND in EAPI7), taking the current set of ruby targets into
+# Adds the specified dependencies, with use condition(s) to BDEPEND,
+# taking the current set of ruby targets into
 # account. This makes sure that all ruby dependencies of the package are
 # installed for the same ruby targets. Use this function for all ruby
 # dependencies instead of setting DEPEND or BDEPEND yourself. The list
@@ -270,16 +253,7 @@ ruby_add_bdepend() {
 	case $# in
 		1) ;;
 		2)
-			case ${EAPI} in
-				6)
-					[[ "${GENTOO_DEV}" == "yes" ]] && eqawarn "You can now use the usual syntax in ruby_add_bdepend for $CATEGORY/$PF"
-					ruby_add_bdepend "$(_ruby_wrap_conditions "$1" "$2")"
-					return
-					;;
-				*)
-					die "Use the usual depend syntax with a single argument in ruby_add_bdepend"
-					;;
-			esac
+			die "Use the usual depend syntax with a single argument in ruby_add_bdepend"
 			;;
 		*)
 			die "bad number of arguments to $0"
@@ -289,25 +263,16 @@ ruby_add_bdepend() {
 	_ruby_set_globals_invalidate_if_stale
 	_ruby_atoms_samelib "$1"
 
-	case ${EAPI} in
-		6) DEPEND+=" ${_RUBY_ATOMS_SAMELIB_RESULT}" ;;
-		*) BDEPEND+=" ${_RUBY_ATOMS_SAMELIB_RESULT}" ;;
-	esac
+	BDEPEND+=" ${_RUBY_ATOMS_SAMELIB_RESULT}"
 }
 
 # @FUNCTION: ruby_add_depend
 # @USAGE: dependencies
 # @DESCRIPTION:
-# Adds the specified dependencies to DEPEND in EAPI7, similar to
-# ruby_add_bdepend.
+# Adds the specified dependencies to DEPEND, similar to ruby_add_bdepend.
 ruby_add_depend() {
 	debug-print-function ${FUNCNAME} "${@}"
 
-	case ${EAPI} in
-		6) die "only available in EAPI 7 and newer" ;;
-		*) ;;
-	esac
-
 	case $# in
 		1) ;;
 		*) die "bad number of arguments to $0" ;;
@@ -369,7 +334,7 @@ _ruby_get_use_targets() {
 # confuse this function with ruby_implementation_depend().
 #
 # @EXAMPLE:
-# EAPI=7
+# EAPI=8
 # RUBY_OPTIONAL=yes
 #
 # inherit ruby-ng
@@ -421,10 +386,7 @@ if [[ ${RUBY_OPTIONAL} != yes ]]; then
 	DEPEND+=" ${_RUBY_IMPLEMENTATIONS_DEPEND}"
 	RDEPEND+=" ${_RUBY_IMPLEMENTATIONS_DEPEND}"
 	REQUIRED_USE+=" || ( ${_RUBY_GET_USE_TARGETS} )"
-	case ${EAPI} in
-		6) ;;
-		*) BDEPEND+=" ${_RUBY_IMPLEMENTATIONS_DEPEND}" ;;
-	esac
+	BDEPEND+=" ${_RUBY_IMPLEMENTATIONS_DEPEND}"
 fi
 
 _ruby_invoke_environment() {
@@ -538,18 +500,9 @@ ruby-ng_src_unpack() {
 }
 
 _ruby_apply_patches() {
-	case ${EAPI} in
-		6)
-			if [[ -n ${RUBY_PATCHES[@]} ]]; then
-			   eqawarn "RUBY_PATCHES is no longer supported, use PATCHES instead"
-			fi
-			;;
-		*)
-			if [[ -n ${RUBY_PATCHES[@]} ]]; then
-				die "RUBY_PATCHES is no longer supported, use PATCHES instead"
-			fi
-			;;
-	esac
+	if [[ -n ${RUBY_PATCHES[@]} ]]; then
+		die "RUBY_PATCHES is no longer supported, use PATCHES instead"
+	fi
 
 	# This is a special case: instead of executing just in the special
 	# "all" environment, this will actually copy the effects on _all_
@@ -699,7 +652,7 @@ doruby() {
 		insinto "${sitelibdir#${EPREFIX}}"
 		insopts -m 0644
 		doins "$@"
-	) || die "failed to install $@"
+	)
 }
 
 # @FUNCTION: ruby_get_libruby
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-08 15:32 David Seifert
  0 siblings, 0 replies; 6663+ messages in thread
From: David Seifert @ 2024-10-08 15:32 UTC (permalink / raw
  To: gentoo-commits
commit:     ab2616765f39a5e5e6f193d292446fd6aa3f476f
Author:     David Seifert <soap <AT> gentoo <DOT> org>
AuthorDate: Tue Oct  8 15:31:29 2024 +0000
Commit:     David Seifert <soap <AT> gentoo <DOT> org>
CommitDate: Tue Oct  8 15:31:29 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=ab261676
python-utils-r1.eclass: drop support for EAPI 6
Signed-off-by: David Seifert <soap <AT> gentoo.org>
 eclass/python-utils-r1.eclass | 30 +++++++++++++++---------------
 1 file changed, 15 insertions(+), 15 deletions(-)
diff --git a/eclass/python-utils-r1.eclass b/eclass/python-utils-r1.eclass
index 45d3da6bb98c..7a133f1ff655 100644
--- a/eclass/python-utils-r1.eclass
+++ b/eclass/python-utils-r1.eclass
@@ -23,14 +23,14 @@
 # metadata/install-qa-check.d/60python-pyc
 # See bug #704286, bug #781878
 
+if [[ -z ${_PYTHON_UTILS_R1_ECLASS} ]]; then
+_PYTHON_UTILS_R1_ECLASS=1
+
 case ${EAPI} in
 	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
-if [[ ! ${_PYTHON_UTILS_R1_ECLASS} ]]; then
-_PYTHON_UTILS_R1_ECLASS=1
-
 [[ ${EAPI} == 7 ]] && inherit eapi8-dosym
 inherit multiprocessing toolchain-funcs
 
@@ -617,8 +617,8 @@ python_optimize() {
 			# 2) skip paths which do not exist
 			#    (python2.6 complains about them verbosely)
 
-			if [[ ${f} == /* && -d ${D%/}${f} ]]; then
-				set -- "${D%/}${f}" "${@}"
+			if [[ ${f} == /* && -d ${D}${f} ]]; then
+				set -- "${D}${f}" "${@}"
 			fi
 		done < <(
 			"${PYTHON}" - <<-EOF || die
@@ -634,7 +634,7 @@ python_optimize() {
 	local d
 	for d; do
 		# make sure to get a nice path without //
-		local instpath=${d#${D%/}}
+		local instpath=${d#${D}}
 		instpath=/${instpath##/}
 
 		einfo "Optimize Python modules for ${instpath}"
@@ -741,7 +741,7 @@ python_newexe() {
 
 	# don't use this at home, just call python_doscript() instead
 	if [[ ${_PYTHON_REWRITE_SHEBANG} ]]; then
-		python_fix_shebang -q "${ED%/}/${d}/${newfn}"
+		python_fix_shebang -q "${ED}${d}/${newfn}"
 	fi
 }
 
@@ -872,15 +872,15 @@ python_domodule() {
 			insinto "${d}"
 			doins -r "${@}" || return ${?}
 		)
-		python_optimize "${ED%/}/${d}"
+		python_optimize "${ED}${d}"
 	elif [[ -n ${BUILD_DIR} ]]; then
 		local dest=${BUILD_DIR}/install${EPREFIX}/${d}
 		mkdir -p "${dest}" || die
 		cp -pR "${@}" "${dest}/" || die
 		(
-			cd "${dest}" &&
-			chmod -R a+rX "${@##*/}"
-		) || die
+			cd "${dest}" || die
+			chmod -R a+rX "${@##*/}" || die
+		)
 	else
 		die "${FUNCNAME} can only be used in src_install or with BUILD_DIR set"
 	fi
@@ -1103,17 +1103,17 @@ python_fix_shebang() {
 			fi
 
 			if [[ ! ${quiet} ]]; then
-				einfo "Fixing shebang in ${f#${D%/}}."
+				einfo "Fixing shebang in ${f#${D}}."
 			fi
 
 			if [[ ! ${error} ]]; then
-				debug-print "${FUNCNAME}: in file ${f#${D%/}}"
+				debug-print "${FUNCNAME}: in file ${f#${D}}"
 				debug-print "${FUNCNAME}: rewriting shebang: ${shebang}"
 				sed -i -e "1s@${from}@#!${EPREFIX}/usr/bin/${EPYTHON}@" "${f}" || die
 				any_fixed=1
 			else
 				eerror "The file has incompatible shebang:"
-				eerror "  file: ${f#${D%/}}"
+				eerror "  file: ${f#${D}}"
 				eerror "  current shebang: ${shebang}"
 				eerror "  requested impl: ${EPYTHON}"
 				die "${FUNCNAME}: conversion of incompatible shebang requested"
@@ -1121,7 +1121,7 @@ python_fix_shebang() {
 		done < <(find -H "${path}" -type f -print0 || die)
 
 		if [[ ! ${any_fixed} ]]; then
-			eerror "QA error: ${FUNCNAME}, ${path#${D%/}} did not match any fixable files."
+			eerror "QA error: ${FUNCNAME}, ${path#${D}} did not match any fixable files."
 			eerror "There are no Python files in specified directory."
 			die "${FUNCNAME} did not match any fixable files"
 		fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-08 15:32 David Seifert
  0 siblings, 0 replies; 6663+ messages in thread
From: David Seifert @ 2024-10-08 15:32 UTC (permalink / raw
  To: gentoo-commits
commit:     52f627a5cd18b6dec318d672438b291ebddf94b9
Author:     David Seifert <soap <AT> gentoo <DOT> org>
AuthorDate: Tue Oct  8 15:31:31 2024 +0000
Commit:     David Seifert <soap <AT> gentoo <DOT> org>
CommitDate: Tue Oct  8 15:31:31 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=52f627a5
ruby-fakegem.eclass: drop support for EAPI 5 and 6
Signed-off-by: David Seifert <soap <AT> gentoo.org>
 eclass/ruby-fakegem.eclass | 57 ++++++++++++++++------------------------------
 1 file changed, 20 insertions(+), 37 deletions(-)
diff --git a/eclass/ruby-fakegem.eclass b/eclass/ruby-fakegem.eclass
index 04099a82ef4f..207ba42b9544 100644
--- a/eclass/ruby-fakegem.eclass
+++ b/eclass/ruby-fakegem.eclass
@@ -8,13 +8,21 @@
 # Author: Diego E. Pettenò <flameeyes@gentoo.org>
 # Author: Alex Legler <a3li@gentoo.org>
 # Author: Hans de Graaff <graaff@gentoo.org>
-# @SUPPORTED_EAPIS: 5 6 7 8
+# @SUPPORTED_EAPIS: 7 8
 # @PROVIDES: ruby-ng
 # @BLURB: An eclass for installing Ruby packages to behave like RubyGems.
 # @DESCRIPTION:
 # This eclass allows to install arbitrary Ruby libraries (including Gems),
 # providing integration into the RubyGems system even for "regular" packages.
 
+if [[ -z ${_RUBY_FAKEGEM_ECLASS} ]]; then
+_RUBY_FAKEGEM_ECLASS=1
+
+case ${EAPI} in
+	7|8) ;;
+	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
+esac
+
 inherit ruby-ng
 
 # @ECLASS_VARIABLE: RUBY_FAKEGEM_NAME
@@ -61,14 +69,7 @@ RUBY_FAKEGEM_TASK_TEST="${RUBY_FAKEGEM_TASK_TEST-test}"
 #  - rdoc (calls `rdoc-2`, adds dev-ruby/rdoc to the dependencies);
 #  - yard (calls `yard`, adds dev-ruby/yard to the dependencies);
 #  - none
-case ${EAPI} in
-	5|6)
-		RUBY_FAKEGEM_RECIPE_DOC="${RUBY_FAKEGEM_RECIPE_DOC-rake}"
-		;;
-	*)
-		RUBY_FAKEGEM_RECIPE_DOC="${RUBY_FAKEGEM_RECIPE_DOC-rdoc}"
-		;;
-esac
+: "${RUBY_FAKEGEM_RECIPE_DOC=rdoc}"
 
 # @ECLASS_VARIABLE: RUBY_FAKEGEM_DOCDIR
 # @DEFAULT_UNSET
@@ -138,15 +139,6 @@ RUBY_FAKEGEM_BINDIR="${RUBY_FAKEGEM_BINDIR-bin}"
 # legacy way to install extensions for a long time.
 RUBY_FAKEGEM_EXTENSION_LIBDIR="${RUBY_FAKEGEM_EXTENSION_LIBDIR-lib}"
 
-case ${EAPI} in
-	6)
-		ewarn "${CATEGORY}/${PF}: ebuild uses ${ECLASS} with deprecated EAPI ${EAPI}!"
-		ewarn "${CATEGORY}/${PF}: Support will be removed on 2024-10-08. Please port to newer EAPI."
-		;;
-	7|8) ;;
-	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
-esac
-
 RUBY_FAKEGEM_SUFFIX="${RUBY_FAKEGEM_SUFFIX:-}"
 
 
@@ -215,13 +207,7 @@ SRC_URI="https://rubygems.org/gems/${RUBY_FAKEGEM_NAME}-${RUBY_FAKEGEM_VERSION}$
 
 ruby_add_bdepend "virtual/rubygems"
 ruby_add_rdepend virtual/rubygems
-case ${EAPI} in
-	5|6)
-		;;
-	*)
-		ruby_add_depend virtual/rubygems
-		;;
-esac
+ruby_add_depend virtual/rubygems
 
 # Many (but not all) extensions use pkgconfig in src_configure.
 if [[ ${#RUBY_FAKEGEM_EXTENSIONS[@]} -gt 0 ]]; then
@@ -258,7 +244,7 @@ ruby_fakegem_doins() {
 	(
 		insinto $(ruby_fakegem_gemsdir)/gems/${RUBY_FAKEGEM_NAME}-${RUBY_FAKEGEM_VERSION}
 		doins "$@"
-	) || die "failed $0 $@"
+	)
 }
 
 # @FUNCTION: ruby_fakegem_newins
@@ -278,7 +264,7 @@ ruby_fakegem_newins() {
 
 		insinto $(ruby_fakegem_gemsdir)/gems/${RUBY_FAKEGEM_NAME}-${RUBY_FAKEGEM_VERSION}${newdirname}
 		newins "$1" ${newbasename}
-	) || die "failed $0 $@"
+	)
 }
 
 # @FUNCTION: ruby_fakegem_install_gemspec
@@ -303,7 +289,7 @@ ruby_fakegem_install_gemspec() {
 				ruby_fakegem_genspec ${gemspec}
 			fi
 		fi
-	) || die "Unable to generate gemspec file."
+	)
 
 	insinto $(ruby_fakegem_gemsdir)/specifications
 	newins ${gemspec} ${RUBY_FAKEGEM_NAME}-${RUBY_FAKEGEM_VERSION}.gemspec || die "Unable to install gemspec file."
@@ -349,14 +335,9 @@ ruby_fakegem_metadata_gemspec() {
 ruby_fakegem_genspec() {
 	debug-print-function ${FUNCNAME} "${@}"
 
-	case ${EAPI} in
-		5|6) ;;
-		*)
-			eqawarn "Generating generic fallback gemspec *without* dependencies"
-			eqawarn "This will only work when there are no runtime dependencies"
-			eqawarn "Set RUBY_FAKEGEM_GEMSPEC to generate a proper specifications file"
-			;;
-	esac
+	eqawarn "Generating generic fallback gemspec *without* dependencies"
+	eqawarn "This will only work when there are no runtime dependencies"
+	eqawarn "Set RUBY_FAKEGEM_GEMSPEC to generate a proper specifications file"
 
 	local required_paths="'lib'"
 	for path in ${RUBY_FAKEGEM_REQUIRE_PATHS}; do
@@ -434,7 +415,7 @@ EOF
 
 		exeinto ${binpath:-/usr/bin}
 		newexe "${T}"/gembin-wrapper-${gembinary} $(basename $newbinary)
-	) || die "Unable to create fakegem wrapper"
+	)
 }
 
 # @FUNCTION: each_fakegem_configure
@@ -701,3 +682,5 @@ all_ruby_install() {
 
 	all_fakegem_install
 }
+
+fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-08 15:32 David Seifert
  0 siblings, 0 replies; 6663+ messages in thread
From: David Seifert @ 2024-10-08 15:32 UTC (permalink / raw
  To: gentoo-commits
commit:     7663fbfcd9ca5a7261d8de4120490f95f732a774
Author:     David Seifert <soap <AT> gentoo <DOT> org>
AuthorDate: Tue Oct  8 15:31:27 2024 +0000
Commit:     David Seifert <soap <AT> gentoo <DOT> org>
CommitDate: Tue Oct  8 15:31:27 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=7663fbfc
preserve-libs.eclass: drop support for EAPI 5 and 6
Signed-off-by: David Seifert <soap <AT> gentoo.org>
 eclass/preserve-libs.eclass | 6 +-----
 1 file changed, 1 insertion(+), 5 deletions(-)
diff --git a/eclass/preserve-libs.eclass b/eclass/preserve-libs.eclass
index 38571447b945..e97e3f846a09 100644
--- a/eclass/preserve-libs.eclass
+++ b/eclass/preserve-libs.eclass
@@ -4,17 +4,13 @@
 # @ECLASS: preserve-libs.eclass
 # @MAINTAINER:
 # base-system@gentoo.org
-# @SUPPORTED_EAPIS: 5 6 7 8
+# @SUPPORTED_EAPIS: 7 8
 # @BLURB: preserve libraries after SONAME changes
 
 if [[ -z ${_PRESERVE_LIBS_ECLASS} ]]; then
 _PRESERVE_LIBS_ECLASS=1
 
 case ${EAPI} in
-	5|6)
-		ewarn "${CATEGORY}/${PF}: ebuild uses ${ECLASS} with deprecated EAPI ${EAPI}!"
-		ewarn "${CATEGORY}/${PF}: Support will be removed on 2024-10-08. Please port to newer EAPI."
-		;;
 	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-08 15:32 David Seifert
  0 siblings, 0 replies; 6663+ messages in thread
From: David Seifert @ 2024-10-08 15:32 UTC (permalink / raw
  To: gentoo-commits
commit:     408ab46afe18d455c3603bedb04610f52f5acc28
Author:     David Seifert <soap <AT> gentoo <DOT> org>
AuthorDate: Tue Oct  8 15:31:37 2024 +0000
Commit:     David Seifert <soap <AT> gentoo <DOT> org>
CommitDate: Tue Oct  8 15:31:37 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=408ab46a
toolchain-funcs.eclass: drop support for EAPI 6
Signed-off-by: David Seifert <soap <AT> gentoo.org>
 eclass/toolchain-funcs.eclass | 7 +------
 1 file changed, 1 insertion(+), 6 deletions(-)
diff --git a/eclass/toolchain-funcs.eclass b/eclass/toolchain-funcs.eclass
index 66819996ea33..478177de141e 100644
--- a/eclass/toolchain-funcs.eclass
+++ b/eclass/toolchain-funcs.eclass
@@ -4,7 +4,7 @@
 # @ECLASS: toolchain-funcs.eclass
 # @MAINTAINER:
 # Toolchain Ninjas <toolchain@gentoo.org>
-# @SUPPORTED_EAPIS: 6 7 8
+# @SUPPORTED_EAPIS: 7 8
 # @BLURB: functions to query common info about the toolchain
 # @DESCRIPTION:
 # The toolchain-funcs aims to provide a complete suite of functions
@@ -17,10 +17,6 @@ if [[ -z ${_TOOLCHAIN_FUNCS_ECLASS} ]]; then
 _TOOLCHAIN_FUNCS_ECLASS=1
 
 case ${EAPI} in
-	6)
-		ewarn "${CATEGORY}/${PF}: ebuild uses ${ECLASS} with deprecated EAPI ${EAPI}!"
-		ewarn "${CATEGORY}/${PF}: Support will be removed on 2024-10-08. Please port to newer EAPI."
-		;;
 	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
@@ -1117,7 +1113,6 @@ gen_usr_ldscript() {
 	ewarn "${FUNCNAME}: Please migrate to usr-ldscript.eclass"
 
 	local lib libdir=$(get_libdir) output_format="" auto=false suffix=$(get_libname)
-	[[ -z ${ED+set} ]] && local ED=${D%/}${EPREFIX}/
 
 	tc-is-static-only && return
 	use prefix && return
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-08 15:32 David Seifert
  0 siblings, 0 replies; 6663+ messages in thread
From: David Seifert @ 2024-10-08 15:32 UTC (permalink / raw
  To: gentoo-commits
commit:     8d9c83916b723374b5d5a6c9d4fd010a9be6f059
Author:     David Seifert <soap <AT> gentoo <DOT> org>
AuthorDate: Tue Oct  8 15:31:35 2024 +0000
Commit:     David Seifert <soap <AT> gentoo <DOT> org>
CommitDate: Tue Oct  8 15:31:35 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=8d9c8391
systemd.eclass: drop support for EAPI 5 and 6
Signed-off-by: David Seifert <soap <AT> gentoo.org>
 eclass/systemd.eclass | 66 ++++++---------------------------------------------
 1 file changed, 7 insertions(+), 59 deletions(-)
diff --git a/eclass/systemd.eclass b/eclass/systemd.eclass
index a5f0decde1e3..95fe64f4414f 100644
--- a/eclass/systemd.eclass
+++ b/eclass/systemd.eclass
@@ -4,7 +4,7 @@
 # @ECLASS: systemd.eclass
 # @MAINTAINER:
 # systemd@gentoo.org
-# @SUPPORTED_EAPIS: 5 6 7 8
+# @SUPPORTED_EAPIS: 7 8
 # @BLURB: helper functions to install systemd units
 # @DESCRIPTION:
 # This eclass provides a set of functions to install unit files for
@@ -24,22 +24,17 @@
 # }
 # @CODE
 
+if [[ -z ${_SYSTEMD_ECLASS} ]]; then
+_SYSTEMD_ECLASS=1
+
 case ${EAPI} in
-	6)
-		ewarn "${CATEGORY}/${PF}: ebuild uses ${ECLASS} with deprecated EAPI ${EAPI}!"
-		ewarn "${CATEGORY}/${PF}: Support will be removed on 2024-10-08. Please port to newer EAPI."
-		;;
 	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
 inherit toolchain-funcs
 
-if [[ ${EAPI} == [56] ]]; then
-	DEPEND="virtual/pkgconfig"
-else
-	BDEPEND="virtual/pkgconfig"
-fi
+BDEPEND="virtual/pkgconfig"
 
 # @FUNCTION: _systemd_get_dir
 # @USAGE: <variable-name> <fallback-directory>
@@ -85,15 +80,6 @@ systemd_get_systemunitdir() {
 	_systemd_get_dir systemdsystemunitdir /lib/systemd/system
 }
 
-# @FUNCTION: systemd_get_unitdir
-# @DESCRIPTION:
-# Deprecated alias for systemd_get_systemunitdir.
-systemd_get_unitdir() {
-	[[ ${EAPI} == 5 ]] || die "${FUNCNAME} is banned in EAPI 6, use systemd_get_systemunitdir instead"
-
-	systemd_get_systemunitdir
-}
-
 # @FUNCTION: systemd_get_userunitdir
 # @DESCRIPTION:
 # Output the path for the systemd user unit directory (not including
@@ -339,46 +325,6 @@ systemd_enable_ntpunit() {
 	return ${ret}
 }
 
-# @FUNCTION: systemd_with_unitdir
-# @USAGE: [<configure-option-name>]
-# @DESCRIPTION:
-# Note: deprecated and banned in EAPI 6. Please use full --with-...=
-# parameter for improved ebuild readability.
-#
-# Output '--with-systemdsystemunitdir' as expected by systemd-aware configure
-# scripts. This function always succeeds. Its output may be quoted in order
-# to preserve whitespace in paths. systemd_to_myeconfargs() is preferred over
-# this function.
-#
-# If upstream does use invalid configure option to handle installing systemd
-# units (e.g. `--with-systemdunitdir'), you can pass the 'suffix' as an optional
-# argument to this function (`$(systemd_with_unitdir systemdunitdir)'). Please
-# remember to report a bug upstream as well.
-systemd_with_unitdir() {
-	[[ ${EAPI} == 5 ]] || die "${FUNCNAME} is banned in EAPI ${EAPI}, use --with-${1:-systemdsystemunitdir}=\"\$(systemd_get_systemunitdir)\" instead"
-
-	debug-print-function ${FUNCNAME} "${@}"
-	local optname=${1:-systemdsystemunitdir}
-
-	echo --with-${optname}="$(systemd_get_systemunitdir)"
-}
-
-# @FUNCTION: systemd_with_utildir
-# @DESCRIPTION:
-# Note: deprecated and banned in EAPI 6. Please use full --with-...=
-# parameter for improved ebuild readability.
-#
-# Output '--with-systemdsystemutildir' as used by some packages to install
-# systemd helpers. This function always succeeds. Its output may be quoted
-# in order to preserve whitespace in paths.
-systemd_with_utildir() {
-	[[ ${EAPI} == 5 ]] || die "${FUNCNAME} is banned in EAPI ${EAPI}, use --with-systemdutildir=\"\$(systemd_get_utildir)\" instead"
-
-	debug-print-function ${FUNCNAME} "${@}"
-
-	echo --with-systemdutildir="$(systemd_get_utildir)"
-}
-
 # @FUNCTION: systemd_update_catalog
 # @DESCRIPTION:
 # Update the journald catalog. This needs to be called after installing
@@ -448,3 +394,5 @@ systemd_reenable() {
 		fi
 	done
 }
+
+fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-08 15:32 David Seifert
  0 siblings, 0 replies; 6663+ messages in thread
From: David Seifert @ 2024-10-08 15:32 UTC (permalink / raw
  To: gentoo-commits
commit:     078850f794af926ef62a403ff17fa0e7876e5992
Author:     David Seifert <soap <AT> gentoo <DOT> org>
AuthorDate: Tue Oct  8 15:31:43 2024 +0000
Commit:     David Seifert <soap <AT> gentoo <DOT> org>
CommitDate: Tue Oct  8 15:31:43 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=078850f7
vim-doc.eclass: drop support for EAPI 6
Signed-off-by: David Seifert <soap <AT> gentoo.org>
 eclass/vim-doc.eclass | 12 ++++--------
 1 file changed, 4 insertions(+), 8 deletions(-)
diff --git a/eclass/vim-doc.eclass b/eclass/vim-doc.eclass
index f20f7397cf65..e87310319c7d 100644
--- a/eclass/vim-doc.eclass
+++ b/eclass/vim-doc.eclass
@@ -4,7 +4,7 @@
 # @ECLASS: vim-doc.eclass
 # @MAINTAINER:
 # vim@gentoo.org
-# @SUPPORTED_EAPIS: 6 7 8
+# @SUPPORTED_EAPIS: 7 8
 # @BLURB: Eclass for vim{,-plugin}.eclass to update documentation tags.
 # @DESCRIPTION:
 # This eclass is used by vim.eclass and vim-plugin.eclass to update
@@ -16,13 +16,10 @@
 # DEPEND in vim-plugin or by whatever version of vim is being
 # installed by the eclass.
 
-if [[ ! ${_VIM_DOC_ECLASS} ]] ; then
+if [[ -z ${_VIM_DOC_ECLASS} ]]; then
+_VIM_DOC_ECLASS=1
 
 case ${EAPI} in
-	6)
-		ewarn "${CATEGORY}/${PF}: ebuild uses ${ECLASS} with deprecated EAPI ${EAPI}!"
-		ewarn "${CATEGORY}/${PF}: Support will be removed on 2024-10-08. Please port to newer EAPI."
-		;;
 	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
@@ -58,7 +55,7 @@ update_vim_helptags() {
 
 	# Install the documentation symlinks into the versioned vim
 	# directory and run :helptags
-	for d in "${EROOT%/}"/usr/share/vim/vim[0-9]*; do
+	for d in "${EROOT}"/usr/share/vim/vim[0-9]*; do
 		[[ -d "${d}/doc" ]] || continue	# catch a failed glob
 
 		# Remove links
@@ -104,5 +101,4 @@ update_vim_helptags() {
 	fi
 }
 
-_VIM_DOC_ECLASS=1
 fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-08 15:32 David Seifert
  0 siblings, 0 replies; 6663+ messages in thread
From: David Seifert @ 2024-10-08 15:32 UTC (permalink / raw
  To: gentoo-commits
commit:     6ff32128c05cd0f447bb2d77430695591370a8a6
Author:     David Seifert <soap <AT> gentoo <DOT> org>
AuthorDate: Tue Oct  8 15:31:36 2024 +0000
Commit:     David Seifert <soap <AT> gentoo <DOT> org>
CommitDate: Tue Oct  8 15:31:36 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=6ff32128
tmpfiles.eclass: drop support for EAPI 5 and 6
Signed-off-by: David Seifert <soap <AT> gentoo.org>
 eclass/tmpfiles.eclass | 8 ++------
 1 file changed, 2 insertions(+), 6 deletions(-)
diff --git a/eclass/tmpfiles.eclass b/eclass/tmpfiles.eclass
index 63889a275fef..aed792adad1c 100644
--- a/eclass/tmpfiles.eclass
+++ b/eclass/tmpfiles.eclass
@@ -8,7 +8,7 @@
 # @AUTHOR:
 # Mike Gilbert <floppym@gentoo.org>
 # William Hubbs <williamh@gentoo.org>
-# @SUPPORTED_EAPIS: 5 6 7 8
+# @SUPPORTED_EAPIS: 7 8
 # @BLURB: Functions related to tmpfiles.d files
 # @DESCRIPTION:
 # This eclass provides functionality related to installing and
@@ -32,7 +32,7 @@
 # Typical usage of this eclass:
 #
 # @CODE
-#	EAPI=6
+#	EAPI=8
 #	inherit tmpfiles
 #
 #	...
@@ -56,10 +56,6 @@ if [[ -z ${_TMPFILES_ECLASS} ]]; then
 _TMPFILES_ECLASS=1
 
 case ${EAPI} in
-	5|6)
-		ewarn "${CATEGORY}/${PF}: ebuild uses ${ECLASS} with deprecated EAPI ${EAPI}!"
-		ewarn "${CATEGORY}/${PF}: Support will be removed on 2024-10-08. Please port to newer EAPI."
-		;;
 	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-08 15:32 David Seifert
  0 siblings, 0 replies; 6663+ messages in thread
From: David Seifert @ 2024-10-08 15:32 UTC (permalink / raw
  To: gentoo-commits
commit:     b4b611d7b4d6fed49624e4fb14edf06c0a8df559
Author:     David Seifert <soap <AT> gentoo <DOT> org>
AuthorDate: Tue Oct  8 15:31:44 2024 +0000
Commit:     David Seifert <soap <AT> gentoo <DOT> org>
CommitDate: Tue Oct  8 15:31:44 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=b4b611d7
vim-plugin.eclass: drop support for EAPI 6
Signed-off-by: David Seifert <soap <AT> gentoo.org>
 eclass/vim-plugin.eclass | 12 ++++--------
 1 file changed, 4 insertions(+), 8 deletions(-)
diff --git a/eclass/vim-plugin.eclass b/eclass/vim-plugin.eclass
index b2ae0cb9e4c3..8c36f42ba277 100644
--- a/eclass/vim-plugin.eclass
+++ b/eclass/vim-plugin.eclass
@@ -4,7 +4,7 @@
 # @ECLASS: vim-plugin.eclass
 # @MAINTAINER:
 # vim@gentoo.org
-# @SUPPORTED_EAPIS: 6 7 8
+# @SUPPORTED_EAPIS: 7 8
 # @BLURB: used for installing vim plugins
 # @DESCRIPTION:
 # This eclass simplifies installation of app-vim plugins into
@@ -16,17 +16,13 @@ if [[ -z ${_VIM_PLUGIN_ECLASS} ]]; then
 _VIM_PLUGIN_ECLASS=1
 
 case ${EAPI} in
-	6)
-		ewarn "${CATEGORY}/${PF}: ebuild uses ${ECLASS} with deprecated EAPI ${EAPI}!"
-		ewarn "${CATEGORY}/${PF}: Support will be removed on 2024-10-08. Please port to newer EAPI."
-		;;
 	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
 inherit vim-doc
 
-[[ ${EAPI} != [67] ]] && _DEFINE_VIM_PLUGIN_SRC_PREPARE=true
+[[ ${EAPI} != 7 ]] && _DEFINE_VIM_PLUGIN_SRC_PREPARE=true
 
 # @ECLASS_VARIABLE: VIM_PLUGIN_VIM_VERSION
 # @DESCRIPTION:
@@ -102,8 +98,8 @@ vim-plugin_src_install() {
 	# Install remainder of plugin
 	insinto /usr/share/vim/vimfiles/
 	local d
-	case ${EAPI:-0} in
-		6|7)
+	case ${EAPI} in
+		7)
 			for d in *; do
 				[[ -d "${d}" ]] || continue
 				doins -r "${d}"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-08 15:32 David Seifert
  0 siblings, 0 replies; 6663+ messages in thread
From: David Seifert @ 2024-10-08 15:32 UTC (permalink / raw
  To: gentoo-commits
commit:     c7082538536c5fceab8d67da2365a938391c0d94
Author:     David Seifert <soap <AT> gentoo <DOT> org>
AuthorDate: Tue Oct  8 15:31:38 2024 +0000
Commit:     David Seifert <soap <AT> gentoo <DOT> org>
CommitDate: Tue Oct  8 15:31:38 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=c7082538
toolchain.eclass: drop support for EAPI 6
Signed-off-by: David Seifert <soap <AT> gentoo.org>
 eclass/toolchain.eclass | 8 ++++----
 1 file changed, 4 insertions(+), 4 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 34f595bcd1bc..6bad1def19f4 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -11,14 +11,14 @@
 # GNAT for Ada). If not building GCC itself, please use toolchain-funcs.eclass
 # instead.
 
+if [[ -z ${_TOOLCHAIN_ECLASS} ]]; then
+_TOOLCHAIN_ECLASS=1
+
 case ${EAPI} in
 	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
-if [[ -z ${_TOOLCHAIN_ECLASS} ]]; then
-_TOOLCHAIN_ECLASS=1
-
 DESCRIPTION="The GNU Compiler Collection"
 HOMEPAGE="https://gcc.gnu.org/"
 
@@ -2647,7 +2647,7 @@ fix_libtool_libdir_paths() {
 	pushd "${D}" >/dev/null || die
 
 	pushd "./${libpath}" >/dev/null || die
-	local dir="${PWD#${D%/}}"
+	local dir="${PWD#${D}}"
 	local allarchives=$(echo *.la)
 	allarchives="\(${allarchives// /\\|}\)"
 	popd >/dev/null || die
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-08 15:32 David Seifert
  0 siblings, 0 replies; 6663+ messages in thread
From: David Seifert @ 2024-10-08 15:32 UTC (permalink / raw
  To: gentoo-commits
commit:     b8697c15fc9eb4e81226455b242a8a22caff8620
Author:     David Seifert <soap <AT> gentoo <DOT> org>
AuthorDate: Tue Oct  8 15:31:39 2024 +0000
Commit:     David Seifert <soap <AT> gentoo <DOT> org>
CommitDate: Tue Oct  8 15:31:39 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=b8697c15
udev.eclass: drop support for EAPI 5 and 6
Signed-off-by: David Seifert <soap <AT> gentoo.org>
 eclass/udev.eclass | 14 +++-----------
 1 file changed, 3 insertions(+), 11 deletions(-)
diff --git a/eclass/udev.eclass b/eclass/udev.eclass
index 7fd99cbba8b0..2c3ef38a3626 100644
--- a/eclass/udev.eclass
+++ b/eclass/udev.eclass
@@ -4,7 +4,7 @@
 # @ECLASS: udev.eclass
 # @MAINTAINER:
 # systemd@gentoo.org
-# @SUPPORTED_EAPIS: 5 6 7 8
+# @SUPPORTED_EAPIS: 7 8
 # @BLURB: Default eclass for determining udev directories.
 # @DESCRIPTION:
 # Default eclass for determining udev directories.
@@ -40,21 +40,13 @@ if [[ -z ${_UDEV_ECLASS} ]]; then
 _UDEV_ECLASS=1
 
 case ${EAPI} in
-	6)
-		ewarn "${CATEGORY}/${PF}: ebuild uses ${ECLASS} with deprecated EAPI ${EAPI}!"
-		ewarn "${CATEGORY}/${PF}: Support will be removed on 2024-10-08. Please port to newer EAPI."
-		;;
 	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
 inherit toolchain-funcs
 
-if [[ ${EAPI} == [56] ]]; then
-	DEPEND="virtual/pkgconfig"
-else
-	BDEPEND="virtual/pkgconfig"
-fi
+BDEPEND="virtual/pkgconfig"
 
 # @FUNCTION: _udev_get_udevdir
 # @INTERNAL
@@ -126,7 +118,7 @@ udev_newrules() {
 # Should be called from pkg_postinst and pkg_postrm in packages which install
 # udev rules or hwdb data.
 udev_reload() {
-	if [[ -n ${ROOT%/} ]]; then
+	if [[ -n ${ROOT} ]]; then
 		return 0
 	fi
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-08 15:32 David Seifert
  0 siblings, 0 replies; 6663+ messages in thread
From: David Seifert @ 2024-10-08 15:32 UTC (permalink / raw
  To: gentoo-commits
commit:     cce64b79655fac9dbcf4111c89533fb13832fb23
Author:     David Seifert <soap <AT> gentoo <DOT> org>
AuthorDate: Tue Oct  8 15:31:42 2024 +0000
Commit:     David Seifert <soap <AT> gentoo <DOT> org>
CommitDate: Tue Oct  8 15:31:42 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=cce64b79
vdr-plugin-2.eclass: drop support for EAPI 6
Signed-off-by: David Seifert <soap <AT> gentoo.org>
 eclass/vdr-plugin-2.eclass | 22 ++++++++++------------
 1 file changed, 10 insertions(+), 12 deletions(-)
diff --git a/eclass/vdr-plugin-2.eclass b/eclass/vdr-plugin-2.eclass
index dc70ca7c5761..a00426fdad39 100644
--- a/eclass/vdr-plugin-2.eclass
+++ b/eclass/vdr-plugin-2.eclass
@@ -60,14 +60,14 @@
 # PO_SUBDIR="bla foo/bla"
 # @CODE
 
+if [[ -z ${_VDR_PLUGIN_2_ECLASS} ]]; then
+_VDR_PLUGIN_2_ECLASS=1
+
 case ${EAPI} in
 	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
-if [[ -z ${_VDR_PLUGIN_2_ECLASS} ]]; then
-_VDR_PLUGIN_2_ECLASS=1
-
 inherit flag-o-matic strip-linguas toolchain-funcs unpacker
 
 # Name of the plugin stripped from all vdrplugin-, vdr- and -cvs pre- and postfixes
@@ -112,14 +112,14 @@ vdr_create_plugindb_file() {
 #		EBUILD=${CATEGORY}/${PN}
 #		EBUILD_V=${PVR}
 #	EOT
-#	obsolet? fix me later...
+#	obsolete? fix me later...
 	{
 		echo "VDRPLUGIN_DB=1"
 		echo "CREATOR=ECLASS"
 		echo "EBUILD=${CATEGORY}/${PN}"
 		echo "EBUILD_V=${PVR}"
 		echo "PLUGINS=\"$@\""
-	} > "${D%/}/${DB_FILE}"
+	} > "${D}/${DB_FILE}" || die
 }
 
 # @FUNCTION: vdr_create_header_checksum_file
@@ -423,7 +423,7 @@ vdr-plugin-2_pkg_setup() {
 	if [[ -n "${VDR_LOCAL_PATCHES_DIR}" ]]; then
 		eerror "Using VDR_LOCAL_PATCHES_DIR is deprecated!"
 		eerror "Please move all your patches into"
-		eerror "${EROOT%/}/etc/portage/patches/${CATEGORY}/${P}"
+		eerror "${EROOT}/etc/portage/patches/${CATEGORY}/${P}"
 		eerror "and remove or unset the VDR_LOCAL_PATCHES_DIR variable."
 		die
 	fi
@@ -517,8 +517,7 @@ vdr-plugin-2_src_compile() {
 				LOCALEDIR="${TMP_LOCALE_DIR}" \
 				LOCDIR="${TMP_LOCALE_DIR}" \
 				LIBDIR="${S}" \
-				TMPDIR="${T}" \
-				|| die "emake all failed"
+				TMPDIR="${T}"
 			;;
 		esac
 
@@ -564,8 +563,7 @@ vdr-plugin-2_src_install() {
 		emake install \
 		${BUILD_PARAMS} \
 		TMPDIR="${T}" \
-		DESTDIR="${D%/}" \
-		|| die "emake install (makefile target) failed"
+		DESTDIR="${D}"
 	else
 		einfo "Notice: Plugin use still the old Makefile handling"
 		insinto "${VDR_PLUGIN_DIR}"
@@ -579,12 +577,12 @@ vdr-plugin-2_src_install() {
 		local linguas
 		for linguas in ${LINGUAS[*]}; do
 		insinto "${LOCDIR}"
-		cp -r --parents ${linguas}* "${D%/}"/${LOCDIR} \
+		cp -r --parents ${linguas}* "${D}"/${LOCDIR} \
 			|| die "could not copy linguas files"
 		done
 	fi
 
-	cd "${D%/}/usr/$(get_libdir)/vdr/plugins" \
+	cd "${D}/usr/$(get_libdir)/vdr/plugins" \
 		|| die "could not change to \$D/usr/libdir/vdr/plugins"
 
 	# create list of all created plugin libs
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-08 15:32 David Seifert
  0 siblings, 0 replies; 6663+ messages in thread
From: David Seifert @ 2024-10-08 15:32 UTC (permalink / raw
  To: gentoo-commits
commit:     49aff324fb4fe754e663f0979741c1139fb5ce42
Author:     David Seifert <soap <AT> gentoo <DOT> org>
AuthorDate: Tue Oct  8 15:31:41 2024 +0000
Commit:     David Seifert <soap <AT> gentoo <DOT> org>
CommitDate: Tue Oct  8 15:31:41 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=49aff324
vcs-clean.eclass: drop support for EAPI 5 and 6
Signed-off-by: David Seifert <soap <AT> gentoo.org>
 eclass/vcs-clean.eclass | 6 +-----
 1 file changed, 1 insertion(+), 5 deletions(-)
diff --git a/eclass/vcs-clean.eclass b/eclass/vcs-clean.eclass
index 719bdec17676..b9282facd83c 100644
--- a/eclass/vcs-clean.eclass
+++ b/eclass/vcs-clean.eclass
@@ -6,17 +6,13 @@
 # base-system@gentoo.org
 # @AUTHOR:
 # Benedikt Böhm <hollow@gentoo.org>
-# @SUPPORTED_EAPIS: 5 6 7 8
+# @SUPPORTED_EAPIS: 7 8
 # @BLURB: helper functions to remove VCS directories
 
 if [[ -z ${_VCS_CLEAN_ECLASS} ]] ; then
 _VCS_CLEAN_ECLASS=1
 
 case ${EAPI} in
-	5|6)
-		ewarn "${CATEGORY}/${PF}: ebuild uses ${ECLASS} with deprecated EAPI ${EAPI}!"
-		ewarn "${CATEGORY}/${PF}: Support will be removed on 2024-10-08. Please port to newer EAPI."
-		;;
 	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-08 15:32 David Seifert
  0 siblings, 0 replies; 6663+ messages in thread
From: David Seifert @ 2024-10-08 15:32 UTC (permalink / raw
  To: gentoo-commits
commit:     d5184aa89c525edc88ebf0df095c179dbab352fa
Author:     David Seifert <soap <AT> gentoo <DOT> org>
AuthorDate: Tue Oct  8 15:31:34 2024 +0000
Commit:     David Seifert <soap <AT> gentoo <DOT> org>
CommitDate: Tue Oct  8 15:31:34 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=d5184aa8
strip-linguas.eclass: drop support for EAPI 5 and 6
Signed-off-by: David Seifert <soap <AT> gentoo.org>
 eclass/strip-linguas.eclass | 6 +-----
 1 file changed, 1 insertion(+), 5 deletions(-)
diff --git a/eclass/strip-linguas.eclass b/eclass/strip-linguas.eclass
index b31f414c87c3..355bdcc6cd19 100644
--- a/eclass/strip-linguas.eclass
+++ b/eclass/strip-linguas.eclass
@@ -6,17 +6,13 @@
 # Ulrich Müller <ulm@gentoo.org>
 # @AUTHOR:
 # Mike Frysinger <vapier@gentoo.org>
-# @SUPPORTED_EAPIS: 5 6 7 8
+# @SUPPORTED_EAPIS: 7 8
 # @BLURB: convenience function for LINGUAS support
 
 if [[ -z ${_STRIP_LINGUAS_ECLASS} ]]; then
 _STRIP_LINGUAS_ECLASS=1
 
 case ${EAPI} in
-	5|6)
-		ewarn "${CATEGORY}/${PF}: ebuild uses ${ECLASS} with deprecated EAPI ${EAPI}!"
-		ewarn "${CATEGORY}/${PF}: Support will be removed on 2024-10-08. Please port to newer EAPI."
-		;;
 	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-08 15:32 David Seifert
  0 siblings, 0 replies; 6663+ messages in thread
From: David Seifert @ 2024-10-08 15:32 UTC (permalink / raw
  To: gentoo-commits
commit:     f31fea7ce7cbb25115c2371d4de35576d415665f
Author:     David Seifert <soap <AT> gentoo <DOT> org>
AuthorDate: Tue Oct  8 15:31:45 2024 +0000
Commit:     David Seifert <soap <AT> gentoo <DOT> org>
CommitDate: Tue Oct  8 15:31:45 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=f31fea7c
vim-spell.eclass: drop support for EAPI 6
Signed-off-by: David Seifert <soap <AT> gentoo.org>
 eclass/vim-spell.eclass | 6 +-----
 1 file changed, 1 insertion(+), 5 deletions(-)
diff --git a/eclass/vim-spell.eclass b/eclass/vim-spell.eclass
index 57bcb0dc8021..f9b496e5ffb0 100644
--- a/eclass/vim-spell.eclass
+++ b/eclass/vim-spell.eclass
@@ -6,7 +6,7 @@
 # Vim Maintainers <vim@gentoo.org>
 # @AUTHOR:
 # Ciaran McCreesh <ciaranm@gentoo.org>
-# @SUPPORTED_EAPIS: 6 7 8
+# @SUPPORTED_EAPIS: 7 8
 # @BLURB: Eclass for managing Vim spell files.
 # @DESCRIPTION:
 # How to make a vim spell file package using prebuilt spell lists
@@ -66,10 +66,6 @@ if [[ -z ${_VIM_SPELL_ECLASS} ]] ; then
 _VIM_SPELL_ECLASS=1
 
 case ${EAPI} in
-	6)
-		ewarn "${CATEGORY}/${PF}: ebuild uses ${ECLASS} with deprecated EAPI ${EAPI}!"
-		ewarn "${CATEGORY}/${PF}: Support will be removed on 2024-10-08. Please port to newer EAPI."
-		;;
 	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-08 15:32 David Seifert
  0 siblings, 0 replies; 6663+ messages in thread
From: David Seifert @ 2024-10-08 15:32 UTC (permalink / raw
  To: gentoo-commits
commit:     ca471955da9c82ea8565147bbe5cc1740248b00c
Author:     David Seifert <soap <AT> gentoo <DOT> org>
AuthorDate: Tue Oct  8 15:31:48 2024 +0000
Commit:     David Seifert <soap <AT> gentoo <DOT> org>
CommitDate: Tue Oct  8 15:31:48 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=ca471955
wrapper.eclass: drop support for EAPI 5 and 6
Signed-off-by: David Seifert <soap <AT> gentoo.org>
 eclass/wrapper.eclass | 8 ++------
 1 file changed, 2 insertions(+), 6 deletions(-)
diff --git a/eclass/wrapper.eclass b/eclass/wrapper.eclass
index a62bb51d0fe7..1f995a60509f 100644
--- a/eclass/wrapper.eclass
+++ b/eclass/wrapper.eclass
@@ -4,17 +4,13 @@
 # @ECLASS: wrapper.eclass
 # @MAINTAINER:
 # base-system@gentoo.org
-# @SUPPORTED_EAPIS: 5 6 7 8
+# @SUPPORTED_EAPIS: 7 8
 # @BLURB: create a shell wrapper script
 
 if [[ -z ${_WRAPPER_ECLASS} ]]; then
 _WRAPPER_ECLASS=1
 
 case ${EAPI} in
-	5|6)
-		ewarn "${CATEGORY}/${PF}: ebuild uses ${ECLASS} with deprecated EAPI ${EAPI}!"
-		ewarn "${CATEGORY}/${PF}: Support will be removed on 2024-10-08. Please port to newer EAPI."
-		;;
 	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
@@ -59,7 +55,7 @@ make_wrapper() {
 		exeopts -m 0755
 		exeinto "${path}"
 		newexe "${tmpwrapper}" "${wrapper}"
-		) || die
+		)
 	else
 		newbin "${tmpwrapper}" "${wrapper}"
 	fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-08 15:32 David Seifert
  0 siblings, 0 replies; 6663+ messages in thread
From: David Seifert @ 2024-10-08 15:32 UTC (permalink / raw
  To: gentoo-commits
commit:     7c49ad54814c04d0c96195c6ff4ad467d4ea2d4f
Author:     David Seifert <soap <AT> gentoo <DOT> org>
AuthorDate: Tue Oct  8 15:31:50 2024 +0000
Commit:     David Seifert <soap <AT> gentoo <DOT> org>
CommitDate: Tue Oct  8 15:31:50 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=7c49ad54
xdg.eclass: drop support for EAPI 6
Signed-off-by: David Seifert <soap <AT> gentoo.org>
 eclass/xdg.eclass | 8 ++------
 1 file changed, 2 insertions(+), 6 deletions(-)
diff --git a/eclass/xdg.eclass b/eclass/xdg.eclass
index 2e16a438d840..042db2b8682d 100644
--- a/eclass/xdg.eclass
+++ b/eclass/xdg.eclass
@@ -6,7 +6,7 @@
 # freedesktop-bugs@gentoo.org
 # @AUTHOR:
 # Original author: Gilles Dartiguelongue <eva@gentoo.org>
-# @SUPPORTED_EAPIS: 6 7 8
+# @SUPPORTED_EAPIS: 7 8
 # @PROVIDES: xdg-utils
 # @BLURB: Provides phases for XDG compliant packages.
 # @DESCRIPTION:
@@ -17,10 +17,6 @@ if [[ -z ${_XDG_ECLASS} ]]; then
 _XDG_ECLASS=1
 
 case ${EAPI} in
-	6)
-		ewarn "${CATEGORY}/${PF}: ebuild uses ${ECLASS} with deprecated EAPI ${EAPI}!"
-		ewarn "${CATEGORY}/${PF}: Support will be removed on 2024-10-08. Please port to newer EAPI."
-		;;
 	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
@@ -34,7 +30,7 @@ inherit xdg-utils
 "
 
 case ${EAPI} in
-	6|7)
+	7)
 		# src_prepare is only exported in EAPI < 8.
 		# @FUNCTION: xdg_src_prepare
 		# @DESCRIPTION:
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-08 15:32 David Seifert
  0 siblings, 0 replies; 6663+ messages in thread
From: David Seifert @ 2024-10-08 15:32 UTC (permalink / raw
  To: gentoo-commits
commit:     bee4e0ad3c31520f2a9566536ff780197e252a57
Author:     David Seifert <soap <AT> gentoo <DOT> org>
AuthorDate: Tue Oct  8 15:31:46 2024 +0000
Commit:     David Seifert <soap <AT> gentoo <DOT> org>
CommitDate: Tue Oct  8 15:31:46 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=bee4e0ad
virtualx.eclass: drop support for EAPI 6
Signed-off-by: David Seifert <soap <AT> gentoo.org>
 eclass/virtualx.eclass | 14 ++++----------
 1 file changed, 4 insertions(+), 10 deletions(-)
diff --git a/eclass/virtualx.eclass b/eclass/virtualx.eclass
index 07d303899582..850e5c5b0892 100644
--- a/eclass/virtualx.eclass
+++ b/eclass/virtualx.eclass
@@ -6,17 +6,13 @@
 # x11@gentoo.org
 # @AUTHOR:
 # Original author: Martin Schlemmer <azarah@gentoo.org>
-# @SUPPORTED_EAPIS: 6 7 8
+# @SUPPORTED_EAPIS: 7 8
 # @BLURB: This eclass can be used for packages that need a working X environment to build.
 
 if [[ -z ${_VIRTUALX_ECLASS} ]]; then
 _VIRTUALX_ECLASS=1
 
 case ${EAPI} in
-	6)
-		ewarn "${CATEGORY}/${PF}: ebuild uses ${ECLASS} with deprecated EAPI ${EAPI}!"
-		ewarn "${CATEGORY}/${PF}: Support will be removed on 2024-10-08. Please port to newer EAPI."
-		;;
 	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
@@ -36,15 +32,15 @@ esac
 # @OUTPUT_VARIABLE
 # @DESCRIPTION:
 # Standard dependencies string that is automatically added to BDEPEND
-# (in EAPI-6: DEPEND) unless VIRTUALX_REQUIRED is set to "manual".
+# unless VIRTUALX_REQUIRED is set to "manual".
 # DEPRECATED: Pre-EAPI-8 you can specify the variable BEFORE inherit
 # to add more dependencies.
-[[ ${EAPI} != [67] ]] && VIRTUALX_DEPEND=""
+[[ ${EAPI} != 7 ]] && VIRTUALX_DEPEND=""
 VIRTUALX_DEPEND+="
 	x11-base/xorg-server[xvfb]
 	x11-apps/xhost
 "
-[[ ${EAPI} != [67] ]] && readonly VIRTUALX_DEPEND
+[[ ${EAPI} != 7 ]] && readonly VIRTUALX_DEPEND
 
 [[ ${VIRTUALX_COMMAND} ]] && die "VIRTUALX_COMMAND has been removed and is a no-op"
 
@@ -62,8 +58,6 @@ case ${VIRTUALX_REQUIRED} in
 		;;
 esac
 
-[[ ${EAPI} == 6 ]] && DEPEND="${BDEPEND}"
-
 
 # @FUNCTION: virtx
 # @USAGE: <command> [command arguments]
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-08 15:32 David Seifert
  0 siblings, 0 replies; 6663+ messages in thread
From: David Seifert @ 2024-10-08 15:32 UTC (permalink / raw
  To: gentoo-commits
commit:     c8af7eb1285a2683460618b71e2e9a14ca6badcd
Author:     David Seifert <soap <AT> gentoo <DOT> org>
AuthorDate: Tue Oct  8 15:31:52 2024 +0000
Commit:     David Seifert <soap <AT> gentoo <DOT> org>
CommitDate: Tue Oct  8 15:31:52 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=c8af7eb1
eclass: canonicalize debug-print-function calls
Closes: https://github.com/gentoo/gentoo/pull/37652
Signed-off-by: David Seifert <soap <AT> gentoo.org>
 eclass/acct-group.eclass          |  6 ++--
 eclass/acct-user.eclass           | 12 ++++----
 eclass/ada.eclass                 | 10 +++----
 eclass/apache-module.eclass       | 12 ++++----
 eclass/app-alternatives.eclass    |  4 +--
 eclass/bash-completion-r1.eclass  | 16 +++++------
 eclass/depend.apache.eclass       | 28 +++++++++----------
 eclass/dist-kernel-utils.eclass   | 10 +++----
 eclass/distutils-r1.eclass        | 52 +++++++++++++++++------------------
 eclass/dotnet-pkg-base.eclass     | 30 ++++++++++----------
 eclass/dotnet-pkg.eclass          |  4 +--
 eclass/dune.eclass                | 10 +++----
 eclass/fortran-2.eclass           | 14 +++++-----
 eclass/go-module.eclass           |  8 +++---
 eclass/greadme.eclass             | 10 +++----
 eclass/guile-single.eclass        | 10 +++----
 eclass/guile-utils.eclass         | 16 +++++------
 eclass/guile.eclass               | 28 +++++++++----------
 eclass/java-utils-2.eclass        |  2 +-
 eclass/kernel-build.eclass        | 10 +++----
 eclass/kernel-install.eclass      | 26 +++++++++---------
 eclass/latex-package.eclass       | 14 +++++-----
 eclass/linux-mod-r1.eclass        | 14 +++++-----
 eclass/llvm-r1.eclass             |  8 +++---
 eclass/llvm-utils.eclass          |  8 +++---
 eclass/llvm.eclass                |  6 ++--
 eclass/lua-single.eclass          | 12 ++++----
 eclass/lua-utils.eclass           | 20 +++++++-------
 eclass/lua.eclass                 |  8 +++---
 eclass/mercurial.eclass           |  4 +--
 eclass/multibuild.eclass          |  8 +++---
 eclass/nuget.eclass               |  2 +-
 eclass/out-of-source-utils.eclass |  2 +-
 eclass/postgres-multi.eclass      |  2 +-
 eclass/postgres.eclass            |  2 +-
 eclass/python-any-r1.eclass       |  6 ++--
 eclass/python-r1.eclass           | 22 +++++++--------
 eclass/python-single-r1.eclass    | 10 +++----
 eclass/python-utils-r1.eclass     | 58 +++++++++++++++++++--------------------
 eclass/readme.gentoo-r1.eclass    |  4 +--
 eclass/rebar-utils.eclass         |  8 +++---
 eclass/rebar.eclass               | 12 ++++----
 eclass/rebar3.eclass              | 14 +++++-----
 eclass/ruby-fakegem.eclass        | 44 ++++++++++++++---------------
 eclass/ruby-ng-gnome2.eclass      | 10 +++----
 eclass/ruby-ng.eclass             | 54 ++++++++++++++++++------------------
 eclass/scons-utils.eclass         |  2 +-
 eclass/secureboot.eclass          |  8 +++---
 eclass/shell-completion.eclass    | 12 ++++----
 eclass/systemd.eclass             | 32 ++++++++++-----------
 eclass/tmpfiles.eclass            |  6 ++--
 eclass/tree-sitter-grammar.eclass | 10 +++----
 eclass/udev.eclass                |  8 +++---
 eclass/vcs-clean.eclass           |  6 ++--
 eclass/vcs-snapshot.eclass        |  2 +-
 eclass/vim-doc.eclass             |  2 +-
 eclass/vim-plugin.eclass          | 12 ++++----
 eclass/webapp.eclass              | 34 +++++++++++------------
 58 files changed, 402 insertions(+), 402 deletions(-)
diff --git a/eclass/acct-group.eclass b/eclass/acct-group.eclass
index 00908dbd8982..ac6dc960ca24 100644
--- a/eclass/acct-group.eclass
+++ b/eclass/acct-group.eclass
@@ -89,7 +89,7 @@ S=${WORKDIR}
 # Performs sanity checks for correct eclass usage, and early-checks
 # whether requested GID can be enforced.
 acct-group_pkg_pretend() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	# verify ACCT_GROUP_ID
 	[[ -n ${ACCT_GROUP_ID} ]] || die "Ebuild error: ACCT_GROUP_ID must be set!"
@@ -131,7 +131,7 @@ acct-group_pkg_pretend() {
 # @DESCRIPTION:
 # Installs sysusers.d file for the group.
 acct-group_src_install() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	# check for the override, use PN in case this is an overlay and
 	# ACCT_GROUP_NAME is not PN and not valid in a bash variable name
@@ -156,7 +156,7 @@ acct-group_src_install() {
 # @DESCRIPTION:
 # Creates the group if it does not exist yet.
 acct-group_pkg_preinst() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	if [[ ${EUID} -ne 0 || -n ${EPREFIX} ]]; then
 		einfo "Insufficient privileges to execute ${FUNCNAME[0]}"
diff --git a/eclass/acct-user.eclass b/eclass/acct-user.eclass
index 19c5239eaede..b3bcff7e550c 100644
--- a/eclass/acct-user.eclass
+++ b/eclass/acct-user.eclass
@@ -155,7 +155,7 @@ S=${WORKDIR}
 # Generate appropriate RDEPEND from ACCT_USER_GROUPS.  This must be
 # called if ACCT_USER_GROUPS are set.
 acct-user_add_deps() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	# ACCT_USER_GROUPS sanity check
 	if [[ $(declare -p ACCT_USER_GROUPS) != "declare -a"* ]]; then
@@ -218,7 +218,7 @@ eislocked() {
 # Performs sanity checks for correct eclass usage, and early-checks
 # whether requested UID can be enforced.
 acct-user_pkg_pretend() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	# verify that acct-user_add_deps() has been called
 	# (it verifies ACCT_USER_GROUPS itself)
@@ -267,7 +267,7 @@ acct-user_pkg_pretend() {
 # Installs a keep-file into the user's home directory to ensure it is
 # owned by the package, and sysusers.d file.
 acct-user_src_install() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	# Replace reserved characters in comment
 	: "${ACCT_USER_COMMENT:=${DESCRIPTION//[:,=]/;}}"
@@ -328,7 +328,7 @@ acct-user_src_install() {
 # Creates the user if it does not exist yet.  Sets permissions
 # of the home directory in install image.
 acct-user_pkg_preinst() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	unset _ACCT_USER_ADDED
 
@@ -397,7 +397,7 @@ acct-user_pkg_preinst() {
 # Updates user properties if necessary.  This needs to be done after
 # new home directory is installed.
 acct-user_pkg_postinst() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	if [[ -n ${_ACCT_USER_ADDED} ]]; then
 		# We just added the user; no need to update it
@@ -481,7 +481,7 @@ acct-user_pkg_postinst() {
 # @DESCRIPTION:
 # Ensures that the user account is locked out when it is removed.
 acct-user_pkg_prerm() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	if [[ -n ${REPLACED_BY_VERSION} ]]; then
 		return
diff --git a/eclass/ada.eclass b/eclass/ada.eclass
index faff19a6ac85..9206bfcc42ca 100644
--- a/eclass/ada.eclass
+++ b/eclass/ada.eclass
@@ -110,7 +110,7 @@ readonly _ADA_ALL_IMPLS
 # unsupported, returns 1 -- and the caller should ignore the entry.
 # If it is invalid, dies with an appropriate error message.
 _ada_impl_supported() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	[[ ${#} -eq 1 ]] || die "${FUNCNAME}: takes exactly 1 argument (impl)."
 
@@ -208,7 +208,7 @@ _ada_set_impls() {
 # They are described more completely in the eclass
 # variable documentation.
 ada_export() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local impl var
 
@@ -404,7 +404,7 @@ unset -f _ada_single_set_globals
 # setup will be done. If wrapper update is requested, the directory
 # shall be removed first.
 ada_wrapper_setup() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local workdir=${1:-${T}/${EADA}}
 	local impl=${2:-${EADA}}
@@ -470,7 +470,7 @@ ada_wrapper_setup() {
 # Determine what the selected Ada implementation is and set
 # the Ada build environment up for it.
 ada_setup() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	unset EADA
 
@@ -518,7 +518,7 @@ ada_setup() {
 # @DESCRIPTION:
 # Runs ada_setup.
 ada_pkg_setup() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	[[ ${MERGE_TYPE} != binary ]] && ada_setup
 }
diff --git a/eclass/apache-module.eclass b/eclass/apache-module.eclass
index f7776f463546..880205a30539 100644
--- a/eclass/apache-module.eclass
+++ b/eclass/apache-module.eclass
@@ -105,7 +105,7 @@ inherit depend.apache
 
 # Internal function to construct the default ${APXS2_S} path if required.
 apache_cd_dir() {
-	debug-print-function $FUNCNAME $*
+	debug-print-function ${FUNCNAME} "$@"
 
 	local CD_DIR="${APXS2_S}"
 
@@ -123,7 +123,7 @@ apache_cd_dir() {
 
 # Internal function to construct the default ${APACHE2_MOD_FILE} if required.
 apache_mod_file() {
-	debug-print-function $FUNCNAME $*
+	debug-print-function ${FUNCNAME} "$@"
 
 	local MOD_FILE="${APACHE2_MOD_FILE:-$(apache_cd_dir)/.libs/${PN}.so}"
 
@@ -135,7 +135,7 @@ apache_mod_file() {
 # optional first argument `html'; if the first argument is equals `html', only
 # html files are returned, otherwise normal (non-html) docs are returned.
 apache_doc_magic() {
-	debug-print-function $FUNCNAME $*
+	debug-print-function ${FUNCNAME} "$@"
 
 	local DOCS=
 
@@ -161,7 +161,7 @@ apache_doc_magic() {
 # module requires a different build setup than this, use ${APXS} in your own
 # src_compile routine.
 apache-module_src_compile() {
-	debug-print-function $FUNCNAME $*
+	debug-print-function ${FUNCNAME} "$@"
 
 	local CD_DIR=$(apache_cd_dir)
 	cd "${CD_DIR}" || die "cd ${CD_DIR} failed"
@@ -180,7 +180,7 @@ apache-module_src_compile() {
 # 55_mod_foo.conf, APACHE2_MOD_CONF would be 55_mod_foo. ${DOCFILES} contains
 # the list of files you want filed as documentation.
 apache-module_src_install() {
-	debug-print-function $FUNCNAME $*
+	debug-print-function ${FUNCNAME} "$@"
 
 	local CD_DIR=$(apache_cd_dir)
 	pushd "${CD_DIR}" >/dev/null || die "cd ${CD_DIR} failed"
@@ -222,7 +222,7 @@ apache-module_src_install() {
 # @DESCRIPTION:
 # This prints out information about the installed module and how to enable it.
 apache-module_pkg_postinst() {
-	debug-print-function $FUNCNAME $*
+	debug-print-function ${FUNCNAME} "$@"
 
 	if [[ -n "${APACHE2_MOD_DEFINE}" ]] ; then
 		local my_opts="-D ${APACHE2_MOD_DEFINE// / -D }"
diff --git a/eclass/app-alternatives.eclass b/eclass/app-alternatives.eclass
index f670b7d843f9..32afedba1e68 100644
--- a/eclass/app-alternatives.eclass
+++ b/eclass/app-alternatives.eclass
@@ -36,7 +36,7 @@ _APP_ALTERNATIVES_ECLASS=1
 # @DESCRIPTION:
 # Set ebuild metadata variables.
 _app-alternatives_set_globals() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	if [[ ${ALTERNATIVES@a} != *a* ]]; then
 		die 'ALTERNATIVES must be an array.'
@@ -71,7 +71,7 @@ _app-alternatives_set_globals
 # @DESCRIPTION:
 # Get the flag name for the selected alternative (i.e. the USE flag set).
 get_alternative() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local flag
 	for flag in "${ALTERNATIVES[@]%%:*}"; do
diff --git a/eclass/bash-completion-r1.eclass b/eclass/bash-completion-r1.eclass
index 643c458dd8a0..2220cb2be508 100644
--- a/eclass/bash-completion-r1.eclass
+++ b/eclass/bash-completion-r1.eclass
@@ -41,7 +41,7 @@ esac
 # @EXAMPLE:
 # _bash-completion-r1_get_bashdir completionsdir /usr/share/bash-completion
 _bash-completion-r1_get_bashdir() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	if $(tc-getPKG_CONFIG) --exists bash-completion &>/dev/null; then
 		local path
@@ -59,7 +59,7 @@ _bash-completion-r1_get_bashdir() {
 # @DESCRIPTION:
 # Get unprefixed bash-completion completions directory.
 _bash-completion-r1_get_bashcompdir() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	_bash-completion-r1_get_bashdir completionsdir /usr/share/bash-completion/completions
 }
@@ -69,7 +69,7 @@ _bash-completion-r1_get_bashcompdir() {
 # @DESCRIPTION:
 # Get unprefixed bash-completion helpers directory.
 _bash-completion-r1_get_bashhelpersdir() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	_bash-completion-r1_get_bashdir helpersdir /usr/share/bash-completion/helpers
 }
@@ -78,7 +78,7 @@ _bash-completion-r1_get_bashhelpersdir() {
 # @DESCRIPTION:
 # Get the bash-completion completions directory.
 get_bashcompdir() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	echo "${EPREFIX}$(_bash-completion-r1_get_bashcompdir)"
 }
@@ -88,7 +88,7 @@ get_bashcompdir() {
 # @DESCRIPTION:
 # Get the bash-completion helpers directory.
 get_bashhelpersdir() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	echo "${EPREFIX}$(_bash-completion-r1_get_bashhelpersdir)"
 }
@@ -99,7 +99,7 @@ get_bashhelpersdir() {
 # Install bash-completion files passed as args. Has EAPI-dependent failure
 # behavior (like doins).
 dobashcomp() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	(
 		insopts -m 0644
@@ -114,7 +114,7 @@ dobashcomp() {
 # Install bash-completion file under a new name. Has EAPI-dependent failure
 # behavior (like newins).
 newbashcomp() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	(
 		insopts -m 0644
@@ -128,7 +128,7 @@ newbashcomp() {
 # @DESCRIPTION:
 # Alias <basename> completion to one or more commands (<alias>es).
 bashcomp_alias() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	[[ ${#} -lt 2 ]] && die "Usage: ${FUNCNAME} <basename> <alias>..."
 	local base=${1} f
diff --git a/eclass/depend.apache.eclass b/eclass/depend.apache.eclass
index 7492a78209e7..e1818be28af3 100644
--- a/eclass/depend.apache.eclass
+++ b/eclass/depend.apache.eclass
@@ -123,7 +123,7 @@ APACHE2_4_DEPEND="=www-servers/apache-2.4*"
 # ==============================================================================
 
 _init_apache2() {
-	debug-print-function $FUNCNAME $*
+	debug-print-function ${FUNCNAME} "$@"
 
 	# WARNING: Do not use these variables with anything that is put
 	# into the dependency cache (DEPEND/RDEPEND/etc)
@@ -143,7 +143,7 @@ _init_apache2_late() {
 }
 
 _init_no_apache() {
-	debug-print-function $FUNCNAME $*
+	debug-print-function ${FUNCNAME} "$@"
 	APACHE_VERSION="0"
 }
 
@@ -158,7 +158,7 @@ _init_no_apache() {
 # apache-2.x support. If the myiuse parameter is not given it defaults to
 # apache2.
 depend.apache_pkg_setup() {
-	debug-print-function $FUNCNAME $*
+	debug-print-function ${FUNCNAME} "$@"
 
 	if [[ "${EBUILD_PHASE}" != "setup" ]]; then
 		die "$FUNCNAME() should be called in pkg_setup()"
@@ -184,7 +184,7 @@ depend.apache_pkg_setup() {
 # An ebuild should additionally call depend.apache_pkg_setup() in pkg_setup()
 # with the same myiuse parameter.
 want_apache() {
-	debug-print-function $FUNCNAME $*
+	debug-print-function ${FUNCNAME} "$@"
 	want_apache2 "$@"
 }
 
@@ -196,7 +196,7 @@ want_apache() {
 # An ebuild should additionally call depend.apache_pkg_setup() in pkg_setup()
 # with the same myiuse parameter.
 want_apache2() {
-	debug-print-function $FUNCNAME $*
+	debug-print-function ${FUNCNAME} "$@"
 
 	local myiuse=${1:-apache2}
 	IUSE="${IUSE} ${myiuse}"
@@ -213,7 +213,7 @@ want_apache2() {
 # An ebuild should additionally call depend.apache_pkg_setup() in pkg_setup()
 # with the same myiuse parameter.
 want_apache2_2() {
-	debug-print-function $FUNCNAME $*
+	debug-print-function ${FUNCNAME} "$@"
 
 	case ${EAPI} in
 		7)
@@ -237,7 +237,7 @@ want_apache2_2() {
 # An ebuild should additionally call depend.apache_pkg_setup() in pkg_setup()
 # with the same myiuse parameter.
 want_apache2_4() {
-	debug-print-function $FUNCNAME $*
+	debug-print-function ${FUNCNAME} "$@"
 
 	local myiuse=${1:-apache2}
 	IUSE="${IUSE} ${myiuse}"
@@ -249,7 +249,7 @@ want_apache2_4() {
 # @DESCRIPTION:
 # An ebuild calls this to get the dependency information for apache.
 need_apache() {
-	debug-print-function $FUNCNAME $*
+	debug-print-function ${FUNCNAME} "$@"
 	need_apache2
 }
 
@@ -257,7 +257,7 @@ need_apache() {
 # @DESCRIPTION:
 # An ebuild calls this to get the dependency information for apache-2.x.
 need_apache2() {
-	debug-print-function $FUNCNAME $*
+	debug-print-function ${FUNCNAME} "$@"
 
 	DEPEND="${DEPEND} ${APACHE2_DEPEND}"
 	RDEPEND="${RDEPEND} ${APACHE2_DEPEND}"
@@ -268,7 +268,7 @@ need_apache2() {
 # @DESCRIPTION:
 # An ebuild calls this to get the dependency information for apache-2.2.x.
 need_apache2_2() {
-	debug-print-function $FUNCNAME $*
+	debug-print-function ${FUNCNAME} "$@"
 
 	case ${EAPI} in
 		7)
@@ -286,7 +286,7 @@ need_apache2_2() {
 # @DESCRIPTION:
 # An ebuild calls this to get the dependency information for apache-2.4.x.
 need_apache2_4() {
-        debug-print-function $FUNCNAME $*
+        debug-print-function ${FUNCNAME} "$@"
 
         DEPEND="${DEPEND} ${APACHE2_4_DEPEND}"
         RDEPEND="${RDEPEND} ${APACHE2_4_DEPEND}"
@@ -299,7 +299,7 @@ need_apache2_4() {
 # dependency without USE-flag, in which case want_apache does not work.
 # DO NOT call this function in global scope.
 has_apache() {
-	debug-print-function $FUNCNAME $*
+	debug-print-function ${FUNCNAME} "$@"
 
 	if has_version '>=www-servers/apache-2'; then
 		_init_apache2
@@ -315,7 +315,7 @@ has_apache() {
 # built with a threaded MPM. If the myflag parameter is not given it defaults to
 # threads.
 has_apache_threads() {
-	debug-print-function $FUNCNAME $*
+	debug-print-function ${FUNCNAME} "$@"
 
 	if ! has_version 'www-servers/apache[threads]'; then
 		return
@@ -338,7 +338,7 @@ has_apache_threads() {
 # package if apache has been built with a threaded MPM. If the myflag parameter
 # is not given it defaults to threads.
 has_apache_threads_in() {
-	debug-print-function $FUNCNAME $*
+	debug-print-function ${FUNCNAME} "$@"
 
 	if ! has_version 'www-servers/apache[threads]'; then
 		return
diff --git a/eclass/dist-kernel-utils.eclass b/eclass/dist-kernel-utils.eclass
index bb058d488a13..67ba459f0ebe 100644
--- a/eclass/dist-kernel-utils.eclass
+++ b/eclass/dist-kernel-utils.eclass
@@ -72,7 +72,7 @@ dist-kernel_get_image_path() {
 # the kernel version, <image> full path to the image, <system.map>
 # full path to System.map.
 dist-kernel_install_kernel() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	[[ ${#} -eq 3 ]] || die "${FUNCNAME}: invalid arguments"
 	local version=${1}
@@ -125,7 +125,7 @@ dist-kernel_install_kernel() {
 # This function is to be used in pkg_postinst() of ebuilds installing
 # kernel modules that are included in the initramfs.
 dist-kernel_reinstall_initramfs() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	[[ ${#} -eq 2 ]] || die "${FUNCNAME}: invalid arguments"
 	local kernel_dir=${1}
@@ -148,7 +148,7 @@ dist-kernel_reinstall_initramfs() {
 # @DESCRIPTION:
 # Convert a Gentoo-style ebuild version to kernel "x.y.z[-rcN]" version.
 dist-kernel_PV_to_KV() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	[[ ${#} -ne 1 ]] && die "${FUNCNAME}: invalid arguments"
 	local pv=${1}
@@ -165,7 +165,7 @@ dist-kernel_PV_to_KV() {
 # Returns the suffix for kernel modules based on the CONFIG_MODULES_COMPESS_*
 # setting in the kernel config and USE=modules-compress.
 dist-kernel_get_module_suffix() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	[[ ${#} -eq 1 ]] || die "${FUNCNAME}: invalid arguments"
 
@@ -194,7 +194,7 @@ dist-kernel_get_module_suffix() {
 # Traverse path for duplicate (un)compressed modules and remove all
 # but the newest variant.
 dist-kernel_compressed_module_cleanup() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	[[ ${#} -ne 1 ]] && die "${FUNCNAME}: invalid arguments"
 	local path=${1}
diff --git a/eclass/distutils-r1.eclass b/eclass/distutils-r1.eclass
index d2549c97ff3b..c3a7d112b03f 100644
--- a/eclass/distutils-r1.eclass
+++ b/eclass/distutils-r1.eclass
@@ -493,7 +493,7 @@ unset -f _distutils_set_globals
 # python_compile_all(), you can call the original implementation
 # as sphinx_compile_all.
 distutils_enable_sphinx() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 	[[ ${#} -ge 1 ]] || die "${FUNCNAME} takes at least one arg: <subdir>"
 
 	_DISTUTILS_SPHINX_SUBDIR=${1}
@@ -589,7 +589,7 @@ distutils_enable_sphinx() {
 # This function must be called in global scope, after RDEPEND has been
 # declared.  Take care not to overwrite the variables set by it.
 distutils_enable_tests() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	case ${1} in
 		--install)
@@ -670,7 +670,7 @@ distutils_enable_tests() {
 #
 # This command dies on failure.
 esetup.py() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	_python_check_EPYTHON
 
@@ -729,7 +729,7 @@ distutils_install_for_testing() {
 # This function must only be used in python_test().  The created file
 # will automatically be removed upon leaving the test phase.
 distutils_write_namespace() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	if [[ ! ${DISTUTILS_USE_PEP517:-no} != no ]]; then
 		die "${FUNCNAME} is available only in PEP517 mode"
@@ -935,7 +935,7 @@ _distutils-r1_print_package_versions() {
 # At some point in the future, it may also apply eclass-specific
 # distutils patches and/or quirks.
 distutils-r1_python_prepare_all() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 	_python_sanity_checks
 	_distutils-r1_check_all_phase_mismatch
 
@@ -1057,7 +1057,7 @@ _distutils-r1_copy_egg_info() {
 # Print the DISTUTILS_USE_PEP517 value corresponding to the backend
 # passed as the only argument.
 _distutils-r1_backend_to_key() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local backend=${1}
 	case ${backend} in
@@ -1109,7 +1109,7 @@ _distutils-r1_backend_to_key() {
 # Read (or guess, in case of setuptools) the build-backend
 # for the package in the current directory.
 _distutils-r1_get_backend() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local build_backend legacy_fallback
 	if [[ -f pyproject.toml ]]; then
@@ -1179,7 +1179,7 @@ _distutils-r1_get_backend() {
 #
 # This function is intended for expert use only.
 distutils_wheel_install() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 	if [[ ${#} -ne 2 ]]; then
 		die "${FUNCNAME} takes exactly two arguments: <root> <wheel>"
 	fi
@@ -1236,7 +1236,7 @@ distutils_wheel_install() {
 # wrapping executables.  The wheel path is returned
 # in DISTUTILS_WHEEL_PATH variable.
 distutils_pep517_install() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 	[[ ${#} -eq 1 ]] || die "${FUNCNAME} takes exactly one argument: root"
 
 	if [[ ! ${DISTUTILS_USE_PEP517:-no} != no ]]; then
@@ -1448,7 +1448,7 @@ declare -g -A DISTUTILS_WHEELS=()
 # function will be appended to setup.py invocation, i.e. passed
 # as options to the 'build' command.
 distutils-r1_python_compile() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	_python_check_EPYTHON
 
@@ -1514,7 +1514,7 @@ distutils-r1_python_compile() {
 # @DESCRIPTION:
 # Moves and wraps all installed scripts/executables as necessary.
 _distutils-r1_wrap_scripts() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	[[ ${#} -eq 1 ]] || die "usage: ${FUNCNAME} <bindir>"
 	local bindir=${1}
@@ -1568,7 +1568,7 @@ _distutils-r1_wrap_scripts() {
 #
 # This function is used only if distutils_enable_tests is called.
 distutils-r1_python_test() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	if [[ -z ${_DISTUTILS_TEST_RUNNER} ]]; then
 		die "${FUNCNAME} can be only used after calling distutils_enable_tests"
@@ -1611,7 +1611,7 @@ distutils-r1_python_test() {
 # Any parameters passed to this function will be appended
 # to the setup.py invocation (i.e. as options to the 'install' command).
 distutils-r1_python_install() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	_python_check_EPYTHON
 
@@ -1728,7 +1728,7 @@ distutils-r1_python_install() {
 # @DESCRIPTION:
 # The default python_install_all(). It installs the documentation.
 distutils-r1_python_install_all() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 	_distutils-r1_check_all_phase_mismatch
 
 	einstalldocs
@@ -1748,7 +1748,7 @@ distutils-r1_python_install_all() {
 # holding the per-implementation copy of sources. BUILD_DIR points
 # to the 'build' subdirectory.
 distutils-r1_run_phase() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	if [[ ${DISTUTILS_IN_SOURCE_BUILD} ]]; then
 		[[ ${DISTUTILS_USE_PEP517} ]] &&
@@ -1869,7 +1869,7 @@ _distutils-r1_run_common_phase() {
 # Run the given phase for each implementation if multiple implementations
 # are enabled, once otherwise.
 _distutils-r1_run_foreach_impl() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	# store for restoring after distutils-r1_run_phase.
 	local _DISTUTILS_INITIAL_CWD=${PWD}
@@ -1890,7 +1890,7 @@ _distutils-r1_run_foreach_impl() {
 }
 
 distutils-r1_src_prepare() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 	local ret=0
 	local _DISTUTILS_DEFAULT_CALLED
 
@@ -1913,7 +1913,7 @@ distutils-r1_src_prepare() {
 }
 
 distutils-r1_src_configure() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 	local ret=0
 
 	if declare -f python_configure >/dev/null; then
@@ -1933,7 +1933,7 @@ distutils-r1_src_configure() {
 # Verify the the match between files installed between this and previous
 # implementation.
 _distutils-r1_compare_installed_files() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	# QA check requires diff(1).
 	if ! type -P diff &>/dev/null; then
@@ -1971,7 +1971,7 @@ _distutils-r1_compare_installed_files() {
 # Post-phase function called after python_compile.  In PEP517 mode,
 # it adjusts the install tree for venv-style usage.
 _distutils-r1_post_python_compile() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local root=${BUILD_DIR}/install
 	if [[ ${DISTUTILS_USE_PEP517} && -d ${root} ]]; then
@@ -2005,7 +2005,7 @@ _distutils-r1_post_python_compile() {
 }
 
 distutils-r1_src_compile() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 	local ret=0
 
 	if declare -f python_compile >/dev/null; then
@@ -2040,7 +2040,7 @@ _distutils-r1_clean_egg_info() {
 # @DESCRIPTION:
 # Post-phase function called after python_test.
 _distutils-r1_post_python_test() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	if [[ ! ${DISTUTILS_USE_PEP517} ]]; then
 		_distutils-r1_clean_egg_info
@@ -2048,7 +2048,7 @@ _distutils-r1_post_python_test() {
 }
 
 distutils-r1_src_test() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 	local ret=0
 
 	if declare -f python_test >/dev/null; then
@@ -2069,7 +2069,7 @@ distutils-r1_src_test() {
 # Find and remove setuptools-style namespaces in the specified
 # directory.
 _distutils-r1_strip_namespace_packages() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local sitedir=${1}
 	local f ns had_any=
@@ -2098,7 +2098,7 @@ _distutils-r1_strip_namespace_packages() {
 # Post-phase function called after python_install.  Performs QA checks.
 # In PEP517 mode, additionally optimizes installed Python modules.
 _distutils-r1_post_python_install() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local sitedir=${D}$(python_get_sitedir)
 	if [[ -d ${sitedir} ]]; then
@@ -2181,7 +2181,7 @@ _distutils-r1_check_namespace_pth() {
 }
 
 distutils-r1_src_install() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 	local ret=0
 
 	if declare -f python_install >/dev/null; then
diff --git a/eclass/dotnet-pkg-base.eclass b/eclass/dotnet-pkg-base.eclass
index a2d95f15a2fb..15e9ba703baa 100644
--- a/eclass/dotnet-pkg-base.eclass
+++ b/eclass/dotnet-pkg-base.eclass
@@ -188,7 +188,7 @@ dotnet-pkg-base_get-configuration() {
 #
 # This function is used inside "dotnet-pkg-base_setup".
 dotnet-pkg-base_get-output() {
-	debug-print-function "${FUNCNAME[0]}" "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	[[ -z ${DOTNET_PKG_CONFIGURATION} ]] &&
 		die "${FUNCNAME[0]}: DOTNET_PKG_CONFIGURATION is not set."
@@ -266,7 +266,7 @@ dotnet-pkg-base_setup() {
 #
 # Used by "dotnet-pkg_src_prepare" from the "dotnet-pkg" eclass.
 dotnet-pkg-base_remove-global-json() {
-	debug-print-function "${FUNCNAME[0]}" "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local file="${1:-.}"/global.json
 
@@ -282,7 +282,7 @@ dotnet-pkg-base_remove-global-json() {
 # @DESCRIPTION:
 # Call dotnet, passing the supplied arguments.
 edotnet() {
-	debug-print-function "${FUNCNAME[0]}" "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	if [[ -z ${DOTNET_PKG_EXECUTABLE} ]] ; then
 	   die "${FUNCNAME[0]}: DOTNET_PKG_EXECUTABLE not set. Was dotnet-pkg-base_setup called?"
@@ -301,7 +301,7 @@ edotnet() {
 # Used by "dotnet-pkg_src_configure" from the "dotnet-pkg" eclass.
 dotnet-pkg-base_info() {
 	if [[ ${CATEGORY}/${PN} == dev-dotnet/csharp-gentoodotnetinfo ]] ; then
-		debug-print-function "${FUNCNAME[0]}: ${P} is a special package, skipping dotnet-pkg-base_info"
+		debug-print-function ${FUNCNAME} "${P} is a special package, skipping dotnet-pkg-base_info"
 	elif command -v gentoo-dotnet-info >/dev/null ; then
 		gentoo-dotnet-info || die "${FUNCNAME[0]}: failed to execute gentoo-dotnet-info"
 	else
@@ -316,7 +316,7 @@ dotnet-pkg-base_info() {
 #
 # Used by "dotnet-pkg_remove-bad" from the "dotnet-pkg" eclass.
 dotnet-pkg-base_sln-remove() {
-	debug-print-function "${FUNCNAME[0]}" "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	[[ -z ${1} ]] && die "${FUNCNAME[0]}: no solution file specified"
 	[[ -z ${2} ]] && die "${FUNCNAME[0]}: no project file specified"
@@ -334,7 +334,7 @@ dotnet-pkg-base_sln-remove() {
 # Used by "dotnet-pkg_src_configure" and "dotnet-pkg_src_test" from
 # the "dotnet-pkg" eclass.
 dotnet-pkg-base_foreach-solution() {
-	debug-print-function "${FUNCNAME[0]}" "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local directory="${1}"
 	shift
@@ -362,7 +362,7 @@ dotnet-pkg-base_foreach-solution() {
 #
 # Used by "dotnet-pkg_src_configure" from the "dotnet-pkg" eclass.
 dotnet-pkg-base_restore() {
-	debug-print-function "${FUNCNAME[0]}" "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local -a restore_args=(
 		--runtime "${DOTNET_PKG_RUNTIME}"
@@ -385,7 +385,7 @@ dotnet-pkg-base_restore() {
 # Additionally any number of "args" maybe be given, they are appended to
 # the "dotnet" command invocation.
 dotnet-pkg-base_restore-tools() {
-	debug-print-function "${FUNCNAME[0]}" "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local -a tool_restore_args=(
 		--add-source "${NUGET_PACKAGES}"
@@ -421,7 +421,7 @@ dotnet-pkg-base_restore_tools() {
 #
 # Used by "dotnet-pkg_src_compile" from the "dotnet-pkg" eclass.
 dotnet-pkg-base_build() {
-	debug-print-function "${FUNCNAME[0]}" "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local -a build_args=(
 		--configuration "${DOTNET_PKG_CONFIGURATION}"
@@ -459,7 +459,7 @@ dotnet-pkg-base_build() {
 #
 # Used by "dotnet-pkg_src_test" from the "dotnet-pkg" eclass.
 dotnet-pkg-base_test() {
-	debug-print-function "${FUNCNAME[0]}" "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local -a test_args=(
 		--configuration "${DOTNET_PKG_CONFIGURATION}"
@@ -479,7 +479,7 @@ dotnet-pkg-base_test() {
 #
 # Installation directory is relative to "ED".
 dotnet-pkg-base_install() {
-	debug-print-function "${FUNCNAME[0]}" "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local installation_directory="${1:-/usr/share/${P}}"
 
@@ -495,7 +495,7 @@ dotnet-pkg-base_install() {
 #
 # For more info see the "_DOTNET_PKG_LAUNCHERDEST" variable.
 dotnet-pkg-base_launcherinto() {
-	debug-print-function "${FUNCNAME[0]}" "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	[[ -z ${1} ]] && die "${FUNCNAME[0]}: no directory specified"
 
@@ -519,7 +519,7 @@ dotnet-pkg-base_launcherinto() {
 #
 # For more info see the "_DOTNET_PKG_LAUNCHERVARS" variable.
 dotnet-pkg-base_append-launchervar() {
-	debug-print-function "${FUNCNAME[0]}" "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	[[ -z ${1} ]] && die "${FUNCNAME[0]}: no variable setting specified"
 
@@ -553,7 +553,7 @@ dotnet-pkg-base_append_launchervar() {
 #
 # The path is prepended by "EPREFIX".
 dotnet-pkg-base_dolauncher() {
-	debug-print-function "${FUNCNAME[0]}" "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local executable_path executable_name
 
@@ -618,7 +618,7 @@ dotnet-pkg-base_dolauncher() {
 #
 # The path is prepended by "EPREFIX".
 dotnet-pkg-base_dolauncher-portable() {
-	debug-print-function "${FUNCNAME[0]}" "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local dll_path="${1}"
 	local executable_name="${2}"
diff --git a/eclass/dotnet-pkg.eclass b/eclass/dotnet-pkg.eclass
index 59a8ae799f86..44a806f2af39 100644
--- a/eclass/dotnet-pkg.eclass
+++ b/eclass/dotnet-pkg.eclass
@@ -210,7 +210,7 @@ dotnet-pkg_src_unpack() {
 #
 # Used by "dotnet-pkg_src_prepare".
 dotnet-pkg_remove-bad() {
-	debug-print-function "${FUNCNAME[0]}" "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	[[ -z ${1} ]] && die "${FUNCNAME[0]}: no solution file specified"
 
@@ -246,7 +246,7 @@ dotnet-pkg_src_prepare() {
 #
 # Used by "dotnet-pkg_src_configure" and "dotnet-pkg_src_compile".
 dotnet-pkg_foreach-project() {
-	debug-print-function "${FUNCNAME[0]}" "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local dotnet_project
 	for dotnet_project in "${DOTNET_PKG_PROJECTS[@]}" ; do
diff --git a/eclass/dune.eclass b/eclass/dune.eclass
index faf40e47eb1e..cfe81433a5bc 100644
--- a/eclass/dune.eclass
+++ b/eclass/dune.eclass
@@ -55,7 +55,7 @@ BDEPEND="
 # edune clean
 # @CODE
 edune() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	edo dune "${@}"
 }
@@ -74,7 +74,7 @@ edune() {
 # dune-release build --target @install menhir menhirLib menhirSdk
 # @CODE
 dune-release() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local subcommand
 	local target
@@ -120,7 +120,7 @@ dune-release() {
 # dune-compile menhir menhirLib menhirSdk
 # @CODE
 dune-compile() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	dune-release build --target @install "${@}"
 }
@@ -135,7 +135,7 @@ dune-compile() {
 # dune-test menhir menhirLib menhirSdk
 # @CODE
 dune-test() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	dune-release runtest "${@}"
 }
@@ -159,7 +159,7 @@ dune_src_test() {
 # dune-install menhir menhirLib menhirSdk
 # @CODE
 dune-install() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local -a pkgs=( "${@}" )
 
diff --git a/eclass/fortran-2.eclass b/eclass/fortran-2.eclass
index 9694a764685a..dcf7ee979d8a 100644
--- a/eclass/fortran-2.eclass
+++ b/eclass/fortran-2.eclass
@@ -91,7 +91,7 @@ unset _f_use
 # Return the Fortran compiler flag to enable 64 bit integers for
 # array indices
 fortran_int64_abi_fflags() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local _FC=$(tc-getFC)
 	if [[ ${_FC} == *gfortran* ]]; then
@@ -108,7 +108,7 @@ fortran_int64_abi_fflags() {
 # @DESCRIPTION:
 # writes fortran test code
 _fortran_write_testsuite() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local filebase=${T}/test-fortran
 
@@ -136,7 +136,7 @@ _fortran_write_testsuite() {
 # Takes fortran compiler as first argument and dialect as second.
 # Checks whether the passed fortran compiler speaks the fortran dialect
 _fortran_compile_test() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local filebase=${T}/test-fortran
 	local fcomp=${1}
@@ -163,7 +163,7 @@ _fortran_compile_test() {
 # @DESCRIPTION:
 # See if the fortran supports OpenMP.
 _fortran-has-openmp() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local flag
 	local filebase=${T}/test-fc-openmp
@@ -192,7 +192,7 @@ _fortran-has-openmp() {
 # @DESCRIPTION:
 # Detailed description how to handle fortran support
 _fortran_die_msg() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	eerror
 	eerror "Please install currently selected gcc version with USE=fortran."
@@ -209,7 +209,7 @@ _fortran_die_msg() {
 # Internal test function for working fortran compiler.
 # It is called in fortran-2_pkg_setup.
 _fortran_test_function() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local dialect
 
@@ -275,7 +275,7 @@ _fortran-2_pkg_setup() {
 # Setup functionality,
 # checks for a valid fortran compiler and optionally for its openmp support.
 fortran-2_pkg_setup() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	if [[ ${MERGE_TYPE} != binary ]]; then
 		_fortran-2_pkg_setup
diff --git a/eclass/go-module.eclass b/eclass/go-module.eclass
index cad63ee6d0f0..73e9ee51c7d5 100644
--- a/eclass/go-module.eclass
+++ b/eclass/go-module.eclass
@@ -322,7 +322,7 @@ go-module_set_globals() {
 # It sets up the go module proxy in the appropriate location.
 go-module_setup_proxy() {
 	# shellcheck disable=SC2120
-	debug-print-function "${FUNCNAME}" "$@"
+	debug-print-function ${FUNCNAME} "$@"
 
 	if [[ ! ${_GO_MODULE_SET_GLOBALS_CALLED} ]]; then
 		die "go-module_set_globals must be called in global scope"
@@ -401,7 +401,7 @@ go-module_src_unpack() {
 # directory correctly.
 _go-module_src_unpack_gosum() {
 	# shellcheck disable=SC2120
-	debug-print-function "${FUNCNAME}" "$@"
+	debug-print-function ${FUNCNAME} "$@"
 
 	if [[ ! ${_GO_MODULE_SET_GLOBALS_CALLED} ]]; then
 		die "go-module_set_globals must be called in global scope"
@@ -472,7 +472,7 @@ _go-module_gosum_synthesize_files() {
 # the package, without actually building it yet.
 _go-module_src_unpack_verify_gosum() {
 	# shellcheck disable=SC2120
-	debug-print-function "${FUNCNAME}" "$@"
+	debug-print-function ${FUNCNAME} "$@"
 
 	if [[ ! ${_GO_MODULE_SET_GLOBALS_CALLED} ]]; then
 		die "go-module_set_globals must be called in global scope"
@@ -499,7 +499,7 @@ _go-module_src_unpack_verify_gosum() {
 # This function is used in live ebuilds to vendor the dependencies when
 # upstream doesn't vendor them.
 go-module_live_vendor() {
-	debug-print-function "${FUNCNAME}" "$@"
+	debug-print-function ${FUNCNAME} "$@"
 
 	# shellcheck disable=SC2086
 	has live ${PROPERTIES} ||
diff --git a/eclass/greadme.eclass b/eclass/greadme.eclass
index 38190becf91d..a4335b1a6286 100644
--- a/eclass/greadme.eclass
+++ b/eclass/greadme.eclass
@@ -69,7 +69,7 @@ _GREADME_REL_PATH="/usr/share/doc/${PF}/README.gentoo"
 # Create the readme doc via stdin.  You can use --append to append to an
 # existing readme doc.
 greadme_stdin() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local append
 	if [[ ${1} = --append ]]; then
@@ -97,7 +97,7 @@ greadme_stdin() {
 # @DESCRIPTION:
 # Installs the provided file as readme doc.
 greadme_file() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local input_doc_file="${1}"
 	if [[ -z ${input_doc_file} ]]; then
@@ -114,7 +114,7 @@ greadme_file() {
 # @DESCRIPTION:
 # Installs the readme file from the temp directory into the image.
 _greadme_install_doc() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local greadme="${_GREADME_TMP_FILE}"
 	if [[ ! ${GREADME_DISABLE_AUTOFORMAT} ]]; then
@@ -148,7 +148,7 @@ _greadme_install_doc() {
 # Performs checks like comparing the readme doc from the image with a
 # potentially existing one in the live system.
 greadme_pkg_preinst() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	if [[ -z ${REPLACING_VERSIONS} ]]; then
 		_GREADME_SHOW="fresh-install"
@@ -224,7 +224,7 @@ greadme_pkg_preinst() {
 # @DESCRIPTION:
 # Conditionally shows the contents of the readme doc via elog.
 greadme_pkg_postinst() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	if [[ ! -v _GREADME_SHOW ]]; then
 		die "_GREADME_SHOW not set. Did you call greadme_pkg_preinst?"
diff --git a/eclass/guile-single.eclass b/eclass/guile-single.eclass
index 66898504a6c4..3498044b6d76 100644
--- a/eclass/guile-single.eclass
+++ b/eclass/guile-single.eclass
@@ -129,7 +129,7 @@ inherit guile-utils
 # Please keep in ascending order.
 
 _guile_setup() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	# Inhibit generating the GUILE_USEDEP.  This variable is not usable
 	# for single packages.
@@ -162,7 +162,7 @@ unset -f _guile_setup
 # "
 # @CODE
 guile_gen_cond_dep() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local deps="$1"
 	shift
@@ -196,7 +196,7 @@ guile_gen_cond_dep() {
 #
 # For details on the latter three, see guile_export.
 guile-single_pkg_setup() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	guile_set_common_vars
 
@@ -223,7 +223,7 @@ guile-single_pkg_setup() {
 # Runs the default prepare stage, and then bumps Guile sources via
 # guile_bump_sources.
 guile-single_src_prepare() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	default
 	guile_bump_sources
@@ -234,7 +234,7 @@ guile-single_src_prepare() {
 # Runs the default install stage, and then marks ccache files not to be
 # stripped using guile_unstrip_ccache.
 guile-single_src_install() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	default
 	guile_unstrip_ccache
diff --git a/eclass/guile-utils.eclass b/eclass/guile-utils.eclass
index 09ca5aabe502..b0660dcfd1ce 100644
--- a/eclass/guile-utils.eclass
+++ b/eclass/guile-utils.eclass
@@ -46,7 +46,7 @@ BDEPEND="virtual/pkgconfig"
 # Checks that GUILE_COMPAT is set to an array, and has no invalid
 # values.
 guile_check_compat() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	if ! [[ ${GUILE_COMPAT@a} == *a* ]]; then
 		die "GUILE_COMPAT not set to an array"
@@ -86,7 +86,7 @@ guile_check_compat
 # Sets common variables that apply to all Guile packages, namely,
 # QA_PREBUILT.
 guile_set_common_vars() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	# These aren't strictly speaking prebuilt. but they do generated a
 	# nonstandard ELF object.
@@ -101,7 +101,7 @@ guile_set_common_vars() {
 # Alters ${PKG_CONFIG_PATH} such that it does not contain any Guile
 # slots besides the ones required by the caller.
 guile_filter_pkgconfig_path() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local filtered_path= unfiltered_path path
 	IFS=: read -ra unfiltered_path <<<"${PKG_CONFIG_PATH}"
@@ -132,7 +132,7 @@ guile_filter_pkgconfig_path() {
 # Generates GUILE_REQUIRED_USE/GUILE_DEPS/GUILE_USEDEP based on
 # GUILE_COMPAT, and populates IUSE.
 guile_generate_depstrings() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	# Generate IUSE, REQUIRED_USE, GUILE_USEDEP
 	local prefix="$1" depop="$2"
@@ -169,7 +169,7 @@ guile_generate_depstrings() {
 # @DESCRIPTION:
 # Marks site-ccache files not to be stripped.  Operates on ${D}.
 guile_unstrip_ccache() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local ccache
 	while read -r -d $'\0' ccache; do
@@ -196,7 +196,7 @@ guile_unstrip_ccache() {
 # - GUILE_SITECCACHEDIR - Path to the site-ccache directory,
 # - GUILE_SITEDIR - Path to the site Scheme directory
 guile_export() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local gver
 	if [[ "${GUILE_CURRENT_VERSION}" ]]; then
@@ -243,7 +243,7 @@ guile_export() {
 # Creates a guile-config executable for a given Guile version, and
 # inserts it into path.
 guile_create_temporary_config() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	[[ ${1} ]] || die "Must specify a Guile version"
 
@@ -267,7 +267,7 @@ guile_create_temporary_config() {
 #
 # http://debbugs.gnu.org/cgi/bugreport.cgi?bug=38112
 guile_bump_sources() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	einfo "bumping *.scm source files..."
 	find "${S}" -name "*.scm" -exec touch {} + || die
diff --git a/eclass/guile.eclass b/eclass/guile.eclass
index e8fde64266e5..1d4a88caf926 100644
--- a/eclass/guile.eclass
+++ b/eclass/guile.eclass
@@ -124,7 +124,7 @@ inherit guile-utils multibuild
 # Please keep in ascending order.
 
 _guile_setup() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	guile_generate_depstrings guile_targets '||'
 }
@@ -142,7 +142,7 @@ unset -f _guile_setup
 # @DESCRIPTION:
 # Sets up eclass-internal variables for this build.
 guile_pkg_setup() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	guile_set_common_vars
 	GUILE_SELECTED_TARGETS=()
@@ -161,7 +161,7 @@ guile_pkg_setup() {
 # Create a single copy of the package sources for each selected Guile
 # implementation.
 guile_copy_sources() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local MULTIBUILD_VARIANTS
 	MULTIBUILD_VARIANTS=("${GUILE_SELECTED_TARGETS[@]}")
@@ -177,7 +177,7 @@ guile_copy_sources() {
 # guile_foreach_impl.
 _guile_multibuild_wrapper() {
 	local GUILE_CURRENT_VERSION="${MULTIBUILD_VARIANT}"
-	debug-print-function ${FUNCNAME} "${@}" "on ${MULTIBUILD_VARIANT}"
+	debug-print-function ${FUNCNAME} "$@" "on ${MULTIBUILD_VARIANT}"
 
 	local -x PATH="${PATH}"
 	guile_create_temporary_config "${GUILE_CURRENT_VERSION}"
@@ -245,7 +245,7 @@ _guile_multibuild_wrapper() {
 # This combination should cover Guile detection of a large amount of
 # packages out of the box.
 guile_foreach_impl() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local MULTIBUILD_VARIANTS
 	MULTIBUILD_VARIANTS=("${GUILE_SELECTED_TARGETS[@]}")
@@ -261,7 +261,7 @@ guile_foreach_impl() {
 # @DESCRIPTION:
 # Runs a single merge_root step for guile_merge_roots.
 _guile_merge_single_root() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	multibuild_merge_root "${SLOTTED_D}" "${D}"
 }
@@ -270,7 +270,7 @@ _guile_merge_single_root() {
 # @DESCRIPTION:
 # Merges install roots from all slots, diagnosing conflicts.
 guile_merge_roots() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	guile_foreach_impl _guile_merge_single_root
 }
@@ -280,7 +280,7 @@ guile_merge_roots() {
 # Runs the passed command once, for the best installed Guile
 # implementation.
 guile_for_best_impl() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	multibuild_for_best_variant _guile_multibuild_wrapper "${@}"
 }
@@ -292,7 +292,7 @@ guile_for_best_impl() {
 # Bumps SCM sources runs the default src_prepare and bumps all *.scm
 # files.  See guile_bump_sources of guile-utils.eclass.
 guile_src_prepare() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	default
 	guile_bump_sources
@@ -302,7 +302,7 @@ guile_src_prepare() {
 # @DESCRIPTION:
 # Runs the default src_configure for each selected variant target.
 guile_src_configure() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	guile_foreach_impl default
 }
@@ -311,7 +311,7 @@ guile_src_configure() {
 # @DESCRIPTION:
 # Runs the default src_compile for each selected variant target.
 guile_src_compile() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	guile_foreach_impl default
 }
@@ -320,7 +320,7 @@ guile_src_compile() {
 # @DESCRIPTION:
 # Runs the default src_test phase for each implementation.
 guile_src_test() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	guile_foreach_impl default
 }
@@ -331,7 +331,7 @@ guile_src_test() {
 # Imitates the default build system install "substep", but for a given
 # ${SLOTTED_D} rather than the usual ${D}.  See guile_src_install.
 _guile_default_install_slot() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	if [[ -f Makefile ]] || [[ -f GNUmakefile ]] || [[ -f makefile ]]; then
 		emake DESTDIR="${SLOTTED_D}" install
@@ -344,7 +344,7 @@ _guile_default_install_slot() {
 # thing for a GNU Build System based Guile package, for each selected
 # variant target.  Merges roots after completing the installs.
 guile_src_install() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	guile_foreach_impl _guile_default_install_slot
 	guile_merge_roots
diff --git a/eclass/java-utils-2.eclass b/eclass/java-utils-2.eclass
index 65fecd28e762..8d9ef40b3570 100644
--- a/eclass/java-utils-2.eclass
+++ b/eclass/java-utils-2.eclass
@@ -3024,7 +3024,7 @@ java-pkg_clean() {
 # $1 - classpath variable either EANT_GENTOO_CLASSPATH or JAVA_GENTOO_CLASSPATH
 # @CODE
 java-pkg_gen-cp() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local atom
 	for atom in ${CP_DEPEND}; do
diff --git a/eclass/kernel-build.eclass b/eclass/kernel-build.eclass
index dbc41824c4b6..4a2af9845ad4 100644
--- a/eclass/kernel-build.eclass
+++ b/eclass/kernel-build.eclass
@@ -171,7 +171,7 @@ kernel-build_pkg_setup() {
 # Prepare the toolchain for building the kernel, get the .config file,
 # and get build tree configured for modprep.
 kernel-build_src_configure() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	if ! tc-is-cross-compiler && use hppa ; then
 		if [[ ${CHOST} == hppa2.0-* ]] ; then
@@ -294,7 +294,7 @@ kernel-build_src_configure() {
 # @DESCRIPTION:
 # Compile the kernel sources.
 kernel-build_src_compile() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local targets=( all )
 
@@ -313,7 +313,7 @@ kernel-build_src_compile() {
 # Test the built kernel via qemu.  This just wraps the logic
 # from kernel-install.eclass with the correct paths.
 kernel-build_src_test() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local targets=( modules_install )
 
@@ -345,7 +345,7 @@ kernel-build_src_test() {
 # Install the built kernel along with subset of sources
 # into /usr/src/linux-${KV_FULL}.  Install the modules.  Save the config.
 kernel-build_src_install() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	# do not use 'make install' as it behaves differently based
 	# on what kind of installkernel is installed
@@ -632,7 +632,7 @@ kernel-build_pkg_postinst() {
 #
 # This function must be called by the ebuild in the src_prepare phase.
 kernel-build_merge_configs() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	[[ -f .config ]] ||
 		die "${FUNCNAME}: No .config, please copy default config into .config"
diff --git a/eclass/kernel-install.eclass b/eclass/kernel-install.eclass
index 4109810d4d14..c5f218a46b91 100644
--- a/eclass/kernel-install.eclass
+++ b/eclass/kernel-install.eclass
@@ -239,7 +239,7 @@ BDEPEND="
 # Determine whether the symlink at <target> (full path) should be
 # updated.  Returns 0 if it should, 1 to leave as-is.
 kernel-install_can_update_symlink() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	[[ ${#} -eq 1 ]] || die "${FUNCNAME}: invalid arguments"
 	local target=${1}
@@ -282,7 +282,7 @@ kernel-install_can_update_symlink() {
 # to <target>-<version> if it's either missing or pointing out to
 # an older version of this package.
 kernel-install_update_symlink() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	[[ ${#} -eq 2 ]] || die "${FUNCNAME}: invalid arguments"
 	local target=${1}
@@ -302,7 +302,7 @@ kernel-install_update_symlink() {
 # @DESCRIPTION:
 # Get appropriate qemu suffix for the current ${ARCH}.
 kernel-install_get_qemu_arch() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	case ${ARCH} in
 		amd64)
@@ -331,7 +331,7 @@ kernel-install_get_qemu_arch() {
 # @DESCRIPTION:
 # Create minimal /sbin/init
 kernel-install_create_init() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	[[ ${#} -eq 1 ]] || die "${FUNCNAME}: invalid arguments"
 	[[ -z ${1} ]] && die "${FUNCNAME}: empty argument specified"
@@ -369,7 +369,7 @@ kernel-install_create_init() {
 # @DESCRIPTION:
 # Create minimal qemu raw image
 kernel-install_create_qemu_image() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	[[ ${#} -eq 1 ]] || die "${FUNCNAME}: invalid arguments"
 	[[ -z ${1} ]] && die "${FUNCNAME}: empty argument specified"
@@ -401,7 +401,7 @@ kernel-install_create_qemu_image() {
 # in qemu.  <version> is the kernel version, <image> path to the image,
 # <modules> path to module tree.
 kernel-install_test() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	[[ ${#} -eq 3 ]] || die "${FUNCNAME}: invalid arguments"
 	local version=${1}
@@ -534,7 +534,7 @@ kernel-install_test() {
 # @DESCRIPTION:
 # Check for missing optional dependencies and output warnings.
 kernel-install_pkg_pretend() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	# Check, but don't die because we can fix the problem and then
 	# emerge --config ... to re-run installation.
@@ -582,7 +582,7 @@ kernel-install_pkg_pretend() {
 # @DESCRIPTION:
 # Boilerplate function to remind people to call the tests.
 kernel-install_src_test() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	die "Please redefine src_test() and call kernel-install_test()."
 }
@@ -591,7 +591,7 @@ kernel-install_src_test() {
 # @DESCRIPTION:
 # Verify whether the kernel has been installed correctly.
 kernel-install_pkg_preinst() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	# Set KV_FULL to ${PV}${KV_LOCALVERSION} if it hasn't
 	# been set elsewhere for backward compatibility with existing
@@ -662,7 +662,7 @@ kernel-install_extract_from_uki() {
 # installkernel. This is called from pkg_postinst() and pkg_config().
 # <ver> is the full kernel version.
 kernel-install_install_all() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	[[ ${#} -eq 1 ]] || die "${FUNCNAME}: invalid arguments"
 	local dir_ver=${1}
@@ -705,7 +705,7 @@ kernel-install_install_all() {
 # Build an initramfs for the kernel, install it and update
 # the /usr/src/linux symlink.
 kernel-install_pkg_postinst() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	kernel-install_update_symlink "${EROOT}/usr/src/linux" "${KV_FULL}"
 	dist-kernel_compressed_module_cleanup \
@@ -733,7 +733,7 @@ kernel-install_pkg_postinst() {
 # @DESCRIPTION:
 # Clean up the generated initramfs from the removed kernel directory.
 kernel-install_pkg_postrm() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	if [[ -z ${ROOT} && ! ${KERNEL_IUSE_GENERIC_UKI} ]]; then
 		local kernel_dir=${EROOT}/usr/src/linux-${KV_FULL}
@@ -762,7 +762,7 @@ kernel-install_pkg_config() {
 # @DESCRIPTION:
 # Compress modules installed in ED, if USE=modules-compress is enabled.
 kernel-install_compress_modules() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	if use modules-compress; then
 		einfo "Compressing kernel modules ..."
diff --git a/eclass/latex-package.eclass b/eclass/latex-package.eclass
index 784254aecf4f..4082e161b843 100644
--- a/eclass/latex-package.eclass
+++ b/eclass/latex-package.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2022 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: latex-package.eclass
@@ -93,7 +93,7 @@ LATEX_DOC_ARGUMENTS=""
 # It installs the files found in the current directory to the standard locations
 # for a TeX installation
 latex-package_src_doinstall() {
-	debug-print-function "${FUNCNAME}" "$@"
+	debug-print-function ${FUNCNAME} "$@"
 
 	# Avoid generating font cache outside of the sandbox
 	export VARTEXFONTS="${T}/fonts"
@@ -205,7 +205,7 @@ latex-package_src_doinstall() {
 # Calls latex for each *.ins in the current directory in order to generate the
 # relevant files that will be installed
 latex-package_src_compile() {
-	debug-print-function "${FUNCNAME}" "$@"
+	debug-print-function ${FUNCNAME} "$@"
 	while IFS= read -r -d '' i; do
 		einfo "Extracting from ${i}"
 		latex --halt-on-error --interaction=nonstopmode "${i}" || die
@@ -216,7 +216,7 @@ latex-package_src_compile() {
 # @DESCRIPTION:
 # Installs the package
 latex-package_src_install() {
-	debug-print-function "${FUNCNAME}" "$@"
+	debug-print-function ${FUNCNAME} "$@"
 	latex-package_src_doinstall all
 	einstalldocs
 }
@@ -226,7 +226,7 @@ latex-package_src_install() {
 # Calls latex-package_rehash to ensure the TeX installation is consistent with
 # the kpathsea database
 latex-package_pkg_postinst() {
-	debug-print-function "${FUNCNAME}" "$@"
+	debug-print-function ${FUNCNAME} "$@"
 	latex-package_rehash
 }
 
@@ -235,7 +235,7 @@ latex-package_pkg_postinst() {
 # Calls latex-package_rehash to ensure the TeX installation is consistent with
 # the kpathsea database
 latex-package_pkg_postrm() {
-	debug-print-function "${FUNCNAME}" "$@"
+	debug-print-function ${FUNCNAME} "$@"
 	latex-package_rehash
 }
 
@@ -243,7 +243,7 @@ latex-package_pkg_postrm() {
 # @DESCRIPTION:
 # Rehashes the kpathsea database, according to the current TeX installation
 latex-package_rehash() {
-	debug-print-function "${FUNCNAME}" "$@"
+	debug-print-function ${FUNCNAME} "$@"
 	texmf-update
 }
 
diff --git a/eclass/linux-mod-r1.eclass b/eclass/linux-mod-r1.eclass
index 241cfc7886e9..f8a45c607dfd 100644
--- a/eclass/linux-mod-r1.eclass
+++ b/eclass/linux-mod-r1.eclass
@@ -329,7 +329,7 @@ fi
 #    (normally these should not be used directly, for custom builds)
 #  3. perform various sanity checks to fail early on issues
 linux-mod-r1_pkg_setup() {
-	debug-print-function ${FUNCNAME[0]} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 	_MODULES_GLOBAL[ran:pkg_setup]=1
 	_modules_check_function ${#} 0 0 || return 0
 
@@ -409,7 +409,7 @@ linux-mod-r1_pkg_setup() {
 # different make arguments per modules or intermediate steps -- albeit,
 # if atypical, may want to build manually (see eclass' example).
 linux-mod-r1_src_compile() {
-	debug-print-function ${FUNCNAME[0]} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 	_modules_check_function ${#} 0 0 || return 0
 
 	[[ ${modlist@a} == *a* && ${#modlist[@]} -gt 0 ]] ||
@@ -480,7 +480,7 @@ linux-mod-r1_src_compile() {
 # Installs modules built by linux-mod-r1_src_compile using
 # linux_domodule, then runs modules_post_process and einstalldocs.
 linux-mod-r1_src_install() {
-	debug-print-function ${FUNCNAME[0]} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 	_modules_check_function ${#} 0 0 || return 0
 
 	(( ${#_MODULES_INSTALL[@]} )) ||
@@ -502,7 +502,7 @@ linux-mod-r1_src_install() {
 # @DESCRIPTION:
 # Updates module dependencies using depmod.
 linux-mod-r1_pkg_postinst() {
-	debug-print-function ${FUNCNAME[0]} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 	_modules_check_function ${#} 0 0 || return 0
 
 	dist-kernel_compressed_module_cleanup "${EROOT}/lib/modules/${KV_FULL}"
@@ -534,7 +534,7 @@ linux-mod-r1_pkg_postinst() {
 #
 # See also linux_moduleinto.
 linux_domodule() {
-	debug-print-function ${FUNCNAME[0]} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 	_modules_check_function ${#} 1 '' "<module>..." || return 0
 	(
 		# linux-mod-r0 formerly supported INSTALL_MOD_PATH (bug #642240), but
@@ -559,7 +559,7 @@ linux_domodule() {
 # this is like setting INSTALL_MOD_DIR which has the same default
 # for external modules.
 linux_moduleinto() {
-	debug-print-function ${FUNCNAME[0]} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 	_modules_check_function ${#} 1 1 "<install-dir>" || return 0
 	_MODULES_GLOBAL[moduleinto]=${1}
 }
@@ -582,7 +582,7 @@ linux_moduleinto() {
 # if modules were unexpectedly pre-compressed possibly due to using
 # make install without passing MODULES_MAKEARGS to disable it.
 modules_post_process() {
-	debug-print-function ${FUNCNAME[0]} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 	_modules_check_function ${#} 0 1 '[<path>]' || return 0
 	[[ ${EBUILD_PHASE} == install ]] ||
 		die "${FUNCNAME[0]} can only be called in the src_install phase"
diff --git a/eclass/llvm-r1.eclass b/eclass/llvm-r1.eclass
index 399902181b65..7b9f26e17b58 100644
--- a/eclass/llvm-r1.eclass
+++ b/eclass/llvm-r1.eclass
@@ -101,7 +101,7 @@ _LLVM_NEWEST_STABLE=18
 # packages using the same eclass, to enforce a LLVM slot match.
 
 _llvm_set_globals() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	if [[ ${LLVM_COMPAT@a} != *a* ]]; then
 		die "LLVM_COMPAT must be set to an array before inheriting ${ECLASS}"
@@ -169,7 +169,7 @@ unset -f _llvm_set_globals
 # "
 # @CODE
 llvm_gen_dep() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	[[ ${#} -ne 1 ]] && die "Usage: ${FUNCNAME} <dependency>"
 
@@ -194,7 +194,7 @@ llvm_gen_dep() {
 # With "-b" option, the path is prefixed by BROOT. LLVM dependencies
 # should be in BDEPEND then.
 get_llvm_prefix() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	[[ ${#} -gt 1 ]] && die "Usage: ${FUNCNAME} [-b|-d]"
 
@@ -228,7 +228,7 @@ get_llvm_prefix() {
 # Note that this function is not exported if LLVM_OPTIONAL is set.
 # In that case, it needs to be called manually.
 llvm-r1_pkg_setup() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	if [[ ${MERGE_TYPE} != binary ]]; then
 		[[ -z ${LLVM_SLOT} ]] && die "LLVM_SLOT unset (broken USE_EXPAND?)"
diff --git a/eclass/llvm-utils.eclass b/eclass/llvm-utils.eclass
index d38ba3a988f1..1ae3295484c8 100644
--- a/eclass/llvm-utils.eclass
+++ b/eclass/llvm-utils.eclass
@@ -27,7 +27,7 @@ _LLVM_UTILS_ECLASS=1
 # Translate a tuple into a target suitable for LLVM_TARGETS.
 # Defaults to ${CHOST} if not specified.
 llvm_tuple_to_target() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	[[ ${#} -gt 1 ]] && die "Usage: ${FUNCNAME} [<tuple>]"
 
@@ -61,7 +61,7 @@ llvm_tuple_to_target() {
 # the major version, to prevent PATH alterations from forcing an older
 # clang version being used.
 llvm_fix_clang_version() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local shopt_save=$(shopt -p -o noglob)
 	set -f
@@ -95,7 +95,7 @@ llvm_fix_clang_version() {
 # current location, to prevent PATH alterations from forcing older
 # versions being used.
 llvm_fix_tool_path() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local shopt_save=$(shopt -p -o noglob)
 	set -f
@@ -118,7 +118,7 @@ llvm_fix_tool_path() {
 # Prepend the path to the specified LLVM slot to PATH variable,
 # and reexport it.
 llvm_prepend_path() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	[[ ${#} -ne 1 ]] && die "Usage: ${FUNCNAME} <slot>"
 	local slot=${1}
diff --git a/eclass/llvm.eclass b/eclass/llvm.eclass
index 39ca1123eabb..9f757e704f7a 100644
--- a/eclass/llvm.eclass
+++ b/eclass/llvm.eclass
@@ -119,7 +119,7 @@ declare -g -r _LLVM_KNOWN_SLOTS=( {19..8} )
 # the function defaults to checking whether sys-devel/llvm:${LLVM_SLOT}
 # is installed.
 get_llvm_slot() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local hv_switch=-d
 	while [[ ${1} == -* ]]; do
@@ -170,7 +170,7 @@ get_llvm_slot() {
 #
 # The options and behavior is the same as for get_llvm_slot.
 get_llvm_prefix() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local prefix=${ESYSROOT}
 	[[ ${1} == -b ]] && prefix=${BROOT}
@@ -193,7 +193,7 @@ get_llvm_prefix() {
 # If any other behavior is desired, the contents of the function
 # should be inlined into the ebuild and modified as necessary.
 llvm_pkg_setup() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	if [[ ${LLVM_ECLASS_SKIP_PKG_SETUP} ]]; then
 		return
diff --git a/eclass/lua-single.eclass b/eclass/lua-single.eclass
index ad7075955153..1a919ad606ef 100644
--- a/eclass/lua-single.eclass
+++ b/eclass/lua-single.eclass
@@ -285,7 +285,7 @@ unset -f _lua_single_set_globals
 #
 # This is an internal function used to implement lua_gen_cond_dep.
 _lua_gen_usedep() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local impl matches=()
 
@@ -338,7 +338,7 @@ _lua_impl_matches() {
 # Verify whether the patterns passed to the eclass function are correct
 # (i.e. can match any valid implementation).  Dies on wrong pattern.
 _lua_verify_patterns() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local impl pattern
 	for pattern; do
@@ -381,7 +381,7 @@ _lua_verify_patterns() {
 #     dev-lua/backported_core_module[lua_targets_lua5-3(-)?,...] )"
 # @CODE
 lua_gen_cond_dep() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local impl matches=()
 
@@ -440,7 +440,7 @@ lua_gen_cond_dep() {
 # )"
 # @CODE
 lua_gen_impl_dep() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local impl
 	local matches=()
@@ -465,7 +465,7 @@ lua_gen_impl_dep() {
 # Determine what the selected Lua implementation is and set
 # the Lua build environment up for it.
 lua_setup() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	unset ELUA
 
@@ -520,7 +520,7 @@ lua_setup() {
 # @DESCRIPTION:
 # Runs lua_setup.
 lua-single_pkg_setup() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	[[ ${MERGE_TYPE} != binary ]] && lua_setup
 }
diff --git a/eclass/lua-utils.eclass b/eclass/lua-utils.eclass
index 7272f80d0370..9be520aeb671 100644
--- a/eclass/lua-utils.eclass
+++ b/eclass/lua-utils.eclass
@@ -124,7 +124,7 @@ _lua_set_impls() {
 # setup will be done. If wrapper update is requested, the directory
 # shall be removed first.
 _lua_wrapper_setup() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local workdir=${1:-${T}/${ELUA}}
 	local impl=${2:-${ELUA}}
@@ -234,7 +234,7 @@ _lua_get_library_file() {
 # or an ELUA one, e.g. lua5.4). If no implementation passed,
 # the current one will be obtained from ${ELUA}.
 _lua_export() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local impl var
 
@@ -374,7 +374,7 @@ _lua_export() {
 # This function must be called in global scope, after RDEPEND has been
 # declared.  Take care not to overwrite the variables set by it.
 lua_enable_tests() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	[[ ${#} -ge 1 ]] || die "${FUNCNAME} takes at least one argument: test-runner (test-directory)"
 	local test_directory
@@ -431,7 +431,7 @@ lua_enable_tests() {
 # Please note that this function requires Lua and pkg-config installed,
 # and therefore proper build-time dependencies need be added to the ebuild.
 lua_get_CFLAGS() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	_lua_export "${@}" LUA_CFLAGS
 	echo "${LUA_CFLAGS}"
@@ -447,7 +447,7 @@ lua_get_CFLAGS() {
 # Please note that this function requires Lua and pkg-config installed,
 # and therefore proper build-time dependencies need be added to the ebuild.
 lua_get_cmod_dir() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	_lua_export "${@}" LUA_CMOD_DIR
 	echo "${LUA_CMOD_DIR}"
@@ -463,7 +463,7 @@ lua_get_cmod_dir() {
 # Please note that this function requires Lua and pkg-config installed,
 # and therefore proper build-time dependencies need be added to the ebuild.
 lua_get_include_dir() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	_lua_export "${@}" LUA_INCLUDE_DIR
 	echo "${LUA_INCLUDE_DIR}"
@@ -479,7 +479,7 @@ lua_get_include_dir() {
 # Please note that this function requires Lua and pkg-config installed,
 # and therefore proper build-time dependencies need be added to the ebuild.
 lua_get_LIBS() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	_lua_export "${@}" LUA_LIBS
 	echo "${LUA_LIBS}"
@@ -495,7 +495,7 @@ lua_get_LIBS() {
 # Please note that this function requires Lua and pkg-config installed,
 # and therefore proper build-time dependencies need be added to the ebuild.
 lua_get_lmod_dir() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	_lua_export "${@}" LUA_LMOD_DIR
 	echo "${LUA_LMOD_DIR}"
@@ -514,7 +514,7 @@ lua_get_lmod_dir() {
 # Please note that this function requires Lua and pkg-config installed,
 # and therefore proper build-time dependencies need be added to the ebuild.
 lua_get_shared_lib() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	_lua_export "${@}" LUA_SHARED_LIB
 	echo "${LUA_SHARED_LIB}"
@@ -529,7 +529,7 @@ lua_get_shared_lib() {
 # Please note that this function requires Lua and pkg-config installed,
 # and therefore proper build-time dependencies need be added to the ebuild.
 lua_get_version() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	_lua_export "${@}" LUA_VERSION
 	echo "${LUA_VERSION}"
diff --git a/eclass/lua.eclass b/eclass/lua.eclass
index 380ec274167c..7629033afb07 100644
--- a/eclass/lua.eclass
+++ b/eclass/lua.eclass
@@ -200,7 +200,7 @@ inherit multibuild lua-utils
 # Enforce the proper setting of LUA_TARGETS, if LUA_COMPAT_OVERRIDE
 # is not in effect. If it is, just warn that the flags will be ignored.
 _lua_validate_useflags() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	if [[ ${LUA_COMPAT_OVERRIDE} ]]; then
 		if [[ ! ${_LUA_COMPAT_OVERRIDE_WARNED} ]]; then
@@ -260,7 +260,7 @@ _lua_obtain_impls() {
 # Initialize the environment for the Lua implementation selected
 # for multibuild.
 _lua_multibuild_wrapper() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local -x ELUA LUA
 	_lua_export "${MULTIBUILD_VARIANT}" ELUA LUA
@@ -279,7 +279,7 @@ _lua_multibuild_wrapper() {
 # to implementation-specific build directory matching BUILD_DIR used by
 # lua_foreach_abi().
 lua_copy_sources() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local MULTIBUILD_VARIANTS
 	_lua_obtain_impls
@@ -301,7 +301,7 @@ lua_copy_sources() {
 # For each command being run, ELUA, LUA and BUILD_DIR are set
 # locally, and the former two are exported to the command environment.
 lua_foreach_impl() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local MULTIBUILD_VARIANTS
 	_lua_obtain_impls
diff --git a/eclass/mercurial.eclass b/eclass/mercurial.eclass
index 16d9fc87cb0a..0d700c79930e 100644
--- a/eclass/mercurial.eclass
+++ b/eclass/mercurial.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2023 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: mercurial.eclass
@@ -100,7 +100,7 @@ EHG_OFFLINE="${EHG_OFFLINE:-${EVCS_OFFLINE}}"
 # EHG_CHECKOUT_DIR, which defaults to S.
 
 mercurial_fetch() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	EHG_REPO_URI=${1-${EHG_REPO_URI}}
 	[[ -z "${EHG_REPO_URI}" ]] && die "EHG_REPO_URI is empty"
diff --git a/eclass/multibuild.eclass b/eclass/multibuild.eclass
index 127654f50e78..652a938d5663 100644
--- a/eclass/multibuild.eclass
+++ b/eclass/multibuild.eclass
@@ -95,7 +95,7 @@ esac
 # nevertheless. It is preferred to call 'die' inside of the passed
 # function.
 multibuild_foreach_variant() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	[[ ${MULTIBUILD_VARIANTS} ]] \
 		|| die "MULTIBUILD_VARIANTS need to be set"
@@ -146,7 +146,7 @@ multibuild_foreach_variant() {
 #
 # The function returns command exit status.
 multibuild_for_best_variant() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	[[ ${MULTIBUILD_VARIANTS} ]] \
 		|| die "MULTIBUILD_VARIANTS need to be set"
@@ -162,7 +162,7 @@ multibuild_for_best_variant() {
 # be placed in directories matching BUILD_DIRs used by
 # multibuild_foreach().
 multibuild_copy_sources() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local _MULTIBUILD_INITIAL_BUILD_DIR=${BUILD_DIR:-${S}}
 
@@ -184,7 +184,7 @@ multibuild_copy_sources() {
 # (the real root). Both directories have to be real, absolute paths
 # (i.e. including ${D}). Source root will be removed.
 multibuild_merge_root() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local src=${1}
 	local dest=${2}
diff --git a/eclass/nuget.eclass b/eclass/nuget.eclass
index ac8629848eca..4efbeb909f43 100644
--- a/eclass/nuget.eclass
+++ b/eclass/nuget.eclass
@@ -245,7 +245,7 @@ nuget_unpack-non-nuget-archives() {
 # This function is used inside "dotnet-pkg_src_prepare"
 # from the "dotnet-pkg" eclass.
 nuget_writeconfig() {
-	debug-print-function "${FUNCNAME[0]}" "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	case "${1}" in
 		"" ) die "${FUNCNAME[0]}: no directory/file path specified" ;;
diff --git a/eclass/out-of-source-utils.eclass b/eclass/out-of-source-utils.eclass
index 567d974449ea..b1b5fc05e37c 100644
--- a/eclass/out-of-source-utils.eclass
+++ b/eclass/out-of-source-utils.eclass
@@ -25,7 +25,7 @@ esac
 # @DESCRIPTION:
 # Run the given command in the directory pointed by BUILD_DIR.
 run_in_build_dir() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 	local ret
 
 	[[ ${#} -eq 0 ]] && die "${FUNCNAME}: no command specified."
diff --git a/eclass/postgres-multi.eclass b/eclass/postgres-multi.eclass
index 5f014389fd89..96aa30d89ad7 100644
--- a/eclass/postgres-multi.eclass
+++ b/eclass/postgres-multi.eclass
@@ -55,7 +55,7 @@ export _POSTGRES_INTERSECT_SLOTS=( )
 # appearance of @PG_SLOT@ in the command and arguments with value of
 # ${PG_SLOT}.
 _postgres-multi_multibuild_wrapper() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 	export PG_SLOT=${MULTIBUILD_VARIANT}
 	export PG_CONFIG=$(type -P pg_config${MULTIBUILD_VARIANT//./})
 	if [[ -n ${PKG_CONFIG_PATH} ]] ; then
diff --git a/eclass/postgres.eclass b/eclass/postgres.eclass
index 6ef6913c2dad..21490df1965e 100644
--- a/eclass/postgres.eclass
+++ b/eclass/postgres.eclass
@@ -136,7 +136,7 @@ postgres_check_slot() {
 # is required if pkg_setup() is declared in the ebuild.
 # Exports PG_SLOT, PG_CONFIG, and PKG_CONFIG_PATH.
 postgres_pkg_setup() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local compat_slot
 	local best_slot
diff --git a/eclass/python-any-r1.eclass b/eclass/python-any-r1.eclass
index 8796c3eddb68..0c01a49f9000 100644
--- a/eclass/python-any-r1.eclass
+++ b/eclass/python-any-r1.eclass
@@ -245,7 +245,7 @@ unset -f _python_any_set_globals
 # )
 # @CODE
 python_gen_any_dep() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local depstr=${1}
 	[[ ${depstr} ]] || die "No dependency string provided"
@@ -271,7 +271,7 @@ python_gen_any_dep() {
 #
 # This function will call python_check_deps() if defined.
 python_setup() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 	_python_sanity_checks
 
 	# support developer override
@@ -338,7 +338,7 @@ python_setup() {
 # In a binary package installs is a no-op. If you need Python in pkg_*
 # phases of a binary package, call python_setup directly.
 python-any-r1_pkg_setup() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	[[ ${MERGE_TYPE} != binary ]] && python_setup
 }
diff --git a/eclass/python-r1.eclass b/eclass/python-r1.eclass
index 28daaed1b463..18f4dadfdd37 100644
--- a/eclass/python-r1.eclass
+++ b/eclass/python-r1.eclass
@@ -242,7 +242,7 @@ unset -f _python_set_globals
 # Enforce the proper setting of PYTHON_TARGETS, if PYTHON_COMPAT_OVERRIDE
 # is not in effect. If it is, just warn that the flags will be ignored.
 _python_validate_useflags() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	if [[ ${PYTHON_COMPAT_OVERRIDE} ]]; then
 		if [[ ! ${_PYTHON_COMPAT_OVERRIDE_WARNED} ]]; then
@@ -282,7 +282,7 @@ _python_validate_useflags() {
 #
 # This is an internal function used to implement python_gen_cond_dep.
 _python_gen_usedep() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local impl matches=()
 
@@ -322,7 +322,7 @@ _python_gen_usedep() {
 # REQUIRED_USE="doc? ( || ( python_targets_python2_7 ) )"
 # @CODE
 python_gen_useflags() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local impl matches=()
 
@@ -366,7 +366,7 @@ python_gen_useflags() {
 #     dev-python/unittest2[python_targets_pypy?] )"
 # @CODE
 python_gen_cond_dep() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local impl matches=()
 	local dep=${1}
@@ -428,7 +428,7 @@ python_gen_cond_dep() {
 #     dev-python/pypy[xml(+)] ) )"
 # @CODE
 python_gen_impl_dep() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local impl matches=()
 	local PYTHON_REQ_USE=${1}
@@ -506,7 +506,7 @@ python_gen_impl_dep() {
 # )
 # @CODE
 python_gen_any_dep() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local depstr=${1}
 	shift
@@ -554,7 +554,7 @@ python_gen_any_dep() {
 # to implementation-specific build directory matching BUILD_DIR used by
 # python_foreach_abi().
 python_copy_sources() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local MULTIBUILD_VARIANTS
 	_python_obtain_impls
@@ -590,7 +590,7 @@ _python_obtain_impls() {
 # Initialize the environment for Python implementation selected
 # for multibuild.
 _python_multibuild_wrapper() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local -x EPYTHON PYTHON
 	local -x PATH=${PATH} PKG_CONFIG_PATH=${PKG_CONFIG_PATH}
@@ -616,7 +616,7 @@ _python_multibuild_wrapper() {
 # For each command being run, EPYTHON, PYTHON and BUILD_DIR are set
 # locally, and the former two are exported to the command environment.
 python_foreach_impl() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 	_python_sanity_checks
 
 	if [[ ${_DISTUTILS_R1_ECLASS} ]]; then
@@ -708,7 +708,7 @@ python_foreach_impl() {
 # }
 # @CODE
 python_setup() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 	_python_sanity_checks
 
 	local has_check_deps
@@ -774,7 +774,7 @@ python_setup() {
 # All specified files must start with a 'python' shebang. A file not
 # having a matching shebang will be refused.
 python_replicate_script() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	_python_replicate_script() {
 		local _PYTHON_FIX_SHEBANG_QUIET=1
diff --git a/eclass/python-single-r1.eclass b/eclass/python-single-r1.eclass
index d3cc4024de36..dc1700393274 100644
--- a/eclass/python-single-r1.eclass
+++ b/eclass/python-single-r1.eclass
@@ -269,7 +269,7 @@ unset -f _python_single_set_globals
 # REQUIRED_USE="doc? ( ^^ ( python_single_target_python2_7 ) )"
 # @CODE
 python_gen_useflags() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local impl matches=()
 
@@ -313,7 +313,7 @@ python_gen_useflags() {
 #     dev-python/unittest2[python_targets_pypy(-)?,...] )"
 # @CODE
 python_gen_cond_dep() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local impl matches=()
 
@@ -367,7 +367,7 @@ python_gen_cond_dep() {
 #     dev-python/pypy[xml(+)] ) )"
 # @CODE
 python_gen_impl_dep() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local impl
 	local matches=()
@@ -392,7 +392,7 @@ python_gen_impl_dep() {
 # Determine what the selected Python implementation is and set
 # the Python build environment up for it.
 python_setup() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 	_python_sanity_checks
 
 	unset EPYTHON
@@ -448,7 +448,7 @@ python_setup() {
 # @DESCRIPTION:
 # Runs python_setup.
 python-single-r1_pkg_setup() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	[[ ${MERGE_TYPE} != binary ]] && python_setup
 }
diff --git a/eclass/python-utils-r1.eclass b/eclass/python-utils-r1.eclass
index 7a133f1ff655..796be7ab456a 100644
--- a/eclass/python-utils-r1.eclass
+++ b/eclass/python-utils-r1.eclass
@@ -75,7 +75,7 @@ readonly _PYTHON_HISTORICAL_IMPLS
 # Verify whether the patterns passed to the eclass function are correct
 # (i.e. can match any valid implementation).  Dies on wrong pattern.
 _python_verify_patterns() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local impl pattern
 	for pattern; do
@@ -298,7 +298,7 @@ _python_impl_matches() {
 # PYTHON_SITEDIR. They are described more completely in the eclass
 # variable documentation.
 _python_export() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local impl var
 
@@ -483,7 +483,7 @@ _python_export() {
 # Obtain and print the 'stdlib' path for the given implementation. If no
 # implementation is provided, ${EPYTHON} will be used.
 python_get_stdlib() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	_python_export "${@}" PYTHON_STDLIB
 	echo "${PYTHON_STDLIB}"
@@ -496,7 +496,7 @@ python_get_stdlib() {
 # implementation. If no implementation is provided, ${EPYTHON} will
 # be used.
 python_get_sitedir() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	_python_export "${@}" PYTHON_SITEDIR
 	echo "${PYTHON_SITEDIR}"
@@ -508,7 +508,7 @@ python_get_sitedir() {
 # Obtain and print the include path for the given implementation. If no
 # implementation is provided, ${EPYTHON} will be used.
 python_get_includedir() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	_python_export "${@}" PYTHON_INCLUDEDIR
 	echo "${PYTHON_INCLUDEDIR}"
@@ -523,7 +523,7 @@ python_get_includedir() {
 # Please note that this function can be used with CPython only. Use
 # in another implementation will result in a fatal failure.
 python_get_library_path() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	_python_export "${@}" PYTHON_LIBPATH
 	echo "${PYTHON_LIBPATH}"
@@ -540,7 +540,7 @@ python_get_library_path() {
 # It requires Python and pkg-config installed, and therefore proper
 # build-time dependencies need be added to the ebuild.
 python_get_CFLAGS() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	_python_export "${@}" PYTHON_CFLAGS
 	echo "${PYTHON_CFLAGS}"
@@ -557,7 +557,7 @@ python_get_CFLAGS() {
 # It requires Python and pkg-config installed, and therefore proper
 # build-time dependencies need be added to the ebuild.
 python_get_LIBS() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	_python_export "${@}" PYTHON_LIBS
 	echo "${PYTHON_LIBS}"
@@ -574,7 +574,7 @@ python_get_LIBS() {
 # It requires Python installed, and therefore proper build-time
 # dependencies need be added to the ebuild.
 python_get_PYTHON_CONFIG() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	_python_export "${@}" PYTHON_CONFIG
 	echo "${PYTHON_CONFIG}"
@@ -587,7 +587,7 @@ python_get_PYTHON_CONFIG() {
 # implementation. If no implementation is provided, ${EPYTHON} will
 # be used.
 python_get_scriptdir() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	_python_export "${@}" PYTHON_SCRIPTDIR
 	echo "${PYTHON_SCRIPTDIR}"
@@ -600,7 +600,7 @@ python_get_scriptdir() {
 # paths). If no directories are provided, the default system paths
 # are used (prepended with ${D}).
 python_optimize() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	[[ ${EPYTHON} ]] || die 'No Python implementation set (EPYTHON is null).'
 
@@ -677,7 +677,7 @@ python_optimize() {
 # }
 # @CODE
 python_scriptinto() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	_PYTHON_SCRIPTROOT=${1}
 }
@@ -691,7 +691,7 @@ python_scriptinto() {
 # The executable will be wrapped properly for the Python implementation,
 # though no shebang mangling will be performed.
 python_doexe() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	[[ ${EBUILD_PHASE} != install ]] &&
 		die "${FUNCNAME} can only be used in src_install"
@@ -712,7 +712,7 @@ python_doexe() {
 # though no shebang mangling will be performed. It will be renamed
 # to <new-name>.
 python_newexe() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	[[ ${EBUILD_PHASE} != install ]] &&
 		die "${FUNCNAME} can only be used in src_install"
@@ -762,7 +762,7 @@ python_newexe() {
 # }
 # @CODE
 python_doscript() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	[[ ${EBUILD_PHASE} != install ]] &&
 		die "${FUNCNAME} can only be used in src_install"
@@ -789,7 +789,7 @@ python_doscript() {
 # }
 # @CODE
 python_newscript() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	[[ ${EBUILD_PHASE} != install ]] &&
 		die "${FUNCNAME} can only be used in src_install"
@@ -827,7 +827,7 @@ python_newscript() {
 # }
 # @CODE
 python_moduleinto() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	_PYTHON_MODULEROOT=${1}
 }
@@ -852,7 +852,7 @@ python_moduleinto() {
 # }
 # @CODE
 python_domodule() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	[[ ${EPYTHON} ]] || die 'No Python implementation set (EPYTHON is null).'
 
@@ -900,7 +900,7 @@ python_domodule() {
 # }
 # @CODE
 python_doheader() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	[[ ${EBUILD_PHASE} != install ]] &&
 		die "${FUNCNAME} can only be used in src_install"
@@ -932,7 +932,7 @@ python_doheader() {
 # setup will be done. If wrapper update is requested, the directory
 # shall be removed first.
 _python_wrapper_setup() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local workdir=${1:-${T}/${EPYTHON}}
 	local impl=${2:-${EPYTHON}}
@@ -1034,7 +1034,7 @@ _python_wrapper_setup() {
 # Python version (but not non-Python shebangs).  --quiet causes
 # the function not to list modified files verbosely.
 python_fix_shebang() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	[[ ${EPYTHON} ]] || die "${FUNCNAME}: EPYTHON unset (pkg_setup not called?)"
 
@@ -1154,7 +1154,7 @@ _python_check_locale_sanity() {
 # nothing if LC_ALL is defined, or if the current locale uses a UTF-8 charmap.
 # This may be used to work around the quirky open() behavior of python3.
 python_export_utf8_locale() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	# If the locale program isn't available, just return.
 	type locale &>/dev/null || return 0
@@ -1206,7 +1206,7 @@ python_export_utf8_locale() {
 # to be taken to run einstalldocs from the same directory
 # (usually ${S}).
 build_sphinx() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 	[[ ${#} -eq 1 ]] || die "${FUNCNAME} takes 1 arg: <directory>"
 
 	local dir=${1}
@@ -1252,7 +1252,7 @@ _python_check_EPYTHON() {
 # package sources that would block installed packages from being used
 # (and effectively e.g. make it impossible to load compiled extensions).
 _python_check_occluded_packages() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	[[ -z ${BUILD_DIR} || ! -d ${BUILD_DIR}/install ]] && return
 
@@ -1362,7 +1362,7 @@ _python_check_occluded_packages() {
 #
 # This command dies on failure and respects nonfatal.
 epytest() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	_python_check_EPYTHON
 	_python_check_occluded_packages
@@ -1490,7 +1490,7 @@ epytest() {
 #
 # This command dies on failure and respects nonfatal.
 eunittest() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	_python_check_EPYTHON
 	_python_check_occluded_packages
@@ -1515,7 +1515,7 @@ eunittest() {
 # code.  Checks whether the interpreter is installed, runs
 # python_check_deps() if declared.
 _python_run_check_deps() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local impl=${1}
 
@@ -1547,7 +1547,7 @@ _python_run_check_deps() {
 # The wrapper accepts multiple package specifications.  For the check
 # to succeed, *all* specified atoms must match.
 python_has_version() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local root_arg=( -b )
 	case ${1} in
@@ -1572,7 +1572,7 @@ python_has_version() {
 # @DESCRIPTION:
 # Perform additional environment sanity checks.
 _python_sanity_checks() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	[[ ${_PYTHON_SANITY_CHECKED} ]] && return
 
diff --git a/eclass/readme.gentoo-r1.eclass b/eclass/readme.gentoo-r1.eclass
index 4f1728da5b6f..02167a746f5a 100644
--- a/eclass/readme.gentoo-r1.eclass
+++ b/eclass/readme.gentoo-r1.eclass
@@ -54,7 +54,7 @@ esac
 # ${FILESDIR}/README.gentoo-${SLOT} also.
 # Usually called at src_install phase.
 readme.gentoo_create_doc() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	if [[ -n "${DOC_CONTENTS}" ]]; then
 		if [[ -n "${DISABLE_AUTOFORMATTING}" ]]; then
@@ -94,7 +94,7 @@ readme.gentoo_create_doc() {
 # rely on specific REPLACING_VERSIONS handling in your ebuild to print messages
 # when people update from versions still providing old message.
 readme.gentoo_print_elog() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	if [[ -z "${README_GENTOO_DOC_VALUE}" ]]; then
 		die "readme.gentoo_print_elog invoked without matching readme.gentoo_create_doc call!"
diff --git a/eclass/rebar-utils.eclass b/eclass/rebar-utils.eclass
index 5657908eb8e9..095223cd11a1 100644
--- a/eclass/rebar-utils.eclass
+++ b/eclass/rebar-utils.eclass
@@ -68,7 +68,7 @@ _rebar_find_dep() {
 # Coverage is not relevant in this context, so there's no harm to disable it,
 # although the issue should be fixed.
 rebar_disable_coverage() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local rebar_config="${1:-rebar.config}"
 
@@ -88,7 +88,7 @@ rebar_disable_coverage() {
 #
 # The function dies on failure.
 rebar_fix_include_path() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local pn="${1}"
 	local rebar_config="${2:-rebar.config}"
@@ -123,7 +123,7 @@ rebar_fix_include_path() {
 #
 # The function dies on failure.
 rebar_remove_deps() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local rebar_config="${1:-rebar.config}"
 
@@ -148,7 +148,7 @@ rebar_remove_deps() {
 #
 # The function dies on failure.
 rebar_set_vsn() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local version="${1:-${PV%_*}}"
 
diff --git a/eclass/rebar.eclass b/eclass/rebar.eclass
index 1e4e845a9adb..951e29b05a91 100644
--- a/eclass/rebar.eclass
+++ b/eclass/rebar.eclass
@@ -69,7 +69,7 @@ _rebar_find_dep() {
 # @DESCRIPTION:
 # Run rebar with verbose flag. Die on failure.
 erebar() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	(( $# > 0 )) || die "erebar: at least one target is required"
 
@@ -87,7 +87,7 @@ erebar() {
 # Existence of rebar.config is optional, but file description file must exist
 # at 'src/${PN}.app.src'.
 rebar_src_prepare() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	default
 	rebar_set_vsn
@@ -101,7 +101,7 @@ rebar_src_prepare() {
 # @DESCRIPTION:
 # Configure with ERL_LIBS set.
 rebar_src_configure() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local -x ERL_LIBS="${EPREFIX}$(get_erl_libs)"
 	default
@@ -111,7 +111,7 @@ rebar_src_configure() {
 # @DESCRIPTION:
 # Compile project with rebar.
 rebar_src_compile() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	erebar compile
 }
@@ -120,7 +120,7 @@ rebar_src_compile() {
 # @DESCRIPTION:
 # Run unit tests.
 rebar_src_test() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	erebar eunit
 }
@@ -132,7 +132,7 @@ rebar_src_test() {
 #
 # Function expects that project conforms to Erlang/OTP structure.
 rebar_src_install() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local bin
 	local dest="$(get_erl_libs)/${P}"
diff --git a/eclass/rebar3.eclass b/eclass/rebar3.eclass
index f6383b9c8cdd..f75a3718fdfd 100644
--- a/eclass/rebar3.eclass
+++ b/eclass/rebar3.eclass
@@ -76,7 +76,7 @@ _rebar_find_dep() {
 # @DESCRIPTION:
 # Run rebar with verbose flag. Die on failure.
 erebar3() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	(( $# > 0 )) || die "${FUNCNAME}: at least one target is required"
 
@@ -99,7 +99,7 @@ erebar3() {
 # Existence of rebar.config is optional, but file description file must exist
 # at 'src/${PN}.app.src'.
 rebar3_src_prepare() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	default
 	rebar_set_vsn
@@ -118,7 +118,7 @@ rebar3_src_prepare() {
 # @DESCRIPTION:
 # Configure with ERL_LIBS set.
 rebar3_src_configure() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local -x ERL_LIBS="${EPREFIX}$(get_erl_libs)"
 	default
@@ -128,7 +128,7 @@ rebar3_src_configure() {
 # @DESCRIPTION:
 # Compile project with rebar3.
 rebar3_src_compile() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	erebar3 as "${REBAR_PROFILE}" release --all
 }
@@ -137,7 +137,7 @@ rebar3_src_compile() {
 # @DESCRIPTION:
 # Run unit tests.
 rebar3_src_test() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	erebar3 eunit -v
 }
@@ -149,7 +149,7 @@ rebar3_src_test() {
 #
 # Function expects that project conforms to Erlang/OTP structure.
 rebar3_install_lib() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local dest="$(get_erl_libs)/${P}"
 	insinto "${dest}"
@@ -169,7 +169,7 @@ rebar3_install_lib() {
 #
 # Function expects that project conforms to Erlang/OTP structure.
 rebar3_src_install() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	pushd "_build/${REBAR_PROFILE}" >/dev/null || die
 	if [[ -d rel/${PN} ]]; then
diff --git a/eclass/ruby-fakegem.eclass b/eclass/ruby-fakegem.eclass
index 207ba42b9544..eb6257a50cf9 100644
--- a/eclass/ruby-fakegem.eclass
+++ b/eclass/ruby-fakegem.eclass
@@ -220,7 +220,7 @@ fi
 # This function returns the gems data directory for the ruby
 # implementation in question.
 ruby_fakegem_gemsdir() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local _gemsitedir=$(ruby_rbconfig_value 'sitelibdir')
 	_gemsitedir=${_gemsitedir//site_ruby/gems}
@@ -239,7 +239,7 @@ ruby_fakegem_gemsdir() {
 # @DESCRIPTION:
 # Installs the specified file(s) into the gems directory.
 ruby_fakegem_doins() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	(
 		insinto $(ruby_fakegem_gemsdir)/gems/${RUBY_FAKEGEM_NAME}-${RUBY_FAKEGEM_VERSION}
@@ -252,7 +252,7 @@ ruby_fakegem_doins() {
 # @DESCRIPTION:
 # Installs the specified file into the gems directory using the provided filename.
 ruby_fakegem_newins() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	(
 		# Since newins does not accept full paths but just basenames
@@ -273,7 +273,7 @@ ruby_fakegem_newins() {
 # by the RUBY_FAKEGEM_GEMSPEC variable, or generate one using
 # ruby_fakegem_genspec.
 ruby_fakegem_install_gemspec() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local gemspec="${T}"/${RUBY_FAKEGEM_NAME}-${_ruby_implementation}
 
@@ -302,7 +302,7 @@ ruby_fakegem_install_gemspec() {
 # RUBY_FAKEGEM_GEMSPEC. This file is eval'ed to produce a final specification
 # in a way similar to packaging the gemspec file.
 ruby_fakegem_gemspec_gemspec() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	${RUBY} --disable=did_you_mean -e "puts eval(File::open('$1').read).to_ruby" > $2
 }
@@ -314,7 +314,7 @@ ruby_fakegem_gemspec_gemspec() {
 # the metadata distributed by the gem itself. This is similar to how
 # rubygems creates an installation from a .gem file.
 ruby_fakegem_metadata_gemspec() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	${RUBY} --disable=did_you_mean -r yaml -e "puts Gem::Specification.from_yaml(File::open('$1', :encoding => 'UTF-8').read).to_ruby" > $2
 }
@@ -333,7 +333,7 @@ ruby_fakegem_metadata_gemspec() {
 # See RUBY_FAKEGEM_NAME and RUBY_FAKEGEM_VERSION for setting name and version.
 # See RUBY_FAKEGEM_REQUIRE_PATHS for setting extra require paths.
 ruby_fakegem_genspec() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	eqawarn "Generating generic fallback gemspec *without* dependencies"
 	eqawarn "This will only work when there are no runtime dependencies"
@@ -369,7 +369,7 @@ EOF
 # to inject additional ruby code into the wrapper. This may be useful to
 # e.g. force a specific version using the gem command.
 ruby_fakegem_binwrapper() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	(
 		local gembinary=$1
@@ -422,7 +422,7 @@ EOF
 # @DESCRIPTION:
 # Configure extensions defined in RUBY_FAKEGEM_EXTENSIONS, if any.
 each_fakegem_configure() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	tc-export PKG_CONFIG
 	for extension in "${RUBY_FAKEGEM_EXTENSIONS[@]}" ; do
@@ -434,7 +434,7 @@ each_fakegem_configure() {
 # @DESCRIPTION:
 # Run each_fakegem_configure for each ruby target
 each_ruby_configure() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	each_fakegem_configure
 }
@@ -444,7 +444,7 @@ each_ruby_configure() {
 # Build documentation for the package if indicated by the doc USE flag
 # and if there is a documentation task defined.
 all_fakegem_compile() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	if [[ -n ${RUBY_FAKEGEM_DOCDIR} ]] && use doc; then
 		case ${RUBY_FAKEGEM_RECIPE_DOC} in
@@ -466,7 +466,7 @@ all_fakegem_compile() {
 # @DESCRIPTION:
 # Compile extensions defined in RUBY_FAKEGEM_EXTENSIONS, if any.
 each_fakegem_compile() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	for extension in "${RUBY_FAKEGEM_EXTENSIONS[@]}" ; do
 		emake V=1 -C ${extension%/*}
@@ -479,7 +479,7 @@ each_fakegem_compile() {
 # @DESCRIPTION:
 # Run each_fakegem_compile for each ruby target
 each_ruby_compile() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	each_fakegem_compile
 }
@@ -488,7 +488,7 @@ each_ruby_compile() {
 # @DESCRIPTION:
 # Unpack the source archive, including support for unpacking gems.
 all_ruby_unpack() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	# Special support for extracting .gem files; the file need to be
 	# extracted twice and the mtime from the archive _has_ to be
@@ -533,7 +533,7 @@ all_ruby_unpack() {
 # @DESCRIPTION:
 # Compile the package.
 all_ruby_compile() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	all_fakegem_compile
 }
@@ -542,7 +542,7 @@ all_ruby_compile() {
 # @DESCRIPTION:
 # Run tests for the package for each ruby target if the test task is defined.
 each_fakegem_test() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	case ${RUBY_FAKEGEM_RECIPE_TEST} in
 		rake)
@@ -584,7 +584,7 @@ fi
 # installed. This is normally done as part of the extension
 # installation, but may be useful when we handle extensions manually.
 ruby_fakegem_extensions_installed() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	mkdir -p "${ED}$(ruby_fakegem_extensionsdir)" || die
 	touch "${ED}$(ruby_fakegem_extensionsdir)/gem.build_complete" || die
@@ -595,7 +595,7 @@ ruby_fakegem_extensions_installed() {
 # The directory where rubygems expects extensions for this package
 # version.
 ruby_fakegem_extensionsdir() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	# Using formula from ruby src/lib/rubygems/basic_specification.
 	extensions_dir=$(${RUBY} --disable=did_you_mean -e "puts File.join('extensions', Gem::Platform.local.to_s, Gem.extension_api_version)")
@@ -607,7 +607,7 @@ ruby_fakegem_extensionsdir() {
 # @DESCRIPTION:
 # Install the package for each ruby target.
 each_fakegem_install() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	ruby_fakegem_install_gemspec
 
@@ -634,7 +634,7 @@ each_fakegem_install() {
 # @DESCRIPTION:
 # Install the package for each target.
 each_ruby_install() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	each_fakegem_install
 }
@@ -643,7 +643,7 @@ each_ruby_install() {
 # @DESCRIPTION:
 # Install files common to all ruby targets.
 all_fakegem_install() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	if [[ -n ${RUBY_FAKEGEM_DOCDIR} ]] && use doc; then
 		for dir in ${RUBY_FAKEGEM_DOCDIR}; do
@@ -678,7 +678,7 @@ all_fakegem_install() {
 # @DESCRIPTION:
 # Install files common to all ruby targets.
 all_ruby_install() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	all_fakegem_install
 }
diff --git a/eclass/ruby-ng-gnome2.eclass b/eclass/ruby-ng-gnome2.eclass
index ed4fdd91a49f..d268e4bd742d 100644
--- a/eclass/ruby-ng-gnome2.eclass
+++ b/eclass/ruby-ng-gnome2.eclass
@@ -76,7 +76,7 @@ all_ruby_prepare() {
 # @DESCRIPTION:
 # Run the configure script in the subbinding for each specific ruby target.
 each_ruby_configure() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	[[ -e extconf.rb ]] || return
 
@@ -87,7 +87,7 @@ each_ruby_configure() {
 # @DESCRIPTION:
 # Compile the C bindings in the subbinding for each specific ruby target.
 each_ruby_compile() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	[[ -e Makefile ]] || return
 
@@ -107,7 +107,7 @@ each_ruby_compile() {
 # @DESCRIPTION:
 # Install the files in the subbinding for each specific ruby target.
 each_ruby_install() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	if [[ -e Makefile ]]; then
 		# Create the directories, or the package will create them as files.
@@ -124,7 +124,7 @@ each_ruby_install() {
 # @DESCRIPTION:
 # Install the files common to all ruby targets.
 all_ruby_install() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	for doc in ../AUTHORS ../NEWS ChangeLog README; do
 		[[ -s ${doc} ]] && dodoc $doc
@@ -141,7 +141,7 @@ all_ruby_install() {
 # @DESCRIPTION:
 # Run the tests for this package.
 each_ruby_test() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	[[ -e test/run-test.rb ]] || return
 
diff --git a/eclass/ruby-ng.eclass b/eclass/ruby-ng.eclass
index 2a552094f60f..f3745b5d3eab 100644
--- a/eclass/ruby-ng.eclass
+++ b/eclass/ruby-ng.eclass
@@ -90,7 +90,7 @@ S="${WORKDIR}"
 # Set `comparator' and `version' to include a comparator (=, >=, etc.) and a
 # version string to the returned string
 ruby_implementation_depend() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	_ruby_implementation_depend $1
 }
@@ -132,7 +132,7 @@ _ruby_get_all_impls() {
 # ruby_add_bdepend(), but may also be useful in an ebuild to specify
 # more complex dependencies.
 ruby_samelib() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	_ruby_set_globals_invalidate_if_stale
 
@@ -151,7 +151,7 @@ ruby_samelib() {
 # Not all implementations have the same command basename as the
 # target; This function translate between the two
 ruby_implementation_command() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local _ruby_name=$1
 
@@ -212,7 +212,7 @@ _ruby_wrap_conditions() {
 # Note: runtime dependencies are also added as build-time test
 # dependencies.
 ruby_add_rdepend() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	case $# in
 		1) ;;
@@ -248,7 +248,7 @@ ruby_add_rdepend() {
 # dependencies instead of setting DEPEND or BDEPEND yourself. The list
 # of atoms uses the same syntax as normal dependencies.
 ruby_add_bdepend() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	case $# in
 		1) ;;
@@ -271,7 +271,7 @@ ruby_add_bdepend() {
 # @DESCRIPTION:
 # Adds the specified dependencies to DEPEND, similar to ruby_add_bdepend.
 ruby_add_depend() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	case $# in
 		1) ;;
@@ -288,7 +288,7 @@ ruby_add_depend() {
 # @DESCRIPTION:
 # Gets an array of ruby use targets enabled by the user
 ruby_get_use_implementations() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	_ruby_set_globals_invalidate_if_stale
 
@@ -303,7 +303,7 @@ ruby_get_use_implementations() {
 # @DESCRIPTION:
 # Gets an array of ruby use targets that the ebuild sets
 ruby_get_use_targets() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	_ruby_set_globals_invalidate_if_stale
 	_ruby_get_use_targets
@@ -316,7 +316,7 @@ ruby_get_use_targets() {
 # Gets an array of ruby use targets that the ebuild sets
 _RUBY_GET_USE_TARGETS=""
 _ruby_get_use_targets() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	_ruby_set_globals_invalidate_if_stale
 
@@ -343,7 +343,7 @@ _ruby_get_use_targets() {
 # RDEPEND="${DEPEND}"
 _RUBY_IMPLEMENTATIONS_DEPEND=""
 ruby_implementations_depend() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	_ruby_set_globals_invalidate_if_stale
 	_ruby_implementations_depend
@@ -472,7 +472,7 @@ _ruby_each_implementation() {
 # @DESCRIPTION:
 # Check whether at least one ruby target implementation is present.
 ruby-ng_pkg_setup() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	# This only checks that at least one implementation is present
 	# before doing anything; by leaving the parameters empty we know
@@ -484,7 +484,7 @@ ruby-ng_pkg_setup() {
 # @DESCRIPTION:
 # Unpack the source archive.
 ruby-ng_src_unpack() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	mkdir "${WORKDIR}"/all
 	pushd "${WORKDIR}"/all &>/dev/null || die
@@ -522,7 +522,7 @@ _ruby_source_copy() {
 # Apply patches and prepare versions for each ruby target
 # implementation. Also carry out common clean up tasks.
 ruby-ng_src_prepare() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	# Way too many Ruby packages are prepared on OSX without removing
 	# the extra data forks, we do it here to avoid repeating it for
@@ -546,7 +546,7 @@ ruby-ng_src_prepare() {
 # @DESCRIPTION:
 # Configure the package.
 ruby-ng_src_configure() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	if type each_ruby_configure &>/dev/null; then
 		_ruby_each_implementation each_ruby_configure
@@ -560,7 +560,7 @@ ruby-ng_src_configure() {
 # @DESCRIPTION:
 # Compile the package.
 ruby-ng_src_compile() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	if type each_ruby_compile &>/dev/null; then
 		_ruby_each_implementation each_ruby_compile
@@ -574,7 +574,7 @@ ruby-ng_src_compile() {
 # @DESCRIPTION:
 # Run tests for the package.
 ruby-ng_src_test() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	if type each_ruby_test &>/dev/null; then
 		_ruby_each_implementation each_ruby_test
@@ -617,7 +617,7 @@ _each_ruby_check_install() {
 # @DESCRIPTION:
 # Install the package for each ruby target implementation.
 ruby-ng_src_install() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	if type each_ruby_install &>/dev/null; then
 		_ruby_each_implementation each_ruby_install
@@ -634,7 +634,7 @@ ruby-ng_src_install() {
 # @USAGE: rbconfig item
 # @RETURN: Returns the value of the given rbconfig item of the Ruby interpreter in ${RUBY}.
 ruby_rbconfig_value() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	echo $(${RUBY} --disable=did_you_mean -rrbconfig -e "puts RbConfig::CONFIG['$1']" || die "Could not read ruby configuration for '${1}'")
 }
@@ -644,7 +644,7 @@ ruby_rbconfig_value() {
 # @DESCRIPTION:
 # Installs the specified file(s) into the sitelibdir of the Ruby interpreter in ${RUBY}.
 doruby() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	[[ -z ${RUBY} ]] && die "\$RUBY is not set"
 	( # don't want to pollute calling env
@@ -658,7 +658,7 @@ doruby() {
 # @FUNCTION: ruby_get_libruby
 # @RETURN: The location of libruby*.so belonging to the Ruby interpreter in ${RUBY}.
 ruby_get_libruby() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	${RUBY} -rrbconfig -e 'puts File.join(RbConfig::CONFIG["libdir"], RbConfig::CONFIG["LIBRUBY"])'
 }
@@ -666,7 +666,7 @@ ruby_get_libruby() {
 # @FUNCTION: ruby_get_hdrdir
 # @RETURN: The location of the header files belonging to the Ruby interpreter in ${RUBY}.
 ruby_get_hdrdir() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local rubyhdrdir=$(ruby_rbconfig_value 'rubyhdrdir')
 
@@ -680,7 +680,7 @@ ruby_get_hdrdir() {
 # @FUNCTION: ruby_get_version
 # @RETURN: The version of the Ruby interpreter in ${RUBY}, or what 'ruby' points to.
 ruby_get_version() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local ruby=${RUBY:-$(type -p ruby 2>/dev/null)}
 
@@ -690,7 +690,7 @@ ruby_get_version() {
 # @FUNCTION: ruby_get_implementation
 # @RETURN: The implementation of the Ruby interpreter in ${RUBY}, or what 'ruby' points to.
 ruby_get_implementation() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local ruby=${RUBY:-$(type -p ruby 2>/dev/null)}
 
@@ -713,7 +713,7 @@ ruby_get_implementation() {
 # rspec version that must be executed. It defaults to 2 for historical
 # compatibility.
 ruby-ng_rspec() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local version=${RSPEC_VERSION-2}
 	local files="$@"
@@ -755,7 +755,7 @@ ruby-ng_rspec() {
 # This is simply a wrapper around the cucumber command (executed by $RUBY})
 # which also respects TEST_VERBOSE and NOCOLOR environment variables.
 ruby-ng_cucumber() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	if [[ "${DEPEND}${BDEPEND}" != *"dev-util/cucumber"* ]]; then
 		ewarn "Missing test dependency dev-util/cucumber"
@@ -788,7 +788,7 @@ ruby-ng_cucumber() {
 # This is simply a wrapper around the sus-parallel command (executed by $RUBY})
 # which also respects TEST_VERBOSE and NOCOLOR environment variables.
 ruby-ng_sus() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	if [[ "${DEPEND}${BDEPEND}" != *"dev-ruby/sus"* ]]; then
 		ewarn "Missing test dependency dev-ruby/sus"
@@ -816,7 +816,7 @@ ruby-ng_sus() {
 # their script and we installed a broken wrapper for a while.
 # This also respects TEST_VERBOSE and NOCOLOR environment variables.
 ruby-ng_testrb-2() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	if [[ "${DEPEND}${BDEPEND}" != *"dev-ruby/test-unit"* ]]; then
 		ewarn "Missing test dependency dev-ruby/test-unit"
diff --git a/eclass/scons-utils.eclass b/eclass/scons-utils.eclass
index b8663d34b1a2..4f5e6962f43e 100644
--- a/eclass/scons-utils.eclass
+++ b/eclass/scons-utils.eclass
@@ -132,7 +132,7 @@ fi
 escons() {
 	local ret
 
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	if [[ ! ${EPYTHON} ]]; then
 		eerror "EPYTHON is unset while calling escons. This most likely means that"
diff --git a/eclass/secureboot.eclass b/eclass/secureboot.eclass
index 4459b0341845..52a7a636ddd2 100644
--- a/eclass/secureboot.eclass
+++ b/eclass/secureboot.eclass
@@ -74,7 +74,7 @@ _SECUREBOOT_ECLASS=1
 # If USE=secureboot is enabled die if the required user variables are unset
 # and die if the keys can't be found.
 _secureboot_die_if_unset() {
-	debug-print-function ${FUNCNAME[0]} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 	use secureboot || return
 
 	if [[ -z ${SECUREBOOT_SIGN_KEY} || -z ${SECUREBOOT_SIGN_CERT} ]]; then
@@ -99,7 +99,7 @@ _secureboot_die_if_unset() {
 # @DESCRIPTION:
 # Checks if required user variables are set before starting the build
 secureboot_pkg_setup() {
-	debug-print-function ${FUNCNAME[0]} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 	use secureboot || return
 
 	# If we are merging a binary then the files in this binary
@@ -117,7 +117,7 @@ secureboot_pkg_setup() {
 # If no output file is specified the output file will be the same
 # as the input file, i.e. the file will be overwritten.
 secureboot_sign_efi_file() {
-	debug-print-function ${FUNCNAME[0]} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 	use secureboot || return
 
 	local input_file=${1}
@@ -153,7 +153,7 @@ secureboot_sign_efi_file() {
 # By default signed files gain the .signed suffix. If the --in-place
 # argument is given the efi files are replaced with a signed version in place.
 secureboot_auto_sign() {
-	debug-print-function ${FUNCNAME[0]} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 	use secureboot || return
 
 	[[ ${EBUILD_PHASE} == install ]] ||
diff --git a/eclass/shell-completion.eclass b/eclass/shell-completion.eclass
index badda02f8d3f..caccdee7b19b 100644
--- a/eclass/shell-completion.eclass
+++ b/eclass/shell-completion.eclass
@@ -43,7 +43,7 @@ _shell-completion_get_zshcompdir() {
 # @FUNCTION: get_fishcompdir
 # @RETURN: the fish completions directory (with EPREFIX)
 get_fishcompdir() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	echo "${EPREFIX}$(_shell-completion_get_fishcompdir)"
 }
@@ -51,7 +51,7 @@ get_fishcompdir() {
 # @FUNCTION: get_zshcompdir
 # @RETURN: the zsh completions directory (with EPREFIX)
 get_zshcompdir() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	echo "${EPREFIX}$(_shell-completion_get_zshcompdir)"
 }
@@ -61,7 +61,7 @@ get_zshcompdir() {
 # @DESCRIPTION:
 # Install fish completion files passed as args.
 dofishcomp() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	(
 		insopts -m 0644
@@ -75,7 +75,7 @@ dofishcomp() {
 # @DESCRIPTION:
 # Install zsh completion files passed as args.
 dozshcomp() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	(
 		insopts -m 0644
@@ -89,7 +89,7 @@ dozshcomp() {
 # @DESCRIPTION:
 # Install fish file under a new name.
 newfishcomp() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	(
 		insopts -m 0644
@@ -103,7 +103,7 @@ newfishcomp() {
 # @DESCRIPTION:
 # Install zsh file under a new name.
 newzshcomp() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	(
 		insopts -m 0644
diff --git a/eclass/systemd.eclass b/eclass/systemd.eclass
index 95fe64f4414f..f908ad688d9d 100644
--- a/eclass/systemd.eclass
+++ b/eclass/systemd.eclass
@@ -75,7 +75,7 @@ _systemd_unprefix() {
 # ${D}).  This function always succeeds, even if systemd is not
 # installed.
 systemd_get_systemunitdir() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	_systemd_get_dir systemdsystemunitdir /lib/systemd/system
 }
@@ -86,7 +86,7 @@ systemd_get_systemunitdir() {
 # ${D}). This function always succeeds, even if systemd is not
 # installed.
 systemd_get_userunitdir() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	_systemd_get_dir systemduserunitdir /usr/lib/systemd/user
 }
@@ -97,7 +97,7 @@ systemd_get_userunitdir() {
 # ${D}). This function always succeeds, even if systemd is not
 # installed.
 systemd_get_utildir() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	_systemd_get_dir systemdutildir /lib/systemd
 }
@@ -107,7 +107,7 @@ systemd_get_utildir() {
 # Output the path for the systemd system generator directory (not including
 # ${D}). This function always succeeds, even if systemd is not installed.
 systemd_get_systemgeneratordir() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	_systemd_get_dir systemdsystemgeneratordir /lib/systemd/system-generators
 }
@@ -117,7 +117,7 @@ systemd_get_systemgeneratordir() {
 # Output the path for the systemd system preset directory (not including
 # ${D}). This function always succeeds, even if systemd is not installed.
 systemd_get_systempresetdir() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	_systemd_get_dir systemdsystempresetdir /lib/systemd/system-preset
 }
@@ -126,7 +126,7 @@ systemd_get_systempresetdir() {
 # @DESCRIPTION:
 # Output the path for the system sleep directory.
 systemd_get_sleepdir() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 	_systemd_get_dir systemdsleepdir /lib/systemd/system-sleep
 }
 
@@ -135,7 +135,7 @@ systemd_get_sleepdir() {
 # @DESCRIPTION:
 # Install systemd unit(s). Uses doins, thus it is fatal.
 systemd_dounit() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	(
 		insopts -m 0644
@@ -149,7 +149,7 @@ systemd_dounit() {
 # @DESCRIPTION:
 # Install systemd unit with a new name. Uses newins, thus it is fatal.
 systemd_newunit() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	(
 		insopts -m 0644
@@ -163,7 +163,7 @@ systemd_newunit() {
 # @DESCRIPTION:
 # Install systemd user unit(s). Uses doins, thus it is fatal.
 systemd_douserunit() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	(
 		insopts -m 0644
@@ -178,7 +178,7 @@ systemd_douserunit() {
 # Install systemd user unit with a new name. Uses newins, thus it
 # is fatal.
 systemd_newuserunit() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	(
 		insopts -m 0644
@@ -195,7 +195,7 @@ systemd_newuserunit() {
 # <conf-file> with the .conf suffix stripped is used
 # (e.g. foo.service.conf -> foo.service.d/00gentoo.conf).
 systemd_install_serviced() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local src=${1}
 	local service=${2}
@@ -233,7 +233,7 @@ systemd_install_serviced() {
 # 	RestartSec=120
 # EOF
 systemd_install_dropin() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local basedir
 	if [[ $# -ge 1 ]] && [[ $1 == "--user" ]]; then
@@ -265,7 +265,7 @@ systemd_install_dropin() {
 # Enable service in desired target, e.g. install a symlink for it.
 # Uses dosym, thus it is fatal.
 systemd_enable_service() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	[[ ${#} -eq 2 ]] || die "Synopsis: systemd_enable_service target service"
 
@@ -290,7 +290,7 @@ systemd_enable_service() {
 #
 # Doc: https://www.freedesktop.org/wiki/Software/systemd/timedated/
 systemd_enable_ntpunit() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 	if [[ ${#} -lt 2 ]]; then
 		die "Usage: systemd_enable_ntpunit <NN-name> <service>..."
 	fi
@@ -335,7 +335,7 @@ systemd_enable_ntpunit() {
 #
 # See: https://www.freedesktop.org/wiki/Software/systemd/catalog
 systemd_update_catalog() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	[[ ${EBUILD_PHASE} == post* ]] \
 		|| die "${FUNCNAME} disallowed during ${EBUILD_PHASE_FUNC:-${EBUILD_PHASE}}"
@@ -365,7 +365,7 @@ systemd_update_catalog() {
 #
 # See: man sd_booted
 systemd_is_booted() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	[[ -d /run/systemd/system ]]
 	local ret=${?}
diff --git a/eclass/tmpfiles.eclass b/eclass/tmpfiles.eclass
index aed792adad1c..f543eaf4eb1d 100644
--- a/eclass/tmpfiles.eclass
+++ b/eclass/tmpfiles.eclass
@@ -76,7 +76,7 @@ fi
 # @DESCRIPTION:
 # Install one or more tmpfiles.d files into /usr/lib/tmpfiles.d.
 dotmpfiles() {
-	debug-print-function "${FUNCNAME}" "$@"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local f
 	for f; do
@@ -97,7 +97,7 @@ dotmpfiles() {
 # @DESCRIPTION:
 # Install a tmpfiles.d file in /usr/lib/tmpfiles.d under a new name.
 newtmpfiles() {
-	debug-print-function "${FUNCNAME}" "$@"
+	debug-print-function ${FUNCNAME} "$@"
 
 	if [[ $2 != *.conf ]]; then
 		die "tmpfiles.d files must end with .conf"
@@ -116,7 +116,7 @@ newtmpfiles() {
 # Call a tmpfiles.d implementation to create new volatile and temporary
 # files and directories.
 tmpfiles_process() {
-	debug-print-function "${FUNCNAME}" "$@"
+	debug-print-function ${FUNCNAME} "$@"
 
 	[[ ${EBUILD_PHASE} == postinst ]] || die "${FUNCNAME}: Only valid in pkg_postinst"
 	[[ ${#} -gt 0 ]] || die "${FUNCNAME}: Must specify at least one filename"
diff --git a/eclass/tree-sitter-grammar.eclass b/eclass/tree-sitter-grammar.eclass
index 10f29b8a0835..499f1c7259a0 100644
--- a/eclass/tree-sitter-grammar.eclass
+++ b/eclass/tree-sitter-grammar.eclass
@@ -87,7 +87,7 @@ _get_tsg_abi_ver() {
 }
 
 tree-sitter-grammar_src_prepare() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	default
 
@@ -102,7 +102,7 @@ tree-sitter-grammar_src_prepare() {
 }
 
 tree-sitter-grammar_src_configure() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local binding
 	for binding in "${TS_BINDINGS[@]}"; do
@@ -156,7 +156,7 @@ _tree-sitter-grammar_legacy_compile() {
 }
 
 tree-sitter-grammar_src_compile() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	# legacy grammars don't have a pyproject.toml
 	if [[ -f "${S}/pyproject.toml" ]]; then
@@ -186,13 +186,13 @@ tree-sitter-grammar_src_compile() {
 # Runs the Tree Sitter parser's test suite.
 # See: https://tree-sitter.github.io/tree-sitter/creating-parsers#command-test
 tree-sitter-grammar_src_test() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	tree-sitter test || die "Test suite failed"
 }
 
 tree-sitter-grammar_src_install() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	# legacy grammars don't have a pyproject.toml
 	if [[ -f "${S}/pyproject.toml" ]]; then
diff --git a/eclass/udev.eclass b/eclass/udev.eclass
index 2c3ef38a3626..9867c68d5836 100644
--- a/eclass/udev.eclass
+++ b/eclass/udev.eclass
@@ -67,7 +67,7 @@ _udev_get_udevdir() {
 # @DESCRIPTION:
 # Use the short version $(get_udevdir) instead!
 udev_get_udevdir() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	eerror "This ebuild should be using the get_udevdir() function instead of the deprecated udev_get_udevdir()"
 	die "Deprecated function call: udev_get_udevdir(), please report to (overlay) maintainers."
@@ -79,7 +79,7 @@ udev_get_udevdir() {
 # This function always succeeds, even if udev is not installed.
 # The fallback value is set to /lib/udev
 get_udevdir() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	echo "$(_udev_get_udevdir)"
 }
@@ -89,7 +89,7 @@ get_udevdir() {
 # @DESCRIPTION:
 # Install udev rule(s). Uses doins, thus it is fatal.
 udev_dorules() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	(
 		insopts -m 0644
@@ -103,7 +103,7 @@ udev_dorules() {
 # @DESCRIPTION:
 # Install udev rule with a new name. Uses newins, thus it is fatal.
 udev_newrules() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	(
 		insopts -m 0644
diff --git a/eclass/vcs-clean.eclass b/eclass/vcs-clean.eclass
index b9282facd83c..8558d9998d34 100644
--- a/eclass/vcs-clean.eclass
+++ b/eclass/vcs-clean.eclass
@@ -23,7 +23,7 @@ esac
 # Remove CVS directories and .cvs* files recursively.  Useful when a
 # source tarball contains internal CVS directories.  Defaults to ${PWD}.
 ecvs_clean() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	[[ $# -eq 0 ]] && set -- .
 	find "$@" '(' -type d -name 'CVS' -prune -o -type f -name '.cvs*' ')' \
@@ -36,7 +36,7 @@ ecvs_clean() {
 # Remove .svn directories recursively.  Useful when a source tarball
 # contains internal Subversion directories.  Defaults to ${PWD}.
 esvn_clean() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	[[ $# -eq 0 ]] && set -- .
 	find "$@" -type d -name '.svn' -prune -exec rm -rf '{}' + || die
@@ -48,7 +48,7 @@ esvn_clean() {
 # Remove .git* directories recursively.  Useful when a source tarball
 # contains internal Git directories.  Defaults to ${PWD}.
 egit_clean() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	[[ $# -eq 0 ]] && set -- .
 	find "$@" -type d -name '.git*' -prune -exec rm -rf '{}' + || die
diff --git a/eclass/vcs-snapshot.eclass b/eclass/vcs-snapshot.eclass
index 14b9a8dd22ff..998fe348a2ab 100644
--- a/eclass/vcs-snapshot.eclass
+++ b/eclass/vcs-snapshot.eclass
@@ -57,7 +57,7 @@ _VCS_SNAPSHOT_ECLASS=1
 # local names. Other archive types will be passed down to regular
 # unpack.
 vcs-snapshot_src_unpack() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local renamed_any=
 	local f
diff --git a/eclass/vim-doc.eclass b/eclass/vim-doc.eclass
index e87310319c7d..ad595c5a67c6 100644
--- a/eclass/vim-doc.eclass
+++ b/eclass/vim-doc.eclass
@@ -29,7 +29,7 @@ esac
 # @DESCRIPTION:
 # Update the documentation tags in the versioned Vim directory.
 update_vim_helptags() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local vimfiles helpfile files vim d
 
diff --git a/eclass/vim-plugin.eclass b/eclass/vim-plugin.eclass
index 8c36f42ba277..d18e2ef8ef5f 100644
--- a/eclass/vim-plugin.eclass
+++ b/eclass/vim-plugin.eclass
@@ -46,7 +46,7 @@ if [[ ${_DEFINE_VIM_PLUGIN_SRC_PREPARE} ]]; then
 # other packages.
 # Note that this function is only defined and exported in EAPIs >= 8.
 vim-plugin_src_prepare() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	default_src_prepare
 
@@ -90,7 +90,7 @@ _VIM_PLUGIN_ALLOWED_DIRS=(
 # }
 # @CODE
 vim-plugin_src_install() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	# Install non-vim-help-docs
 	einstalldocs
@@ -124,7 +124,7 @@ vim-plugin_src_install() {
 #
 # * display_vim_plugin_help
 vim-plugin_pkg_postinst() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	update_vim_helptags # from vim-doc
 	update_vim_afterscripts	# see below
@@ -137,7 +137,7 @@ vim-plugin_pkg_postinst() {
 # This function calls the update_vim_helptags and update_vim_afterscripts
 # functions and eventually removes a bunch of empty directories.
 vim-plugin_pkg_postrm() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	update_vim_helptags # from vim-doc
 	update_vim_afterscripts	# see below
@@ -154,7 +154,7 @@ vim-plugin_pkg_postrm() {
 # Creates scripts in /usr/share/vim/vimfiles/after/*
 # comprised of the snippets in /usr/share/vim/vimfiles/after/*/*.d
 update_vim_afterscripts() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local d f afterdir="${EROOT}"/usr/share/vim/vimfiles/after
 
@@ -193,7 +193,7 @@ update_vim_afterscripts() {
 # extra message regarding enabling filetype plugins is displayed if
 # VIM_PLUGIN_MESSAGES includes the word "filetype".
 display_vim_plugin_help() {
-	debug-print-function ${FUNCNAME} "${@}"
+	debug-print-function ${FUNCNAME} "$@"
 
 	local h
 
diff --git a/eclass/webapp.eclass b/eclass/webapp.eclass
index 19fa9590707c..ded66fa7f671 100644
--- a/eclass/webapp.eclass
+++ b/eclass/webapp.eclass
@@ -62,7 +62,7 @@ WEBAPP_CLEANER="${EROOT}/usr/sbin/webapp-cleaner"
 # Load the config file /etc/vhosts/webapp-config
 # Supports both the old bash version, and the new python version
 webapp_read_config() {
-	debug-print-function $FUNCNAME $*
+	debug-print-function ${FUNCNAME} "$@"
 
 	if has_version '>=app-admin/webapp-config-1.50'; then
 		ENVVAR=$(${WEBAPP_CONFIG} --query ${PN} ${PVR}) || die "Could not read settings from webapp-config!"
@@ -79,7 +79,7 @@ webapp_read_config() {
 
 # Check whether a specified file exists in the given directory (`.' by default)
 webapp_checkfileexists() {
-	debug-print-function $FUNCNAME $*
+	debug-print-function ${FUNCNAME} "$@"
 
 	local my_prefix=${2:+${2}/}
 
@@ -92,12 +92,12 @@ webapp_checkfileexists() {
 }
 
 webapp_check_installedat() {
-	debug-print-function $FUNCNAME $*
+	debug-print-function ${FUNCNAME} "$@"
 	${WEBAPP_CONFIG} --show-installed -h localhost -d "${INSTALL_DIR}" 2> /dev/null
 }
 
 webapp_getinstalltype() {
-	debug-print-function $FUNCNAME $*
+	debug-print-function ${FUNCNAME} "$@"
 
 	if ! has vhosts ${IUSE} || use vhosts; then
 		return
@@ -174,7 +174,7 @@ need_httpd_fastcgi() {
 # @DESCRIPTION:
 # Mark a file config-protected for a web-based application.
 webapp_configfile() {
-	debug-print-function $FUNCNAME $*
+	debug-print-function ${FUNCNAME} "$@"
 
 	local m
 	for m in "$@"; do
@@ -197,7 +197,7 @@ webapp_configfile() {
 # Install a script that will run after a virtual copy is created, and
 # before a virtual copy has been removed.
 webapp_hook_script() {
-	debug-print-function $FUNCNAME $*
+	debug-print-function ${FUNCNAME} "$@"
 
 	webapp_checkfileexists "${1}"
 
@@ -211,7 +211,7 @@ webapp_hook_script() {
 # @DESCRIPTION:
 # Install a text file containing post-installation instructions.
 webapp_postinst_txt() {
-	debug-print-function $FUNCNAME $*
+	debug-print-function ${FUNCNAME} "$@"
 
 	webapp_checkfileexists "${2}"
 
@@ -224,7 +224,7 @@ webapp_postinst_txt() {
 # @DESCRIPTION:
 # Install a text file containing post-upgrade instructions.
 webapp_postupgrade_txt() {
-	debug-print-function $FUNCNAME $*
+	debug-print-function ${FUNCNAME} "$@"
 
 	webapp_checkfileexists "${2}"
 
@@ -234,7 +234,7 @@ webapp_postupgrade_txt() {
 
 # helper for webapp_serverowned()
 _webapp_serverowned() {
-	debug-print-function $FUNCNAME $*
+	debug-print-function ${FUNCNAME} "$@"
 
 	webapp_checkfileexists "${1}" "${D}"
 	local my_file
@@ -253,7 +253,7 @@ _webapp_serverowned() {
 # The ownership of the file is NOT set until the application is installed using
 # the webapp-config tool. If -R is given directories are handled recursively.
 webapp_serverowned() {
-	debug-print-function $FUNCNAME $*
+	debug-print-function ${FUNCNAME} "$@"
 
 	local m
 	if [[ "${1}" == "-R" ]]; then
@@ -280,7 +280,7 @@ webapp_serverowned() {
 # used by default. Note: this function will automagically prepend $1 to the
 # front of your config file's name.
 webapp_server_configfile() {
-	debug-print-function $FUNCNAME $*
+	debug-print-function ${FUNCNAME} "$@"
 
 	webapp_checkfileexists "${2}"
 
@@ -303,7 +303,7 @@ webapp_server_configfile() {
 # If a version is given the script should upgrade the database schema from
 # the given version to $PVR.
 webapp_sqlscript() {
-	debug-print-function $FUNCNAME $*
+	debug-print-function ${FUNCNAME} "$@"
 
 	webapp_checkfileexists "${2}"
 
@@ -330,7 +330,7 @@ webapp_sqlscript() {
 # You need to call this function in src_install() BEFORE anything else has run.
 # For now we just create required webapp-config directories.
 webapp_src_preinst() {
-	debug-print-function $FUNCNAME $*
+	debug-print-function ${FUNCNAME} "$@"
 
 	# sanity checks, to catch bugs in the ebuild
 	if [[ ! -f "${T}/${SETUP_CHECK_FILE}" ]]; then
@@ -371,7 +371,7 @@ webapp_src_preinst() {
 # You need to call this function BEFORE anything else has run in your custom
 # pkg_setup().
 webapp_pkg_setup() {
-	debug-print-function $FUNCNAME $*
+	debug-print-function ${FUNCNAME} "$@"
 
 	# to test whether or not the ebuild has correctly called this function
 	# we add an empty file to the filesystem
@@ -432,7 +432,7 @@ webapp_pkg_setup() {
 # You need to call this function AFTER everything else has run in your custom
 # src_install().
 webapp_src_install() {
-	debug-print-function $FUNCNAME $*
+	debug-print-function ${FUNCNAME} "$@"
 
 	# to test whether or not the ebuild has correctly called this function
 	# we add an empty file to the filesystem
@@ -460,7 +460,7 @@ webapp_src_install() {
 # You need to call this function AFTER everything else has run in your custom
 # pkg_postinst().
 webapp_pkg_postinst() {
-	debug-print-function $FUNCNAME $*
+	debug-print-function ${FUNCNAME} "$@"
 
 	webapp_read_config
 
@@ -539,7 +539,7 @@ webapp_pkg_postinst() {
 # remove all installed copies of this web application. Otherwise instruct the
 # user to manually remove those copies. See bug #136959.
 webapp_pkg_prerm() {
-	debug-print-function $FUNCNAME $*
+	debug-print-function ${FUNCNAME} "$@"
 
 	local my_output=
 	my_output="$(${WEBAPP_CONFIG} --list-installs ${PN} ${PVR})"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-08 15:32 David Seifert
  0 siblings, 0 replies; 6663+ messages in thread
From: David Seifert @ 2024-10-08 15:32 UTC (permalink / raw
  To: gentoo-commits
commit:     bb1b0ac3768d755253ac8dbe2b7598dd73998bdf
Author:     David Seifert <soap <AT> gentoo <DOT> org>
AuthorDate: Tue Oct  8 15:31:47 2024 +0000
Commit:     David Seifert <soap <AT> gentoo <DOT> org>
CommitDate: Tue Oct  8 15:31:47 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=bb1b0ac3
webapp.eclass: drop support for EAPI 6
Signed-off-by: David Seifert <soap <AT> gentoo.org>
 eclass/webapp.eclass | 20 ++++++++------------
 1 file changed, 8 insertions(+), 12 deletions(-)
diff --git a/eclass/webapp.eclass b/eclass/webapp.eclass
index e8bc127e1b96..19fa9590707c 100644
--- a/eclass/webapp.eclass
+++ b/eclass/webapp.eclass
@@ -4,7 +4,7 @@
 # @ECLASS: webapp.eclass
 # @MAINTAINER:
 # web-apps@gentoo.org
-# @SUPPORTED_EAPIS: 6 7 8
+# @SUPPORTED_EAPIS: 7 8
 # @BLURB: functions for installing applications to run under a web server
 # @DESCRIPTION:
 # The webapp eclass contains functions to handle web applications with
@@ -14,10 +14,6 @@ if [[ -z ${_WEBAPP_ECLASS} ]]; then
 _WEBAPP_ECLASS=1
 
 case ${EAPI} in
-	6)
-		ewarn "${CATEGORY}/${PF}: ebuild uses ${ECLASS} with deprecated EAPI ${EAPI}!"
-		ewarn "${CATEGORY}/${PF}: Support will be removed on 2024-10-08. Please port to newer EAPI."
-		;;
 	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
@@ -55,9 +51,9 @@ IS_REPLACE=0
 INSTALL_CHECK_FILE="installed_by_webapp_eclass"
 SETUP_CHECK_FILE="setup_by_webapp_eclass"
 
-ETC_CONFIG="${ROOT%/}/etc/vhosts/webapp-config"
-WEBAPP_CONFIG="${ROOT%/}/usr/sbin/webapp-config"
-WEBAPP_CLEANER="${ROOT%/}/usr/sbin/webapp-cleaner"
+ETC_CONFIG="${EROOT}/etc/vhosts/webapp-config"
+WEBAPP_CONFIG="${EROOT}/usr/sbin/webapp-config"
+WEBAPP_CLEANER="${EROOT}/usr/sbin/webapp-cleaner"
 
 # ==============================================================================
 # INTERNAL FUNCTIONS
@@ -370,7 +366,7 @@ webapp_src_preinst() {
 # @DESCRIPTION:
 # The default pkg_setup() for this eclass. This will gather required variables
 # from webapp-config and check if there is an application installed to
-# `${ROOT%/}/var/www/localhost/htdocs/${PN}/' if USE=vhosts is not set.
+# `${ROOT}/var/www/localhost/htdocs/${PN}/' if USE=vhosts is not set.
 #
 # You need to call this function BEFORE anything else has run in your custom
 # pkg_setup().
@@ -394,7 +390,7 @@ webapp_pkg_setup() {
 	G_HOSTNAME="localhost"
 	webapp_read_config
 
-	local my_dir="${ROOT%/}/${VHOST_ROOT}/${MY_HTDOCSBASE}/${PN}"
+	local my_dir="${ROOT}/${VHOST_ROOT}/${MY_HTDOCSBASE}/${PN}"
 
 	# if USE=vhosts is enabled OR no application is installed we're done here
 	if ! has vhosts ${IUSE} || use vhosts || [[ ! -d "${my_dir}" ]]; then
@@ -458,7 +454,7 @@ webapp_src_install() {
 # @FUNCTION: webapp_pkg_postinst
 # @DESCRIPTION:
 # The default pkg_postinst() for this eclass. This installs the web application to
-# `${ROOT%/}/var/www/localhost/htdocs/${PN}/' if USE=vhosts is not set. Otherwise
+# `${ROOT}/var/www/localhost/htdocs/${PN}/' if USE=vhosts is not set. Otherwise
 # display a short notice how to install this application with webapp-config.
 #
 # You need to call this function AFTER everything else has run in your custom
@@ -469,7 +465,7 @@ webapp_pkg_postinst() {
 	webapp_read_config
 
 	# sanity checks, to catch bugs in the ebuild
-	if [[ ! -f "${ROOT%/}/${MY_APPDIR}/${INSTALL_CHECK_FILE}" ]]; then
+	if [[ ! -f "${ROOT}/${MY_APPDIR}/${INSTALL_CHECK_FILE}" ]]; then
 		eerror
 		eerror "This ebuild did not call webapp_src_install() at the end"
 		eerror "of the src_install() function"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-08 15:32 David Seifert
  0 siblings, 0 replies; 6663+ messages in thread
From: David Seifert @ 2024-10-08 15:32 UTC (permalink / raw
  To: gentoo-commits
commit:     ec9bd064a3b2e495970f49d751d57ca62fa77b84
Author:     David Seifert <soap <AT> gentoo <DOT> org>
AuthorDate: Tue Oct  8 15:31:51 2024 +0000
Commit:     David Seifert <soap <AT> gentoo <DOT> org>
CommitDate: Tue Oct  8 15:31:51 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=ec9bd064
eclass: standardize inherit guard
Signed-off-by: David Seifert <soap <AT> gentoo.org>
 eclass/app-alternatives.eclass   | 4 ++--
 eclass/aspell-dict-r1.eclass     | 4 ++--
 eclass/bash-completion-r1.eclass | 2 +-
 eclass/dotnet.eclass             | 4 ++--
 eclass/dune.eclass               | 2 +-
 eclass/emboss-r3.eclass          | 4 ++--
 eclass/gkrellm-plugin.eclass     | 4 ++--
 eclass/kernel-build.eclass       | 2 +-
 eclass/kernel-install.eclass     | 2 +-
 eclass/linux-mod-r1.eclass       | 2 +-
 eclass/llvm-r1.eclass            | 2 +-
 eclass/llvm-utils.eclass         | 2 +-
 eclass/llvm.eclass               | 2 +-
 eclass/mozcoreconf-v6.eclass     | 2 +-
 eclass/mozextension.eclass       | 4 ++--
 eclass/mozlinguas-v2.eclass      | 4 ++--
 eclass/postgres-multi.eclass     | 2 +-
 eclass/postgres.eclass           | 2 +-
 eclass/pypi.eclass               | 4 ++--
 eclass/python-any-r1.eclass      | 2 +-
 eclass/python-single-r1.eclass   | 2 +-
 eclass/rocm.eclass               | 2 +-
 eclass/ruby-ng-gnome2.eclass     | 2 +-
 eclass/ruby-single.eclass        | 4 ++--
 eclass/selinux-policy-2.eclass   | 2 +-
 eclass/shell-completion.eclass   | 4 ++--
 eclass/vcs-snapshot.eclass       | 2 +-
 eclass/waf-utils.eclass          | 4 ++--
 28 files changed, 39 insertions(+), 39 deletions(-)
diff --git a/eclass/app-alternatives.eclass b/eclass/app-alternatives.eclass
index c6924bfc6d2a..f670b7d843f9 100644
--- a/eclass/app-alternatives.eclass
+++ b/eclass/app-alternatives.eclass
@@ -1,4 +1,4 @@
-# Copyright 2022 Gentoo Authors
+# Copyright 2022-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: app-alternatives.eclass
@@ -21,7 +21,7 @@ case ${EAPI} in
 	*) die "${ECLASS}: EAPI ${EAPI:-0} unsupported."
 esac
 
-if [[ ! ${_APP_ALTERNATIVES_ECLASS} ]]; then
+if [[ -z ${_APP_ALTERNATIVES_ECLASS} ]]; then
 _APP_ALTERNATIVES_ECLASS=1
 
 # @ECLASS_VARIABLE: ALTERNATIVES
diff --git a/eclass/aspell-dict-r1.eclass b/eclass/aspell-dict-r1.eclass
index 1a3bd0b21b24..6d10c9fb302e 100644
--- a/eclass/aspell-dict-r1.eclass
+++ b/eclass/aspell-dict-r1.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2023 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: aspell-dict-r1.eclass
@@ -41,7 +41,7 @@ case ${EAPI} in
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
-if [[ ! ${_ASPELL_DICT_R1_ECLASS} ]]; then
+if [[ -z ${_ASPELL_DICT_R1_ECLASS} ]]; then
 _ASPELL_DICT_R1_ECLASS=1
 
 # Most of those aspell packages have an idiosyncratic versioning scheme,
diff --git a/eclass/bash-completion-r1.eclass b/eclass/bash-completion-r1.eclass
index fd16fca66538..643c458dd8a0 100644
--- a/eclass/bash-completion-r1.eclass
+++ b/eclass/bash-completion-r1.eclass
@@ -23,7 +23,7 @@
 # }
 # @CODE
 
-if [[ ! ${_BASH_COMPLETION_R1_ECLASS} ]]; then
+if [[ -z ${_BASH_COMPLETION_R1_ECLASS} ]]; then
 _BASH_COMPLETION_R1_ECLASS=1
 
 inherit toolchain-funcs
diff --git a/eclass/dotnet.eclass b/eclass/dotnet.eclass
index 1fb288dd1094..aeaee2f58e94 100644
--- a/eclass/dotnet.eclass
+++ b/eclass/dotnet.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2023 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: dotnet.eclass
@@ -17,7 +17,7 @@ case ${EAPI} in
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
-if [[ ! ${_DOTNET_ECLASS} ]]; then
+if [[ -z ${_DOTNET_ECLASS} ]]; then
 _DOTNET_ECLASS=1
 
 BDEPEND="dev-lang/mono"
diff --git a/eclass/dune.eclass b/eclass/dune.eclass
index ba54e87ceaf9..faf40e47eb1e 100644
--- a/eclass/dune.eclass
+++ b/eclass/dune.eclass
@@ -19,7 +19,7 @@ case ${EAPI} in
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
-if [[ ! ${_DUNE_ECLASS} ]]; then
+if [[ -z ${_DUNE_ECLASS} ]]; then
 _DUNE_ECLASS=1
 
 # @ECLASS_VARIABLE: DUNE_PKG_NAME
diff --git a/eclass/emboss-r3.eclass b/eclass/emboss-r3.eclass
index 84e258e02058..5db69dd86332 100644
--- a/eclass/emboss-r3.eclass
+++ b/eclass/emboss-r3.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2022 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: emboss-r3.eclass
@@ -38,7 +38,7 @@ case ${EAPI} in
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
-if [[ ! ${_EMBOSS_R3_ECLASS} ]]; then
+if [[ -z ${_EMBOSS_R3_ECLASS} ]]; then
 _EMBOSS_R3_ECLASS=1
 
 inherit flag-o-matic
diff --git a/eclass/gkrellm-plugin.eclass b/eclass/gkrellm-plugin.eclass
index 1424fdfe53f9..03b72dffa6e9 100644
--- a/eclass/gkrellm-plugin.eclass
+++ b/eclass/gkrellm-plugin.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2023 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: gkrellm-plugin.eclass
@@ -36,7 +36,7 @@ case ${EAPI} in
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
-if [[ ! ${_GKRELLM_PLUGIN_ECLASS} ]]; then
+if [[ -z ${_GKRELLM_PLUGIN_ECLASS} ]]; then
 _GKRELLM_PLUGIN_ECLASS=1
 
 inherit multilib
diff --git a/eclass/kernel-build.eclass b/eclass/kernel-build.eclass
index ce87fd72acdd..dbc41824c4b6 100644
--- a/eclass/kernel-build.eclass
+++ b/eclass/kernel-build.eclass
@@ -33,7 +33,7 @@ case ${EAPI} in
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
-if [[ ! ${_KERNEL_BUILD_ECLASS} ]]; then
+if [[ -z ${_KERNEL_BUILD_ECLASS} ]]; then
 _KERNEL_BUILD_ECLASS=1
 
 PYTHON_COMPAT=( python3_{10..13} )
diff --git a/eclass/kernel-install.eclass b/eclass/kernel-install.eclass
index dc337c7862fd..4109810d4d14 100644
--- a/eclass/kernel-install.eclass
+++ b/eclass/kernel-install.eclass
@@ -49,7 +49,7 @@
 # packages to depend on for building the generic UKI and their licenses.
 # Used in kernel-build.eclass.
 
-if [[ ! ${_KERNEL_INSTALL_ECLASS} ]]; then
+if [[ -z ${_KERNEL_INSTALL_ECLASS} ]]; then
 _KERNEL_INSTALL_ECLASS=1
 
 case ${EAPI} in
diff --git a/eclass/linux-mod-r1.eclass b/eclass/linux-mod-r1.eclass
index 120fb019d74a..241cfc7886e9 100644
--- a/eclass/linux-mod-r1.eclass
+++ b/eclass/linux-mod-r1.eclass
@@ -106,7 +106,7 @@ case ${EAPI} in
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
-if [[ ! ${_LINUX_MOD_R1_ECLASS} ]]; then
+if [[ -z ${_LINUX_MOD_R1_ECLASS} ]]; then
 _LINUX_MOD_R1_ECLASS=1
 
 inherit dist-kernel-utils edo linux-info multiprocessing toolchain-funcs
diff --git a/eclass/llvm-r1.eclass b/eclass/llvm-r1.eclass
index 0a53b9a3cb5e..399902181b65 100644
--- a/eclass/llvm-r1.eclass
+++ b/eclass/llvm-r1.eclass
@@ -42,7 +42,7 @@ case ${EAPI} in
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
-if [[ ! ${_LLVM_R1_ECLASS} ]]; then
+if [[ -z ${_LLVM_R1_ECLASS} ]]; then
 _LLVM_R1_ECLASS=1
 
 inherit llvm-utils
diff --git a/eclass/llvm-utils.eclass b/eclass/llvm-utils.eclass
index 532e609679b8..d38ba3a988f1 100644
--- a/eclass/llvm-utils.eclass
+++ b/eclass/llvm-utils.eclass
@@ -18,7 +18,7 @@ case ${EAPI} in
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
-if [[ ! ${_LLVM_UTILS_ECLASS} ]]; then
+if [[ -z ${_LLVM_UTILS_ECLASS} ]]; then
 _LLVM_UTILS_ECLASS=1
 
 # @FUNCTION: llvm_tuple_to_target
diff --git a/eclass/llvm.eclass b/eclass/llvm.eclass
index bb5ff5d78290..39ca1123eabb 100644
--- a/eclass/llvm.eclass
+++ b/eclass/llvm.eclass
@@ -63,7 +63,7 @@ case ${EAPI} in
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
-if [[ ! ${_LLVM_ECLASS} ]]; then
+if [[ -z ${_LLVM_ECLASS} ]]; then
 _LLVM_ECLASS=1
 
 inherit llvm-utils
diff --git a/eclass/mozcoreconf-v6.eclass b/eclass/mozcoreconf-v6.eclass
index e7cf85fca24a..b814663a8f66 100644
--- a/eclass/mozcoreconf-v6.eclass
+++ b/eclass/mozcoreconf-v6.eclass
@@ -20,7 +20,7 @@ case ${EAPI} in
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
-if [[ ! ${_MOZCORECONF_V6_ECLASS} ]]; then
+if [[ -z ${_MOZCORECONF_V6_ECLASS} ]]; then
 _MOZCORECONF_V6_ECLASS=1
 
 inherit toolchain-funcs flag-o-matic python-any-r1
diff --git a/eclass/mozextension.eclass b/eclass/mozextension.eclass
index 52fe26280e6e..f888491d9919 100644
--- a/eclass/mozextension.eclass
+++ b/eclass/mozextension.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2023 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: mozextension.eclass
@@ -12,7 +12,7 @@ case ${EAPI} in
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
-if [[ ! ${_MOZEXTENSION_ECLASS} ]]; then
+if [[ -z ${_MOZEXTENSION_ECLASS} ]]; then
 _MOZEXTENSION_ECLASS=1
 
 # @ECLASS_VARIABLE: MOZEXTENSION_TARGET
diff --git a/eclass/mozlinguas-v2.eclass b/eclass/mozlinguas-v2.eclass
index 81e00275a8f6..c8e4c2393945 100644
--- a/eclass/mozlinguas-v2.eclass
+++ b/eclass/mozlinguas-v2.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2023 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: mozlinguas-v2.eclass
@@ -19,7 +19,7 @@ case ${EAPI} in
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
-if [[ ! ${_MOZLINGUAS_V2_ECLASS} ]]; then
+if [[ -z ${_MOZLINGUAS_V2_ECLASS} ]]; then
 _MOZLINGUAS_V2_ECLASS=1
 
 inherit mozextension
diff --git a/eclass/postgres-multi.eclass b/eclass/postgres-multi.eclass
index 92299b8cf34c..5f014389fd89 100644
--- a/eclass/postgres-multi.eclass
+++ b/eclass/postgres-multi.eclass
@@ -19,7 +19,7 @@ case ${EAPI} in
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
-if [[ ! ${_POSTGRES_MULTI_ECLASS} ]]; then
+if [[ -z ${_POSTGRES_MULTI_ECLASS} ]]; then
 _POSTGRES_MULTI_ECLASS=1
 
 inherit multibuild postgres
diff --git a/eclass/postgres.eclass b/eclass/postgres.eclass
index 2c44358898e6..6ef6913c2dad 100644
--- a/eclass/postgres.eclass
+++ b/eclass/postgres.eclass
@@ -19,7 +19,7 @@ case ${EAPI} in
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
-if [[ ! ${_POSTGRES_ECLASS} ]]; then
+if [[ -z ${_POSTGRES_ECLASS} ]]; then
 _POSTGRES_ECLASS=1
 
 # @ECLASS_VARIABLE: _POSTGRES_ALL_VERSIONS
diff --git a/eclass/pypi.eclass b/eclass/pypi.eclass
index b80ff9c95d36..47d40449d13a 100644
--- a/eclass/pypi.eclass
+++ b/eclass/pypi.eclass
@@ -1,4 +1,4 @@
-# Copyright 2023 Gentoo Authors
+# Copyright 2023-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: pypi.eclass
@@ -40,7 +40,7 @@ case ${EAPI} in
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
-if [[ ! ${_PYPI_ECLASS} ]]; then
+if [[ -z ${_PYPI_ECLASS} ]]; then
 _PYPI_ECLASS=1
 
 # @ECLASS_VARIABLE: PYPI_NO_NORMALIZE
diff --git a/eclass/python-any-r1.eclass b/eclass/python-any-r1.eclass
index c1f27cfbac0d..8796c3eddb68 100644
--- a/eclass/python-any-r1.eclass
+++ b/eclass/python-any-r1.eclass
@@ -43,7 +43,7 @@ case ${EAPI} in
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
-if [[ ! ${_PYTHON_ANY_R1_ECLASS} ]]; then
+if [[ -z ${_PYTHON_ANY_R1_ECLASS} ]]; then
 _PYTHON_ANY_R1_ECLASS=1
 
 if [[ ${_PYTHON_R1_ECLASS} ]]; then
diff --git a/eclass/python-single-r1.eclass b/eclass/python-single-r1.eclass
index 481b6cf91ba0..d3cc4024de36 100644
--- a/eclass/python-single-r1.eclass
+++ b/eclass/python-single-r1.eclass
@@ -42,7 +42,7 @@ case ${EAPI} in
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
-if [[ ! ${_PYTHON_SINGLE_R1_ECLASS} ]]; then
+if [[ -z ${_PYTHON_SINGLE_R1_ECLASS} ]]; then
 _PYTHON_SINGLE_R1_ECLASS=1
 
 if [[ ${_PYTHON_R1_ECLASS} ]]; then
diff --git a/eclass/rocm.eclass b/eclass/rocm.eclass
index cf501d5a8861..acf3a5310a06 100644
--- a/eclass/rocm.eclass
+++ b/eclass/rocm.eclass
@@ -89,7 +89,7 @@ case ${EAPI} in
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
-if [[ ! ${_ROCM_ECLASS} ]]; then
+if [[ -z ${_ROCM_ECLASS} ]]; then
 _ROCM_ECLASS=1
 
 inherit flag-o-matic
diff --git a/eclass/ruby-ng-gnome2.eclass b/eclass/ruby-ng-gnome2.eclass
index c38c5f15904d..ed4fdd91a49f 100644
--- a/eclass/ruby-ng-gnome2.eclass
+++ b/eclass/ruby-ng-gnome2.eclass
@@ -18,7 +18,7 @@ case ${EAPI} in
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
-if [[ ! ${_RUBY_NG_GNOME2_ECLASS} ]]; then
+if [[ -z ${_RUBY_NG_GNOME2_ECLASS} ]]; then
 _RUBY_NG_GNOME2_ECLASS=1
 
 RUBY_FAKEGEM_NAME="${RUBY_FAKEGEM_NAME:-${PN#ruby-}}"
diff --git a/eclass/ruby-single.eclass b/eclass/ruby-single.eclass
index effdbd3e96a0..10d15c6d19f6 100644
--- a/eclass/ruby-single.eclass
+++ b/eclass/ruby-single.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2023 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: ruby-single.eclass
@@ -28,7 +28,7 @@ case ${EAPI} in
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
-if [[ ! ${_RUBY_SINGLE_ECLASS} ]]; then
+if [[ -z ${_RUBY_SINGLE_ECLASS} ]]; then
 _RUBY_SINGLE_ECLASS=1
 
 inherit ruby-utils
diff --git a/eclass/selinux-policy-2.eclass b/eclass/selinux-policy-2.eclass
index e7d6cd9a9e5f..e8b7ef863ad4 100644
--- a/eclass/selinux-policy-2.eclass
+++ b/eclass/selinux-policy-2.eclass
@@ -23,7 +23,7 @@ case ${EAPI} in
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
-if [[ ! ${_SELINUX_POLICY_2_ECLASS} ]]; then
+if [[ -z ${_SELINUX_POLICY_2_ECLASS} ]]; then
 _SELINUX_POLICY_2_ECLASS=1
 
 # @ECLASS_VARIABLE: MODS
diff --git a/eclass/shell-completion.eclass b/eclass/shell-completion.eclass
index d582028847b4..badda02f8d3f 100644
--- a/eclass/shell-completion.eclass
+++ b/eclass/shell-completion.eclass
@@ -1,4 +1,4 @@
-# Copyright 2023 Gentoo Authors
+# Copyright 2023-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: shell-completion.eclass
@@ -20,7 +20,7 @@ case ${EAPI} in
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported"
 esac
 
-if [[ ! ${_SHELL_COMPLETION_ECLASS} ]]; then
+if [[ -z ${_SHELL_COMPLETION_ECLASS} ]]; then
 _SHELL_COMPLETION_ECLASS=1
 
 # Extend bash-completion-r1
diff --git a/eclass/vcs-snapshot.eclass b/eclass/vcs-snapshot.eclass
index 0279e89ec3ab..14b9a8dd22ff 100644
--- a/eclass/vcs-snapshot.eclass
+++ b/eclass/vcs-snapshot.eclass
@@ -47,7 +47,7 @@ case ${EAPI} in
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
-if [[ ! ${_VCS_SNAPSHOT_ECLASS} ]]; then
+if [[ -z ${_VCS_SNAPSHOT_ECLASS} ]]; then
 _VCS_SNAPSHOT_ECLASS=1
 
 # @FUNCTION: vcs-snapshot_src_unpack
diff --git a/eclass/waf-utils.eclass b/eclass/waf-utils.eclass
index f8d4b0aa94b4..377b455de736 100644
--- a/eclass/waf-utils.eclass
+++ b/eclass/waf-utils.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2023 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: waf-utils.eclass
@@ -20,7 +20,7 @@ case ${EAPI} in
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
-if [[ ! ${_WAF_UTILS_ECLASS} ]]; then
+if [[ -z ${_WAF_UTILS_ECLASS} ]]; then
 _WAF_UTILS_ECLASS=1
 
 inherit multilib toolchain-funcs multiprocessing
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-08 15:32 David Seifert
  0 siblings, 0 replies; 6663+ messages in thread
From: David Seifert @ 2024-10-08 15:32 UTC (permalink / raw
  To: gentoo-commits
commit:     bc7675865f8f89016e64865db0a40083de2d6784
Author:     David Seifert <soap <AT> gentoo <DOT> org>
AuthorDate: Tue Oct  8 15:31:49 2024 +0000
Commit:     David Seifert <soap <AT> gentoo <DOT> org>
CommitDate: Tue Oct  8 15:31:49 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=bc767586
xdg-utils.eclass: drop support for EAPI 5 and 6
Signed-off-by: David Seifert <soap <AT> gentoo.org>
 eclass/xdg-utils.eclass | 12 ++++--------
 1 file changed, 4 insertions(+), 8 deletions(-)
diff --git a/eclass/xdg-utils.eclass b/eclass/xdg-utils.eclass
index 84f88eee18fc..de383d88cf95 100644
--- a/eclass/xdg-utils.eclass
+++ b/eclass/xdg-utils.eclass
@@ -7,7 +7,7 @@
 # freedesktop-bugs@gentoo.org
 # @AUTHOR:
 # Original author: Gilles Dartiguelongue <eva@gentoo.org>
-# @SUPPORTED_EAPIS: 5 6 7 8
+# @SUPPORTED_EAPIS: 7 8
 # @BLURB: Auxiliary functions commonly used by XDG compliant packages.
 # @DESCRIPTION:
 # This eclass provides a set of auxiliary functions needed by most XDG
@@ -18,10 +18,6 @@
 #  * XDG mime information database management
 
 case ${EAPI} in
-	5|6)
-		ewarn "${CATEGORY}/${PF}: ebuild uses ${ECLASS} with deprecated EAPI ${EAPI}!"
-		ewarn "${CATEGORY}/${PF}: Support will be removed on 2024-10-08. Please port to newer EAPI."
-		;;
 	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
@@ -72,7 +68,7 @@ xdg_desktop_database_update() {
 	fi
 
 	ebegin "Updating .desktop files database"
-	update-desktop-database -q "${EROOT%/}${DESKTOP_DATABASE_DIR}"
+	update-desktop-database -q "${EROOT}${DESKTOP_DATABASE_DIR}"
 	eend $?
 }
 
@@ -93,7 +89,7 @@ xdg_icon_cache_update() {
 	ebegin "Updating icons cache"
 	local dir retval=0
 	local fails=()
-	for dir in "${EROOT%/}"/usr/share/icons/*; do
+	for dir in "${EROOT}"/usr/share/icons/*; do
 		if [[ -f ${dir}/index.theme ]]; then
 			if ! gtk-update-icon-cache -qf "${dir}"; then
 				debug-print "Updating cache failed on ${dir}"
@@ -134,6 +130,6 @@ xdg_mimeinfo_database_update() {
 	local -x PKGSYSTEM_ENABLE_FSYNC=0
 
 	ebegin "Updating shared mime info database"
-	update-mime-database "${EROOT%/}${MIMEINFO_DATABASE_DIR}"
+	update-mime-database "${EROOT}${MIMEINFO_DATABASE_DIR}"
 	eend $?
 }
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-09 11:45 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-10-09 11:45 UTC (permalink / raw
  To: gentoo-commits
commit:     22c975e57f50b9302bf28aaa486942adb2a20ad1
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Wed Oct  9 11:27:59 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Wed Oct  9 11:45:27 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=22c975e5
llvm.org.eclass: Add 20.0.0_pre20241009 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index f51f01ff48b4..852dd55db43f 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -72,6 +72,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 			_LLVM_SOURCE_TYPE=snapshot
 
 			case ${PV} in
+				20.0.0_pre20241009)
+					EGIT_COMMIT=fb2960aad93f6c02e0ea8de0568c0aef8896eee8
+					;;
 				20.0.0_pre20241004)
 					EGIT_COMMIT=b837c9e289dab93c7f8a06876e3f70b6864f40ab
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-10 14:47 Andrew Ammerlaan
  0 siblings, 0 replies; 6663+ messages in thread
From: Andrew Ammerlaan @ 2024-10-10 14:47 UTC (permalink / raw
  To: gentoo-commits
commit:     dec7ddaabb47c81ecddc603fb2819c4c4f5066ea
Author:     Andrew Ammerlaan <andrewammerlaan <AT> gentoo <DOT> org>
AuthorDate: Tue Oct  1 18:34:43 2024 +0000
Commit:     Andrew Ammerlaan <andrewammerlaan <AT> gentoo <DOT> org>
CommitDate: Thu Oct 10 14:46:47 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=dec7ddaa
kernel-install.eclass: fix objcopy overwriting uki
From the manual:
If  you do not specify outfile, objcopy creates a temporary file and
destructively renames the result with the name of infile.
We don't want that. Unfortunately we cannot use /dev/null as dump, objcopy
complains, so we dump it in T instead.
Signed-off-by: Andrew Ammerlaan <andrewammerlaan <AT> gentoo.org>
 eclass/kernel-install.eclass | 5 ++++-
 1 file changed, 4 insertions(+), 1 deletion(-)
diff --git a/eclass/kernel-install.eclass b/eclass/kernel-install.eclass
index c5f218a46b91..29abb9b419e6 100644
--- a/eclass/kernel-install.eclass
+++ b/eclass/kernel-install.eclass
@@ -650,7 +650,10 @@ kernel-install_extract_from_uki() {
 	local uki=${2}
 	local out=${3}
 
-	$(tc-getOBJCOPY) "${uki}" --dump-section ".${extract_type}=${out}" ||
+	# objcopy overwrites input if there is no output, dump the output in T.
+	# We unfortunately cannot use /dev/null here
+	$(tc-getOBJCOPY) "${uki}" "${T}/dump.efi" \
+		--dump-section ".${extract_type}=${out}" ||
 		die "Failed to extract ${extract_type}"
 	chmod 644 "${out}" || die
 }
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-15  7:17 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-10-15  7:17 UTC (permalink / raw
  To: gentoo-commits
commit:     41bb10ce3c254e8d234f688e8ce364a8bc733bb8
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Tue Oct 15 07:03:05 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Tue Oct 15 07:17:25 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=41bb10ce
llvm.org.eclass: Remove code for old snapshots
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 9 ---------
 1 file changed, 9 deletions(-)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index 852dd55db43f..4efd39c5e2e9 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -75,15 +75,6 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 				20.0.0_pre20241009)
 					EGIT_COMMIT=fb2960aad93f6c02e0ea8de0568c0aef8896eee8
 					;;
-				20.0.0_pre20241004)
-					EGIT_COMMIT=b837c9e289dab93c7f8a06876e3f70b6864f40ab
-					;;
-				20.0.0_pre20240924)
-					EGIT_COMMIT=cde7b30268a85a3e7900a31534a97e7eb4de9236
-					;;
-				20.0.0_pre20240917)
-					EGIT_COMMIT=41f1b467a29d2ca4e35df37c3aa79a0a8c04bc4f
-					;;
 				*)
 					die "Unknown snapshot: ${PV}"
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-15 13:13 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-10-15 13:13 UTC (permalink / raw
  To: gentoo-commits
commit:     ab27bc68b10c84271c02ce50d66b1eaf994c24d4
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Tue Oct 15 12:58:01 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Tue Oct 15 12:58:01 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=ab27bc68
llvm.org.eclass: Add 20.0.0_pre20241015 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index 4efd39c5e2e9..065b02f3b269 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -72,6 +72,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 			_LLVM_SOURCE_TYPE=snapshot
 
 			case ${PV} in
+				20.0.0_pre20241015)
+					EGIT_COMMIT=9aef0fd52a0b2bf31cf3bae8a0693d6df8db6e04
+					;;
 				20.0.0_pre20241009)
 					EGIT_COMMIT=fb2960aad93f6c02e0ea8de0568c0aef8896eee8
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-16  4:54 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-10-16  4:54 UTC (permalink / raw
  To: gentoo-commits
commit:     115181ac99d8d65fba3d4cb33270e02f609b8fc4
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Oct 12 12:25:37 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Wed Oct 16 04:54:30 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=115181ac
verify-sig.eclass: Add support for verifying sigstore signatures
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/verify-sig.eclass | 54 +++++++++++++++++++++++++++++++++++++++++++-----
 1 file changed, 49 insertions(+), 5 deletions(-)
diff --git a/eclass/verify-sig.eclass b/eclass/verify-sig.eclass
index 9886e3352db7..0e6b9b43e557 100644
--- a/eclass/verify-sig.eclass
+++ b/eclass/verify-sig.eclass
@@ -57,6 +57,7 @@ IUSE="verify-sig"
 #
 #  - minisig -- verify signatures with (base64) Ed25519 public key using app-crypt/minisign
 #  - openpgp -- verify PGP signatures using app-crypt/gnupg (the default)
+#  - sigstore -- verify signatures using dev-python/sigstore
 #  - signify -- verify signatures with Ed25519 public key using app-crypt/signify
 : "${VERIFY_SIG_METHOD:=openpgp}"
 
@@ -75,6 +76,14 @@ case ${VERIFY_SIG_METHOD} in
 	signify)
 		BDEPEND="verify-sig? ( app-crypt/signify )"
 		;;
+	sigstore)
+		BDEPEND="
+			verify-sig? (
+				dev-python/sigstore
+				sec-keys/sigstore-trusted-root
+			)
+		"
+		;;
 	*)
 		die "${ECLASS}: unknown method '${VERIFY_SIG_METHOD}'"
 		;;
@@ -89,8 +98,19 @@ esac
 #
 # The value of BROOT will be prepended to this path automatically.
 #
-# NB: this variable is also used for non-OpenPGP signatures.  The name
-# contains "OPENPGP" for historical reasons.
+# This variable is also used for non-OpenPGP signatures.  The name
+# contains "OPENPGP" for historical reasons.  It is not used
+# for sigstore, since it uses a single trusted root.
+
+# @ECLASS_VARIABLE: VERIFY_SIG_CERT_IDENTITY
+# @DEFAULT_UNSET
+# @DESCRIPTION:
+# --cert-identity passed to sigstore invocation.
+
+# @ECLASS_VARIABLE: VERIFY_SIG_CERT_OIDC_ISSUER
+# @DEFAULT_UNSET
+# @DESCRIPTION:
+# --cert-oidc-issuer passed to sigstore invocation.
 
 # @ECLASS_VARIABLE: VERIFY_SIG_OPENPGP_KEYSERVER
 # @DEFAULT_UNSET
@@ -108,7 +128,7 @@ esac
 # in make.conf to enable.  Note that this requires working Internet
 # connection.
 #
-# Supported for OpenPGP only.
+# Supported for OpenPGP and sigstore.
 : "${VERIFY_SIG_OPENPGP_KEY_REFRESH:=no}"
 
 # @FUNCTION: verify-sig_verify_detached
@@ -123,7 +143,17 @@ verify-sig_verify_detached() {
 	local sig=${2}
 	local key=${3}
 
-	if [[ -z ${key} ]]; then
+	if [[ ${VERIFY_SIG_METHOD} == sigstore ]]; then
+		if [[ -n ${key:-${VERIFY_SIG_OPENPGP_KEY_PATH}} ]]; then
+			die "${FUNCNAME}: key unexpectedly specified for sigstore"
+		fi
+		if [[ -z ${VERIFY_SIG_CERT_IDENTITY} ]]; then
+			die "${FUNCNAME}: VERIFY_SIG_CERT_IDENTITY must be specified for sigstore"
+		fi
+		if [[ -z ${VERIFY_SIG_CERT_OIDC_ISSUER} ]]; then
+			die "${FUNCNAME}: VERIFY_SIG_CERT_OIDC_ISSUER must be specified for sigstore"
+		fi
+	elif [[ -z ${key} ]]; then
 		if [[ -z ${VERIFY_SIG_OPENPGP_KEY_PATH} ]]; then
 			die "${FUNCNAME}: no key passed and VERIFY_SIG_OPENPGP_KEY_PATH unset"
 		else
@@ -173,6 +203,20 @@ verify-sig_verify_detached() {
 				-V -p "${key}" -m "${file}" -x "${sig}" ||
 				die "Signify signature verification failed"
 			;;
+		sigstore)
+			if [[ ${VERIFY_SIG_OPENPGP_KEY_REFRESH} != yes ]]; then
+				extra_args+=( --offline )
+			fi
+
+			cp -r "${BROOT}"/usr/share/sigstore-gentoo/{.cache,.local} \
+				"${HOME}"/ || die
+			sigstore verify identity "${extra_args[@]}" \
+				--bundle "${sig}" \
+				--cert-identity "${VERIFY_SIG_CERT_IDENTITY}" \
+				--cert-oidc-issuer "${VERIFY_SIG_CERT_OIDC_ISSUER}" \
+				"${file}" ||
+				die "Sigstore signature verification failed"
+			;;
 		*)
 			die "${FUNCNAME} not supported with ${VERIFY_SIG_METHOD}"
 			;;
@@ -394,7 +438,7 @@ verify-sig_src_unpack() {
 		# find all distfiles and signatures, and combine them
 		for f in ${A}; do
 			found=
-			for suffix in .asc .sig .minisig; do
+			for suffix in .asc .sig .minisig .sigstore; do
 				if [[ ${f} == *${suffix} ]]; then
 					signatures+=( "${f}" )
 					found=sig
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-16  4:54 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-10-16  4:54 UTC (permalink / raw
  To: gentoo-commits
commit:     d49e67fc4060ef6fe96ffcf5928534d00886d539
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Oct 12 12:18:42 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Wed Oct 16 04:54:30 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=d49e67fc
verify-sig.eclass: Error out on invalid method+function combos
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/verify-sig.eclass | 9 +++++++++
 1 file changed, 9 insertions(+)
diff --git a/eclass/verify-sig.eclass b/eclass/verify-sig.eclass
index d601c7838a00..9886e3352db7 100644
--- a/eclass/verify-sig.eclass
+++ b/eclass/verify-sig.eclass
@@ -173,6 +173,9 @@ verify-sig_verify_detached() {
 				-V -p "${key}" -m "${file}" -x "${sig}" ||
 				die "Signify signature verification failed"
 			;;
+		*)
+			die "${FUNCNAME} not supported with ${VERIFY_SIG_METHOD}"
+			;;
 	esac
 }
 
@@ -234,6 +237,9 @@ verify-sig_verify_message() {
 			signify -V -e -p "${key}" -m "${output_file}" -x "${file}" ||
 				die "Signify signature verification failed"
 			;;
+		*)
+			die "${FUNCNAME} not supported with ${VERIFY_SIG_METHOD}"
+			;;
 	esac
 }
 
@@ -367,6 +373,9 @@ verify-sig_verify_signed_checksums() {
 				-x "${checksum_file}" "${files[@]}" ||
 				die "Signify signature verification failed"
 			;;
+		*)
+			die "${FUNCNAME} not supported with ${VERIFY_SIG_METHOD}"
+			;;
 	esac
 }
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-16  4:54 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-10-16  4:54 UTC (permalink / raw
  To: gentoo-commits
commit:     0dbf54a0490c0270e4e743e8af8f6b51603bad3c
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Oct 12 12:08:54 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Wed Oct 16 04:54:29 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=0dbf54a0
verify-sig.eclass: Refactor code to use extra_args for all types
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/verify-sig.eclass | 11 ++++++++---
 1 file changed, 8 insertions(+), 3 deletions(-)
diff --git a/eclass/verify-sig.eclass b/eclass/verify-sig.eclass
index b74ed78290aa..d601c7838a00 100644
--- a/eclass/verify-sig.eclass
+++ b/eclass/verify-sig.eclass
@@ -132,7 +132,6 @@ verify-sig_verify_detached() {
 	fi
 
 	local extra_args=()
-	[[ ${VERIFY_SIG_OPENPGP_KEY_REFRESH} == yes ]] || extra_args+=( -R )
 	if [[ -n ${VERIFY_SIG_OPENPGP_KEYSERVER+1} ]]; then
 		[[ ${VERIFY_SIG_METHOD} == openpgp ]] ||
 			die "${FUNCNAME}: VERIFY_SIG_OPENPGP_KEYSERVER is not supported"
@@ -152,10 +151,15 @@ verify-sig_verify_detached() {
 	einfo "Verifying ${filename} ..."
 	case ${VERIFY_SIG_METHOD} in
 		minisig)
-			minisign -V -P "$(<"${key}")" -x "${sig}" -m "${file}" ||
+			minisign "${extra_args[@]}" \
+				-V -P "$(<"${key}")" -x "${sig}" -m "${file}" ||
 				die "minisig signature verification failed"
 			;;
 		openpgp)
+			if [[ ${VERIFY_SIG_OPENPGP_KEY_REFRESH} != yes ]]; then
+				extra_args+=( -R )
+			fi
+
 			# gpg can't handle very long TMPDIR
 			# https://bugs.gentoo.org/854492
 			local -x TMPDIR=/tmp
@@ -165,7 +169,8 @@ verify-sig_verify_detached() {
 				die "PGP signature verification failed"
 			;;
 		signify)
-			signify -V -p "${key}" -m "${file}" -x "${sig}" ||
+			signify "${extra_args[@]}" \
+				-V -p "${key}" -m "${file}" -x "${sig}" ||
 				die "Signify signature verification failed"
 			;;
 	esac
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-16 16:13 Andreas Sturmlechner
  0 siblings, 0 replies; 6663+ messages in thread
From: Andreas Sturmlechner @ 2024-10-16 16:13 UTC (permalink / raw
  To: gentoo-commits
commit:     d15fed7177044717ef148dd54221412d5189442d
Author:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
AuthorDate: Wed Oct 16 15:55:49 2024 +0000
Commit:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
CommitDate: Wed Oct 16 16:13:21 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=d15fed71
ecm-common.eclass: Add missing dev-qt/qt{core,base}:[56] BDEPEND
Closes: https://bugs.gentoo.org/941617
Signed-off-by: Andreas Sturmlechner <asturm <AT> gentoo.org>
 eclass/ecm-common.eclass | 10 +++++++++-
 1 file changed, 9 insertions(+), 1 deletion(-)
diff --git a/eclass/ecm-common.eclass b/eclass/ecm-common.eclass
index ba6840d75a6d..7f5d3d1e9915 100644
--- a/eclass/ecm-common.eclass
+++ b/eclass/ecm-common.eclass
@@ -165,8 +165,16 @@ if [[ ${ECM_KCM_TARGETS} ]]; then
 	KF6_BDEPEND+=( "kde-frameworks/kcmutils:6" )
 fi
 
+KF6_BDEPEND+=( "dev-qt/qtbase:6" )
+
 if $(ver_test ${KFMIN} -lt 5.240) && [[ ${KF6_BDEPEND} && ${KF5_BDEPEND} ]]; then
-	BDEPEND+=" || ( ( ${KF6_BDEPEND[*]} ) ( ${KF5_BDEPEND[*]} ) )"
+	BDEPEND+=" || (
+		( ${KF6_BDEPEND[*]} )
+		(
+			${KF5_BDEPEND[*]}
+			dev-qt/qtcore:5
+		)
+	)"
 else
 	BDEPEND+=" ${KF6_BDEPEND[*]}"
 fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-18 17:54 Ulrich Müller
  0 siblings, 0 replies; 6663+ messages in thread
From: Ulrich Müller @ 2024-10-18 17:54 UTC (permalink / raw
  To: gentoo-commits
commit:     d78b4c787bd09872107c367299bd69b5eb2ea28e
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Mon Oct 14 10:33:32 2024 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Fri Oct 18 17:54:35 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=d78b4c78
cvs.eclass: Rewrite the ssh wrapper script in bash
OpenSSH version 8.4 and later supports the SSH_ASKPASS_REQUIRE
environment variable which allows to force the use of the SSH_ASKPASS
program. This makes detaching the process from its controlling terminal
(TIOCNOTTY ioctl) and setting the DISPLAY variable unnecessary.
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 eclass/cvs.eclass | 62 +++++++++++++++----------------------------------------
 1 file changed, 17 insertions(+), 45 deletions(-)
diff --git a/eclass/cvs.eclass b/eclass/cvs.eclass
index ec0ad2ec8f71..1289ee54cc3b 100644
--- a/eclass/cvs.eclass
+++ b/eclass/cvs.eclass
@@ -192,7 +192,7 @@ if [[ ${ECVS_AUTH} == "ext" ]] ; then
 	if [[ ${CVS_RSH} != "ssh" ]] ; then
 		die "Support for ext auth with clients other than ssh has not been implemented yet"
 	fi
-	BDEPEND+=" net-misc/openssh"
+	BDEPEND+=" >=net-misc/openssh-8.4"
 fi
 
 # @FUNCTION: cvs_fetch
@@ -362,40 +362,9 @@ cvs_fetch() {
 		# Hack to support SSH password authentication
 
 		if [[ ${CVS_RSH} == "ssh" ]] ; then
-			# Force SSH to use SSH_ASKPASS by creating python wrapper
-
-			local -x CVS_RSH="${T}/cvs_sshwrapper"
-			cat > "${CVS_RSH}" <<EOF || die
-#!${EPREFIX}/usr/bin/python
-import fcntl
-import os
-import sys
-try:
-	fd = os.open('/dev/tty', 2)
-	TIOCNOTTY=0x5422
-	try:
-		fcntl.ioctl(fd, TIOCNOTTY)
-	except:
-		pass
-	os.close(fd)
-except:
-	pass
-newarglist = sys.argv[:]
-EOF
-
-			# disable X11 forwarding which causes .xauth access violations
-			# - 20041205 Armando Di Cianno <fafhrd@gentoo.org>
-			echo "newarglist.insert(1, '-oClearAllForwardings=yes')" \
-				>> "${CVS_RSH}" || die
-			echo "newarglist.insert(1, '-oForwardX11=no')" \
-				>> "${CVS_RSH}" || die
-
 			# Handle SSH host key checking
 
 			local known_hosts_file="${T}/cvs_ssh_known_hosts"
-			echo "newarglist.insert(1, '-oUserKnownHostsFile=${known_hosts_file}')" \
-				>> "${CVS_RSH}" || die
-
 			local strict_host_key_checking
 			if [[ -z ${ECVS_SSH_HOST_KEY} ]] ; then
 				ewarn "Warning: The SSH host key of the remote server will not be verified."
@@ -407,28 +376,31 @@ EOF
 				echo "${ECVS_SSH_HOST_KEY}" > "${known_hosts_file}" || die
 			fi
 
-			echo -n "newarglist.insert(1, '-oStrictHostKeyChecking=" \
-				>> "${CVS_RSH}" || die
-			echo "${strict_host_key_checking}')" \
-				>> "${CVS_RSH}" || die
-			echo "os.execv('${EPREFIX}/usr/bin/ssh', newarglist)" \
-				>> "${CVS_RSH}" || die
+			# Create a wrapper script to pass additional options to SSH
+			# Disable X11 forwarding which causes .xauth access violations
 
+			local -x CVS_RSH="${T}/cvs_sshwrapper"
+			cat > "${CVS_RSH}" <<-EOF || die
+				#!${BROOT}/bin/bash
+				exec "${BROOT}/usr/bin/ssh" \\
+					-oStrictHostKeyChecking=${strict_host_key_checking} \\
+					-oUserKnownHostsFile="${known_hosts_file}" \\
+					-oForwardX11=no \\
+					-oClearAllForwardings=yes \\
+					"\$@"
+				EOF
 			chmod a+x "${CVS_RSH}" || die
 
-			# Make sure DISPLAY is set (SSH will not use SSH_ASKPASS
-			# if DISPLAY is not set)
-
-			local -x DISPLAY="${DISPLAY:-DISPLAY}"
-
 			# Create a dummy executable to echo ${ECVS_PASS}
 
 			local -x SSH_ASKPASS="${T}/cvs_sshechopass"
+			local -x SSH_ASKPASS_REQUIRE="force"
+
 			if [[ ${ECVS_AUTH} != "no" ]] ; then
-				echo -en "#!/bin/bash\necho \"${ECVS_PASS}\"\n" \
+				echo -en "#!${BROOT}/bin/bash\necho \"${ECVS_PASS}\"\n" \
 					> "${SSH_ASKPASS}" || die
 			else
-				echo -en "#!/bin/bash\nreturn\n" \
+				echo -en "#!${BROOT}/bin/bash\nreturn\n" \
 					> "${SSH_ASKPASS}" || die
 			fi
 			chmod a+x "${SSH_ASKPASS}" || die
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-18 17:54 Ulrich Müller
  0 siblings, 0 replies; 6663+ messages in thread
From: Ulrich Müller @ 2024-10-18 17:54 UTC (permalink / raw
  To: gentoo-commits
commit:     79d26649cb50e6f26be6728621459ae94c542d3b
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Mon Oct 14 10:36:08 2024 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Fri Oct 18 17:54:34 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=79d26649
cvs.eclass: Add local declarations and die statements throughout
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 eclass/cvs.eclass | 120 +++++++++++++++++++++++-------------------------------
 1 file changed, 52 insertions(+), 68 deletions(-)
diff --git a/eclass/cvs.eclass b/eclass/cvs.eclass
index dbacc2c09cfe..ec0ad2ec8f71 100644
--- a/eclass/cvs.eclass
+++ b/eclass/cvs.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2023 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: cvs.eclass
@@ -268,13 +268,14 @@ cvs_fetch() {
 	# In case ECVS_TOP_DIR is a symlink to a dir, get the real path,
 	# otherwise addwrite() doesn't work.
 
-	cd -P "${ECVS_TOP_DIR}" >/dev/null
+	cd -P "${ECVS_TOP_DIR}" >/dev/null || die
 	ECVS_TOP_DIR=$(pwd)
 
 	# Disable the sandbox for this dir
 	addwrite "${ECVS_TOP_DIR}"
 
 	# Determine the CVS command mode (checkout or update)
+	local mode
 	if [[ ! -d ${ECVS_TOP_DIR}/${ECVS_LOCALNAME}/CVS ]] ; then
 		mode=checkout
 	else
@@ -294,14 +295,14 @@ cvs_fetch() {
 
 	# Switch servers automagically if needed
 	if [[ ${mode} == "update" ]] ; then
-		cd "/${ECVS_TOP_DIR}/${ECVS_LOCALNAME}"
-		local oldserver=$(cat CVS/Root)
+		cd "/${ECVS_TOP_DIR}/${ECVS_LOCALNAME}" || die
+		local oldserver=$(cat CVS/Root || die)
 		if [[ ${server} != "${oldserver}" ]] ; then
 			einfo "Changing the CVS server from ${oldserver} to ${server}:"
 			debug-print "${FUNCNAME}: Changing the CVS server from ${oldserver} to ${server}:"
 
 			einfo "Searching for CVS directories ..."
-			local cvsdirs=$(find . -iname CVS -print)
+			local cvsdirs=$(find . -iname CVS -print || die)
 			debug-print "${FUNCNAME}: CVS directories found:"
 			debug-print "${cvsdirs}"
 
@@ -309,21 +310,22 @@ cvs_fetch() {
 			local x
 			for x in ${cvsdirs} ; do
 				debug-print "In ${x}"
-				echo "${server}" > "${x}/Root"
+				echo "${server}" > "${x}/Root" || die
 			done
 		fi
 	fi
 
 	# Prepare a cvspass file just for this session, we don't want to
 	# mess with ~/.cvspass
-	touch "${T}/cvspass"
-	export CVS_PASSFILE="${T}/cvspass"
+	local -x CVS_PASSFILE="${T}/cvspass"
+	touch "${CVS_PASSFILE}" || die
 
 	# The server string with the password in it, for login (only used for pserver)
-	cvsroot_pass=":${connection}:${ECVS_USER}:${ECVS_PASS}@${ECVS_SERVER}"
+	local cvsroot_pass=":${connection}:${ECVS_USER}:${ECVS_PASS}@${ECVS_SERVER}"
 
 	# Ditto without the password, for checkout/update after login, so
 	# that the CVS/Root files don't contain the password in plaintext
+	local cvsroot_nopass
 	if [[ ${ECVS_AUTH} == "no" ]] ; then
 		cvsroot_nopass="${ECVS_USER}@${ECVS_SERVER}"
 	else
@@ -331,13 +333,21 @@ cvs_fetch() {
 	fi
 
 	# Commands to run
-	cmdlogin=( ${ECVS_CVS_COMMAND} -d "${cvsroot_pass}" login )
-	cmdupdate=( ${ECVS_CVS_COMMAND} -d "${cvsroot_nopass}" update ${ECVS_UP_OPTS} ${ECVS_LOCALNAME} )
-	cmdcheckout=( ${ECVS_CVS_COMMAND} -d "${cvsroot_nopass}" checkout ${ECVS_CO_OPTS} ${ECVS_MODULE} )
+	local cmdlogin=(
+		${ECVS_CVS_COMMAND} -d "${cvsroot_pass}" login
+	)
+	local cmdupdate=(
+		${ECVS_CVS_COMMAND} -d "${cvsroot_nopass}" update
+		${ECVS_UP_OPTS} ${ECVS_LOCALNAME}
+	)
+	local cmdcheckout=(
+		${ECVS_CVS_COMMAND} -d "${cvsroot_nopass}" checkout
+		${ECVS_CO_OPTS} ${ECVS_MODULE}
+	)
 
 	# Execute commands
 
-	cd "${ECVS_TOP_DIR}"
+	cd "${ECVS_TOP_DIR}" || die
 	if [[ ${ECVS_AUTH} == "pserver" ]] ; then
 		einfo "Running ${cmdlogin[*]}"
 		"${cmdlogin[@]}" || die "cvs login command failed"
@@ -351,26 +361,11 @@ cvs_fetch() {
 	elif [[ ${ECVS_AUTH} == "ext" || ${ECVS_AUTH} == "no" ]] ; then
 		# Hack to support SSH password authentication
 
-		# Backup environment variable values
-		local CVS_ECLASS_ORIG_CVS_RSH="${CVS_RSH}"
-
-		if [[ ${SSH_ASKPASS+set} == "set" ]] ; then
-			local CVS_ECLASS_ORIG_SSH_ASKPASS="${SSH_ASKPASS}"
-		else
-			unset CVS_ECLASS_ORIG_SSH_ASKPASS
-		fi
-
-		if [[ ${DISPLAY+set} == "set" ]] ; then
-			local CVS_ECLASS_ORIG_DISPLAY="${DISPLAY}"
-		else
-			unset CVS_ECLASS_ORIG_DISPLAY
-		fi
-
 		if [[ ${CVS_RSH} == "ssh" ]] ; then
 			# Force SSH to use SSH_ASKPASS by creating python wrapper
 
-			export CVS_RSH="${T}/cvs_sshwrapper"
-			cat > "${CVS_RSH}"<<EOF
+			local -x CVS_RSH="${T}/cvs_sshwrapper"
+			cat > "${CVS_RSH}" <<EOF || die
 #!${EPREFIX}/usr/bin/python
 import fcntl
 import os
@@ -391,52 +386,52 @@ EOF
 			# disable X11 forwarding which causes .xauth access violations
 			# - 20041205 Armando Di Cianno <fafhrd@gentoo.org>
 			echo "newarglist.insert(1, '-oClearAllForwardings=yes')" \
-				>> "${CVS_RSH}"
+				>> "${CVS_RSH}" || die
 			echo "newarglist.insert(1, '-oForwardX11=no')" \
-				>> "${CVS_RSH}"
+				>> "${CVS_RSH}" || die
 
 			# Handle SSH host key checking
 
-			local CVS_ECLASS_KNOWN_HOSTS="${T}/cvs_ssh_known_hosts"
-			echo "newarglist.insert(1, '-oUserKnownHostsFile=${CVS_ECLASS_KNOWN_HOSTS}')" \
-				>> "${CVS_RSH}"
+			local known_hosts_file="${T}/cvs_ssh_known_hosts"
+			echo "newarglist.insert(1, '-oUserKnownHostsFile=${known_hosts_file}')" \
+				>> "${CVS_RSH}" || die
 
+			local strict_host_key_checking
 			if [[ -z ${ECVS_SSH_HOST_KEY} ]] ; then
 				ewarn "Warning: The SSH host key of the remote server will not be verified."
 				einfo "A temporary known hosts list will be used."
-				local CVS_ECLASS_STRICT_HOST_CHECKING="no"
-				touch "${CVS_ECLASS_KNOWN_HOSTS}"
+				strict_host_key_checking="no"
+				touch "${known_hosts_file}" || die
 			else
-				local CVS_ECLASS_STRICT_HOST_CHECKING="yes"
-				echo "${ECVS_SSH_HOST_KEY}" > "${CVS_ECLASS_KNOWN_HOSTS}"
+				strict_host_key_checking="yes"
+				echo "${ECVS_SSH_HOST_KEY}" > "${known_hosts_file}" || die
 			fi
 
 			echo -n "newarglist.insert(1, '-oStrictHostKeyChecking=" \
-				>> "${CVS_RSH}"
-			echo "${CVS_ECLASS_STRICT_HOST_CHECKING}')" \
-				>> "${CVS_RSH}"
+				>> "${CVS_RSH}" || die
+			echo "${strict_host_key_checking}')" \
+				>> "${CVS_RSH}" || die
 			echo "os.execv('${EPREFIX}/usr/bin/ssh', newarglist)" \
-				>> "${CVS_RSH}"
+				>> "${CVS_RSH}" || die
 
-			chmod a+x "${CVS_RSH}"
+			chmod a+x "${CVS_RSH}" || die
 
 			# Make sure DISPLAY is set (SSH will not use SSH_ASKPASS
 			# if DISPLAY is not set)
 
-			: "${DISPLAY:="DISPLAY"}"
-			export DISPLAY
+			local -x DISPLAY="${DISPLAY:-DISPLAY}"
 
 			# Create a dummy executable to echo ${ECVS_PASS}
 
-			export SSH_ASKPASS="${T}/cvs_sshechopass"
+			local -x SSH_ASKPASS="${T}/cvs_sshechopass"
 			if [[ ${ECVS_AUTH} != "no" ]] ; then
 				echo -en "#!/bin/bash\necho \"${ECVS_PASS}\"\n" \
-					> "${SSH_ASKPASS}"
+					> "${SSH_ASKPASS}" || die
 			else
 				echo -en "#!/bin/bash\nreturn\n" \
-					> "${SSH_ASKPASS}"
+					> "${SSH_ASKPASS}" || die
 			fi
-			chmod a+x "${SSH_ASKPASS}"
+			chmod a+x "${SSH_ASKPASS}" || die
 		fi
 
 		if [[ ${mode} == "update" ]] ; then
@@ -446,20 +441,6 @@ EOF
 			einfo "Running ${cmdcheckout[*]}"
 			"${cmdcheckout[@]}" || die "cvs checkout command failed"
 		fi
-
-		# Restore environment variable values
-		export CVS_RSH="${CVS_ECLASS_ORIG_CVS_RSH}"
-		if [[ ${CVS_ECLASS_ORIG_SSH_ASKPASS+set} == "set" ]] ; then
-			export SSH_ASKPASS="${CVS_ECLASS_ORIG_SSH_ASKPASS}"
-		else
-			unset SSH_ASKPASS
-		fi
-
-		if [[ ${CVS_ECLASS_ORIG_DISPLAY+set} == "set" ]] ; then
-			export DISPLAY="${CVS_ECLASS_ORIG_DISPLAY}"
-		else
-			unset DISPLAY
-		fi
 	fi
 }
 
@@ -508,12 +489,14 @@ cvs_src_unpack() {
 	debug-print "Copying module ${ECVS_MODULE} local_mode=${ECVS_LOCAL} from ${ECVS_TOP_DIR} ..."
 
 	# This is probably redundant, but best to make sure.
-	mkdir -p "${WORKDIR}/${ECVS_LOCALNAME}"
+	mkdir -p "${WORKDIR}/${ECVS_LOCALNAME}" || die
 
 	if [[ -n ${ECVS_LOCAL} ]] ; then
-		cp -f "${ECVS_TOP_DIR}/${ECVS_LOCALNAME}"/* "${WORKDIR}/${ECVS_LOCALNAME}"
+		cp -f "${ECVS_TOP_DIR}/${ECVS_LOCALNAME}"/* \
+			"${WORKDIR}/${ECVS_LOCALNAME}" || die
 	else
-		cp -Rf "${ECVS_TOP_DIR}/${ECVS_LOCALNAME}" "${WORKDIR}/${ECVS_LOCALNAME}/.."
+		cp -Rf "${ECVS_TOP_DIR}/${ECVS_LOCALNAME}" \
+			"${WORKDIR}/${ECVS_LOCALNAME}/.." || die
 	fi
 
 	# Not exactly perfect, but should be pretty close #333773
@@ -522,6 +505,7 @@ cvs_src_unpack() {
 			LC_ALL=C sort | \
 			sha1sum | \
 			awk '{print $1}'
+		assert
 	)
 
 	# If the directory is empty, remove it; empty directories cannot
@@ -530,7 +514,7 @@ cvs_src_unpack() {
 	# the empty directory in workdir though.
 	if [[ $(ls -A "${ECVS_TOP_DIR}/${ECVS_LOCALNAME}") == "CVS" ]] ; then
 		debug-print "${FUNCNAME}: removing empty CVS directory ${ECVS_LOCALNAME}"
-		rm -rf "${ECVS_TOP_DIR}/${ECVS_LOCALNAME}"
+		rm -rf "${ECVS_TOP_DIR}/${ECVS_LOCALNAME}" || die
 	fi
 
 	einfo "CVS module ${ECVS_MODULE} is now in ${WORKDIR}"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-18 17:54 Ulrich Müller
  0 siblings, 0 replies; 6663+ messages in thread
From: Ulrich Müller @ 2024-10-18 17:54 UTC (permalink / raw
  To: gentoo-commits
commit:     2a3ae6dbbbf9f6ffbefa0c140b41fdcd1863fa2f
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Mon Oct 14 10:45:24 2024 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Fri Oct 18 17:54:35 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=2a3ae6db
cvs.eclass: New eclass variable ECVS_SSH_EXTRA_OPTS
This allows passing additional options to ssh.
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 eclass/cvs.eclass | 12 ++++++++++++
 1 file changed, 12 insertions(+)
diff --git a/eclass/cvs.eclass b/eclass/cvs.eclass
index 1289ee54cc3b..007240e6ba25 100644
--- a/eclass/cvs.eclass
+++ b/eclass/cvs.eclass
@@ -174,6 +174,12 @@ _CVS_ECLASS=1
 # WARNING: If a SSH host key is not specified using this variable, the
 # remote host key will not be verified.
 
+# @ECLASS_VARIABLE: ECVS_SSH_EXTRA_OPTS
+# @DEFAULT_UNSET
+# @DESCRIPTION:
+# If SSH is used for "ext" authentication, this array variable can be
+# used to pass additional options to the SSH command.
+
 # @ECLASS_VARIABLE: ECVS_CLEAN
 # @DEFAULT_UNSET
 # @DESCRIPTION:
@@ -376,6 +382,11 @@ cvs_fetch() {
 				echo "${ECVS_SSH_HOST_KEY}" > "${known_hosts_file}" || die
 			fi
 
+			local i quoted_opts=()
+			for i in "${!ECVS_SSH_EXTRA_OPTS[@]}"; do
+				printf -v "quoted_opts[i]" "%q" "${ECVS_SSH_EXTRA_OPTS[i]}"
+			done
+
 			# Create a wrapper script to pass additional options to SSH
 			# Disable X11 forwarding which causes .xauth access violations
 
@@ -387,6 +398,7 @@ cvs_fetch() {
 					-oUserKnownHostsFile="${known_hosts_file}" \\
 					-oForwardX11=no \\
 					-oClearAllForwardings=yes \\
+					${quoted_opts[*]} \\
 					"\$@"
 				EOF
 			chmod a+x "${CVS_RSH}" || die
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-19 13:47 Ionen Wolkens
  0 siblings, 0 replies; 6663+ messages in thread
From: Ionen Wolkens @ 2024-10-19 13:47 UTC (permalink / raw
  To: gentoo-commits
commit:     e91760a3bbc3d9267fb0bfd018b8af834e0b4286
Author:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
AuthorDate: Sat Oct 19 12:49:43 2024 +0000
Commit:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
CommitDate: Sat Oct 19 13:47:15 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=e91760a3
qt6-build.eclass: extend -m* flags sanitizing
A user on the forums reported a build failure with:
`-march=znver4 -mavx512vp2intersect`
On its own, there is no issue there (expanded from -march=native) but
when Qt passes `-march=haswell` to build certain parts (e.g. avx2 bits
for runtime detection regardless of what CHOST supports), it overrides
znver4 and keeps -mavx512vp2intersect resulting in an incomplete set
and then qsimd_p.h complains
Do not plan to pursue this myself, but this specific issue could
be improved upstream by passing -mavx2 and others rather than
-march=haswell (this would also allow overriding a -mno-avx2 that
we currently need to change), and/or ideally by making qsimd_p.h
be able to deal with these configurations without #error.
If problems keep piling up, could consider always filtering *all*
-m{,no-}<instr> flags and doing x86-64-v* unconditionally. Albeit
that'd still require maintaining a list of these not to filter
unrelated -m* flags which could be important.
Signed-off-by: Ionen Wolkens <ionen <AT> gentoo.org>
 eclass/qt6-build.eclass | 34 ++++++++++++++++++++++++----------
 1 file changed, 24 insertions(+), 10 deletions(-)
diff --git a/eclass/qt6-build.eclass b/eclass/qt6-build.eclass
index c6b8db578f46..2dec4b7ec14e 100644
--- a/eclass/qt6-build.eclass
+++ b/eclass/qt6-build.eclass
@@ -301,18 +301,31 @@ _qt6-build_sanitize_cpu_flags() {
 		fma4 sse4a
 	)
 
+	# extras for which -mno-* does not matter, but can lead to enabling
+	# other flags when set and breaking the -march=haswell case below
+	# (add more as needed if users use these)
+	local cpuflags_filter_only=(
+		avx512vp2intersect
+	)
+
 	# check if any known problematic -mno-* C(XX)FLAGS
 	if ! is-flagq "@($(IFS='|'; echo "${cpuflags[*]/#/-mno-}"))"; then
-		# check if qsimd_p.h (search for "enable all") will accept -march
-		: "$($(tc-getCXX) -E -P ${CXXFLAGS} ${CPPFLAGS} - <<-EOF | tail -n 1
-				#if (defined(__AVX2__) && (__BMI__ + __BMI2__ + __F16C__ + __FMA__ + __LZCNT__ + __POPCNT__) != 6) || \
-					(defined(__AVX512F__) && (__AVX512BW__ + __AVX512CD__ + __AVX512DQ__ + __AVX512VL__) != 4)
-				bad
-				#endif
-			EOF
-			assert
-		)"
-		[[ ${_} == bad ]] || return 0 # *should* be fine as-is
+		# check if qsimd_p.h (search for "enable all") will accept -march, and
+		# further check when -march=haswell is appended (which Qt uses for some
+		# parts) given combination with other -m* could lead to partial support
+		local bad flags
+		for flags in '' '-march=haswell'; do
+			: "$($(tc-getCXX) -E -P ${CXXFLAGS} ${CPPFLAGS} ${flags} - <<-EOF | tail -n 1
+					#if (defined(__AVX2__) && (__BMI__ + __BMI2__ + __F16C__ + __FMA__ + __LZCNT__ + __POPCNT__) != 6) || \
+						(defined(__AVX512F__) && (__AVX512BW__ + __AVX512CD__ + __AVX512DQ__ + __AVX512VL__) != 4)
+					bad
+					#endif
+				EOF
+				assert
+			)"
+			[[ ${_} == bad ]] && bad=1 && break
+		done
+		[[ -v bad ]] || return 0 # *should* be fine as-is
 	fi
 
 	# determine highest(known) usable x86-64 feature level
@@ -332,6 +345,7 @@ _qt6-build_sanitize_cpu_flags() {
 		assert
 	)
 
+	cpuflags+=("${cpuflags_filter_only[@]}")
 	filter-flags '-march=*' "${cpuflags[@]/#/-m}" "${cpuflags[@]/#/-mno-}"
 	[[ ${march} == x86-64* ]] && append-flags $(test-flags-CXX -march=${march})
 	einfo "C(XX)FLAGS were adjusted due to Qt limitations: ${CXXFLAGS}"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-21  9:32 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-10-21  9:32 UTC (permalink / raw
  To: gentoo-commits
commit:     72d5ea56d41b7d5aac351854b7479f5c2c430c83
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Oct 21 09:31:40 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Oct 21 09:31:58 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=72d5ea56
toolchain.eclass: filter -fdiagnostics-explain-harder
This is an experimental flag not yet merged upstream but filtering
it makes it easier to test with so it doesn't confuse older unpatched (locally)
GCCs.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 4 ++++
 1 file changed, 4 insertions(+)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 6bad1def19f4..dd4130ef9b85 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1944,6 +1944,10 @@ gcc_do_filter_flags() {
 		filter-flags -Walloc-size
 	fi
 
+	if ver_test -lt 15.1 ; then
+		filter-flags -fdiagnostics-explain-harder
+	fi
+
 	# Please use USE=lto instead (bug #906007).
 	filter-lto
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-23 12:18 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-10-23 12:18 UTC (permalink / raw
  To: gentoo-commits
commit:     d138c8c9a84a7c44f8a846ceb88c7b8bb2a27a98
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Wed Oct 23 12:00:45 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Wed Oct 23 12:18:03 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=d138c8c9
llvm.org.eclass: Add 20.0.0_pre20241023 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index 065b02f3b269..7f104862b24b 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -72,6 +72,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 			_LLVM_SOURCE_TYPE=snapshot
 
 			case ${PV} in
+				20.0.0_pre20241023)
+					EGIT_COMMIT=0cb80c4f00689ca00a85e1f38bc6ae9dd0bf980e
+					;;
 				20.0.0_pre20241015)
 					EGIT_COMMIT=9aef0fd52a0b2bf31cf3bae8a0693d6df8db6e04
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-29 13:01 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-10-29 13:01 UTC (permalink / raw
  To: gentoo-commits
commit:     70048de89455f6231d604ae7289dff52e8b371c3
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Tue Oct 29 13:00:02 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Tue Oct 29 13:01:26 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=70048de8
llvm.org.eclass: Add 20.0.0_pre20241029 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index 7f104862b24b..dddb87735875 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -72,6 +72,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 			_LLVM_SOURCE_TYPE=snapshot
 
 			case ${PV} in
+				20.0.0_pre20241029)
+					EGIT_COMMIT=3f4468faaa9525ad615118675c3c68938f4a8d5f
+					;;
 				20.0.0_pre20241023)
 					EGIT_COMMIT=0cb80c4f00689ca00a85e1f38bc6ae9dd0bf980e
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-29 23:22 Maciej Barć
  0 siblings, 0 replies; 6663+ messages in thread
From: Maciej Barć @ 2024-10-29 23:22 UTC (permalink / raw
  To: gentoo-commits
commit:     6ee0117091c9e8e2911603b2243b874adaba5aab
Author:     Maciej Barć <xgqt <AT> gentoo <DOT> org>
AuthorDate: Wed Oct 23 19:37:20 2024 +0000
Commit:     Maciej Barć <xgqt <AT> gentoo <DOT> org>
CommitDate: Tue Oct 29 23:22:16 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=6ee01170
eclass/dotnet-pkg-base: turn off DOTNET_NUGET_SIGNATURE_VERIFICATION
Speeds up "dotnet restore". Especially can be noticed when running
without network sandbox.
Suggested by vimproved on IRC - thanks!
See also: https://github.com/NuGet/Home/issues/13062
Signed-off-by: Maciej Barć <xgqt <AT> gentoo.org>
 eclass/dotnet-pkg-base.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/dotnet-pkg-base.eclass b/eclass/dotnet-pkg-base.eclass
index 15e9ba703baa..784db5ce83f0 100644
--- a/eclass/dotnet-pkg-base.eclass
+++ b/eclass/dotnet-pkg-base.eclass
@@ -101,6 +101,9 @@ export DOTNET_SKIP_FIRST_TIME_EXPERIENCE=1
 export MSBUILDDISABLENODEREUSE=1
 export POWERSHELL_TELEMETRY_OPTOUT=1
 export POWERSHELL_UPDATECHECK=0
+# Speeds up restore. Having this turned on is redundant with Portage manifests.
+# See also: https://github.com/NuGet/Home/issues/13062
+export DOTNET_NUGET_SIGNATURE_VERIFICATION=false
 # Overwrite selected MSBuild properties ("-p:XYZ").
 export UseSharedCompilation=false
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-29 23:22 Maciej Barć
  0 siblings, 0 replies; 6663+ messages in thread
From: Maciej Barć @ 2024-10-29 23:22 UTC (permalink / raw
  To: gentoo-commits
commit:     a9261dc65b6e9b43fdc0cfc9b9fb1445eeaeac7e
Author:     Maciej Barć <xgqt <AT> gentoo <DOT> org>
AuthorDate: Wed Oct 23 19:45:48 2024 +0000
Commit:     Maciej Barć <xgqt <AT> gentoo <DOT> org>
CommitDate: Tue Oct 29 23:22:16 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=a9261dc6
eclass/dotnet-pkg-base: add efsi function for running FSI
This will replace "edotnet fsi" as used in "app-shells/pwsh" package.
Signed-off-by: Maciej Barć <xgqt <AT> gentoo.org>
 eclass/dotnet-pkg-base.eclass | 12 ++++++++++++
 1 file changed, 12 insertions(+)
diff --git a/eclass/dotnet-pkg-base.eclass b/eclass/dotnet-pkg-base.eclass
index 784db5ce83f0..8ec21c9a276c 100644
--- a/eclass/dotnet-pkg-base.eclass
+++ b/eclass/dotnet-pkg-base.eclass
@@ -294,6 +294,18 @@ edotnet() {
 	edo "${DOTNET_PKG_EXECUTABLE}" "${@}"
 }
 
+# @FUNCTION: efsi
+# @USAGE: <command> [args...]
+# @DESCRIPTION:
+# Call dotnet fsi, passing the supplied arguments.
+# FSI is the F# interpreter shipped with .NET SDK, it is useful for running F#
+# maintenance scripts.
+efsi() {
+	debug-print-function ${FUNCNAME} "$@"
+
+	edotnet fsi --nologo "${@}"
+}
+
 # @FUNCTION: dotnet-pkg-base_info
 # @DESCRIPTION:
 # Show information about current .NET SDK that is being used.
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-30  2:27 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-10-30  2:27 UTC (permalink / raw
  To: gentoo-commits
commit:     30a37b9022cdb0108ba04051eba37c0da9f60a50
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Oct 30 02:25:37 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Oct 30 02:26:29 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=30a37b90
toolchain.eclass: filter -Warray-bounds if building D
Bug: https://gcc.gnu.org/PR116975
Closes: https://bugs.gentoo.org/940750
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 5 +++++
 1 file changed, 5 insertions(+)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index dd4130ef9b85..438ef6c2c66a 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1948,6 +1948,11 @@ gcc_do_filter_flags() {
 		filter-flags -fdiagnostics-explain-harder
 	fi
 
+	if is_d ; then
+		# bug #940750
+		filter-flags -Warray-bounds
+	fi
+
 	# Please use USE=lto instead (bug #906007).
 	filter-lto
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-30 11:43 Miroslav Šulc
  0 siblings, 0 replies; 6663+ messages in thread
From: Miroslav Šulc @ 2024-10-30 11:43 UTC (permalink / raw
  To: gentoo-commits
commit:     48a74a98e1d9abbe59dab0b2ca9300479ffcf423
Author:     Volkmar W. Pogatzki <gentoo <AT> pogatzki <DOT> net>
AuthorDate: Wed Oct 30 08:19:38 2024 +0000
Commit:     Miroslav Šulc <fordfrog <AT> gentoo <DOT> org>
CommitDate: Wed Oct 30 11:43:03 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=48a74a98
java-utils-2.eclass: remove undocumented unused function
Removes java-pkg_set-current-vm
Signed-off-by: Volkmar W. Pogatzki <gentoo <AT> pogatzki.net>
Closes: https://github.com/gentoo/gentoo/pull/38836
Signed-off-by: Miroslav Šulc <fordfrog <AT> gentoo.org>
 eclass/java-utils-2.eclass | 4 ----
 1 file changed, 4 deletions(-)
diff --git a/eclass/java-utils-2.eclass b/eclass/java-utils-2.eclass
index 8d9ef40b3570..237657cf551a 100644
--- a/eclass/java-utils-2.eclass
+++ b/eclass/java-utils-2.eclass
@@ -1636,10 +1636,6 @@ java-pkg_is-vm-version-ge() {
 	fi
 }
 
-java-pkg_set-current-vm() {
-	export GENTOO_VM=${1}
-}
-
 # @FUNCTION: java-pkg_current-vm-matches
 # @USAGE: <vm_string1> [<vm_string2> [<vm_string3>...]]
 # @RETURN: 0: the current vm matches any of the provided strings
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-10-30 20:50 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-10-30 20:50 UTC (permalink / raw
  To: gentoo-commits
commit:     ced8cd934532e56c19f72d6a71136c6c907685ea
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Oct 30 20:49:39 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Oct 30 20:49:39 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=ced8cd93
toolchain.eclass: filter -fdiagnostics-details too
Same as 72d5ea56d41b7d5aac351854b7479f5c2c430c83, the flag got renamed.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 438ef6c2c66a..805fc30952ce 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1945,7 +1945,7 @@ gcc_do_filter_flags() {
 	fi
 
 	if ver_test -lt 15.1 ; then
-		filter-flags -fdiagnostics-explain-harder
+		filter-flags -fdiagnostics-explain-harder -fdiagnostics-details
 	fi
 
 	if is_d ; then
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-11-01  9:03 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-11-01  9:03 UTC (permalink / raw
  To: gentoo-commits
commit:     efe2c28cf7a7b9f3a4a26c4fe4057e62de81deb3
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Fri Nov  1 08:58:06 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Fri Nov  1 09:03:52 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=efe2c28c
toolchain.eclass: Add USE=time64 to 14.2.1_p20241026 and newer
Acked-by: Sam James <sam <AT> gentoo.org>
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/toolchain.eclass | 4 ++++
 1 file changed, 4 insertions(+)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 805fc30952ce..e464f8c53972 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -330,6 +330,7 @@ if [[ ${PN} != kgcc64 && ${PN} != gcc-* ]] ; then
 	# and https://rust-gcc.github.io/2023/04/24/gccrs-and-gcc13-release.html for why
 	# it was disabled in 13.
 	tc_version_is_at_least 14.0.0_pre20230423 ${PV} && IUSE+=" rust" TC_FEATURES+=( rust )
+	tc_version_is_at_least 14.2.1_p20241026 ${PV} && IUSE+=" time64"
 fi
 
 if tc_version_is_at_least 10; then
@@ -1060,6 +1061,9 @@ toolchain_src_configure() {
 
 	downgrade_arch_flags
 	gcc_do_filter_flags
+	if tc_version_is_at_least 14.2.1_p20241026 ${PV}; then
+		append-cppflags "-D_GENTOO_TIME64_FORCE=$(usex time64 1 0)"
+	fi
 
 	if ! tc_version_is_at_least 11 && [[ $(gcc-major-version) -ge 12 ]] ; then
 		# https://gcc.gnu.org/PR105695 (bug #849359)
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-11-03  9:35 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-11-03  9:35 UTC (permalink / raw
  To: gentoo-commits
commit:     d82f81cd65b9a668bd7940151e3fa876d4b0ce92
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Nov  3 09:34:26 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Nov  3 09:35:21 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=d82f81cd
toolchain.eclass: fix death hooks for JIT build
We want to recover logs from that too.
Bug: https://bugs.gentoo.org/942769
Fixes: 5bed0c77a1c54ac9297db4bb54af2e45c0558ec7
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 27 +++++++++++++++------------
 1 file changed, 15 insertions(+), 12 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index e464f8c53972..aa7134b23e8e 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -2976,18 +2976,21 @@ XGCC() { get_make_var GCC_FOR_TARGET ; }
 
 has toolchain_death_notice ${EBUILD_DEATH_HOOKS} || EBUILD_DEATH_HOOKS+=" toolchain_death_notice"
 toolchain_death_notice() {
-	if [[ -e "${WORKDIR}"/build ]] ; then
-		pushd "${WORKDIR}"/build >/dev/null
-		(echo '' | $(tc-getCC ${CTARGET}) ${CFLAGS} -v -E - 2>&1) > gccinfo.log
-		[[ -e "${T}"/build.log ]] && cp "${T}"/build.log .
-		tar -acf "${WORKDIR}"/gcc-build-logs.tar.xz \
-			gccinfo.log build.log $(find -name config.log)
-		rm gccinfo.log build.log
-		eerror
-		eerror "Please include ${WORKDIR}/gcc-build-logs.tar.xz in your bug report."
-		eerror
-		popd >/dev/null
-	fi
+	local dir
+	for dir in "${WORKDIR}"/build-jit "${WORKDIR}"/build ; do
+		if [[ -e "${dir}" ]] ; then
+			pushd "${WORKDIR}" >/dev/null
+			(echo '' | $(tc-getCC ${CTARGET}) ${CFLAGS} -v -E - 2>&1) > gccinfo.log
+			[[ -e "${T}"/build.log ]] && cp "${T}"/build.log .
+			tar -arf "${WORKDIR}"/gcc-build-logs.tar.xz \
+				"${dir}"/gccinfo.log "${dir}"/build.log $(find -name "${dir}"/config.log)
+			rm "${dir}"/gccinfo.log "${dir}"/build.log
+			eerror
+			eerror "Please include ${WORKDIR}/gcc-build-logs.tar.xz in your bug report."
+			eerror
+			popd >/dev/null
+		fi
+	done
 }
 
 fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-11-05 10:47 Florian Schmaus
  0 siblings, 0 replies; 6663+ messages in thread
From: Florian Schmaus @ 2024-11-05 10:47 UTC (permalink / raw
  To: gentoo-commits
commit:     9a5db816fec806706bdf4d95ee112bf961e8dc5c
Author:     Volkmar W. Pogatzki <gentoo <AT> pogatzki <DOT> net>
AuthorDate: Mon Nov  4 09:22:42 2024 +0000
Commit:     Florian Schmaus <flow <AT> gentoo <DOT> org>
CommitDate: Tue Nov  5 10:46:50 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=9a5db816
java-utils-2.eclass: remove reference to java-ant-2.eclass
Signed-off-by: Volkmar W. Pogatzki <gentoo <AT> pogatzki.net>
Signed-off-by: Florian Schmaus <flow <AT> gentoo.org>
 eclass/java-utils-2.eclass | 19 -------------------
 1 file changed, 19 deletions(-)
diff --git a/eclass/java-utils-2.eclass b/eclass/java-utils-2.eclass
index 237657cf551a..c0a900b35a00 100644
--- a/eclass/java-utils-2.eclass
+++ b/eclass/java-utils-2.eclass
@@ -2029,25 +2029,6 @@ java-utils-2_pkg_preinst() {
 eant() {
 	debug-print-function ${FUNCNAME} $*
 
-	if [[ ${!JAVA_PKG_BSFIX*} ]] \
-		|| [[ ${JAVA_ANT_BSFIX_EXTRA_ARGS} ]] \
-		|| [[ ${JAVA_ANT_CLASSPATH_TAGS} ]] \
-		|| [[ ${JAVA_ANT_JAVADOC_INPUT_DIRS} ]] \
-		|| [[ ${JAVA_ANT_REWRITE_CLASSPATH} ]] \
-		|| [[ ${EANT_BUILD_XML} ]] \
-		|| [[ ${!EANT_GENTOO_CLASSPATH*} ]] \
-		|| [[ ${EANT_TEST_GENTOO_CLASSPATH} ]]
-	then
-		if [[ ${EBUILD_PHASE} = compile ]]; then
-			java-ant-2_src_configure
-		fi
-
-		if ! has java-ant-2 ${INHERITED}; then
-			local msg="You should inherit java-ant-2 when using eant"
-			java-pkg_announce-qa-violation "${msg}"
-		fi
-	fi
-
 	local antflags="-Dnoget=true -Dmaven.mode.offline=true -Dbuild.sysclasspath=ignore"
 
 	java-pkg_init-compiler_
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-11-05 10:47 Florian Schmaus
  0 siblings, 0 replies; 6663+ messages in thread
From: Florian Schmaus @ 2024-11-05 10:47 UTC (permalink / raw
  To: gentoo-commits
commit:     f28ab51fad9acb876a8fef5dd56f656afcd2776c
Author:     Volkmar W. Pogatzki <gentoo <AT> pogatzki <DOT> net>
AuthorDate: Sun Nov  3 09:21:35 2024 +0000
Commit:     Florian Schmaus <flow <AT> gentoo <DOT> org>
CommitDate: Tue Nov  5 10:46:51 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=f28ab51f
java-ant-2.eclass: Remove dead eclass
Bug: https://bugs.gentoo.org/268313
Bug: https://bugs.gentoo.org/318625
Bug: https://bugs.gentoo.org/539958
Signed-off-by: Volkmar W. Pogatzki <gentoo <AT> pogatzki.net>
Closes: https://github.com/gentoo/gentoo/pull/39180
Signed-off-by: Florian Schmaus <flow <AT> gentoo.org>
 eclass/java-ant-2.eclass | 440 -----------------------------------------------
 1 file changed, 440 deletions(-)
diff --git a/eclass/java-ant-2.eclass b/eclass/java-ant-2.eclass
deleted file mode 100644
index c34c81331998..000000000000
--- a/eclass/java-ant-2.eclass
+++ /dev/null
@@ -1,440 +0,0 @@
-# Copyright 2004-2024 Gentoo Authors
-# Distributed under the terms of the GNU General Public License v2
-
-# @DEAD
-# @ECLASS: java-ant-2.eclass
-# @MAINTAINER:
-# java@gentoo.org
-# @AUTHOR:
-# kiorky <kiorky@cryptelium.net>
-# Petteri Räty <betelgeuse@gentoo.org>
-# @SUPPORTED_EAPIS: 7 8
-# @PROVIDES: java-utils-2
-# @BLURB: eclass for ant based Java packages
-# @DEPRECATED: none
-# @DESCRIPTION:
-# Eclass for Ant-based Java packages. Provides support for both automatic and
-# manual manipulation of build.xml files. Should be inherited after java-pkg-2
-# or java-pkg-opt-2 eclass.
-
-case ${EAPI} in
-	7|8) ;;
-	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
-esac
-
-if [[ -z ${_JAVA_ANT_2_ECLASS} ]] ; then
-_JAVA_ANT_2_ECLASS=1
-
-inherit java-utils-2 multilib
-
-# This eclass provides functionality for Java packages which use
-# ant to build. In particular, it will attempt to fix build.xml files, so that
-# they use the appropriate 'target' and 'source' attributes.
-
-# @ECLASS_VARIABLE: WANT_ANT_TASKS
-# @DEFAULT_UNSET
-# @DESCRIPTION:
-# An $IFS separated list of ant tasks.
-# Ebuild can specify this variable before inheriting java-ant-2 eclass to
-# determine ANT_TASKS it needs. They will be automatically translated to
-# DEPEND variable and ANT_TASKS variable. JAVA_PKG_FORCE_ANT_TASKS can override
-# ANT_TASKS set by WANT_ANT_TASKS, but not the DEPEND due to caching.
-# Ebuilds that need to depend conditionally on certain tasks and specify them
-# differently for different eant calls can't use this simplified approach.
-# You also cannot specify version or anything else than ant-*.
-#
-# @CODE
-# WANT_ANT_TASKS="ant-junit ant-trax"
-# @CODE
-
-#The implementation of dependencies is handled by java-utils-2.eclass
-#WANT_ANT_TASKS
-
-# @VARIABLE: JAVA_ANT_E_DEPEND
-# @INTERNAL
-# @DESCRIPTION:
-# Convenience variable adding packages to DEPEND so they need not be added
-# in the ebuild.
-JAVA_ANT_E_DEPEND+=" >=dev-java/ant-1.10.14-r2:0"
-
-# add ant tasks specified in WANT_ANT_TASKS to DEPEND
-ANT_TASKS_DEPEND="$(java-pkg_ant-tasks-depend)"
-# check that java-pkg_ant-tasks-depend didn't fail
-if [[ $? != 0 ]]; then
-	eerror "${ANT_TASKS_DEPEND}"
-	die "java-pkg_ant-tasks-depend() failed"
-fi
-
-# We need some tools from javatoolkit. We also need ant dependencies
-# constructed above.
-JAVA_ANT_E_DEPEND="${JAVA_ANT_E_DEPEND}
-	${ANT_TASKS_DEPEND}
-	dev-java/javatoolkit"
-unset ANT_TASKS_DEPEND
-
-# this eclass must be inherited after java-pkg-2 or java-pkg-opt-2
-# if it's java-pkg-opt-2, ant dependencies are pulled based on USE flag
-if has java-pkg-opt-2 ${INHERITED}; then
-	JAVA_ANT_E_DEPEND="${JAVA_PKG_OPT_USE}? ( ${JAVA_ANT_E_DEPEND} )"
-elif ! has java-pkg-2 ${INHERITED}; then
-	eerror "java-ant-2 eclass can only be inherited AFTER java-pkg-2 or java-pkg-opt-2"
-fi
-
-DEPEND="${JAVA_ANT_E_DEPEND}"
-
-# @ECLASS_VARIABLE: JAVA_PKG_BSFIX
-# @DESCRIPTION:
-# Should we attempt to 'fix' ant build files to include the source/target
-# attributes when calling javac?
-JAVA_PKG_BSFIX=${JAVA_PKG_BSFIX:-"on"}
-
-# @ECLASS_VARIABLE: JAVA_PKG_BSFIX_ALL
-# @DESCRIPTION:
-# If we're fixing build files, should we try to fix all the ones we can find?
-JAVA_PKG_BSFIX_ALL=${JAVA_PKG_BSFIX_ALL:-"yes"}
-
-# @ECLASS_VARIABLE: JAVA_PKG_BSFIX_NAME
-# @DESCRIPTION:
-# Filename of build files to fix/search for
-JAVA_PKG_BSFIX_NAME=${JAVA_PKG_BSFIX_NAME:-"build.xml"}
-
-# @ECLASS_VARIABLE: JAVA_PKG_BSFIX_TARGET_TAGS
-# @DESCRIPTION:
-# Targets to fix the 'source' attribute in
-JAVA_PKG_BSFIX_TARGET_TAGS=${JAVA_PKG_BSFIX_TARGET_TAGS:-"javac xjavac javac.preset"}
-
-# @ECLASS_VARIABLE: JAVA_PKG_BSFIX_SOURCE_TAGS
-# @DESCRIPTION:
-# Targets to fix the 'target' attribute in
-JAVA_PKG_BSFIX_SOURCE_TAGS=${JAVA_PKG_BSFIX_SOURCE_TAGS:-"javadoc javac xjavac javac.preset"}
-
-# @ECLASS_VARIABLE: JAVA_ANT_CLASSPATH_TAGS
-# @DESCRIPTION:
-# Targets to add the classpath attribute to
-JAVA_ANT_CLASSPATH_TAGS="javac xjavac"
-
-# @ECLASS_VARIABLE: JAVA_ANT_IGNORE_SYSTEM_CLASSES
-# @DEFAULT_UNSET
-# @DESCRIPTION:
-# When set, <available> Ant tasks are rewritten to ignore Ant's runtime classpath.
-
-# @FUNCTION: java-ant-2_src_configure
-# @DESCRIPTION:
-# src_configure rewrites the build.xml files automatically.
-java-ant-2_src_configure() {
-	# if java support is optional, don't perform this when the USE flag is off
-	if has java-pkg-opt-2 ${INHERITED}; then
-		use ${JAVA_PKG_OPT_USE} || return
-	fi
-
-	# eant will call us unless called by Portage
-	[[ -e "${T}/java-ant-2_src_configure-run" ]] && return
-
-	[[ "${JAVA_ANT_IGNORE_SYSTEM_CLASSES}" ]] \
-		&& java-ant_ignore-system-classes "${S}/build.xml"
-
-	java-ant_bsfix
-	touch "${T}/java-ant-2_src_configure-run"
-}
-
-# @FUNCTION: java-ant_bsfix
-# @INTERNAL
-# @DESCRIPTION:
-# Attempts to fix build files.
-#
-# @CODE
-# Affected by variables:
-# 	JAVA_PKG_BSFIX
-#	JAVA_PKG_BSFIX_ALL
-#	JAVA_PKG_BSFIX_NAME,
-# @CODE
-java-ant_bsfix() {
-	debug-print-function ${FUNCNAME} $*
-
-	[[ "${JAVA_PKG_BSFIX}" != "on" ]] && return
-	if ! java-pkg_needs-vm; then
-		echo "QA Notice: Package is using java-ant, but doesn't depend on a Java VM"
-	fi
-
-	pushd "${S}" >/dev/null || die
-
-	local find_args=""
-	[[ "${JAVA_PKG_BSFIX_ALL}" == "yes" ]] || find_args="-maxdepth 1"
-
-	find_args="${find_args} -type f ( -name ${JAVA_PKG_BSFIX_NAME// / -o -name } )"
-
-	local bsfix_these=() line
-	while IFS= read -r -d $'\0' line; do
-		bsfix_these+=( "${line}" )
-	done < <(find . ${find_args} -print0)
-
-	[[ "${bsfix_these[@]}" ]] && java-ant_bsfix_files "${bsfix_these[@]}"
-
-	popd > /dev/null || die
-}
-
-# @FUNCTION: java-ant_bsfix_files
-# @USAGE: <path/to/first/build.xml> [path/to/second.build.xml ...]
-# @DESCRIPTION:
-# Attempts to fix named build files.
-#
-# @CODE
-# Affected by variables:
-#	JAVA_PKG_BSFIX_SOURCE_TAGS
-#	JAVA_PKG_BSFIX_TARGET_TAGS
-#	JAVA_ANT_REWRITE_CLASSPATH
-#	JAVA_ANT_JAVADOC_INPUT_DIRS: Where we can find java sources for javadoc
-#                                input. Can be a space separated list of
-#                                directories
-#	JAVA_ANT_BSFIX_EXTRA_ARGS: You can use this to pass extra variables to the
-#	                           rewriter if you know what you are doing.
-# @CODE
-#
-# If JAVA_ANT_JAVADOC_INPUT_DIRS is set, we will turn on the adding of a basic
-# javadoc target to the ant's build.xml with the javadoc xml-rewriter feature.
-# Then we will set EANT DOC TARGET to the added javadoc target
-# NOTE: the variable JAVA_ANT_JAVADOC_OUTPUT_DIR points where we will
-#       generate the javadocs. This is a read-only variable, dont change it.
-
-# When changing this function, make sure that it works with paths with spaces in
-# them.
-java-ant_bsfix_files() {
-	debug-print-function ${FUNCNAME} $*
-
-	[[ ${#} = 0 ]] && die "${FUNCNAME} called without arguments"
-
-	local want_source="$(java-pkg_get-source)"
-	local want_target="$(java-pkg_get-target)"
-
-	debug-print "${FUNCNAME}: target: ${want_target} source: ${want_source}"
-
-	if [ -z "${want_source}" -o -z "${want_target}" ]; then
-		eerror "Could not find valid -source/-target values"
-		eerror "Please file a bug about this on bugs.gentoo.org"
-		die "Could not find valid -source/-target values"
-	else
-		local files=()
-
-		for file in "${@}"; do
-			debug-print "${FUNCNAME}: ${file}"
-
-			if [[ -n "${JAVA_PKG_DEBUG}" ]]; then
-				cp "${file}" "${file}.orig" || die "failed to copy ${file}"
-			fi
-
-			if [[ ! -w "${file}" ]]; then
-				chmod u+w "${file}" || die "chmod u+w ${file} failed"
-			fi
-
-			files+=( -f "${file}" )
-		done
-
-		if [ -e "${EPREFIX}/usr/libexec/javatoolkit" ]; then
-			local rewriter3="${EPREFIX}/usr/libexec/javatoolkit/xml-rewrite-3.py"
-			local rewriter4="${EPREFIX}/usr/libexec/javatoolkit/build-xml-rewrite"
-		else
-			local rewriter3="${EPREFIX}/usr/$(get_libdir)/javatoolkit/bin/xml-rewrite-3.py"
-			local rewriter4="${EPREFIX}/usr/$(get_libdir)/javatoolkit/bin/build-xml-rewrite"
-		fi
-
-		if [[ -x ${rewriter4} && ${JAVA_ANT_ENCODING} ]]; then
-			[[ ${JAVA_ANT_REWRITE_CLASSPATH} ]] && local gcp="-g"
-			[[ ${JAVA_ANT_ENCODING} ]] && local enc="-e ${JAVA_ANT_ENCODING}"
-			echo "cElementTree rewriter"
-			debug-print "${rewriter4} extra args: ${gcp} ${enc}"
-			${rewriter4} ${gcp} ${enc} \
-				-c "${JAVA_PKG_BSFIX_SOURCE_TAGS}" source ${want_source} \
-				-c "${JAVA_PKG_BSFIX_TARGET_TAGS}" target ${want_target} \
-				"${@}" || die "build-xml-rewrite failed"
-		else
-			debug-print "Using third generation rewriter"
-			echo "Rewriting attributes"
-			local bsfix_extra_args=()
-			# WARNING KEEP THE ORDER, ESPECIALLY FOR CHANGED ATTRIBUTES!
-			if [[ -n ${JAVA_ANT_REWRITE_CLASSPATH} ]]; then
-				local cp_tags="${JAVA_ANT_CLASSPATH_TAGS// / -e }"
-				bsfix_extra_args+=( -g -e ${cp_tags} )
-				bsfix_extra_args+=( -a classpath -v '${gentoo.classpath}' )
-			fi
-			if [[ -n ${JAVA_ANT_JAVADOC_INPUT_DIRS} ]]; then
-				if [[ -n ${JAVA_ANT_JAVADOC_OUTPUT_DIR} ]]; then
-					die "Do not define JAVA_ANT_JAVADOC_OUTPUT_DIR!"
-				fi
-				# Where will our generated javadoc go.
-				readonly JAVA_ANT_JAVADOC_OUTPUT_DIR="${WORKDIR}/gentoo_javadoc"
-				mkdir -p "${JAVA_ANT_JAVADOC_OUTPUT_DIR}" || die
-
-				if has doc ${IUSE}; then
-					if use doc; then
-						if [[ -z ${EANT_DOC_TARGET} ]]; then
-							EANT_DOC_TARGET="gentoojavadoc"
-						else
-							die "You can't use javadoc adding and set EANT_DOC_TARGET too."
-						fi
-
-						for dir in ${JAVA_ANT_JAVADOC_INPUT_DIRS};do
-							if [[ ! -d ${dir} ]]; then
-								eerror "Directory ${dir} doesn't exist"
-								die "You must specify directories for javadoc input/output dirs."
-							fi
-						done
-						bsfix_extra_args+=( --javadoc --source-directory )
-						# filter third/double spaces
-						JAVA_ANT_JAVADOC_INPUT_DIRS=${JAVA_ANT_JAVADOC_INPUT_DIRS//   /}
-						JAVA_ANT_JAVADOC_INPUT_DIRS=${JAVA_ANT_JAVADOC_INPUT_DIRS//  /}
-						bsfix_extra_args+=( ${JAVA_ANT_JAVADOC_INPUT_DIRS// / --source-directory } )
-						bsfix_extra_args+=( --output-directory "${JAVA_ANT_JAVADOC_OUTPUT_DIR}" )
-					fi
-				else
-					die "You need to have doc in IUSE when using JAVA_ANT_JAVADOC_INPUT_DIRS"
-				fi
-			fi
-
-			[[ -n ${JAVA_ANT_BSFIX_EXTRA_ARGS} ]] \
-				&& bsfix_extra_args+=( ${JAVA_ANT_BSFIX_EXTRA_ARGS} )
-
-			debug-print "bsfix_extra_args: ${bsfix_extra_args[*]}"
-
-			${rewriter3} "${files[@]}" \
-				-c --source-element ${JAVA_PKG_BSFIX_SOURCE_TAGS// / --source-element } \
-				--source-attribute source --source-value ${want_source} \
-				--target-element   ${JAVA_PKG_BSFIX_TARGET_TAGS// / --target-element }  \
-				--target-attribute target --target-value ${want_target} \
-				--target-attribute nowarn --target-value yes \
-				"${bsfix_extra_args[@]}" \
-				|| die "xml-rewrite-3 failed: ${file}"
-		fi
-
-		if [[ -n "${JAVA_PKG_DEBUG}" ]]; then
-			for file in "${@}"; do
-				diff -NurbB "${file}.orig" "${file}"
-			done
-		fi
-	fi
-	return 0 # so that the 1 for diff doesn't get reported
-}
-
-
-# @FUNCTION: java-ant_bsfix_one
-# @USAGE: <path/to/build.xml>
-# @DESCRIPTION:
-# Attempts to fix named build file.
-#
-# @CODE
-# Affected by variables:
-#	JAVA_PKG_BSFIX_SOURCE_TAGS
-#	JAVA_PKG_BSFIX_TARGET_TAGS
-# @CODE
-java-ant_bsfix_one() {
-	debug-print-function ${FUNCNAME} $*
-
-	if [ -z "${1}" ]; then
-		eerror "${FUNCNAME} needs one argument"
-		die "${FUNCNAME} needs one argument"
-	fi
-
-	java-ant_bsfix_files "${1}"
-}
-
-# @FUNCTION: java-ant_rewrite-classpath
-# @USAGE: [path/to/build.xml]
-# @DESCRIPTION:
-# Adds 'classpath="${gentoo.classpath}"' to specified build file.
-#
-# Affected by:
-#	JAVA_ANT_CLASSPATH_TAGS
-#
-# Parameter defaults to build.xml when not specified
-java-ant_rewrite-classpath() {
-	debug-print-function ${FUNCNAME} $*
-
-	local file="${1}"
-	[[ -z "${1}" ]] && file=build.xml
-	[[ ${#} -gt 1 ]] && die "${FUNCNAME} currently can only rewrite one file."
-
-	echo "Adding gentoo.classpath to ${file}"
-	debug-print "java-ant_rewrite-classpath: ${file}"
-
-	cp "${file}" "${file}.orig" || die "failed to copy ${file}"
-
-	chmod u+w "${file}"
-
-	java-ant_xml-rewrite -f "${file}" --change \
-		-e ${JAVA_ANT_CLASSPATH_TAGS// / -e } -a classpath -v '${gentoo.classpath}'
-
-	if [[ -n "${JAVA_PKG_DEBUG}" ]]; then
-		diff -NurbB "${file}.orig" "${file}"
-	fi
-}
-
-# @FUNCTION: java-ant_ignore-system-classes
-# @USAGE: [path/to/build.xml]
-# @DESCRIPTION:
-# Makes the available task ignore classes in the system classpath
-# Parameter defaults to build.xml when not specified
-java-ant_ignore-system-classes() {
-	debug-print-function ${FUNCNAME} $*
-	local file=${1:-build.xml}
-	echo "Changing ignoresystemclasses to true for available tasks in ${file}"
-	java-ant_xml-rewrite -f "${file}" --change \
-		-e available -a ignoresystemclasses -v "true"
-}
-
-# @FUNCTION: java-ant_xml-rewrite
-# @USAGE: <xml rewriter arguments>
-# @DESCRIPTION:
-# Run the right xml-rewrite binary with the given arguments
-java-ant_xml-rewrite() {
-	local gen2_1="${EPREFIX}/usr/$(get_libdir)/javatoolkit/bin/xml-rewrite-2.py"
-	local gen2_2="${EPREFIX}/usr/libexec/javatoolkit/xml-rewrite-2.py"
-	# gen1 is deprecated
-	if [[ -x "${gen2_2}" ]]; then
-		${gen2_2} "${@}" || die "${gen2_2} failed"
-	elif [[ -x "${gen2_1}" ]]; then
-		${gen2_1} "${@}" || die "${gen2_1} failed"
-	else
-		eerror "No binary for rewriting found."
-		eerror "Do you have dev-java/javatoolkit installed?"
-		die "xml-rewrite not found"
-	fi
-}
-
-# @FUNCTION: java-ant_rewrite-bootclasspath
-# @USAGE: <version> [path/to/build.xml] [prepend] [append]
-# @DESCRIPTION:
-# Adds bootclasspath to javac-like tasks in build.xml filled with jars of a
-# bootclasspath package of given version.
-#
-# @CODE
-# Affected by:
-#	JAVA_PKG_BSFIX_TARGET_TAGS - the tags of javac tasks
-#
-# Parameters:
-# $1 - the version of bootclasspath (e.g. 1.5), 'auto' for bootclasspath
-#      of the current JDK
-# $2 - path to desired build.xml file, defaults to 'build.xml'
-# $3 - (optional) what to prepend the bootclasspath with (to override)
-# $4 - (optional) what to append to the bootclasspath
-# @CODE
-java-ant_rewrite-bootclasspath() {
-	local version="${1}"
-	local file="${2-build.xml}"
-	local extra_before="${3}"
-	local extra_after="${4}"
-
-	local bcp="$(java-pkg_get-bootclasspath "${version}")"
-
-	if [[ -n "${extra_before}" ]]; then
-		bcp="${extra_before}:${bcp}"
-	fi
-	if [[ -n "${extra_after}" ]]; then
-		bcp="${bcp}:${extra_after}"
-	fi
-
-	java-ant_xml-rewrite -f "${file}" -c -e ${JAVA_PKG_BSFIX_TARGET_TAGS// / -e } \
-		-a bootclasspath -v "${bcp}"
-}
-
-fi
-
-EXPORT_FUNCTIONS src_configure
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-11-06 11:27 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-11-06 11:27 UTC (permalink / raw
  To: gentoo-commits
commit:     1bf781b83fdfd96e662ec76a54ff5ca0b9aad5f6
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Nov  6 11:18:47 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Nov  6 11:18:47 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=1bf781b8
toolchain.eclass: further death hook fixes
Fixes: d82f81cd65b9a668bd7940151e3fa876d4b0ce92
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index aa7134b23e8e..b25c5dcf0929 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -2980,10 +2980,10 @@ toolchain_death_notice() {
 	for dir in "${WORKDIR}"/build-jit "${WORKDIR}"/build ; do
 		if [[ -e "${dir}" ]] ; then
 			pushd "${WORKDIR}" >/dev/null
-			(echo '' | $(tc-getCC ${CTARGET}) ${CFLAGS} -v -E - 2>&1) > gccinfo.log
-			[[ -e "${T}"/build.log ]] && cp "${T}"/build.log .
+			(echo '' | $(tc-getCC ${CTARGET}) ${CFLAGS} -v -E - 2>&1) > "${dir}"/gccinfo.log
+			[[ -e "${T}"/build.log ]] && cp "${T}"/build.log "${dir}"
 			tar -arf "${WORKDIR}"/gcc-build-logs.tar.xz \
-				"${dir}"/gccinfo.log "${dir}"/build.log $(find -name "${dir}"/config.log)
+				"${dir#${WORKDIR}/}"/gccinfo.log "${dir#${WORKDIR}/}"/build.log $(find -name "${dir}"/config.log)
 			rm "${dir}"/gccinfo.log "${dir}"/build.log
 			eerror
 			eerror "Please include ${WORKDIR}/gcc-build-logs.tar.xz in your bug report."
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-11-07  5:28 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-11-07  5:28 UTC (permalink / raw
  To: gentoo-commits
commit:     528958f2f29247e0ab7c85d9c80e6a69cda7f9c8
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Wed Nov  6 14:53:18 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Thu Nov  7 05:26:40 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=528958f2
llvm.org.eclass: Add 20.0.0_pre20241106 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index 4d7e0e271485..7325bf75e3bb 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -72,6 +72,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 			_LLVM_SOURCE_TYPE=snapshot
 
 			case ${PV} in
+				20.0.0_pre20241106)
+					EGIT_COMMIT=0e907c17214aa3b1a60b66867fea3cc0f0dcbaa0
+					;;
 				20.0.0_pre20241029)
 					EGIT_COMMIT=3f4468faaa9525ad615118675c3c68938f4a8d5f
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-11-07  5:28 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-11-07  5:28 UTC (permalink / raw
  To: gentoo-commits
commit:     258da63848e5049c974beb87e2d2ed97594ba0ad
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Wed Nov  6 07:27:30 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Thu Nov  7 05:26:39 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=258da638
llvm.org.eclass: Remove old snapshots
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 9 ---------
 1 file changed, 9 deletions(-)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index dddb87735875..4d7e0e271485 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -75,15 +75,6 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 				20.0.0_pre20241029)
 					EGIT_COMMIT=3f4468faaa9525ad615118675c3c68938f4a8d5f
 					;;
-				20.0.0_pre20241023)
-					EGIT_COMMIT=0cb80c4f00689ca00a85e1f38bc6ae9dd0bf980e
-					;;
-				20.0.0_pre20241015)
-					EGIT_COMMIT=9aef0fd52a0b2bf31cf3bae8a0693d6df8db6e04
-					;;
-				20.0.0_pre20241009)
-					EGIT_COMMIT=fb2960aad93f6c02e0ea8de0568c0aef8896eee8
-					;;
 				*)
 					die "Unknown snapshot: ${PV}"
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-11-09  6:26 Matt Jolly
  0 siblings, 0 replies; 6663+ messages in thread
From: Matt Jolly @ 2024-11-09  6:26 UTC (permalink / raw
  To: gentoo-commits
commit:     8ba94e73b14d16da3b8154ee468826df34bd61e0
Author:     Matt Jolly <kangie <AT> gentoo <DOT> org>
AuthorDate: Tue Nov  5 06:26:11 2024 +0000
Commit:     Matt Jolly <kangie <AT> gentoo <DOT> org>
CommitDate: Sat Nov  9 05:31:34 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=8ba94e73
cargo: update for rust eclass
Inherit the rust eclass and take advantage of eclass features like
`RUST_MIN_VER`.
`RUST_DEPEND` was moved into the rust eclass in the previous commit
and is now prowided via this mechanism
`CARGO_OPTIONAL` now sets `RUST_OPTIONAL`, requiring ebuilds to
set `RUST_DEPEND` manually and manage both cargo and rust eclass
functions.
Replace calls to `cargo` with the rust eclass exported ${CARGO}.
Signed-off-by: Matt Jolly <kangie <AT> gentoo.org>
 eclass/cargo.eclass | 59 +++++++++++++++++++++++++++++++++++++----------------
 1 file changed, 41 insertions(+), 18 deletions(-)
diff --git a/eclass/cargo.eclass b/eclass/cargo.eclass
index 499fe5498c96..855692b72ec7 100644
--- a/eclass/cargo.eclass
+++ b/eclass/cargo.eclass
@@ -8,6 +8,7 @@
 # Doug Goldstein <cardoe@gentoo.org>
 # Georgy Yakovlev <gyakovlev@gentoo.org>
 # @SUPPORTED_EAPIS: 8
+# @PROVIDES: rust
 # @BLURB: common functions and variables for cargo builds
 
 case ${EAPI} in
@@ -18,25 +19,36 @@ esac
 if [[ -z ${_CARGO_ECLASS} ]]; then
 _CARGO_ECLASS=1
 
-# check and document RUST_DEPEND and options we need below in case conditions.
+if [[ -n ${RUST_NEEDS_LLVM} ]]; then
+	if [[ -z ${_LLVM_R1_ECLASS} ]]; then
+		die "Please inherit llvm-r1.eclass before cargo.eclass when using RUST_NEEDS_LLVM"
+	fi
+fi
+
+if [[ -n ${CARGO_OPTIONAL} ]]; then
+	RUST_OPTIONAL=1
+fi
+
+# Either the lowest slot supported by rust.eclass _or_
+# reference the changelog for a particular feature requirement
 # https://github.com/rust-lang/cargo/blob/master/CHANGELOG.md
-RUST_DEPEND="virtual/rust"
+_CARGO_ECLASS_RUST_MIN_VER="1.71.1"
 
 case ${EAPI} in
 	8)
-		# 1.39 added --workspace
-		# 1.46 added --target dir
-		# 1.48 added term.progress config option
-		# 1.51 added split-debuginfo profile option
-		# 1.52 may need setting RUSTC_BOOTSTRAP envvar for some crates
-		# 1.53 added cargo update --offline, can be used to update vulnerable crates from pre-fetched registry without editing toml
-		RUST_DEPEND=">=virtual/rust-1.53"
+		if [[ -n ${RUST_MIN_VER} ]]; then
+			# This is _very_ unlikely given that we leverage the rust eclass but just in case cargo requires a newer version
+			# than the oldest in-tree in future.
+			if ver_test "${RUST_MIN_VER}" -lt "${_CARGO_ECLASS_RUST_MIN_VER}"; then
+				die "RUST_MIN_VERSION must be at least ${_CARGO_ECLASS_RUST_MIN_VER}"
+			fi
+		else
+			RUST_MIN_VER="${_CARGO_ECLASS_RUST_MIN_VER}"
+		fi
 		;;
 esac
 
-inherit flag-o-matic multiprocessing rust-toolchain toolchain-funcs
-
-[[ ! ${CARGO_OPTIONAL} ]] && BDEPEND="${RUST_DEPEND}"
+inherit flag-o-matic multiprocessing rust rust-toolchain toolchain-funcs
 
 IUSE="${IUSE} debug"
 
@@ -107,9 +119,8 @@ ECARGO_VENDOR="${ECARGO_HOME}/gentoo"
 # be considered optional. No dependencies will be added and no phase
 # functions will be exported.
 #
-# If you enable CARGO_OPTIONAL, you have to set BDEPEND on virtual/rust
-# for your package and call at least cargo_gen_config manually before using
-# other src_functions or cargo_env of this eclass.
+# If you enable CARGO_OPTIONAL call at least cargo_gen_config manually
+# before using other src_functions or cargo_env of this eclass.
 # Note that cargo_gen_config is automatically called by cargo_src_unpack.
 
 # @ECLASS_VARIABLE: myfeatures
@@ -129,6 +140,11 @@ ECARGO_VENDOR="${ECARGO_HOME}/gentoo"
 # }
 # @CODE
 
+# @ECLASS_VARIABLE: ECARGO_HOME
+# @OUTPUT_VARIABLE
+# @DESCRIPTION:
+# Location of the cargo home directory.
+
 # @ECLASS_VARIABLE: ECARGO_REGISTRY_DIR
 # @USER_VARIABLE
 # @DEFAULT_UNSET
@@ -148,6 +164,11 @@ ECARGO_VENDOR="${ECARGO_HOME}/gentoo"
 # cargo_live_src_unpack.
 # Inherits value of EVCS_OFFLINE if not set explicitly.
 
+# @ECLASS_VARIABLE: ECARGO_VENDOR
+# @OUTPUT_VARIABLE
+# @DESCRIPTION:
+# Location of the cargo vendor directory.
+
 # @ECLASS_VARIABLE: EVCS_UMASK
 # @USER_VARIABLE
 # @DEFAULT_UNSET
@@ -531,6 +552,8 @@ cargo_src_configure() {
 # take affect due to Cargo limitations, so add these to your ebuild's RUSTFLAGS
 # if they seem important.
 cargo_env() {
+	debug-print-function ${FUNCNAME} "$@"
+
 	[[ ${_CARGO_GEN_CONFIG_HAS_RUN} ]] || \
 		die "FATAL: please call cargo_gen_config before using ${FUNCNAME}"
 
@@ -604,7 +627,7 @@ cargo_env() {
 cargo_src_compile() {
 	debug-print-function ${FUNCNAME} "$@"
 
-	set -- cargo build $(usex debug "" --release) ${ECARGO_ARGS[@]} "$@"
+	set -- ${CARGO} build $(usex debug "" --release) ${ECARGO_ARGS[@]} "$@"
 	einfo "${@}"
 	cargo_env "${@}" || die "cargo build failed"
 }
@@ -618,7 +641,7 @@ cargo_src_compile() {
 cargo_src_install() {
 	debug-print-function ${FUNCNAME} "$@"
 
-	set -- cargo install $(has --path ${@} || echo --path ./) \
+	set -- ${CARGO} install $(has --path ${@} || echo --path ./) \
 		--root "${ED}/usr" \
 		${GIT_CRATES[@]:+--frozen} \
 		$(usex debug --debug "") \
@@ -636,7 +659,7 @@ cargo_src_install() {
 cargo_src_test() {
 	debug-print-function ${FUNCNAME} "$@"
 
-	set -- cargo test $(usex debug "" --release) ${ECARGO_ARGS[@]} "$@"
+	set -- ${CARGO} test $(usex debug "" --release) ${ECARGO_ARGS[@]} "$@"
 	einfo "${@}"
 	cargo_env "${@}" || die "cargo test failed"
 }
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-11-09  6:26 Matt Jolly
  0 siblings, 0 replies; 6663+ messages in thread
From: Matt Jolly @ 2024-11-09  6:26 UTC (permalink / raw
  To: gentoo-commits
commit:     542e055db9a8c762714d3870816f8a5c6e52f853
Author:     Matt Jolly <kangie <AT> gentoo <DOT> org>
AuthorDate: Sun Nov  3 00:15:32 2024 +0000
Commit:     Matt Jolly <kangie <AT> gentoo <DOT> org>
CommitDate: Sat Nov  9 05:31:28 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=542e055d
rust.eclass: Introduce new eclass for slotted Rust
The rust eclass acts similarly to the llvm eclass.
It works with optional `RUST_{MAX,MIN}_SLOT` variables to
enable ebuilds to trivially dependencies on appropriate
Rust SLOTs.
A `RUST_NEEDS_LLVM` variable can be set to have the eclass read
`LLVM_COMPAT` and generate an llvm-r1-USE-gated dependency string.
`RUST_USEDEP`, if set will be included in the dependency string
and checks against installed packages.
In either case these are stored in `RUST_DEPEND` for consumpion
in the ebuild, and added to BDEPEND unless unless `RUST_OPTIONAL`
is set. `RUST_DEPEND` will only ever include in-tree slots; there
is no need to set `RUST_MIN_VER` if all in-tree versions are suitable.
If `RUST_MIN_VER` is set to a value older than the oldest in-tree slot
it is treated as if it is set to the lowest available.
The default `rust_pkg_setup` will prefix the selected slot to
`PATH` and export `RUSTC` and `CARGO` variables pointing to that
slot for ease-of-use.
This should prevent issues like:
Bug: https://bugs.gentoo.org/907492
Bug: https://bugs.gentoo.org/942444
Signed-off-by: Matt Jolly <kangie <AT> gentoo.org>
 eclass/rust.eclass | 464 +++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 file changed, 464 insertions(+)
diff --git a/eclass/rust.eclass b/eclass/rust.eclass
new file mode 100644
index 000000000000..12ef4b90a7ac
--- /dev/null
+++ b/eclass/rust.eclass
@@ -0,0 +1,464 @@
+# Copyright 2024 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+# @ECLASS: rust.eclass
+# @MAINTAINER:
+# Matt Jolly <kangie@gentoo.org>
+# @AUTHOR:
+# Matt Jolly <kangie@gentoo.org>
+# @SUPPORTED_EAPIS: 8
+# @BLURB: Utility functions to build against slotted Rust
+# @DESCRIPTION:
+# An eclass to reliably depend on a Rust or Rust/LLVM combination for
+# a given Rust slot. To use the eclass:
+#
+# 1. If required, set RUST_{MAX,MIN}_SLOT to the range of supported slots.
+# 2. If rust is optional, set RUST_OPTIONAL to a non-empty value then
+#     appropriately gate ${RUST_DEPEND}
+# 3. Use rust_pkg_setup, get_rust_prefix or RUST_SLOT.
+
+# Example use for a package supporting Rust 1.72.0 to 1.82.0:
+# @CODE
+#
+# RUST_MAX_VER="1.82.0"
+# RUST_MIN_VER="1.72.0"
+#
+# inherit meson rust
+#
+# # only if you need to define one explicitly
+# pkg_setup() {
+#	rust_pkg_setup
+#	do-something-else
+# }
+# @CODE
+#
+# Example for a package needing Rust w/ a specific target:
+# @CODE
+# RUST_USEDEP='clippy,${MULTILIB_USEDEP}'
+#
+# inherit multilib-minimal meson rust
+#
+# @CODE
+
+case ${EAPI} in
+	8) ;;
+	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
+esac
+
+if [[ -z ${_RUST_ECLASS} ]]; then
+_RUST_ECLASS=1
+
+if [[ -n ${RUST_NEEDS_LLVM} ]]; then
+	if [[ -z ${_LLVM_R1_ECLASS} ]]; then
+		die "Please inherit llvm-r1.eclass before rust.eclass when using RUST_NEEDS_LLVM"
+	fi
+fi
+
+# == internal control knobs ==
+
+# @ECLASS_VARIABLE: _RUST_LLVM_MAP
+# @INTERNAL
+# @DESCRIPTION:
+# Definitive list of Rust slots and the associated LLVM slot, newest first.
+declare -A -g -r _RUST_LLVM_MAP=(
+	["1.82.0"]=19
+	["1.81.0"]=18
+	["1.80.1"]=18
+	["1.79.0"]=18
+	["1.77.1"]=17
+	["1.75.0"]=17
+	["1.74.1"]=17
+	["1.71.1"]=16
+)
+
+# @ECLASS_VARIABLE: _RUST_SLOTS_ORDERED
+# @INTERNAL
+# @DESCRIPTION:
+# Array of Rust slots, newest first.
+# While _RUST_LLVM_MAP stores useful info about the relationship between Rust and LLVM slots,
+# this array is used to store the Rust slots in a more convenient order for iteration.
+declare -a -g -r _RUST_SLOTS_ORDERED=(
+	"1.82.0"
+	"1.81.0"
+	"1.80.1"
+	"1.79.0"
+	"1.77.1"
+	"1.75.0"
+	"1.74.1"
+	"1.71.1"
+)
+
+# == control variables ==
+
+# @ECLASS_VARIABLE: RUST_MAX_VER
+# @DEFAULT_UNSET
+# @DESCRIPTION:
+# Highest Rust slot supported by the package. Needs to be set before
+# rust_pkg_setup is called. If unset, no upper bound is assumed.
+
+# @ECLASS_VARIABLE: RUST_MIN_VER
+# @DEFAULT_UNSET
+# @DESCRIPTION:
+# Lowest Rust slot supported by the package. Needs to be set before
+# rust_pkg_setup is called. If unset, no lower bound is assumed.
+
+# @eclass-variable: RUST_NEEDS_LLVM
+# @DEFAULT_UNSET
+# @DESCRIPTION:
+# If set to a non-empty value generate a llvm_slot_${llvm_slot}? gated
+# dependency block for rust slots in LLVM_COMPAT. This is useful for
+# packages that need a tight coupling between Rust and LLVM but don't
+# really care _which_ version of Rust is selected. Combine with
+# RUST_MAX_VER and RUST_MIN_VER to limit the range of Rust versions
+# that are acceptable. Will `die` if llvm-r1 is not inherited or
+# an invalid combination of RUST and LLVM slots is detected; this probably
+# means that a LLVM slot in LLVM_COMPAT has had all of its Rust slots filtered.
+
+# @ECLASS_VARIABLE: RUST_DEPEND
+# @OUTPUT_VARIABLE
+# @DESCRIPTION:
+# This is an eclass-generated Rust dependency string, filtered by
+# RUST_MAX_VER and RUST_MIN_VER. If RUST_NEEDS_LLVM is set, this
+# is gropeda and gated by an appropriate `llvm_slot_x` USE for all
+# implementations listed in LLVM_COMPAT.
+
+# @ECLASS_VARIABLE: RUST_OPTIONAL
+# @DEFAULT_UNSET
+# @DESCRIPTION:
+# If set to a non-empty value, the Rust dependency will not be added
+# to BDEPEND. This is useful for where packages need to gate rust behind
+# certain USE themselves.
+
+# @ECLASS_VARIABLE: RUST_USEDEP
+# @DEFAULT_UNSET
+# @DESCRIPTION:
+# Additional USE-dependencies to be added to the Rust dependency.
+# This is useful for packages that need to depend on specific Rust
+# features, like clippy or rustfmt. The variable is expanded before
+# being used in the Rust dependency.
+
+# == global metadata ==
+
+_rust_set_globals() {
+	debug-print-function ${FUNCNAME} "$@"
+
+	# If RUST_MIN_VER is older than our oldest slot we'll just set it to that
+	# internally so we don't have to worry about it later.
+	if ! ver_test "${_RUST_SLOTS_ORDERED[-1]}" -gt "${RUST_MIN_VER:-0}"; then
+		RUST_MIN_VER="${_RUST_SLOTS_ORDERED[-1]}"
+	fi
+
+	# and if it falls between slots we'll set it to the next highest slot
+	# We can skip this we match a slot exactly.
+	if ! [[ "${_RUST_SLOTS_ORDERED[@]}" == *"${RUST_MIN_VER}"* ]]; then
+		local i
+		for (( i=${#_RUST_SLOTS_ORDERED[@]}-1 ; i>=0 ; i-- )); do
+			if ver_test "${_RUST_SLOTS_ORDERED[$i]}" -gt "${RUST_MIN_VER}"; then
+				RUST_MIN_VER="${_RUST_SLOTS_ORDERED[$i]}"
+				break
+			fi
+		done
+	fi
+
+	if [[ -n "${RUST_MAX_VER}" && -n "${RUST_MIN_VER}" ]]; then
+		if ! ver_test "${RUST_MAX_VER}" -ge "${RUST_MIN_VER}"; then
+			die "RUST_MAX_VER must not be older than RUST_MIN_VER"
+		fi
+	fi
+
+	local slot
+	# Try to keep this in order of newest to oldest
+	for slot in "${_RUST_SLOTS_ORDERED[@]}"; do
+		if ver_test "${slot}" -le "${RUST_MAX_VER:-9999}" && \
+			ver_test "${slot}" -ge "${RUST_MIN_VER:-0}"; then
+			_RUST_SLOTS+=( "${slot}" )
+		fi
+	done
+
+	_RUST_SLOTS=( "${_RUST_SLOTS[@]}" )
+
+	# We may have been passed a variable like ${MULTILIB_USEDEP}; expand it.
+	if [[ -n "${RUST_USEDEP}" ]]; then
+		eval $(echo RUST_USEDEP="${RUST_USEDEP}")
+		[[ -z "${RUST_USEDEP}" ]] && die "When evaluated, RUST_USEDEP is empty"
+	fi
+
+	readonly _RUST_SLOTS
+
+	local rust_dep=()
+	local llvm_slot
+	local rust_slot
+	local usedep
+
+	# If we're not using LLVM, we can just generate a simple Rust dependency
+	if [[ -z "${RUST_NEEDS_LLVM}" ]]; then
+		rust_dep=( "|| (" )
+		for slot in "${_RUST_SLOTS[@]}"; do
+				usedep="${RUST_USEDEP+[${RUST_USEDEP}]}"
+				rust_dep+=(
+					"dev-lang/rust:${slot}${usedep}"
+					"dev-lang/rust-bin:${slot}${usedep}"
+				)
+		done
+		rust_dep+=( ")" )
+		RUST_DEPEND="${rust_dep[*]}"
+	else
+		for llvm_slot in "${LLVM_COMPAT[@]}"; do
+			# Quick sanity check to make sure that the llvm slot is valid for Rust.
+			if [[ "${_RUST_LLVM_MAP[@]}" == *"${llvm_slot}"* ]]; then
+				# We're working a bit backwards here; iterate over _RUST_LLVM_MAP, check the
+				# LLVM slot, and if it matches add this to a new array because it may (and likely will)
+				# match multiple Rust slots. We already filtered Rust max/min slots.
+				# We always have a usedep for the LLVM slot, append `,RUST_USEDEP` if it's set
+				usedep="[llvm_slot_${llvm_slot}${RUST_USEDEP+,${RUST_USEDEP}}]"
+				local slot_dep_content=()
+				for rust_slot in "${_RUST_SLOTS[@]}"; do
+					if [[ "${_RUST_LLVM_MAP[${rust_slot}]}" == "${llvm_slot}" ]]; then
+						slot_dep_content+=(
+							"dev-lang/rust:${rust_slot}${usedep}"
+							"dev-lang/rust-bin:${rust_slot}${usedep}"
+						)
+					fi
+				done
+				if [ ${#slot_dep_content[@]} -ne 0 ]; then
+					rust_dep+=( "llvm_slot_${llvm_slot}? ( || ( ${slot_dep_content[*]} ) )" )
+				else
+					die "${FUNCNAME}: no Rust slots found for LLVM slot ${llvm_slot}"
+				fi
+			fi
+		done
+		RUST_DEPEND="${rust_dep[*]}"
+	fi
+
+	readonly RUST_DEPEND
+	if [[ -z ${RUST_OPTIONAL} ]]; then
+		BDEPEND="${RUST_DEPEND}"
+	fi
+}
+_rust_set_globals
+unset -f _rust_set_globals
+
+# == ebuild helpers ==
+
+# @FUNCTION: get_rust_slot
+# @USAGE: [-b|-d]
+# @DESCRIPTION:
+# Find the newest Rust install that is acceptable for the package,
+# and print its version number (i.e. SLOT) and type (source or bin[ary]).
+#
+# If -b is specified, the checks are performed relative to BROOT,
+# and BROOT-path is returned.
+#
+# If -d is specified, the checks are performed relative to ESYSROOT,
+# and ESYSROOT-path is returned. -d is the default.
+#
+# If RUST_M{AX,IN}_SLOT is non-zero, then only Rust versions that
+# are not newer or older than the specified slot(s) will be considered.
+# Otherwise, all Rust versions are be considered acceptable.
+#
+# If the `rust_check_deps()` function is defined within the ebuild, it
+# will be called to verify whether a particular slot is accepable.
+# Within the function scope, RUST_SLOT and LLVM_SLOT will be defined.
+#
+# The function should return a true status if the slot is acceptable,
+# false otherwise. If rust_check_deps() is not defined, the function
+# defaults to checking whether a suitable Rust package is installed.
+get_rust_slot() {
+	debug-print-function ${FUNCNAME} "$@"
+
+	local hv_switch=-d
+	while [[ ${1} == -* ]]; do
+		case ${1} in
+			-b|-d) hv_switch="${1}";;
+			*) break;;
+		esac
+		shift
+	done
+
+	local max_slot
+	if [[ -z "${RUST_MAX_VER}" ]]; then
+		max_slot=
+	else
+		max_slot="${RUST_MAX_VER}"
+	fi
+	local slot
+	local llvm_slot
+
+	if [[ -n "${RUST_NEEDS_LLVM}" ]]; then
+		local unique_slots=()
+		local llvm_r1_slot
+		# Associative array keys are unique, so let's use that to our advantage
+		for llvm_slot in "${_RUST_LLVM_MAP[@]}"; do
+			unique_slots["${llvm_slot}"]="1"
+		done
+		for llvm_slot in "${!unique_slots[@]}"; do
+			if [[ "${LLVM_COMPAT[@]}" == *"${llvm_slot}"* ]]; then
+				# We can check for the USE
+				use "llvm_slot_${llvm_slot}" && llvm_r1_slot="${llvm_slot}"
+			else
+				continue
+			fi
+		done
+		if [[ -z "${llvm_r1_slot}" ]]; then
+			die "${FUNCNAME}: no LLVM slot found"
+		fi
+	fi
+
+	# iterate over known slots, newest first
+	for slot in "${_RUST_SLOTS_ORDERED[@]}"; do
+		llvm_slot="${_RUST_LLVM_MAP[${slot}]}"
+		# skip higher slots
+		if [[ -n "${max_slot}" ]]; then
+			if ver_test "${slot}" -eq "${max_slot}"; then
+				max_slot=
+			elif ver_test "${slot}" -gt "${max_slot}"; then
+				continue
+			fi
+		fi
+
+		# If we're in LLVM mode we can skip any slots that don't match the selected USE
+		if [[ -n "${RUST_NEEDS_LLVM}" ]]; then
+			if [[ "${llvm_slot}" != "${llvm_r1_slot}" ]]; then
+				continue
+			fi
+		fi
+
+		if declare -f rust_check_deps >/dev/null; then
+			local RUST_SLOT="${slot}"
+			local LLVM_SLOT="${_RUST_LLVM_MAP[${slot}]}"
+			rust_check_deps && return
+		else
+			local rust_usedep="${RUST_USEDEP+[${RUST_USEDEP}]}"
+			# When checking for installed packages prefer the non `-bin` package
+			# if effort was put into building it we should use it.
+			local rust_pkgs=(
+				"dev-lang/rust:${slot}${rust_usedep}"
+				"dev-lang/rust-bin:${slot}${rust_usedep}"
+			)
+			local _pkg
+			for _pkg in "${rust_pkgs[@]}"
+				do
+					if has_version "${hv_switch}" "${_pkg}"; then
+						echo "${slot}"
+						if [[ "${_pkg}" == "dev-lang/rust:${slot}${rust_usedep}" ]]; then
+							echo source
+						else
+							echo binary
+						fi
+						return
+					fi
+				done
+		fi
+
+		# We want to process the slot before escaping the loop if we've hit the minimum slot
+		if ver_test "${slot}" -eq "${RUST_MIN_VER}"; then
+			break
+		fi
+
+	done
+
+	# max_slot should have been unset in the iteration
+	if [[ -n "${max_slot}" ]]; then
+		die "${FUNCNAME}: invalid max_slot=${max_slot}"
+	fi
+
+	die "No Rust slot${1:+ <= ${1}} satisfying the package's dependencies found installed!"
+}
+
+# @FUNCTION: get_rust_path
+# @USAGE: prefix slot rust_type 
+# @DESCRIPTION:
+# Given argument of slot and rust_type, return an appropriate path
+# for the Rust install. The rust_type should be either "source"
+# or "binary". If the rust_type is not one of these, the function
+# will die.
+get_rust_path() {
+	debug-print-function ${FUNCNAME} "$@"
+
+	local prefix="${1}"
+	local slot="${2}"
+	local rust_type="${3}"
+
+	if [[ ${#} -ne 3 ]]; then
+		die "${FUNCNAME}: invalid number of arguments"
+	fi
+
+	if [[ "${rust_type}" != "source" && "${rust_type}" != "binary" ]]; then
+		die "${FUNCNAME}: invalid rust_type=${rust_type}"
+	fi
+
+	if [[ "${rust_type}" == "source" ]]; then
+		echo "${prefix}/usr/lib/rust/${slot}/"
+	else
+		echo "${prefix}opt/rust-bin-${slot}/"
+	fi
+}
+
+# @FUNCTION: get_rust_prefix
+# @USAGE: [-b|-d]
+# @DESCRIPTION:
+# Find the newest Rust install that is acceptable for the package,
+# and print an absolute path to it. If both -bin and regular Rust
+# are installed, the regular Rust is preferred.
+#
+# The options and behavior are the same as get_rust_slot.
+get_rust_prefix() {
+	debug-print-function ${FUNCNAME} "$@"
+
+	local prefix=${BROOT}
+	[[ ${1} == -d ]] && prefix=${ESYSROOT}
+
+	local slot rust_type
+	{ read -r slot; read -r rust_type; } <<< $(get_rust_slot)
+	echo $(get_rust_path "${prefix}" "${slot}" "${rust_type}")
+}
+
+# @FUNCTION: rust_prepend_path
+# @USAGE: <slot> <type>
+# @DESCRIPTION:
+# Prepend the path to the specified Rust to PATH and re-export it.
+rust_prepend_path() {
+	debug-print-function ${FUNCNAME} "$@"
+
+	[[ ${#} -ne 2 ]] && die "Usage: ${FUNCNAME} <slot> <type>"
+	local slot="${1}"
+	local type="${2}"
+	export PATH="$(get_rust_path "${BROOT}" "${slot}" "${type}")/bin:${PATH}"
+}
+
+# @FUNCTION: rust_pkg_setup
+# @DESCRIPTION:
+# Prepend the appropriate executable directory for the newest
+# acceptable Rust slot to the PATH. If used with LLVM, an appropriate
+# `llvm_pkg_setup` call should be made in addition to this function.
+# For path determination logic, please see the get_rust_prefix documentation.
+#
+# The highest acceptable Rust slot can be set in RUST_MAX_VER variable.
+# If it is unset or empty, any slot is acceptable.
+#
+# The lowest acceptable Rust slot can be set in RUST_MIN_VER variable.
+# If it is unset or empty, any slot is acceptable.
+#
+# `CARGO` and `RUSTC` variables are set for the selected slot and exported.
+#
+# The PATH manipulation is only done for source builds. The function
+# is a no-op when installing a binary package.
+#
+# If any other behavior is desired, the contents of the function
+# should be inlined into the ebuild and modified as necessary.
+rust_pkg_setup() {
+	debug-print-function ${FUNCNAME} "$@"
+
+	if [[ ${MERGE_TYPE} != binary ]]; then
+		{ read -r RUST_SLOT; read -r RUST_TYPE; } <<< $(get_rust_slot)
+		rust_prepend_path "${RUST_SLOT}" "${RUST_TYPE}"
+		CARGO="$(get_rust_prefix)bin/cargo"
+		RUSTC="$(get_rust_prefix)bin/rustc"
+		export CARGO RUSTC
+		einfo "Using Rust ${RUST_SLOT} (${RUST_TYPE})"
+	fi
+}
+
+fi
+
+EXPORT_FUNCTIONS pkg_setup
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-11-09  6:26 Matt Jolly
  0 siblings, 0 replies; 6663+ messages in thread
From: Matt Jolly @ 2024-11-09  6:26 UTC (permalink / raw
  To: gentoo-commits
commit:     583a1a9ac556d01e1b0df6fe64e67cb646fa4118
Author:     Matt Jolly <kangie <AT> gentoo <DOT> org>
AuthorDate: Thu Nov  7 13:14:49 2024 +0000
Commit:     Matt Jolly <kangie <AT> gentoo <DOT> org>
CommitDate: Sat Nov  9 05:31:34 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=583a1a9a
toolchain: inherit rust eclass for `RUST_DEPEND`
`RUST_OPTIONAL` is set so that ebuilds must explicitly consume
Rust features.
Signed-off-by: Matt Jolly <kangie <AT> gentoo.org>
 eclass/toolchain.eclass | 6 ++++--
 1 file changed, 4 insertions(+), 2 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index b25c5dcf0929..6e3a974f373e 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -14,6 +14,8 @@
 if [[ -z ${_TOOLCHAIN_ECLASS} ]]; then
 _TOOLCHAIN_ECLASS=1
 
+RUST_OPTIONAL="1"
+
 case ${EAPI} in
 	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
@@ -22,7 +24,7 @@ esac
 DESCRIPTION="The GNU Compiler Collection"
 HOMEPAGE="https://gcc.gnu.org/"
 
-inherit edo flag-o-matic gnuconfig libtool multilib pax-utils toolchain-funcs prefix
+inherit edo flag-o-matic gnuconfig libtool multilib pax-utils rust toolchain-funcs prefix
 
 [[ -n ${TOOLCHAIN_HAS_TESTS} ]] && inherit python-any-r1
 
@@ -427,7 +429,7 @@ fi
 if tc_has_feature rust && tc_version_is_at_least 14.0.0_pre20230421 ; then
 	# This was added upstream in r14-9968-g3e1e73fc995844 as a temporary measure.
 	# See https://inbox.sourceware.org/gcc/34fec7ea-8762-4cac-a1c8-ff54e20e31ed@embecosm.com/
-	BDEPEND+=" rust? ( virtual/rust )"
+	BDEPEND+=" rust? ( ${RUST_DEPEND} )"
 fi
 
 PDEPEND=">=sys-devel/gcc-config-2.11"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-11-09  7:21 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-11-09  7:21 UTC (permalink / raw
  To: gentoo-commits
commit:     1fd4265df079cdf0569c8bc6b6c059a16d96d005
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Nov  9 07:20:57 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Nov  9 07:20:57 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=1fd4265d
toolchain.eclass: call rust_pkg_setup for USE=rust
Followup to 583a1a9ac556d01e1b0df6fe64e67cb646fa4118. Noticed by inspection.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 2 ++
 1 file changed, 2 insertions(+)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 6e3a974f373e..4d5973bb4959 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -595,6 +595,8 @@ toolchain_pkg_setup() {
 	MAKEOPTS="--output-sync=line ${MAKEOPTS}"
 
 	[[ -n ${TOOLCHAIN_HAS_TESTS} ]] && use test && python-any-r1_pkg_setup
+
+	_tc_use_if_iuse rust && rust_pkg_setup
 }
 
 #---->> src_unpack <<----
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-11-09  7:31 Matt Jolly
  0 siblings, 0 replies; 6663+ messages in thread
From: Matt Jolly @ 2024-11-09  7:31 UTC (permalink / raw
  To: gentoo-commits
commit:     18209a19fee456d23f6e97182b668fd3bf5c5d1b
Author:     Matt Jolly <kangie <AT> gentoo <DOT> org>
AuthorDate: Sat Nov  9 07:30:21 2024 +0000
Commit:     Matt Jolly <kangie <AT> gentoo <DOT> org>
CommitDate: Sat Nov  9 07:30:21 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=18209a19
rust.eclass: add missing `/` in `get_rust_path` for `binary` builds.
Signed-off-by: Matt Jolly <kangie <AT> gentoo.org>
 eclass/rust.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/rust.eclass b/eclass/rust.eclass
index 12ef4b90a7ac..e91048a6f193 100644
--- a/eclass/rust.eclass
+++ b/eclass/rust.eclass
@@ -390,7 +390,7 @@ get_rust_path() {
 	if [[ "${rust_type}" == "source" ]]; then
 		echo "${prefix}/usr/lib/rust/${slot}/"
 	else
-		echo "${prefix}opt/rust-bin-${slot}/"
+		echo "${prefix}/opt/rust-bin-${slot}/"
 	fi
 }
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-11-09  9:02 Matt Jolly
  0 siblings, 0 replies; 6663+ messages in thread
From: Matt Jolly @ 2024-11-09  9:02 UTC (permalink / raw
  To: gentoo-commits
commit:     3c5d0b8b9c4a593d6766e10c98b05975119a7028
Author:     Matt Jolly <kangie <AT> gentoo <DOT> org>
AuthorDate: Sat Nov  9 08:47:18 2024 +0000
Commit:     Matt Jolly <kangie <AT> gentoo <DOT> org>
CommitDate: Sat Nov  9 09:00:39 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=3c5d0b8b
rust.eclass: dependency strings: dev-lang/rust-bin first
To better match the behaviour of the legacy virtual/rust package,
update generated dependency strings so that dev-lang/rust-bin is
output before dev-lang/rust.
In the longer term it is expected that this will be reverted
to the original order (prefer dev-lang/rust) as users that
particularly care about this also have the option of selecting
an appropriate binpkg.
When selecting an installed Rust to use the non-bin package is
still preferred over the -bin if both are installed.
Signed-off-by: Matt Jolly <kangie <AT> gentoo.org>
 eclass/rust.eclass | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/eclass/rust.eclass b/eclass/rust.eclass
index e91048a6f193..08f935a821a8 100644
--- a/eclass/rust.eclass
+++ b/eclass/rust.eclass
@@ -196,8 +196,8 @@ _rust_set_globals() {
 		for slot in "${_RUST_SLOTS[@]}"; do
 				usedep="${RUST_USEDEP+[${RUST_USEDEP}]}"
 				rust_dep+=(
-					"dev-lang/rust:${slot}${usedep}"
 					"dev-lang/rust-bin:${slot}${usedep}"
+					"dev-lang/rust:${slot}${usedep}"
 				)
 		done
 		rust_dep+=( ")" )
@@ -215,8 +215,8 @@ _rust_set_globals() {
 				for rust_slot in "${_RUST_SLOTS[@]}"; do
 					if [[ "${_RUST_LLVM_MAP[${rust_slot}]}" == "${llvm_slot}" ]]; then
 						slot_dep_content+=(
-							"dev-lang/rust:${rust_slot}${usedep}"
 							"dev-lang/rust-bin:${rust_slot}${usedep}"
+							"dev-lang/rust:${rust_slot}${usedep}"
 						)
 					fi
 				done
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-11-09 10:50 Matt Jolly
  0 siblings, 0 replies; 6663+ messages in thread
From: Matt Jolly @ 2024-11-09 10:50 UTC (permalink / raw
  To: gentoo-commits
commit:     c5f28a3d0a5b4ab6959b9223e6299e8502e0b7bd
Author:     Matt Jolly <kangie <AT> gentoo <DOT> org>
AuthorDate: Sat Nov  9 10:41:39 2024 +0000
Commit:     Matt Jolly <kangie <AT> gentoo <DOT> org>
CommitDate: Sat Nov  9 10:49:59 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=c5f28a3d
rust.eclass: Fix conditional for ensuring that RUST_MIN_VER is set
The check was negated meaning that RUST_MIN_VER would only be set when
it was not required.
Signed-off-by: Matt Jolly <kangie <AT> gentoo.org>
 eclass/rust.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/rust.eclass b/eclass/rust.eclass
index 08f935a821a8..ca71c6535061 100644
--- a/eclass/rust.eclass
+++ b/eclass/rust.eclass
@@ -144,7 +144,7 @@ _rust_set_globals() {
 
 	# If RUST_MIN_VER is older than our oldest slot we'll just set it to that
 	# internally so we don't have to worry about it later.
-	if ! ver_test "${_RUST_SLOTS_ORDERED[-1]}" -gt "${RUST_MIN_VER:-0}"; then
+	if ver_test "${_RUST_SLOTS_ORDERED[-1]}" -gt "${RUST_MIN_VER:-0}"; then
 		RUST_MIN_VER="${_RUST_SLOTS_ORDERED[-1]}"
 	fi
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-11-10 17:24 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-11-10 17:24 UTC (permalink / raw
  To: gentoo-commits
commit:     e08def09c01c484bcd0f1305e88165b4418f43b3
Author:     Andrei Horodniceanu <a.horodniceanu <AT> proton <DOT> me>
AuthorDate: Thu Nov  7 13:49:00 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Nov 10 17:23:44 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=e08def09
toolchain.eclass: Check for gnu environment when enabling cet on x86
Like we do for arm64 and amd64, diverge from the upstream check for
linux and only enable it for gnu triples.
Closes: https://bugs.gentoo.org/942951
Signed-off-by: Andrei Horodniceanu <a.horodniceanu <AT> proton.me>
Closes: https://github.com/gentoo/gentoo/pull/39228
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 4d5973bb4959..573471351dd1 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1583,7 +1583,7 @@ toolchain_src_configure() {
 			fi
 		}
 
-		enable_cet_for 'i[34567]86' 'linux' 'cet'
+		enable_cet_for 'i[34567]86' 'gnu' 'cet'
 		enable_cet_for 'x86_64' 'gnu' 'cet'
 		enable_cet_for 'aarch64' 'gnu' 'standard-branch-protection'
 	fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-11-11  8:53 Matt Jolly
  0 siblings, 0 replies; 6663+ messages in thread
From: Matt Jolly @ 2024-11-11  8:53 UTC (permalink / raw
  To: gentoo-commits
commit:     9224c0acf8aa541c49de424042c88e87f0e76e26
Author:     Matt Jolly <kangie <AT> gentoo <DOT> org>
AuthorDate: Sun Nov 10 01:24:33 2024 +0000
Commit:     Matt Jolly <kangie <AT> gentoo <DOT> org>
CommitDate: Mon Nov 11 08:49:16 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=9224c0ac
eclass: update rust usedep handling; address feedback
- Inherit llvm-r1 where required and let it die if LLVM_COMPAT is not
  set.
- New variable: RUST_MULTILIB; if set will generate a multilib usedep
  for supported rust slots.
- RUST_USEDEP -> RUST_REQ_USE to be consistent with other eclasses
  (ebuild updates handled in a followup commit).
- Tidyup & address feedback
- Improve RUST_MIN_VER (only) dependency specification
Closes: https://bugs.gentoo.org/943206
Signed-off-by: Matt Jolly <kangie <AT> gentoo.org>
 eclass/rust.eclass | 126 ++++++++++++++++++++++++++++-------------------------
 1 file changed, 66 insertions(+), 60 deletions(-)
diff --git a/eclass/rust.eclass b/eclass/rust.eclass
index ca71c6535061..f7c2d6e9a80e 100644
--- a/eclass/rust.eclass
+++ b/eclass/rust.eclass
@@ -34,7 +34,8 @@
 #
 # Example for a package needing Rust w/ a specific target:
 # @CODE
-# RUST_USEDEP='clippy,${MULTILIB_USEDEP}'
+# RUST_REQ_USE='clippy'
+# RUST_MULTILIB=1
 #
 # inherit multilib-minimal meson rust
 #
@@ -49,9 +50,12 @@ if [[ -z ${_RUST_ECLASS} ]]; then
 _RUST_ECLASS=1
 
 if [[ -n ${RUST_NEEDS_LLVM} ]]; then
-	if [[ -z ${_LLVM_R1_ECLASS} ]]; then
-		die "Please inherit llvm-r1.eclass before rust.eclass when using RUST_NEEDS_LLVM"
-	fi
+	inherit llvm-r1
+fi
+
+if [[ -n ${RUST_MULTILIB} ]]; then
+	inherit multilib-build
+	RUST_REQ_USE="${RUST_REQ_USE+${RUST_REQ_USE},}${MULTILIB_USEDEP}"
 fi
 
 # == internal control knobs ==
@@ -114,6 +118,13 @@ declare -a -g -r _RUST_SLOTS_ORDERED=(
 # an invalid combination of RUST and LLVM slots is detected; this probably
 # means that a LLVM slot in LLVM_COMPAT has had all of its Rust slots filtered.
 
+# @eclass-variable: RUST_MULTILIB
+# @DEFAULT_UNSET
+# @DESCRIPTION:
+# If set to a non-empty value insert MULTILIB_USEDEP into the generated
+# Rust dependency. For this to be useful inherit a multilib eclass and
+# configure the appropriate phase functions.
+
 # @ECLASS_VARIABLE: RUST_DEPEND
 # @OUTPUT_VARIABLE
 # @DESCRIPTION:
@@ -129,7 +140,7 @@ declare -a -g -r _RUST_SLOTS_ORDERED=(
 # to BDEPEND. This is useful for where packages need to gate rust behind
 # certain USE themselves.
 
-# @ECLASS_VARIABLE: RUST_USEDEP
+# @ECLASS_VARIABLE: RUST_REQ_USE
 # @DEFAULT_UNSET
 # @DESCRIPTION:
 # Additional USE-dependencies to be added to the Rust dependency.
@@ -150,7 +161,7 @@ _rust_set_globals() {
 
 	# and if it falls between slots we'll set it to the next highest slot
 	# We can skip this we match a slot exactly.
-	if ! [[ "${_RUST_SLOTS_ORDERED[@]}" == *"${RUST_MIN_VER}"* ]]; then
+	if [[ "${_RUST_SLOTS_ORDERED[@]}" != *"${RUST_MIN_VER}"* ]]; then
 		local i
 		for (( i=${#_RUST_SLOTS_ORDERED[@]}-1 ; i>=0 ; i-- )); do
 			if ver_test "${_RUST_SLOTS_ORDERED[$i]}" -gt "${RUST_MIN_VER}"; then
@@ -169,20 +180,14 @@ _rust_set_globals() {
 	local slot
 	# Try to keep this in order of newest to oldest
 	for slot in "${_RUST_SLOTS_ORDERED[@]}"; do
-		if ver_test "${slot}" -le "${RUST_MAX_VER:-9999}" && \
-			ver_test "${slot}" -ge "${RUST_MIN_VER:-0}"; then
-			_RUST_SLOTS+=( "${slot}" )
+		if ver_test "${slot}" -le "${RUST_MAX_VER:-9999}" &&
+			ver_test "${slot}" -ge "${RUST_MIN_VER:-0}"
+			then
+				_RUST_SLOTS+=( "${slot}" )
 		fi
 	done
 
 	_RUST_SLOTS=( "${_RUST_SLOTS[@]}" )
-
-	# We may have been passed a variable like ${MULTILIB_USEDEP}; expand it.
-	if [[ -n "${RUST_USEDEP}" ]]; then
-		eval $(echo RUST_USEDEP="${RUST_USEDEP}")
-		[[ -z "${RUST_USEDEP}" ]] && die "When evaluated, RUST_USEDEP is empty"
-	fi
-
 	readonly _RUST_SLOTS
 
 	local rust_dep=()
@@ -193,13 +198,24 @@ _rust_set_globals() {
 	# If we're not using LLVM, we can just generate a simple Rust dependency
 	if [[ -z "${RUST_NEEDS_LLVM}" ]]; then
 		rust_dep=( "|| (" )
-		for slot in "${_RUST_SLOTS[@]}"; do
-				usedep="${RUST_USEDEP+[${RUST_USEDEP}]}"
+		# We can be more flexible if we generate a simpler, open-ended dependency
+		# when we don't have a max version set.
+		if [[ -z "${RUST_MAX_VER}" ]]; then
+			rust_dep+=(
+				">=dev-lang/rust-bin-${RUST_MIN_VER}:*${usedep}"
+				">=dev-lang/rust-${RUST_MIN_VER}:*${usedep}"
+			)
+		else
+			# depend on each slot between RUST_MIN_VER and RUST_MAX_VER; it's a bit specific but
+			# won't hurt as we only ever add newer Rust slots.
+			for slot in "${_RUST_SLOTS[@]}"; do
+				usedep="${RUST_REQ_USE+[${RUST_REQ_USE}]}"
 				rust_dep+=(
 					"dev-lang/rust-bin:${slot}${usedep}"
 					"dev-lang/rust:${slot}${usedep}"
 				)
-		done
+			done
+		fi
 		rust_dep+=( ")" )
 		RUST_DEPEND="${rust_dep[*]}"
 	else
@@ -209,8 +225,8 @@ _rust_set_globals() {
 				# We're working a bit backwards here; iterate over _RUST_LLVM_MAP, check the
 				# LLVM slot, and if it matches add this to a new array because it may (and likely will)
 				# match multiple Rust slots. We already filtered Rust max/min slots.
-				# We always have a usedep for the LLVM slot, append `,RUST_USEDEP` if it's set
-				usedep="[llvm_slot_${llvm_slot}${RUST_USEDEP+,${RUST_USEDEP}}]"
+				# We always have a usedep for the LLVM slot, append `,RUST_REQ_USE` if it's set
+				usedep="[llvm_slot_${llvm_slot}${RUST_REQ_USE+,${RUST_REQ_USE}}]"
 				local slot_dep_content=()
 				for rust_slot in "${_RUST_SLOTS[@]}"; do
 					if [[ "${_RUST_LLVM_MAP[${rust_slot}]}" == "${llvm_slot}" ]]; then
@@ -220,7 +236,7 @@ _rust_set_globals() {
 						)
 					fi
 				done
-				if [ ${#slot_dep_content[@]} -ne 0 ]; then
+				if [[ "${#slot_dep_content[@]}" -ne 0 ]]; then
 					rust_dep+=( "llvm_slot_${llvm_slot}? ( || ( ${slot_dep_content[*]} ) )" )
 				else
 					die "${FUNCNAME}: no Rust slots found for LLVM slot ${llvm_slot}"
@@ -240,7 +256,7 @@ unset -f _rust_set_globals
 
 # == ebuild helpers ==
 
-# @FUNCTION: get_rust_slot
+# @FUNCTION: _get_rust_slot
 # @USAGE: [-b|-d]
 # @DESCRIPTION:
 # Find the newest Rust install that is acceptable for the package,
@@ -263,7 +279,7 @@ unset -f _rust_set_globals
 # The function should return a true status if the slot is acceptable,
 # false otherwise. If rust_check_deps() is not defined, the function
 # defaults to checking whether a suitable Rust package is installed.
-get_rust_slot() {
+_get_rust_slot() {
 	debug-print-function ${FUNCNAME} "$@"
 
 	local hv_switch=-d
@@ -295,8 +311,6 @@ get_rust_slot() {
 			if [[ "${LLVM_COMPAT[@]}" == *"${llvm_slot}"* ]]; then
 				# We can check for the USE
 				use "llvm_slot_${llvm_slot}" && llvm_r1_slot="${llvm_slot}"
-			else
-				continue
 			fi
 		done
 		if [[ -z "${llvm_r1_slot}" ]]; then
@@ -328,33 +342,30 @@ get_rust_slot() {
 			local LLVM_SLOT="${_RUST_LLVM_MAP[${slot}]}"
 			rust_check_deps && return
 		else
-			local rust_usedep="${RUST_USEDEP+[${RUST_USEDEP}]}"
+			local usedep="${RUST_REQ_USE+[${RUST_REQ_USE}]}"
 			# When checking for installed packages prefer the non `-bin` package
 			# if effort was put into building it we should use it.
 			local rust_pkgs=(
-				"dev-lang/rust:${slot}${rust_usedep}"
-				"dev-lang/rust-bin:${slot}${rust_usedep}"
+				"dev-lang/rust:${slot}${usedep}"
+				"dev-lang/rust-bin:${slot}${usedep}"
 			)
 			local _pkg
-			for _pkg in "${rust_pkgs[@]}"
-				do
-					if has_version "${hv_switch}" "${_pkg}"; then
-						echo "${slot}"
-						if [[ "${_pkg}" == "dev-lang/rust:${slot}${rust_usedep}" ]]; then
-							echo source
-						else
-							echo binary
-						fi
-						return
+			for _pkg in "${rust_pkgs[@]}"; do
+				if has_version "${hv_switch}" "${_pkg}"; then
+					if [[ "${_pkg}" == "dev-lang/rust:${slot}${usedep}" ]]; then
+						echo "${slot} source"
+					else
+						echo "${slot} binary"
 					fi
-				done
+					return
+				fi
+			done
 		fi
 
 		# We want to process the slot before escaping the loop if we've hit the minimum slot
 		if ver_test "${slot}" -eq "${RUST_MIN_VER}"; then
 			break
 		fi
-
 	done
 
 	# max_slot should have been unset in the iteration
@@ -366,7 +377,7 @@ get_rust_slot() {
 }
 
 # @FUNCTION: get_rust_path
-# @USAGE: prefix slot rust_type 
+# @USAGE: prefix slot rust_type
 # @DESCRIPTION:
 # Given argument of slot and rust_type, return an appropriate path
 # for the Rust install. The rust_type should be either "source"
@@ -383,15 +394,11 @@ get_rust_path() {
 		die "${FUNCNAME}: invalid number of arguments"
 	fi
 
-	if [[ "${rust_type}" != "source" && "${rust_type}" != "binary" ]]; then
-		die "${FUNCNAME}: invalid rust_type=${rust_type}"
-	fi
-
-	if [[ "${rust_type}" == "source" ]]; then
-		echo "${prefix}/usr/lib/rust/${slot}/"
-	else
-		echo "${prefix}/opt/rust-bin-${slot}/"
-	fi
+	case ${rust_type} in
+		source) echo "${prefix}/usr/lib/rust/${slot}/";;
+		binary) echo "${prefix}/opt/rust-bin-${slot}/";;
+		*) die "${FUNCNAME}: invalid rust_type=${rust_type}";;
+	esac
 }
 
 # @FUNCTION: get_rust_prefix
@@ -409,8 +416,8 @@ get_rust_prefix() {
 	[[ ${1} == -d ]] && prefix=${ESYSROOT}
 
 	local slot rust_type
-	{ read -r slot; read -r rust_type; } <<< $(get_rust_slot)
-	echo $(get_rust_path "${prefix}" "${slot}" "${rust_type}")
+	read -r slot rust_type <<< $(_get_rust_slot)
+	get_rust_path "${prefix}" "${slot}" "${rust_type}"
 }
 
 # @FUNCTION: rust_prepend_path
@@ -421,16 +428,14 @@ rust_prepend_path() {
 	debug-print-function ${FUNCNAME} "$@"
 
 	[[ ${#} -ne 2 ]] && die "Usage: ${FUNCNAME} <slot> <type>"
-	local slot="${1}"
-	local type="${2}"
-	export PATH="$(get_rust_path "${BROOT}" "${slot}" "${type}")/bin:${PATH}"
+	export PATH="$(get_rust_path "${BROOT}" "$@")/bin:${PATH}"
 }
 
 # @FUNCTION: rust_pkg_setup
 # @DESCRIPTION:
 # Prepend the appropriate executable directory for the newest
 # acceptable Rust slot to the PATH. If used with LLVM, an appropriate
-# `llvm_pkg_setup` call should be made in addition to this function.
+# `llvm-r1_pkg_setup` call should be made in addition to this function.
 # For path determination logic, please see the get_rust_prefix documentation.
 #
 # The highest acceptable Rust slot can be set in RUST_MAX_VER variable.
@@ -450,10 +455,11 @@ rust_pkg_setup() {
 	debug-print-function ${FUNCNAME} "$@"
 
 	if [[ ${MERGE_TYPE} != binary ]]; then
-		{ read -r RUST_SLOT; read -r RUST_TYPE; } <<< $(get_rust_slot)
+		read -r RUST_SLOT RUST_TYPE <<< $(_get_rust_slot)
 		rust_prepend_path "${RUST_SLOT}" "${RUST_TYPE}"
-		CARGO="$(get_rust_prefix)bin/cargo"
-		RUSTC="$(get_rust_prefix)bin/rustc"
+		local prefix=$(get_rust_prefix)
+		CARGO="${prefix}bin/cargo"
+		RUSTC="${prefix}bin/rustc"
 		export CARGO RUSTC
 		einfo "Using Rust ${RUST_SLOT} (${RUST_TYPE})"
 	fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-11-11  8:53 Matt Jolly
  0 siblings, 0 replies; 6663+ messages in thread
From: Matt Jolly @ 2024-11-11  8:53 UTC (permalink / raw
  To: gentoo-commits
commit:     9393ba8b683e6a055522d81740f94a11a0abfcb4
Author:     Matt Jolly <kangie <AT> gentoo <DOT> org>
AuthorDate: Sun Nov 10 00:15:54 2024 +0000
Commit:     Matt Jolly <kangie <AT> gentoo <DOT> org>
CommitDate: Mon Nov 11 08:49:15 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=9393ba8b
cargo.eclass: check for and quote `CARGO`
A quick sanity check that `CARGO` is set in appropriate cargo_src_*
phase functions will make it easier for users to catch occurrences
where pkg_setup does not call rust_pkg_setup.
Also inherit llvm-r1 if required and let it die instead of us if
the environment is not properly setup.
Closes: https://bugs.gentoo.org/943147
Signed-off-by: Matt Jolly <kangie <AT> gentoo.org>
 eclass/cargo.eclass | 22 ++++++++++++++++------
 1 file changed, 16 insertions(+), 6 deletions(-)
diff --git a/eclass/cargo.eclass b/eclass/cargo.eclass
index 855692b72ec7..95ff317e1f21 100644
--- a/eclass/cargo.eclass
+++ b/eclass/cargo.eclass
@@ -20,9 +20,7 @@ if [[ -z ${_CARGO_ECLASS} ]]; then
 _CARGO_ECLASS=1
 
 if [[ -n ${RUST_NEEDS_LLVM} ]]; then
-	if [[ -z ${_LLVM_R1_ECLASS} ]]; then
-		die "Please inherit llvm-r1.eclass before cargo.eclass when using RUST_NEEDS_LLVM"
-	fi
+		inherit llvm-r1
 fi
 
 if [[ -n ${CARGO_OPTIONAL} ]]; then
@@ -627,7 +625,11 @@ cargo_env() {
 cargo_src_compile() {
 	debug-print-function ${FUNCNAME} "$@"
 
-	set -- ${CARGO} build $(usex debug "" --release) ${ECARGO_ARGS[@]} "$@"
+	if [[ -z "${CARGO}" ]]; then
+		die "CARGO is not set; was rust_pkg_setup run?"
+	fi
+
+	set -- "${CARGO}" build $(usex debug "" --release) ${ECARGO_ARGS[@]} "$@"
 	einfo "${@}"
 	cargo_env "${@}" || die "cargo build failed"
 }
@@ -641,7 +643,11 @@ cargo_src_compile() {
 cargo_src_install() {
 	debug-print-function ${FUNCNAME} "$@"
 
-	set -- ${CARGO} install $(has --path ${@} || echo --path ./) \
+	if [[ -z "${CARGO}" ]]; then
+		die "CARGO is not set; was rust_pkg_setup run?"
+	fi
+
+	set -- "${CARGO}" install $(has --path ${@} || echo --path ./) \
 		--root "${ED}/usr" \
 		${GIT_CRATES[@]:+--frozen} \
 		$(usex debug --debug "") \
@@ -659,7 +665,11 @@ cargo_src_install() {
 cargo_src_test() {
 	debug-print-function ${FUNCNAME} "$@"
 
-	set -- ${CARGO} test $(usex debug "" --release) ${ECARGO_ARGS[@]} "$@"
+	if [[ -z "${CARGO}" ]]; then
+		die "CARGO is not set; was rust_pkg_setup run?"
+	fi
+
+	set -- "${CARGO}" test $(usex debug "" --release) ${ECARGO_ARGS[@]} "$@"
 	einfo "${@}"
 	cargo_env "${@}" || die "cargo test failed"
 }
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-11-11 19:28 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-11-11 19:28 UTC (permalink / raw
  To: gentoo-commits
commit:     a0767621299b316a2e451a890e82c4672abd3891
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Nov 11 19:09:29 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Nov 11 19:27:57 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=a0767621
toolchain.eclass: add comment explaining --with-newlib
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 5 ++++-
 1 file changed, 4 insertions(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 573471351dd1..c900e2051cd1 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1252,7 +1252,10 @@ toolchain_src_configure() {
 	# 	;;
 	# esac
 
-	### Cross-compiler options
+	### Cross-compiler option
+	#
+	# Note that 'newlib' here doesn't have to mean genuine newlib.
+	# See https://gcc.gnu.org/pipermail/gcc/2014-January/211653.html.
 	if is_crosscompile ; then
 		# Enable build warnings by default with cross-compilers when system
 		# paths are included (e.g. via -I flags).
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-11-11 23:48 Matt Jolly
  0 siblings, 0 replies; 6663+ messages in thread
From: Matt Jolly @ 2024-11-11 23:48 UTC (permalink / raw
  To: gentoo-commits
commit:     7c7e11e46ad664457ccf4954e5bc346c148cff2d
Author:     Matt Jolly <kangie <AT> gentoo <DOT> org>
AuthorDate: Mon Nov 11 20:50:47 2024 +0000
Commit:     Matt Jolly <kangie <AT> gentoo <DOT> org>
CommitDate: Mon Nov 11 23:39:58 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=7c7e11e4
rust.eclass: define `usedep` before its first usage
The open-ended dependency (no `RUST_MAX_VER`) was generated
before `usedep` was set to anything. Define `usedep` when
the variable is initialised and let the `RUST_NEEDS_LLVM`
path set it per llvm slot as required.
Closes: https://bugs.gentoo.org/943289
Signed-off-by: Matt Jolly <kangie <AT> gentoo.org>
 eclass/rust.eclass | 3 +--
 1 file changed, 1 insertion(+), 2 deletions(-)
diff --git a/eclass/rust.eclass b/eclass/rust.eclass
index f7c2d6e9a80e..791af971eb3d 100644
--- a/eclass/rust.eclass
+++ b/eclass/rust.eclass
@@ -193,7 +193,7 @@ _rust_set_globals() {
 	local rust_dep=()
 	local llvm_slot
 	local rust_slot
-	local usedep
+	local usedep="${RUST_REQ_USE+[${RUST_REQ_USE}]}"
 
 	# If we're not using LLVM, we can just generate a simple Rust dependency
 	if [[ -z "${RUST_NEEDS_LLVM}" ]]; then
@@ -209,7 +209,6 @@ _rust_set_globals() {
 			# depend on each slot between RUST_MIN_VER and RUST_MAX_VER; it's a bit specific but
 			# won't hurt as we only ever add newer Rust slots.
 			for slot in "${_RUST_SLOTS[@]}"; do
-				usedep="${RUST_REQ_USE+[${RUST_REQ_USE}]}"
 				rust_dep+=(
 					"dev-lang/rust-bin:${slot}${usedep}"
 					"dev-lang/rust:${slot}${usedep}"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-11-11 23:48 Matt Jolly
  0 siblings, 0 replies; 6663+ messages in thread
From: Matt Jolly @ 2024-11-11 23:48 UTC (permalink / raw
  To: gentoo-commits
commit:     bfbc75e17d70b281f7f8548a62a0e820821b175a
Author:     Matt Jolly <kangie <AT> gentoo <DOT> org>
AuthorDate: Mon Nov 11 23:03:56 2024 +0000
Commit:     Matt Jolly <kangie <AT> gentoo <DOT> org>
CommitDate: Mon Nov 11 23:40:15 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=bfbc75e1
rust.eclass: fix typo
Signed-off-by: Matt Jolly <kangie <AT> gentoo.org>
 eclass/rust.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/rust.eclass b/eclass/rust.eclass
index 791af971eb3d..3837c3a1f6c5 100644
--- a/eclass/rust.eclass
+++ b/eclass/rust.eclass
@@ -130,7 +130,7 @@ declare -a -g -r _RUST_SLOTS_ORDERED=(
 # @DESCRIPTION:
 # This is an eclass-generated Rust dependency string, filtered by
 # RUST_MAX_VER and RUST_MIN_VER. If RUST_NEEDS_LLVM is set, this
-# is gropeda and gated by an appropriate `llvm_slot_x` USE for all
+# is grouped and gated by an appropriate `llvm_slot_x` USE for all
 # implementations listed in LLVM_COMPAT.
 
 # @ECLASS_VARIABLE: RUST_OPTIONAL
^ permalink raw reply related	[flat|nested] 6663+ messages in thread
* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-11-12  8:09 Andrew Ammerlaan
  0 siblings, 0 replies; 6663+ messages in thread
From: Andrew Ammerlaan @ 2024-11-12  8:09 UTC (permalink / raw
  To: gentoo-commits
commit:     3d37ab7f493f626e059cd24b8de8b722ba53b30a
Author:     Nowa Ammerlaan <andrewammerlaan <AT> gentoo <DOT> org>
AuthorDate: Tue Nov 12 08:06:27 2024 +0000
Commit:     Andrew Ammerlaan <andrewammerlaan <AT> gentoo <DOT> org>
CommitDate: Tue Nov 12 08:09:11 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=3d37ab7f
kernel-build.eclass: install x509.genkey and everything else in certs/
Users setting up kernel module signing are instructed by our and upstream
documentation to use the kernels x509.genkey config file. This ensures that
a supported key is generated.
However, in the current situation users will first have to emerge
gentoo-sources or similar to actually get this genkey file. This is inconvenient
so lets just install the genkey config file in our dist-kernels.
There are also some other tools, scripts, and lists that may be useful, so while
we are changing this anyway lets just install all of those as well and in the
process simplify the code.
Signed-off-by: Nowa Ammerlaan <andrewammerlaan <AT> gentoo.org>
 eclass/kernel-build.eclass | 11 +++--------
 1 file changed, 3 insertions(+), 8 deletions(-)
diff --git a/eclass/kernel-build.eclass b/eclass/kernel-build.eclass
index 4a2af9845ad4..9d33aef92691 100644
--- a/eclass/kernel-build.eclass
+++ b/eclass/kernel-build.eclass
@@ -397,7 +397,7 @@ kernel-build_src_install() {
 	fi
 
 	dodir "${kernel_dir}/arch/${kern_arch}"
-	mv include scripts "${ED}${kernel_dir}/" || die
+	mv certs include scripts "${ED}${kernel_dir}/" || die
 	mv "arch/${kern_arch}/include" \
 		"${ED}${kernel_dir}/arch/${kern_arch}/" || die
 	# some arches need module.lds linker script to build external modules
@@ -438,13 +438,8 @@ kernel-build_src_install() {
 	local image=${ED}${kernel_dir}/${image_path}
 	cp -p "build/${image_path}" "${image}" || die
 
-	# If a key was generated, copy it so external modules can be signed
-	local suffix
-	for suffix in pem x509; do
-		if [[ -f "build/certs/signing_key.${suffix}" ]]; then
-			cp -p "build/certs/signing_key.${suffix}" "${ED}${kernel_dir}/certs" || die
-		fi
-	done
+	# Copy built key/certificate files
+	cp -p build/certs/* "${ED}${kernel_dir}/certs/" || die
 
 	# building modules fails with 'vmlinux has no symtab?' if stripped
 	use ppc64 && dostrip -x "${kernel_dir}/${image_path}"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-11-12  9:09 Matt Jolly
  0 siblings, 0 replies; 6663+ messages in thread
From: Matt Jolly @ 2024-11-12  9:09 UTC (permalink / raw
  To: gentoo-commits
commit:     34b74faa06a90bf9d4f62ecfca746b380d60517a
Author:     Matt Jolly <kangie <AT> gentoo <DOT> org>
AuthorDate: Tue Nov 12 03:07:51 2024 +0000
Commit:     Matt Jolly <kangie <AT> gentoo <DOT> org>
CommitDate: Tue Nov 12 09:07:42 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=34b74faa
rust.eclass: revert simplified dependency simplification
The simplified dependency specification for cases where no RUST_MAX_SLOT
is set is the desired end state, however the edge case where portage
drops blockers with `--keep-going` has an unfortunate interaction where
both packages are installed simultaneously, e.g. dev-lang/rust-1.82.0:stable
and dev-lang/rust-1.82.0:1.82.0, and there's no easy way for end users
to resolve that as the legacy (though masked) ebuilds will meet the simple
Rust dependency.
Both packages install rlibs with different hashes in them to the same
path (as shown below) resulting in failures when a package attempts
to link against an rlib and finds two.
1.82.0:      .../x86_64-unknown-linux-gnu/lib/libunwind-fc4fe814489209c6.rlib
1.82.0-r100: .../x86_64-unknown-linux-gnu/lib/libunwind-ab65e6747cbe4a5a.rlib
Bug: https://bugs.gentoo.org/943143
Bug: https://bugs.gentoo.org/943206
Signed-off-by: Matt Jolly <kangie <AT> gentoo.org>
 eclass/rust.eclass | 27 ++++++++++++---------------
 1 file changed, 12 insertions(+), 15 deletions(-)
diff --git a/eclass/rust.eclass b/eclass/rust.eclass
index 3837c3a1f6c5..3a8a93718787 100644
--- a/eclass/rust.eclass
+++ b/eclass/rust.eclass
@@ -196,25 +196,22 @@ _rust_set_globals() {
 	local usedep="${RUST_REQ_USE+[${RUST_REQ_USE}]}"
 
 	# If we're not using LLVM, we can just generate a simple Rust dependency
+	# In time we need to implement trivial dependencies
+	# (>=RUST_MIN_VER) where RUST_MAX_VER isnt't set,
+	# however the previous attempt to do this ran into issues
+	# where `emerge ... --keep-going` ate legacy non-slotted
+	# Rust blockers resutling in the non-slotted version never
+	# being removed and breaking builds. #943206 #943143
 	if [[ -z "${RUST_NEEDS_LLVM}" ]]; then
 		rust_dep=( "|| (" )
-		# We can be more flexible if we generate a simpler, open-ended dependency
-		# when we don't have a max version set.
-		if [[ -z "${RUST_MAX_VER}" ]]; then
+		# depend on each slot between RUST_MIN_VER and RUST_MAX_VER; it's a bit specific but
+		# won't hurt as we only ever add newer Rust slots.
+		for slot in "${_RUST_SLOTS[@]}"; do
 			rust_dep+=(
-				">=dev-lang/rust-bin-${RUST_MIN_VER}:*${usedep}"
-				">=dev-lang/rust-${RUST_MIN_VER}:*${usedep}"
+				"dev-lang/rust-bin:${slot}${usedep}"
+				"dev-lang/rust:${slot}${usedep}"
 			)
-		else
-			# depend on each slot between RUST_MIN_VER and RUST_MAX_VER; it's a bit specific but
-			# won't hurt as we only ever add newer Rust slots.
-			for slot in "${_RUST_SLOTS[@]}"; do
-				rust_dep+=(
-					"dev-lang/rust-bin:${slot}${usedep}"
-					"dev-lang/rust:${slot}${usedep}"
-				)
-			done
-		fi
+		done
 		rust_dep+=( ")" )
 		RUST_DEPEND="${rust_dep[*]}"
 	else
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-11-12 19:19 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-11-12 19:19 UTC (permalink / raw
  To: gentoo-commits
commit:     d6cb7a61dad7e9672a8448597835dbbf9b9e0ccf
Author:     Ian Jordan <immoloism <AT> gmail <DOT> com>
AuthorDate: Tue Nov 12 18:32:15 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Nov 12 19:18:51 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=d6cb7a61
toolchain.eclass: Disable CET on x86
Remove enable_cet_for 'i[34567]86' 'gnu' 'cet' from to prevent -fcf-protection on x86
systens	where CET support will never be	fully enabled anyway.
This should help with bug #933772 also but I was unable	to reproduce to	confirm.
Closes: https://bugs.gentoo.org/943332
Bug: https://bugs.gentoo.org/933772
Thanks-to: Sam James <sam <AT> gentoo.org>
Signed-off-by: Ian Jordan <immoloism <AT> gmail.com>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 1 -
 1 file changed, 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index c900e2051cd1..1f043de0b548 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1586,7 +1586,6 @@ toolchain_src_configure() {
 			fi
 		}
 
-		enable_cet_for 'i[34567]86' 'gnu' 'cet'
 		enable_cet_for 'x86_64' 'gnu' 'cet'
 		enable_cet_for 'aarch64' 'gnu' 'standard-branch-protection'
 	fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-11-13  6:16 Matt Jolly
  0 siblings, 0 replies; 6663+ messages in thread
From: Matt Jolly @ 2024-11-13  6:16 UTC (permalink / raw
  To: gentoo-commits
commit:     f8b206fd6688628bd9bbb2f2c5e3d3eb627d76dc
Author:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
AuthorDate: Wed Nov 13 01:33:50 2024 +0000
Commit:     Matt Jolly <kangie <AT> gentoo <DOT> org>
CommitDate: Wed Nov 13 06:14:01 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=f8b206fd
rust.eclass: cross compile fixes
Change _get_rust_slot to default to -b/BROOT.
Reuse _get_rust_slot result in pkg_setup.
Pass along arguments from get_rust_prefix to _get_rust_slot.
Signed-off-by: Mike Gilbert <floppym <AT> gentoo.org>
Closes: https://github.com/gentoo/gentoo/pull/39298
Signed-off-by: Matt Jolly <kangie <AT> gentoo.org>
 eclass/rust.eclass | 12 ++++++------
 1 file changed, 6 insertions(+), 6 deletions(-)
diff --git a/eclass/rust.eclass b/eclass/rust.eclass
index 3a8a93718787..f293e96d7ce8 100644
--- a/eclass/rust.eclass
+++ b/eclass/rust.eclass
@@ -259,10 +259,10 @@ unset -f _rust_set_globals
 # and print its version number (i.e. SLOT) and type (source or bin[ary]).
 #
 # If -b is specified, the checks are performed relative to BROOT,
-# and BROOT-path is returned.
+# and BROOT-path is returned. -b is the default.
 #
 # If -d is specified, the checks are performed relative to ESYSROOT,
-# and ESYSROOT-path is returned. -d is the default.
+# and ESYSROOT-path is returned.
 #
 # If RUST_M{AX,IN}_SLOT is non-zero, then only Rust versions that
 # are not newer or older than the specified slot(s) will be considered.
@@ -278,7 +278,7 @@ unset -f _rust_set_globals
 _get_rust_slot() {
 	debug-print-function ${FUNCNAME} "$@"
 
-	local hv_switch=-d
+	local hv_switch=-b
 	while [[ ${1} == -* ]]; do
 		case ${1} in
 			-b|-d) hv_switch="${1}";;
@@ -412,7 +412,7 @@ get_rust_prefix() {
 	[[ ${1} == -d ]] && prefix=${ESYSROOT}
 
 	local slot rust_type
-	read -r slot rust_type <<< $(_get_rust_slot)
+	read -r slot rust_type <<< $(_get_rust_slot "$@")
 	get_rust_path "${prefix}" "${slot}" "${rust_type}"
 }
 
@@ -451,9 +451,9 @@ rust_pkg_setup() {
 	debug-print-function ${FUNCNAME} "$@"
 
 	if [[ ${MERGE_TYPE} != binary ]]; then
-		read -r RUST_SLOT RUST_TYPE <<< $(_get_rust_slot)
+		read -r RUST_SLOT RUST_TYPE <<< $(_get_rust_slot -b)
 		rust_prepend_path "${RUST_SLOT}" "${RUST_TYPE}"
-		local prefix=$(get_rust_prefix)
+		local prefix=$(get_rust_path "${BROOT}" "${RUST_SLOT}" "${RUST_TYPE}")
 		CARGO="${prefix}bin/cargo"
 		RUSTC="${prefix}bin/rustc"
 		export CARGO RUSTC
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-11-13 18:21 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-11-13 18:21 UTC (permalink / raw
  To: gentoo-commits
commit:     b0d162996da5a80e992bd5bcf6b5240bfe4f0db4
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Wed Nov 13 17:17:30 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Wed Nov 13 18:21:18 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=b0d16299
llvm.org.eclass: Add 20.0.0_pre20241113 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index 7325bf75e3bb..22cbeb6c0fc6 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -72,6 +72,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 			_LLVM_SOURCE_TYPE=snapshot
 
 			case ${PV} in
+				20.0.0_pre20241113)
+					EGIT_COMMIT=c7df10643bda4acdc9a02406a2eee8aa4ced747f
+					;;
 				20.0.0_pre20241106)
 					EGIT_COMMIT=0e907c17214aa3b1a60b66867fea3cc0f0dcbaa0
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-11-13 19:22 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-11-13 19:22 UTC (permalink / raw
  To: gentoo-commits
commit:     2aa4020e09554055db2d6a6f65c55370565a440e
Author:     Andrei Horodniceanu <a.horodniceanu <AT> proton <DOT> me>
AuthorDate: Wed Nov 13 09:31:00 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Nov 13 19:22:10 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=2aa4020e
toolchain.eclass: unconditionally pass --disable-cet on x86
d6cb7a61dad7e9672a8448597835dbbf9b9e0ccf removed the check that passed
--enable-cet or --disable-cet to configure making the script fallback to
automagic. The goal was to prevent passing --enable-cet on x86 gnu
triples as that would lead to gcc failing to build under crossdev. Note
that this specific crossdev cet issue has been solved in crossdev by
package.use.mask'ing the cet USE flag for gcc on x86 but targets
configured before that can still have the cet USE flag enabled.
Bug: https://bugs.gentoo.org/943332
Signed-off-by: Andrei Horodniceanu <a.horodniceanu <AT> proton.me>
Closes: https://github.com/gentoo/gentoo/pull/39300
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 1 +
 1 file changed, 1 insertion(+)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 1f043de0b548..99db7916c91d 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1588,6 +1588,7 @@ toolchain_src_configure() {
 
 		enable_cet_for 'x86_64' 'gnu' 'cet'
 		enable_cet_for 'aarch64' 'gnu' 'standard-branch-protection'
+		[[ ${CTARGET} == i[34567]86-* ]] && confgcc+=( --disable-cet )
 	fi
 
 	if in_iuse systemtap ; then
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-11-14  0:36 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-11-14  0:36 UTC (permalink / raw
  To: gentoo-commits
commit:     4d201afa8ab194f6ecf932f90fc35b9cb1fc92a1
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Nov 14 00:34:48 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Nov 14 00:35:08 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=4d201afa
toolchain.eclass: fix time64 conditional for kgcc64
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 99db7916c91d..8fe3cde2a69f 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1065,7 +1065,7 @@ toolchain_src_configure() {
 
 	downgrade_arch_flags
 	gcc_do_filter_flags
-	if tc_version_is_at_least 14.2.1_p20241026 ${PV}; then
+	if [[ ${PN} != kgcc64 && ${PN} != gcc-* ]] && tc_version_is_at_least 14.2.1_p20241026 ${PV}; then
 		append-cppflags "-D_GENTOO_TIME64_FORCE=$(usex time64 1 0)"
 	fi
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-11-17  5:27 Matt Jolly
  0 siblings, 0 replies; 6663+ messages in thread
From: Matt Jolly @ 2024-11-17  5:27 UTC (permalink / raw
  To: gentoo-commits
commit:     0fb3a82b51afa552cfc9cf7169e3d865b4f3419b
Author:     Matt Jolly <kangie <AT> gentoo <DOT> org>
AuthorDate: Sun Nov 17 05:23:34 2024 +0000
Commit:     Matt Jolly <kangie <AT> gentoo <DOT> org>
CommitDate: Sun Nov 17 05:27:08 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=0fb3a82b
rust.eclass: fix ECLASS_VARIABLE for LLVM/MULTILIB
RUST_NEEDS_LLVM and RUST_MULTILIB incorrectly had
ECLASS_VARIABLE in lowercase, resulting in these variables
not ending up in documentation.
Closes: https://bugs.gentoo.org/943559
Signed-off-by: Matt Jolly <kangie <AT> gentoo.org>
 eclass/rust.eclass | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/eclass/rust.eclass b/eclass/rust.eclass
index f293e96d7ce8..b578f6cf9afa 100644
--- a/eclass/rust.eclass
+++ b/eclass/rust.eclass
@@ -106,7 +106,7 @@ declare -a -g -r _RUST_SLOTS_ORDERED=(
 # Lowest Rust slot supported by the package. Needs to be set before
 # rust_pkg_setup is called. If unset, no lower bound is assumed.
 
-# @eclass-variable: RUST_NEEDS_LLVM
+# @ECLASS_VARIABLE: RUST_NEEDS_LLVM
 # @DEFAULT_UNSET
 # @DESCRIPTION:
 # If set to a non-empty value generate a llvm_slot_${llvm_slot}? gated
@@ -118,7 +118,7 @@ declare -a -g -r _RUST_SLOTS_ORDERED=(
 # an invalid combination of RUST and LLVM slots is detected; this probably
 # means that a LLVM slot in LLVM_COMPAT has had all of its Rust slots filtered.
 
-# @eclass-variable: RUST_MULTILIB
+# @ECLASS_VARIABLE: RUST_MULTILIB
 # @DEFAULT_UNSET
 # @DESCRIPTION:
 # If set to a non-empty value insert MULTILIB_USEDEP into the generated
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-11-17  5:27 Matt Jolly
  0 siblings, 0 replies; 6663+ messages in thread
From: Matt Jolly @ 2024-11-17  5:27 UTC (permalink / raw
  To: gentoo-commits
commit:     0b84ec0b3c260bc8a75616f73f0bfa9bdec0d600
Author:     Matt Jolly <kangie <AT> gentoo <DOT> org>
AuthorDate: Sun Nov 17 05:25:46 2024 +0000
Commit:     Matt Jolly <kangie <AT> gentoo <DOT> org>
CommitDate: Sun Nov 17 05:27:08 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=0b84ec0b
rust.eclass: break up eclass documentation
Signed-off-by: Matt Jolly <kangie <AT> gentoo.org>
 eclass/rust.eclass | 4 +++-
 1 file changed, 3 insertions(+), 1 deletion(-)
diff --git a/eclass/rust.eclass b/eclass/rust.eclass
index b578f6cf9afa..450911ba2ea0 100644
--- a/eclass/rust.eclass
+++ b/eclass/rust.eclass
@@ -13,8 +13,10 @@
 # a given Rust slot. To use the eclass:
 #
 # 1. If required, set RUST_{MAX,MIN}_SLOT to the range of supported slots.
+#
 # 2. If rust is optional, set RUST_OPTIONAL to a non-empty value then
-#     appropriately gate ${RUST_DEPEND}
+#    appropriately gate ${RUST_DEPEND}
+#
 # 3. Use rust_pkg_setup, get_rust_prefix or RUST_SLOT.
 
 # Example use for a package supporting Rust 1.72.0 to 1.82.0:
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-11-18  9:28 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-11-18  9:28 UTC (permalink / raw
  To: gentoo-commits
commit:     7040530e1c792a2e6e8f36969c408459f9338bde
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Nov 18 09:27:03 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Nov 18 09:27:22 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=7040530e
toolchain.eclass: only show checking warning w/ USE=-debug
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 12 +++++++-----
 1 file changed, 7 insertions(+), 5 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 8fe3cde2a69f..deedb1867816 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1185,11 +1185,13 @@ toolchain_src_configure() {
 		if grep -q "experimental" gcc/DEV-PHASE ; then
 			# Tell users about the non-obvious behavior here so they don't think
 			# e.g. the next GCC release is super slow to compile things.
-			ewarn "Unreleased GCCs default to extra runtime checks even with USE=-debug,"
-			ewarn "matching upstream default behavior. We recommend keeping these enabled."
-			ewarn "The checks (sometimes substantially) increase build time but provide important protection"
-			ewarn "from potential miscompilations (wrong code) by turning them into build-time errors."
-			ewarn "To override (not recommended), set: GCC_CHECKS_LIST=\"release\"."
+			if ! use debug ; then
+				ewarn "Unreleased GCCs default to extra runtime checks even with USE=-debug,"
+				ewarn "matching upstream default behavior. We recommend keeping these enabled."
+				ewarn "The checks (sometimes substantially) increase build time but provide important protection"
+				ewarn "from potential miscompilations (wrong code) by turning them into build-time errors."
+				ewarn "To override (not recommended), set: GCC_CHECKS_LIST=\"release\"."
+			fi
 
 			# - USE=debug for pre-releases: yes,extra,rtl (stornger than USE=debug for releases)
 			# - USE=-debug for pre-releases: yes,extra (following upstream default)
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-11-18 11:11 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-11-18 11:11 UTC (permalink / raw
  To: gentoo-commits
commit:     8ff6b44d29f8bbd4b3c3970af11d0ea3aebb2ca6
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Nov 18 11:09:01 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Nov 18 11:11:00 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=8ff6b44d
toolchain.eclass: drop -g for src_test
I was seriously mistaken on this: `1 file changed, 2228 deletions(-)` when
testing dropping it.
-g ultimately causes many more matches because of debug statements
and it confuses so many tests.
I must have just made an error when testing other big test flag changes
around the time.
This reverts commit 7200aecb3db3b2dd91129e1530bcb75ce096af91.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 4 ----
 1 file changed, 4 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index deedb1867816..f131da7dbd68 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -2270,10 +2270,6 @@ toolchain_src_test() {
 		GCC_TESTS_CFLAGS+=" -fno-stack-clash-protection"
 		GCC_TESTS_CXXFLAGS+=" -fno-stack-clash-protection"
 
-		# configure defaults to '-O2 -g' and some tests expect it
-		# accordingly.
-		GCC_TESTS_CFLAGS+=" -g"
-
 		# TODO: Does this handle s390 (-m31) correctly?
 		# TODO: What if there are multiple ABIs like x32 too?
 		# XXX: Disabled until validate_failures.py can handle 'variants'
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-11-18 16:44 Mike Gilbert
  0 siblings, 0 replies; 6663+ messages in thread
From: Mike Gilbert @ 2024-11-18 16:44 UTC (permalink / raw
  To: gentoo-commits
commit:     f8642f4a3ef06b7b82985c9f770e5cda862adb54
Author:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
AuthorDate: Mon Nov 11 00:59:40 2024 +0000
Commit:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
CommitDate: Mon Nov 18 16:43:00 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=f8642f4a
fcaps.eclass: leave permissions alone by default
Removing the read bit from suid binaries has questionable security
benefit, and may cause problems for some software.
Instead of clobbering the entire file mode, just toggle the suid bit if
needed. In most cases this will result in a world-readable file.
Introduce the FCAPS_DENY_WORLD_READ setting for users who insist on
having their suid binaries unreadable.
Skip calling chown/chmod if the owner/mode is empty. This may be used by
ebuild authors in certain use cases.
Bug: https://bugs.gentoo.org/938164
Signed-off-by: Mike Gilbert <floppym <AT> gentoo.org>
 eclass/fcaps.eclass | 35 ++++++++++++++++++++++++++---------
 1 file changed, 26 insertions(+), 9 deletions(-)
diff --git a/eclass/fcaps.eclass b/eclass/fcaps.eclass
index 477e1e954ab8..5cb781a7a75d 100644
--- a/eclass/fcaps.eclass
+++ b/eclass/fcaps.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2023 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: fcaps.eclass
@@ -66,6 +66,12 @@ esac
 #
 # Note: If you override pkg_postinst, you must call fcaps_pkg_postinst yourself.
 
+# @ECLASS_VARIABLE: FCAPS_DENY_WORLD_READ
+# @USER_VARIABLE
+# @DEFAULT_UNSET
+# @DESCRIPTION:
+# When set, deny read access on files updated by the fcaps function.
+
 # @FUNCTION: fcaps
 # @USAGE: [-o <owner>] [-g <group>] [-m <mode>] [-M <caps mode>] <capabilities> <file[s]>
 # @DESCRIPTION:
@@ -96,8 +102,13 @@ fcaps() {
 	# Process the user options first.
 	local owner='0'
 	local group='0'
-	local mode='4711'
-	local caps_mode='711'
+	local mode=u+s
+	local caps_mode=
+
+	if [[ -n ${FCAPS_DENY_WORLD_READ} ]]; then
+		mode=u+s,go-r
+		caps_mode=go-r
+	fi
 
 	while [[ $# -gt 0 ]] ; do
 		case $1 in
@@ -137,9 +148,10 @@ fcaps() {
 			# fs doesn't support it, but abort on all others.
 			debug-print "${FUNCNAME}: setting caps '${caps}' on '${file}'"
 
-			# If everything goes well, we don't want the file to be readable
-			# by people.
-			chmod ${caps_mode} "${file}" || die
+			# Remove the read bits if requested.
+			if [[ -n ${caps_mode} ]]; then
+				chmod ${caps_mode} "${file}" || die
+			fi
 
 			if ! out=$(LC_ALL=C setcap "${caps}" "${file}" 2>&1) ; then
 				case ${out} in
@@ -170,9 +182,14 @@ fcaps() {
 		fi
 
 		# If we're still here, setcaps failed.
-		debug-print "${FUNCNAME}: setting owner/mode on '${file}'"
-		chown "${owner}:${group}" "${file}" || die
-		chmod ${mode} "${file}" || die
+		if [[ -n ${owner} || -n ${group} ]]; then
+			debug-print "${FUNCNAME}: setting owner on '${file}'"
+			chown "${owner}:${group}" "${file}" || die
+		fi
+		if [[ -n ${mode} ]]; then
+			debug-print "${FUNCNAME}: setting mode on '${file}'"
+			chmod ${mode} "${file}" || die
+		fi
 	done
 }
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-11-18 19:32 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-11-18 19:32 UTC (permalink / raw
  To: gentoo-commits
commit:     d9336e4f6e20d6a25c85f056b114eeaeace9e9d3
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Mon Nov 18 18:41:33 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Mon Nov 18 19:32:15 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=d9336e4f
llvm.org.eclass: Add 20.0.0_pre20241118 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index 22cbeb6c0fc6..e332e6d1804c 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -72,6 +72,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 			_LLVM_SOURCE_TYPE=snapshot
 
 			case ${PV} in
+				20.0.0_pre20241118)
+					EGIT_COMMIT=a6385a3fc8a88f092d07672210a1e773481c2919
+					;;
 				20.0.0_pre20241113)
 					EGIT_COMMIT=c7df10643bda4acdc9a02406a2eee8aa4ced747f
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-11-19 14:50 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-11-19 14:50 UTC (permalink / raw
  To: gentoo-commits
commit:     f6a974f8f2378c6c6a83345c101afce233fdf1d7
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Nov 19 14:49:04 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Nov 19 14:50:08 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=f6a974f8
toolchain.eclass: fix libdiagnostics handling
Reported by ulm. This was introduced by a last-minute simplification I made,
but USE=libdiagnostics only exists for 9999 and the *next* snapshot, not
the current one, but even then, the code was wrong for < 15 as the use_enable
part was run unconditionally w/ USE=jit.
Fixes: b923a4c0d1a330e40f0a05f3bc94bb4f32ce1cbb
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 5 ++++-
 1 file changed, 4 insertions(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index edff7254c905..e28479dc44af 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1761,7 +1761,6 @@ toolchain_src_configure() {
 
 			--enable-host-shared
 			--enable-languages=jit
-			$(use_enable libdiagnostics)
 
 			# Might be used for the just-built GCC. Easier to just
 			# respect USE=graphite here in case the user passes some
@@ -1771,6 +1770,10 @@ toolchain_src_configure() {
 			--with-system-zlib
 		)
 
+		if tc_version_is_at_least 15.0.0_pre20241124 ; then
+			confgcc_jit+=( $(use_enable libdiagnostics) )
+		fi
+
 		if tc_version_is_at_least 13.1 ; then
 			confgcc_jit+=( --disable-fixincludes )
 		fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-11-19 15:01 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-11-19 15:01 UTC (permalink / raw
  To: gentoo-commits
commit:     14b4ce60bae26089b0b80f9f629900bf7721e9f5
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Nov 19 14:59:53 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Nov 19 14:59:53 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=14b4ce60
toolchain.eclass: fix libdiagnostics handling (more)
I continue to mix up how tc_version_is_at_least works. One day I'll
change it...
Closes: https://bugs.gentoo.org/944007
Fixes: f6a974f8f2378c6c6a83345c101afce233fdf1d7
Fixes: b923a4c0d1a330e40f0a05f3bc94bb4f32ce1cbb
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index e28479dc44af..02db921ce133 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1770,7 +1770,7 @@ toolchain_src_configure() {
 			--with-system-zlib
 		)
 
-		if tc_version_is_at_least 15.0.0_pre20241124 ; then
+		if tc_version_is_at_least 15.0.0_pre20241124 ${PV} ; then
 			confgcc_jit+=( $(use_enable libdiagnostics) )
 		fi
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-11-20 12:05 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-11-20 12:05 UTC (permalink / raw
  To: gentoo-commits
commit:     1b5d47858780c700e706582aa370a69148552055
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Nov 20 11:59:35 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Nov 20 11:59:35 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=1b5d4785
toolchain.eclass: fix Ada bootstrap paths for cross
Same sort of thing as 434a6775ce93a15ef517478565a938aa73d1d528 although
the paths are different as we're using something from libexec (gnat1).
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 02db921ce133..b3eb184498d9 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -956,10 +956,10 @@ toolchain_setup_ada() {
 	case ${ada_bootstrap_type} in
 		ada-bootstrap)
 			export PATH="${BROOT}/usr/lib/ada-bootstrap/bin:${PATH}"
-			gnat1_path=${BROOT}/usr/lib/ada-bootstrap/libexec/gcc/${CBUILD}/${ada_bootstrap}/gnat1
+			gnat1_path=${BROOT}/usr/lib/ada-bootstrap/libexec/gcc/${CHOST}/${ada_bootstrap}/gnat1
 			;;
 		*)
-			gnat1_path=${BROOT}/usr/libexec/gcc/${CBUILD}/${ada_bootstrap}/gnat1
+			gnat1_path=${BROOT}/usr/libexec/gcc/${CHOST}/${ada_bootstrap}/gnat1
 			;;
 	esac
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-11-20 12:15 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-11-20 12:15 UTC (permalink / raw
  To: gentoo-commits
commit:     0a0b2fe6aadb9d0c3b41fdabb21535659c839bf5
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Nov 20 12:15:05 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Nov 20 12:15:38 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=0a0b2fe6
toolchain.eclass: followup Ada fix
Followup to 1b5d47858780c700e706582aa370a69148552055.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index b3eb184498d9..8b3b5db38900 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -976,7 +976,7 @@ toolchain_setup_ada() {
 	# work for us as the stage1 compiler doesn't necessarily have Ada
 	# support. Substitute the Ada compiler we found earlier.
 	local adalib
-	adalib=$(${CBUILD}-gcc-${ada_bootstrap} -print-libgcc-file-name || die "Finding adalib dir failed")
+	adalib=$(${CHOST}-gcc-${ada_bootstrap} -print-libgcc-file-name || die "Finding adalib dir failed")
 	adalib="${adalib%/*}/adalib"
 	sed -i \
 		-e "s:adalib=.*:adalib=${adalib}:" \
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-11-20 12:20 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-11-20 12:20 UTC (permalink / raw
  To: gentoo-commits
commit:     97069fd8721ea55980e548b9cf1d55e2a234a514
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Nov 20 12:20:00 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Nov 20 12:20:13 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=97069fd8
toolchain.eclass: another Ada cross fix
Followup followup to 0a0b2fe6aadb9d0c3b41fdabb21535659c839bf5 and
1b5d47858780c700e706582aa370a69148552055.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 8b3b5db38900..8178a7b837b2 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -989,7 +989,7 @@ toolchain_setup_ada() {
 	for tool in gnat{,bind,chop,clean,kr,link,ls,make,name,prep} ; do
 		cat <<-EOF > "${T}"/ada-wrappers/${tool} || die
 		#!/bin/sh
-		exec $(type -P ${CBUILD}-${tool}-${ada_bootstrap}) "\$@"
+		exec $(type -P ${CHOST}-${tool}-${ada_bootstrap}) "\$@"
 		EOF
 
 		export "${tool^^}"="${T}"/ada-wrappers/${tool}
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-11-20 12:37 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-11-20 12:37 UTC (permalink / raw
  To: gentoo-commits
commit:     839a158bb5efbf454e09414e96cd7716a2550f31
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Nov 20 12:36:08 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Nov 20 12:36:08 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=839a158b
toolchain.eclass: revert Ada changes for now
I need to do some more. Revert my earlier changes for now.
Reverts: 97069fd8721ea55980e548b9cf1d55e2a234a514
Reverts: 0a0b2fe6aadb9d0c3b41fdabb21535659c839bf5
Reverts: 1b5d47858780c700e706582aa370a69148552055
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 8 ++++----
 1 file changed, 4 insertions(+), 4 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 8178a7b837b2..02db921ce133 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -956,10 +956,10 @@ toolchain_setup_ada() {
 	case ${ada_bootstrap_type} in
 		ada-bootstrap)
 			export PATH="${BROOT}/usr/lib/ada-bootstrap/bin:${PATH}"
-			gnat1_path=${BROOT}/usr/lib/ada-bootstrap/libexec/gcc/${CHOST}/${ada_bootstrap}/gnat1
+			gnat1_path=${BROOT}/usr/lib/ada-bootstrap/libexec/gcc/${CBUILD}/${ada_bootstrap}/gnat1
 			;;
 		*)
-			gnat1_path=${BROOT}/usr/libexec/gcc/${CHOST}/${ada_bootstrap}/gnat1
+			gnat1_path=${BROOT}/usr/libexec/gcc/${CBUILD}/${ada_bootstrap}/gnat1
 			;;
 	esac
 
@@ -976,7 +976,7 @@ toolchain_setup_ada() {
 	# work for us as the stage1 compiler doesn't necessarily have Ada
 	# support. Substitute the Ada compiler we found earlier.
 	local adalib
-	adalib=$(${CHOST}-gcc-${ada_bootstrap} -print-libgcc-file-name || die "Finding adalib dir failed")
+	adalib=$(${CBUILD}-gcc-${ada_bootstrap} -print-libgcc-file-name || die "Finding adalib dir failed")
 	adalib="${adalib%/*}/adalib"
 	sed -i \
 		-e "s:adalib=.*:adalib=${adalib}:" \
@@ -989,7 +989,7 @@ toolchain_setup_ada() {
 	for tool in gnat{,bind,chop,clean,kr,link,ls,make,name,prep} ; do
 		cat <<-EOF > "${T}"/ada-wrappers/${tool} || die
 		#!/bin/sh
-		exec $(type -P ${CHOST}-${tool}-${ada_bootstrap}) "\$@"
+		exec $(type -P ${CBUILD}-${tool}-${ada_bootstrap}) "\$@"
 		EOF
 
 		export "${tool^^}"="${T}"/ada-wrappers/${tool}
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-11-22 19:25 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-11-22 19:25 UTC (permalink / raw
  To: gentoo-commits
commit:     f97d6acdc51b31a5473ada79b5636388f9e16cd3
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Nov 22 19:25:26 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Nov 22 19:25:35 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=f97d6acd
toolchain.eclass: filter -fdiagnostics-set-output=text:experimental-nesting=yes for < 15
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 1 +
 1 file changed, 1 insertion(+)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 02db921ce133..696eec73b4ba 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1966,6 +1966,7 @@ gcc_do_filter_flags() {
 
 	if ver_test -lt 15.1 ; then
 		filter-flags -fdiagnostics-explain-harder -fdiagnostics-details
+		filter-flags -fdiagnostics-set-output=text:experimental-nesting=yes
 	fi
 
 	if is_d ; then
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-11-23 13:15 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-11-23 13:15 UTC (permalink / raw
  To: gentoo-commits
commit:     046c2aa1d89481de5fcdfe21e1c6aa63fcf59597
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Nov 23 13:13:51 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat Nov 23 13:15:47 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=046c2aa1
llvm.org.eclass: Remove old snapshots
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 9 ---------
 1 file changed, 9 deletions(-)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index e5388f548228..fe93a0deb841 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -78,15 +78,6 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 				20.0.0_pre20241118)
 					EGIT_COMMIT=a6385a3fc8a88f092d07672210a1e773481c2919
 					;;
-				20.0.0_pre20241113)
-					EGIT_COMMIT=c7df10643bda4acdc9a02406a2eee8aa4ced747f
-					;;
-				20.0.0_pre20241106)
-					EGIT_COMMIT=0e907c17214aa3b1a60b66867fea3cc0f0dcbaa0
-					;;
-				20.0.0_pre20241029)
-					EGIT_COMMIT=3f4468faaa9525ad615118675c3c68938f4a8d5f
-					;;
 				*)
 					die "Unknown snapshot: ${PV}"
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-11-24 19:01 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-11-24 19:01 UTC (permalink / raw
  To: gentoo-commits
commit:     729c11d560d55971b8f46295fce77afc4e895265
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Wed Nov 20 16:51:48 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sun Nov 24 19:01:40 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=729c11d5
toolchain.eclass: Throw an error if trying to disable time64
Throw an error if the user is trying to build a non-time64 version
of GCC on a system featuring a time64 GCC already.  Most of the time,
this will mean that the user has accidentally switched to a non-time64
profile.
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
Closes: https://github.com/gentoo/gentoo/pull/39384
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/toolchain.eclass | 13 +++++++++++++
 1 file changed, 13 insertions(+)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 696eec73b4ba..13f3298fea90 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -576,6 +576,19 @@ toolchain_pkg_pretend() {
 		_tc_use_if_iuse objc++ && \
 			ewarn 'Obj-C++ requires a C++ compiler, disabled due to USE="-cxx"'
 	fi
+
+	# Do the check for pure source builds only, since the override
+	# cannot work with binary packages, see https://bugs.gentoo.org/944198
+	if [[ ${BUILD_TYPE} == source ]] && in_iuse time64 && ! use time64 &&
+		has_version -r "${CATEGORY}/${PN}[time64(-)]" &&
+		[[ ! ${TC_FORCE_TIME32} ]]
+	then
+		eerror "Attempting to build USE=-time64 version of gcc when at least"
+		eerror "one USE=time64 version is installed. Did you accidentally"
+		eerror "switch back to a non-time64 profile? If this is really"
+		eerror "desirable, set TC_FORCE_TIME32=1 to force the build."
+		die "Attempting to build USE=-time64 on a USE=time64 system"
+	fi
 }
 
 #---->> pkg_setup <<----
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-11-26  1:45 Maciej Barć
  0 siblings, 0 replies; 6663+ messages in thread
From: Maciej Barć @ 2024-11-26  1:45 UTC (permalink / raw
  To: gentoo-commits
commit:     19097e3b12aef083f542c88bafe01303f5d61fbf
Author:     Maciej Barć <xgqt <AT> gentoo <DOT> org>
AuthorDate: Wed Nov 20 21:43:10 2024 +0000
Commit:     Maciej Barć <xgqt <AT> gentoo <DOT> org>
CommitDate: Tue Nov 26 01:44:57 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=19097e3b
eclass/nuget: add eclassdoc that describes how to generate the NUGETS list
Some users asked for it. Also add a link to the Gentoo Wiki with more
specific examples.
Signed-off-by: Maciej Barć <xgqt <AT> gentoo.org>
 eclass/nuget.eclass | 15 +++++++++++++++
 1 file changed, 15 insertions(+)
diff --git a/eclass/nuget.eclass b/eclass/nuget.eclass
index 4efbeb909f43..3fa732e79b5f 100644
--- a/eclass/nuget.eclass
+++ b/eclass/nuget.eclass
@@ -71,6 +71,21 @@ export NUGET_PACKAGES
 # @DESCRIPTION:
 # String containing all NuGet packages that need to be downloaded.
 #
+# To generate the "NUGETS" list use the "gdmt restore" tool from the
+# "dev-dotnet/gentoo-dotnet-maintainer-tools" package. To see all "gdmt restore"
+# options invoke it with the "--help" flag. The Gentoo Wiki page
+# Dotnet/Devguide (https://wiki.gentoo.org/wiki/Dotnet/Devguide) contains some
+# examples and special cases to be beware of.
+#
+# Generally you will want to invoke "gdmt restore" form within a (clean) tagged
+# checkout of a given .NET-based project. The invocation will look something
+# like this: gdmt restore --sdk-ver SDK-VER --cache "$(pwd)/.cache" --project PROJECT
+# Where:
+#   * "SDK-VER" is a .NET version (6.0, 8.0), mind the full version, "8" is not allowed,
+#   * "PROJECT" is a given project file (.csproj or .fsproj) or a directory containing it.
+# So, for example:
+# gdmt restore --sdk-ver 8.0 --cache "$(pwd)/.cache" --project src/App/App.csproj
+#
 # Used by "_nuget_uris".
 #
 # Example:
^ permalink raw reply related	[flat|nested] 6663+ messages in thread
* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-11-26  1:45 Maciej Barć
  0 siblings, 0 replies; 6663+ messages in thread
From: Maciej Barć @ 2024-11-26  1:45 UTC (permalink / raw
  To: gentoo-commits
commit:     3c00cc939e174c24bb62583b1441bcdf99cf8195
Author:     Maciej Barć <xgqt <AT> gentoo <DOT> org>
AuthorDate: Wed Nov 20 21:40:26 2024 +0000
Commit:     Maciej Barć <xgqt <AT> gentoo <DOT> org>
CommitDate: Tue Nov 26 01:44:57 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=3c00cc93
eclass/dotnet-pkg-base: disable MSBUILDTERMINALLOGGER from .NET 9.0
Disable the fancy terminal logger introduced in .NET 9.0.
If enabled, it messes up with the Portage log file output.
Signed-off-by: Maciej Barć <xgqt <AT> gentoo.org>
 eclass/dotnet-pkg-base.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/dotnet-pkg-base.eclass b/eclass/dotnet-pkg-base.eclass
index 8ec21c9a276c..d9abff3859f6 100644
--- a/eclass/dotnet-pkg-base.eclass
+++ b/eclass/dotnet-pkg-base.eclass
@@ -104,6 +104,9 @@ export POWERSHELL_UPDATECHECK=0
 # Speeds up restore. Having this turned on is redundant with Portage manifests.
 # See also: https://github.com/NuGet/Home/issues/13062
 export DOTNET_NUGET_SIGNATURE_VERIFICATION=false
+# Disable the fancy terminal logger introduced in .NET 9.0.
+# It messes up the Portage log file output.
+export MSBUILDTERMINALLOGGER=off
 # Overwrite selected MSBuild properties ("-p:XYZ").
 export UseSharedCompilation=false
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-11-26 17:28 Florian Schmaus
  0 siblings, 0 replies; 6663+ messages in thread
From: Florian Schmaus @ 2024-11-26 17:28 UTC (permalink / raw
  To: gentoo-commits
commit:     dec60bb6900d6ebdaaa6aa1dcb845b30b739f9b5
Author:     Florian Schmaus <flow <AT> gentoo <DOT> org>
AuthorDate: Tue Nov 26 17:28:34 2024 +0000
Commit:     Florian Schmaus <flow <AT> gentoo <DOT> org>
CommitDate: Tue Nov 26 17:28:52 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=dec60bb6
texlive-module.eclass: add man pages of texlive 2024
Signed-off-by: Florian Schmaus <flow <AT> gentoo.org>
 eclass/texlive-module.eclass | 2 ++
 1 file changed, 2 insertions(+)
diff --git a/eclass/texlive-module.eclass b/eclass/texlive-module.eclass
index d7ec59c25a8a..f8b6f0858cd6 100644
--- a/eclass/texlive-module.eclass
+++ b/eclass/texlive-module.eclass
@@ -377,6 +377,7 @@ texlive-module_src_install() {
 				ctangle.1
 				ctie.1
 				ctwill.1
+				ctwill-proofsort.1
 				ctwill-refsort.1
 				ctwill-twinx.1
 				cweave.1
@@ -506,6 +507,7 @@ texlive-module_src_install() {
 				ttf2afm.1
 				ttfdump.1
 				twill.1
+				twill-refsort.1
 				upbibtex.1
 				updmap.1
 				updmap.cfg.5
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-11-27  9:21 Nowa Ammerlaan
  0 siblings, 0 replies; 6663+ messages in thread
From: Nowa Ammerlaan @ 2024-11-27  9:21 UTC (permalink / raw
  To: gentoo-commits
commit:     43886ead1d7373603bad3ba704a2763a978a8cb1
Author:     Nowa Ammerlaan <nowa <AT> gentoo <DOT> org>
AuthorDate: Tue Nov 26 20:55:37 2024 +0000
Commit:     Nowa Ammerlaan <nowa <AT> gentoo <DOT> org>
CommitDate: Wed Nov 27 09:21:41 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=43886ead
kernel-build.eclass: install dtb into /lib/modules instead of /boot
Systemd's kernel-install hooks expect it here or in the firmware directory. We
need to find it for building UKI's and registering BLS type 1 entries. Fedora
and Arch also install the dtb files here.
If it is needed in /boot then it is probably a better idea to delegate that
task to /sbin/installkernel anyway. That way the part of the emerge that writes
to /boot is contained to only the postinst and config phases and makes it
possible to re-try this via emerge --config ... .
Closes: https://bugs.gentoo.org/945072
Signed-off-by: Nowa Ammerlaan <nowa <AT> gentoo.org>
Closes: https://github.com/gentoo/gentoo/pull/39486
Signed-off-by: Nowa Ammerlaan <nowa <AT> gentoo.org>
 eclass/kernel-build.eclass | 5 +++--
 1 file changed, 3 insertions(+), 2 deletions(-)
diff --git a/eclass/kernel-build.eclass b/eclass/kernel-build.eclass
index 9d33aef92691..376cebf3b1be 100644
--- a/eclass/kernel-build.eclass
+++ b/eclass/kernel-build.eclass
@@ -379,9 +379,10 @@ kernel-build_src_install() {
 
 	local target
 	for target in "${targets[@]}" ; do
-		emake O="${WORKDIR}"/build "${MAKEARGS[@]}" \
+		emake O="${WORKDIR}"/build "${MAKEARGS[@]}" INSTALL_PATH="${ED}/boot" \
 			INSTALL_MOD_PATH="${ED}" INSTALL_MOD_STRIP="${strip_args}" \
-			INSTALL_PATH="${ED}/boot" "${compress[@]}" "${target}"
+			INSTALL_DTBS_PATH="${ED}/lib/modules/${KV_FULL}/dtb" \
+			"${compress[@]}" "${target}"
 	done
 
 	# note: we're using mv rather than doins to save space and time
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-11-29 21:18 Eli Schwartz
  0 siblings, 0 replies; 6663+ messages in thread
From: Eli Schwartz @ 2024-11-29 21:18 UTC (permalink / raw
  To: gentoo-commits
commit:     b7b0732f914295d30e77f7be40cba1c79fdf2313
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sun Nov 10 03:29:37 2024 +0000
Commit:     Eli Schwartz <eschwartz <AT> gentoo <DOT> org>
CommitDate: Fri Nov 29 21:12:06 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=b7b0732f
distutils-r1.eclass: Also do SETUPTOOLS_RUST_CARGO_PROFILE uncond.
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
Signed-off-by: Eli Schwartz <eschwartz <AT> gentoo.org>
 eclass/distutils-r1.eclass | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/eclass/distutils-r1.eclass b/eclass/distutils-r1.eclass
index 2a71899f08b7..e5a13e9c88cd 100644
--- a/eclass/distutils-r1.eclass
+++ b/eclass/distutils-r1.eclass
@@ -1259,6 +1259,9 @@ distutils_pep517_install() {
 
 	# set it globally in case we were using "standalone" wrapper
 	local -x HATCH_METADATA_CLASSIFIERS_NO_VERIFY=1
+	if in_iuse debug && use debug; then
+		local -x SETUPTOOLS_RUST_CARGO_PROFILE=dev
+	fi
 
 	case ${DISTUTILS_USE_PEP517} in
 		maturin)
@@ -1351,9 +1354,6 @@ distutils_pep517_install() {
 			)
 			;;
 		setuptools)
-			if in_iuse debug && use debug; then
-				local -x SETUPTOOLS_RUST_CARGO_PROFILE=dev
-			fi
 			if [[ -n ${DISTUTILS_ARGS[@]} ]]; then
 				config_settings=$(
 					"${EPYTHON}" - "${DISTUTILS_ARGS[@]}" <<-EOF || die
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-11-29 21:18 Eli Schwartz
  0 siblings, 0 replies; 6663+ messages in thread
From: Eli Schwartz @ 2024-11-29 21:18 UTC (permalink / raw
  To: gentoo-commits
commit:     9450bddf360dd6cd5480fd064553eff53bf93d9b
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Wed Oct 23 19:20:31 2024 +0000
Commit:     Eli Schwartz <eschwartz <AT> gentoo <DOT> org>
CommitDate: Fri Nov 29 21:11:58 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=9450bddf
python-utils-r1.eclass: Move python3_13t before other python*
Move the python3_13t target on the list before other CPython targets.
This means it's technically "less preferred", so e.g. *all phases
would rather be performed with regular CPython, which should generally
be more faster.
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
Signed-off-by: Eli Schwartz <eschwartz <AT> gentoo.org>
 eclass/python-utils-r1.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/python-utils-r1.eclass b/eclass/python-utils-r1.eclass
index 555b6c561a18..aa22b164020c 100644
--- a/eclass/python-utils-r1.eclass
+++ b/eclass/python-utils-r1.eclass
@@ -40,8 +40,8 @@ inherit multiprocessing toolchain-funcs
 # All supported Python implementations, most preferred last.
 _PYTHON_ALL_IMPLS=(
 	pypy3
-	python3_{10..13}
 	python3_13t
+	python3_{10..13}
 )
 readonly _PYTHON_ALL_IMPLS
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-11-29 21:18 Eli Schwartz
  0 siblings, 0 replies; 6663+ messages in thread
From: Eli Schwartz @ 2024-11-29 21:18 UTC (permalink / raw
  To: gentoo-commits
commit:     4f313c8a60d62cceab147cb62d2a4ee07484dd50
Author:     Eli Schwartz <eschwartz <AT> gentoo <DOT> org>
AuthorDate: Fri Jul  5 19:22:04 2024 +0000
Commit:     Eli Schwartz <eschwartz <AT> gentoo <DOT> org>
CommitDate: Fri Nov 29 21:12:08 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=4f313c8a
distutils-r1.eclass: disable setuptools validation of pypi.org allowed strings
In the previous commit, a change was patched into setuptools to enable
skipping pypi.org specific validations we do not want. Export the
environment variable which activates this, whenever the build backend is
setuptools.
Bug: https://github.com/pypa/setuptools/issues/4459
Signed-off-by: Eli Schwartz <eschwartz <AT> gentoo.org>
 eclass/distutils-r1.eclass | 1 +
 1 file changed, 1 insertion(+)
diff --git a/eclass/distutils-r1.eclass b/eclass/distutils-r1.eclass
index e5a13e9c88cd..c2d7e7eb8d06 100644
--- a/eclass/distutils-r1.eclass
+++ b/eclass/distutils-r1.eclass
@@ -1259,6 +1259,7 @@ distutils_pep517_install() {
 
 	# set it globally in case we were using "standalone" wrapper
 	local -x HATCH_METADATA_CLASSIFIERS_NO_VERIFY=1
+	local -x GENTOO_VALIDATE_PYPROJECT_NO_TROVE_CLASSIFIERS=1
 	if in_iuse debug && use debug; then
 		local -x SETUPTOOLS_RUST_CARGO_PROFILE=dev
 	fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-11-29 21:18 Eli Schwartz
  0 siblings, 0 replies; 6663+ messages in thread
From: Eli Schwartz @ 2024-11-29 21:18 UTC (permalink / raw
  To: gentoo-commits
commit:     b7a319036353b6fe12fe76ffea061b697546412e
Author:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
AuthorDate: Tue Nov  5 02:52:25 2024 +0000
Commit:     Eli Schwartz <eschwartz <AT> gentoo <DOT> org>
CommitDate: Fri Nov 29 21:12:05 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=b7a31903
distutils-r1.eclass: Update maturin's skip auditwheel option
>=maturin-1.7.1 has deprecated --skip-auditwheel and added
--auditwheel=<check|repair|skip> to replace it. Update and set
the lower bound to latest stable rather than use has_version.
Signed-off-by: Ionen Wolkens <ionen <AT> gentoo.org>
Closes: https://github.com/gentoo/gentoo/pull/39204
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
Signed-off-by: Eli Schwartz <eschwartz <AT> gentoo.org>
 eclass/distutils-r1.eclass | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/eclass/distutils-r1.eclass b/eclass/distutils-r1.eclass
index 357e64e6f75c..1806eb06483d 100644
--- a/eclass/distutils-r1.eclass
+++ b/eclass/distutils-r1.eclass
@@ -271,7 +271,7 @@ _distutils_set_globals() {
 				;;
 			maturin)
 				bdep+='
-					>=dev-util/maturin-1.4.0[${PYTHON_USEDEP}]
+					>=dev-util/maturin-1.7.4[${PYTHON_USEDEP}]
 				'
 				;;
 			no)
@@ -1262,8 +1262,8 @@ distutils_pep517_install() {
 			# `maturin pep517 build-wheel --help` for options
 			local maturin_args=(
 				"${DISTUTILS_ARGS[@]}"
+				--auditwheel=skip # see bug #831171
 				--jobs="$(makeopts_jobs)"
-				--skip-auditwheel # see bug #831171
 				$(in_iuse debug && usex debug '--profile=dev' '')
 			)
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-11-29 21:18 Eli Schwartz
  0 siblings, 0 replies; 6663+ messages in thread
From: Eli Schwartz @ 2024-11-29 21:18 UTC (permalink / raw
  To: gentoo-commits
commit:     5c431d966af391ec2419df55eb6eb92d833f63d9
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sun Nov 10 03:27:41 2024 +0000
Commit:     Eli Schwartz <eschwartz <AT> gentoo <DOT> org>
CommitDate: Fri Nov 29 21:12:06 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=5c431d96
distutils-r1.eclass: Use HATCH_METADATA_CLASSIFIERS_NO_VERIFY
Bug: https://github.com/pypa/hatch/issues/1368
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
Signed-off-by: Eli Schwartz <eschwartz <AT> gentoo.org>
 eclass/distutils-r1.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/distutils-r1.eclass b/eclass/distutils-r1.eclass
index 1806eb06483d..2a71899f08b7 100644
--- a/eclass/distutils-r1.eclass
+++ b/eclass/distutils-r1.eclass
@@ -1257,6 +1257,9 @@ distutils_pep517_install() {
 		cmd+=( cargo_env )
 	fi
 
+	# set it globally in case we were using "standalone" wrapper
+	local -x HATCH_METADATA_CLASSIFIERS_NO_VERIFY=1
+
 	case ${DISTUTILS_USE_PEP517} in
 		maturin)
 			# `maturin pep517 build-wheel --help` for options
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-11-30  2:08 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-11-30  2:08 UTC (permalink / raw
  To: gentoo-commits
commit:     2cfb62836bcd010f49e186bfa9679ea469e72b32
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Nov 30 02:05:12 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Nov 30 02:08:36 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=2cfb6283
toolchain.eclass: wire up nvptx more
We need to handle nvptx* in CTARGET in a few more places so we propagate
that we're using newlib (which is obviously right but also means we don't
then fail when building libatomic b/c libg.a is missing).
Bug: https://bugs.gentoo.org/945296
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 3 ++-
 1 file changed, 2 insertions(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 13f3298fea90..bcc47ffb9635 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1311,6 +1311,7 @@ toolchain_src_configure() {
 				confgcc+=( --enable-shared --disable-threads )
 				;;
 			nvptx*)
+				needed_libc=newlib
 				# "LTO is not supported for this target"
 				confgcc+=( --disable-lto )
 				;;
@@ -1389,7 +1390,7 @@ toolchain_src_configure() {
 	# __cxa_atexit is "essential for fully standards-compliant handling of
 	# destructors", but apparently requires glibc.
 	case ${CTARGET} in
-		*-elf|*-eabi)
+		nvptx*|*-elf|*-eabi)
 			confgcc+=( --with-newlib )
 			;;
 		*-musl*)
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-11-30  5:10 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-11-30  5:10 UTC (permalink / raw
  To: gentoo-commits
commit:     6d9336278643e0ad9fc99cfd497d50c3a8f30319
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Nov 30 02:59:57 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Nov 30 05:10:29 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=6d933627
toolchain.eclass: wire up offloading for nvptx
'crossdev -t nvptx-none' creates a standalone cross-compiler which is needed
anyway, but by itself, it's less useful than offloading support within
host gcc, where GCC can choose to offload into that cross-compiler as
appropriate.
This could include amdgcn-amdhsa support in the future.
Bug: https://bugs.gentoo.org/945296
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 32 ++++++++++++++++++++++++++++++--
 1 file changed, 30 insertions(+), 2 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index bcc47ffb9635..5b68c5acbc49 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1312,8 +1312,30 @@ toolchain_src_configure() {
 				;;
 			nvptx*)
 				needed_libc=newlib
-				# "LTO is not supported for this target"
-				confgcc+=( --disable-lto )
+				confgcc+=(
+					# "LTO is not supported for this target"
+					--disable-lto
+				)
+
+				# --enable-as-accelerator-for= seems to disable
+				# installing nvtpx-none-cc etc, so we have to
+				# avoid passing that for the stage1-build that
+				# crossdev does. If we pass it unconditionally,
+				# we can't build newlib after building stage1 gcc.
+				if has_version ${CATEGORY}/${PN} ; then
+					confgcc+=(
+						# It's unlikely that anyone will want
+						# to build nvptx-none as a pure standalone
+						# toolchain (which will be single-threaded, etc).
+						#
+						# If someone really wants it, we can see about
+						# adding a USE=offload or similar based on CTARGET
+						# for cross targets. But for now, we always assume
+						# we're being built as an offloading compiler (accelerator).
+						--enable-as-accelerator-for=${CHOST}
+						--disable-sjlj-exceptions
+					)
+				fi
 				;;
 		esac
 
@@ -1547,6 +1569,12 @@ toolchain_src_configure() {
 	[[ ${CTARGET} == *-darwin* ]] && \
 		confgcc+=( --enable-version-specific-runtime-libs )
 
+	# TODO: amdgcn-amdhsa?
+	[[ ${CTARGET} == x86_64* ]] && confgcc+=(
+		--enable-offload-defaulted
+		--enable-offload-targets=nvptx-none
+	)
+
 	### library options
 
 	if in_iuse openmp ; then
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-11-30  5:10 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-11-30  5:10 UTC (permalink / raw
  To: gentoo-commits
commit:     83ff8f581b40c21ca65a5370d4d86085972ebf89
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Nov 30 03:05:50 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Nov 30 05:10:29 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=83ff8f58
toolchain.eclass: filter -Werror=format-security
Bug: https://gcc.gnu.org/PR100431
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 5b68c5acbc49..eac300438da5 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1995,6 +1995,9 @@ gcc_do_filter_flags() {
 		fi
 	fi
 
+	# https://gcc.gnu.org/PR100431
+	filter-flags -Werror=format-security
+
 	if ver_test -lt 13.6 ; then
 		# These aren't supported by the just-built compiler either.
 		filter-flags -fharden-compares -fharden-conditional-branches \
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-11-30  7:17 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-11-30  7:17 UTC (permalink / raw
  To: gentoo-commits
commit:     db66158182dafb2614ddfe5514216f17e166792d
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Nov 30 07:15:43 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat Nov 30 07:15:43 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=db661581
distutils-r1.eclass: Revert "disable setuptools validation ..."
Unauthorized changes, superseded by a later patchset.
Reverts: 4f313c8a60d62cceab147cb62d2a4ee07484dd50
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/distutils-r1.eclass | 1 -
 1 file changed, 1 deletion(-)
diff --git a/eclass/distutils-r1.eclass b/eclass/distutils-r1.eclass
index c2d7e7eb8d06..e5a13e9c88cd 100644
--- a/eclass/distutils-r1.eclass
+++ b/eclass/distutils-r1.eclass
@@ -1259,7 +1259,6 @@ distutils_pep517_install() {
 
 	# set it globally in case we were using "standalone" wrapper
 	local -x HATCH_METADATA_CLASSIFIERS_NO_VERIFY=1
-	local -x GENTOO_VALIDATE_PYPROJECT_NO_TROVE_CLASSIFIERS=1
 	if in_iuse debug && use debug; then
 		local -x SETUPTOOLS_RUST_CARGO_PROFILE=dev
 	fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-11-30  7:17 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-11-30  7:17 UTC (permalink / raw
  To: gentoo-commits
commit:     142233f08e4be891468e74727ce4e0e538adc5c7
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sun Oct 20 15:55:00 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat Nov 30 07:16:12 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=142233f0
python-any-r1.eclass: Remove obsolete variable
Remove a leftover variable from before PYTHON_PKG_DEP was used.
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/python-any-r1.eclass | 3 +--
 1 file changed, 1 insertion(+), 2 deletions(-)
diff --git a/eclass/python-any-r1.eclass b/eclass/python-any-r1.eclass
index ca2ddf146406..adc7b1bfec47 100644
--- a/eclass/python-any-r1.eclass
+++ b/eclass/python-any-r1.eclass
@@ -167,8 +167,7 @@ inherit python-utils-r1
 # @CODE
 
 _python_any_set_globals() {
-	local usestr deps i PYTHON_PKG_DEP
-	[[ ${PYTHON_REQ_USE} ]] && usestr="[${PYTHON_REQ_USE}]"
+	local deps i PYTHON_PKG_DEP
 
 	_python_set_impls
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-11-30 13:09 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-11-30 13:09 UTC (permalink / raw
  To: gentoo-commits
commit:     52a39b64a029c40995c6490a307f0c51e9897f2b
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Nov 30 12:49:09 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Nov 30 13:09:02 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=52a39b64
toolchain.eclass: move nvptx files to accel/ subdir
This is what Fedora does and it seems to have fixed the issue I was having
with needing to manually move libgomp.{a,spec} and then after that, getting
undefined references to gomp_nvptx_main (which I assume is because the plugin
wasn't being loaded).
Bug: https://bugs.gentoo.org/945296
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 18 ++++++++++++++++++
 1 file changed, 18 insertions(+)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index eac300438da5..d41d7c3737a1 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -2698,6 +2698,24 @@ gcc_movelibs() {
 		fix_libtool_libdir_paths "${LIBPATH}/${MULTIDIR}"
 	done
 
+	# Without this, we end up either unable to find the libgomp spec/archive, or
+	# we underlink and can't find gomp_nvptx_main (presumably because we can't find the plugin)
+	# https://src.fedoraproject.org/rpms/gcc/blob/02c34dfa3627ef05d676d30e152a66e77b58529b/f/gcc.spec#_1445
+	if [[ ${CTARGET} == nvptx* ]] && has_version ${CATEGORY}/${PN} ; then
+		rm -rf "${ED}"/usr/libexec/gcc/nvptx-none/${GCCMAJOR}/install-tools
+		rm -rf "${ED}"/usr/libexec/gcc/${CHOST}/${GCCMAJOR}/accel/nvptx-none/{install-tools,plugin,cc1,cc1plus,f951}
+		rm -rf "${ED}"/usr/lib/gcc/nvptx-none/${GCCMAJOR}/{install-tools,plugin}
+		rm -rf "${ED}"/usr/lib/gcc/${CHOST}/${GCCMAJOR}/accel/nvptx-none/{install-tools,plugin,include-fixed}
+		mv "${ED}"/usr/nvptx-none/lib/*.{a,spec} "${ED}"/usr/lib/gcc/${CHOST}/${GCCMAJOR}/accel/nvptx-none/
+		mv "${ED}"/usr/nvptx-none/lib/mgomp/*.{a,spec} "${ED}"/usr/lib/gcc/${CHOST}/${GCCMAJOR}/accel/nvptx-none/mgomp/
+		mv "${ED}"/usr/nvptx-none/lib/mptx-3.1/*.{a,spec} "${ED}"/usr/lib/gcc/${CHOST}/${GCCMAJOR}/accel/nvptx-none/mptx-3.1/
+		mv "${ED}"/usr/nvptx-none/lib/mgomp/mptx-3.1/*.{a,spec} "${ED}"/usr/lib/gcc/${CHOST}/${GCCMAJOR}/accel/nvptx-none/mgomp/mptx-3.1/
+		mv "${ED}"/usr/lib/gcc/nvptx-none/${GCCMAJOR}/*.a "${ED}"/usr/lib/gcc/${CHOST}/${GCCMAJOR}/accel/nvptx-none/ || die
+		mv "${ED}"/usr/lib/gcc/nvptx-none/${GCCMAJOR}/mgomp/*.a "${ED}"/usr/lib/gcc/${CHOST}/${GCCMAJOR}/accel/nvptx-none/mgomp/ || die
+		mv "${ED}"/usr/lib/gcc/nvptx-none/${GCCMAJOR}/mptx-3.1/*.a "${ED}"/usr/lib/gcc/${CHOST}/${GCCMAJOR}/accel/nvptx-none/mptx-3.1/ || die
+		mv "${ED}"/usr/lib/gcc/nvptx-none/${GCCMAJOR}/mgomp/mptx-3.1/*.a "${ED}"/usr/lib/gcc/${CHOST}/${GCCMAJOR}/accel/nvptx-none/mgomp/mptx-3.1/ || die
+	fi
+
 	# We remove directories separately to avoid this case:
 	#	mv SRC/lib/../lib/*.o DEST
 	#	rmdir SRC/lib/../lib/
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-11-30 14:36 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-11-30 14:36 UTC (permalink / raw
  To: gentoo-commits
commit:     407e8b720858c57c802614439242364d3cc630a3
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Nov 30 14:35:40 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Nov 30 14:35:40 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=407e8b72
toolchain.eclass: move more for nvptx
Bug: https://bugs.gentoo.org/945296
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 8 ++++----
 1 file changed, 4 insertions(+), 4 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index d41d7c3737a1..505e7c2666d7 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -2710,10 +2710,10 @@ gcc_movelibs() {
 		mv "${ED}"/usr/nvptx-none/lib/mgomp/*.{a,spec} "${ED}"/usr/lib/gcc/${CHOST}/${GCCMAJOR}/accel/nvptx-none/mgomp/
 		mv "${ED}"/usr/nvptx-none/lib/mptx-3.1/*.{a,spec} "${ED}"/usr/lib/gcc/${CHOST}/${GCCMAJOR}/accel/nvptx-none/mptx-3.1/
 		mv "${ED}"/usr/nvptx-none/lib/mgomp/mptx-3.1/*.{a,spec} "${ED}"/usr/lib/gcc/${CHOST}/${GCCMAJOR}/accel/nvptx-none/mgomp/mptx-3.1/
-		mv "${ED}"/usr/lib/gcc/nvptx-none/${GCCMAJOR}/*.a "${ED}"/usr/lib/gcc/${CHOST}/${GCCMAJOR}/accel/nvptx-none/ || die
-		mv "${ED}"/usr/lib/gcc/nvptx-none/${GCCMAJOR}/mgomp/*.a "${ED}"/usr/lib/gcc/${CHOST}/${GCCMAJOR}/accel/nvptx-none/mgomp/ || die
-		mv "${ED}"/usr/lib/gcc/nvptx-none/${GCCMAJOR}/mptx-3.1/*.a "${ED}"/usr/lib/gcc/${CHOST}/${GCCMAJOR}/accel/nvptx-none/mptx-3.1/ || die
-		mv "${ED}"/usr/lib/gcc/nvptx-none/${GCCMAJOR}/mgomp/mptx-3.1/*.a "${ED}"/usr/lib/gcc/${CHOST}/${GCCMAJOR}/accel/nvptx-none/mgomp/mptx-3.1/ || die
+		mv "${ED}"/usr/lib/gcc/nvptx-none/${GCCMAJOR}/*.{a,spec} "${ED}"/usr/lib/gcc/${CHOST}/${GCCMAJOR}/accel/nvptx-none/ || die
+		mv "${ED}"/usr/lib/gcc/nvptx-none/${GCCMAJOR}/mgomp/*.{a,spec} "${ED}"/usr/lib/gcc/${CHOST}/${GCCMAJOR}/accel/nvptx-none/mgomp/ || die
+		mv "${ED}"/usr/lib/gcc/nvptx-none/${GCCMAJOR}/mptx-3.1/*.{a,spec} "${ED}"/usr/lib/gcc/${CHOST}/${GCCMAJOR}/accel/nvptx-none/mptx-3.1/ || die
+		mv "${ED}"/usr/lib/gcc/nvptx-none/${GCCMAJOR}/mgomp/mptx-3.1/*.{a,spec} "${ED}"/usr/lib/gcc/${CHOST}/${GCCMAJOR}/accel/nvptx-none/mgomp/mptx-3.1/ || die
 	fi
 
 	# We remove directories separately to avoid this case:
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-01  8:53 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-12-01  8:53 UTC (permalink / raw
  To: gentoo-commits
commit:     5e374fdf18c2105783e812102f5721397c7a1649
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Dec  1 08:50:00 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Dec  1 08:51:47 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=5e374fdf
toolchain.eclass: add more mirrors to EGIT_REPO_URI
sourceware was down earlier, so add some mirrors.
sourcehut is an official mirror (albeit an experiment IIRC) by sourceware
and x86-gcc is run by H.J. Lu. gcc-mirror on github (which was in the
list already) looks like an automatic one but let's leave it last.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 7 ++++++-
 1 file changed, 6 insertions(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 505e7c2666d7..a546f80f766f 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -33,7 +33,12 @@ tc_is_live() {
 }
 
 if tc_is_live ; then
-	EGIT_REPO_URI="https://gcc.gnu.org/git/gcc.git https://github.com/gcc-mirror/gcc"
+	EGIT_REPO_URI="
+		https://gcc.gnu.org/git/gcc.git
+		https://git.sr.ht/~sourceware/gcc
+		https://gitlab.com/x86-gcc/gcc.git
+		https://github.com/gcc-mirror/gcc.git
+	"
 	# Naming style:
 	# gcc-10.1.0_pre9999 -> gcc-10-branch
 	#  Note that the micro version is required or lots of stuff will break.
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-01  9:25 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-12-01  9:25 UTC (permalink / raw
  To: gentoo-commits
commit:     60551c277310cdae29d2aeeeeb3b20448156d344
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Dec  1 09:24:54 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Dec  1 09:24:54 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=60551c27
rust.eclass: add rust-1.83.0
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/rust.eclass | 2 ++
 1 file changed, 2 insertions(+)
diff --git a/eclass/rust.eclass b/eclass/rust.eclass
index 450911ba2ea0..68983f688e42 100644
--- a/eclass/rust.eclass
+++ b/eclass/rust.eclass
@@ -67,6 +67,7 @@ fi
 # @DESCRIPTION:
 # Definitive list of Rust slots and the associated LLVM slot, newest first.
 declare -A -g -r _RUST_LLVM_MAP=(
+	["1.83.0"]=19
 	["1.82.0"]=19
 	["1.81.0"]=18
 	["1.80.1"]=18
@@ -84,6 +85,7 @@ declare -A -g -r _RUST_LLVM_MAP=(
 # While _RUST_LLVM_MAP stores useful info about the relationship between Rust and LLVM slots,
 # this array is used to store the Rust slots in a more convenient order for iteration.
 declare -a -g -r _RUST_SLOTS_ORDERED=(
+	"1.83.0"
 	"1.82.0"
 	"1.81.0"
 	"1.80.1"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread
* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-01 12:12 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-12-01 12:12 UTC (permalink / raw
  To: gentoo-commits
commit:     f18b12262d54db706be91f22c070c52294084007
Author:     Andrei Horodniceanu <a.horodniceanu <AT> proton <DOT> me>
AuthorDate: Thu Oct 17 15:08:40 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Dec  1 12:06:53 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=f18b1226
toolchain.eclass: refactor common ada and d bootstrap code
Additionally, when cross compiling only look for a bootstrap gcc that
matches the SLOT that is currently being built since both ada and d
would fail with any other version.
Also correct some CBUILD vs CHOST usage to support cross-compiling ada.
Signed-off-by: Andrei Horodniceanu <a.horodniceanu <AT> proton.me>
Closes: https://github.com/gentoo/gentoo/pull/39019
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 168 ++++++++++++++++++++++++++++++++----------------
 1 file changed, 112 insertions(+), 56 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index a546f80f766f..114a008b700f 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -852,19 +852,107 @@ setup_multilib_osdirnames() {
 	sed -i "${sed_args[@]}" "${S}"/gcc/config/${config} || die
 }
 
+# @FUNCTION: _get_bootstrap_gcc_info
+# @USAGE: [gcc_pkg|gcc_bin_base]...
+# @DESCRIPTION:
+# Get some information about the gcc that would be used to build this package.
+# All the variables that are passed as arguments will be set to their apropriate
+# values:
+#
+# - bootstrap_gcc_pkg = the ${CATEGORY}/${PN} that provides the build gcc
+#
+# - bootstrap_gcc_bin_base = the directory up to /gcc-bin but excluding the slot, of
+# the aformentioned package.
+_get_bootstrap_gcc_info() {
+	crossp() {
+		tc-is-cross-compiler && echo "${2}" || echo "${1}"
+	}
+
+	local arg
+	for arg ; do
+		case "${arg}" in
+			bootstrap_gcc_pkg)
+				bootstrap_gcc_pkg=$(crossp sys-devel/gcc cross-${CHOST}/gcc)
+				;;
+			bootstrap_gcc_bin_base)
+				bootstrap_gcc_bin_base=${BROOT}/usr/$(crossp ${CHOST} ${CBUILD}/${CHOST})/gcc-bin
+				;;
+			*)
+				die "Unknown argument '${arg}' passed to ${FUNCNAME}"
+		esac
+	done
+}
+
+# @FUNCTION: _find_bootstrap_gcc_with
+# @USAGE: <use_expression> <pretty_use_name> <minimum_slot>
+# @RETURN: Shell true if a matching gcc installation was found, false otherwise
+# @INTERNAL
+# @DESCRIPTION:
+# Check installed versions of gcc that can be used as a compiler for the current
+# build for one matching a certain USE expression.  The order of preference is
+# checking for the same SLOT we are building, then iterate downwards until (and
+# including) minimum_slot, then iterate upward starting with SLOT+1.  When
+# cross-compiling only SLOT is checked.
+#
+# If a proper installation is discovered this function will set
+# ${bootstrap_gcc_bin_dir} to the full path of the directory in which
+# ${CHOST}-gcc and friends are found and ${bootstrap_gcc_slot} to the slot that
+# was found.  If nothing was found those variables will be empty.
+#
+# This function is provided to aid languages like ada and d that require
+# bootstraping.
+_find_bootstrap_gcc_with() {
+	local use="${1}"
+	local pretty_use="${2}"
+	local bootstrap_gcc_pkg bootstrap_gcc_bin_base
+	_get_bootstrap_gcc_info bootstrap_gcc_pkg bootstrap_gcc_bin_base
+
+	local min_slot max_slot
+	if tc-is-cross-compiler ; then
+		min_slot="${SLOT}"
+		max_slot="${SLOT}"
+	else
+		min_slot="${3}"
+		max_slot=$(best_version -b "${bootstrap_gcc_pkg}")
+		max_slot="${max_slot#${bootstrap_gcc_pkg}-}"
+		max_slot=$(ver_cut 1 ${max_slot})
+	fi
+
+	local candidate result
+	for candidate in ${SLOT} $(seq $((${SLOT} - 1)) -1 ${min_slot}) $(seq $((${SLOT} + 1)) ${max_slot}) ; do
+		has_version -b "${bootstrap_gcc_pkg}:${candidate}" || continue
+
+		ebegin "Testing ${bootstrap_gcc_pkg}:${candidate} for ${pretty_use}"
+		if has_version -b "${bootstrap_gcc_pkg}:${candidate}${use}" ; then
+			result=${candidate}
+
+			eend 0
+			break
+		fi
+		eend 1
+	done
+
+	if [[ ${result} ]] ; then
+		bootstrap_gcc_bin_dir="${bootstrap_gcc_bin_base}/${result}"
+		bootstrap_gcc_slot=${result}
+		return 0
+	else
+		bootstrap_gcc_bin_dir=
+		bootstrap_gcc_slot=
+		return 1
+	fi
+}
+
 # @FUNCTION: toolchain_setup_ada
 # @INTERNAL
 # @DESCRIPTION:
 # Determine the most suitable GNAT (Ada compiler) for bootstrapping
 # and setup the environment, including wrappers, for building.
 toolchain_setup_ada() {
-	local latest_gcc=$(best_version -b "sys-devel/gcc")
-	latest_gcc="${latest_gcc#sys-devel/gcc-}"
-	latest_gcc=$(ver_cut 1 ${latest_gcc})
-
 	local ada_bootstrap
 	local ada_candidate
 	local ada_bootstrap_type
+	local ada_bootstrap_bin_dir
 	# GNAT can usually be built using the last major version and
 	# the current version, at least.
 	#
@@ -872,19 +960,12 @@ toolchain_setup_ada() {
 	# 1) Match the version being built;
 	# 2) Iterate downwards from the version being built;
 	# 3) Iterate upwards from the version being built to the greatest version installed.
-	for ada_candidate in ${SLOT} $(seq $((${SLOT} - 1)) -1 10) $(seq $((${SLOT} + 1)) ${latest_gcc}) ; do
-		has_version -b "sys-devel/gcc:${ada_candidate}" || continue
-
-		ebegin "Testing sys-devel/gcc:${ada_candidate} for Ada"
-		if has_version -b "sys-devel/gcc:${ada_candidate}[ada(-)]" ; then
-			ada_bootstrap=${ada_candidate}
-			ada_bootstrap_type=gcc
-
-			eend 0
-			break
-		fi
-		eend 1
-	done
+	local bootstrap_gcc_slot bootstrap_gcc_bin_dir
+	if _find_bootstrap_gcc_with "[ada(-)]" "Ada" 10 ; then
+		ada_bootstrap=${bootstrap_gcc_slot}
+		ada_bootstrap_type=gcc
+		ada_bootstrap_bin_dir="${bootstrap_gcc_bin_dir}"
+	fi
 
 	# As a penultimate resort, try dev-lang/ada-bootstrap.
 	if ver_test ${ada_bootstrap} -gt ${PV} || [[ -z ${ada_bootstrap} ]] ; then
@@ -897,6 +978,7 @@ toolchain_setup_ada() {
 			#latest_ada_bootstrap=$(ver_cut 1 ${latest_ada_bootstrap})
 			ada_bootstrap="10"
 			ada_bootstrap_type=ada-bootstrap
+			ada_bootstrap_bin_dir="${BROOT}/usr/lib/ada-bootstrap/bin"
 
 			eend 0
 		else
@@ -910,6 +992,7 @@ toolchain_setup_ada() {
 		if has_version -b "dev-lang/gnat-gpl" ; then
 			ada_bootstrap=10
 			ada_bootstrap_type=gcc
+			ada_bootstrap_bin_dir="${BROOT}/usr/${CHOST}/gcc-bin/${ada_bootstrap}"
 			eend 0
 		else
 			eend 1
@@ -974,10 +1057,10 @@ toolchain_setup_ada() {
 	case ${ada_bootstrap_type} in
 		ada-bootstrap)
 			export PATH="${BROOT}/usr/lib/ada-bootstrap/bin:${PATH}"
-			gnat1_path=${BROOT}/usr/lib/ada-bootstrap/libexec/gcc/${CBUILD}/${ada_bootstrap}/gnat1
+			gnat1_path=${BROOT}/usr/lib/ada-bootstrap/libexec/gcc/${CHOST}/${ada_bootstrap}/gnat1
 			;;
 		*)
-			gnat1_path=${BROOT}/usr/libexec/gcc/${CBUILD}/${ada_bootstrap}/gnat1
+			gnat1_path=${BROOT}/usr/libexec/gcc/${CHOST}/${ada_bootstrap}/gnat1
 			;;
 	esac
 
@@ -994,7 +1077,7 @@ toolchain_setup_ada() {
 	# work for us as the stage1 compiler doesn't necessarily have Ada
 	# support. Substitute the Ada compiler we found earlier.
 	local adalib
-	adalib=$(${CBUILD}-gcc-${ada_bootstrap} -print-libgcc-file-name || die "Finding adalib dir failed")
+	adalib=$("${ada_bootstrap_bin_dir}"/${CHOST}-gcc -print-libgcc-file-name || die "Finding adalib dir failed")
 	adalib="${adalib%/*}/adalib"
 	sed -i \
 		-e "s:adalib=.*:adalib=${adalib}:" \
@@ -1007,7 +1090,7 @@ toolchain_setup_ada() {
 	for tool in gnat{,bind,chop,clean,kr,link,ls,make,name,prep} ; do
 		cat <<-EOF > "${T}"/ada-wrappers/${tool} || die
 		#!/bin/sh
-		exec $(type -P ${CBUILD}-${tool}-${ada_bootstrap}) "\$@"
+		exec "${ada_bootstrap_bin_dir}"/${CHOST}-${tool} "\$@"
 		EOF
 
 		export "${tool^^}"="${T}"/ada-wrappers/${tool}
@@ -1024,47 +1107,20 @@ toolchain_setup_ada() {
 # Determine the most suitable GDC (D compiler) for bootstrapping
 # and setup the environment for building.
 toolchain_setup_d() {
-	local gcc_pkg gcc_bin_base
-	if tc-is-cross-compiler ; then
-		gcc_pkg=cross-${CHOST}/gcc
-		gcc_bin_base=${BROOT}/usr/${CBUILD}/${CHOST}/gcc-bin
-	else
-		gcc_pkg=sys-devel/gcc
-		gcc_bin_base=${BROOT}/usr/${CHOST}/gcc-bin
-	fi
-
-	local latest_gcc=$(best_version -b "${gcc_pkg}")
-	latest_gcc="${latest_gcc#${gcc_pkg}-}"
-	latest_gcc=$(ver_cut 1 ${latest_gcc})
-
-	local d_bootstrap
-	local d_candidate
-	# Order of preference (descending):
-	# 1) Match the version being built;
-	# 2) Iterate downwards from the version being built;
-	# 3) Iterate upwards from the version being built to the greatest version installed.
-	for d_candidate in ${SLOT} $(seq $((${SLOT} - 1)) -1 10) $(seq $((${SLOT} + 1)) ${latest_gcc}) ; do
-		has_version -b "${gcc_pkg}:${d_candidate}" || continue
-
-		ebegin "Testing ${gcc_pkg}:${d_candidate} for D"
-		if has_version -b "${gcc_pkg}:${d_candidate}[d(-)]" ; then
-			d_bootstrap=${d_candidate}
-
-			eend 0
-			break
-		fi
-		eend 1
-	done
+	local bootstrap_gcc_slot bootstrap_gcc_bin_dir
+	_find_bootstrap_gcc_with "[d(-)]" "D" 11
 
-	if [[ -z ${d_bootstrap} ]] ; then
+	if [[ -z ${bootstrap_gcc_bin_dir} ]] ; then
 		if tc-is-cross-compiler ; then
 			# We can't add cross-${CHOST}/gcc[d] to BDEPEND but we can
 			# print a useful message to the user.
-			eerror "No ${gcc_pkg}[d] was found installed."
+			local bootstrap_gcc_pkg
+			_get_bootstrap_gcc_info bootstrap_gcc_pkg
+			eerror "No ${bootstrap_gcc_pkg}[d] was found installed."
 			eerror "When cross-compiling GDC a bootstrap GDC is required."
 			eerror "Either disable the d USE flag or add:"
 			eerror ""
-			eerror "    ${gcc_pkg} d"
+			eerror "    ${bootstrap_gcc_pkg} d"
 			eerror ""
 			eerror "In your package.use and re-emerge it."
 			eerror ""
@@ -1073,7 +1129,7 @@ toolchain_setup_d() {
 		die "Did not find any appropriate GDC compiler installed"
 	fi
 
-	export GDC=${gcc_bin_base}/${d_bootstrap}/${CHOST}-gdc
+	export GDC=${bootstrap_gcc_bin_dir}/${CHOST}-gdc
 }
 
 #---->> src_configure <<----
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-02  8:46 Matt Jolly
  0 siblings, 0 replies; 6663+ messages in thread
From: Matt Jolly @ 2024-12-02  8:46 UTC (permalink / raw
  To: gentoo-commits
commit:     12a24a054fb00f9b7706348b0b2de3f2f85e0b54
Author:     Matt Jolly <kangie <AT> gentoo <DOT> org>
AuthorDate: Thu Nov 21 14:08:40 2024 +0000
Commit:     Matt Jolly <kangie <AT> gentoo <DOT> org>
CommitDate: Mon Dec  2 07:54:17 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=12a24a05
cargo.eclass: add trivial crate overrides
Updating vulnerable (or otherwise outdated) crates in Rust ebuilds
is painful. Generally speaking, there are 5 options:
- Run `cargo update` to fetch new versions from the web.
  This is obviously not suitable for use in Portage.
- Patch the software via Portage to accept a non-vulnerable crate.
  This is a reasonable option when the package is not too complex
  but still requires significant developer effort and some familiarity
  with Cargo. In the case of complex patches this may not be feasible,
  or require the generation of a dependency tarball.
- [patch] the source (repository) in Cargo.toml. This enables the
  targeting of specific crates, but does not allow the replacement
  of only a specific version in the depgraph.
- [replace] a particular crate:version in the Cargo.toml. This
  enables the targeting of a particular version with an arbitrary
  path however the replacement crate must *have the same version*
  as the one being overridden.
- `paths = [...]` overrides: pass an array of paths to directories that
  contain a Cargo.toml. Cargo will override any crate with the same package name
  arbitrarily, ignoring the lock file and versions; typically used for testing.
  Is applied via ${CARGO_HOME}/config.toml (i.e. globally)
This commit:
- Implements the `paths` overrides, which will work even when
  Cargo is configured to use a vendored directory. This is not a 'smart'
  replacement and care must be taken to ensure that all versions of
  the crate in use are compatible (`cargo tree` will help).
- Provides a helper which runs `cargo --update --offline` against
  ${ECARGO_VENDOR} (where ${CRATES} are unpacked). This enables the
  replacement of vulnerable versions in ${CRATES}. It is up to the
  consumer to ensure that only the desired crates are being replaced
  and that package behaviour does not change.
Resources:
- https://doc.rust-lang.org/cargo/reference/overriding-dependencies.html
- https://github.com/rust-lang/cargo/issues/3308
Signed-off-by: Matt Jolly <kangie <AT> gentoo.org>
 eclass/cargo.eclass | 94 +++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 file changed, 94 insertions(+)
diff --git a/eclass/cargo.eclass b/eclass/cargo.eclass
index 5a3820267544..02b048732f7f 100644
--- a/eclass/cargo.eclass
+++ b/eclass/cargo.eclass
@@ -7,6 +7,7 @@
 # @AUTHOR:
 # Doug Goldstein <cardoe@gentoo.org>
 # Georgy Yakovlev <gyakovlev@gentoo.org>
+# Matt Jolly <kangie@gentoo.org>
 # @SUPPORTED_EAPIS: 8
 # @PROVIDES: rust
 # @BLURB: common functions and variables for cargo builds
@@ -51,6 +52,10 @@ case ${EAPI} in
 		;;
 esac
 
+if [[ -n ${CRATE_PATHS_OVERRIDE} ]]; then
+	CRATES="${CRATES} ${CRATE_PATHS_OVERRIDE}"
+fi
+
 inherit flag-o-matic multiprocessing rust rust-toolchain toolchain-funcs
 
 IUSE="${IUSE} debug"
@@ -81,6 +86,41 @@ ECARGO_VENDOR="${ECARGO_HOME}/gentoo"
 # SRC_URI="${CARGO_CRATE_URIS}"
 # @CODE
 
+# @ECLASS_VARIABLE: CRATE_PATHS_OVERRIDE
+# @DEFAULT_UNSET
+# @PRE_INHERIT
+# @DESCRIPTION:
+# Bash string containing crates that will be used to override
+# dependencies via generated `paths = ['/path/to/crate']` configuration.
+# This is not "smart", _all crates_ which match the `Cargo.toml`
+# for a given crate/path will be overridden, ignoring lockfiles,
+# version constraints, etc.
+#
+# This should be used as a last resort where (e.g.) you are
+# bootstrapping Rust and need to override a vendored crate
+# with a newer version, and all versions in use are compatible.
+#
+# Crate names and versions must be separated by a `@`;
+# multiple crates are separated by a space or newline.
+# Crates in CRATE_PATHS_OVERRIDE are implicitly added to CRATES;
+# they do not need to be listed.
+#
+# Example:
+# @CODE
+# CRATES="
+# 	foo@1.2.3
+# "
+#
+# CRATE_PATHS_OVERRIDE="
+# 	openssl@0.10.35
+# 	openssl-sys@0.9.65
+# "
+#
+# inherit cargo
+# ...
+# SRC_URI="${CARGO_CRATE_URIS}"
+# @CODE
+
 # @ECLASS_VARIABLE: GIT_CRATES
 # @DEFAULT_UNSET
 # @PRE_INHERIT
@@ -277,6 +317,26 @@ cargo_crate_uris() {
 	echo "${CARGO_CRATE_URIS}"
 }
 
+# @FUNCTION: _cargo_gen_override_paths_config
+# @INTERNAL
+# @DESCRIPTION:
+# Generate the TOML content for overriding crates globally using the package manager.
+# This is called from within cargo_gen_config to insert the appropriate snippet
+# into the generated config.toml. Does not support git crates.
+_cargo_gen_override_paths_config() {
+	if [[ ! ${#CRATE_PATHS_OVERRIDE[@]} -gt 0 ]]; then
+		return
+	fi
+	local content override path
+	content=( 'paths = [' )
+	for override in ${CRATE_PATHS_OVERRIDE}; do
+		local path="${ECARGO_VENDOR}/${override//@/-}"
+		content+=( "'${path}'," )
+	done
+	content+=( ']' )
+	printf "%s\n" "${content[@]}"
+}
+
 # @FUNCTION: cargo_gen_config
 # @DESCRIPTION:
 # Generate the $CARGO_HOME/config.toml necessary to use our local registry and settings.
@@ -293,6 +353,8 @@ cargo_gen_config() {
 	mkdir -p "${ECARGO_HOME}" || die
 
 	cat > "${ECARGO_HOME}/config.toml" <<- _EOF_ || die "Failed to create cargo config"
+	$(_cargo_gen_override_paths_config)
+
 	[source.gentoo]
 	directory = "${ECARGO_VENDOR}"
 
@@ -311,6 +373,7 @@ cargo_gen_config() {
 	verbose = true
 	$([[ "${NOCOLOR}" = true || "${NOCOLOR}" = yes ]] && echo "color = 'never'")
 	$(_cargo_gen_git_config)
+
 	_EOF_
 
 	export CARGO_HOME="${ECARGO_HOME}"
@@ -358,6 +421,37 @@ cargo_target_dir() {
 	echo "${CARGO_TARGET_DIR:-target}/$(rust_abi)/$(usex debug debug release)"
 }
 
+# @FUNCTION: cargo_update_crates
+# @USAGE:
+# @DESCRIPTION:
+# Helper function to call `cargo update --offline` with the given Cargo.toml.
+# This will update Cargo.{toml,lock}. This should provide a straightforward
+# approach to updating vulnerable crates in a package.
+#
+# To use: replace any vulnerable crates in ${CRATES} with updated (and compatible)
+# versions, then call `cargo_update_crates` in src_prepare. If Cargo.toml is not
+# in the root of ${S}, pass the path to the Cargo.toml as the first argument.
+# It is up to the ebuild to ensure that the updated crates are compatible with the
+# package and that no unexpected breakage occurs.
+cargo_update_crates () {
+	debug-print-function ${FUNCNAME} "$@"
+
+	if [[ -z ${CARGO} ]]; then
+		die "CARGO is not set; was rust_pkg_setup run?"
+	fi
+
+	local path=${1:-"${S}/Cargo.toml"}
+	if [[ $# -gt 1 ]]; then
+		die "Usage: cargo_update_crates [path_to_Cargo.toml]"
+	fi
+	[[ -f ${path} ]] || die "${path} does not exist"
+
+	set -- "${CARGO}" update --offline --manifest-path "${path}"
+	einfo "${@}"
+	# This is overkill (we're not using rustflags (etc) here) but it's safe.
+	cargo_env "${@}" || die "Failed to update crates"
+}
+
 # @FUNCTION: cargo_src_unpack
 # @DESCRIPTION:
 # Unpacks the package and the cargo registry.
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-02  8:46 Matt Jolly
  0 siblings, 0 replies; 6663+ messages in thread
From: Matt Jolly @ 2024-12-02  8:46 UTC (permalink / raw
  To: gentoo-commits
commit:     e13b0ea6d4432745d9275d98fdb7ee36cd62ac8f
Author:     Matt Jolly <kangie <AT> gentoo <DOT> org>
AuthorDate: Mon Nov 25 12:40:51 2024 +0000
Commit:     Matt Jolly <kangie <AT> gentoo <DOT> org>
CommitDate: Mon Dec  2 07:54:17 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=e13b0ea6
cargo.eclass: add ${CARGO_BOOTSTRAP}
This variable enables ebuilds to tell the eclass to ignore
the minimum Rust/Cargo version reqirement. It is intended
for use when bootstrapping older Rust, consumers who are
not dev-lang/rust should have a good reason for using this.
Signed-off-by: Matt Jolly <kangie <AT> gentoo.org>
 eclass/cargo.eclass | 16 ++++++++++++++--
 1 file changed, 14 insertions(+), 2 deletions(-)
diff --git a/eclass/cargo.eclass b/eclass/cargo.eclass
index 95ff317e1f21..5a3820267544 100644
--- a/eclass/cargo.eclass
+++ b/eclass/cargo.eclass
@@ -30,6 +30,9 @@ fi
 # Either the lowest slot supported by rust.eclass _or_
 # reference the changelog for a particular feature requirement
 # https://github.com/rust-lang/cargo/blob/master/CHANGELOG.md
+# For reference the actual minimum version of cargo that can be used
+# is 1.53.0 for `cargo update --offline`; updated to 1.71.1 with rust eclass.
+# No need to enable usage of legacy rust versions in ebuilds; keep it as-is.
 _CARGO_ECLASS_RUST_MIN_VER="1.71.1"
 
 case ${EAPI} in
@@ -37,8 +40,10 @@ case ${EAPI} in
 		if [[ -n ${RUST_MIN_VER} ]]; then
 			# This is _very_ unlikely given that we leverage the rust eclass but just in case cargo requires a newer version
 			# than the oldest in-tree in future.
-			if ver_test "${RUST_MIN_VER}" -lt "${_CARGO_ECLASS_RUST_MIN_VER}"; then
-				die "RUST_MIN_VERSION must be at least ${_CARGO_ECLASS_RUST_MIN_VER}"
+			if [[ -z ${CARGO_BOOTSTRAP} ]]; then
+				if ver_test "${RUST_MIN_VER}" -lt "${_CARGO_ECLASS_RUST_MIN_VER}"; then
+					die "RUST_MIN_VERSION must be at least ${_CARGO_ECLASS_RUST_MIN_VER}"
+				fi
 			fi
 		else
 			RUST_MIN_VER="${_CARGO_ECLASS_RUST_MIN_VER}"
@@ -109,6 +114,13 @@ ECARGO_VENDOR="${ECARGO_HOME}/gentoo"
 # )
 # @CODE
 
+# @ECLASS_VARIABLE: CARGO_BOOTSTRAP
+# @DEFAULT_UNSET
+# @PRE_INHERIT
+# @DESCRIPTION:
+# Ignore `_CARGO_ECLASS_RUST_MIN_VER` checks.
+# If you aren't bootstrapping Rust you probably don't need this.
+
 # @ECLASS_VARIABLE: CARGO_OPTIONAL
 # @DEFAULT_UNSET
 # @PRE_INHERIT
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-04 11:33 Matt Jolly
  0 siblings, 0 replies; 6663+ messages in thread
From: Matt Jolly @ 2024-12-04 11:33 UTC (permalink / raw
  To: gentoo-commits
commit:     4ff6bf33c94566b2acc07b75712094d567c77fc9
Author:     Matt Jolly <kangie <AT> gentoo <DOT> org>
AuthorDate: Tue Dec  3 12:06:30 2024 +0000
Commit:     Matt Jolly <kangie <AT> gentoo <DOT> org>
CommitDate: Wed Dec  4 11:30:31 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=4ff6bf33
rust.eclass: add ERUST_{SLOT,TYPE} user variables
These variables enable users (though most likely Gentoo developers)
to override the selection of the Rust implementation by the eclass.
This means that _only_ the specified ERUST_SLOT and/or ERUST_TYPE
('source' or 'binary') will be checked for, with the eclass `die`ing
with "No Rust slot satisfying the package's dependencies..." if the
selected impl is not available.
These variables are intended to enable reproducing bugs and testing
packages against specific dev-lang/rust{,-bin} packages; they must
not be set in ebuilds.
Closes: https://bugs.gentoo.org/945752
Signed-off-by: Matt Jolly <kangie <AT> gentoo.org>
 eclass/rust.eclass | 49 ++++++++++++++++++++++++++++++++++++++++++++-----
 1 file changed, 44 insertions(+), 5 deletions(-)
diff --git a/eclass/rust.eclass b/eclass/rust.eclass
index 71cbb4b24f8c..991a9cdb7f14 100644
--- a/eclass/rust.eclass
+++ b/eclass/rust.eclass
@@ -98,6 +98,26 @@ declare -a -g -r _RUST_SLOTS_ORDERED=(
 	"1.54.0"
 )
 
+# == user control knobs ==
+
+# @ECLASS_VARIABLE: ERUST_SLOT
+# @USER_VARIABLE
+# @DESCRIPTION:
+# Specify the version (slot) of Rust to be used by the package. This is
+# useful for troubleshooting and debugging purposes; If unset, the newest
+# acceptable Rust version will be used. May be combined with ERUST_TYPE.
+# This variable must not be set in ebuilds.
+
+# @ECLASS_VARIABLE: ERUST_TYPE
+# @USER_VARIABLE
+# @DESCRIPTION:
+# Specify the type of Rust to be used by the package from options:
+# 'source' or 'binary' (-bin). This is useful for troubleshooting and
+# debugging purposes. If unset, the standard eclass logic will be used
+# to determine the type of Rust to use (i.e. prefer source if binary
+# is also available). May be combined with ERUST_SLOT.
+# This variable must not be set in ebuilds.
+
 # == control variables ==
 
 # @ECLASS_VARIABLE: RUST_MAX_VER
@@ -332,6 +352,10 @@ _get_rust_slot() {
 			fi
 		fi
 
+		if [[ -n "${ERUST_SLOT}" && "${slot}" != "${ERUST_SLOT}" ]]; then
+			continue
+		fi
+
 		# If we're in LLVM mode we can skip any slots that don't match the selected USE
 		if [[ -n "${RUST_NEEDS_LLVM}" ]]; then
 			if [[ "${llvm_slot}" != "${llvm_r1_slot}" ]]; then
@@ -345,12 +369,27 @@ _get_rust_slot() {
 			rust_check_deps && return
 		else
 			local usedep="${RUST_REQ_USE+[${RUST_REQ_USE}]}"
-			# When checking for installed packages prefer the non `-bin` package
+			# When checking for installed packages prefer the source package;
 			# if effort was put into building it we should use it.
-			local rust_pkgs=(
-				"dev-lang/rust:${slot}${usedep}"
-				"dev-lang/rust-bin:${slot}${usedep}"
-			)
+			local rust_pkgs
+			case "${ERUST_TYPE}" in
+				source)
+					rust_pkgs=(
+						"dev-lang/rust:${slot}${usedep}"
+					)
+					;;
+				binary)
+					rust_pkgs=(
+						"dev-lang/rust-bin:${slot}${usedep}"
+					)
+					;;
+				*)
+					rust_pkgs=(
+						"dev-lang/rust:${slot}${usedep}"
+						"dev-lang/rust-bin:${slot}${usedep}"
+					)
+					;;
+			esac
 			local _pkg
 			for _pkg in "${rust_pkgs[@]}"; do
 				if has_version "${hv_switch}" "${_pkg}"; then
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-04 11:34 Matt Jolly
  0 siblings, 0 replies; 6663+ messages in thread
From: Matt Jolly @ 2024-12-04 11:34 UTC (permalink / raw
  To: gentoo-commits
commit:     7687cc69cda0158af53edae6d89944653760dea9
Author:     Matt Jolly <kangie <AT> gentoo <DOT> org>
AuthorDate: Wed Dec  4 11:34:01 2024 +0000
Commit:     Matt Jolly <kangie <AT> gentoo <DOT> org>
CommitDate: Wed Dec  4 11:34:01 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=7687cc69
Revert "rust.eclass: add ERUST_{SLOT,TYPE} user variables"
This reverts commit 4ff6bf33c94566b2acc07b75712094d567c77fc9.
My branch was dirty, this is still under review.
Signed-off-by: Matt Jolly <kangie <AT> gentoo.org>
 eclass/rust.eclass | 49 +++++--------------------------------------------
 1 file changed, 5 insertions(+), 44 deletions(-)
diff --git a/eclass/rust.eclass b/eclass/rust.eclass
index 991a9cdb7f14..71cbb4b24f8c 100644
--- a/eclass/rust.eclass
+++ b/eclass/rust.eclass
@@ -98,26 +98,6 @@ declare -a -g -r _RUST_SLOTS_ORDERED=(
 	"1.54.0"
 )
 
-# == user control knobs ==
-
-# @ECLASS_VARIABLE: ERUST_SLOT
-# @USER_VARIABLE
-# @DESCRIPTION:
-# Specify the version (slot) of Rust to be used by the package. This is
-# useful for troubleshooting and debugging purposes; If unset, the newest
-# acceptable Rust version will be used. May be combined with ERUST_TYPE.
-# This variable must not be set in ebuilds.
-
-# @ECLASS_VARIABLE: ERUST_TYPE
-# @USER_VARIABLE
-# @DESCRIPTION:
-# Specify the type of Rust to be used by the package from options:
-# 'source' or 'binary' (-bin). This is useful for troubleshooting and
-# debugging purposes. If unset, the standard eclass logic will be used
-# to determine the type of Rust to use (i.e. prefer source if binary
-# is also available). May be combined with ERUST_SLOT.
-# This variable must not be set in ebuilds.
-
 # == control variables ==
 
 # @ECLASS_VARIABLE: RUST_MAX_VER
@@ -352,10 +332,6 @@ _get_rust_slot() {
 			fi
 		fi
 
-		if [[ -n "${ERUST_SLOT}" && "${slot}" != "${ERUST_SLOT}" ]]; then
-			continue
-		fi
-
 		# If we're in LLVM mode we can skip any slots that don't match the selected USE
 		if [[ -n "${RUST_NEEDS_LLVM}" ]]; then
 			if [[ "${llvm_slot}" != "${llvm_r1_slot}" ]]; then
@@ -369,27 +345,12 @@ _get_rust_slot() {
 			rust_check_deps && return
 		else
 			local usedep="${RUST_REQ_USE+[${RUST_REQ_USE}]}"
-			# When checking for installed packages prefer the source package;
+			# When checking for installed packages prefer the non `-bin` package
 			# if effort was put into building it we should use it.
-			local rust_pkgs
-			case "${ERUST_TYPE}" in
-				source)
-					rust_pkgs=(
-						"dev-lang/rust:${slot}${usedep}"
-					)
-					;;
-				binary)
-					rust_pkgs=(
-						"dev-lang/rust-bin:${slot}${usedep}"
-					)
-					;;
-				*)
-					rust_pkgs=(
-						"dev-lang/rust:${slot}${usedep}"
-						"dev-lang/rust-bin:${slot}${usedep}"
-					)
-					;;
-			esac
+			local rust_pkgs=(
+				"dev-lang/rust:${slot}${usedep}"
+				"dev-lang/rust-bin:${slot}${usedep}"
+			)
 			local _pkg
 			for _pkg in "${rust_pkgs[@]}"; do
 				if has_version "${hv_switch}" "${_pkg}"; then
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-06  5:10 Ionen Wolkens
  0 siblings, 0 replies; 6663+ messages in thread
From: Ionen Wolkens @ 2024-12-06  5:10 UTC (permalink / raw
  To: gentoo-commits
commit:     81c8ffec6e3f587993081be4d64cda604f6aa61d
Author:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
AuthorDate: Fri Dec  6 04:21:58 2024 +0000
Commit:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
CommitDate: Fri Dec  6 05:10:08 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=81c8ffec
linux-mod-r1.eclass: pass COMPRESS_ALL= in MAKEARGS usable in >=6.12
Technically a no-op so quick-adding without review. It could mean
something if the kernel adds new compression methods in the future
(_ALL ensures everything is disabled rather than have to list each
of them, which is what we want there).
When the day comes when we drop support for <=6.12 kernels or the
change was backported (if ever) for long enough, we could cleanup
passing COMRESS_GZIP/XZ/ZSTD there and only keep _ALL.
Signed-off-by: Ionen Wolkens <ionen <AT> gentoo.org>
 eclass/linux-mod-r1.eclass | 3 ++-
 1 file changed, 2 insertions(+), 1 deletion(-)
diff --git a/eclass/linux-mod-r1.eclass b/eclass/linux-mod-r1.eclass
index f8a45c607dfd..4e5b17548b04 100644
--- a/eclass/linux-mod-r1.eclass
+++ b/eclass/linux-mod-r1.eclass
@@ -1263,7 +1263,8 @@ _modules_set_makeargs() {
 		# these are only needed if using these arguments for installing, lets
 		# eclass handle strip, sign, compress, and depmod (CONFIG_ should
 		# have no impact on building, only used by Makefile.modinst)
-		CONFIG_MODULE_{SIG_ALL,COMPRESS_{GZIP,XZ,ZSTD}}=
+		# note: COMPRESS_ALL is enough for kernel >=6.12, rest is for compat
+		CONFIG_MODULE_{SIG_ALL,COMPRESS_{ALL,GZIP,XZ,ZSTD}}=
 		DEPMOD=true #916587
 		STRIP=true
 	)
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-06  7:43 Miroslav Šulc
  0 siblings, 0 replies; 6663+ messages in thread
From: Miroslav Šulc @ 2024-12-06  7:43 UTC (permalink / raw
  To: gentoo-commits
commit:     449449afcca0e9f34e76aecf0deee9efdb2fc267
Author:     Volkmar W. Pogatzki <gentoo <AT> pogatzki <DOT> net>
AuthorDate: Fri Nov 22 08:45:05 2024 +0000
Commit:     Miroslav Šulc <fordfrog <AT> gentoo <DOT> org>
CommitDate: Fri Dec  6 07:43:14 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=449449af
java-utils-2.eclass: remove unused and undocumented functions
removes the undocumented eclass functions:
- java-pkg_jar-list
- increment-qa-violations
Signed-off-by: Volkmar W. Pogatzki <gentoo <AT> pogatzki.net>
Closes: https://github.com/gentoo/gentoo/pull/39233/commits/5792412f99de65ec392f765cd4bd3585b53bb8fe
Signed-off-by: Miroslav Šulc <fordfrog <AT> gentoo.org>
 eclass/java-utils-2.eclass | 23 -----------------------
 1 file changed, 23 deletions(-)
diff --git a/eclass/java-utils-2.eclass b/eclass/java-utils-2.eclass
index 00ae7f790e08..5874f6ba8665 100644
--- a/eclass/java-utils-2.eclass
+++ b/eclass/java-utils-2.eclass
@@ -253,9 +253,6 @@ JAVA_PKG_COMPILERS_CONF=${JAVA_PKG_COMPILERS_CONF:="/etc/java-config-2/build/com
 #	)
 # @CODE
 
-# TODO document me
-JAVA_PKG_QA_VIOLATIONS=0
-
 # @FUNCTION: java-pkg_doexamples
 # @USAGE: [--subdir <subdir>] <file1/dir1> [<file2> ...]
 # @DESCRIPTION:
@@ -2784,19 +2781,6 @@ java-pkg_die() {
 }
 
 
-# TODO document
-# List jars in the source directory, ${S}
-java-pkg_jar-list() {
-	if [[ -n "${JAVA_PKG_DEBUG}" ]]; then
-		einfo "Linked Jars"
-		find "${S}" -type l -name '*.jar' -print0 | xargs -0 -r -n 500 ls -ald | sed -e "s,${WORKDIR},\${WORKDIR},"
-		einfo "Jars"
-		find "${S}" -type f -name '*.jar' -print0 | xargs -0 -r -n 500 ls -ald | sed -e "s,${WORKDIR},\${WORKDIR},"
-		einfo "Classes"
-		find "${S}" -type f -name '*.class' -print0 | xargs -0 -r -n 500 ls -ald | sed -e "s,${WORKDIR},\${WORKDIR},"
-	fi
-}
-
 # @FUNCTION: java-pkg_verify-classes
 # @INTERNAL
 # @DESCRIPTION:
@@ -2958,16 +2942,9 @@ java-pkg_announce-qa-violation() {
 		nodie="true"
 		shift
 	fi
-	echo "Java QA Notice: $@" >&2
-	increment-qa-violations
 	[[ -z "${nodie}" ]] && is-java-strict && die "${@}"
 }
 
-increment-qa-violations() {
-	let "JAVA_PKG_QA_VIOLATIONS+=1"
-	export JAVA_PKG_QA_VIOLATIONS
-}
-
 # @FUNCTION: is-java-strict
 # @INTERNAL
 # @RETURN: 0: JAVA_PKG_STRICT is set
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-06  7:43 Miroslav Šulc
  0 siblings, 0 replies; 6663+ messages in thread
From: Miroslav Šulc @ 2024-12-06  7:43 UTC (permalink / raw
  To: gentoo-commits
commit:     064e2f7c7eba7d780f062329fcd363bf3ececa23
Author:     Volkmar W. Pogatzki <gentoo <AT> pogatzki <DOT> net>
AuthorDate: Thu Dec  5 23:11:36 2024 +0000
Commit:     Miroslav Šulc <fordfrog <AT> gentoo <DOT> org>
CommitDate: Fri Dec  6 07:42:31 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=064e2f7c
java-utils-2.eclass: drop -Dtest.resources.dir from etestng()
This property is specific to dev-java/testng.
Signed-off-by: Volkmar W. Pogatzki <gentoo <AT> pogatzki.net>
Closes: https://github.com/gentoo/gentoo/pull/39233/commits/6b4df3a589a5ef516c9b2915e611fd46df8d354e
Signed-off-by: Miroslav Šulc <fordfrog <AT> gentoo.org>
 eclass/java-utils-2.eclass | 1 -
 1 file changed, 1 deletion(-)
diff --git a/eclass/java-utils-2.eclass b/eclass/java-utils-2.eclass
index c0a900b35a00..00ae7f790e08 100644
--- a/eclass/java-utils-2.eclass
+++ b/eclass/java-utils-2.eclass
@@ -1942,7 +1942,6 @@ etestng() {
 		-cp ${cp}
 		-Djava.io.tmpdir="${T}"
 		-Djava.awt.headless=true
-		-Dtest.resources.dir="${JAVA_TEST_RESOURCE_DIRS}"
 		${JAVA_TEST_EXTRA_ARGS[@]}
 		${runner}
 		${JAVA_TEST_RUNNER_EXTRA_ARGS[@]}
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-06  7:44 Miroslav Šulc
  0 siblings, 0 replies; 6663+ messages in thread
From: Miroslav Šulc @ 2024-12-06  7:44 UTC (permalink / raw
  To: gentoo-commits
commit:     b4811e07c355f6baa89d7581fe233fd57e63293a
Author:     Volkmar W. Pogatzki <gentoo <AT> pogatzki <DOT> net>
AuthorDate: Fri Nov 22 09:05:26 2024 +0000
Commit:     Miroslav Šulc <fordfrog <AT> gentoo <DOT> org>
CommitDate: Fri Dec  6 07:43:54 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=b4811e07
java-utils-2.eclass: add some missing documentation
Signed-off-by: Volkmar W. Pogatzki <gentoo <AT> pogatzki.net>
Closes: https://github.com/gentoo/gentoo/pull/39233/commits/ea4b4f6f7397d8be1ccc99aa7baeea87fda0f90a
Signed-off-by: Miroslav Šulc <fordfrog <AT> gentoo.org>
 eclass/java-utils-2.eclass | 42 ++++++++++++++++++++++++++++++++++++++++++
 1 file changed, 42 insertions(+)
diff --git a/eclass/java-utils-2.eclass b/eclass/java-utils-2.eclass
index 5874f6ba8665..e2af63819839 100644
--- a/eclass/java-utils-2.eclass
+++ b/eclass/java-utils-2.eclass
@@ -213,6 +213,48 @@ JAVA_PKG_COMPILERS_CONF=${JAVA_PKG_COMPILERS_CONF:="/etc/java-config-2/build/com
 # 	ebuild foo.ebuild compile
 # @CODE
 
+# @ECLASS_VARIABLE: EBUILD_DEATH_HOOKS
+# @INTERNAL
+# @DEFAULT_UNSET
+# @DESCRIPTION:
+# Used internally.
+
+# @ECLASS_VARIABLE: JAVA_PKG_BUILD_DEPEND_FILE
+# @INTERNAL
+# @DEFAULT_UNSET
+# @DESCRIPTION:
+# Used in ejunit_, java-pkg_do_write_ and java-pkg_record-jar_
+
+# @ECLASS_VARIABLE: JAVA_PKG_DEPEND_FILE
+# @INTERNAL
+# @DEFAULT_UNSET
+# @DESCRIPTION:
+# Used in ejunit_, java-pkg_do_write_ and java-pkg_record-jar_
+
+# @ECLASS_VARIABLE: JAVA_PKG_EXTRA_ENV
+# @INTERNAL
+# @DEFAULT_UNSET
+# @DESCRIPTION:
+# Used in java-pkg_register-environment-variable and java-pkg_do_write_,
+
+# @ECLASS_VARIABLE: JAVA_PKG_EXTRA_ENV_VARS
+# @INTERNAL
+# @DEFAULT_UNSET
+# @DESCRIPTION:
+# Used in java-pkg_register-environment-variable and java-pkg_do_write_
+
+# @ECLASS_VARIABLE: JAVA_PKG_OPTIONAL_DEPEND_FILE
+# @INTERNAL
+# @DEFAULT_UNSET
+# @DESCRIPTION:
+# Used in java-pkg_do_write_ and java-pkg_record-jar_
+
+# @ECLASS_VARIABLE: WANT_JAVA_CONFIG
+# @INTERNAL
+# @DEFAULT_UNSET
+# @DESCRIPTION:
+# Gets exported to make sure we use java-config-2
+
 # @ECLASS_VARIABLE: JAVADOC_CLASSPATH
 # @DEFAULT_UNSET
 # @DESCRIPTION:
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-06 11:33 Nowa Ammerlaan
  0 siblings, 0 replies; 6663+ messages in thread
From: Nowa Ammerlaan @ 2024-12-06 11:33 UTC (permalink / raw
  To: gentoo-commits
commit:     c3a527ae22dadc00ebee74a72aae5a295e26a5d5
Author:     Nowa Ammerlaan <nowa <AT> gentoo <DOT> org>
AuthorDate: Fri Dec  6 09:46:26 2024 +0000
Commit:     Nowa Ammerlaan <nowa <AT> gentoo <DOT> org>
CommitDate: Fri Dec  6 11:31:14 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=c3a527ae
eclass/{dist-,}kernel{-utils,-build}.eclass: fix compression for >=6.12
Upstream commit [1] introduces several changes to the way module compression is
configured. To summarize:
- CONFIG_MODULE_COMPRESS_NONE is renamed to CONFIG_MODULE_COMPRESS and moved up,
	this (and CONFIG_MODULE_COMPRESS_<type>) control support for module
	compression.
- A new switch CONFIG_MODULE_COMPRESS_ALL is introduced to control whether the
	modules are actually compressed when running make modules_install.
This change introduced several problems that are fixed here:
- CONFIG_MODULE_COMPRESS is not implicitly enabled by setting
	CONFIG_MODULE_COMPRESS_XZ=y in the same way that CONFIG_MODULE_COMPRESS_NONE
	was previously implicitly disabled by enabling the xz compression. Fixed by
	explicitly enabling these options.
- The dist-kernel_get_module_suffix() function did not recognize the renamed
	option which caused the 'compressor not known' error in some configurations.
	Fixed by adding another condition to the elif statement in this function.
Furthermore, we now also set the switch CONFIG_MODULE_COMPRESS_ALL based on the
state of the "modules-compress" USE flag. This technically makes the "suffix-y"
override unnecessary for the >=6.12 kernels, but it does no harm so let's keep
that as it is and not add a new version conditional here.
[1] https://github.com/torvalds/linux/commit/c7ff693fa2094ba0a9d0a20feb4ab1658eff9c33
Signed-off-by: Nowa Ammerlaan <nowa <AT> gentoo.org>
Closes: https://github.com/gentoo/gentoo/pull/39609
Signed-off-by: Nowa Ammerlaan <nowa <AT> gentoo.org>
 eclass/dist-kernel-utils.eclass |  3 ++-
 eclass/kernel-build.eclass      | 19 ++++++++++++++-----
 2 files changed, 16 insertions(+), 6 deletions(-)
diff --git a/eclass/dist-kernel-utils.eclass b/eclass/dist-kernel-utils.eclass
index 67ba459f0ebe..210c586c8c29 100644
--- a/eclass/dist-kernel-utils.eclass
+++ b/eclass/dist-kernel-utils.eclass
@@ -175,7 +175,8 @@ dist-kernel_get_module_suffix() {
 		echo .ko
 	elif [[ ! -r ${config} ]]; then
 		die "Cannot find kernel config ${config}"
-	elif grep -q "CONFIG_MODULE_COMPRESS_NONE=y" "${config}"; then
+	elif grep -q "CONFIG_MODULE_COMPRESS_NONE=y" "${config}" ||
+		grep -q "# CONFIG_MODULE_COMPRESS is not set" "${config}"; then
 		echo .ko
 	elif grep -q "CONFIG_MODULE_COMPRESS_GZIP=y" "${config}"; then
 		echo .ko.gz
diff --git a/eclass/kernel-build.eclass b/eclass/kernel-build.eclass
index 376cebf3b1be..831027216321 100644
--- a/eclass/kernel-build.eclass
+++ b/eclass/kernel-build.eclass
@@ -371,8 +371,7 @@ kernel-build_src_install() {
 	local compress=()
 	if [[ ${KERNEL_IUSE_GENERIC_UKI} ]] && ! use modules-compress; then
 		compress+=(
-			# force installing uncompressed modules even if compression
-			# is enabled via config
+			# Workaround for <6.12, does not have CONFIG_MODULE_COMPRESS_ALL
 			suffix-y=
 		)
 	fi
@@ -656,12 +655,22 @@ kernel-build_merge_configs() {
 
 	# Only semi-related but let's use that to avoid changing stable ebuilds.
 	if [[ ${KERNEL_IUSE_GENERIC_UKI} ]]; then
-		# NB: we enable this even with USE=-modules-compress, in order
-		# to support both uncompressed and compressed modules in prebuilt
-		# kernels
+		# NB: we enable support for compressed modules even with
+		# USE=-modules-compress, in order to support both uncompressed and
+		# compressed modules in prebuilt kernels.
 		cat <<-EOF > "${WORKDIR}/module-compress.config" || die
+			CONFIG_MODULE_COMPRESS=y
 			CONFIG_MODULE_COMPRESS_XZ=y
 		EOF
+		# CONFIG_MODULE_COMPRESS_ALL is supported only by >=6.12, for older
+		# versions we accomplish the same by overriding suffix-y=
+		if use modules-compress; then
+			echo "CONFIG_MODULE_COMPRESS_ALL=y" \
+				>> "${WORKDIR}/module-compress.config" || die
+		else
+			echo "# CONFIG_MODULE_COMPRESS_ALL is not set" \
+				>> "${WORKDIR}/module-compress.config" || die
+		fi
 		merge_configs+=( "${WORKDIR}/module-compress.config" )
 	fi
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-06 21:55 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-12-06 21:55 UTC (permalink / raw
  To: gentoo-commits
commit:     9056ac677938e04f22a5972fe76db7173a157846
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Dec  6 21:55:27 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Dec  6 21:55:27 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=9056ac67
llvm-r1.eclass: update _LLVM_NEWEST_SLOT to 19
Bug: https://bugs.gentoo.org/945145
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/llvm-r1.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/llvm-r1.eclass b/eclass/llvm-r1.eclass
index 7b9f26e17b58..f2bf0fffee09 100644
--- a/eclass/llvm-r1.eclass
+++ b/eclass/llvm-r1.eclass
@@ -61,7 +61,7 @@ _LLVM_OLDEST_SLOT=15
 # @DESCRIPTION:
 # The newest stable LLVM version.  Versions newer than that won't
 # be automatically enabled via USE defaults.
-_LLVM_NEWEST_STABLE=18
+_LLVM_NEWEST_STABLE=19
 
 # == control variables ==
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread
* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-07 23:23 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-12-07 23:23 UTC (permalink / raw
  To: gentoo-commits
commit:     ec6ccd63bb77770eeeb8eb220d66efafc91ac572
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Dec  7 23:21:14 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Dec  7 23:21:14 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=ec6ccd63
toolchain.eclass: pass -fcf-protection=none for stage1 builds with Clang
GCC's host_detect_local_cpu returns NULL when built with Clang (see bug
for details) so pass -fcf-protection=none for stage1 (where it doesn't
really matter anyway) to avoid a failure when -march=native ends up
resolving to nothing (b/c NULL) and then erroring out as CET isn't supported
for the baseline -m32 CPU.
Bug: https://gcc.gnu.org/PR117952
Closes: https://bugs.gentoo.org/933772
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 7 +++++++
 1 file changed, 7 insertions(+)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index be8bfcddfafd..565a2f359488 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -2261,6 +2261,13 @@ gcc_do_make() {
 			STAGE1_CXXFLAGS="-O2"
 		fi
 
+		# Workaround -march=native not working for stage1 with
+		# non-GCC (bug #933772).
+		if ! tc-is-gcc ; then
+			STAGE1_CFLAGS+=" $(test-flags-CC -fcf-protection=none)"
+			STAGE1_CXXFLAGS+=" $(test-flags-CXX -fcf-protection=none)"
+		fi
+
 		# We only want to use the system's CFLAGS if not building a
 		# cross-compiler.
 		STAGE1_CFLAGS=${STAGE1_CFLAGS-"$(get_abi_CFLAGS ${TARGET_DEFAULT_ABI}) ${CFLAGS}"}
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-08  1:11 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-12-08  1:11 UTC (permalink / raw
  To: gentoo-commits
commit:     f82ed28a4cbf188cac0d20175d7fea963a742e25
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Dec  7 23:36:33 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Dec  8 00:49:35 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=f82ed28a
toolchain.eclass: disable CET if stage 1 compiler is Clang and -march=native
It's too much hassle to make this edge-case work for now (not really
worth it given kind of niche, not like glibc even defaults to enforcement
yet or even has a mechanism to set a default) and I've filed a bug upstream.
The problem with my previous approach (even after then trying STAGE1_TFLAGS)
is that w/ --enable-cet or bootstrap-cet at least, we end up adding
-fcf-protection after our added -fcf-protection=none.
This partly reverts commit ec6ccd63bb77770eeeb8eb220d66efafc91ac572.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 18 ++++++++----------
 1 file changed, 8 insertions(+), 10 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 565a2f359488..8e91816735a9 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -775,7 +775,7 @@ tc_enable_hardened_gcc() {
 		hardened_gcc_flags+=" -DDEF_GENTOO_ZNOW"
 	fi
 
-	if _tc_use_if_iuse cet && [[ ${CTARGET} == *x86_64*-linux-gnu* ]] ; then
+	if _tc_use_if_iuse cet && [[ -z ${CLANG_DISABLE_CET_HACK} && ${CTARGET} == *x86_64*-linux-gnu* ]] ; then
 		einfo "Updating gcc to use x86-64 control flow protection by default ..."
 		hardened_gcc_flags+=" -DEXTRA_OPTIONS_CF"
 	fi
@@ -1149,6 +1149,11 @@ toolchain_src_configure() {
 		export ac_cv_std_swap_in_utility=no
 	fi
 
+	# Workaround -march=native not working for stage1 with non-GCC (bug #933772).
+	if ! tc-is-gcc && [[ "${CFLAGS}${CXXFLAGS}" == *-march=native* ]] ; then
+		CLANG_DISABLE_CET_HACK=1
+	fi
+
 	local flag
 	for flag in $(all-flag-vars) ; do
 		einfo "${flag}=\"${!flag}\""
@@ -1308,7 +1313,7 @@ toolchain_src_configure() {
 		BUILD_CONFIG_TARGETS+=( bootstrap-lto )
 	fi
 
-	if tc_version_is_at_least 12 && _tc_use_if_iuse cet && [[ ${CTARGET} == x86_64-*-gnu* ]] ; then
+	if tc_version_is_at_least 12 && _tc_use_if_iuse cet && [[ -z ${CLANG_DISABLE_CET_HACK} && ${CTARGET} == x86_64-*-gnu* ]] ; then
 		BUILD_CONFIG_TARGETS+=( bootstrap-cet )
 	fi
 
@@ -1694,7 +1699,7 @@ toolchain_src_configure() {
 
 		enable_cet_for 'x86_64' 'gnu' 'cet'
 		enable_cet_for 'aarch64' 'gnu' 'standard-branch-protection'
-		[[ ${CTARGET} == i[34567]86-* ]] && confgcc+=( --disable-cet )
+		[[ -n ${CLANG_DISABLE_CET_HACK} || ${CTARGET} == i[34567]86-* ]] && confgcc+=( --disable-cet )
 	fi
 
 	if in_iuse systemtap ; then
@@ -2261,13 +2266,6 @@ gcc_do_make() {
 			STAGE1_CXXFLAGS="-O2"
 		fi
 
-		# Workaround -march=native not working for stage1 with
-		# non-GCC (bug #933772).
-		if ! tc-is-gcc ; then
-			STAGE1_CFLAGS+=" $(test-flags-CC -fcf-protection=none)"
-			STAGE1_CXXFLAGS+=" $(test-flags-CXX -fcf-protection=none)"
-		fi
-
 		# We only want to use the system's CFLAGS if not building a
 		# cross-compiler.
 		STAGE1_CFLAGS=${STAGE1_CFLAGS-"$(get_abi_CFLAGS ${TARGET_DEFAULT_ABI}) ${CFLAGS}"}
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-08 23:34 Matt Jolly
  0 siblings, 0 replies; 6663+ messages in thread
From: Matt Jolly @ 2024-12-08 23:34 UTC (permalink / raw
  To: gentoo-commits
commit:     d1ef411b6e2cab683bbaf83a03f44b22fd46cede
Author:     Matt Jolly <kangie <AT> gentoo <DOT> org>
AuthorDate: Tue Dec  3 12:22:37 2024 +0000
Commit:     Matt Jolly <kangie <AT> gentoo <DOT> org>
CommitDate: Sun Dec  8 23:34:01 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=d1ef411b
rust.eclass: add ERUST_{SLOT,TYPE}_OVERRIDE user variables
These variables enable users (though most likely Gentoo developers)
to override the selection of the Rust implementation by the eclass.
This means that _only_ the specified SLOT and/or TYPE ('source'/'binary')
will be checked for, with the eclass `die`ing with
"No Rust slot satisfying the package's dependencies..." if the
selected impl is not available.
These variables are intended to enable reproducing bugs and testing
packages against specific dev-lang/rust{,-bin} packages; they must
not be set in ebuilds.
Closes: https://bugs.gentoo.org/945752
Signed-off-by: Matt Jolly <kangie <AT> gentoo.org>
 eclass/rust.eclass | 49 ++++++++++++++++++++++++++++++++++++++++++++-----
 1 file changed, 44 insertions(+), 5 deletions(-)
diff --git a/eclass/rust.eclass b/eclass/rust.eclass
index 2bf0b27b3f40..eb14ca2329b5 100644
--- a/eclass/rust.eclass
+++ b/eclass/rust.eclass
@@ -102,6 +102,26 @@ declare -a -g -r _RUST_SLOTS_ORDERED=(
 	"1.54.0"
 )
 
+# == user control knobs ==
+
+# @ECLASS_VARIABLE: ERUST_SLOT_OVERRIDE
+# @USER_VARIABLE
+# @DESCRIPTION:
+# Specify the version (slot) of Rust to be used by the package. This is
+# useful for troubleshooting and debugging purposes; If unset, the newest
+# acceptable Rust version will be used. May be combined with ERUST_TYPE_OVERRIDE.
+# This variable must not be set in ebuilds.
+
+# @ECLASS_VARIABLE: ERUST_TYPE_OVERRIDE
+# @USER_VARIABLE
+# @DESCRIPTION:
+# Specify the type of Rust to be used by the package from options:
+# 'source' or 'binary' (-bin). This is useful for troubleshooting and
+# debugging purposes. If unset, the standard eclass logic will be used
+# to determine the type of Rust to use (i.e. prefer source if binary
+# is also available). May be combined with ERUST_SLOT_OVERRIDE.
+# This variable must not be set in ebuilds.
+
 # == control variables ==
 
 # @ECLASS_VARIABLE: RUST_MAX_VER
@@ -336,6 +356,10 @@ _get_rust_slot() {
 			fi
 		fi
 
+		if [[ -n "${ERUST_SLOT_OVERRIDE}" && "${slot}" != "${ERUST_SLOT_OVERRIDE}" ]]; then
+			continue
+		fi
+
 		# If we're in LLVM mode we can skip any slots that don't match the selected USE
 		if [[ -n "${RUST_NEEDS_LLVM}" ]]; then
 			if [[ "${llvm_slot}" != "${llvm_r1_slot}" ]]; then
@@ -349,12 +373,27 @@ _get_rust_slot() {
 			rust_check_deps && return
 		else
 			local usedep="${RUST_REQ_USE+[${RUST_REQ_USE}]}"
-			# When checking for installed packages prefer the non `-bin` package
+			# When checking for installed packages prefer the source package;
 			# if effort was put into building it we should use it.
-			local rust_pkgs=(
-				"dev-lang/rust:${slot}${usedep}"
-				"dev-lang/rust-bin:${slot}${usedep}"
-			)
+			local rust_pkgs
+			case "${ERUST_TYPE_OVERRIDE}" in
+				source)
+					rust_pkgs=(
+						"dev-lang/rust:${slot}${usedep}"
+					)
+					;;
+				binary)
+					rust_pkgs=(
+						"dev-lang/rust-bin:${slot}${usedep}"
+					)
+					;;
+				*)
+					rust_pkgs=(
+						"dev-lang/rust:${slot}${usedep}"
+						"dev-lang/rust-bin:${slot}${usedep}"
+					)
+					;;
+			esac
 			local _pkg
 			for _pkg in "${rust_pkgs[@]}"; do
 				if has_version "${hv_switch}" "${_pkg}"; then
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-08 23:34 Matt Jolly
  0 siblings, 0 replies; 6663+ messages in thread
From: Matt Jolly @ 2024-12-08 23:34 UTC (permalink / raw
  To: gentoo-commits
commit:     f425fb09c3ca9e7d112df01222039713dd7ac3ec
Author:     MYT <mytdragon <AT> protonmail <DOT> com>
AuthorDate: Tue Dec  3 16:28:52 2024 +0000
Commit:     Matt Jolly <kangie <AT> gentoo <DOT> org>
CommitDate: Sun Dec  8 23:34:01 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=f425fb09
Add 'host' variable to GIT_CRATES
Also handle the gitea use-case.
This change indroduces possibility to fetch git crates from hosts other
than github/main gitlab instance, like the gnome's gitlab which wasn't
possible before. This is done by adding new key in the crate value
`;gitlab` for example.
Signed-off-by: MYT <mytdragon <AT> protonmail.com>
Signed-off-by: Matt Jolly <kangie <AT> gentoo.org>
 eclass/cargo.eclass | 41 ++++++++++++++++++++++++++++++++++-------
 1 file changed, 34 insertions(+), 7 deletions(-)
diff --git a/eclass/cargo.eclass b/eclass/cargo.eclass
index 02b048732f7f..b1285e13a5b2 100644
--- a/eclass/cargo.eclass
+++ b/eclass/cargo.eclass
@@ -138,6 +138,10 @@ ECARGO_VENDOR="${ECARGO_HOME}/gentoo"
 # - optionally: the path to look for Cargo.toml in.
 #   - This will also replace the string "%commit%" with the commit's checksum.
 #   - Defaults to: "${crate}-%commit%"
+# - optionally: the git host so it would generate tarball download link.
+#   - E.g. gitlab
+#   - It fallbacks to detecting from URL if it's gitlab.com or github.com
+#     if no host provided.
 #
 # Example of a simple definition with no path to Cargo.toml:
 # @CODE
@@ -153,6 +157,13 @@ ECARGO_VENDOR="${ECARGO_HOME}/gentoo"
 # 	[rustpython-parser]="https://github.com/RustPython/RustPython;4f38cb68e4a97aeea9eb19673803a0bd5f655383;RustPython-%commit%/compiler/parser"
 # )
 # @CODE
+#
+# Example with host defined:
+# @CODE
+# declare -A GIT_CRATES=(
+#	[clapper]="https://gitlab.gnome.org/JanGernert/clapper-rs;530b6fd53a60563d8038f7a1d9d735d6dc496adb;clapper-rs-%commit%/libclapper-rs;gitlab"
+# )
+# @CODE
 
 # @ECLASS_VARIABLE: CARGO_BOOTSTRAP
 # @DEFAULT_UNSET
@@ -269,22 +280,38 @@ _cargo_set_crate_uris() {
 
 	if declare -p GIT_CRATES &>/dev/null; then
 		if [[ $(declare -p GIT_CRATES) == "declare -A"* ]]; then
-			local crate commit crate_uri crate_dir repo_ext feat_expr
+			local crate commit crate_uri crate_dir host repo_ext feat_expr
 
 			for crate in "${!GIT_CRATES[@]}"; do
-				IFS=';' read -r crate_uri commit crate_dir <<< "${GIT_CRATES[${crate}]}"
+				IFS=';' read -r crate_uri commit crate_dir host <<< "${GIT_CRATES[${crate}]}"
+
+				if [[ -z ${host} ]]; then
+					case "${crate_uri}" in
+						https://github.com/*)
+							host="github"
+						;;
+						https://gitlab.com/*)
+							host="gitlab"
+						;;
+					esac
+				fi
 
-				case "${crate_uri}" in
-					https://github.com/*)
+				case "${host}" in
+					github)
 						repo_ext=".gh"
 						repo_name="${crate_uri##*/}"
 						crate_uri="${crate_uri%/}/archive/%commit%.tar.gz"
 					;;
-					https://gitlab.com/*)
+					gitlab)
 						repo_ext=".gl"
 						repo_name="${crate_uri##*/}"
 						crate_uri="${crate_uri%/}/-/archive/%commit%/${repo_name}-%commit%.tar.gz"
 					;;
+					gitea)
+						repo_ext=".gt"
+						repo_name="${crate_uri##*/}"
+						crate_uri="${crate_uri%/}/archive/%commit%.tar.gz"
+					;;
 					*)
 						repo_ext=
 						repo_name="${crate}"
@@ -395,11 +422,11 @@ _cargo_gen_git_config() {
 	git_crates_type="$(declare -p GIT_CRATES 2>&-)"
 
 	if [[ ${git_crates_type} == "declare -A "* ]]; then
-		local crate commit crate_uri crate_dir
+		local crate commit crate_uri crate_dir host
 		local -A crate_patches
 
 		for crate in "${!GIT_CRATES[@]}"; do
-			IFS=';' read -r crate_uri commit crate_dir <<< "${GIT_CRATES[${crate}]}"
+			IFS=';' read -r crate_uri commit crate_dir host <<< "${GIT_CRATES[${crate}]}"
 			: "${crate_dir:=${crate}-%commit%}"
 			crate_patches["${crate_uri}"]+="${crate} = { path = \"${WORKDIR}/${crate_dir//%commit%/${commit}}\" };;"
 		done
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-09 18:49 Ulrich Müller
  0 siblings, 0 replies; 6663+ messages in thread
From: Ulrich Müller @ 2024-12-09 18:49 UTC (permalink / raw
  To: gentoo-commits
commit:     94ee6e4ec34ece5759c6398cf6d33cf66c5e2687
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Sun Nov 24 18:25:26 2024 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Mon Dec  9 18:48:10 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=94ee6e4e
eapi9-pipestatus.eclass: New eclass
This implements the pipestatus command, as proposed for EAPI 9:
| Checks the shell's pipe status array, i.e. the exit status of the
| command(s) in the most recently executed foreground pipeline.
| Returns shell true (0) if all elements are zero, or the last
| non-zero element otherwise. If called with -v as the first argument,
| also outputs the pipe status array as a space-separated list.
Bug: https://bugs.gentoo.org/566342
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 eclass/eapi9-pipestatus.eclass | 60 ++++++++++++++++++++++++++++++++++++++++++
 1 file changed, 60 insertions(+)
diff --git a/eclass/eapi9-pipestatus.eclass b/eclass/eapi9-pipestatus.eclass
new file mode 100644
index 000000000000..f92afe42ef14
--- /dev/null
+++ b/eclass/eapi9-pipestatus.eclass
@@ -0,0 +1,60 @@
+# Copyright 2024 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+# @ECLASS: eapi9-pipestatus.eclass
+# @MAINTAINER:
+# Ulrich Müller <ulm@gentoo.org>
+# @AUTHOR:
+# Ulrich Müller <ulm@gentoo.org>
+# @SUPPORTED_EAPIS: 7 8
+# @BLURB: check the PIPESTATUS array
+# @DESCRIPTION:
+# A stand-alone implementation of a possible future pipestatus command
+# (which would be aimed for EAPI 9).  It is meant as a replacement for
+# "assert".  In its simplest form it can be called like this:
+#
+# @CODE
+# foo | bar
+# pipestatus || die
+# @CODE
+#
+# With the -v option, the command will also echo the pipe status array,
+# so it can be assigned to a variable like in the following example:
+#
+# @CODE
+# local status
+# foo | bar
+# status=$(pipestatus -v) || die "foo | bar failed, status ${status}"
+# @CODE
+#
+# Caveat: "pipestatus" must be the next command following the pipeline.
+# In particular, the "local" declaration must be before the pipeline,
+# otherwise it would reset the status.
+
+case ${EAPI} in
+	7|8) ;;
+	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
+esac
+
+# @FUNCTION: pipestatus
+# @USAGE: [-v]
+# @RETURN: last non-zero element of PIPESTATUS, or zero if all are zero
+# @DESCRIPTION:
+# Check the PIPESTATUS array, i.e. the exit status of the command(s)
+# in the most recently executed foreground pipeline.  If called with
+# option -v, also output the PIPESTATUS array.
+pipestatus() {
+	local status=( "${PIPESTATUS[@]}" )
+	local s ret=0 verbose=""
+
+	[[ ${1} == -v ]] && { verbose=1; shift; }
+	[[ $# -ne 0 ]] && die "usage: ${FUNCNAME} [-v]"
+
+	for s in "${status[@]}"; do
+		[[ ${s} -ne 0 ]] && ret=${s}
+	done
+
+	[[ ${verbose} ]] && echo "${status[@]}"
+
+	return "${ret}"
+}
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-10  5:21 Ionen Wolkens
  0 siblings, 0 replies; 6663+ messages in thread
From: Ionen Wolkens @ 2024-12-10  5:21 UTC (permalink / raw
  To: gentoo-commits
commit:     d4a350cbc34fa6cc2c013a397c0aac53ae0bb0b1
Author:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
AuthorDate: Tue Dec 10 04:36:40 2024 +0000
Commit:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
CommitDate: Tue Dec 10 05:10:26 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=d4a350cb
qt6-build.eclass: replace assert with pipestatus
Not very interesting to show pipestatus -v when the 2nd command
is just tail(1), realistically it's CC that will have failed.
Preemptively limit to EAPI=8 for when port to 9, albeit that will
likely be short lived as there is no need for extended EAPI=8 support
here after Qt ebuilds are migrated & stabilized.
Signed-off-by: Ionen Wolkens <ionen <AT> gentoo.org>
 eclass/qt6-build.eclass | 5 +++--
 1 file changed, 3 insertions(+), 2 deletions(-)
diff --git a/eclass/qt6-build.eclass b/eclass/qt6-build.eclass
index 2dec4b7ec14e..3d3531dd96d5 100644
--- a/eclass/qt6-build.eclass
+++ b/eclass/qt6-build.eclass
@@ -22,6 +22,7 @@ _QT6_BUILD_ECLASS=1
 	die "${ECLASS} is only to be used for building Qt6"
 
 inherit cmake flag-o-matic toolchain-funcs
+[[ ${EAPI} == 8 ]] && inherit eapi9-pipestatus
 
 # @ECLASS_VARIABLE: QT6_BUILD_TYPE
 # @DESCRIPTION:
@@ -321,7 +322,7 @@ _qt6-build_sanitize_cpu_flags() {
 					bad
 					#endif
 				EOF
-				assert
+				pipestatus || die
 			)"
 			[[ ${_} == bad ]] && bad=1 && break
 		done
@@ -342,7 +343,7 @@ _qt6-build_sanitize_cpu_flags() {
 			#  endif
 			#endif
 		EOF
-		assert
+		pipestatus || die
 	)
 
 	cpuflags+=("${cpuflags_filter_only[@]}")
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-11 11:52 Ionen Wolkens
  0 siblings, 0 replies; 6663+ messages in thread
From: Ionen Wolkens @ 2024-12-11 11:52 UTC (permalink / raw
  To: gentoo-commits
commit:     58f67ed970b56897b769d99b37a9b7d874e7fa87
Author:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
AuthorDate: Wed Dec 11 11:49:22 2024 +0000
Commit:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
CommitDate: Wed Dec 11 11:51:27 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=58f67ed9
qt6-build.eclass: pass -Wno-dev by default
Been very noisy and starting to get annoying when trying to
look at the output, don't think they're going to help in
debugging issues downstream.
Signed-off-by: Ionen Wolkens <ionen <AT> gentoo.org>
 eclass/qt6-build.eclass | 2 ++
 1 file changed, 2 insertions(+)
diff --git a/eclass/qt6-build.eclass b/eclass/qt6-build.eclass
index 75630843c087..f8161447074a 100644
--- a/eclass/qt6-build.eclass
+++ b/eclass/qt6-build.eclass
@@ -156,6 +156,8 @@ qt6-build_src_configure() {
 		# cmake defaults to "STATUS" but Qt changes that to "NOTICE" which
 		# hides a lot of information that is useful for bug reports
 		--log-level=STATUS
+		# ...but dev messages are noisy and not really useful downstream
+		-Wno-dev
 		# see _qt6-build_create_user_facing_links
 		-DINSTALL_PUBLICBINDIR="${QT6_PREFIX}"/bin
 		# note that if qtbase was built with tests, this is default ON
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-11 11:52 Ionen Wolkens
  0 siblings, 0 replies; 6663+ messages in thread
From: Ionen Wolkens @ 2024-12-11 11:52 UTC (permalink / raw
  To: gentoo-commits
commit:     d2d4b0b7154f57c9962e01d75b27b8aacbd8764e
Author:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
AuthorDate: Wed Dec 11 10:52:55 2024 +0000
Commit:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
CommitDate: Wed Dec 11 11:44:35 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=d2d4b0b7
qt6-build.eclass: add workaround for cpus with broken rdrand/rdseed
Not perfect but it should prevent failures for the average user.
Formerly meant to check if -march=native is in *FLAGS, but it
shouldn't matter as long as it is not cross.
Can't test myself, but it should work in theory.
Closes: https://bugs.gentoo.org/922498
Signed-off-by: Ionen Wolkens <ionen <AT> gentoo.org>
 eclass/qt6-build.eclass | 12 ++++++++++++
 1 file changed, 12 insertions(+)
diff --git a/eclass/qt6-build.eclass b/eclass/qt6-build.eclass
index a0ca9c619405..75630843c087 100644
--- a/eclass/qt6-build.eclass
+++ b/eclass/qt6-build.eclass
@@ -335,6 +335,18 @@ _qt6-build_sanitize_cpu_flags() {
 		done
 	fi
 
+	# some cpus have broken rdrand/rdseed and it's enabled regardless
+	# with -march=native, Qt detects this and fails (bug #922498)
+	if [[ ! -v sanitize ]] &&
+		! tc-is-cross-compiler &&
+		# the kernel also detects this and removes it from cpuinfo
+		[[ -r /proc/cpuinfo && $(</proc/cpuinfo) != *rdrand* ]] &&
+		tc-cpp-is-true __RDRND__ ${CXXFLAGS} ${CPPFLAGS}
+	then
+		einfo "Detected CPU with (likely) broken rdrand/rdseed (bug #922498)"
+		sanitize=1
+	fi
+
 	[[ -v sanitize ]] || return 0 # *should* be fine as-is
 
 	# determine highest(known) usable x86-64 feature level
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-11 11:52 Ionen Wolkens
  0 siblings, 0 replies; 6663+ messages in thread
From: Ionen Wolkens @ 2024-12-11 11:52 UTC (permalink / raw
  To: gentoo-commits
commit:     4712e403c0ccfc6d3d857df61dee1fc910f4451f
Author:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
AuthorDate: Wed Dec 11 10:00:22 2024 +0000
Commit:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
CommitDate: Wed Dec 11 11:44:29 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=4712e403
qt6-build.eclass: split sanitize_cpu_flags checks in separate blocks
About to add a new one and increasing the if levels was getting
confusing. This way can remove or add new ones without affecting
the others. Do need to check the sanitize variable multiple times
to avoid running extra checks for nothing though.
Signed-off-by: Ionen Wolkens <ionen <AT> gentoo.org>
 eclass/qt6-build.eclass | 22 +++++++++++++++-------
 1 file changed, 15 insertions(+), 7 deletions(-)
diff --git a/eclass/qt6-build.eclass b/eclass/qt6-build.eclass
index 3d3531dd96d5..a0ca9c619405 100644
--- a/eclass/qt6-build.eclass
+++ b/eclass/qt6-build.eclass
@@ -309,12 +309,16 @@ _qt6-build_sanitize_cpu_flags() {
 		avx512vp2intersect
 	)
 
+	local sanitize
+
 	# check if any known problematic -mno-* C(XX)FLAGS
-	if ! is-flagq "@($(IFS='|'; echo "${cpuflags[*]/#/-mno-}"))"; then
-		# check if qsimd_p.h (search for "enable all") will accept -march, and
-		# further check when -march=haswell is appended (which Qt uses for some
-		# parts) given combination with other -m* could lead to partial support
-		local bad flags
+	is-flagq "@($(IFS='|'; echo "${cpuflags[*]/#/-mno-}"))" && sanitize=1
+
+	# check if qsimd_p.h (search for "enable all") will accept -march, and
+	# further check when -march=haswell is appended (which Qt uses for some
+	# parts) given combination with other -m* could lead to partial support
+	if [[ ! -v sanitize ]]; then
+		local flags
 		for flags in '' '-march=haswell'; do
 			: "$($(tc-getCXX) -E -P ${CXXFLAGS} ${CPPFLAGS} ${flags} - <<-EOF | tail -n 1
 					#if (defined(__AVX2__) && (__BMI__ + __BMI2__ + __F16C__ + __FMA__ + __LZCNT__ + __POPCNT__) != 6) || \
@@ -324,11 +328,15 @@ _qt6-build_sanitize_cpu_flags() {
 				EOF
 				pipestatus || die
 			)"
-			[[ ${_} == bad ]] && bad=1 && break
+			if [[ ${_} == bad ]]; then
+				sanitize=1
+				break
+			fi
 		done
-		[[ -v bad ]] || return 0 # *should* be fine as-is
 	fi
 
+	[[ -v sanitize ]] || return 0 # *should* be fine as-is
+
 	# determine highest(known) usable x86-64 feature level
 	local march=$(
 		$(tc-getCXX) -E -P ${CXXFLAGS} ${CPPFLAGS} - <<-EOF | tail -n 1
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-12  7:47 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-12-12  7:47 UTC (permalink / raw
  To: gentoo-commits
commit:     6d18ca00e9b8cc2b0a6d931eff5ecd9802dc8b37
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Dec 12 07:36:32 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Dec 12 07:46:55 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=6d18ca00
toolchain.eclass: tidy up fixincludes comment
It's not particularly useful these days.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 6 +-----
 1 file changed, 1 insertion(+), 5 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 55db818f6233..6584e57fb0fd 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -2494,11 +2494,7 @@ toolchain_src_install() {
 
 	if [[ ${GCC_RUN_FIXINCLUDES} == 0 ]] ; then
 		# We remove the generated fixincludes, as they can cause things to break
-		# (ncurses, openssl, etc).  We do not prevent them from being built, as
-		# in the following commit which we revert:
-		# https://sources.gentoo.org/cgi-bin/viewvc.cgi/gentoo-x86/eclass/toolchain.eclass?r1=1.647&r2=1.648
-		# This is because bsd userland needs fixedincludes to build gcc, while
-		# linux does not.  Both can dispose of them afterwards.
+		# (ncurses, openssl, etc).
 		while read x ; do
 			grep -q 'It has been auto-edited by fixincludes from' "${x}" \
 				&& rm -f "${x}"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-12  7:47 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-12-12  7:47 UTC (permalink / raw
  To: gentoo-commits
commit:     c048402e74be87600d1842702d79f778d5b59e9c
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Dec 12 07:34:20 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Dec 12 07:46:55 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=c048402e
toolchain.eclass: allow overriding GCC_RUN_FIXINCLUDES
Useful for testing hacks.
Bug: https://bugs.gentoo.org/933282
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 8e91816735a9..55db818f6233 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -204,7 +204,7 @@ GCCMICRO=$(ver_cut 3 ${GCC_PV})
 # @INTERNAL
 # @DESCRIPTION:
 # Controls whether fixincludes should be used.
-GCC_RUN_FIXINCLUDES=0
+: "${GCC_RUN_FIXINCLUDES:=0}"
 
 tc_use_major_version_only() {
 	local use_major_version_only=0
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-12  7:47 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-12-12  7:47 UTC (permalink / raw
  To: gentoo-commits
commit:     7d99be77433bf10fb0ce6fc99c7b40de700ed650
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Dec 12 07:42:00 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Dec 12 07:46:56 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=7d99be77
toolchain.eclass: stop deleting `install-tools`
Since da19e742f2d45221bec7a70c23903278c28e2664, we deleted anything in
`install-tools`, but this includes `mkheaders` which is needed to refresh
fixincludes.
See https://gcc.gnu.org/onlinedocs/gcc/Fixed-Headers.html.
Bug: https://bugs.gentoo.org/933282
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 4 ----
 1 file changed, 4 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 6584e57fb0fd..d72047e891d1 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -2514,8 +2514,6 @@ toolchain_src_install() {
 		pushd "${WORKDIR}"/build-jit > /dev/null || die
 		S="${WORKDIR}"/build-jit emake DESTDIR="${D}" -j1 install
 
-		# Punt some tools which are really only useful while building gcc
-		find "${ED}" -name install-tools -prune -type d -exec rm -rf "{}" \; || die
 		# This one comes with binutils
 		find "${ED}" -name libiberty.a -delete || die
 
@@ -2538,8 +2536,6 @@ toolchain_src_install() {
 	# - https://gcc.gnu.org/PR109898
 	S="${WORKDIR}"/build emake DESTDIR="${D}" -j1 install
 
-	# Punt some tools which are really only useful while building gcc
-	find "${ED}" -name install-tools -prune -type d -exec rm -rf "{}" \; || die
 	# This one comes with binutils
 	find "${ED}" -name libiberty.a -delete || die
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-12 17:03 Florian Schmaus
  0 siblings, 0 replies; 6663+ messages in thread
From: Florian Schmaus @ 2024-12-12 17:03 UTC (permalink / raw
  To: gentoo-commits
commit:     b19ff3462450417986410812624ed7c29a767824
Author:     Florian Schmaus <flow <AT> gentoo <DOT> org>
AuthorDate: Wed Dec 11 09:13:32 2024 +0000
Commit:     Florian Schmaus <flow <AT> gentoo <DOT> org>
CommitDate: Thu Dec 12 16:57:05 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=b19ff346
latex-package.eclass: do not set $@ in latex-package_src_doinstall's loop
Since 595611085bc5 ("latex-package: kill POSIX and old EAPI"), the 'tex'
and 'dtx' case handling of latex-package_src_doinstall's loop would set
$@ to a pdflatex invocation. However, the main loop of this function
iterates over $@, and after $@ is set to a pdflatex command, this
iteration would continue to process the components of the pdflatex
command.
As result, ebuild have to
latex-package_src_doinstall doc
latex-package_src_doinstall pdf
when
latex-package_src_doinstall doc
should be sufficient, because the 'doc' case expands to the "tex dtx dvi
ps pdf" cases. However, once a 'tex' or 'dtx' case was processed, the
remaining onces are no longer be processed, due the bug described above.
The fix is simple: do not abuse $@ to save the pdflatex command,
instead, use a dedicated local variable.
Fixes: 595611085bc532afb9f31fa23cee734bc37d21a4
Signed-off-by: Florian Schmaus <flow <AT> gentoo.org>
 eclass/latex-package.eclass | 13 +++++++++----
 1 file changed, 9 insertions(+), 4 deletions(-)
diff --git a/eclass/latex-package.eclass b/eclass/latex-package.eclass
index 4082e161b843..d6426775f720 100644
--- a/eclass/latex-package.eclass
+++ b/eclass/latex-package.eclass
@@ -137,11 +137,16 @@ latex-package_src_doinstall() {
 						continue
 
 						einfo "Making documentation: ${i}"
+						local mypdflatex=(
+							pdflatex
+							${LATEX_DOC_ARGUMENTS}
+							--halt-on-error
+							--interaction=nonstopmode
+							"${i}"
+						)
 						# some macros need compiler called twice, do it here.
-						set -- pdflatex ${LATEX_DOC_ARGUMENTS} \
-							--halt-on-error --interaction=nonstopmode "${i}"
-						if "${@}"; then
-							"${@}"
+						if "${mypdflatex[@]}"; then
+							"${mypdflatex[@]}"
 						else
 							einfo "pdflatex failed, trying texi2dvi"
 							texi2dvi -q -c --language=latex "${i}" || die
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-12 17:03 Florian Schmaus
  0 siblings, 0 replies; 6663+ messages in thread
From: Florian Schmaus @ 2024-12-12 17:03 UTC (permalink / raw
  To: gentoo-commits
commit:     ba4bc48984a181310b7d15fb63f253c9518c9084
Author:     Florian Schmaus <flow <AT> gentoo <DOT> org>
AuthorDate: Wed Dec 11 09:49:39 2024 +0000
Commit:     Florian Schmaus <flow <AT> gentoo <DOT> org>
CommitDate: Thu Dec 12 16:57:05 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=ba4bc489
latex-package.eclass: add default case to latex-package_src_doinstall
Add a default case to the switch/case statement in
latex-package_src_doinstall, invoking die.
Signed-off-by: Florian Schmaus <flow <AT> gentoo.org>
 eclass/latex-package.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/latex-package.eclass b/eclass/latex-package.eclass
index d6426775f720..dfef7fc2836f 100644
--- a/eclass/latex-package.eclass
+++ b/eclass/latex-package.eclass
@@ -200,6 +200,9 @@ latex-package_src_doinstall() {
 			"all")
 				latex-package_src_doinstall styles fonts bin doc
 				;;
+			*)
+				die "Unknown module: ${1}"
+				;;
 		esac
 	shift
 	done
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-12 17:03 Florian Schmaus
  0 siblings, 0 replies; 6663+ messages in thread
From: Florian Schmaus @ 2024-12-12 17:03 UTC (permalink / raw
  To: gentoo-commits
commit:     5293d4b91dabb4c61afc4990b4f177d273f0fc80
Author:     Florian Schmaus <flow <AT> gentoo <DOT> org>
AuthorDate: Wed Dec 11 08:49:42 2024 +0000
Commit:     Florian Schmaus <flow <AT> gentoo <DOT> org>
CommitDate: Thu Dec 12 17:02:03 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=5293d4b9
texlive-module.eclass: use pipestatus
Signed-off-by: Florian Schmaus <flow <AT> gentoo.org>
 eclass/texlive-module.eclass | 15 +++++++--------
 1 file changed, 7 insertions(+), 8 deletions(-)
diff --git a/eclass/texlive-module.eclass b/eclass/texlive-module.eclass
index f8b6f0858cd6..ebd65e3dd0d8 100644
--- a/eclass/texlive-module.eclass
+++ b/eclass/texlive-module.eclass
@@ -79,7 +79,7 @@ esac
 if [[ -z ${_TEXLIVE_MODULE_ECLASS} ]]; then
 _TEXLIVE_MODULE_ECLASS=1
 
-inherit texlive-common
+inherit eapi9-pipestatus texlive-common
 
 HOMEPAGE="https://www.tug.org/texlive/"
 
@@ -537,16 +537,15 @@ texlive-module_src_install() {
 				grep_expressions+=(-e "/${f//./\\.}\$")
 			done
 
+			local status
+			# "success-status aware grep", returning exit status 0 instead of 1.
+			_sgrep() { grep "$@"; return "$(( $? <= 1 ? 0 : $? ))"; }
 			ebegin "Installing man pages"
 			find texmf-dist/doc/man -type f -name '*.[0-9n]' -print |
-				grep -v "${grep_expressions[@]}" |
+				_sgrep -v "${grep_expressions[@]}" |
 				xargs -d '\n' --no-run-if-empty nonfatal doman
-			local pipestatus="${PIPESTATUS[*]}"
-			# The grep in the middle of the pipe may return 1 in case
-			# everything from the input is dropped.
-			# See https://bugs.gentoo.org/931994
-			[[ ${pipestatus} == "0 "[01]" 0" ]]
-			eend $? || die "error installing man pages (pipestatus: ${pipestatus})"
+			status=$(pipestatus -v)
+			eend $? || die "error installing man pages (PIPESTATUS: ${status})"
 
 			# Delete all man pages under texmf-dist/doc/man
 			find texmf-dist/doc/man -type f -name '*.[0-9n]' -delete ||
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-13 10:02 Florian Schmaus
  0 siblings, 0 replies; 6663+ messages in thread
From: Florian Schmaus @ 2024-12-13 10:02 UTC (permalink / raw
  To: gentoo-commits
commit:     589efbb6dd81a44451e2ec6c8e1b52991d29b9d7
Author:     Florian Schmaus <flow <AT> gentoo <DOT> org>
AuthorDate: Fri Dec 13 09:59:08 2024 +0000
Commit:     Florian Schmaus <flow <AT> gentoo <DOT> org>
CommitDate: Fri Dec 13 10:02:33 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=589efbb6
texlive-module.eclass: change _sgrep to _tl_sgrep
Bash functions are always global, hence put the "local" function under a
proper '_tl' namespace. Thanks to ulm for pointing this out.
Signed-off-by: Florian Schmaus <flow <AT> gentoo.org>
 eclass/texlive-module.eclass | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/eclass/texlive-module.eclass b/eclass/texlive-module.eclass
index ebd65e3dd0d8..15dcdea5df20 100644
--- a/eclass/texlive-module.eclass
+++ b/eclass/texlive-module.eclass
@@ -539,10 +539,10 @@ texlive-module_src_install() {
 
 			local status
 			# "success-status aware grep", returning exit status 0 instead of 1.
-			_sgrep() { grep "$@"; return "$(( $? <= 1 ? 0 : $? ))"; }
+			_tl_sgrep() { grep "$@"; return "$(( $? <= 1 ? 0 : $? ))"; }
 			ebegin "Installing man pages"
 			find texmf-dist/doc/man -type f -name '*.[0-9n]' -print |
-				_sgrep -v "${grep_expressions[@]}" |
+				_tl_sgrep -v "${grep_expressions[@]}" |
 				xargs -d '\n' --no-run-if-empty nonfatal doman
 			status=$(pipestatus -v)
 			eend $? || die "error installing man pages (PIPESTATUS: ${status})"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-13 13:11 Hans de Graaff
  0 siblings, 0 replies; 6663+ messages in thread
From: Hans de Graaff @ 2024-12-13 13:11 UTC (permalink / raw
  To: gentoo-commits
commit:     09b4524862a03f6e11a9e42d7913f82c66e65b63
Author:     Hans de Graaff <graaff <AT> gentoo <DOT> org>
AuthorDate: Sun Dec  8 08:23:12 2024 +0000
Commit:     Hans de Graaff <graaff <AT> gentoo <DOT> org>
CommitDate: Fri Dec 13 13:10:51 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=09b45248
ruby-fakegem.eclass: compile ruby31 extensions with gnu17
The varargs implementation in Ruby 3.2 is not compatible with gnu23. Ruby
3.1 is in security maintenance mode upstream so it is unlikely that the
fixes from Ruby 3.2 will be backported. Ruby 3.1 is EOL in March 2025
and will be removed from Gentoo around that time.
Signed-off-by: Hans de Graaff <graaff <AT> gentoo.org>
 eclass/ruby-fakegem.eclass | 12 ++++++++++++
 1 file changed, 12 insertions(+)
diff --git a/eclass/ruby-fakegem.eclass b/eclass/ruby-fakegem.eclass
index eb6257a50cf9..fc78428be714 100644
--- a/eclass/ruby-fakegem.eclass
+++ b/eclass/ruby-fakegem.eclass
@@ -23,6 +23,8 @@ case ${EAPI} in
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
+# flag-o-matic is only required for ruby31 support.
+inherit flag-o-matic
 inherit ruby-ng
 
 # @ECLASS_VARIABLE: RUBY_FAKEGEM_NAME
@@ -424,6 +426,16 @@ EOF
 each_fakegem_configure() {
 	debug-print-function ${FUNCNAME} "$@"
 
+	# Ruby 3.1 has a varargs implementation that is not compatible with
+	# gnu23. Ruby 3.1 is EOL in March 2025 and will be removed shortly
+	# after that.
+	case ${RUBY} in
+		*ruby31)
+			append-flags -std=gnu17
+			filter-flags -std=gnu23
+			;;
+	esac
+
 	tc-export PKG_CONFIG
 	for extension in "${RUBY_FAKEGEM_EXTENSIONS[@]}" ; do
 		CC=$(tc-getCC) ${RUBY} --disable=did_you_mean -C ${extension%/*} ${extension##*/} --with-cflags="${CFLAGS}" --with-ldflags="${LDFLAGS}" ${RUBY_FAKEGEM_EXTENSION_OPTIONS} || die
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-14 12:47 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-12-14 12:47 UTC (permalink / raw
  To: gentoo-commits
commit:     4618bed8161e7e28c6704726cee0aebdf5f17109
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Dec 14 12:46:13 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Dec 14 12:47:07 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=4618bed8
toolchain.eclass: don't try to enable offloading for non-linux
--enable-offload-defaulted doesn't work with x86_64-w64-mingw32 and
gets confused by plugin support not being available. Just disable it
for non-Linux.
Closes: https://bugs.gentoo.org/946397
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 3 ++-
 1 file changed, 2 insertions(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index d72047e891d1..c59f1246459f 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1635,8 +1635,9 @@ toolchain_src_configure() {
 	[[ ${CTARGET} == *-darwin* ]] && \
 		confgcc+=( --enable-version-specific-runtime-libs )
 
+	# Linux specifically here for bug #946397.
 	# TODO: amdgcn-amdhsa?
-	[[ ${CTARGET} == x86_64* ]] && confgcc+=(
+	[[ ${CTARGET} == x86_64*-*-linux-* ]] && confgcc+=(
 		--enable-offload-defaulted
 		--enable-offload-targets=nvptx-none
 	)
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-14 16:33 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-12-14 16:33 UTC (permalink / raw
  To: gentoo-commits
commit:     148b773c86ce9a1b6e97fadde809652938236c59
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Dec 14 16:24:27 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Dec 14 16:30:58 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=148b773c
toolchain.eclass: only make gnat* tool wrappers for native builds
Only make the wrappers for native builds. For cross, we can't
do it as CBUILD vs CHOST will get mixed up then.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 29 ++++++++++++++++++-----------
 1 file changed, 18 insertions(+), 11 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index c59f1246459f..51704a7f5fbf 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1085,19 +1085,26 @@ toolchain_setup_ada() {
 
 	# Create bin wrappers because not all of the build system respects
 	# GNATBIND or GNATMAKE.
-	mkdir "${T}"/ada-wrappers || die
-	local tool
-	for tool in gnat{,bind,chop,clean,kr,link,ls,make,name,prep} ; do
-		cat <<-EOF > "${T}"/ada-wrappers/${tool} || die
-		#!/bin/sh
-		exec "${ada_bootstrap_bin_dir}"/${CHOST}-${tool} "\$@"
-		EOF
+	_toolchain_make_gnat_wrappers() {
+		mkdir "${T}"/ada-wrappers || die
+		local tool
+		for tool in gnat{,bind,chop,clean,kr,link,ls,make,name,prep} ; do
+			cat <<-EOF > "${T}"/ada-wrappers/${tool} || die
+			#!/bin/sh
+			exec "${ada_bootstrap_bin_dir}"/${CHOST}-${tool} "\$@"
+			EOF
+
+			export "${tool^^}"="${T}"/ada-wrappers/${tool}
+		done
+		chmod +x "${T}"/ada-wrappers/gnat{,bind,chop,clean,kr,link,ls,make,name,prep} || die
 
-		export "${tool^^}"="${T}"/ada-wrappers/${tool}
-	done
-	chmod +x "${T}"/ada-wrappers/gnat{,bind,chop,clean,kr,link,ls,make,name,prep} || die
+		export PATH="${T}/ada-wrappers:${old_path}"
+	}
+
+	# Only make the wrappers for native builds. For cross, we can't
+	# do it as CBUILD vs CHOST will get mixed up then.
+	! tc-is-cross-compiler && _toolchain_make_gnat_wrappers
 
-	export PATH="${T}/ada-wrappers:${old_path}"
 	export CC="$(tc-getCC) -specs=${T}/ada.spec"
 }
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-14 18:43 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-12-14 18:43 UTC (permalink / raw
  To: gentoo-commits
commit:     9c0077a62d40b6b7078ff75c883f3b33cd8ecca9
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Dec 14 18:41:27 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Dec 14 18:43:02 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=9c0077a6
toolchain.eclass: prepare for dev-lang/ada-bootstrap with diff version
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 14 +++++++++-----
 1 file changed, 9 insertions(+), 5 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 51704a7f5fbf..6eef2a0ec03e 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -971,12 +971,16 @@ toolchain_setup_ada() {
 	if ver_test ${ada_bootstrap} -gt ${PV} || [[ -z ${ada_bootstrap} ]] ; then
 		ebegin "Testing fallback dev-lang/ada-bootstrap for Ada"
 		if has_version -b "<dev-lang/ada-bootstrap-${SLOT}" ; then
-			# TODO: Figure out ada-bootstrap versioning/slots
+			# Workaround the old scheme
+			if has_version -b "=dev-lang/ada-bootstrap-0_p2021*" ; then
+				ada_bootstrap=10
+			else
+				local latest_ada_bootstrap=$(best_version -b "<dev-lang/ada-bootstrap-${SLOT}")
+				latest_ada_bootstrap="${latest_ada_bootstrap#dev-lang/ada-bootstrap-}"
+				latest_ada_bootstrap=$(ver_cut 1 ${latest_ada_bootstrap})
+				ada_bootstrap="${latest_ada_bootstrap}"
+			fi
 
-			#local latest_ada_bootstrap=$(best_version -b "<dev-lang/ada-bootstrap-${SLOT}")
-			#latest_ada_bootstrap="${latest_ada_bootstrap#dev-lang/ada-bootstrap-}"
-			#latest_ada_bootstrap=$(ver_cut 1 ${latest_ada_bootstrap})
-			ada_bootstrap="10"
 			ada_bootstrap_type=ada-bootstrap
 			ada_bootstrap_bin_dir="${BROOT}/usr/lib/ada-bootstrap/bin"
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-15  3:08 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-12-15  3:08 UTC (permalink / raw
  To: gentoo-commits
commit:     407beaa9de0f6d3056b71d5144cd7205ae413a6f
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Dec 15 03:05:12 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Dec 15 03:07:40 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=407beaa9
toolchain.eclass: set ADA_{INCLUDE,OBJECTS}_DIR for new ada-bootstrap path
For self-built ada-bootstrpa tarballs, we need this to help find
the runtime library.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 6eef2a0ec03e..4e27cd2fb8f6 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -979,6 +979,9 @@ toolchain_setup_ada() {
 				latest_ada_bootstrap="${latest_ada_bootstrap#dev-lang/ada-bootstrap-}"
 				latest_ada_bootstrap=$(ver_cut 1 ${latest_ada_bootstrap})
 				ada_bootstrap="${latest_ada_bootstrap}"
+
+				export ADA_INCLUDE_PATH="${BROOT}/usr/lib/ada-bootstrap/usr/lib/gcc/${CHOST}/${ada_bootstrap}/adainclude::${ADA_INCLUDE_PATH}"
+				export ADA_OBJECTS_PATH="${BROOT}/usr/lib/ada-bootstrap/usr/lib/gcc/${CHOST}/${ada_bootstrap}/adalib:${ADA_OBJECTS_PATH}"
 			fi
 
 			ada_bootstrap_type=ada-bootstrap
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-15  9:47 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-12-15  9:47 UTC (permalink / raw
  To: gentoo-commits
commit:     e0012940b823476f795f088db4bf2395577df2bb
Author:     Eric Joldasov <bratishkaerik <AT> landless-city <DOT> net>
AuthorDate: Mon May 13 11:21:46 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Dec 15 09:47:05 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=e0012940
zig.eclass: new eclass
This eclass is built on top of `zig-utils.eclass` and works with
`zig build` sub-commands and `build.zig` system, here called ZBS or
Zig Build System. By default it adds convenient default dependencies
and phase functions (which can be opt-out by setting `ZIG_OPTIONAL=1`)
that:
 * work with dependencies from official package manager,
 * configures basic sane options for `zig build`, which can be further
   complemented by ebuild authors and users,
 * respects user settings for verbosity and jobs number,
 * has some basic support for cross-compilation, which works on my PC
   with `crossdev` and QEMU-ed Docker container, but it was not tested
   on real machine yet.
This is a major step in unifying behaviour and de-duplicating logic
spanning multiple ebuilds (target convertion and jobs amount
in `dev-lang/zig`, different Zig search and build options configuration
in `sys-fs/ncdu` and other ebuilds in community overlays). Mentioned
ebuilds are converted in next commits.
It is recommended to use https://github.com/BratishkaErik/zig-ebuilder
with this eclass to generate base for new ebuilds.
Signed-off-by: Eric Joldasov <bratishkaerik <AT> landless-city.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/zig.eclass | 558 ++++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 file changed, 558 insertions(+)
diff --git a/eclass/zig.eclass b/eclass/zig.eclass
new file mode 100644
index 000000000000..e838616ef72a
--- /dev/null
+++ b/eclass/zig.eclass
@@ -0,0 +1,558 @@
+# Copyright 2024 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+# @ECLASS: zig.eclass
+# @MAINTAINER:
+# Eric Joldasov <bratishkaerik@landless-city.net>
+# @AUTHOR:
+# Alfred Wingate <parona@protonmail.com>
+# Violet Purcell <vimproved@inventati.org>
+# Eric Joldasov <bratishkaerik@landless-city.net>
+# @SUPPORTED_EAPIS: 8
+# @PROVIDES: zig-utils
+# @BLURB: Functions for working with ZBS (Zig Build System)
+# @DESCRIPTION:
+# Functions for working with Zig build system and package manager.
+# Supports Zig 0.13+.  Exports default functions for convenience.
+#
+# Note that zig.eclass is mostly tailored for projects that:
+# 1) Install something in build.zig steps: "artifacts" (executable,
+# libraries, objects), source codes, assets, tests, scripts etc.   But
+# many authors also use it to write Zig "modules", build logic
+# and/or bindings/wrappers for C/C++ libraries.  They install nothing
+# and are only used at build-time, so it's unneccessary and mostly
+# useless to make ebuilds for them.
+# 2) Have required `target`, `cpu` and optional `optimize` options in
+# build.zig that accept standard Zig-style target and optimize mode.
+# They are usually created by calling `b.standardTargetOptions` and
+# `b.standardOptimizeOption` functions.
+#
+# For end-user executables, usually it's recommended to patch to call
+# these options and upstream it, but in some cases authors have good
+# reasons to not have them, f.e. if it is built only for WASM
+# platform with ReleaseSmall, and is not intended to run in /usr/bin/.
+# In this case, declare dummy options using `b.option` and  ignore
+# their values, or else eclass wouldn't work.
+#
+# Another case is when upstream has `target` option but it has
+# custom format and does not accept usual Zig targets, but rather
+# something specific to the project like "linux-baseline-lts", or
+# combine CPU and target in one option.
+# In this case, it's best to rename that option to something like
+# `target-custom`, then declare `target` option and make converter
+# from one value to other.
+#
+# For non-executable binaries like C libraries, objects etc. our
+# policy is stricter, all 3 options are required and should not
+# be ignored, with no exceptions.
+
+if [[ -z ${_ZIG_ECLASS} ]]; then
+_ZIG_ECLASS=1
+
+case ${EAPI} in
+	8) ;;
+	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
+esac
+
+inherit multiprocessing zig-utils
+
+# @ECLASS_VARIABLE: ZIG_OPTIONAL
+# @PRE_INHERIT
+# @DEFAULT_UNSET
+# @DESCRIPTION:
+# If set to a non-empty value, all logic in zig-utils and
+# zig eclasses will be considered optional.  No dependencies
+# will be added and no phase functions will be exported.
+#
+# For zig.eclass users:
+# You need to add Zig and pkgconfig dependencies in your BDEPEND, set
+# QA_FLAGS_IGNORED and call all phase functions manually.  If you want
+# to use "ezig build" directly, call "zig_pkg_setup" before it.
+#
+# For zig-utils.eclass users: see documentation in
+# zig-utils.eclass instead.
+if [[ ! ${ZIG_OPTIONAL} ]]; then
+	BDEPEND="virtual/pkgconfig"
+
+	# See https://github.com/ziglang/zig/issues/3382
+	# Zig Build System does not support CFLAGS/LDFLAGS/etc.
+	QA_FLAGS_IGNORED=".*"
+fi
+
+# @ECLASS_VARIABLE: ZBS_DEPENDENCIES
+# @PRE_INHERIT
+# @DEFAULT_UNSET
+# @DESCRIPTION:
+# Bash associative array with all tarballs that will be fetched by
+# "ezig fetch" in zig_src_unpack phase.  Value is URL where
+# tarball is located, key is name under which it would be downloaded
+# and renamed.  So generally it has effect of "value -> key".
+#
+# Note: if Zig Build System dependency can't be represented in SRC_URI
+# (like direct Git commit URIs), you should do the following
+# (zig-ebuilder does archiving automatically for you):
+#   1. Archive each folder with dependency content in some tarball,
+#      so f.e. if you have 2 Git dependencies, create 2 tarballs.
+#   2. Archive all previous tarballs into one combined tarball (also
+#      called tarball-tarball from now on), no subdirs, so that eclass
+#      can firstly unpack this tarball with "unpack",
+#      and secondly unpack its content with "zig fetch".
+#   3. (zig-ebuilder can't do this) Host this tarball somewhere
+#      and put URL of this tarball in SRC_URI, and archives in
+#      ZBS_DEPENDENCIES, keys must be names of archives, values empty.
+#
+# Example:
+# @CODE
+# declare -r -A ZBS_DEPENDENCIES=(
+# 	[tarball_a-<long-hash>.tar.gz]='URL_A'
+# 	[tarball_b-<long-hash>.tar.gz]='URL_B'
+#
+# 	# If there are Git dependencies:
+# 	[git_c-<long-hash>.tar.gz]=''
+# 	# Tarball-tarball should contain inside above tarball flatly.
+# )
+# @CODE
+
+# @ECLASS_VARIABLE: ZBS_DEPENDENCIES_SRC_URI
+# @OUTPUT_VARIABLE
+# @DEFAULT_UNSET
+# @DESCRIPTION:
+# Content of ZBS_DEPENDENCIES converted at inherit-time, to be used in
+# SRC_URI.  Note that elements with empty keys will be skipped.
+# Example:
+# @CODE
+# SRC_URI="
+# 	<URL to project sources, patches, non-Zig resources etc.>
+#
+# 	# If there are Git dependencies:
+# 	# <URL to tarball-tarball>
+#
+# 	${ZBS_DEPENDENCIES_SRC_URI}
+# "
+# @CODE
+
+# @FUNCTION: _zig_set_zbs_uris
+# @INTERNAL
+# @DESCRIPTION:
+# Sets ZBS_DEPENDENCIES_SRC_URI variable based on ZBS_DEPENDENCIES.
+_zig_set_zbs_uris() {
+	# Thanks to Alfred Wingate "parona" for inspiration here:
+	# https://gitlab.com/Parona/parona-overlay/-/blob/874dcfe03116574a33ed51f469cc993e98db1fa2/eclass/zig.eclass
+
+	ZBS_DEPENDENCIES_SRC_URI=
+
+	local dependency
+	for dependency in "${!ZBS_DEPENDENCIES[@]}"; do
+		local uri="${ZBS_DEPENDENCIES[${dependency}]}"
+		if [[ -n "${uri}" ]]; then
+			ZBS_DEPENDENCIES_SRC_URI+=" ${uri} -> ${dependency}"
+		fi
+	done
+}
+_zig_set_zbs_uris
+
+# @ECLASS_VARIABLE: my_zbs_args
+# @DESCRIPTION:
+# Bash array with ebuild-specified arguments to pass to the
+# "zig build" after "src_configure".
+# It's appended to the ZBS_ARGS during "src_configure".  Note: if you
+# need to override default optimize mode of this eclass (ReleaseSafe)
+# with your default, please use "--release=small" etc. syntax so that
+# user can still override it in ZBS_ARGS_EXTRA.
+#
+# Example:
+# @CODE
+# src_configure() {
+# 	local my_zbs_args=(
+# 		-Dpie=true
+# 	)
+#
+# 	zig_src_configure
+# }
+# @CODE
+: "${my_zbs_args:=}"
+
+# @ECLASS_VARIABLE: ZBS_ARGS_EXTRA
+# @USER_VARIABLE
+# @DESCRIPTION:
+# Bash string with user-specified arguments to pass to the "zig build"
+# after "src_configure".
+# It's appended to the ZBS_ARGS during "zig_src_configure".
+#
+# If this does not have amount of jobs, eclass will try to take amount
+# of jobs from MAKEOPTS, and if it also does not have them, it will
+# default to $(nproc).
+#
+# Example:
+# @CODE
+# ZBS_ARGS_EXTRA="-j8 --release=small"
+# @CODE
+: "${ZBS_ARGS_EXTRA:=}"
+
+# @ECLASS_VARIABLE: ZBS_VERBOSE
+# @USER_VARIABLE
+# @DESCRIPTION:
+# If enabled, eclass will add "--summary all --verbose" options to
+# "ezig build", so that it prints every command before executing,
+# and summarry tree at the end of step.  If not, will do nothing.
+# Enabled by default.  Set to OFF to disable these verbose messages.
+#
+# Note: this variable does not control other options starting with
+# "--verbose-", such as "--verbose-link" or "--verbose-cimport".  If
+# you need them, add them manually to ZBS_ARGS_EXTRA.
+: "${ZBS_VERBOSE:=ON}"
+
+# @ECLASS_VARIABLE: BUILD_DIR
+# @DEFAULT_UNSET
+# @DESCRIPTION:
+# Directory where all "ezig build" calls will be proceeded.
+# Defaults to "${WORKDIR}/${P}-build" if not set.
+: "${BUILD_DIR:=${WORKDIR}/${P}-build}"
+
+# @ECLASS_VARIABLE: ZBS_ECLASS_DIR
+# @DESCRIPTION:
+# Directory where various files used by this eclass are stored.
+# They can be supplied by the ebuild or by eclass.
+# Currently, it's used only for Zig packages, which are stored in "p/"
+# subdirectory.
+# Defaults to "${WORKDIR}/zig-eclass" if not set.
+# Should be set before calling "zig_src_unpack" or
+# "zig_live_fetch".
+: "${ZBS_ECLASS_DIR:=${WORKDIR}/zig-eclass}"
+
+# @FUNCTION: zig_get_jobs
+# @DESCRIPTION:
+# Returns number of jobs from ZBS_ARGS_EXTRA or MAKEOPTS.
+# If there is none, defaults to number of available processing units.
+zig_get_jobs() {
+	local all_args="${MAKEOPTS} ${ZBS_ARGS_EXTRA}"
+	local default_jobs="$(get_nproc)"
+	local jobs="$(makeopts_jobs "${all_args}" "${default_jobs}")"
+
+	if [[ "${jobs}" == "0" ]]; then
+		# Zig build system does not allow "-j0", and does not have
+		# option for unlimited parallelism. Pass our default number
+		# of jobs here.
+		echo "${default_jobs}"
+	else
+		echo "${jobs}"
+	fi
+}
+
+# @FUNCTION: zig_init_base_args
+# @DESCRIPTION:
+# Stores basic args for future "ezig build" calls in ZBS_ARGS_BASE.
+# Package manager option is managed by "zig_src_prepare",
+# ebuild and user options are added by "zig_src_configure".
+#
+# This function is used by "zig_pkg_setup", and it is neccessary
+# that args are available as early as possible, so that ebuilds
+# could use them in steps like "src_unpack" if neccessary, while
+# still having verbosity and amount of jobs from user respected.
+#
+#
+# TODO: currently this function enables "--search-prefix" (1) and
+# "--sysroot" (2) only when cross-compiling, should be fixed to
+# unconditionally enabling it.
+#
+# For solving (1) this patch should be reworked and upstreamed:
+# https://paste.sr.ht/~bratishkaerik/2ddffe2bf0f8f9d6dfb60403c2e9560334edaa88
+#
+# (2)
+# "--sysroot" should be passed together with "--search-prefix" above,
+# if we pass only "--sysroot" it gives these errors:
+# @CODE
+# error: unable to find dynamic system library 'zstd' using strategy 'paths_first'. searched paths: none
+# @CODE
+zig_init_base_args() {
+	[[ "${ZBS_ARGS_BASE}" ]] && return
+
+	# Sync with the output format of `zig libc`.
+	# TODO maybe add to upstream to use ZON format instead...
+	# Will also help "https://github.com/ziglang/zig/issues/20327",
+	# and hopefully will respect our settings too.
+	cat <<- _EOF_ > "${T}/zig_libc.txt" || die "Failed to provide Zig libc info"
+		# Note: they are not prepended by "--sysroot" value,
+		# so repeat it here.
+		# Also, no quotes here, they are interpreted verbatim.
+		include_dir=${ESYSROOT}/usr/include/
+		sys_include_dir=${ESYSROOT}/usr/include/
+		crt_dir=${ESYSROOT}/usr/$(get_libdir)/
+		# Windows with MSVC only.
+		msvc_lib_dir=
+		# Windows with MSVC only.
+		kernel32_lib_dir=
+		# Haiku only.
+		gcc_dir=
+	_EOF_
+
+	declare -g -a ZBS_ARGS_BASE=(
+		-j$(zig_get_jobs)
+
+		-Dtarget="${ZIG_TARGET}"
+		-Dcpu="${ZIG_CPU}"
+		--release=safe
+
+		--prefix-exe-dir bin/
+		--prefix-lib-dir "$(get_libdir)/"
+		--prefix-include-dir include/
+
+		# Should be relative path to make other calls easier,
+		# so remove leading slash here.
+		--prefix "${EPREFIX:+${EPREFIX#/}/}usr/"
+
+		--libc "${T}/zig_libc.txt"
+	)
+	if [[ "${ZBS_VERBOSE}" != OFF ]]; then
+		ZBS_ARGS_BASE+=( --summary all --verbose )
+	fi
+
+	if tc-is-cross-compiler; then
+		ZBS_ARGS_BASE+=(
+			--search-prefix "${ESYSROOT}/usr/"
+			--sysroot "${ESYSROOT}/"
+		)
+	fi
+}
+
+# @FUNCTION: zig_pkg_setup
+# @DESCRIPTION:
+# Sets up environmental variables for Zig toolchain
+# and basic args for Zig Build System.
+zig_pkg_setup() {
+	[[ "${MERGE_TYPE}" != binary ]] || return 0
+
+	zig-utils_setup
+	zig_init_base_args
+
+	mkdir "${T}/zig-cache/" || die
+
+	# Environment variables set by this eclass.
+
+	# Used by Zig Build System to find `pkg-config`.
+	# UPSTREAM Used only by 9999 for now, should land in future
+	# 0.14 release.
+	export PKG_CONFIG="${PKG_CONFIG:-"$(tc-getPKG_CONFIG)"}"
+	# Used by whole Zig toolchain (most of the sub-commands)
+	# to find local and global cache directories.
+	export ZIG_LOCAL_CACHE_DIR="${T}/zig-cache/local/"
+	export ZIG_GLOBAL_CACHE_DIR="${T}/zig-cache/global/"
+}
+
+# @FUNCTION: zig_live_fetch
+# @USAGE: [<args>...]
+# @DESCRIPTION:
+# Fetches packages, if they exist, to the "ZBS_ECLASS_DIR/p/".
+# Adds build file path to ZBS_BASE_ARGS.
+# If you have some lazy dependency which is not triggered in default
+# configuration, pass options like you would pass them for regular
+# "ezig build".  Try to cover all of them before "src_configure".
+# **Note**: this function will be deprecated once/if
+# https://github.com/ziglang/zig/pull/19975 lands.
+#
+# Example:
+# @CODE
+# src_unpack() {
+# 	# If there are no lazy dependency:
+# 	zig_live_fetch
+#
+# 	# If there are lazy dependencies that can be triggered together:
+# 	zig_live_fetch -Denable-wayland -Denable-xwayland
+#
+# 	# If there are 2 lazy dependencies that can't be triggered
+# 	# together in one call because they conflict:
+# 	zig_live_fetch -Dmain-backend=opengl
+# 	zig_live_fetch -Dmain-backend=vulkan
+# }
+# @CODE
+zig_live_fetch() {
+	# This function will likely be called in src_unpack,
+	# before [zig_]src_prepare, so this directory might not
+	# exist yet.
+	mkdir -p "${BUILD_DIR}" > /dev/null || die
+	pushd "${BUILD_DIR}" > /dev/null || die
+
+	ZBS_ARGS_BASE+=( --build-file "${S}/build.zig" )
+
+	local args=(
+		"${ZBS_ARGS_BASE[@]}"
+
+		--global-cache-dir "${ZBS_ECLASS_DIR}/"
+
+		# Function arguments
+		"${@}"
+	)
+
+	einfo "ZBS: live-fetching with:"
+	einfo "${args[@]}"
+	ezig build --help "${args[@]}" > /dev/null
+
+	popd > /dev/null || die
+}
+
+# @FUNCTION: zig_src_unpack
+# @DESCRIPTION:
+# Unpacks every archive in SRC_URI and ZBS_DEPENDENCIES,
+# in that order.  Adds build file path to ZBS_BASE_ARGS.
+zig_src_unpack() {
+	# Thanks to Alfred Wingate "parona" for inspiration here:
+	# https://gitlab.com/Parona/parona-overlay/-/blob/874dcfe03116574a33ed51f469cc993e98db1fa2/eclass/zig.eclass
+
+	ZBS_ARGS_BASE+=( --build-file "${S}/build.zig" )
+
+	if [[ "${#ZBS_DEPENDENCIES_SRC_URI}" -eq 0 ]]; then
+		default_src_unpack
+		return
+	fi
+
+	local zig_deps=()
+	for dependency in "${!ZBS_DEPENDENCIES[@]}"; do
+		zig_deps+=("${dependency}")
+	done
+
+	# First unpack non-Zig dependencies, so that
+	# tarball with all Git dependencies tarballs is unpacked early.
+	local dist
+	for dist in ${A}; do
+		if ! has "${dist}" "${zig_deps[@]}"; then
+			unpack "${dist}"
+		fi
+	done
+
+	# Now unpack all Zig dependencies, including those that are
+	# now unpacked from tarball-tarball.
+	local zig_dep
+	for zig_dep in "${zig_deps[@]}"; do
+		# Hide now-spammy hash from stdout
+		ezig fetch --global-cache-dir "${ZBS_ECLASS_DIR}/" \
+			"${DISTDIR}/${zig_dep}" > /dev/null
+	done
+	einfo "ZBS: ${#zig_deps[@]} dependencies unpacked"
+}
+
+# @FUNCTION: zig_src_prepare
+# @DESCRIPTION:
+# Calls default "src_prepare" function, creates BUILD_DIR directory
+# and enables system mode (by adding to ZBS_BASE_ARGS).
+#
+# System mode is toggled here and not in "src_unpack" because they
+# could have been fetched by "live_fetch" in live ebuilds instead.
+zig_src_prepare() {
+	default_src_prepare
+
+	mkdir -p "${BUILD_DIR}" || die
+	einfo "BUILD_DIR: \"${BUILD_DIR}\""
+
+	local system_dir="${ZBS_ECLASS_DIR}/p/"
+	mkdir -p "${system_dir}" || die
+	ZBS_ARGS_BASE+=(
+		# Disable network access after ensuring all dependencies
+		# are unpacked (by "src_unpack" or "live_fetch")
+		--system "${system_dir}"
+	)
+}
+
+# @FUNCTION: zig_src_configure
+# @DESCRIPTION:
+# Creates ZBS_ARGS array which can be used in all future phases,
+# by combining ZBS_ARGS_BASE set previously, my_zbs_args from ebuild,
+# and ZBS_ARGS_EXTRA by user, in this order.
+#
+# Specific flags currently only add support for the cross-compilation.
+# They are likely to be extended in the future.
+zig_src_configure() {
+	# Handle quoted whitespace.
+	eval "local -a ZBS_ARGS_EXTRA=( ${ZBS_ARGS_EXTRA} )"
+
+	# Since most arguments in array are also cached by ZBS, we
+	# want to reuse array as much as possible, so prevent
+	# modification of it.
+	declare -g -a -r ZBS_ARGS=(
+		# Base arguments from pkg_setup/setup_base_args
+		"${ZBS_ARGS_BASE[@]}"
+
+		# Arguments from ebuild
+		"${my_zbs_args[@]}"
+
+		# Arguments from user
+		"${ZBS_ARGS_EXTRA[@]}"
+	)
+
+	einfo "ZBS: configured with:"
+	einfo "${ZBS_ARGS[@]}"
+}
+
+# @FUNCTION: zig_src_compile
+# @USAGE: [<args>...]
+# @DESCRIPTION:
+# Calls "ezig build" with previously set ZBS_ARGS.
+# Args passed to this function will be passed after ZBS_ARGS.
+zig_src_compile() {
+	pushd "${BUILD_DIR}" > /dev/null || die
+
+	local args=( "${ZBS_ARGS[@]}" "${@}" )
+	einfo "ZBS: compiling with: ${args[@]}"
+	nonfatal ezig build "${args[@]}" || die "ZBS: compilation failed"
+
+	popd > /dev/null || die
+}
+
+# @FUNCTION: zig_src_test
+# @USAGE: [<args>...]
+# @DESCRIPTION:
+# If "test" step exist, calls "ezig build test" with previously set
+# ZBS_ARGS.
+# Args passed to this function will be passed after ZBS_ARGS.
+# Note: currently step detection might give false positives in
+# very rare cases, it will be improved in the future.
+zig_src_test() {
+	pushd "${BUILD_DIR}" > /dev/null || die
+
+	local args=( "${ZBS_ARGS[@]}" "${@}" )
+
+	# UPSTREAM std.testing.tmpDir and a lot of other functions
+	# do not respect --cache-dir or ZIG_LOCAL_CACHE_DIR:
+	# https://github.com/ziglang/zig/issues/19874
+	mkdir ".zig-cache/" || die
+
+	# UPSTREAM Currently, step name can have any characters in it,
+	# including whitespaces, so splitting names and descriptions
+	# by whitespaces is not enough for some cases.
+	# We probably need something like  "--list-steps names_only".
+	# In practice, almost nobody sets such names.
+	if grep -q '^[ ]*test[ ]' < <(
+		nonfatal ezig build --list-steps "${args[@]}" ||
+			die "ZBS: listing steps failed"
+	); then
+		einfo "ZBS: testing with: ${args[@]}"
+		nonfatal ezig build test "${args[@]}" ||
+			die "ZBS: tests failed"
+	else
+		einfo "Test step not found, skipping."
+	fi
+
+	popd > /dev/null || die
+}
+
+# @FUNCTION: zig_src_install
+# @USAGE: [<args>...]
+# @DESCRIPTION:
+# Calls "ezig build" with DESTDIR and previously set ZBS_ARGS.
+# Args passed to this function will be passed after ZBS_ARGS.
+# Also installs documentation via "einstalldocs".
+zig_src_install() {
+	pushd "${BUILD_DIR}" > /dev/null || die
+	local args=( "${ZBS_ARGS[@]}" "${@}" )
+	einfo "ZBS: installing with: ${args[@]}"
+	DESTDIR="${D}" nonfatal ezig build "${args[@]}" ||
+		die "ZBS: installing failed"
+	popd > /dev/null || die
+
+	einstalldocs
+}
+
+fi
+
+if [[ ! ${ZIG_OPTIONAL} ]]; then
+	EXPORT_FUNCTIONS pkg_setup src_unpack src_prepare src_configure src_compile src_test src_install
+fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-15 12:48 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-12-15 12:48 UTC (permalink / raw
  To: gentoo-commits
commit:     3ab36cc3531af8a39c1b28bc30f8b724b9242949
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Dec 15 12:18:34 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Dec 15 12:48:14 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=3ab36cc3
toolchain.eclass: don't build with LTO for USE=ada && < gcc-12
There's another -Wlto-type-mismatch issue in GCC 11 with USE=ada and
the patch we used in >=12 doesn't apply cleanly there, not worth spending
the time on for an EOL branch.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 9 +++++++--
 1 file changed, 7 insertions(+), 2 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 4e27cd2fb8f6..55b2127a4f11 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1323,8 +1323,13 @@ toolchain_src_configure() {
 	confgcc+=( --enable-lto )
 
 	# Build compiler itself using LTO
-	if tc_version_is_at_least 9.1 && _tc_use_if_iuse lto ; then
-		BUILD_CONFIG_TARGETS+=( bootstrap-lto )
+	if tc_use_if_iuse lto ; then
+		# GCC 11 at least has a -Wlto-type-mismatch issue with Ada
+		if ! tc_version_is_at_least 12.1 && is_ada ; then
+			:;
+		elif tc_version_is_at_least 9.1 ; then
+			BUILD_CONFIG_TARGETS+=( bootstrap-lto )
+		fi
 	fi
 
 	if tc_version_is_at_least 12 && _tc_use_if_iuse cet && [[ -z ${CLANG_DISABLE_CET_HACK} && ${CTARGET} == x86_64-*-gnu* ]] ; then
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-16  5:57 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-12-16  5:57 UTC (permalink / raw
  To: gentoo-commits
commit:     d4dc2d719da567dd79ce4a7c406a5130ea98ce85
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sun Dec 15 20:12:00 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Mon Dec 16 05:55:42 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=d4dc2d71
llvm.org.eclass: Add 20.0.0_pre20241215 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index a7685a38575b..6a68bde89a46 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -72,6 +72,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 			_LLVM_SOURCE_TYPE=snapshot
 
 			case ${PV} in
+				20.0.0_pre20241215)
+					EGIT_COMMIT=49a5ad8e5714fd404210279303acc97b495d66d0
+					;;
 				20.0.0_pre20241207)
 					EGIT_COMMIT=32f7f0010bca99ee4bd917f57272733fb2bf3bd9
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-16 15:17 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-12-16 15:17 UTC (permalink / raw
  To: gentoo-commits
commit:     4490fff1cd5ba88de79a9e956b91241f2a1fecaa
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Dec 16 15:16:39 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Dec 16 15:16:39 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=4490fff1
toolchain.eclass: fix _tc_use_if_iuse typo
Fixes: 3ab36cc3531af8a39c1b28bc30f8b724b9242949
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 55b2127a4f11..8d2c04b6bf25 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1323,7 +1323,7 @@ toolchain_src_configure() {
 	confgcc+=( --enable-lto )
 
 	# Build compiler itself using LTO
-	if tc_use_if_iuse lto ; then
+	if _tc_use_if_iuse lto ; then
 		# GCC 11 at least has a -Wlto-type-mismatch issue with Ada
 		if ! tc_version_is_at_least 12.1 && is_ada ; then
 			:;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-16 18:45 Ulrich Müller
  0 siblings, 0 replies; 6663+ messages in thread
From: Ulrich Müller @ 2024-12-16 18:45 UTC (permalink / raw
  To: gentoo-commits
commit:     4066b05ec44ace7c595a38cc94497037c3b9b8aa
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Mon Dec 16 18:44:40 2024 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Mon Dec 16 18:44:40 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=4066b05e
elisp-common.eclass: Fix elisp-check-emacs-version() documentation
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 eclass/elisp-common.eclass | 1 -
 1 file changed, 1 deletion(-)
diff --git a/eclass/elisp-common.eclass b/eclass/elisp-common.eclass
index e328a7920002..117544e94b35 100644
--- a/eclass/elisp-common.eclass
+++ b/eclass/elisp-common.eclass
@@ -260,7 +260,6 @@ elisp-emacs-version() {
 }
 
 # @FUNCTION: elisp-check-emacs-version
-# @USAGE: [version]
 # @DESCRIPTION:
 # Test if the eselected Emacs version is at least the version of
 # GNU Emacs specified in the NEED_EMACS variable, or die otherwise.
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-16 18:45 Ulrich Müller
  0 siblings, 0 replies; 6663+ messages in thread
From: Ulrich Müller @ 2024-12-16 18:45 UTC (permalink / raw
  To: gentoo-commits
commit:     c29fac1afd8428bf2128aeeaf883e84f6689c402
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Mon Dec 16 18:44:24 2024 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Mon Dec 16 18:44:24 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=c29fac1a
elisp-common.eclass: Whitespace
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 eclass/elisp-common.eclass | 54 +++++++++++++++++++++++-----------------------
 1 file changed, 27 insertions(+), 27 deletions(-)
diff --git a/eclass/elisp-common.eclass b/eclass/elisp-common.eclass
index ad9d3c7e60c6..e328a7920002 100644
--- a/eclass/elisp-common.eclass
+++ b/eclass/elisp-common.eclass
@@ -25,7 +25,7 @@
 # When relying on the emacs USE flag, you need to add
 #
 # @CODE
-# 	emacs? ( >=app-editors/emacs-25.3:* )
+# emacs? ( >=app-editors/emacs-25.3:* )
 # @CODE
 #
 # to your DEPEND/RDEPEND line and use the functions provided here to
@@ -39,7 +39,7 @@
 # NEED_EMACS with the Emacs version, as in the following example:
 #
 # @CODE
-# 	NEED_EMACS=26.1
+# NEED_EMACS=26.1
 # @CODE
 #
 # Please note that this should be done only for packages that are known
@@ -54,7 +54,7 @@
 # are loadable.
 #
 # @CODE
-# 	elisp-compile *.el
+# elisp-compile *.el
 # @CODE
 #
 # Function elisp-make-autoload-file() can be used to generate a file
@@ -75,7 +75,7 @@
 # (see below) the change, as it defaults to ${PN}.
 #
 # @CODE
-# 	elisp-install ${PN} *.el *.elc
+# elisp-install ${PN} *.el *.elc
 # @CODE
 #
 # To let the Emacs support be activated by Emacs on startup, you need
@@ -84,9 +84,9 @@
 # Normally this would look like this:
 #
 # @CODE
-# 	(add-to-list 'load-path "@SITELISP@")
-# 	(add-to-list 'auto-mode-alist '("\\.csv\\'" . csv-mode))
-# 	(autoload 'csv-mode "csv-mode" "Major mode for csv files." t)
+# (add-to-list 'load-path "@SITELISP@")
+# (add-to-list 'auto-mode-alist '("\\.csv\\'" . csv-mode))
+# (autoload 'csv-mode "csv-mode" "Major mode for csv files." t)
 # @CODE
 #
 # If your Emacs support files are installed in a subdirectory of
@@ -117,13 +117,13 @@
 # your ebuild (e.g., right after S or RDEPEND):
 #
 # @CODE
-# 	SITEFILE="50${PN}-gentoo.el"
+# SITEFILE="50${PN}-gentoo.el"
 # @CODE
 #
 # Which is then installed by
 #
 # @CODE
-# 	elisp-site-file-install "${FILESDIR}/${SITEFILE}"
+# elisp-site-file-install "${FILESDIR}/${SITEFILE}"
 # @CODE
 #
 # in src_install().  Any characters after the "-gentoo" part and before
@@ -137,7 +137,7 @@
 # and install a site-init file that does just that:
 #
 # @CODE
-# 	elisp-make-site-file "${SITEFILE}"
+# elisp-make-site-file "${SITEFILE}"
 # @CODE
 #
 # Again, this must be called in src_install().  See the function's
@@ -153,7 +153,7 @@
 # version.  In this case, you can add an explicit check in pkg_setup:
 #
 # @CODE
-# 	elisp-check-emacs-version
+# elisp-check-emacs-version
 # @CODE
 #
 # When having optional Emacs support, you should prepend "use emacs &&"
@@ -165,13 +165,13 @@
 # emerging and unmerging by using
 #
 # @CODE
-# 	pkg_postinst() {
-# 		elisp-site-regen
-# 	}
+# pkg_postinst() {
+# 	elisp-site-regen
+# }
 #
-# 	pkg_postrm() {
-# 		elisp-site-regen
-# 	}
+# pkg_postrm() {
+# 	elisp-site-regen
+# }
 # @CODE
 #
 # Again, with optional Emacs support, you should prepend "use emacs &&"
@@ -356,8 +356,8 @@ elisp-make-autoload-file() {
 #
 # Example:
 # @CODE
-# 	elisp-org-export-to texinfo README.org
-# 	mv README.texi ${PN}.texi || die
+# elisp-org-export-to texinfo README.org
+# mv README.texi ${PN}.texi || die
 # @CODE
 
 elisp-org-export-to() {
@@ -512,16 +512,16 @@ elisp-test-ert() {
 #
 # Example:
 # @CODE
-# 	inherit elisp-common
+# inherit elisp-common
 #
-# 	...
+# ...
 #
-# 	elisp-enable-tests --optional ert-runner "${S}"/elisp -t "!org"
+# elisp-enable-tests --optional ert-runner "${S}"/elisp -t "!org"
 #
-# 	src_test() {
-# 		emake -C tests test
-# 		elisp-test
-# 	}
+# src_test() {
+# 	emake -C tests test
+# 	elisp-test
+# }
 # @CODE
 
 elisp-enable-tests() {
@@ -662,7 +662,7 @@ elisp-site-file-install() {
 # this will add the package's SITELISP subdirectory to Emacs' load-path:
 #
 # @CODE
-# 	(add-to-list 'load-path "@SITELISP@")
+# (add-to-list 'load-path "@SITELISP@")
 # @CODE
 #
 # Additional arguments are appended as lines to the destination file.
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-17 17:14 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-12-17 17:14 UTC (permalink / raw
  To: gentoo-commits
commit:     14e674bb7a8cb8aa50498582e392d0ecd21f2d4a
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Dec 17 17:13:11 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Dec 17 17:13:52 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=14e674bb
toolchain.eclass: allow current slot for ada-bootstrap dep
Otherwise, you don't get a clean path for 14-with-14.
Bug: https://bugs.gentoo.org/940472
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 31 ++++++++++++++++++++++---------
 1 file changed, 22 insertions(+), 9 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 8d2c04b6bf25..b74984fc8ea8 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -411,16 +411,29 @@ if tc_has_feature valgrind ; then
 fi
 
 if [[ ${PN} != gnat-gpl ]] && tc_has_feature ada ; then
-	BDEPEND+="
-		ada? (
-			|| (
-				sys-devel/gcc:${SLOT}[ada]
-				<sys-devel/gcc-${SLOT}[ada]
-				<dev-lang/ada-bootstrap-${SLOT}
-				dev-lang/gnat-gpl[ada]
+	if tc_use_major_version_only ; then
+		BDEPEND+="
+			ada? (
+				|| (
+					sys-devel/gcc:${SLOT}[ada]
+					<sys-devel/gcc-${SLOT}[ada]
+					<dev-lang/ada-bootstrap-$((${SLOT} + 1))
+					dev-lang/gnat-gpl[ada]
+				)
 			)
-		)
-	"
+		"
+	else
+                BDEPEND+="
+                        ada? (
+                                || (
+                                        sys-devel/gcc:${SLOT}[ada]
+                                        <sys-devel/gcc-${SLOT}[ada]
+                                        <dev-lang/ada-bootstrap-${SLOT}
+                                        dev-lang/gnat-gpl[ada]
+                                )
+                        )
+                "
+	fi
 fi
 
 # TODO: Add a pkg_setup & pkg_pretend check for whether the active compiler
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-17 17:34 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-12-17 17:34 UTC (permalink / raw
  To: gentoo-commits
commit:     77810cba2a601d0c0870589850b9864ec59d9fe8
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Dec 17 17:33:53 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Dec 17 17:33:53 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=77810cba
toolchain.eclass: allow existing slot in has_version check for ada-bootstrap too
Followup to 14e674bb7a8cb8aa50498582e392d0ecd21f2d4a.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 4 +++-
 1 file changed, 3 insertions(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index b74984fc8ea8..8659a78be17e 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -983,7 +983,9 @@ toolchain_setup_ada() {
 	# As a penultimate resort, try dev-lang/ada-bootstrap.
 	if ver_test ${ada_bootstrap} -gt ${PV} || [[ -z ${ada_bootstrap} ]] ; then
 		ebegin "Testing fallback dev-lang/ada-bootstrap for Ada"
-		if has_version -b "<dev-lang/ada-bootstrap-${SLOT}" ; then
+		# XXX: This can be cleaned up like BDEPEND for tc_use_major_version_only
+		# once we only support such versions.
+		if has_version -b "=dev-lang/ada-bootstrap-${SLOT}*" || has_version -b "<dev-lang/ada-bootstrap-${SLOT}" ; then
 			# Workaround the old scheme
 			if has_version -b "=dev-lang/ada-bootstrap-0_p2021*" ; then
 				ada_bootstrap=10
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-17 21:44 Andreas Sturmlechner
  0 siblings, 0 replies; 6663+ messages in thread
From: Andreas Sturmlechner @ 2024-12-17 21:44 UTC (permalink / raw
  To: gentoo-commits
commit:     9b766950efcc78bf411ec7c2ca26c49174865c4f
Author:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
AuthorDate: Mon Dec 16 22:01:19 2024 +0000
Commit:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
CommitDate: Tue Dec 17 21:43:47 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=9b766950
office-ext-r1.eclass: Support EAPI-8
Signed-off-by: Andreas Sturmlechner <asturm <AT> gentoo.org>
 eclass/office-ext-r1.eclass | 28 +++++++++-------------------
 1 file changed, 9 insertions(+), 19 deletions(-)
diff --git a/eclass/office-ext-r1.eclass b/eclass/office-ext-r1.eclass
index 7e4d894483fe..9ee4561f0c11 100644
--- a/eclass/office-ext-r1.eclass
+++ b/eclass/office-ext-r1.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2023 Gentoo Authors
+# Copyright 1999-2024 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: office-ext-r1.eclass
@@ -6,13 +6,13 @@
 # The office team <office@gentoo.org>
 # @AUTHOR:
 # Tomáš Chvátal <scarabeus@gentoo.org>
-# @SUPPORTED_EAPIS: 7
+# @SUPPORTED_EAPIS: 7 8
 # @BLURB: Eclass for installing libreoffice extensions
 # @DESCRIPTION:
 # Eclass for easing maintenance of libreoffice extensions.
 
 case ${EAPI} in
-	7) ;;
+	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
@@ -70,11 +70,13 @@ fi
 # @CODE
 : "${OFFICE_EXTENSIONS_LOCATION:=${DISTDIR}}"
 
-IUSE=""
-RDEPEND=""
+# Most projects actually do not provide any relevant sourcedir as they are oxt.
+S="${WORKDIR}"
+
+IUSE="$(printf 'office_implementation_%s ' ${OFFICE_IMPLEMENTATIONS[@]})"
+REQUIRED_USE="|| ( $(printf 'office_implementation_%s ' ${OFFICE_IMPLEMENTATIONS[@]}) )"
 
 for i in ${OFFICE_IMPLEMENTATIONS[@]}; do
-	IUSE+=" office_implementation_${i}"
 	if [[ ${i} == "libreoffice" ]]; then
 		RDEPEND+="
 			office_implementation_${i}? (
@@ -86,19 +88,7 @@ for i in ${OFFICE_IMPLEMENTATIONS[@]}; do
 		"
 	fi
 done
-
-REQUIRED_USE="|| ( "
-for i in ${OFFICE_IMPLEMENTATIONS[@]}; do
-	REQUIRED_USE+=" office_implementation_${i} "
-done
-REQUIRED_USE+=" )"
-
-DEPEND="${RDEPEND}
-	app-arch/unzip
-"
-
-# Most projects actually do not provide any relevant sourcedir as they are oxt.
-S="${WORKDIR}"
+BDEPEND="app-arch/unzip"
 
 # @FUNCTION: office-ext-r1_src_unpack
 # @DESCRIPTION:
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-17 22:14 Andreas Sturmlechner
  0 siblings, 0 replies; 6663+ messages in thread
From: Andreas Sturmlechner @ 2024-12-17 22:14 UTC (permalink / raw
  To: gentoo-commits
commit:     10b4b0976610ae256e6f3bba5181ca57dfad0e08
Author:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
AuthorDate: Fri Dec 13 18:00:16 2024 +0000
Commit:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
CommitDate: Tue Dec 17 22:14:02 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=10b4b097
toolchain-funcs.eclass: Add tc-check-min_ver()
Signed-off-by: Andreas Sturmlechner <asturm <AT> gentoo.org>
 eclass/toolchain-funcs.eclass | 44 +++++++++++++++++++++++++++++++++++++++++++
 1 file changed, 44 insertions(+)
diff --git a/eclass/toolchain-funcs.eclass b/eclass/toolchain-funcs.eclass
index 2911ed66e63c..0abed5b8d75e 100644
--- a/eclass/toolchain-funcs.eclass
+++ b/eclass/toolchain-funcs.eclass
@@ -647,6 +647,50 @@ _tc-has-openmp() {
 	return ${ret}
 }
 
+# @FUNCTION: tc-check-min_ver
+# @USAGE: <gcc or clang> <minimum version>
+# @DESCRIPTION:
+# Minimum version of active GCC or Clang to require.
+#
+# You should test for any necessary minimum version in pkg_pretend in order to
+# warn the user of required toolchain changes.  You must still check for it at
+# build-time, e.g.
+# @CODE
+# pkg_pretend() {
+#	[[ ${MERGE_TYPE} != binary ]] && tc-check-min_ver gcc 13.2.0
+# }
+#
+# pkg_setup() {
+#	[[ ${MERGE_TYPE} != binary ]] && tc-check-min_ver gcc 13.2.0
+# }
+# @CODE
+tc-check-min_ver() {
+	do_check() {
+		debug-print "Compiler version check for ${1}"
+		debug-print "Detected: ${2}"
+		debug-print "Required: ${3}"
+		if ver_test ${2} -lt ${3}; then
+			eerror "Your current compiler is too old for this package!"
+			die "Active compiler is too old for this package (found ${1} ${2})."
+		fi
+	}
+
+	case ${1} in
+		gcc)
+			tc-is-gcc || return
+			do_check GCC $(gcc-version) ${2}
+			;;
+		clang)
+			tc-is-clang || return
+			do_check Clang $(clang-version) ${2}
+			;;
+		*)
+			eerror "Unknown first parameter for ${FUNCNAME} - must be gcc or clang"
+			die "${FUNCNAME}: Parameter ${1} unknown"
+			;;
+	esac
+}
+
 # @FUNCTION: tc-check-openmp
 # @DESCRIPTION:
 # Test for OpenMP support with the current compiler and error out with
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-18  2:46 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-12-18  2:46 UTC (permalink / raw
  To: gentoo-commits
commit:     b85da6096998aefba65d432607c12748efccc907
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Dec 18 02:45:05 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Dec 18 02:45:05 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=b85da609
toolchain.eclass: handle nvptx multilib changes in 15
GCC trunk recently changed its default multilib for nvptx. Make the
`mv` there nonfatal with some comments added. We may want to enable
all multilibs in future.
Bug: https://bugs.gentoo.org/945296
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 6 ++++--
 1 file changed, 4 insertions(+), 2 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 8659a78be17e..602f99437145 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -2805,8 +2805,10 @@ gcc_movelibs() {
 		mv "${ED}"/usr/nvptx-none/lib/mgomp/mptx-3.1/*.{a,spec} "${ED}"/usr/lib/gcc/${CHOST}/${GCCMAJOR}/accel/nvptx-none/mgomp/mptx-3.1/
 		mv "${ED}"/usr/lib/gcc/nvptx-none/${GCCMAJOR}/*.{a,spec} "${ED}"/usr/lib/gcc/${CHOST}/${GCCMAJOR}/accel/nvptx-none/ || die
 		mv "${ED}"/usr/lib/gcc/nvptx-none/${GCCMAJOR}/mgomp/*.{a,spec} "${ED}"/usr/lib/gcc/${CHOST}/${GCCMAJOR}/accel/nvptx-none/mgomp/ || die
-		mv "${ED}"/usr/lib/gcc/nvptx-none/${GCCMAJOR}/mptx-3.1/*.{a,spec} "${ED}"/usr/lib/gcc/${CHOST}/${GCCMAJOR}/accel/nvptx-none/mptx-3.1/ || die
-		mv "${ED}"/usr/lib/gcc/nvptx-none/${GCCMAJOR}/mgomp/mptx-3.1/*.{a,spec} "${ED}"/usr/lib/gcc/${CHOST}/${GCCMAJOR}/accel/nvptx-none/mgomp/mptx-3.1/ || die
+		# Nonfatal because the multilib variants change: see r15-5975-g86b3a7532d56f7 and r15-6029-gd4e1f7cfdb8375
+		# TODO: Should we enable all of them unconditionally? Expose it somehow (USE_EXPAND?)?
+		mv "${ED}"/usr/lib/gcc/nvptx-none/${GCCMAJOR}/mptx-3.1/*.{a,spec} "${ED}"/usr/lib/gcc/${CHOST}/${GCCMAJOR}/accel/nvptx-none/mptx-3.1/
+		mv "${ED}"/usr/lib/gcc/nvptx-none/${GCCMAJOR}/mgomp/mptx-3.1/*.{a,spec} "${ED}"/usr/lib/gcc/${CHOST}/${GCCMAJOR}/accel/nvptx-none/mgomp/mptx-3.1/
 	fi
 
 	# We remove directories separately to avoid this case:
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-18  3:00 Matt Turner
  0 siblings, 0 replies; 6663+ messages in thread
From: Matt Turner @ 2024-12-18  3:00 UTC (permalink / raw
  To: gentoo-commits
commit:     2b210d2cf3d12742d2109d82a3ea7f388c3641bd
Author:     Matt Turner <mattst88 <AT> gentoo <DOT> org>
AuthorDate: Tue Dec 17 04:14:28 2024 +0000
Commit:     Matt Turner <mattst88 <AT> gentoo <DOT> org>
CommitDate: Wed Dec 18 02:59:44 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=2b210d2c
xorg-3.eclass: Disallow EAPI=7
Signed-off-by: Matt Turner <mattst88 <AT> gentoo.org>
 eclass/xorg-3.eclass | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/eclass/xorg-3.eclass b/eclass/xorg-3.eclass
index ee4038533bfd..0d51be294051 100644
--- a/eclass/xorg-3.eclass
+++ b/eclass/xorg-3.eclass
@@ -8,7 +8,7 @@
 # Author: Tomáš Chvátal <scarabeus@gentoo.org>
 # Author: Donnie Berkholz <dberkholz@gentoo.org>
 # Author: Matt Turner <mattst88@gentoo.org>
-# @SUPPORTED_EAPIS: 7 8
+# @SUPPORTED_EAPIS: 8
 # @PROVIDES: multilib-minimal
 # @BLURB: Reduces code duplication in the modularized X11 ebuilds.
 # @DESCRIPTION:
@@ -23,7 +23,7 @@
 # everything else should be automatic.
 
 case ${EAPI} in
-	7|8) ;;
+	8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-18  3:00 Matt Turner
  0 siblings, 0 replies; 6663+ messages in thread
From: Matt Turner @ 2024-12-18  3:00 UTC (permalink / raw
  To: gentoo-commits
commit:     43a23c24493e561eae1ce88a4d2c10c82da4002b
Author:     Matt Turner <mattst88 <AT> gentoo <DOT> org>
AuthorDate: Tue Dec 17 04:13:10 2024 +0000
Commit:     Matt Turner <mattst88 <AT> gentoo <DOT> org>
CommitDate: Wed Dec 18 02:59:44 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=43a23c24
xorg-3.eclass: Change XORG_TARBALL_SUFFIX default from bz2 to xz
No ebuilds rely on the default being bz2.
Signed-off-by: Matt Turner <mattst88 <AT> gentoo.org>
 eclass/xorg-3.eclass | 5 ++---
 1 file changed, 2 insertions(+), 3 deletions(-)
diff --git a/eclass/xorg-3.eclass b/eclass/xorg-3.eclass
index 0d51be294051..2ca5959dd1e7 100644
--- a/eclass/xorg-3.eclass
+++ b/eclass/xorg-3.eclass
@@ -111,9 +111,8 @@ HOMEPAGE="https://www.x.org/wiki/ https://gitlab.freedesktop.org/xorg/${XORG_MOD
 # @ECLASS_VARIABLE: XORG_TARBALL_SUFFIX
 # @PRE_INHERIT
 # @DESCRIPTION:
-# Most X11 projects provide tarballs as tar.bz2 or tar.xz. This eclass defaults
-# to bz2.
-: "${XORG_TARBALL_SUFFIX:="bz2"}"
+# Most X11 projects provide tarballs as tar.xz. This eclass defaults to xz.
+: "${XORG_TARBALL_SUFFIX:="xz"}"
 
 if [[ ${PV} == *9999* ]]; then
 	: "${EGIT_REPO_URI:="https://gitlab.freedesktop.org/xorg/${XORG_MODULE}${XORG_PACKAGE_NAME}.git"}"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-21 10:28 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-12-21 10:28 UTC (permalink / raw
  To: gentoo-commits
commit:     a9320ac86aaeea1e98a4a25dd75a439c77bace7e
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Dec 21 10:10:29 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat Dec 21 10:28:04 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=a9320ac8
llvm.org.eclass: Add 20.0.0_pre20241221 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index 6a68bde89a46..e36e846801c3 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -72,6 +72,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 			_LLVM_SOURCE_TYPE=snapshot
 
 			case ${PV} in
+				20.0.0_pre20241221)
+					EGIT_COMMIT=665d79f2e967a5eee6fff93685e45f50cf24cab2
+					;;
 				20.0.0_pre20241215)
 					EGIT_COMMIT=49a5ad8e5714fd404210279303acc97b495d66d0
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-22  1:30 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-12-22  1:30 UTC (permalink / raw
  To: gentoo-commits
commit:     38e96b4caa2c618b9410e787c4b29cde207dab94
Author:     Eric Joldasov <bratishkaerik <AT> landless-city <DOT> net>
AuthorDate: Sun Dec 15 21:18:29 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Dec 22 01:27:47 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=38e96b4c
zig.eclass: fix rare spurious `error.BrokenPipe` during `src_test`
Most likely caused by `grep -q` processing too fast when steps are
filtered. Can sometimes be reproduced with this command (you might
need several retries to hit it):
```console
$ for i in {0..20}; do zig build --list-steps | grep -q test; done
error: BrokenPipe
/usr/lib64/zig/9999/lib/compiler/build_runner.zig:1229:9: 0x1518f3e in steps__anon_4736 (build)
        try out_stream.print("  {s:<28} {s}\n", .{ name, top_level_step.description });
        ^
/usr/lib64/zig/9999/lib/compiler/build_runner.zig:374:9: 0x1511b81 in main (build)
        return steps(builder, stdout_writer);
        ^
error: the following build command failed with exit code 1:
/home/bratishkaerik/github.com/zig/.zig-cache/o/4b3846557c333ec9e467b7cc136d3698/build /usr/lib64/zig/9999/bin/zig /usr/lib64/zig/9999/lib /home/bratishkaerik/github.com/zig /home/bratishkaerik/github.com/zig/.zig-cache /home/bratishkaerik/.cache/zig --seed 0x86f5c718 -Z7b5e4ad814524daf --list-steps
```
Caught this today when I merged and tested `dev-lang/zig:9999` 9 times
in a row because I was checking patch for upstream. Out of these 9 times
it failed only once. I couldn't reproduce this on `sys-fs/ncdu` or
`gui-wm/river::guru`, my guess here is that `test` step is listed last
there, so zig pipe catches up with it.
Signed-off-by: Eric Joldasov <bratishkaerik <AT> landless-city.net>
Closes: https://github.com/gentoo/gentoo/pull/39723
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/zig.eclass | 5 +++--
 1 file changed, 3 insertions(+), 2 deletions(-)
diff --git a/eclass/zig.eclass b/eclass/zig.eclass
index e838616ef72a..2a0178e66d71 100644
--- a/eclass/zig.eclass
+++ b/eclass/zig.eclass
@@ -520,9 +520,10 @@ zig_src_test() {
 	# by whitespaces is not enough for some cases.
 	# We probably need something like  "--list-steps names_only".
 	# In practice, almost nobody sets such names.
+	# Ignore failures like rare random "error.BrokenPipe" here.
+	# If they are real, they would appear in "ezig build test" anyway.
 	if grep -q '^[ ]*test[ ]' < <(
-		nonfatal ezig build --list-steps "${args[@]}" ||
-			die "ZBS: listing steps failed"
+		nonfatal ezig build --list-steps "${args[@]}"
 	); then
 		einfo "ZBS: testing with: ${args[@]}"
 		nonfatal ezig build test "${args[@]}" ||
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-22  3:20 Matt Jolly
  0 siblings, 0 replies; 6663+ messages in thread
From: Matt Jolly @ 2024-12-22  3:20 UTC (permalink / raw
  To: gentoo-commits
commit:     d393753de4be9164251344e887e97adfcc0f0bce
Author:     Matt Jolly <kangie <AT> gentoo <DOT> org>
AuthorDate: Mon Dec 16 23:45:07 2024 +0000
Commit:     Matt Jolly <kangie <AT> gentoo <DOT> org>
CommitDate: Sun Dec 22 03:13:08 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=d393753d
rust.eclass: be verbose when checking if a Rust is suitable
This commit enables the Rust eclass to provide feedback to users
on what it's actually doing and why a particular Rust was
(or was not) deemed suitable for use.
To do this we now:
- Explicitly note if a Rust slot was skipped due to LLVM_SLOT
  incompatibility
- Provide a python-utils-r1 style `Checking whether Rust SLOT is
  suitable ...` for each slot
- List each package (and usedep) that we are checking for
- Provide an error message that clearly explains the requirements
  if no suitable package is available.
`_get_rust_slot` has been adjusted to export RUST_SLOT and RUST_TYPE
if a suitable slot is found.
Still TODO is enhancing output for `rust_check_deps` (perhaps
ebegin/eend?), however there don't appear to be any consumers
in the wild, this can probably wait a little longer.
Signed-off-by: Matt Jolly <kangie <AT> gentoo.org>
 eclass/rust.eclass | 21 ++++++++++++++++-----
 1 file changed, 16 insertions(+), 5 deletions(-)
diff --git a/eclass/rust.eclass b/eclass/rust.eclass
index eb14ca2329b5..a7199f984af8 100644
--- a/eclass/rust.eclass
+++ b/eclass/rust.eclass
@@ -286,7 +286,8 @@ unset -f _rust_set_globals
 # @USAGE: [-b|-d]
 # @DESCRIPTION:
 # Find the newest Rust install that is acceptable for the package,
-# and print its version number (i.e. SLOT) and type (source or bin[ary]).
+# and export its version (i.e. SLOT) and type (source or bin[ary])
+# as RUST_SLOT and RUST_TYPE.
 #
 # If -b is specified, the checks are performed relative to BROOT,
 # and BROOT-path is returned. -b is the default.
@@ -363,10 +364,13 @@ _get_rust_slot() {
 		# If we're in LLVM mode we can skip any slots that don't match the selected USE
 		if [[ -n "${RUST_NEEDS_LLVM}" ]]; then
 			if [[ "${llvm_slot}" != "${llvm_r1_slot}" ]]; then
+				einfo "Skipping Rust ${slot} as it does not match llvm_slot_${llvm_r1_slot}"
 				continue
 			fi
 		fi
 
+		einfo "Checking whether Rust ${slot} is suitable ..."
+
 		if declare -f rust_check_deps >/dev/null; then
 			local RUST_SLOT="${slot}"
 			local LLVM_SLOT="${_RUST_LLVM_MAP[${slot}]}"
@@ -396,11 +400,13 @@ _get_rust_slot() {
 			esac
 			local _pkg
 			for _pkg in "${rust_pkgs[@]}"; do
+				einfo " Checking for ${_pkg} ..."
 				if has_version "${hv_switch}" "${_pkg}"; then
+					export RUST_SLOT="${slot}"
 					if [[ "${_pkg}" == "dev-lang/rust:${slot}${usedep}" ]]; then
-						echo "${slot} source"
+						export RUST_TYPE="source"
 					else
-						echo "${slot} binary"
+						export RUST_TYPE="binary"
 					fi
 					return
 				fi
@@ -418,7 +424,12 @@ _get_rust_slot() {
 		die "${FUNCNAME}: invalid max_slot=${max_slot}"
 	fi
 
-	die "No Rust slot${1:+ <= ${1}} satisfying the package's dependencies found installed!"
+	local requirement_msg=""
+	[[ -n "${RUST_MAX_VER}" ]] && requirement_msg+="<= ${RUST_MAX_VER} "
+	[[ -n "${RUST_MIN_VER}" ]] && requirement_msg+=">= ${RUST_MIN_VER} "
+	[[ -n "${RUST_REQ_USE}" ]] && requirement_msg+="with USE=${RUST_REQ_USE}"
+	requirement_msg="${requirement_msg% }"
+	die "No Rust matching requirements${requirement_msg:+ (${requirement_msg})} found installed!"
 }
 
 # @FUNCTION: get_rust_path
@@ -500,7 +511,7 @@ rust_pkg_setup() {
 	debug-print-function ${FUNCNAME} "$@"
 
 	if [[ ${MERGE_TYPE} != binary ]]; then
-		read -r RUST_SLOT RUST_TYPE <<< $(_get_rust_slot -b)
+		_get_rust_slot -b
 		rust_prepend_path "${RUST_SLOT}" "${RUST_TYPE}"
 		local prefix=$(get_rust_path "${BROOT}" "${RUST_SLOT}" "${RUST_TYPE}")
 		CARGO="${prefix}bin/cargo"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-22 19:41 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-12-22 19:41 UTC (permalink / raw
  To: gentoo-commits
commit:     438a09957f5e4d6885fee7982814b2071282e861
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Dec 22 19:40:11 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Dec 22 19:40:59 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=438a0995
rust.eclass: update get_rust_path for recent change
Speculative fix based on description in bug.
Closes: https://bugs.gentoo.org/946824
Fixes: d393753de4be9164251344e887e97adfcc0f0bce
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/rust.eclass | 5 ++---
 1 file changed, 2 insertions(+), 3 deletions(-)
diff --git a/eclass/rust.eclass b/eclass/rust.eclass
index a7199f984af8..30b6468d2a9b 100644
--- a/eclass/rust.eclass
+++ b/eclass/rust.eclass
@@ -471,9 +471,8 @@ get_rust_prefix() {
 	local prefix=${BROOT}
 	[[ ${1} == -d ]] && prefix=${ESYSROOT}
 
-	local slot rust_type
-	read -r slot rust_type <<< $(_get_rust_slot "$@")
-	get_rust_path "${prefix}" "${slot}" "${rust_type}"
+	_get_rust_slot "$@"
+	get_rust_path "${prefix}" "${RUST_SLOT}" "${RUST_TYPE}"
 }
 
 # @FUNCTION: rust_prepend_path
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-23 17:10 Andreas Sturmlechner
  0 siblings, 0 replies; 6663+ messages in thread
From: Andreas Sturmlechner @ 2024-12-23 17:10 UTC (permalink / raw
  To: gentoo-commits
commit:     212ef97914f409c33cf386aa88e1a17263b8011d
Author:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
AuthorDate: Mon Dec 23 05:43:17 2024 +0000
Commit:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
CommitDate: Mon Dec 23 17:08:14 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=212ef979
frameworks.kde.org.eclass: Simplify SLOT assignment
Signed-off-by: Andreas Sturmlechner <asturm <AT> gentoo.org>
 eclass/frameworks.kde.org.eclass | 15 +++++++--------
 1 file changed, 7 insertions(+), 8 deletions(-)
diff --git a/eclass/frameworks.kde.org.eclass b/eclass/frameworks.kde.org.eclass
index e1dc77c93561..f66a6b7efba5 100644
--- a/eclass/frameworks.kde.org.eclass
+++ b/eclass/frameworks.kde.org.eclass
@@ -46,15 +46,14 @@ SLOT=6
 if ver_test ${PV} -lt 5.240; then
 	SLOT=5
 fi
-if [[ ${PN} == extra-cmake-modules ]]; then
-	SLOT=0
-else
-	if [[ ${KDE_BUILD_TYPE} == release ]]; then
+case ${PN} in
+	extra-cmake-modules)
+		SLOT=0
+		;;
+	*)
 		SLOT=${SLOT}/${KDE_CATV}
-	else
-		SLOT=${SLOT}/9999
-	fi
-fi
+		;;
+esac
 
 # @ECLASS_VARIABLE: KDE_ORG_SCHEDULE_URI
 # @INTERNAL
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-25 15:08 Hans de Graaff
  0 siblings, 0 replies; 6663+ messages in thread
From: Hans de Graaff @ 2024-12-25 15:08 UTC (permalink / raw
  To: gentoo-commits
commit:     7dad58d9f7874a2f69fb594cbc031470180201ff
Author:     Hans de Graaff <graaff <AT> gentoo <DOT> org>
AuthorDate: Wed Dec 25 15:07:26 2024 +0000
Commit:     Hans de Graaff <graaff <AT> gentoo <DOT> org>
CommitDate: Wed Dec 25 15:08:21 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=7dad58d9
eclass/ruby-fakegem.eclass: install sig directory by default
The sig directory contains rbs type signatures and is showing up in more
and more gems. Install it when present by default.
Signed-off-by: Hans de Graaff <graaff <AT> gentoo.org>
 eclass/ruby-fakegem.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/ruby-fakegem.eclass b/eclass/ruby-fakegem.eclass
index fc78428be714..c358015902bb 100644
--- a/eclass/ruby-fakegem.eclass
+++ b/eclass/ruby-fakegem.eclass
@@ -624,7 +624,7 @@ each_fakegem_install() {
 	ruby_fakegem_install_gemspec
 
 	local _gemlibdirs="${RUBY_FAKEGEM_EXTRAINSTALL}"
-	for directory in "${RUBY_FAKEGEM_BINDIR}" lib; do
+	for directory in "${RUBY_FAKEGEM_BINDIR}" lib sig; do
 		[[ -d ${directory} ]] && _gemlibdirs="${_gemlibdirs} ${directory}"
 	done
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-26 10:59 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-12-26 10:59 UTC (permalink / raw
  To: gentoo-commits
commit:     bd408878bb57af9b91956f93eb86c8a32e137010
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Dec 26 10:01:35 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Dec 26 10:59:39 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=bd408878
guile-utils.eclass: set GUILE_AUTO_COMPILE=fresh
Noticed this when looking at app-office/gnucash which was disabling
GUILE_AUTO_COMPILE entirely (see 72dbf2ec4049df11ad63576971883ee239eadb7f).
We don't want Guile making decisions based on the system cache
files. Always recompile so we're deterministic.
See https://www.gnu.org/software/guile/manual/html_node/Environment-Variables.html#index-GUILE_005fAUTO_005fCOMPILE.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/guile-utils.eclass | 6 +++++-
 1 file changed, 5 insertions(+), 1 deletion(-)
diff --git a/eclass/guile-utils.eclass b/eclass/guile-utils.eclass
index b0660dcfd1ce..d066013486ed 100644
--- a/eclass/guile-utils.eclass
+++ b/eclass/guile-utils.eclass
@@ -84,10 +84,14 @@ guile_check_compat
 # @FUNCTION: guile_set_common_vars
 # @DESCRIPTION:
 # Sets common variables that apply to all Guile packages, namely,
-# QA_PREBUILT.
+# GUILE_AUTO_COMPILE and QA_PREBUILT.
 guile_set_common_vars() {
 	debug-print-function ${FUNCNAME} "$@"
 
+	# We don't want Guile making decisions based on the system cache
+	# files. Always recompile so we're deterministic.
+	export GUILE_AUTO_COMPILE=fresh
+
 	# These aren't strictly speaking prebuilt. but they do generated a
 	# nonstandard ELF object.
 	if [[ -z ${QA_PREBUILT} ]]; then
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-27 21:25 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-12-27 21:25 UTC (permalink / raw
  To: gentoo-commits
commit:     dc359ed71c4f83da39765fd80f81498dc8669b59
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Fri Dec 27 20:37:20 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Fri Dec 27 21:24:50 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=dc359ed7
llvm.org.eclass: Add 20.0.0_pre20241227 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index e36e846801c3..9b5be08eb1bb 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -72,6 +72,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 			_LLVM_SOURCE_TYPE=snapshot
 
 			case ${PV} in
+				20.0.0_pre20241227)
+					EGIT_COMMIT=ccfe0de0e1e37ed369c9bf89dd0188ba0afb2e9a
+					;;
 				20.0.0_pre20241221)
 					EGIT_COMMIT=665d79f2e967a5eee6fff93685e45f50cf24cab2
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-28 14:51 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2024-12-28 14:51 UTC (permalink / raw
  To: gentoo-commits
commit:     f198fe992017f2fde6d1ad6c9a99a1e5c76cfb50
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Dec 28 14:50:50 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Dec 28 14:51:29 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=f198fe99
mono-env.eclass: fix @SUPPORTED_EAPIS
I forgot to update this in 69a2292af3ff6086933650e3ffb59ef4e7e4acfc
which added EAPI 8 support.
Closes: https://bugs.gentoo.org/937112
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/mono-env.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/mono-env.eclass b/eclass/mono-env.eclass
index 5415a7043fed..2e19c0b744ee 100644
--- a/eclass/mono-env.eclass
+++ b/eclass/mono-env.eclass
@@ -4,7 +4,7 @@
 # @ECLASS: mono-env.eclass
 # @MAINTAINER:
 # maintainer-needed@gentoo.org
-# @SUPPORTED_EAPIS: 7
+# @SUPPORTED_EAPIS: 7 8
 # @BLURB: Set environment variables commonly used by dotnet packages.
 # @DESCRIPTION:
 # Set environment variables commonly used by dotnet packages.
^ permalink raw reply related	[flat|nested] 6663+ messages in thread
* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-28 19:43 Alfredo Tupone
  0 siblings, 0 replies; 6663+ messages in thread
From: Alfredo Tupone @ 2024-12-28 19:43 UTC (permalink / raw
  To: gentoo-commits
commit:     648bcbb7da7f164dfc27dd18326840808c06d01d
Author:     Alfredo Tupone <tupone <AT> gentoo <DOT> org>
AuthorDate: Sat Dec 28 19:42:59 2024 +0000
Commit:     Alfredo Tupone <tupone <AT> gentoo <DOT> org>
CommitDate: Sat Dec 28 19:43:25 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=648bcbb7
ada.eclass: add CHOST to gnatmake
Signed-off-by: Alfredo Tupone <tupone <AT> gentoo.org>
 eclass/ada.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/ada.eclass b/eclass/ada.eclass
index 9206bfcc42ca..3d22dd5d2a61 100644
--- a/eclass/ada.eclass
+++ b/eclass/ada.eclass
@@ -282,7 +282,7 @@ ada_export() {
 				debug-print "${FUNCNAME}: GNATBIND = ${GNATBIND}"
 				;;
 			GNATMAKE)
-				export GNATMAKE=${EPREFIX}/usr/bin/gnatmake-${gcc_pv}
+				export GNATMAKE=${EPREFIX}/usr/bin/${CHOST}-gnatmake-${gcc_pv}
 				debug-print "${FUNCNAME}: GNATMAKE = ${GNATMAKE}"
 				;;
 			GNATLS)
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-29  9:22 Ulrich Müller
  0 siblings, 0 replies; 6663+ messages in thread
From: Ulrich Müller @ 2024-12-29  9:22 UTC (permalink / raw
  To: gentoo-commits
commit:     8a6207aae78d8f1a13cb430ecf4728d11cd471b7
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Thu Dec 26 12:03:23 2024 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Sun Dec 29 09:22:04 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=8a6207aa
elisp.eclass: Call makeinfo with --no-split option
By default, makeinfo will split output files larger than 300 kB into
smaller subfiles. Although this doesn't currently happen for any elisp
package, it might happen in future and could break some assumptions.
This is also consistent with GNU Emacs itself which installs unsplit
Info files for its documentation.
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 eclass/elisp.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/elisp.eclass b/eclass/elisp.eclass
index 1fa8aab29753..e2f629edf132 100644
--- a/eclass/elisp.eclass
+++ b/eclass/elisp.eclass
@@ -139,7 +139,7 @@ elisp_src_configure() { :; }
 elisp_src_compile() {
 	elisp-compile *.el
 	if [[ -n ${ELISP_TEXINFO} ]]; then
-		makeinfo ${ELISP_TEXINFO} || die
+		makeinfo --no-split ${ELISP_TEXINFO} || die
 	fi
 }
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-30 11:35 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-12-30 11:35 UTC (permalink / raw
  To: gentoo-commits
commit:     58e2defd4a6146affe90fa265068c3a7a685be28
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Thu Dec 12 13:27:44 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Mon Dec 30 11:32:04 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=58e2defd
llvm-r2.eclass: Copy from llvm-r1.eclass
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm-r2.eclass | 257 ++++++++++++++++++++++++++++++++++++++++++++++++++
 1 file changed, 257 insertions(+)
diff --git a/eclass/llvm-r2.eclass b/eclass/llvm-r2.eclass
new file mode 100644
index 000000000000..6d0223f73f10
--- /dev/null
+++ b/eclass/llvm-r2.eclass
@@ -0,0 +1,257 @@
+# Copyright 2024 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+# @ECLASS: llvm-r2.eclass
+# @MAINTAINER:
+# Michał Górny <mgorny@gentoo.org>
+# @AUTHOR:
+# Michał Górny <mgorny@gentoo.org>
+# @SUPPORTED_EAPIS: 8
+# @PROVIDES: llvm-utils
+# @BLURB: Provide LLVM_SLOT to build against slotted LLVM
+# @DESCRIPTION:
+# An eclass to reliably depend on a set of LLVM-related packages
+# in a matching slot.  To use the eclass:
+#
+# 1. Set LLVM_COMPAT to the list of supported LLVM slots.
+#
+# 2. Use llvm_gen_dep and/or LLVM_USEDEP to add appropriate
+#    dependencies.
+#
+# 3. Use llvm-r2_pkg_setup, get_llvm_prefix or LLVM_SLOT.
+#
+# The eclass sets IUSE and REQUIRED_USE.  The flag corresponding
+# to the newest supported stable LLVM slot (or the newest testing,
+# if no stable slots are supported) is enabled by default.
+#
+# Example:
+# @CODE
+# LLVM_COMPAT=( {16..18} )
+#
+# inherit llvm-r2
+#
+# DEPEND="
+#   dev-libs/libfoo[${LLVM_USEDEP}]
+#   $(llvm_gen_dep '
+#     llvm-core/clang:${LLVM_SLOT}=
+#     llvm-core/llvm:${LLVM_SLOT}=
+#   ')
+# "
+# @CODE
+
+case ${EAPI} in
+	8) ;;
+	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
+esac
+
+if [[ -z ${_LLVM_R2_ECLASS} ]]; then
+_LLVM_R2_ECLASS=1
+
+inherit llvm-utils
+
+# == internal control knobs ==
+
+# @ECLASS_VARIABLE: _LLVM_OLDEST_SLOT
+# @INTERNAL
+# @DESCRIPTION:
+# Oldest supported LLVM slot.  This is used to automatically filter out
+# unsupported LLVM_COMPAT values.
+_LLVM_OLDEST_SLOT=15
+
+# @ECLASS_VARIABLE: _LLVM_NEWEST_STABLE
+# @INTERNAL
+# @DESCRIPTION:
+# The newest stable LLVM version.  Versions newer than that won't
+# be automatically enabled via USE defaults.
+_LLVM_NEWEST_STABLE=19
+
+# == control variables ==
+
+# @ECLASS_VARIABLE: LLVM_COMPAT
+# @PRE_INHERIT
+# @REQUIRED
+# @DESCRIPTION:
+# A list of LLVM slots supported by the package, oldest to newest.
+#
+# Example:
+# @CODE
+# LLVM_COMPAT=( {15..17} )
+# @CODE
+
+# @ECLASS_VARIABLE: LLVM_OPTIONAL
+# @PRE_INHERIT
+# @DEFAULT_UNSET
+# @DESCRIPTION:
+# If set to a non-empty value, disables setting REQUIRED_USE
+# and exporting pkg_setup.  You have to add LLVM_REQUIRED_USE and call
+# pkg_setup manually, with appropriate USE conditions.
+
+# == global metadata ==
+
+# @ECLASS_VARIABLE: LLVM_REQUIRED_USE
+# @OUTPUT_VARIABLE
+# @DESCRIPTION:
+# An eclass-generated REQUIRED_USE string that enforces selecting
+# exactly one slot.  It LLVM_OPTIONAL is set, it needs to be copied
+# into REQUIRED_USE, under appropriate USE conditions.  Otherwise,
+# it is added automatically.
+
+# @ECLASS_VARIABLE: LLVM_USEDEP
+# @OUTPUT_VARIABLE
+# @DESCRIPTION:
+# An eclass-generated USE dependency string that can be applied to other
+# packages using the same eclass, to enforce a LLVM slot match.
+
+_llvm_set_globals() {
+	debug-print-function ${FUNCNAME} "$@"
+
+	if [[ ${LLVM_COMPAT@a} != *a* ]]; then
+		die "LLVM_COMPAT must be set to an array before inheriting ${ECLASS}"
+	fi
+
+	local stable=() unstable=()
+	local x
+	for x in "${LLVM_COMPAT[@]}"; do
+		if [[ ${x} -gt ${_LLVM_NEWEST_STABLE} ]]; then
+			unstable+=( "${x}" )
+		elif [[ ${x} -ge ${_LLVM_OLDEST_SLOT} ]]; then
+			stable+=( "${x}" )
+		fi
+	done
+
+	_LLVM_SLOTS=( "${stable[@]}" "${unstable[@]}" )
+	if [[ ! ${_LLVM_SLOTS[@]} ]]; then
+		die "LLVM_COMPAT does not contain any valid versions (all older than ${_LLVM_OLDEST_SLOT}?)"
+	fi
+
+	if [[ ${stable[@]} ]]; then
+		# If there is at least one stable slot supported, then enable
+		# the newest stable slot by default.
+		IUSE="+llvm_slot_${stable[-1]}"
+		unset 'stable[-1]'
+	else
+		# Otherwise, enable the "oldest" ~arch slot.  We really only
+		# expect a single ~arch version, so this primarily prevents
+		# defaulting to non-keyworded slots.
+		IUSE="+llvm_slot_${unstable[0]}"
+		unset 'unstable[0]'
+	fi
+	local nondefault=( "${stable[@]}" "${unstable[@]}" )
+	IUSE+=" ${nondefault[*]/#/llvm_slot_}"
+
+	local flags=( "${_LLVM_SLOTS[@]/#/llvm_slot_}" )
+	LLVM_REQUIRED_USE="^^ ( ${flags[*]} )"
+	local usedep_flags=${flags[*]/%/(-)?}
+	LLVM_USEDEP=${usedep_flags// /,}
+	readonly LLVM_REQUIRED_USE LLVM_USEDEP
+
+	if [[ ! ${LLVM_OPTIONAL} ]]; then
+		REQUIRED_USE=${LLVM_REQUIRED_USE}
+	fi
+}
+_llvm_set_globals
+unset -f _llvm_set_globals
+
+# == metadata helpers ==
+
+# @FUNCTION: llvm_gen_dep
+# @USAGE: <dependency>
+# @DESCRIPTION:
+# Output a dependency block, repeating "<dependency>" conditionally
+# to all llvm_slot_* USE flags.  Any occurences of '${LLVM_SLOT}'
+# within the block will be substituted for the respective slot.
+#
+# Example:
+# @CODE
+# DEPEND="
+#   $(llvm_gen_dep '
+#     llvm-core/clang:${LLVM_SLOT}=
+#     llvm-core/llvm:${LLVM_SLOT}=
+#   ')
+# "
+# @CODE
+llvm_gen_dep() {
+	debug-print-function ${FUNCNAME} "$@"
+
+	[[ ${#} -ne 1 ]] && die "Usage: ${FUNCNAME} <dependency>"
+
+	local dep=${1}
+
+	local slot
+	for slot in "${_LLVM_SLOTS[@]}"; do
+		echo "llvm_slot_${slot}? ( ${dep//\$\{LLVM_SLOT\}/${slot}} )"
+	done
+}
+
+# == ebuild helpers ==
+
+# @FUNCTION: get_llvm_prefix
+# @USAGE: [-b|-d]
+# @DESCRIPTION:
+# Output the path to the selected LLVM slot.
+#
+# With no option or "-d", the path is prefixed by ESYSROOT.  LLVM
+# dependencies should be in DEPEND then.
+#
+# With "-b" option, the path is prefixed by BROOT. LLVM dependencies
+# should be in BDEPEND then.
+get_llvm_prefix() {
+	debug-print-function ${FUNCNAME} "$@"
+
+	[[ ${#} -gt 1 ]] && die "Usage: ${FUNCNAME} [-b|-d]"
+
+	local prefix
+	case ${1--d} in
+		-d)
+			prefix=${ESYSROOT}
+			;;
+		-b)
+			prefix=${BROOT}
+			;;
+		*)
+			die "${FUNCNAME}: invalid option: ${1}"
+			;;
+	esac
+
+	echo "${prefix}/usr/lib/llvm/${LLVM_SLOT}"
+}
+
+# @FUNCTION: llvm-r2_pkg_setup
+# @DESCRIPTION:
+# Prepend the appropriate executable directory for the selected LLVM
+# slot to PATH.
+#
+# The PATH manipulation is only done for source builds. The function
+# is a no-op when installing a binary package.
+#
+# If any other behavior is desired, the contents of the function
+# should be inlined into the ebuild and modified as necessary.
+#
+# Note that this function is not exported if LLVM_OPTIONAL is set.
+# In that case, it needs to be called manually.
+llvm-r2_pkg_setup() {
+	debug-print-function ${FUNCNAME} "$@"
+
+	if [[ ${MERGE_TYPE} != binary ]]; then
+		[[ -z ${LLVM_SLOT} ]] && die "LLVM_SLOT unset (broken USE_EXPAND?)"
+
+		llvm_fix_clang_version CC CPP CXX
+		# keep in sync with profiles/features/llvm/make.defaults!
+		llvm_fix_tool_path ADDR2LINE AR AS LD NM OBJCOPY OBJDUMP RANLIB
+		llvm_fix_tool_path READELF STRINGS STRIP
+
+		# Set LLVM_CONFIG to help Meson (bug #907965) but only do it
+		# for empty ESYSROOT (as a proxy for "are we cross-compiling?").
+		if [[ -z ${ESYSROOT} ]] ; then
+			llvm_fix_tool_path LLVM_CONFIG
+		fi
+
+		llvm_prepend_path "${LLVM_SLOT}"
+	fi
+}
+
+fi
+
+if [[ ! ${LLVM_OPTIONAL} ]]; then
+	EXPORT_FUNCTIONS pkg_setup
+fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-30 11:35 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-12-30 11:35 UTC (permalink / raw
  To: gentoo-commits
commit:     bc0ec53fa675fe53b95cdf997c3d33dd4b2fdca0
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Thu Dec 12 13:27:22 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Mon Dec 30 11:32:03 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=bc0ec53f
llvm-r1.eclass: Fix list in eclassdoc
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm-r1.eclass | 2 ++
 1 file changed, 2 insertions(+)
diff --git a/eclass/llvm-r1.eclass b/eclass/llvm-r1.eclass
index 7326e3a6b271..e59bd9c317b9 100644
--- a/eclass/llvm-r1.eclass
+++ b/eclass/llvm-r1.eclass
@@ -14,8 +14,10 @@
 # in a matching slot.  To use the eclass:
 #
 # 1. Set LLVM_COMPAT to the list of supported LLVM slots.
+#
 # 2. Use llvm_gen_dep and/or LLVM_USEDEP to add appropriate
 #    dependencies.
+#
 # 3. Use llvm-r1_pkg_setup, get_llvm_prefix or LLVM_SLOT.
 #
 # The eclass sets IUSE and REQUIRED_USE.  The flag corresponding
^ permalink raw reply related	[flat|nested] 6663+ messages in thread
* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-30 11:35 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-12-30 11:35 UTC (permalink / raw
  To: gentoo-commits
commit:     caac268d789d91d16960452a3d6466474acf0fa8
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sun Dec 29 16:14:54 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Mon Dec 30 11:32:36 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=caac268d
llvm-r2.eclass: add Polly_ROOT
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
Closes: https://github.com/gentoo/gentoo/pull/39696
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm-r2.eclass | 1 +
 1 file changed, 1 insertion(+)
diff --git a/eclass/llvm-r2.eclass b/eclass/llvm-r2.eclass
index 5fc39945875c..4dda9aedc7c6 100644
--- a/eclass/llvm-r2.eclass
+++ b/eclass/llvm-r2.eclass
@@ -428,6 +428,7 @@ llvm_chost_setup() {
 	export Clang_ROOT="${esysroot_prefix}"
 	export LLD_ROOT="${esysroot_prefix}"
 	export MLIR_ROOT="${esysroot_prefix}"
+	export Polly_ROOT="${esysroot_prefix}"
 
 	# satisfies llvm-config calls, e.g. from meson
 	export PATH="${T}/llvm-bin:${PATH}"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-30 11:35 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-12-30 11:35 UTC (permalink / raw
  To: gentoo-commits
commit:     ba77142fd668fd93a03f188cf2bcc791624ca05b
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Mon Dec 16 07:50:30 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Mon Dec 30 11:32:29 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=ba77142f
llvm-utils.eclass: Support -b/-d to llvm_prepend_path
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm-utils.eclass | 27 ++++++++++++++++++++++++---
 1 file changed, 24 insertions(+), 3 deletions(-)
diff --git a/eclass/llvm-utils.eclass b/eclass/llvm-utils.eclass
index 1ae3295484c8..b105e169fbc4 100644
--- a/eclass/llvm-utils.eclass
+++ b/eclass/llvm-utils.eclass
@@ -113,17 +113,38 @@ llvm_fix_tool_path() {
 }
 
 # @FUNCTION: llvm_prepend_path
-# @USAGE: <slot>
+# @USAGE: [-b|-d] <slot>
 # @DESCRIPTION:
 # Prepend the path to the specified LLVM slot to PATH variable,
 # and reexport it.
+#
+# With no option or "-d", the path is prefixed by ESYSROOT.  LLVM
+# dependencies should be in DEPEND then.
+#
+# With "-b" option, the path is prefixed by BROOT. LLVM dependencies
+# should be in BDEPEND then.
 llvm_prepend_path() {
 	debug-print-function ${FUNCNAME} "$@"
 
-	[[ ${#} -ne 1 ]] && die "Usage: ${FUNCNAME} <slot>"
+	local prefix
+	case ${1--d} in
+		-d)
+			prefix=${ESYSROOT}
+			shift
+			;;
+		-b)
+			prefix=${BROOT}
+			shift
+			;;
+		-*)
+			die "${FUNCNAME}: invalid option: ${1}"
+			;;
+	esac
+
+	[[ ${#} -ne 1 ]] && die "Usage: ${FUNCNAME} [-b|-d] <slot>"
 	local slot=${1}
 
-	local llvm_path=${ESYSROOT}/usr/lib/llvm/${slot}/bin
+	local llvm_path=${prefix}/usr/lib/llvm/${slot}/bin
 	local IFS=:
 	local split_path=( ${PATH} )
 	local new_path=()
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-30 11:35 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-12-30 11:35 UTC (permalink / raw
  To: gentoo-commits
commit:     4f071c7272814a2eca93a24a61930ec5fd357014
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Wed Dec 18 12:29:50 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Mon Dec 30 11:32:32 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=4f071c72
llvm-r2.eclass: Remove obsolete Meson LLVM_CONFIG hack
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm-r2.eclass | 7 -------
 1 file changed, 7 deletions(-)
diff --git a/eclass/llvm-r2.eclass b/eclass/llvm-r2.eclass
index 3d18f1a0a19c..4c2628dd3b7e 100644
--- a/eclass/llvm-r2.eclass
+++ b/eclass/llvm-r2.eclass
@@ -401,13 +401,6 @@ llvm_cbuild_setup() {
 	# keep in sync with profiles/features/llvm/make.defaults!
 	llvm_fix_tool_path ADDR2LINE AR AS LD NM OBJCOPY OBJDUMP RANLIB
 	llvm_fix_tool_path READELF STRINGS STRIP
-
-	# Set LLVM_CONFIG to help Meson (bug #907965) but only do it
-	# for empty ESYSROOT (as a proxy for "are we cross-compiling?").
-	if [[ -z ${ESYSROOT} ]] ; then
-		llvm_fix_tool_path LLVM_CONFIG
-	fi
-
 	llvm_prepend_path -b "${LLVM_SLOT}"
 }
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-30 11:35 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-12-30 11:35 UTC (permalink / raw
  To: gentoo-commits
commit:     9675dfad09d92b64ea05adabbd2ea9bbe221de59
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Mon Dec 16 10:37:29 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Mon Dec 30 11:32:31 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=9675dfad
llvm-r2.eclass: Generate a llvm-config script for CHOST
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm-r2.eclass | 173 +++++++++++++++++++++++++++++++++++++++++++++++++-
 1 file changed, 172 insertions(+), 1 deletion(-)
diff --git a/eclass/llvm-r2.eclass b/eclass/llvm-r2.eclass
index 91e841821331..e499f9dba38d 100644
--- a/eclass/llvm-r2.eclass
+++ b/eclass/llvm-r2.eclass
@@ -216,6 +216,162 @@ get_llvm_prefix() {
 	echo "${prefix}/usr/lib/llvm/${LLVM_SLOT}"
 }
 
+# @FUNCTION: generate_llvm_config
+# @DESCRIPTION:
+# Output a llvm-config compatible script that yields paths specific
+# to the requested LLVM version.
+generate_llvm_config() {
+	debug-print-function ${FUNCNAME} "$@"
+
+	local bindir=$(get_llvm_prefix -b)/bin
+	[[ ! -d ${bindir} ]] && bindir=
+
+	local prefix=$(get_llvm_prefix -d)
+	local includedir=${prefix}/include
+	local libdir=${prefix}/$(get_libdir)
+	local cmake_conf=${libdir}/cmake/llvm/LLVMConfig.cmake
+	if [[ ! -f ${cmake_conf} ]]; then
+		cat <<-EOF
+			#!/usr/bin/env sh
+			echo "LLVM ${LLVM_SLOT} not installed for ABI=${ABI}" >&2
+			exit 127
+		EOF
+		return
+	fi
+
+	local version=$(
+		sed -ne 's:set(LLVM_PACKAGE_VERSION \(.*\)):\1:p' "${cmake_conf}" || die
+	)
+	[[ -n ${version} ]] || die
+	local cppdefs=$(
+		sed -ne 's:set(LLVM_DEFINITIONS "\(.*\)"):\1:p' "${cmake_conf}" || die
+	)
+	[[ -n ${cppdefs} ]] || die
+	local targets=$(
+		sed -ne 's:set(LLVM_TARGETS_TO_BUILD \(.*\)):\1:p' "${cmake_conf}" || die
+	)
+	[[ -n ${targets} ]] || die
+	local libs=$(
+		sed -ne 's:set(LLVM_AVAILABLE_LIBS \(.*\)):\1:p' "${cmake_conf}" || die
+	)
+	[[ -n ${libs} ]] || die
+	local target_triple=$(
+		sed -ne 's:set(LLVM_TARGET_TRIPLE "\(.*\)"):\1:p' "${cmake_conf}" || die
+	)
+	[[ -n ${target_triple} ]] || die
+
+	readarray -d';' -t targets <<<"${targets}"
+	readarray -d';' -t libs <<<"${libs}"
+	# easier than parsing CMake booleans
+	local assertions=OFF
+	[[ ${cppdefs} == *-D_DEBUG* ]] && assertions=ON
+	# major + suffix
+	local shlib_name=LLVM-${version%%.*}
+	[[ ${version} == *git* ]] && shlib_name+="git${version##*git}"
+
+	local components=(
+		"${libs[@]#LLVM}" "${targets[@]}"
+		# special component groups (grep for add_llvm_component_group)
+		all all-targets engine native nativecodegen
+	)
+
+	cat <<-EOF
+		#!/usr/bin/env sh
+
+		echo "\${0} \${*}" >> "${T}/llvm-config-calls.txt"
+
+		do_echo() {
+			echo "  \${*}" >> "${T}/llvm-config-calls.txt"
+			echo "\${@}"
+		}
+
+		for arg; do
+			case \${arg} in
+				--assertion-mode)
+					do_echo "${assertions}"
+					;;
+				--bindir)
+					if [ -n "${bindir}" ]; then
+						do_echo "${bindir}"
+					else
+						do_echo "CBUILD LLVM not available" >&2
+						exit 1
+					fi
+					;;
+				--build-mode)
+					do_echo RelWithDebInfo
+					;;
+				--build-system)
+					do_echo cmake
+					;;
+				--cflags|--cppflags)
+					do_echo "-I${includedir} ${cppdefs[*]}"
+					;;
+				--cmakedir)
+					do_echo "${libdir}/cmake/llvm"
+					;;
+				--components)
+					do_echo "${components[*],,}"
+					;;
+				--cxxflags)
+					do_echo "-I${includedir} -std=c++17 ${cppdefs[*]}"
+					;;
+				--has-rtti)
+					do_echo YES
+					;;
+				--host-target)
+					do_echo "${target_triple}"
+					;;
+				--ignore-libllvm)
+					# ignored
+					;;
+				--includedir)
+					do_echo "${includedir}"
+					;;
+				--ldflags)
+					do_echo "-L${libdir}"
+					;;
+				--libdir)
+					do_echo "${libdir}"
+					;;
+				--libfiles)
+					do_echo "${libdir}/lib${shlib_name}.so"
+					;;
+				--libnames)
+					do_echo lib${shlib_name}.so
+					;;
+				--libs)
+					do_echo "-l${shlib_name}"
+					;;
+				--link-shared|--link-static)
+					# ignored
+					;;
+				--obj-root|--prefix)
+					do_echo "${prefix}"
+					;;
+				--shared-mode)
+					do_echo shared
+					;;
+				--system-libs)
+					do_echo
+					;;
+				--targets-built)
+					do_echo "${targets[*]}"
+					;;
+				--version)
+					do_echo "${version}"
+					;;
+				-*)
+					do_echo "Unsupported option: \${arg}" >&2
+					exit 1
+					;;
+				*)
+					# ignore components, we always return the dylib
+					;;
+			esac
+		done
+	EOF
+}
 # @FUNCTION: llvm_cbuild_setup
 # @DESCRIPTION:
 # Prepend the PATH for selected LLVM version in CBUILD.
@@ -251,11 +407,14 @@ llvm_cbuild_setup() {
 # @FUNCTION: llvm_chost_setup
 # @DESCRIPTION:
 # Set the environment for finding selected LLVM slot installed
-# for CHOST.
+# for CHOST.  Create llvm-config wrappers to satisfy legacy lookups.
 #
 # This function is meant to be used when the package in question uses
 # LLVM compiles against and links to LLVM.  It is called automatically
 # by llvm-r2_pkg_setup if LLVM is found installed in ESYSROOT.
+#
+# Note that the generated llvm-config may refer to CBUILD installation
+# of LLVM via --bindir, if it is found available.
 llvm_chost_setup() {
 	debug-print-function ${FUNCNAME} "$@"
 
@@ -268,6 +427,18 @@ llvm_chost_setup() {
 	export LLVM_ROOT="${esysroot_prefix}"
 	export Clang_ROOT="${esysroot_prefix}"
 	export LLD_ROOT="${esysroot_prefix}"
+
+	# satisfies llvm-config calls, e.g. from meson
+	export PATH="${T}/llvm-bin:${PATH}"
+	mkdir "${T}"/llvm-bin || die
+	# we need to generate it per-ABI, since libdir changes
+	local ABI
+	for ABI in $(get_all_abis); do
+		local path="${T}/llvm-bin/$(get_abi_CHOST)-llvm-config"
+		generate_llvm_config > "${path}" || die
+		chmod +x "${path}" || die
+	done
+	ln -s "$(get_abi_CHOST)-llvm-config" "${T}/llvm-bin/llvm-config" || die
 }
 
 # @FUNCTION: llvm-r2_pkg_setup
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-30 11:35 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-12-30 11:35 UTC (permalink / raw
  To: gentoo-commits
commit:     d9a6a468bb2c0a16c62cb9b4f22369b5c99a34a9
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sun Dec 22 19:23:18 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Mon Dec 30 11:32:35 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=d9a6a468
llvm-r2.eclass: Add MLIR_ROOT
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm-r2.eclass | 1 +
 1 file changed, 1 insertion(+)
diff --git a/eclass/llvm-r2.eclass b/eclass/llvm-r2.eclass
index 4c2628dd3b7e..5fc39945875c 100644
--- a/eclass/llvm-r2.eclass
+++ b/eclass/llvm-r2.eclass
@@ -427,6 +427,7 @@ llvm_chost_setup() {
 	export LLVM_ROOT="${esysroot_prefix}"
 	export Clang_ROOT="${esysroot_prefix}"
 	export LLD_ROOT="${esysroot_prefix}"
+	export MLIR_ROOT="${esysroot_prefix}"
 
 	# satisfies llvm-config calls, e.g. from meson
 	export PATH="${T}/llvm-bin:${PATH}"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-30 11:35 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-12-30 11:35 UTC (permalink / raw
  To: gentoo-commits
commit:     93056be235ad8804d3865005737ed6b54ac9aad3
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Mon Dec 16 10:17:59 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Mon Dec 30 11:32:29 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=93056be2
llvm-r2.eclass: Readjust for BROOT, split to llvm_cbuild_setup
Readjust the old pkg_setup logic for BROOT tool use, move it to
llvm_cbuild_setup function.
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm-r2.eclass | 45 ++++++++++++++++++++++++++++++++++-----------
 1 file changed, 34 insertions(+), 11 deletions(-)
diff --git a/eclass/llvm-r2.eclass b/eclass/llvm-r2.eclass
index 6d0223f73f10..93c16e75be83 100644
--- a/eclass/llvm-r2.eclass
+++ b/eclass/llvm-r2.eclass
@@ -216,6 +216,38 @@ get_llvm_prefix() {
 	echo "${prefix}/usr/lib/llvm/${LLVM_SLOT}"
 }
 
+# @FUNCTION: llvm_cbuild_setup
+# @DESCRIPTION:
+# Prepend the PATH for selected LLVM version in CBUILD.
+#
+# This function is meant to be used when the package in question uses
+# LLVM tools at build time.  It is called automatically
+# by llvm-r2_pkg_setup if LLVM is found installed in BROOT.
+#
+# Note that llvm-config from this path must not be used to build against
+# LLVM, as that will break cross-compilation.
+llvm_cbuild_setup() {
+	debug-print-function ${FUNCNAME} "$@"
+
+	local broot_prefix=$(get_llvm_prefix -b)
+	einfo "Using ${broot_prefix} for CBUILD LLVM ${LLVM_SLOT}"
+	[[ -d ${broot_prefix}/bin ]] ||
+		die "LLVM ${LLVM_SLOT} not found installed in BROOT (expected: ${broot_prefix}/bin)"
+
+	llvm_fix_clang_version CC CPP CXX
+	# keep in sync with profiles/features/llvm/make.defaults!
+	llvm_fix_tool_path ADDR2LINE AR AS LD NM OBJCOPY OBJDUMP RANLIB
+	llvm_fix_tool_path READELF STRINGS STRIP
+
+	# Set LLVM_CONFIG to help Meson (bug #907965) but only do it
+	# for empty ESYSROOT (as a proxy for "are we cross-compiling?").
+	if [[ -z ${ESYSROOT} ]] ; then
+		llvm_fix_tool_path LLVM_CONFIG
+	fi
+
+	llvm_prepend_path -b "${LLVM_SLOT}"
+}
+
 # @FUNCTION: llvm-r2_pkg_setup
 # @DESCRIPTION:
 # Prepend the appropriate executable directory for the selected LLVM
@@ -235,18 +267,9 @@ llvm-r2_pkg_setup() {
 	if [[ ${MERGE_TYPE} != binary ]]; then
 		[[ -z ${LLVM_SLOT} ]] && die "LLVM_SLOT unset (broken USE_EXPAND?)"
 
-		llvm_fix_clang_version CC CPP CXX
-		# keep in sync with profiles/features/llvm/make.defaults!
-		llvm_fix_tool_path ADDR2LINE AR AS LD NM OBJCOPY OBJDUMP RANLIB
-		llvm_fix_tool_path READELF STRINGS STRIP
-
-		# Set LLVM_CONFIG to help Meson (bug #907965) but only do it
-		# for empty ESYSROOT (as a proxy for "are we cross-compiling?").
-		if [[ -z ${ESYSROOT} ]] ; then
-			llvm_fix_tool_path LLVM_CONFIG
+		if [[ -d $(get_llvm_prefix -b)/bin ]]; then
+			llvm_cbuild_setup
 		fi
-
-		llvm_prepend_path "${LLVM_SLOT}"
 	fi
 }
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-30 11:35 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-12-30 11:35 UTC (permalink / raw
  To: gentoo-commits
commit:     c774f99101c5c940c92fea36061e838ce7514c3e
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Mon Dec 16 10:24:07 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Mon Dec 30 11:32:30 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=c774f991
llvm-r2.eclass: Add llvm_chost_setup, set CMake path variables
Add a llvm_chost_setup function that handles CHOST-specific setup.
Initially, this means setting CMake variables that control
`find_package()` lookups.
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm-r2.eclass | 37 ++++++++++++++++++++++++++++++-------
 1 file changed, 30 insertions(+), 7 deletions(-)
diff --git a/eclass/llvm-r2.eclass b/eclass/llvm-r2.eclass
index 93c16e75be83..91e841821331 100644
--- a/eclass/llvm-r2.eclass
+++ b/eclass/llvm-r2.eclass
@@ -248,16 +248,35 @@ llvm_cbuild_setup() {
 	llvm_prepend_path -b "${LLVM_SLOT}"
 }
 
-# @FUNCTION: llvm-r2_pkg_setup
+# @FUNCTION: llvm_chost_setup
 # @DESCRIPTION:
-# Prepend the appropriate executable directory for the selected LLVM
-# slot to PATH.
+# Set the environment for finding selected LLVM slot installed
+# for CHOST.
 #
-# The PATH manipulation is only done for source builds. The function
-# is a no-op when installing a binary package.
+# This function is meant to be used when the package in question uses
+# LLVM compiles against and links to LLVM.  It is called automatically
+# by llvm-r2_pkg_setup if LLVM is found installed in ESYSROOT.
+llvm_chost_setup() {
+	debug-print-function ${FUNCNAME} "$@"
+
+	local esysroot_prefix=$(get_llvm_prefix -d)
+	einfo "Using ${esysroot_prefix} for CHOST LLVM ${LLVM_SLOT}"
+	[[ -d ${esysroot_prefix} ]] ||
+		die "LLVM ${LLVM_SLOT} not found installed in ESYSROOT (expected: ${esysroot_prefix})"
+
+	# satisfies find_package() in CMake
+	export LLVM_ROOT="${esysroot_prefix}"
+	export Clang_ROOT="${esysroot_prefix}"
+	export LLD_ROOT="${esysroot_prefix}"
+}
+
+# @FUNCTION: llvm-r2_pkg_setup
+# @DESCRIPTION:
+# Handle all supported setup actions automatically.  If LLVM is found
+# installed for CBUILD, call llvm_cbuild_setup.  If it is found
+# installed for CHOST, call llvm_chost_setup.
 #
-# If any other behavior is desired, the contents of the function
-# should be inlined into the ebuild and modified as necessary.
+# This function is a no-op when installing a binary package.
 #
 # Note that this function is not exported if LLVM_OPTIONAL is set.
 # In that case, it needs to be called manually.
@@ -270,6 +289,10 @@ llvm-r2_pkg_setup() {
 		if [[ -d $(get_llvm_prefix -b)/bin ]]; then
 			llvm_cbuild_setup
 		fi
+
+		if [[ -d $(get_llvm_prefix -d) ]]; then
+			llvm_chost_setup
+		fi
 	fi
 }
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2024-12-30 11:35 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2024-12-30 11:35 UTC (permalink / raw
  To: gentoo-commits
commit:     0493ab731361510edde65db19ae95cc350fffdc2
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Mon Dec 16 10:40:46 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Mon Dec 30 11:32:32 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=0493ab73
llvm-r2.eclass: Update top-level docs for CBUILD/CHOST support
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm-r2.eclass | 9 ++++++++-
 1 file changed, 8 insertions(+), 1 deletion(-)
diff --git a/eclass/llvm-r2.eclass b/eclass/llvm-r2.eclass
index e499f9dba38d..3d18f1a0a19c 100644
--- a/eclass/llvm-r2.eclass
+++ b/eclass/llvm-r2.eclass
@@ -18,12 +18,19 @@
 # 2. Use llvm_gen_dep and/or LLVM_USEDEP to add appropriate
 #    dependencies.
 #
-# 3. Use llvm-r2_pkg_setup, get_llvm_prefix or LLVM_SLOT.
+# 3. Use llvm-r2_pkg_setup, llvm_chost_setup, llvm_cbuild_setup,
+#    get_llvm_prefix or LLVM_SLOT.
 #
 # The eclass sets IUSE and REQUIRED_USE.  The flag corresponding
 # to the newest supported stable LLVM slot (or the newest testing,
 # if no stable slots are supported) is enabled by default.
 #
+# Note that the eclass aims for a best-effort support of CHOST builds
+# (i.e. compiling/linking against LLVM) and CBUILD use (i.e. calling
+# LLVM tools at build time).  You need to determine what the package
+# in question needs, and put the appropriate packages in DEPEND and/or
+# BDEPEND appropriately.
+#
 # Example:
 # @CODE
 # LLVM_COMPAT=( {16..18} )
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-01-01 10:06 James Le Cuirot
  0 siblings, 0 replies; 6663+ messages in thread
From: James Le Cuirot @ 2025-01-01 10:06 UTC (permalink / raw
  To: gentoo-commits
commit:     08794e8f284e2f5555493a0e4061c294d0089ba9
Author:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
AuthorDate: Mon Dec 30 23:29:10 2024 +0000
Commit:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
CommitDate: Wed Jan  1 10:06:03 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=08794e8f
toolchain.eclass: Fix strip exclusion for prefixed cross-compilers
dostrip limitations mean that we cannot strip the CTARGET binaries in a
cross-compiler. There is already a `dostrip -x` call to exclude such
binaries from stripping, but it expects the argument to be unprefixed,
and the argument given was prefixed.
Signed-off-by: James Le Cuirot <chewi <AT> gentoo.org>
 eclass/toolchain.eclass | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 602f99437145..c605c437f355 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2024 Gentoo Authors
+# Copyright 1999-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: toolchain.eclass
@@ -2641,7 +2641,7 @@ toolchain_src_install() {
 	#  - "${D}${LIBPATH}"
 	# As dostrip does not specify host to override ${CHOST} tools just skip
 	# non-native binary stripping.
-	is_crosscompile && dostrip -x "${LIBPATH}"
+	is_crosscompile && dostrip -x "${LIBPATH#"${EPREFIX}"}"
 
 	cd "${S}" || die
 	if is_crosscompile; then
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-01-01 15:45 Miroslav Šulc
  0 siblings, 0 replies; 6663+ messages in thread
From: Miroslav Šulc @ 2025-01-01 15:45 UTC (permalink / raw
  To: gentoo-commits
commit:     76d4017fad0aa22c946d7238684da3ecd46daae4
Author:     Volkmar W. Pogatzki <gentoo <AT> pogatzki <DOT> net>
AuthorDate: Tue Dec 24 09:09:41 2024 +0000
Commit:     Miroslav Šulc <fordfrog <AT> gentoo <DOT> org>
CommitDate: Wed Jan  1 15:44:51 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=76d4017f
java-pkg-simple.eclass: drop support for EAPI 7
Signed-off-by: Volkmar W. Pogatzki <gentoo <AT> pogatzki.net>
Closes: https://github.com/gentoo/gentoo/pull/39911
Signed-off-by: Miroslav Šulc <fordfrog <AT> gentoo.org>
 eclass/java-pkg-simple.eclass | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/eclass/java-pkg-simple.eclass b/eclass/java-pkg-simple.eclass
index 5ed7e3e5b78e..ce4a62f048da 100644
--- a/eclass/java-pkg-simple.eclass
+++ b/eclass/java-pkg-simple.eclass
@@ -6,7 +6,7 @@
 # java@gentoo.org
 # @AUTHOR:
 # Java maintainers <java@gentoo.org>
-# @SUPPORTED_EAPIS: 7 8
+# @SUPPORTED_EAPIS: 8
 # @BLURB: Eclass for packaging Java software with ease.
 # @DESCRIPTION:
 # This class is intended to build pure Java packages from Java sources
@@ -17,7 +17,7 @@
 # directory before calling the src_compile function of this eclass.
 
 case ${EAPI} in
-	7|8) ;;
+	8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-01-02 17:08 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-01-02 17:08 UTC (permalink / raw
  To: gentoo-commits
commit:     a9b25945f57ea44213913ed4796582435d011b1a
Author:     Nowa Ammerlaan <nowa <AT> gentoo <DOT> org>
AuthorDate: Sun Dec 29 19:13:36 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Thu Jan  2 17:08:29 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=a9b25945
mount-boot-utils.eclass: document user variables for skipping mount check
And introduce a new variable DONT_MOUNT_ESP to disable only the mount
checking of the EFI System Partition. Useful for ebuilds where we know that
only /boot is touched and not /efi. Or for users that know their kernel
installation layout does not require mounting the ESP.
Bug: https://bugs.gentoo.org/937785
Bug: https://bugs.gentoo.org/939760
Signed-off-by: Nowa Ammerlaan <nowa <AT> gentoo.org>
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/mount-boot-utils.eclass | 16 ++++++++++++++--
 1 file changed, 14 insertions(+), 2 deletions(-)
diff --git a/eclass/mount-boot-utils.eclass b/eclass/mount-boot-utils.eclass
index e24b4e0c0826..72b4c9ccd14a 100644
--- a/eclass/mount-boot-utils.eclass
+++ b/eclass/mount-boot-utils.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2024 Gentoo Authors
+# Copyright 1999-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: mount-boot-utils.eclass
@@ -16,6 +16,18 @@
 # This eclass provides the functions used by mount-boot.eclass in an "inherit-
 # safe" way. This allows these functions to be used in other eclasses cleanly.
 
+# @ECLASS_VARIABLE: DONT_MOUNT_BOOT
+# @USER_VARIABLE
+# @DESCRIPTION:
+# May be set by the user or an ebuild to completely disable mount checking
+# of the /boot partition and the EFI System Partition.
+
+# @ECLASS_VARIABLE: DONT_MOUNT_ESP
+# @USER_VARIABLE
+# @DESCRIPTION:
+# May be set by the user or an ebuild to disable mount checking of the
+# EFI System Partition only.
+
 case ${EAPI} in
 	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
@@ -62,7 +74,7 @@ mount-boot_check_status() {
 	local candidates=( /boot )
 
 	# If system is booted with UEFI, check for ESP as well
-	if [[ -d /sys/firmware/efi ]]; then
+	if [[ -d /sys/firmware/efi && -z ${DONT_MOUNT_ESP} ]]; then
 		# Use same candidates for ESP as installkernel and eclean-kernel
 		candidates+=( /efi /boot/efi /boot/EFI )
 	fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-01-02 17:08 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-01-02 17:08 UTC (permalink / raw
  To: gentoo-commits
commit:     fde53f23bb5aceee88ca188ffcfb522ffc6b419d
Author:     Nowa Ammerlaan <nowa <AT> gentoo <DOT> org>
AuthorDate: Mon Dec 23 17:31:08 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Thu Jan  2 17:08:27 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=fde53f23
kernel-{build,install}.eclass: create multi-profile generic UKIs
systemd 257's ukify gains the ability to specify multiple "profiles" for an
UKI. This allows us to finally solve Bug 921195, which made it impossible to
simultaneously enforce verification of the kernel image (secureboot) and
enforce verification of the kernel modules (lockdown=integrity).
We also add a profile for "quiet splash", and change KERNEL_GENERIC_UKI_CMDLINE
to add another profile instead of overwriting the built-in kernel cmdline. To
support splash we add the plymouth and drm dracut modules but omit the drm
kernel modules that pull in huge firmware files. This will result in a less
visually smooth boot, but significantly decreases the size of the image.
Ukify can now also pass on the signing engine argument to systemd-measure
which enables the usage of pkcs11 uri's for measured boot.
Minimal version of systemd for USE=generic-uki is bumped to 257.
Closes: https://bugs.gentoo.org/921195
Signed-off-by: Nowa Ammerlaan <nowa <AT> gentoo.org>
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/kernel-build.eclass   | 84 +++++++++++++++++++++++++++++++++++---------
 eclass/kernel-install.eclass |  6 ++--
 2 files changed, 71 insertions(+), 19 deletions(-)
diff --git a/eclass/kernel-build.eclass b/eclass/kernel-build.eclass
index 831027216321..aae55d9e3ac5 100644
--- a/eclass/kernel-build.eclass
+++ b/eclass/kernel-build.eclass
@@ -1,4 +1,4 @@
-# Copyright 2020-2024 Gentoo Authors
+# Copyright 2020-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: kernel-build.eclass
@@ -108,10 +108,14 @@ IUSE="+strip"
 # @ECLASS_VARIABLE: KERNEL_GENERIC_UKI_CMDLINE
 # @USER_VARIABLE
 # @DESCRIPTION:
-# If KERNEL_IUSE_GENERIC_UKI is set, this variable allows setting the
-# built-in kernel command line for the UKI. If unset, the default is
-# root=/dev/gpt-auto-root ro
-: "${KERNEL_GENERIC_UKI_CMDLINE:="root=/dev/gpt-auto-root ro"}"
+# If KERNEL_IUSE_GENERIC_UKI is set, and this variable is not
+# empty, then the contents are used as the first kernel cmdline
+# option of the multi-profile generic UKI. Supplementing the four
+# standard options of:
+# - root=/dev/gpt-auto-root ro
+# - root=/dev/gpt-auto-root ro quiet splash
+# - root=/dev/gpt-auto-root ro lockdown=integrity
+# - root=/dev/gpt-auto-root ro quiet splash lockdown=integrity
 
 if [[ ${KERNEL_IUSE_MODULES_SIGN} ]]; then
 	IUSE+=" modules-sign"
@@ -497,10 +501,10 @@ kernel-build_src_install() {
 
 			local dracut_modules=(
 				base bash btrfs cifs crypt crypt-gpg crypt-loop dbus dbus-daemon
-				dm dmraid dracut-systemd fido2 i18n fs-lib kernel-modules
+				dm dmraid dracut-systemd drm fido2 i18n fs-lib kernel-modules
 				kernel-network-modules kernel-modules-extra lunmask lvm nbd
 				mdraid modsign network network-manager nfs nvdimm nvmf pcsc
-				pkcs11 qemu qemu-net resume rngd rootfs-block shutdown
+				pkcs11 plymouth qemu qemu-net resume rngd rootfs-block shutdown
 				systemd systemd-ac-power systemd-ask-password systemd-initrd
 				systemd-integritysetup systemd-pcrphase systemd-sysusers
 				systemd-udevd systemd-veritysetup terminfo tpm2-tss udev-rules
@@ -526,7 +530,7 @@ kernel-build_src_install() {
 				--ro-mnt
 				--modules "${dracut_modules[*]}"
 				# Pulls in huge firmware files
-				--omit-drivers "nfp"
+				--omit-drivers "amdgpu i915 nfp nouveau nvidia xe"
 			)
 
 			# Tries to update ld cache
@@ -534,29 +538,77 @@ kernel-build_src_install() {
 			dracut "${dracut_args[@]}" "${image%/*}/initrd" ||
 				die "Failed to generate initramfs"
 
+			# Note, we cannot use an associative array here because those are
+			# not ordered.
+			local profiles=()
+			local cmdlines=()
+
+			# If defined, make the user entry the first and default
+			if [[ -n ${KERNEL_GENERIC_UKI_CMDLINE} ]]; then
+				profiles+=(
+					$'TITLE=User specified at build time\nID=user'
+				)
+				cmdlines+=( "${KERNEL_GENERIC_UKI_CMDLINE}" )
+			fi
+
+			profiles+=(
+				$'TITLE=Default\nID=default'
+				$'TITLE=Default with splash\nID=splash'
+				$'TITLE=Default with lockdown\nID=lockdown'
+				$'TITLE=Default with splash and lockdown\nID=splash-lockdown'
+			)
+
+			cmdlines+=(
+				"root=/dev/gpt-auto-root ro"
+				"root=/dev/gpt-auto-root ro quiet splash"
+				"root=/dev/gpt-auto-root ro lockdown=integrity"
+				"root=/dev/gpt-auto-root ro quiet splash lockdown=integrity"
+			)
+
 			local ukify_args=(
 				--linux="${image}"
 				--initrd="${image%/*}/initrd"
-				--cmdline="${KERNEL_GENERIC_UKI_CMDLINE}"
 				--uname="${KV_FULL}"
 				--output="${image%/*}/uki.efi"
-			)
+				--profile="${profiles[0]}"
+				--cmdline="${cmdlines[0]}"
+			) # 0th profile is default
+
+			# Additional profiles have to be added with --join-profile
+			local i
+			for (( i=1; i<"${#profiles[@]}"; i++ )); do
+				ukify build \
+					--profile="${profiles[i]}" \
+					--cmdline="${cmdlines[i]}" \
+					--output="${T}/profile${i}.efi" ||
+						die "Failed to create profile ${i}"
+
+				ukify_args+=( --join-profile="${T}/profile${i}.efi" )
+			done
 
 			if [[ ${KERNEL_IUSE_MODULES_SIGN} ]] && use secureboot; then
+				openssl x509 \
+					-in "${SECUREBOOT_SIGN_CERT}" -inform PEM \
+					-out ${T}/pcrpkey.der -outform DER ||
+						die "Failed to convert certificate to DER format"
 				ukify_args+=(
-					--signtool=sbsign
 					--secureboot-private-key="${SECUREBOOT_SIGN_KEY}"
 					--secureboot-certificate="${SECUREBOOT_SIGN_CERT}"
+					--pcrpkey="${T}/pcrpkey.der"
+					--measure
 				)
 				if [[ ${SECUREBOOT_SIGN_KEY} == pkcs11:* ]]; then
 					ukify_args+=(
 						--signing-engine="pkcs11"
+						--pcr-private-key="${SECUREBOOT_SIGN_KEY}"
+						--pcr-public-key="${SECUREBOOT_SIGN_CERT}"
+						--phases="enter-initrd"
+						--pcr-private-key="${SECUREBOOT_SIGN_KEY}"
+						--pcr-public-key="${SECUREBOOT_SIGN_CERT}"
+						--phases="enter-initrd:leave-initrd enter-initrd:leave-initrd:sysinit enter-initrd:leave-initrd:sysinit:ready"
 					)
 				else
-					# Sytemd-measure does not currently support pkcs11
 					ukify_args+=(
-						--measure
-						--pcrpkey="${ED}${kernel_dir}/certs/signing_key.x509"
 						--pcr-private-key="${SECUREBOOT_SIGN_KEY}"
 						--phases="enter-initrd"
 						--pcr-private-key="${SECUREBOOT_SIGN_KEY}"
@@ -565,9 +617,7 @@ kernel-build_src_install() {
 				fi
 			fi
 
-			# systemd<255 does not install ukify in /usr/bin
-			PATH="${PATH}:${BROOT}/usr/lib/systemd:${BROOT}/lib/systemd" \
-				ukify build "${ukify_args[@]}" || die "Failed to generate UKI"
+			ukify build "${ukify_args[@]}" || die "Failed to generate UKI"
 
 			# Overwrite unnecessary image types to save space
 			> "${image}" || die
diff --git a/eclass/kernel-install.eclass b/eclass/kernel-install.eclass
index a341dd9426ff..5b4f3b096c41 100644
--- a/eclass/kernel-install.eclass
+++ b/eclass/kernel-install.eclass
@@ -1,4 +1,4 @@
-# Copyright 2020-2024 Gentoo Authors
+# Copyright 2020-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: kernel-install.eclass
@@ -162,9 +162,10 @@ if [[ ${KERNEL_IUSE_GENERIC_UKI} ]]; then
 		["sys-apps/rng-tools"]="GPL-2"
 		["sys-apps/sed"]="GPL-3+"
 		["sys-apps/shadow"]="BSD GPL-2"
-		["sys-apps/systemd[boot(-),cryptsetup,pkcs11,policykit,tpm,ukify(-)]"]="GPL-2 LGPL-2.1 MIT public-domain"
+		[">=sys-apps/systemd-257[boot(-),cryptsetup,pkcs11,policykit,tpm,ukify(-)]"]="GPL-2 LGPL-2.1 MIT public-domain"
 		["sys-apps/util-linux"]="GPL-2 GPL-3 LGPL-2.1 BSD-4 MIT public-domain"
 		["sys-auth/polkit"]="LGPL-2"
+		["sys-boot/plymouth[drm,systemd(+),udev]"]="GPL-2+"
 		["sys-block/nbd"]="GPL-2"
 		["sys-devel/gcc"]="GPL-3+ LGPL-3+ || ( GPL-3+ libgcc libstdc++ gcc-runtime-library-exception-3.1 ) FDL-1.3+"
 		["sys-fs/btrfs-progs"]="GPL-2"
@@ -190,6 +191,7 @@ if [[ ${KERNEL_IUSE_GENERIC_UKI} ]]; then
 		["sys-libs/readline"]="GPL-3+"
 		["sys-libs/zlib"]="ZLIB"
 		["sys-process/procps"]="GPL-2+ LGPL-2+ LGPL-2.1+"
+		["x11-libs/libdrm"]="MIT"
 		["amd64? ( sys-firmware/intel-microcode )"]="amd64? ( intel-ucode )"
 		["x86? ( sys-firmware/intel-microcode )"]="x86? ( intel-ucode )"
 	)
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-01-02 17:08 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-01-02 17:08 UTC (permalink / raw
  To: gentoo-commits
commit:     9af7e9d11ede9c823e2904a9cf387d5e1286a4d0
Author:     Nowa Ammerlaan <nowa <AT> gentoo <DOT> org>
AuthorDate: Sun Dec 29 20:46:40 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Thu Jan  2 17:08:30 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=9af7e9d1
dist-kernel-utils.eclass: implement basic support for install with ROOT
Before this change the kernel installation is silently skipped in all cases.
Using sys-kernel/installkernel to generate an initramfs/uki will indeed be
a huge mess so when an initramfs is requested we now print a helpful error
message. If we do not want an initramfs, or the initramfs/uki was generated
with portage using USE=generic-uki then we can safely try to install the kernel.
Installkernel-50 is capable of dealing with this situation in most cases, but it
will print a bunch of warnings since plugins are skipped. Bootloader
configuration, for example, cannot be updated in this case.
For kernel modules we can also safely make this change, all modules that can be
in the initramfs have the initramfs flag and if it is enabled then we will also
hit this error message.
End result of this change is more verbosity when kernel installation is skipped
and basic support for installing the kernel with --root set for simple
configurations (no initramfs or generic-uki with compat layout or uki layout).
Signed-off-by: Nowa Ammerlaan <nowa <AT> gentoo.org>
Closes: https://github.com/gentoo/gentoo/pull/38842
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/dist-kernel-utils.eclass | 25 +++++++++++++++++++++++--
 eclass/kernel-install.eclass    |  8 ++------
 eclass/linux-mod-r1.eclass      |  4 ++--
 3 files changed, 27 insertions(+), 10 deletions(-)
diff --git a/eclass/dist-kernel-utils.eclass b/eclass/dist-kernel-utils.eclass
index 210c586c8c29..3d7315e9e94e 100644
--- a/eclass/dist-kernel-utils.eclass
+++ b/eclass/dist-kernel-utils.eclass
@@ -1,4 +1,4 @@
-# Copyright 2020-2024 Gentoo Authors
+# Copyright 2020-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: dist-kernel-utils.eclass
@@ -82,12 +82,33 @@ dist-kernel_install_kernel() {
 	local success=
 	# not an actual loop but allows error handling with 'break'
 	while true; do
+		if [[ -n ${ROOT} ]] && in_iuse initramfs && use initramfs; then
+			if ! in_iuse generic-uki || ! use generic-uki; then
+				eerror
+				eerror "ROOT is set, and (re-)generation of an initramfs is requested"
+				eerror "via the USE=initramfs flag. However, this is currently not"
+				eerror "supported via the sys-kernel/installkernel mechanism."
+				eerror
+				if in_iuse generic-uki && ! use generic-uki; then
+					eerror "Generation and installation of a generic initramfs and/or"
+					eerror "Unified Kernel Image is possible via portage by enabling the"
+					eerror "USE=generic-uki flag. Please enable the generic-uki flag, or"
+					eerror "chroot into: ROOT=${ROOT}"
+				else
+					eerror "Please chroot into: ROOT=${ROOT}"
+				fi
+				break
+			fi
+		fi
+
 		nonfatal mount-boot_check_status || break
+		mkdir -p "${EROOT}/boot" || break
 
 		ebegin "Installing the kernel via installkernel"
 		# note: .config is taken relatively to System.map;
 		# initrd relatively to bzImage
-		ARCH=$(tc-arch-kernel) installkernel "${version}" "${image}" "${map}" || break
+		ARCH=$(tc-arch-kernel) installkernel "${version}" "${image}" "${map}" \
+			"${EROOT}/boot" || break
 		eend ${?} || die -n "Installing the kernel failed"
 
 		success=1
diff --git a/eclass/kernel-install.eclass b/eclass/kernel-install.eclass
index 5b4f3b096c41..6ca39e551110 100644
--- a/eclass/kernel-install.eclass
+++ b/eclass/kernel-install.eclass
@@ -716,9 +716,7 @@ kernel-install_pkg_postinst() {
 	dist-kernel_compressed_module_cleanup \
 		"${EROOT}/lib/modules/${KV_FULL}"
 
-	if [[ -z ${ROOT} ]]; then
-		kernel-install_install_all "${KV_FULL}"
-	fi
+	kernel-install_install_all "${KV_FULL}"
 
 	if [[ ${KERNEL_IUSE_GENERIC_UKI} ]] && use generic-uki; then
 		ewarn "The prebuilt initramfs and unified kernel image are highly experimental!"
@@ -740,7 +738,7 @@ kernel-install_pkg_postinst() {
 kernel-install_pkg_postrm() {
 	debug-print-function ${FUNCNAME} "$@"
 
-	if [[ -z ${ROOT} && ! ${KERNEL_IUSE_GENERIC_UKI} ]]; then
+	if [[ ! ${KERNEL_IUSE_GENERIC_UKI} ]]; then
 		local kernel_dir=${EROOT}/usr/src/linux-${KV_FULL}
 		local image_path=$(dist-kernel_get_image_path)
 		ebegin "Removing initramfs"
@@ -754,8 +752,6 @@ kernel-install_pkg_postrm() {
 # @DESCRIPTION:
 # Rebuild the initramfs and reinstall the kernel.
 kernel-install_pkg_config() {
-	[[ -z ${ROOT} ]] || die "ROOT!=/ not supported currently"
-
 	if [[ -z ${KV_FULL} ]]; then
 		KV_FULL=${PV}${KV_LOCALVERSION}
 	fi
diff --git a/eclass/linux-mod-r1.eclass b/eclass/linux-mod-r1.eclass
index 4e5b17548b04..f6a5d4f187d8 100644
--- a/eclass/linux-mod-r1.eclass
+++ b/eclass/linux-mod-r1.eclass
@@ -1,4 +1,4 @@
-# Copyright 2023-2024 Gentoo Authors
+# Copyright 2023-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: linux-mod-r1.eclass
@@ -508,7 +508,7 @@ linux-mod-r1_pkg_postinst() {
 	dist-kernel_compressed_module_cleanup "${EROOT}/lib/modules/${KV_FULL}"
 	_modules_update_depmod
 
-	if [[ -z ${ROOT} && ${MODULES_INITRAMFS_IUSE} ]] &&
+	if [[ ${MODULES_INITRAMFS_IUSE} ]] &&
 		use dist-kernel && use ${MODULES_INITRAMFS_IUSE#+}
 	then
 		dist-kernel_reinstall_initramfs "${KV_DIR}" "${KV_FULL}"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-01-02 18:33 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-01-02 18:33 UTC (permalink / raw
  To: gentoo-commits
commit:     8f9703447530c55709c3462035ecdb7562347185
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Jan  2 18:28:11 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Jan  2 18:28:11 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=8f970344
toolchain.eclass: cleanup /etc/clang/gentoo-gcc-install.cfg on removing last GCC
Otherwise, /etc/clang/gentoo-gcc-install.cfg is left with a broken non-existent
--gcc-install-dir value on LLVM-only profiles when the last installed GCC
gets removed.
Closes: https://bugs.gentoo.org/906040
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 6 ++++++
 1 file changed, 6 insertions(+)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index c605c437f355..acc51ead74cc 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -2961,6 +2961,12 @@ toolchain_pkg_postrm() {
 			rm -f "${EROOT}"/usr/bin/${CTARGET}-{gcc,{g,c}++}{,32,64}
 		fi
 		return 0
+	else
+		# Removed the last GCC installed (bug #906040)
+		if ! has_version "sys-devel/gcc" && has_version "sys-devel/clang" ; then
+			einfo "Last GCC version removed. Cleaning up ${EROOT}/etc/clang/gentoo-gcc-install.cfg."
+			echo > "${EROOT}"/etc/clang/gentoo-gcc-install.cfg
+		fi
 	fi
 
 	# gcc stopped installing .la files fixer in June 2020.
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-01-02 23:32 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-01-02 23:32 UTC (permalink / raw
  To: gentoo-commits
commit:     3fa625c5967246ee3ffd59393b26379af4c91e8c
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Jan  2 23:30:56 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Jan  2 23:31:57 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=3fa625c5
toolchain.eclass: run fixincludes for x86_64-w32-mingw32 too
This came up in a PR to add CI for mingw targets to crossdev,
specifically https://github.com/gentoo/crossdev/actions/runs/12337160095/job/34430532180?pr=29.
Bug: https://bugs.gentoo.org/925204
Bug: https://bugs.gentoo.org/946397
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index acc51ead74cc..244de97076e4 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1804,7 +1804,7 @@ toolchain_src_configure() {
 		fi
 
 		case ${CBUILD}-${CHOST}-${CTARGET} in
-			*i686-w64-mingw32*|*x86_64-w64-mingw32*)
+			*i686-w64-mingw32*|*x86_64-w64-mingw32*|*x86_64-w32-mingw32*)
 				# config/i386/t-cygming requires fixincludes (bug #925204)
 				GCC_RUN_FIXINCLUDES=1
 				;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-01-02 23:34 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-01-02 23:34 UTC (permalink / raw
  To: gentoo-commits
commit:     57c187b2d74e2ac5a1a1dde590ba78f73d91f591
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Jan  2 23:33:43 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Jan  2 23:33:43 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=57c187b2
toolchain.eclass: run fixincludes for all mingw targets
Same as 3fa625c5967246ee3ffd59393b26379af4c91e8c.
x86_64-w64-mingw64 needs it too.
Bug: https://bugs.gentoo.org/925204
Bug: https://bugs.gentoo.org/946397
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 244de97076e4..6dc139bd1a02 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1804,7 +1804,7 @@ toolchain_src_configure() {
 		fi
 
 		case ${CBUILD}-${CHOST}-${CTARGET} in
-			*i686-w64-mingw32*|*x86_64-w64-mingw32*|*x86_64-w32-mingw32*)
+			*-w*-mingw*)
 				# config/i386/t-cygming requires fixincludes (bug #925204)
 				GCC_RUN_FIXINCLUDES=1
 				;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-01-03  0:59 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-01-03  0:59 UTC (permalink / raw
  To: gentoo-commits
commit:     94cfc2abd5924cc71314e28fb9f26e147ed9659e
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Jan  3 00:58:00 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Jan  3 00:58:41 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=94cfc2ab
toolchain.eclass: move Clang CET hack earlier to influence tc_enable_hardened_gcc
Otherwise, we may still set -DEXTRA_OPTIONS_CF.
Bug: https://bugs.gentoo.org/933772
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 10 +++++-----
 1 file changed, 5 insertions(+), 5 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 6dc139bd1a02..85b5a2b23392 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -688,6 +688,11 @@ toolchain_src_prepare() {
 
 	eapply_user
 
+	# Workaround -march=native not working for stage1 with non-GCC (bug #933772).
+	if ! tc-is-gcc && [[ "${CFLAGS}${CXXFLAGS}" == *-march=native* ]] ; then
+		CLANG_DISABLE_CET_HACK=1
+	fi
+
 	if ! use vanilla ; then
 		tc_enable_hardened_gcc
 	fi
@@ -1178,11 +1183,6 @@ toolchain_src_configure() {
 		export ac_cv_std_swap_in_utility=no
 	fi
 
-	# Workaround -march=native not working for stage1 with non-GCC (bug #933772).
-	if ! tc-is-gcc && [[ "${CFLAGS}${CXXFLAGS}" == *-march=native* ]] ; then
-		CLANG_DISABLE_CET_HACK=1
-	fi
-
 	local flag
 	for flag in $(all-flag-vars) ; do
 		einfo "${flag}=\"${!flag}\""
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-01-03 17:54 James Le Cuirot
  0 siblings, 0 replies; 6663+ messages in thread
From: James Le Cuirot @ 2025-01-03 17:54 UTC (permalink / raw
  To: gentoo-commits
commit:     44d2dbd6db9e05f156a81a3a360ff48e2ac9d773
Author:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
AuthorDate: Thu Jan  2 16:25:10 2025 +0000
Commit:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
CommitDate: Fri Jan  3 17:54:17 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=44d2dbd6
toolchain.eclass: Don't prefixify dynamic linker for cross-compilers
Cross environments within a prefixed system do not have a nested prefix,
i.e. they are located at ${EPREFIX}/usr/${CHOST}, not
${EPREFIX}/usr/${CHOST}/${EPREFIX}. Binaries built with the
cross-compiler should therefore get an unprefixed dynamic linker path by
default so that they work out of the box with QEMU's -L option.
Signed-off-by: James Le Cuirot <chewi <AT> gentoo.org>
 eclass/toolchain.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 85b5a2b23392..d85994855704 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -721,7 +721,7 @@ toolchain_src_prepare() {
 
 	gnuconfig_update
 
-	if ! use prefix-guest && [[ -n ${EPREFIX} ]] ; then
+	if ! is_crosscompile && ! use prefix-guest && [[ -n ${EPREFIX} ]] ; then
 		einfo "Prefixifying dynamic linkers..."
 		for f in gcc/config/*/*linux*.h ; do
 			ebegin "  Updating ${f}"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-01-04 15:28 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-01-04 15:28 UTC (permalink / raw
  To: gentoo-commits
commit:     20087812f7a55ef6ad96877af303a570182a7e0b
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Jan  4 12:48:38 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat Jan  4 15:27:43 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=20087812
llvm.org.eclass: Remove old snapshots
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 14 +-------------
 1 file changed, 1 insertion(+), 13 deletions(-)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index 9b5be08eb1bb..ac622fdab37c 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -1,4 +1,4 @@
-# Copyright 2019-2024 Gentoo Authors
+# Copyright 2019-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: llvm.org.eclass
@@ -75,18 +75,6 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 				20.0.0_pre20241227)
 					EGIT_COMMIT=ccfe0de0e1e37ed369c9bf89dd0188ba0afb2e9a
 					;;
-				20.0.0_pre20241221)
-					EGIT_COMMIT=665d79f2e967a5eee6fff93685e45f50cf24cab2
-					;;
-				20.0.0_pre20241215)
-					EGIT_COMMIT=49a5ad8e5714fd404210279303acc97b495d66d0
-					;;
-				20.0.0_pre20241207)
-					EGIT_COMMIT=32f7f0010bca99ee4bd917f57272733fb2bf3bd9
-					;;
-				20.0.0_pre20241130)
-					EGIT_COMMIT=a348f223cab54b21a7b1c38dec7bc6aa2f81c949
-					;;
 				*)
 					die "Unknown snapshot: ${PV}"
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-01-04 15:28 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-01-04 15:28 UTC (permalink / raw
  To: gentoo-commits
commit:     83da955674c870724457b9712f3c5f3d180f907e
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Jan  4 15:07:26 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat Jan  4 15:27:44 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=83da9556
llvm.org.eclass: Add 20.0.0_pre20250104 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index ac622fdab37c..0d5a8f6b5c83 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -72,6 +72,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 			_LLVM_SOURCE_TYPE=snapshot
 
 			case ${PV} in
+				20.0.0_pre20250104)
+					EGIT_COMMIT=2529a8df53af9bc6cecfd6c83404ffa5e89e3370
+					;;
 				20.0.0_pre20241227)
 					EGIT_COMMIT=ccfe0de0e1e37ed369c9bf89dd0188ba0afb2e9a
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-01-04 21:34 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-01-04 21:34 UTC (permalink / raw
  To: gentoo-commits
commit:     24a553bfcba8788ee1003476836b6085c50b7a1b
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Jan  4 19:20:36 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jan  4 21:32:27 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=24a553bf
gstreamer-meson.eclass: add GLIB_VERSION per gst major version
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/gstreamer-meson.eclass | 8 +++++++-
 1 file changed, 7 insertions(+), 1 deletion(-)
diff --git a/eclass/gstreamer-meson.eclass b/eclass/gstreamer-meson.eclass
index 7d6b5d6b3249..15b0a6390a42 100644
--- a/eclass/gstreamer-meson.eclass
+++ b/eclass/gstreamer-meson.eclass
@@ -199,8 +199,14 @@ S="${WORKDIR}/${GST_ORG_MODULE}-${PV}"
 LICENSE="GPL-2"
 SLOT="1.0"
 
+if ver_test ${GST_ORG_PVP} -ge 1.24 ; then
+	GLIB_VERSION=2.64.0
+else
+	GLIB_VERSION=2.62.0
+fi
+
 RDEPEND="
-	>=dev-libs/glib-2.40.0:2[${MULTILIB_USEDEP}]
+	>=dev-libs/glib-${GLIB_VERSION}:2[${MULTILIB_USEDEP}]
 "
 BDEPEND="
 	virtual/pkgconfig
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-01-04 21:34 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-01-04 21:34 UTC (permalink / raw
  To: gentoo-commits
commit:     c891c27ff33ddcaab27a1337f7065cb5594abed4
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Jan  4 19:16:34 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jan  4 21:32:27 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=c891c27f
gstreamer-meson.eclass: cleanup TODOs for old/new versions
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/gstreamer-meson.eclass | 12 ++----------
 1 file changed, 2 insertions(+), 10 deletions(-)
diff --git a/eclass/gstreamer-meson.eclass b/eclass/gstreamer-meson.eclass
index 937c86a0f15b..7d6b5d6b3249 100644
--- a/eclass/gstreamer-meson.eclass
+++ b/eclass/gstreamer-meson.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2024 Gentoo Authors
+# Copyright 1999-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: gstreamer-meson.eclass
@@ -38,11 +38,6 @@ esac
 PYTHON_COMPAT=( python3_{10..12} )
 [[ ${EAPI} == 8 ]] && inherit python-any-r1
 
-# TODO: Remove after all older versions are gone from tree
-if ver_test ${PV} -lt 1.22.10 ; then
-	inherit virtualx
-fi
-
 # multilib-minimal goes last
 inherit meson multilib toolchain-funcs xdg-utils multilib-minimal
 
@@ -133,10 +128,7 @@ gstreamer_system_package() {
 			pc=${tuple#*:}-${SLOT}
 			sed -e "1i${dependency} = dependency('${pc}', required : true)" \
 				-i "${pdir}"/meson.build || die
-			# TODO: Remove conditional applying once older versions are all gone
-			if ver_test ${PV} -gt 1.22.5 ; then
-				sed -e "/meson\.override_dependency[(]pkg_name, ${dependency}[)]/d" -i "${S}"/gst-libs/gst/*/meson.build || die
-			fi
+			sed -e "/meson\.override_dependency[(]pkg_name, ${dependency}[)]/d" -i "${S}"/gst-libs/gst/*/meson.build || die
 		done
 	done
 }
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-01-05 13:39 Nowa Ammerlaan
  0 siblings, 0 replies; 6663+ messages in thread
From: Nowa Ammerlaan @ 2025-01-05 13:39 UTC (permalink / raw
  To: gentoo-commits
commit:     bb6c8448a19ba02525369fe60ff243db5d6ff549
Author:     Nowa Ammerlaan <nowa <AT> gentoo <DOT> org>
AuthorDate: Sat Jan  4 12:57:31 2025 +0000
Commit:     Nowa Ammerlaan <nowa <AT> gentoo <DOT> org>
CommitDate: Sun Jan  5 13:39:26 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=bb6c8448
secureboot.eclass: QOL fixes based on user feedback
Previously there was some misalignment between how MODULES_SIGN_* and
SECUREBOOT_SIGN_* are handled.
- USE=modules-sign with unset MODULES_SIGN_* would cause the kernel build
	system to generate a new key, while USE=secureboot with unset
	SECUREBOOT_SIGN_* would die. Align this better by adding some sensible
	default locations to look for a key (sbctl and kernel) and by adding some
	logic to generate a new key. Use for the new key the same config files
	that the kernel would use if they exist.
- USE=modules-sign infers the certificate from the key if the certificate is
	not set, whereas USE=secureboot would not do this. Align this better by
	setting the SECUREBOOT_SIGN_CERT to the SECUREBOOT_SIGN_KEY if the later is
	set but the former is not.
Signed-off-by: Nowa Ammerlaan <nowa <AT> gentoo.org>
Closes: https://github.com/gentoo/gentoo/pull/39974
Signed-off-by: Nowa Ammerlaan <nowa <AT> gentoo.org>
 eclass/secureboot.eclass | 149 +++++++++++++++++++++++++++++++++++++----------
 1 file changed, 119 insertions(+), 30 deletions(-)
diff --git a/eclass/secureboot.eclass b/eclass/secureboot.eclass
index a854061719a9..7361465ee2d3 100644
--- a/eclass/secureboot.eclass
+++ b/eclass/secureboot.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2024 Gentoo Authors
+# Copyright 1999-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: secureboot.eclass
@@ -57,6 +57,13 @@ BDEPEND="
 # @DESCRIPTION:
 # Used with USE=secureboot.  Should be set to the path of the private
 # key in PEM format to use, or a PKCS#11 URI.
+# If unspecified the following locations are tried in order:
+# - /etc/portage/secureboot.pem
+# - /var/lib/sbctl/keys/db/db.{key,pem} (from app-crypt/sbctl)
+# - the MODULES_SIGN_KEY (and MODULES_SIGN_CERT if set)
+# - the contents of CONFIG_MODULE_SIG_KEY in the current kernel
+# If none of these exist, a new key will be generated at
+# /etc/portage/secureboot.pem.
 
 # @ECLASS_VARIABLE: SECUREBOOT_SIGN_CERT
 # @USER_VARIABLE
@@ -64,36 +71,13 @@ BDEPEND="
 # @DESCRIPTION:
 # Used with USE=secureboot.  Should be set to the path of the public
 # key certificate in PEM format to use.
+# If unspecified the SECUREBOOT_SIGN_KEY is assumed to also contain the
+# certificate belonging to it.
 
 if [[ -z ${_SECUREBOOT_ECLASS} ]]; then
 _SECUREBOOT_ECLASS=1
 
-# @FUNCTION: _secureboot_die_if_unset
-# @INTERNAL
-# @DESCRIPTION:
-# If USE=secureboot is enabled die if the required user variables are unset
-# and die if the keys can't be found.
-_secureboot_die_if_unset() {
-	debug-print-function ${FUNCNAME} "$@"
-	use secureboot || return
-
-	if [[ -z ${SECUREBOOT_SIGN_KEY} || -z ${SECUREBOOT_SIGN_CERT} ]]; then
-		die "USE=secureboot enabled but SECUREBOOT_SIGN_KEY and/or SECUREBOOT_SIGN_CERT not set."
-	fi
-
-	# Sanity check: fail early if key/cert in DER format or does not exist
-	local openssl_args=(
-		-inform PEM -in "${SECUREBOOT_SIGN_CERT}"
-		-noout -nocert
-	)
-	if [[ ${SECUREBOOT_SIGN_KEY} == pkcs11:* ]]; then
-		openssl_args+=( -engine pkcs11 -keyform ENGINE -key "${SECUREBOOT_SIGN_KEY}" )
-	else
-		openssl_args+=( -keyform PEM -key "${SECUREBOOT_SIGN_KEY}" )
-	fi
-	openssl x509 "${openssl_args[@]}" ||
-		die "Secure Boot signing certificate or key not found or not PEM format."
-}
+inherit linux-info
 
 # @FUNCTION: secureboot_pkg_setup
 # @DESCRIPTION:
@@ -105,7 +89,114 @@ secureboot_pkg_setup() {
 	# If we are merging a binary then the files in this binary
 	# are already signed, no need to check the variables.
 	if [[ ${MERGE_TYPE} != binary ]]; then
-		_secureboot_die_if_unset
+		if [[ -z ${SECUREBOOT_SIGN_KEY} ]]; then
+			# No key specified, try some usual suspects
+			linux-info_pkg_setup
+			local module_sig_key=
+			if linux_config_exists MODULE_SIG_KEY; then
+				: "$(linux_chkconfig_string MODULE_SIG_KEY)"
+				module_sig_key=${_//\"}
+				# Convert to absolute path if required
+				if [[ ${module_sig_key} != pkcs11:* &&
+					${module_sig_key} != /* ]]
+				then
+					module_sig_key=${KV_OUT_DIR}/${module_sig_key}
+				fi
+			fi
+
+			# Check both the SYSROOT and ROOT, like linux-info.eclass
+			ewarn "No Secure Boot signing key specified."
+			if [[ -r ${SYSROOT}/etc/portage/secureboot.pem ]]; then
+				ewarn "Using ${SYSROOT}/etc/portage/secureboot.pem as signing key"
+				export SECUREBOOT_SIGN_KEY=${SYSROOT}/etc/portage/secureboot.pem
+				export SECUREBOOT_SIGN_CERT=${SYSROOT}/etc/portage/secureboot.pem
+			elif [[ -r ${ROOT}/etc/portage/secureboot.pem ]]; then
+				ewarn "Using ${ROOT}/etc/portage/secureboot.pem as signing key"
+				export SECUREBOOT_SIGN_KEY=${ROOT}/etc/portage/secureboot.pem
+				export SECUREBOOT_SIGN_CERT=${ROOT}/etc/portage/secureboot.pem
+			elif [[ -r ${SYSROOT}/var/lib/sbctl/keys/db/db.key &&
+				-r ${SYSROOT}/var/lib/sbctl/keys/db/db.pem ]]
+			then
+				ewarn "Using keys maintained by app-crypt/sbctl"
+				export SECUREBOOT_SIGN_KEY=${SYSROOT}/var/lib/sbctl/keys/db/db.key
+				export SECUREBOOT_SIGN_CERT=${SYSROOT}/var/lib/sbctl/keys/db/db.pem
+			elif [[ -r ${ROOT}/var/lib/sbctl/keys/db/db.key &&
+				-r ${ROOT}/var/lib/sbctl/keys/db/db.pem ]]
+			then
+				ewarn "Using keys maintained by app-crypt/sbctl"
+				export SECUREBOOT_SIGN_KEY=${ROOT}/var/lib/sbctl/keys/db/db.key
+				export SECUREBOOT_SIGN_CERT=${ROOT}/var/lib/sbctl/keys/db/db.pem
+			elif [[ -r ${MODULES_SIGN_KEY} ]]; then
+				ewarn "Using the kernel module signing key"
+				export SECUREBOOT_SIGN_KEY=${MODULES_SIGN_KEY}
+				if [[ -r ${MODULES_SIGN_CERT} ]]; then
+					export SECUREBOOT_SIGN_CERT=${MODULES_SIGN_CERT}
+				else
+					export SECUREBOOT_SIGN_CERT=${MODULES_SIGN_KEY}
+				fi
+			elif [[ -r ${KV_OUT_DIR}/certs/signing_key.x509 ]] &&
+				[[ -r ${module_sig_key} || ${module_sig_key} == pkcs11:* ]]
+			then
+				ewarn "Using keys maintained by the kernel"
+				openssl x509 \
+					-in "${KV_OUT_DIR}/certs/signing_key.x509" -inform DER \
+					-out "${T}/secureboot.pem" -outform PEM ||
+						die "Failed to convert kernel certificate to PEM format"
+				export SECUREBOOT_SIGN_KEY=${module_sig_key}
+				export SECUREBOOT_SIGN_CERT=${T}/secureboot.pem
+			else
+				ewarn "No candidate keys found, generating a new key"
+				local openssl_gen_args=(
+					req -new -batch -nodes -utf8 -sha256 -days 36500 -x509
+					-outform PEM -out "${SYSROOT}/etc/portage/secureboot.pem"
+					-keyform PEM -keyout "${SYSROOT}/etc/portage/secureboot.pem"
+					)
+				if [[ -r ${KV_OUT_DIR}/certs/x509.genkey ]]; then
+					openssl_gen_args+=(
+						-config "${KV_OUT_DIR}/certs/x509.genkey"
+					)
+				elif [[ -r ${KV_OUT_DIR}/certs/default_x509.genkey ]]; then
+					openssl_gen_args+=(
+						-config "${KV_OUT_DIR}/certs/default_x509.genkey"
+					)
+				else
+					openssl_gen_args+=(
+						-subj '/CN=Build time autogenerated kernel key'
+					)
+				fi
+				(
+					umask 066
+					openssl "${openssl_gen_args[@]}" ||
+						die "Failed to generate new signing key"
+					# Generate DER format key as well for easy inclusion in
+					# either the UEFI dB or MOK list.
+					openssl x509 \
+						-in "${SYSROOT}/etc/portage/secureboot.pem" -inform PEM \
+						-out "${ROOT}/etc/portage/secureboot.x509" -outform DER ||
+							die "Failed to convert signing certificate to DER format"
+				)
+				export SECUREBOOT_SIGN_KEY=${SYSROOT}/etc/portage/secureboot.pem
+				export SECUREBOOT_SIGN_CERT=${SYSROOT}/etc/portage/secureboot.pem
+			fi
+		elif [[ -z ${SECUREBOOT_SIGN_CERT} ]]; then
+			ewarn "A SECUREBOOT_SIGN_KEY was specified but no SECUREBOOT_SIGN_CERT"
+			ewarn "was set. Assuming the certificate is in the same file as the key."
+			export SECUREBOOT_SIGN_CERT=${SECUREBOOT_SIGN_KEY}
+		fi
+
+		# Sanity check: fail early if key/cert in DER format or does not exist
+		local openssl_args=(
+			-inform PEM -in "${SECUREBOOT_SIGN_CERT}"
+			-noout -nocert
+		)
+		if [[ ${SECUREBOOT_SIGN_KEY} == pkcs11:* ]]; then
+			openssl_args+=( -engine pkcs11 -keyform ENGINE -key "${SECUREBOOT_SIGN_KEY}" )
+		else
+			openssl_args+=( -keyform PEM -key "${SECUREBOOT_SIGN_KEY}" )
+		fi
+
+		openssl x509 "${openssl_args[@]}" ||
+			die "Secure Boot signing certificate or key not found or not PEM format."
 	fi
 }
 
@@ -123,8 +214,6 @@ secureboot_sign_efi_file() {
 	local input_file=${1}
 	local output_file=${2:-${1}}
 
-	_secureboot_die_if_unset
-
 	ebegin "Signing ${input_file}"
 	local return=1
 	if sbverify "${input_file}" --cert "${SECUREBOOT_SIGN_CERT}" &> /dev/null; then
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-01-05 13:39 Nowa Ammerlaan
  0 siblings, 0 replies; 6663+ messages in thread
From: Nowa Ammerlaan @ 2025-01-05 13:39 UTC (permalink / raw
  To: gentoo-commits
commit:     b678c191a5e453a42b6dcf2b3406fd41fcd6d5c7
Author:     Nowa Ammerlaan <nowa <AT> gentoo <DOT> org>
AuthorDate: Sat Jan  4 12:56:20 2025 +0000
Commit:     Nowa Ammerlaan <nowa <AT> gentoo <DOT> org>
CommitDate: Sun Jan  5 13:39:25 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=b678c191
kernel-build.eclass: pcrpkey should be PEM not DER
We sill need the call to openssl to ensure that we don't accidentally append
the key itself to the UKI.
Signed-off-by: Nowa Ammerlaan <nowa <AT> gentoo.org>
 eclass/kernel-build.eclass | 10 +++++++---
 1 file changed, 7 insertions(+), 3 deletions(-)
diff --git a/eclass/kernel-build.eclass b/eclass/kernel-build.eclass
index aae55d9e3ac5..e3175453fea7 100644
--- a/eclass/kernel-build.eclass
+++ b/eclass/kernel-build.eclass
@@ -587,14 +587,18 @@ kernel-build_src_install() {
 			done
 
 			if [[ ${KERNEL_IUSE_MODULES_SIGN} ]] && use secureboot; then
+				# --pcrpkey is appended as is. If the certificate and key
+				# are in the same file, we could accidentally leak the key
+				# into the UKI. Pass the certificate through openssl to ensure
+				# that it truly contains *only* the certificate.
 				openssl x509 \
 					-in "${SECUREBOOT_SIGN_CERT}" -inform PEM \
-					-out ${T}/pcrpkey.der -outform DER ||
-						die "Failed to convert certificate to DER format"
+					-out "${T}/pcrpkey.pem" -outform PEM ||
+						die "Failed to extract certificate"
 				ukify_args+=(
 					--secureboot-private-key="${SECUREBOOT_SIGN_KEY}"
 					--secureboot-certificate="${SECUREBOOT_SIGN_CERT}"
-					--pcrpkey="${T}/pcrpkey.der"
+					--pcrpkey="${T}/pcrpkey.pem"
 					--measure
 				)
 				if [[ ${SECUREBOOT_SIGN_KEY} == pkcs11:* ]]; then
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-01-06 14:37 Nowa Ammerlaan
  0 siblings, 0 replies; 6663+ messages in thread
From: Nowa Ammerlaan @ 2025-01-06 14:37 UTC (permalink / raw
  To: gentoo-commits
commit:     65594d38630d5406918d60ebd6d2aba7367aad6b
Author:     Nowa Ammerlaan <nowa <AT> gentoo <DOT> org>
AuthorDate: Mon Jan  6 09:20:31 2025 +0000
Commit:     Nowa Ammerlaan <nowa <AT> gentoo <DOT> org>
CommitDate: Mon Jan  6 14:37:49 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=65594d38
kernel-install.eclass: only remove initrd,uki.efi if src dir still exists
Closes: https://bugs.gentoo.org/947359
Signed-off-by: Nowa Ammerlaan <nowa <AT> gentoo.org>
 eclass/kernel-install.eclass | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/eclass/kernel-install.eclass b/eclass/kernel-install.eclass
index 6ca39e551110..f70556ad41f5 100644
--- a/eclass/kernel-install.eclass
+++ b/eclass/kernel-install.eclass
@@ -738,9 +738,9 @@ kernel-install_pkg_postinst() {
 kernel-install_pkg_postrm() {
 	debug-print-function ${FUNCNAME} "$@"
 
-	if [[ ! ${KERNEL_IUSE_GENERIC_UKI} ]]; then
-		local kernel_dir=${EROOT}/usr/src/linux-${KV_FULL}
-		local image_path=$(dist-kernel_get_image_path)
+	local kernel_dir=${EROOT}/usr/src/linux-${KV_FULL}
+	local image_path=$(dist-kernel_get_image_path)
+	if [[ ! ${KERNEL_IUSE_GENERIC_UKI} && -d ${kernel_dir} ]]; then
 		ebegin "Removing initramfs"
 		rm -f "${kernel_dir}/${image_path%/*}"/{initrd,uki.efi} &&
 			find "${kernel_dir}" -depth -type d -empty -delete
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-01-06 20:25 Nowa Ammerlaan
  0 siblings, 0 replies; 6663+ messages in thread
From: Nowa Ammerlaan @ 2025-01-06 20:25 UTC (permalink / raw
  To: gentoo-commits
commit:     9163b23ef60ec34e3739e06eabe5167e36295ab7
Author:     Nowa Ammerlaan <nowa <AT> gentoo <DOT> org>
AuthorDate: Mon Jan  6 17:46:01 2025 +0000
Commit:     Nowa Ammerlaan <nowa <AT> gentoo <DOT> org>
CommitDate: Mon Jan  6 20:25:37 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=9163b23e
kernel-{build,install}.eclass: exclude any generated keys from binpkgs
The kernel build system supports generating a new module signing key if the
CONFIG_MODULE_SIG_KEY is set to the default value (MODULES_SIGN_KEY is not set)
and no key exists at that default location.
This results in the unfortunate situation where private key material ends up
in generated binary packages. That is almost never what you want since binary
packages are usually readable by regular users. To avoid this we move the key
out of the ED in the install phase, and move it back in the preinst phase after
the binary package has been built.
This also means that when distributing built binary packages to other systems
the signing key will now never be installed onto all those other systems, which
is probably what you want anyway.
Note, there is no change for folks who use externally managed keys, i.e. for
everyone who has MODULES_SIGN_KEY, MODULE_SIGN_CERT set.
Signed-off-by: Nowa Ammerlaan <nowa <AT> gentoo.org>
Closes: https://github.com/gentoo/gentoo/pull/40017
Signed-off-by: Nowa Ammerlaan <nowa <AT> gentoo.org>
 eclass/kernel-build.eclass   | 6 +++++-
 eclass/kernel-install.eclass | 9 +++++++++
 2 files changed, 14 insertions(+), 1 deletion(-)
diff --git a/eclass/kernel-build.eclass b/eclass/kernel-build.eclass
index 8f3346bb4874..65433d9fc9c0 100644
--- a/eclass/kernel-build.eclass
+++ b/eclass/kernel-build.eclass
@@ -447,6 +447,11 @@ kernel-build_src_install() {
 
 	# Copy built key/certificate files
 	cp -p build/certs/* "${ED}${kernel_dir}/certs/" || die
+	# If a key was generated, exclude it from the binpkg
+	local generated_key=${ED}${kernel_dir}/certs/signing_key.pem
+	if [[ -r ${generated_key} ]]; then
+		mv "${generated_key}" "${T}/signing_key.pem" || die
+	fi
 
 	# building modules fails with 'vmlinux has no symtab?' if stripped
 	use ppc64 && dostrip -x "${kernel_dir}/${image_path}"
@@ -654,7 +659,6 @@ kernel-build_pkg_postinst() {
 			ewarn "MODULES_SIGN_KEY was not set, this means the kernel build system"
 			ewarn "automatically generated the signing key. This key was installed"
 			ewarn "in ${EROOT}/usr/src/linux-${KV_FULL}/certs"
-			ewarn "and will also be included in any binary packages."
 			ewarn "Please take appropriate action to protect the key!"
 			ewarn
 			ewarn "Recompiling this package causes a new key to be generated. As"
diff --git a/eclass/kernel-install.eclass b/eclass/kernel-install.eclass
index f70556ad41f5..1cc2bd0bb737 100644
--- a/eclass/kernel-install.eclass
+++ b/eclass/kernel-install.eclass
@@ -607,6 +607,15 @@ kernel-install_pkg_preinst() {
 	[[ ! -d ${kernel_dir} ]] &&
 		die "Kernel directory ${kernel_dir} not installed!"
 
+	# We moved this in order to omit it from the binpkg, move it back
+	if [[ -r "${T}/signing_key.pem" ]]; then
+		# cp instead of mv to set owner to root in one go
+		(
+			umask 066 &&
+				cp "${T}/signing_key.pem" "${kernel_dir}/certs/signing_key.pem"
+		) || die
+	fi
+
 	# perform the version check for release ebuilds only
 	if [[ ${PV} != *9999 ]]; then
 		local expected_ver=$(dist-kernel_PV_to_KV "${PV}")
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-01-06 20:25 Nowa Ammerlaan
  0 siblings, 0 replies; 6663+ messages in thread
From: Nowa Ammerlaan @ 2025-01-06 20:25 UTC (permalink / raw
  To: gentoo-commits
commit:     07dd6fa527001c5f877c668bf8036f3a2453135f
Author:     Nowa Ammerlaan <nowa <AT> gentoo <DOT> org>
AuthorDate: Mon Jan  6 17:27:42 2025 +0000
Commit:     Nowa Ammerlaan <nowa <AT> gentoo <DOT> org>
CommitDate: Mon Jan  6 20:25:33 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=07dd6fa5
kernel-build.eclass: resolve configure problem with USE=secureboot
if no keys set, then secureboot.eclass now inherits linux-info.eclass to check
for potential key candidates in the kernel config. This would set KV_FULL
and create a mess later on in the configure phase. Ensure that KV_FULL remains
local to the setup phase specifically for the kernel packages.
Signed-off-by: Nowa Ammerlaan <nowa <AT> gentoo.org>
 eclass/kernel-build.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/kernel-build.eclass b/eclass/kernel-build.eclass
index e3175453fea7..8f3346bb4874 100644
--- a/eclass/kernel-build.eclass
+++ b/eclass/kernel-build.eclass
@@ -137,6 +137,9 @@ fi
 kernel-build_pkg_setup() {
 	python-any-r1_pkg_setup
 	if [[ ${KERNEL_IUSE_MODULES_SIGN} && ${MERGE_TYPE} != binary ]]; then
+		# inherits linux-info to check config values for keys
+		# ensure KV_FULL will not be set globally, that breaks configure
+		local KV_FULL
 		secureboot_pkg_setup
 
 		if use modules-sign && [[ -n ${MODULES_SIGN_KEY} ]]; then
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-01-06 20:25 Nowa Ammerlaan
  0 siblings, 0 replies; 6663+ messages in thread
From: Nowa Ammerlaan @ 2025-01-06 20:25 UTC (permalink / raw
  To: gentoo-commits
commit:     54e6dfe511a93656092b9672755b857136daab79
Author:     Nowa Ammerlaan <nowa <AT> gentoo <DOT> org>
AuthorDate: Mon Jan  6 17:34:57 2025 +0000
Commit:     Nowa Ammerlaan <nowa <AT> gentoo <DOT> org>
CommitDate: Mon Jan  6 20:25:34 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=54e6dfe5
linux-mod-r1.eclass: drop left over -z ROOT condition
This we don't need any more since dist-kernel_reinstall_initramfs already
does the appropriate checks.
Signed-off-by: Nowa Ammerlaan <nowa <AT> gentoo.org>
 eclass/linux-mod-r1.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/linux-mod-r1.eclass b/eclass/linux-mod-r1.eclass
index f6a5d4f187d8..16c280219ef8 100644
--- a/eclass/linux-mod-r1.eclass
+++ b/eclass/linux-mod-r1.eclass
@@ -333,7 +333,7 @@ linux-mod-r1_pkg_setup() {
 	_MODULES_GLOBAL[ran:pkg_setup]=1
 	_modules_check_function ${#} 0 0 || return 0
 
-	if [[ -z ${ROOT} && ${MODULES_INITRAMFS_IUSE} ]] &&
+	if [[ ${MODULES_INITRAMFS_IUSE} ]] &&
 		use dist-kernel && use ${MODULES_INITRAMFS_IUSE#+}
 	then
 		# Check, but don't die because we can fix the problem and then
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-01-07 11:34 Miroslav Šulc
  0 siblings, 0 replies; 6663+ messages in thread
From: Miroslav Šulc @ 2025-01-07 11:34 UTC (permalink / raw
  To: gentoo-commits
commit:     495a0a25e181d019233ee10ff6a9110db097b605
Author:     Volkmar W. Pogatzki <gentoo <AT> pogatzki <DOT> net>
AuthorDate: Wed Jan  1 14:09:43 2025 +0000
Commit:     Miroslav Šulc <fordfrog <AT> gentoo <DOT> org>
CommitDate: Tue Jan  7 11:34:52 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=495a0a25
java-pkg-2.eclass: drop support for EAPI 7
Signed-off-by: Volkmar W. Pogatzki <gentoo <AT> pogatzki.net>
Closes: https://github.com/gentoo/gentoo/pull/40023
Signed-off-by: Miroslav Šulc <fordfrog <AT> gentoo.org>
 eclass/java-pkg-2.eclass | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/eclass/java-pkg-2.eclass b/eclass/java-pkg-2.eclass
index eebdec584ccc..0b35490e0365 100644
--- a/eclass/java-pkg-2.eclass
+++ b/eclass/java-pkg-2.eclass
@@ -1,4 +1,4 @@
-# Copyright 2004-2024 Gentoo Authors
+# Copyright 2004-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: java-pkg-2.eclass
@@ -6,7 +6,7 @@
 # java@gentoo.org
 # @AUTHOR:
 # Thomas Matthijs <axxo@gentoo.org>
-# @SUPPORTED_EAPIS: 7 8
+# @SUPPORTED_EAPIS: 8
 # @PROVIDES: java-utils-2
 # @BLURB: Eclass for Java Packages
 # @DESCRIPTION:
@@ -17,7 +17,7 @@ if [[ -z ${_JAVA_PKG_2_ECLASS} ]] ; then
 _JAVA_PKG_2_ECLASS=1
 
 case ${EAPI} in
-	7|8) ;;
+	8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-01-08  2:18 Ionen Wolkens
  0 siblings, 0 replies; 6663+ messages in thread
From: Ionen Wolkens @ 2025-01-08  2:18 UTC (permalink / raw
  To: gentoo-commits
commit:     25a29b7fc4c103a32348b0adcb3e8014173e0665
Author:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
AuthorDate: Wed Jan  8 02:14:00 2025 +0000
Commit:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
CommitDate: Wed Jan  8 02:14:04 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=25a29b7f
qt6-build.eclass: add avx512vnni to qtwebengine's sanitizing
Possible that more flags from bug #947696 will cause issues (untested),
but at least looked at all the -mavx512* that xnnpack uses and the only
one that's missing was vnni.
qtbase does not care for it, so put it in qtwebengine's block.
Closes: https://bugs.gentoo.org/947696
Signed-off-by: Ionen Wolkens <ionen <AT> gentoo.org>
 eclass/qt6-build.eclass | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/eclass/qt6-build.eclass b/eclass/qt6-build.eclass
index f8161447074a..ca6c63081053 100644
--- a/eclass/qt6-build.eclass
+++ b/eclass/qt6-build.eclass
@@ -1,4 +1,4 @@
-# Copyright 2021-2024 Gentoo Authors
+# Copyright 2021-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: qt6-build.eclass
@@ -296,7 +296,7 @@ _qt6-build_sanitize_cpu_flags() {
 	# extras only needed by chromium in qtwebengine
 	# (see also chromium's ebuild wrt bug #530248,#544702,#546984,#853646)
 	[[ ${PN} == qtwebengine ]] && cpuflags+=(
-		mmx xop
+		avx512vnni mmx xop
 
 		# unclear if these two are really needed given (current) chromium
 		# does not pass these flags, albeit it may side-disable something
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-01-08  6:33 Joonas Niilola
  0 siblings, 0 replies; 6663+ messages in thread
From: Joonas Niilola @ 2025-01-08  6:33 UTC (permalink / raw
  To: gentoo-commits
commit:     33f22ac2fd51aa5ad16ffd1840f0349ad8a2984f
Author:     sin-ack <sin-ack <AT> protonmail <DOT> com>
AuthorDate: Thu Jan  2 15:59:57 2025 +0000
Commit:     Joonas Niilola <juippis <AT> gentoo <DOT> org>
CommitDate: Wed Jan  8 06:32:59 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=33f22ac2
zig-utils.eclass: add ZIG_NEEDS_LLVM variable
If set to a non-empty value, the package will BDEPEND on a Zig package
with LLVM enabled. This is currently required for packages that require
C/C++ source files to be compiled with Zig.
There's some special logic required to detect which Zig binary we should
actually use, because we may have dev-lang/zig[-llvm] installed with
dev-lang/zig-bin (in which case we would need to pick zig-bin over zig).
Tested in a clean stage3 chroot with dev-lang/zig[-llvm] and
dev-lang/zig-bin installed, in which case zig-utils.eclass will pick
zig-bin over zig.
Co-authored-by: Eric Joldasov <bratishkaerik <AT> landless-city.net>
Signed-off-by: sin-ack <sin-ack <AT> protonmail.com>
Signed-off-by: Joonas Niilola <juippis <AT> gentoo.org>
 eclass/zig-utils.eclass | 25 +++++++++++++++++++++++--
 1 file changed, 23 insertions(+), 2 deletions(-)
diff --git a/eclass/zig-utils.eclass b/eclass/zig-utils.eclass
index ca72e89ed6ea..5502d997935e 100644
--- a/eclass/zig-utils.eclass
+++ b/eclass/zig-utils.eclass
@@ -1,4 +1,4 @@
-# Copyright 2024 Gentoo Authors
+# Copyright 2024-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: zig-utils.eclass
@@ -54,6 +54,14 @@ inherit edo flag-o-matic linux-info
 # and most likely changed to more common in other eclasses ZIG_MIN/
 # ZIG_MAX form.
 
+# @ECLASS_VARIABLE: ZIG_NEEDS_LLVM
+# @PRE_INHERIT
+# @DEFAULT_UNSET
+# @DESCRIPTION:
+# If set to a non-empty value, the package will BDEPEND on a Zig package
+# with LLVM enabled.  This is currently required for packages that require
+# C/C++ source files to be compiled with Zig.
+
 # @ECLASS_VARIABLE: ZIG_OPTIONAL
 # @PRE_INHERIT
 # @DEFAULT_UNSET
@@ -69,9 +77,15 @@ inherit edo flag-o-matic linux-info
 # For zig.eclass users: see documentation in zig.eclass
 # instead.
 if [[ ! ${ZIG_OPTIONAL} ]]; then
+	_ZIG_USEDEP=""
+	if [[ ${ZIG_NEEDS_LLVM} ]]; then
+		_ZIG_USEDEP="[llvm(+)]"
+	fi
+
+	# NOTE: zig-bin is always built with LLVM support, so no USE needed.
 	BDEPEND="
 		|| (
-			dev-lang/zig:${ZIG_SLOT}
+			dev-lang/zig:${ZIG_SLOT}${_ZIG_USEDEP}
 			dev-lang/zig-bin:${ZIG_SLOT}
 		)
 	"
@@ -440,6 +454,10 @@ zig-utils_find_installation() {
 
 	local base_path="${BROOT}/usr/bin"
 
+	local -x ZIG_GLOBAL_CACHE_DIR="${T}/zig-detect"
+	mkdir -p "${ZIG_GLOBAL_CACHE_DIR}" || die
+	touch "${ZIG_GLOBAL_CACHE_DIR}/empty.zig" || die
+
 	local selected_path selected_ver
 	for selected_ver in "${zig_supported_versions[@]}"; do
 		# Check if candidate satisfies ZIG_SLOT condition.
@@ -451,6 +469,9 @@ zig-utils_find_installation() {
 		local candidate_path
 		for candidate_path in "${base_path}"/zig{,-bin}-"${selected_ver}"; do
 			if [[ -x "${candidate_path}" ]]; then
+				if [[ ${ZIG_NEEDS_LLVM} ]]; then
+					"${candidate_path}" test -fllvm -OReleaseSmall "${ZIG_GLOBAL_CACHE_DIR}/empty.zig" &> /dev/null || continue
+				fi
 				selected_path="${candidate_path}"
 				break 2
 			fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-01-10 13:15 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-01-10 13:15 UTC (permalink / raw
  To: gentoo-commits
commit:     c80dc591e4803f5f2feacde4a79d339c0cc2e3b5
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Mon Dec 23 14:28:36 2024 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Fri Jan 10 13:15:02 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=c80dc591
verify-sig.eclass: Add verify-sig_uncompress_verify_unpack
Add a function that carries out the surprisingly common pattern of
uncompress-verify-unpack found in kernel.org distfiles, where
the signature is created against the uncompressed archive rather than
the actual distfile.  Just like the code currently copied across
ebuilds, the function uses a pipeline to simultaneously decompress,
unpack and verify the signature, except with correct error handling
this time.
Note that the code technically implies that the archive will be unpacked
even if the signature does not match -- the ebuild will abort
afterwards.
Thanks to Ulrich Müller for the suggestion!
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/verify-sig.eclass | 34 +++++++++++++++++++++++++++++++++-
 1 file changed, 33 insertions(+), 1 deletion(-)
diff --git a/eclass/verify-sig.eclass b/eclass/verify-sig.eclass
index 0e6b9b43e557..12b689f0f4b2 100644
--- a/eclass/verify-sig.eclass
+++ b/eclass/verify-sig.eclass
@@ -1,4 +1,4 @@
-# Copyright 2020-2024 Gentoo Authors
+# Copyright 2020-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: verify-sig.eclass
@@ -48,6 +48,8 @@ esac
 if [[ -z ${_VERIFY_SIG_ECLASS} ]]; then
 _VERIFY_SIG_ECLASS=1
 
+inherit eapi9-pipestatus
+
 IUSE="verify-sig"
 
 # @ECLASS_VARIABLE: VERIFY_SIG_METHOD
@@ -423,6 +425,36 @@ verify-sig_verify_signed_checksums() {
 	esac
 }
 
+# @FUNCTION: verify-sig_uncompress_verify_unpack
+# @USAGE: <compressed-tar> <sig-file> [<key-file>]
+# @DESCRIPTION:
+# Uncompress the <compressed-tar> tarball, verify the uncompressed
+# archive against the signature in <sig-file> and unpack it.  This is
+# useful for kernel.org packages that sign the uncompressed tarball
+# instead of the compressed archive.  <key-file> can either be passed
+# directly, or it defaults to VERIFY_SIG_OPENPGP_KEY_PATH.  The function
+# dies if verification or any of the unpacking steps fail.
+verify-sig_uncompress_verify_unpack() {
+	local file=${1}
+	local unpacker
+
+	# TODO: integrate with unpacker.eclass somehow?
+	case ${file} in
+		*.tar.xz)
+			unpacker=( xz -cd )
+			;;
+		*)
+			die "${FUNCNAME}: only .tar.xz archives are supported at the moment"
+			;;
+	esac
+
+	einfo "Unpacking ${file} ..."
+	verify-sig_verify_detached - "${@:2}" < <(
+		"${unpacker[@]}" "${file}" | tee >(tar -xf - || die)
+		pipestatus || die
+	)
+}
+
 # @FUNCTION: verify-sig_src_unpack
 # @DESCRIPTION:
 # Default src_unpack override that verifies signatures for all
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-01-10 16:44 Nowa Ammerlaan
  0 siblings, 0 replies; 6663+ messages in thread
From: Nowa Ammerlaan @ 2025-01-10 16:44 UTC (permalink / raw
  To: gentoo-commits
commit:     422a7e51c1e1a7774e406e3f0856b4e415fee46f
Author:     Nowa Ammerlaan <nowa <AT> gentoo <DOT> org>
AuthorDate: Thu Jan  9 18:22:39 2025 +0000
Commit:     Nowa Ammerlaan <nowa <AT> gentoo <DOT> org>
CommitDate: Fri Jan 10 16:44:19 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=422a7e51
kernel-install.eclass: verify uki/kernel image before installing
This avoids accidentally installing a kernel image or generic UKI with an
invalid signature in both gentoo-kernel and gentoo-kernel-bin. This means we
will catch regressions such as described below earlier, notably it will now
error out when building the binpkgs for gentoo-kernel-bin.
We also add some logic to recover from the case where the kernel image is
larger then it should be. This may be the case with ukify>=257 because starting
from this version onwards the space that the kernel needs to extract and run
is reserved in the .linux section of the UKI as padding. Objcopy unfortunately
copies this padding along with the rest of the data, invalidating the signature.
In previous versions of ukify this was not an issue because the .linux section
was always the last section in the UKI and you could therefore usually get away
with not reserving the extra required space.
Sbverify helpfully reports a warning about this padding with the exact size
the kernel image should have. We use this to strip the padding from the
kernel image, and verify if the signature problem is now resolved. There may be
a better way to do this that does not involve parsing the output of sbverify,
but I have not been able to find any.
See-also: https://github.com/systemd/systemd/issues/35851
See-also: https://forums.gentoo.org/viewtopic-t-1172386.html
Signed-off-by: Nowa Ammerlaan <nowa <AT> gentoo.org>
 eclass/kernel-install.eclass | 59 +++++++++++++++++++++++++++++++++++++++++---
 1 file changed, 56 insertions(+), 3 deletions(-)
diff --git a/eclass/kernel-install.eclass b/eclass/kernel-install.eclass
index 1cc2bd0bb737..cf34007844a8 100644
--- a/eclass/kernel-install.eclass
+++ b/eclass/kernel-install.eclass
@@ -204,6 +204,7 @@ if [[ ${KERNEL_IUSE_GENERIC_UKI} ]]; then
 	"
 	IDEPEND="
 		generic-uki? (
+			app-crypt/sbsigntools
 			>=sys-kernel/installkernel-14[-dracut(-),-ugrd(-),-ukify(-)]
 		)
 		!generic-uki? (
@@ -660,13 +661,65 @@ kernel-install_extract_from_uki() {
 	local extract_type=${1}
 	local uki=${2}
 	local out=${3}
+	local out_temp=${T}/${extract_type}-section-dumped
 
 	# objcopy overwrites input if there is no output, dump the output in T.
 	# We unfortunately cannot use /dev/null here
 	$(tc-getOBJCOPY) "${uki}" "${T}/dump.efi" \
-		--dump-section ".${extract_type}=${out}" ||
-		die "Failed to extract ${extract_type}"
-	chmod 644 "${out}" || die
+		--dump-section ".${extract_type}=${out_temp}" ||
+			die "Failed to extract ${extract_type}"
+
+	# Sanity checks for kernel images
+	if [[ ${extract_type} == linux ]] &&
+		{ ! in_iuse secureboot || use secureboot ;}
+	then
+		# Extract the used SECUREBOOT_SIGN_CERT to verify the kernel image
+		local cert=${T}/pcrpkey
+		kernel-install_extract_from_uki pcrpkey "${uki}" "${cert}"
+		if [[ $(head -n1 "${cert}") != "-----BEGIN CERTIFICATE-----" ]]; then
+			# This is a DER format certificate, convert it to PEM
+			openssl x509 \
+				-inform DER -in "${cert}" \
+				-outform PEM -out "${cert}" ||
+					die "Failed to convert pcrpkey to PEM format"
+		fi
+
+		# Check if the signature on the UKI is valid
+		sbverify --cert "${cert}" "${uki}" ||
+			die "ERROR: UKI signature is invalid"
+
+		# Check if the signature on the kernel image is valid
+		local sbverify_err=$(
+			sbverify --cert "${cert}" "${out_temp}" 2>&1 >/dev/null
+		)
+
+		# Check if there was a padding warning
+		if [[ ${sbverify_err} == "warning: data remaining"*": gaps between PE/COFF sections?"* ]]
+		then
+			# https://github.com/systemd/systemd/issues/35851
+			local proper_size=${sbverify_err#"warning: data remaining["}
+			proper_size=${proper_size%" vs"*}
+			# Strip the padding
+			head "${out_temp}" --bytes "${proper_size}" \
+				>"${out_temp}_trimmed" || die
+			# Check if the signature verifies now
+			sbverify_err=$(
+				sbverify --cert "${cert}" "${out_temp}_trimmed" 2>&1 >/dev/null
+			)
+			[[ -z ${sbverify_err} ]] && out_temp=${out_temp}_trimmed
+		fi
+
+		# Something has gone wrong, stop here to prevent installing a kernel
+		# with an invalid signature or a completely broken kernel image.
+		if [[ -n ${sbverify_err} ]]; then
+			eerror "${sbverify_err}"
+			die "ERROR: Kernel image signature is invalid"
+		else
+			einfo "Signature verification OK"
+		fi
+	fi
+
+	install -m 644 "${out_temp}" "${out}" || die
 }
 
 # @FUNCTION: kernel-install_install_all
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-01-11  8:10 Arthur Zamarin
  0 siblings, 0 replies; 6663+ messages in thread
From: Arthur Zamarin @ 2025-01-11  8:10 UTC (permalink / raw
  To: gentoo-commits
commit:     17d2c57c9636fe18469c17a461508d5779cc1d4c
Author:     Arthur Zamarin <arthurzam <AT> gentoo <DOT> org>
AuthorDate: Sat Jan 11 08:09:42 2025 +0000
Commit:     Arthur Zamarin <arthurzam <AT> gentoo <DOT> org>
CommitDate: Sat Jan 11 08:09:59 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=17d2c57c
rust.eclass: add rust 1.84.0
Signed-off-by: Arthur Zamarin <arthurzam <AT> gentoo.org>
 eclass/rust.eclass | 4 +++-
 1 file changed, 3 insertions(+), 1 deletion(-)
diff --git a/eclass/rust.eclass b/eclass/rust.eclass
index 30b6468d2a9b..0630d5973854 100644
--- a/eclass/rust.eclass
+++ b/eclass/rust.eclass
@@ -1,4 +1,4 @@
-# Copyright 2024 Gentoo Authors
+# Copyright 2024-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: rust.eclass
@@ -67,6 +67,7 @@ fi
 # @DESCRIPTION:
 # Definitive list of Rust slots and the associated LLVM slot, newest first.
 declare -A -g -r _RUST_LLVM_MAP=(
+	["1.84.0"]=19
 	["1.83.0"]=19
 	["1.82.0"]=19
 	["1.81.0"]=18
@@ -88,6 +89,7 @@ declare -A -g -r _RUST_LLVM_MAP=(
 # While _RUST_LLVM_MAP stores useful info about the relationship between Rust and LLVM slots,
 # this array is used to store the Rust slots in a more convenient order for iteration.
 declare -a -g -r _RUST_SLOTS_ORDERED=(
+	"1.84.0"
 	"1.83.0"
 	"1.82.0"
 	"1.81.0"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread
* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-01-11 18:12 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-01-11 18:12 UTC (permalink / raw
  To: gentoo-commits
commit:     6e3c53e76cd9534447eacbb6627ef38ec64934ed
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Jan 11 18:01:28 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat Jan 11 18:11:50 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=6e3c53e7
llvm.org.eclass: Add 20.0.0_pre20250111 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index 0d5a8f6b5c83..a810027f74f5 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -72,6 +72,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 			_LLVM_SOURCE_TYPE=snapshot
 
 			case ${PV} in
+				20.0.0_pre20250111)
+					EGIT_COMMIT=8af4d206e0f979f68925a08f9dffd60a98ce97e2
+					;;
 				20.0.0_pre20250104)
 					EGIT_COMMIT=2529a8df53af9bc6cecfd6c83404ffa5e89e3370
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-01-14  4:53 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-01-14  4:53 UTC (permalink / raw
  To: gentoo-commits
commit:     f38cc077c1d26004a130b6f92de3351402514ec9
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Jan 14 04:33:16 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jan 14 04:51:32 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=f38cc077
toolchain.eclass: fix toolchain_death_notice
* Actually include config.logs again
* Really compress (add 'a' to auto-compress based on suffix)
Bug: https://bugs.gentoo.org/948045
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index d85994855704..86302f3bcb4a 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -3159,9 +3159,9 @@ toolchain_death_notice() {
 			pushd "${WORKDIR}" >/dev/null
 			(echo '' | $(tc-getCC ${CTARGET}) ${CFLAGS} -v -E - 2>&1) > "${dir}"/gccinfo.log
 			[[ -e "${T}"/build.log ]] && cp "${T}"/build.log "${dir}"
-			tar -arf "${WORKDIR}"/gcc-build-logs.tar.xz \
-				"${dir#${WORKDIR}/}"/gccinfo.log "${dir#${WORKDIR}/}"/build.log $(find -name "${dir}"/config.log)
-			rm "${dir}"/gccinfo.log "${dir}"/build.log
+			tar -carf "${WORKDIR}"/gcc-build-logs.tar.xz \
+				"${dir#${WORKDIR}/}"/gccinfo.log "${dir#${WORKDIR}/}"/build.log $(find -name "${dir#${WORKDIR}/}"/config.log)
+			rm "${dir#${WORKDIR}/}"/gccinfo.log "${dir#${WORKDIR}/}"/build.log
 			eerror
 			eerror "Please include ${WORKDIR}/gcc-build-logs.tar.xz in your bug report."
 			eerror
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-01-14 17:07 Maciej Barć
  0 siblings, 0 replies; 6663+ messages in thread
From: Maciej Barć @ 2025-01-14 17:07 UTC (permalink / raw
  To: gentoo-commits
commit:     15f398581e7c6643ee4134434df82871a0606cb1
Author:     Maciej Barć <xgqt <AT> gentoo <DOT> org>
AuthorDate: Tue Jan  7 17:18:50 2025 +0000
Commit:     Maciej Barć <xgqt <AT> gentoo <DOT> org>
CommitDate: Tue Jan 14 17:07:18 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=15f39858
eclass/dotnet-pkg-base.eclass: add DOTNET_VERBOSITY user variable
DOTNET_VERBOSITY controls dotnet restore/build/test verbosity.
We allow the user to set this value to any other to value because it
might be helpful when debugging dotnet processes. On the other hand,
generally warnings and errors provide enough info for debugging package
emerge process.
Normally we use the default value - "minimal", that still reports what is
being built and any warnings/errors but it might come handy to set it
to a higher value for the Gentoo Tinderbox CI.
Signed-off-by: Maciej Barć <xgqt <AT> gentoo.org>
 eclass/dotnet-pkg-base.eclass | 23 ++++++++++++++++++++++-
 1 file changed, 22 insertions(+), 1 deletion(-)
diff --git a/eclass/dotnet-pkg-base.eclass b/eclass/dotnet-pkg-base.eclass
index d9abff3859f6..b266c1b5dffc 100644
--- a/eclass/dotnet-pkg-base.eclass
+++ b/eclass/dotnet-pkg-base.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2024 Gentoo Authors
+# Copyright 1999-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: dotnet-pkg-base.eclass
@@ -32,6 +32,23 @@ _DOTNET_PKG_BASE_ECLASS=1
 
 inherit edo multiprocessing nuget
 
+# @ECLASS_VARIABLE: DOTNET_VERBOSITY
+# @USER_VARIABLE
+# @DESCRIPTION:
+# Controls verbosity of the dotnet restore/build/test processes.
+#
+# Defaults to "minimal" - this only reports which projects are being built
+# and warnings/errors, if any. All the possible values are: "quiet", "minimal",
+# "normal", "detailed" and "diagnostic". For more information on verbosity
+# levels, see the official .NET SDK documentation on:
+# * https://learn.microsoft.com/en-us/dotnet/core/tools/dotnet
+# * https://learn.microsoft.com/en-us/dotnet/api/microsoft.build.framework.loggerverbosity
+#
+# This variable can be used to debug package build process (by selecting
+# anything above "minimal") but generally warnings/errors provide all
+# the necessary info.
+: "${DOTNET_VERBOSITY:=minimal}"
+
 # @ECLASS_VARIABLE: DOTNET_PKG_COMPAT
 # @REQUIRED
 # @PRE_INHERIT
@@ -385,6 +402,7 @@ dotnet-pkg-base_restore() {
 	local -a restore_args=(
 		--runtime "${DOTNET_PKG_RUNTIME}"
 		--source "${NUGET_PACKAGES}"
+		--verbosity "${DOTNET_VERBOSITY}"
 		-maxCpuCount:$(makeopts_jobs)
 		"${@}"
 	)
@@ -407,6 +425,7 @@ dotnet-pkg-base_restore-tools() {
 
 	local -a tool_restore_args=(
 		--add-source "${NUGET_PACKAGES}"
+		--verbosity "${DOTNET_VERBOSITY}"
 	)
 
 	if [[ -n "${1}" ]] ; then
@@ -447,6 +466,7 @@ dotnet-pkg-base_build() {
 		--no-self-contained
 		--output "${DOTNET_PKG_OUTPUT}"
 		--runtime "${DOTNET_PKG_RUNTIME}"
+		--verbosity "${DOTNET_VERBOSITY}"
 		-maxCpuCount:$(makeopts_jobs)
 	)
 
@@ -482,6 +502,7 @@ dotnet-pkg-base_test() {
 	local -a test_args=(
 		--configuration "${DOTNET_PKG_CONFIGURATION}"
 		--no-restore
+		--verbosity "${DOTNET_VERBOSITY}"
 		-maxCpuCount:$(makeopts_jobs)
 		"${@}"
 	)
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-01-15 14:39 Ulrich Müller
  0 siblings, 0 replies; 6663+ messages in thread
From: Ulrich Müller @ 2025-01-15 14:39 UTC (permalink / raw
  To: gentoo-commits
commit:     623294d2cb0ab7815d2b7b8a4202f2a7c481299b
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Wed Jan 15 14:35:23 2025 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Wed Jan 15 14:39:33 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=623294d2
optfeature.eclass: Update example
"app-misc/baz[bar]" needs to be quoted, otherwise they may be
interpreted as filename expansion patterns.
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 eclass/optfeature.eclass | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/eclass/optfeature.eclass b/eclass/optfeature.eclass
index c8b4911320d3..b82ac893addd 100644
--- a/eclass/optfeature.eclass
+++ b/eclass/optfeature.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2023 Gentoo Authors
+# Copyright 1999-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: optfeature.eclass
@@ -79,7 +79,7 @@ optfeature_header() {
 # @CODE
 # pkg_postinst() {
 # 	optfeature "foo support" app-misc/foo
-# 	optfeature "bar support" app-misc/bar app-misc/baz[bar]
+# 	optfeature "bar support" app-misc/bar "app-misc/baz[bar]"
 # 	optfeature "alphabet support" "app-misc/a app-misc/b" app-misc/c
 # }
 # @CODE
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-01-15 19:38 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-01-15 19:38 UTC (permalink / raw
  To: gentoo-commits
commit:     ae18c5b4149e30064751e7cea79cc830076b0292
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Jan 15 19:37:40 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Jan 15 19:37:40 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=ae18c5b4
toolchain.eclass: fix toolchain_death_notice more
* Go back to -arf. As Marcus points out, it doesn't make sense to append
  there.
* Compress afterwards given we want to handle both directories.
Bug: https://bugs.gentoo.org/948045
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 3 ++-
 1 file changed, 2 insertions(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 86302f3bcb4a..ad4703fc550e 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -3159,7 +3159,7 @@ toolchain_death_notice() {
 			pushd "${WORKDIR}" >/dev/null
 			(echo '' | $(tc-getCC ${CTARGET}) ${CFLAGS} -v -E - 2>&1) > "${dir}"/gccinfo.log
 			[[ -e "${T}"/build.log ]] && cp "${T}"/build.log "${dir}"
-			tar -carf "${WORKDIR}"/gcc-build-logs.tar.xz \
+			tar -arf "${WORKDIR}"/gcc-build-logs.tar.xz \
 				"${dir#${WORKDIR}/}"/gccinfo.log "${dir#${WORKDIR}/}"/build.log $(find -name "${dir#${WORKDIR}/}"/config.log)
 			rm "${dir#${WORKDIR}/}"/gccinfo.log "${dir#${WORKDIR}/}"/build.log
 			eerror
@@ -3168,6 +3168,7 @@ toolchain_death_notice() {
 			popd >/dev/null
 		fi
 	done
+	xz -9e "${WORKDIR}"/gcc-build-logs.tar.xz
 }
 
 fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-01-16  8:21 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-01-16  8:21 UTC (permalink / raw
  To: gentoo-commits
commit:     6c73b4acbae2ef7475471d1869b509d77ee980da
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Jan 16 08:20:53 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Jan 16 08:21:17 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=6c73b4ac
toolchain.eclass: another death_hooks fix
Hopefully the last.
Bug: https://bugs.gentoo.org/948045
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index ad4703fc550e..7068fc452dbe 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -3159,7 +3159,7 @@ toolchain_death_notice() {
 			pushd "${WORKDIR}" >/dev/null
 			(echo '' | $(tc-getCC ${CTARGET}) ${CFLAGS} -v -E - 2>&1) > "${dir}"/gccinfo.log
 			[[ -e "${T}"/build.log ]] && cp "${T}"/build.log "${dir}"
-			tar -arf "${WORKDIR}"/gcc-build-logs.tar.xz \
+			tar -arf "${WORKDIR}"/gcc-build-logs.tar \
 				"${dir#${WORKDIR}/}"/gccinfo.log "${dir#${WORKDIR}/}"/build.log $(find -name "${dir#${WORKDIR}/}"/config.log)
 			rm "${dir#${WORKDIR}/}"/gccinfo.log "${dir#${WORKDIR}/}"/build.log
 			eerror
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-01-16 14:06 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-01-16 14:06 UTC (permalink / raw
  To: gentoo-commits
commit:     89e3c1416372bd56bd6c8de7b5352c61b9f826f4
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Jan 11 12:30:06 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Thu Jan 16 14:06:07 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=89e3c141
cargo.eclass: Emit a warning if the package uses 300+ crates
Emit a QA warning suggesting the use of crate tarball, when the package
in question uses 300 crates or more.  Such a long crate lists cause
ebuilds and Manifests to grow very fast, causing significant space
consumption on end user systems (including users who are not using
the package in question) and git history growth.  On top of that,
fetching that many crates takes significant time.
The number of 300 is pretty arbitrary, chosen approximately to match
Manifests that are over 100 KiB in size.  We should probably look into
lowering in the future, as more packages are transitioned.
Closes: https://github.com/gentoo/gentoo/pull/40096
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/cargo.eclass | 8 +++++++-
 1 file changed, 7 insertions(+), 1 deletion(-)
diff --git a/eclass/cargo.eclass b/eclass/cargo.eclass
index b1285e13a5b2..0bc24feea222 100644
--- a/eclass/cargo.eclass
+++ b/eclass/cargo.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2024 Gentoo Authors
+# Copyright 1999-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: cargo.eclass
@@ -527,6 +527,12 @@ cargo_src_unpack() {
 		done < <(sha256sum -z "${crates[@]}" || die)
 
 		popd >/dev/null || die
+
+		if [[ ${#crates[@]} -ge 300 ]]; then
+			eqawarn "This package uses a very large number of CRATES.  Please provide"
+			eqawarn "a crate tarball instead and fetch it via SRC_URI.  You can use"
+			eqawarn "'pycargoebuild --crate-tarball' to create one."
+		fi
 	fi
 
 	cargo_gen_config
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-01-18  8:21 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-01-18  8:21 UTC (permalink / raw
  To: gentoo-commits
commit:     ee80caabafde70fb96d404137db093017c70d3a9
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Jan 18 07:22:05 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat Jan 18 07:22:05 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=ee80caab
llvm.org.eclass: Remove old snapshots
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 6 ------
 1 file changed, 6 deletions(-)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index a810027f74f5..d5a615383a19 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -75,12 +75,6 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 				20.0.0_pre20250111)
 					EGIT_COMMIT=8af4d206e0f979f68925a08f9dffd60a98ce97e2
 					;;
-				20.0.0_pre20250104)
-					EGIT_COMMIT=2529a8df53af9bc6cecfd6c83404ffa5e89e3370
-					;;
-				20.0.0_pre20241227)
-					EGIT_COMMIT=ccfe0de0e1e37ed369c9bf89dd0188ba0afb2e9a
-					;;
 				*)
 					die "Unknown snapshot: ${PV}"
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-01-18 15:09 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-01-18 15:09 UTC (permalink / raw
  To: gentoo-commits
commit:     be481e205c70f9f581206f87598e28e9af22ad71
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Jan 18 15:00:24 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat Jan 18 15:02:40 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=be481e20
llvm.org.eclass: Add 20.0.0_pre20250118 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index d5a615383a19..7d7774cfb027 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -72,6 +72,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 			_LLVM_SOURCE_TYPE=snapshot
 
 			case ${PV} in
+				20.0.0_pre20250118)
+					EGIT_COMMIT=c3a935e3f967f8f22f5db240d145459ee621c1e0
+					;;
 				20.0.0_pre20250111)
 					EGIT_COMMIT=8af4d206e0f979f68925a08f9dffd60a98ce97e2
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-01-18 23:51 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-01-18 23:51 UTC (permalink / raw
  To: gentoo-commits
commit:     5f69535668852a6c83b03d1e09f0a23f6d645a29
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Jan 18 23:43:32 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jan 18 23:51:22 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=5f695356
toolchain.eclass: drop redundant 'a' flag from tar invocation
.. for death hooks. We're not compressing yet, hence we certainly
don't need autodetection of compression based on suffix...
Bug: https://bugs.gentoo.org/948045
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 3f6fd1cfd821..18e5619b10c2 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -3159,7 +3159,7 @@ toolchain_death_notice() {
 			pushd "${WORKDIR}" >/dev/null
 			(echo '' | $(tc-getCC ${CTARGET}) ${CFLAGS} -v -E - 2>&1) > "${dir}"/gccinfo.log
 			[[ -e "${T}"/build.log ]] && cp "${T}"/build.log "${dir}"
-			tar -arf "${WORKDIR}"/gcc-build-logs.tar \
+			tar -rf "${WORKDIR}"/gcc-build-logs.tar \
 				"${dir#${WORKDIR}/}"/gccinfo.log "${dir#${WORKDIR}/}"/build.log $(find -name "${dir#${WORKDIR}/}"/config.log)
 			rm "${dir#${WORKDIR}/}"/gccinfo.log "${dir#${WORKDIR}/}"/build.log
 			eerror
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-01-18 23:51 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-01-18 23:51 UTC (permalink / raw
  To: gentoo-commits
commit:     71d7f80e14968cb219e40700721f1c50f6052705
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Jan 18 23:42:34 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jan 18 23:51:21 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=71d7f80e
toolchain.eclass: don't try to compress a (non-existent) compress file
... in death hook. Pointed out by Eli.
Bug: https://bugs.gentoo.org/948045
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 7068fc452dbe..3f6fd1cfd821 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -3168,7 +3168,7 @@ toolchain_death_notice() {
 			popd >/dev/null
 		fi
 	done
-	xz -9e "${WORKDIR}"/gcc-build-logs.tar.xz
+	xz -9e "${WORKDIR}"/gcc-build-logs.tar
 }
 
 fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-01-18 23:51 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-01-18 23:51 UTC (permalink / raw
  To: gentoo-commits
commit:     2ca5e513fa45a32fbf03b130ca8d1ec5e3e73641
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Jan 18 23:47:31 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jan 18 23:51:22 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=2ca5e513
toolchain.eclass: fix finding config.logs in death hooks
Bug: https://bugs.gentoo.org/948045
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 18e5619b10c2..df5daeb6dfe4 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -3160,7 +3160,7 @@ toolchain_death_notice() {
 			(echo '' | $(tc-getCC ${CTARGET}) ${CFLAGS} -v -E - 2>&1) > "${dir}"/gccinfo.log
 			[[ -e "${T}"/build.log ]] && cp "${T}"/build.log "${dir}"
 			tar -rf "${WORKDIR}"/gcc-build-logs.tar \
-				"${dir#${WORKDIR}/}"/gccinfo.log "${dir#${WORKDIR}/}"/build.log $(find -name "${dir#${WORKDIR}/}"/config.log)
+				"${dir#${WORKDIR}/}"/gccinfo.log "${dir#${WORKDIR}/}"/build.log $(find "${dir#${WORKDIR}/}" -type f -name "config.log")
 			rm "${dir#${WORKDIR}/}"/gccinfo.log "${dir#${WORKDIR}/}"/build.log
 			eerror
 			eerror "Please include ${WORKDIR}/gcc-build-logs.tar.xz in your bug report."
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-01-19  1:16 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-01-19  1:16 UTC (permalink / raw
  To: gentoo-commits
commit:     d6788adfff00dacda8c3f1a19d806dad5ba80e89
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Jan 19 01:16:12 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Jan 19 01:16:12 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=d6788adf
toolchain.eclass: add TODO for collecting differing bootstrap objects
Add a TODO for bootstrap comparison failures, where we should include the stage2 & stage3
differing objects to avoid having to ask reporters to manually collect...
Bug: https://bugs.gentoo.org/904426
Bug: https://bugs.gentoo.org/920719
Bug: https://bugs.gentoo.org/932789
Bug: https://bugs.gentoo.org/947752
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 2 ++
 1 file changed, 2 insertions(+)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index df5daeb6dfe4..a52fd268c8e8 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -3153,6 +3153,8 @@ XGCC() { get_make_var GCC_FOR_TARGET ; }
 
 has toolchain_death_notice ${EBUILD_DEATH_HOOKS} || EBUILD_DEATH_HOOKS+=" toolchain_death_notice"
 toolchain_death_notice() {
+	# TODO: For bootstrap comparison failures, include the stage2 & stage3
+	# differing objects to avoid having to ask reporters to manually collect...
 	local dir
 	for dir in "${WORKDIR}"/build-jit "${WORKDIR}"/build ; do
 		if [[ -e "${dir}" ]] ; then
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-01-20  9:44 Petr Vaněk
  0 siblings, 0 replies; 6663+ messages in thread
From: Petr Vaněk @ 2025-01-20  9:44 UTC (permalink / raw
  To: gentoo-commits
commit:     6ee5fb922e28796f012a42457f2afb7d86566544
Author:     Petr Vaněk <arkamar <AT> gentoo <DOT> org>
AuthorDate: Fri Jan  3 10:45:14 2025 +0000
Commit:     Petr Vaněk <arkamar <AT> gentoo <DOT> org>
CommitDate: Mon Jan 20 09:44:29 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=6ee5fb92
dotnet.eclass: mark as deprecated
The eclass has last two consumers in the tree. One of them is already
last-rited, the second is slowly rotting. However, the eclass is still
used in ::dotnet overlay, which does not seem to be very active and it
is not in good shape.
Signed-off-by: Petr Vaněk <arkamar <AT> gentoo.org>
 eclass/dotnet.eclass | 3 ++-
 1 file changed, 2 insertions(+), 1 deletion(-)
diff --git a/eclass/dotnet.eclass b/eclass/dotnet.eclass
index aeaee2f58e94..3a65626032cb 100644
--- a/eclass/dotnet.eclass
+++ b/eclass/dotnet.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2024 Gentoo Authors
+# Copyright 1999-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: dotnet.eclass
@@ -6,6 +6,7 @@
 # maintainer-needed@gentoo.org
 # @SUPPORTED_EAPIS: 7
 # @BLURB: common settings and functions for mono and dotnet related packages
+# @DEPRECATED: none
 # @DESCRIPTION:
 # The dotnet eclass contains common environment settings that are useful for
 # dotnet packages.  Currently, it provides no functions, just exports
^ permalink raw reply related	[flat|nested] 6663+ messages in thread
* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-01-20  9:44 Petr Vaněk
  0 siblings, 0 replies; 6663+ messages in thread
From: Petr Vaněk @ 2025-01-20  9:44 UTC (permalink / raw
  To: gentoo-commits
commit:     1952483833e727ce9c6f2629822209f4ffadd16f
Author:     Petr Vaněk <arkamar <AT> gentoo <DOT> org>
AuthorDate: Fri Jan  3 11:09:29 2025 +0000
Commit:     Petr Vaněk <arkamar <AT> gentoo <DOT> org>
CommitDate: Mon Jan 20 09:44:40 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=19524838
mono.eclass: mark as DEAD
The eclass is no longer used by any package in the tree nor in ::dotnet
overlay.
Bug: https://bugs.gentoo.org/372453
Bug: https://bugs.gentoo.org/374867
Signed-off-by: Petr Vaněk <arkamar <AT> gentoo.org>
 eclass/mono.eclass | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/eclass/mono.eclass b/eclass/mono.eclass
index c096acc8c40e..d4f45e5acf70 100644
--- a/eclass/mono.eclass
+++ b/eclass/mono.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2023 Gentoo Authors
+# Copyright 1999-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: mono.eclass
@@ -6,7 +6,7 @@
 # maintainer-needed@gentoo.org
 # @SUPPORTED_EAPIS: 7
 # @BLURB: common settings and functions for mono and dotnet related packages
-# @DEPRECATED: mono-env
+# @DEAD
 # @DESCRIPTION:
 # The mono eclass contains common environment settings that are useful for
 # dotnet packages.  Currently, it provides no functions, just exports
^ permalink raw reply related	[flat|nested] 6663+ messages in thread
* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-01-21 23:13 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-01-21 23:13 UTC (permalink / raw
  To: gentoo-commits
commit:     b9c5c7723b11f68319ff9d00a3eeba26c4a22733
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Jan 21 23:12:23 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jan 21 23:12:54 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=b9c5c772
toolchain.eclass: use lib*, not get_libdir for cross
get_libdir isn't right for ROOT and cross-compilation.
Closes: https://bugs.gentoo.org/908455
Bug: https://bugs.gentoo.org/794181
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 4 +++-
 1 file changed, 3 insertions(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index a52fd268c8e8..3f7c2fbff780 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -2749,7 +2749,9 @@ gcc_movelibs() {
 	# code to run on the target.
 	if is_crosscompile ; then
 		dodir "${HOSTLIBPATH#${EPREFIX}}"
-		mv "${ED}"/usr/$(get_libdir)/libcc1* "${D}${HOSTLIBPATH}" || die
+		# XXX: Ideally, we'd use $(get_libdir) here, but it's
+		# not right for cross. See bug #942573 and bug #794181.
+		mv "${ED}"/usr/lib*/libcc1* "${D}${HOSTLIBPATH}" || die
 	fi
 
 	# libgccjit gets installed to /usr/lib, not /usr/$(get_libdir). Probably
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-01-22 19:15 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-01-22 19:15 UTC (permalink / raw
  To: gentoo-commits
commit:     15f80deb9b3f0020ba3949b6dc1edba029d6daa1
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Wed Jan 22 16:33:04 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Wed Jan 22 19:15:18 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=15f80deb
llvm.org.eclass: Add 20.0.0_pre20250122 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index 414a9ef59523..67fabd54e768 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -72,6 +72,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 			_LLVM_SOURCE_TYPE=snapshot
 
 			case ${PV} in
+				20.0.0_pre20250122)
+					EGIT_COMMIT=97c3a990f05606cb807faf53bc41302fb62c7980
+					;;
 				20.0.0_pre20250118)
 					EGIT_COMMIT=c3a935e3f967f8f22f5db240d145459ee621c1e0
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-01-22 19:15 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-01-22 19:15 UTC (permalink / raw
  To: gentoo-commits
commit:     c44b01389c8cd7af719b5e0b7838e8315f1648e9
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Wed Jan 22 16:32:27 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Wed Jan 22 19:15:17 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=c44b0138
llvm.org.eclass: SPIRV is production since 20.0.0_pre20250122
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 28 ++++++++++++++++++++--------
 1 file changed, 20 insertions(+), 8 deletions(-)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index 7d7774cfb027..414a9ef59523 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -185,14 +185,26 @@ case ${LLVM_MAJOR} in
 		)
 		;;
 	*)
-		ALL_LLVM_EXPERIMENTAL_TARGETS=(
-			ARC CSKY DirectX M68k SPIRV Xtensa
-		)
-		ALL_LLVM_PRODUCTION_TARGETS=(
-			AArch64 AMDGPU ARM AVR BPF Hexagon Lanai LoongArch Mips
-			MSP430 NVPTX PowerPC RISCV Sparc SystemZ VE WebAssembly X86
-			XCore
-		)
+		# TODO: limit to < 20 when we remove old snapshots
+		if ver_test ${PV} -lt 20.0.0_pre20250122; then
+			ALL_LLVM_EXPERIMENTAL_TARGETS=(
+				ARC CSKY DirectX M68k SPIRV Xtensa
+			)
+			ALL_LLVM_PRODUCTION_TARGETS=(
+				AArch64 AMDGPU ARM AVR BPF Hexagon Lanai LoongArch Mips
+				MSP430 NVPTX PowerPC RISCV Sparc SystemZ VE WebAssembly X86
+				XCore
+			)
+		else
+			ALL_LLVM_EXPERIMENTAL_TARGETS=(
+				ARC CSKY DirectX M68k Xtensa
+			)
+			ALL_LLVM_PRODUCTION_TARGETS=(
+				AArch64 AMDGPU ARM AVR BPF Hexagon Lanai LoongArch Mips
+				MSP430 NVPTX PowerPC RISCV Sparc SPIRV SystemZ VE
+				WebAssembly X86 XCore
+			)
+		fi
 		;;
 esac
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-01-25 13:33 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-01-25 13:33 UTC (permalink / raw
  To: gentoo-commits
commit:     980eeb06da7b108911fc971f037296ccaa5a8225
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Jan 25 13:07:48 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat Jan 25 13:32:54 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=980eeb06
llvm.org.eclass: Add 20.0.0_pre20250125 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index 67fabd54e768..c99aa430a740 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -72,6 +72,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 			_LLVM_SOURCE_TYPE=snapshot
 
 			case ${PV} in
+				20.0.0_pre20250125)
+					EGIT_COMMIT=1f26ac10ca1bef40a80be8f81a6f109713bc586f
+					;;
 				20.0.0_pre20250122)
 					EGIT_COMMIT=97c3a990f05606cb807faf53bc41302fb62c7980
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-01-28  7:22 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-01-28  7:22 UTC (permalink / raw
  To: gentoo-commits
commit:     914fa2ab19a1a8313a05b657e09bc29ec61230a3
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Jan 28 07:19:22 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jan 28 07:19:22 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=914fa2ab
flag-o-matic.eclass: fix negation of -fstack-protector-all
Closes: https://bugs.gentoo.org/943761
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/flag-o-matic.eclass | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/eclass/flag-o-matic.eclass b/eclass/flag-o-matic.eclass
index 3e67e3b4c11f..9590192bb1f4 100644
--- a/eclass/flag-o-matic.eclass
+++ b/eclass/flag-o-matic.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2024 Gentoo Authors
+# Copyright 1999-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: flag-o-matic.eclass
@@ -201,7 +201,7 @@ _filter-hardened() {
 					continue
 				fi
 
-				is-flagq -fno-stack-protector-all || append-flags $(test-flags -fno-stack-protector-all)
+				is-flagq -fno-stack-protector || append-flags $(test-flags -fno-stack-protector)
 				;;
 			-fno-strict-overflow)
 				gcc-specs-nostrict || continue
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-01-28 12:15 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-01-28 12:15 UTC (permalink / raw
  To: gentoo-commits
commit:     ddb45b4bb42a99dcf16bcfbbd59a8028fd14187e
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Jan 28 12:14:20 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jan 28 12:14:20 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=ddb45b4b
cargo.eclass: respect MAKEOPTS for `cargo test`
Without this, while (test) compile jobs respect MAKEOPTS via our config settings
already deployed via the eclass, *test* jobs do not.
We may want to consider setting NEXTEST_TEST_THREADS and/or having
a cargo_enable_tests helper in the eclass at some point too.
Bug: https://github.com/rust-lang/cargo/issues/8430
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/cargo.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/cargo.eclass b/eclass/cargo.eclass
index 0bc24feea222..25a2127f6391 100644
--- a/eclass/cargo.eclass
+++ b/eclass/cargo.eclass
@@ -396,6 +396,9 @@ cargo_gen_config() {
 	jobs = $(makeopts_jobs)
 	incremental = false
 
+	[env]
+	RUST_TEST_THREADS = "$(makeopts_jobs)"
+
 	[term]
 	verbose = true
 	$([[ "${NOCOLOR}" = true || "${NOCOLOR}" = yes ]] && echo "color = 'never'")
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-01-29 23:22 Matt Jolly
  0 siblings, 0 replies; 6663+ messages in thread
From: Matt Jolly @ 2025-01-29 23:22 UTC (permalink / raw
  To: gentoo-commits
commit:     604336243989f74e6e9f459a95debea71d8b0945
Author:     Matt Jolly <kangie <AT> gentoo <DOT> org>
AuthorDate: Wed Jan 29 05:03:32 2025 +0000
Commit:     Matt Jolly <kangie <AT> gentoo <DOT> org>
CommitDate: Wed Jan 29 23:16:22 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=60433624
rust.eclass: Drop 1.54.0
This slot was removed when the (m)rust(c) bootstrap path was added
but its removal from the eclass was overlooked.
Signed-off-by: Matt Jolly <kangie <AT> gentoo.org>
 eclass/rust.eclass | 2 --
 1 file changed, 2 deletions(-)
diff --git a/eclass/rust.eclass b/eclass/rust.eclass
index 0630d5973854..d25c5303c0d0 100644
--- a/eclass/rust.eclass
+++ b/eclass/rust.eclass
@@ -79,7 +79,6 @@ declare -A -g -r _RUST_LLVM_MAP=(
 	["1.75.0"]=17
 	["1.74.1"]=17
 	["1.71.1"]=16
-	["1.54.0"]=12
 )
 
 # @ECLASS_VARIABLE: _RUST_SLOTS_ORDERED
@@ -101,7 +100,6 @@ declare -a -g -r _RUST_SLOTS_ORDERED=(
 	"1.75.0"
 	"1.74.1"
 	"1.71.1"
-	"1.54.0"
 )
 
 # == user control knobs ==
^ permalink raw reply related	[flat|nested] 6663+ messages in thread
* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-01-30  1:31 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-01-30  1:31 UTC (permalink / raw
  To: gentoo-commits
commit:     d0f22208ed3fe7a108614c01217d8a6cfffcf049
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Jan 30 01:19:49 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Jan 30 01:19:49 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=d0f22208
toolchain.eclass: add TODO for --enable-version-specific-runtime-libs
While we pass it only for Darwin, I have to wonder if these days
at least whether we should be using that all the time instead of passing
LIBPATH.
Prompted by https://inbox.sourceware.org/libc-alpha/5fc11ae8d8cc26b8cb2b500ee7a08ce8f6e98588.camel <AT> xry111.site/.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 2 ++
 1 file changed, 2 insertions(+)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 3f7c2fbff780..2bfa751b531d 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -2266,6 +2266,8 @@ gcc_do_make() {
 
 	local emakeargs=(
 		LDFLAGS="${LDFLAGS}"
+		# TODO: Can we replace this with --enable-version-specific-runtime-libs
+		# these days?
 		LIBPATH="${LIBPATH}"
 	)
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-01-31 21:51 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-01-31 21:51 UTC (permalink / raw
  To: gentoo-commits
commit:     e334611f71b57f3696da8457a93ce59f4be30c61
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Fri Jan 31 21:00:00 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Fri Jan 31 21:50:57 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=e334611f
llvm.org.eclass: main is now 21.x
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index 305d68328028..348bea3dd1db 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -57,7 +57,7 @@ LLVM_VERSION=$(ver_cut 1-3)
 # @DESCRIPTION:
 # The major version of current LLVM trunk.  Used to determine
 # the correct branch to use.
-_LLVM_MAIN_MAJOR=20
+_LLVM_MAIN_MAJOR=21
 
 # @ECLASS_VARIABLE: _LLVM_SOURCE_TYPE
 # @INTERNAL
^ permalink raw reply related	[flat|nested] 6663+ messages in thread
* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-01-31 21:51 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-01-31 21:51 UTC (permalink / raw
  To: gentoo-commits
commit:     2ea3c0bfc6eb84b48f567783134e9c892a7d6d54
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Fri Jan 31 20:59:45 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Fri Jan 31 21:50:56 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=2ea3c0bf
llvm.org.eclass: Remove old snapshots
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 9 ---------
 1 file changed, 9 deletions(-)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index c99aa430a740..305d68328028 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -75,15 +75,6 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 				20.0.0_pre20250125)
 					EGIT_COMMIT=1f26ac10ca1bef40a80be8f81a6f109713bc586f
 					;;
-				20.0.0_pre20250122)
-					EGIT_COMMIT=97c3a990f05606cb807faf53bc41302fb62c7980
-					;;
-				20.0.0_pre20250118)
-					EGIT_COMMIT=c3a935e3f967f8f22f5db240d145459ee621c1e0
-					;;
-				20.0.0_pre20250111)
-					EGIT_COMMIT=8af4d206e0f979f68925a08f9dffd60a98ce97e2
-					;;
 				*)
 					die "Unknown snapshot: ${PV}"
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-02-01  0:40 Ionen Wolkens
  0 siblings, 0 replies; 6663+ messages in thread
From: Ionen Wolkens @ 2025-02-01  0:40 UTC (permalink / raw
  To: gentoo-commits
commit:     7827b36dd37936a36d455fbd910d620ecbf11381
Author:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
AuthorDate: Sat Feb  1 00:04:57 2025 +0000
Commit:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
CommitDate: Sat Feb  1 00:34:21 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=7827b36d
qt6-build.eclass: update for user_facing_tool_links.txt changes
Still keep a bash loop given want to keep the sanity check and it
spares us from doing `cd "${D}${QT6_PREFIX}"` for a `xargs ln` to
work, but it let us simplify a little bit.
Keeping old version in its own block so it's easy to drop later.
Also drop the empty ${links} variable from the sanity check, dates
back to old unused code.
Closes: https://bugs.gentoo.org/949126
Signed-off-by: Ionen Wolkens <ionen <AT> gentoo.org>
 eclass/qt6-build.eclass | 29 ++++++++++++++++++++++-------
 1 file changed, 22 insertions(+), 7 deletions(-)
diff --git a/eclass/qt6-build.eclass b/eclass/qt6-build.eclass
index 31bdf1e01167..ae23f4e9bd82 100644
--- a/eclass/qt6-build.eclass
+++ b/eclass/qt6-build.eclass
@@ -234,18 +234,33 @@ _qt6-build_create_user_facing_links() {
 	# even if no links (empty), if missing will assume that it is an error
 	[[ ${PN} == qttranslations ]] && return
 
-	# loop and match using paths (upstream suggests `xargs ln -s < ${links}`
-	# but, for what it is worth, that will fail if paths have spaces)
+	# TODO: drop when <6.8.3 is gone, unneeded version with relative paths
+	if ver_test -lt 6.8.3; then
+		local link
+		while IFS= read -r link; do
+			if [[ -z ${link} ]]; then
+				continue
+			elif [[ ${link} =~ ^("${QT6_PREFIX}"/.+)\ ("${QT6_PREFIX}"/bin/.+) ]]
+			then
+				dosym -r "${BASH_REMATCH[1]#"${EPREFIX}"}" \
+					"${BASH_REMATCH[2]#"${EPREFIX}"}"
+			else
+				die "unrecognized user_facing_tool_links.txt line: ${link}"
+			fi
+		done < "${BUILD_DIR}"/user_facing_tool_links.txt || die
+
+		return
+	fi
+
 	local link
 	while IFS= read -r link; do
 		if [[ -z ${link} ]]; then
 			continue
-		elif [[ ${link} =~ ^("${QT6_PREFIX}"/.+)\ ("${QT6_PREFIX}"/bin/.+) ]]
-		then
-			dosym -r "${BASH_REMATCH[1]#"${EPREFIX}"}" \
-				"${BASH_REMATCH[2]#"${EPREFIX}"}"
+		elif [[ ${link} =~ (../[^ ]+)\ (bin/.+) ]]; then
+			dosym "${BASH_REMATCH[1]}" \
+				"${QT6_PREFIX#"${EPREFIX}"}/${BASH_REMATCH[2]}"
 		else
-			die "unrecognized line '${link}' in '${links}'"
+			die "unrecognized user_facing_tool_links.txt line: ${link}"
 		fi
 	done < "${BUILD_DIR}"/user_facing_tool_links.txt || die
 }
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-02-01 13:14 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-02-01 13:14 UTC (permalink / raw
  To: gentoo-commits
commit:     d12a6adf88f47be36f883b7d959a1a1046d20847
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Feb  1 13:11:50 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat Feb  1 13:14:38 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=d12a6adf
llvm.org.eclass: Add 21.0.0_pre20250201 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index 348bea3dd1db..f9704aceeb2a 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -72,6 +72,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 			_LLVM_SOURCE_TYPE=snapshot
 
 			case ${PV} in
+				21.0.0_pre20250201)
+					EGIT_COMMIT=bfa7edcc6652bdb37d53e0cec64926aab3f280eb
+					;;
 				20.0.0_pre20250125)
 					EGIT_COMMIT=1f26ac10ca1bef40a80be8f81a6f109713bc586f
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-02-05 20:37 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-02-05 20:37 UTC (permalink / raw
  To: gentoo-commits
commit:     1f793c840c6e1854649b328bdb6b58f09b7bd77d
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Feb  5 20:37:19 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Feb  5 20:37:19 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=1f793c84
toolchain.eclass: drop flags not supported by GCC 9
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 5 +++++
 1 file changed, 5 insertions(+)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 2bfa751b531d..fb8ebedd9de3 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -2099,6 +2099,11 @@ gcc_do_filter_flags() {
 	# https://gcc.gnu.org/PR100431
 	filter-flags -Werror=format-security
 
+	if ver_test -lt 10.1 ; then
+		filter-flags '-fdiagnostics-urls=*'
+		filter-flags '-Wstringop-overread'
+	fi
+
 	if ver_test -lt 13.6 ; then
 		# These aren't supported by the just-built compiler either.
 		filter-flags -fharden-compares -fharden-conditional-branches \
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-02-06 16:40 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-02-06 16:40 UTC (permalink / raw
  To: gentoo-commits
commit:     c19cd9a609d2b7f5e70a114899fd71f8e32a124e
Author:     Z. Liu <zhixu.liu <AT> gmail <DOT> com>
AuthorDate: Wed Feb  5 15:02:39 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Feb  6 16:40:18 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=c19cd9a6
toolchain.eclass: fix typo sys-devel/ -> llvm-core/
Signed-off-by: Z. Liu <zhixu.liu <AT> gmail.com>
Closes: https://github.com/gentoo/gentoo/pull/40452
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index fb8ebedd9de3..f203e32a0450 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -2972,7 +2972,7 @@ toolchain_pkg_postrm() {
 		return 0
 	else
 		# Removed the last GCC installed (bug #906040)
-		if ! has_version "sys-devel/gcc" && has_version "sys-devel/clang" ; then
+		if ! has_version "sys-devel/gcc" && has_version "llvm-core/clang" ; then
 			einfo "Last GCC version removed. Cleaning up ${EROOT}/etc/clang/gentoo-gcc-install.cfg."
 			echo > "${EROOT}"/etc/clang/gentoo-gcc-install.cfg
 		fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-02-07 18:04 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-02-07 18:04 UTC (permalink / raw
  To: gentoo-commits
commit:     672b4e16d50c895f63ed0dffd13b127735adaa89
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Feb  7 18:01:22 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Feb  7 18:04:11 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=672b4e16
toolchain.eclass: depend on doxygen for USE=doc
Needed for libstdc++ docs.
This goes back to 3998c0e241690b9f5520a66c36382d6173c2bdad and
337957a79e26b67eda2ef3bd5af71f75217b32b5. I don't see why we want
that behaviour these days.
Closes: https://bugs.gentoo.org/949398
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 27 ++++++++++++---------------
 1 file changed, 12 insertions(+), 15 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index f203e32a0450..153018607a02 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -373,6 +373,7 @@ BDEPEND="
 	app-alternatives/yacc
 	sys-devel/binutils:*
 	>=sys-devel/flex-2.5.4
+	doc? ( app-text/doxygen )
 	nls? ( sys-devel/gettext )
 	test? (
 		${PYTHON_DEPS}
@@ -2348,21 +2349,17 @@ gcc_do_make() {
 	emake "${emakeargs[@]}" ${GCC_MAKE_TARGET}
 
 	if ! is_crosscompile && _tc_use_if_iuse cxx && _tc_use_if_iuse doc ; then
-		if type -p doxygen > /dev/null ; then
-			cd "${CTARGET}"/libstdc++-v3/doc || die
-			emake doc-man-doxygen
-
-			# Clean bogus manpages. bug #113902
-			find -name '*_build_*' -delete || die
-
-			# Blow away generated directory references. Newer versions of gcc
-			# have gotten better at this, but not perfect. This is easier than
-			# backporting all of the various doxygen patches. bug #486754
-			find -name '*_.3' -exec grep -l ' Directory Reference ' {} + | \
-				xargs rm -f
-		else
-			ewarn "Skipping libstdc++ manpage generation since you don't have doxygen installed"
-		fi
+		cd "${CTARGET}"/libstdc++-v3/doc || die
+		emake doc-man-doxygen
+
+		# Clean bogus manpages. bug #113902
+		find -name '*_build_*' -delete || die
+
+		# Blow away generated directory references. Newer versions of gcc
+		# have gotten better at this, but not perfect. This is easier than
+		# backporting all of the various doxygen patches. bug #486754
+		find -name '*_.3' -exec grep -l ' Directory Reference ' {} + | \
+			xargs rm -f
 	fi
 
 	popd >/dev/null || die
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-02-07 18:33 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-02-07 18:33 UTC (permalink / raw
  To: gentoo-commits
commit:     5837f60b82e256c6321fe741c75a3d0933875def
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Feb  7 18:32:57 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Feb  7 18:33:24 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=5837f60b
toolchain.eclass: fix USE=doc for non-gcc (kgcc64)
We can simplify the has_feature ... && _use_if ... later.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 11 ++++++++---
 1 file changed, 8 insertions(+), 3 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 153018607a02..205c0e5314db 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -299,7 +299,8 @@ tc_has_feature() {
 if [[ ${PN} != kgcc64 && ${PN} != gcc-* ]] ; then
 	IUSE+=" debug +cxx"
 	IUSE+=" +fortran" TC_FEATURES+=( fortran )
-	IUSE+=" doc hardened multilib objc"
+	IUSE+=" doc" TC_FEATURES+=( doc )
+	IUSE+=" hardened multilib objc"
 	IUSE+=" pgo"
 	IUSE+=" objc-gc" TC_FEATURES+=( objc-gc )
 	IUSE+=" libssp objc++"
@@ -373,7 +374,6 @@ BDEPEND="
 	app-alternatives/yacc
 	sys-devel/binutils:*
 	>=sys-devel/flex-2.5.4
-	doc? ( app-text/doxygen )
 	nls? ( sys-devel/gettext )
 	test? (
 		${PYTHON_DEPS}
@@ -381,6 +381,11 @@ BDEPEND="
 		>=sys-devel/autogen-5.5.4
 	)
 "
+
+if tc_has_feature doc ; then
+	BDEPEND+=" doc? ( app-text/doxygen )"
+fi
+
 DEPEND="${RDEPEND}"
 
 if [[ ${PN} == gcc && ${PV} == *_p* ]] ; then
@@ -2348,7 +2353,7 @@ gcc_do_make() {
 	pushd "${WORKDIR}"/build >/dev/null || die
 	emake "${emakeargs[@]}" ${GCC_MAKE_TARGET}
 
-	if ! is_crosscompile && _tc_use_if_iuse cxx && _tc_use_if_iuse doc ; then
+	if ! is_crosscompile && _tc_use_if_iuse cxx && tc_has_feature doc && _tc_use_if_iuse doc ; then
 		cd "${CTARGET}"/libstdc++-v3/doc || die
 		emake doc-man-doxygen
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-02-08 11:51 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-02-08 11:51 UTC (permalink / raw
  To: gentoo-commits
commit:     431a332e56d5345e2feea11a15da14cd642d37c3
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Feb  8 11:48:32 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat Feb  8 11:48:32 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=431a332e
llvm.org.eclass: Add 21.0.0_pre20250208 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index f9704aceeb2a..2cad858c64fe 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -72,6 +72,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 			_LLVM_SOURCE_TYPE=snapshot
 
 			case ${PV} in
+				21.0.0_pre20250208)
+					EGIT_COMMIT=6f241e36831927e3aea113cfc017c34fdeda340a
+					;;
 				21.0.0_pre20250201)
 					EGIT_COMMIT=bfa7edcc6652bdb37d53e0cec64926aab3f280eb
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-02-09 19:13 Andreas Sturmlechner
  0 siblings, 0 replies; 6663+ messages in thread
From: Andreas Sturmlechner @ 2025-02-09 19:13 UTC (permalink / raw
  To: gentoo-commits
commit:     f5673fc04204031e26bdfa18f26b741ea65d8a26
Author:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
AuthorDate: Sun Jan 12 11:34:36 2025 +0000
Commit:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
CommitDate: Sun Feb  9 19:12:12 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=f5673fc0
ecm.eclass: Strip SLOT of sub-slot to sanitise metainfo target path
Amends c715f7a87d835a5d7eb9204475e4e8360c6e8908
Signed-off-by: Andreas Sturmlechner <asturm <AT> gentoo.org>
 eclass/ecm.eclass | 8 ++++----
 1 file changed, 4 insertions(+), 4 deletions(-)
diff --git a/eclass/ecm.eclass b/eclass/ecm.eclass
index 826a32a17d08..1f40dd69fc74 100644
--- a/eclass/ecm.eclass
+++ b/eclass/ecm.eclass
@@ -749,18 +749,18 @@ ecm_src_install() {
 
 	if [[ -n ${_KDE_ORG_ECLASS} && -d "${ED}"/usr/share/metainfo/ ]]; then
 		if [[ ${KDE_ORG_NAME} != ${PN} ]]; then
-			local ecm_metainfo
+			local ecm_metainfo mainslot=${SLOT%/*}
 			pushd "${ED}"/usr/share/metainfo/ > /dev/null || die
 			for ecm_metainfo in find * -type f -iname "*metainfo.xml"; do
 				case ${ecm_metainfo} in
 					*${KDE_ORG_NAME}*)
-						mv_metainfo ${ecm_metainfo} ${KDE_ORG_NAME} ${PN}${SLOT/0*/}
+						mv_metainfo ${ecm_metainfo} ${KDE_ORG_NAME} ${PN}${mainslot/0*/}
 						;;
 					*${KDE_ORG_NAME/-/_}*)
-						mv_metainfo ${ecm_metainfo} ${KDE_ORG_NAME/-/_} ${PN}${SLOT/0*/}
+						mv_metainfo ${ecm_metainfo} ${KDE_ORG_NAME/-/_} ${PN}${mainslot/0*/}
 						;;
 					org.kde.*)
-						mv_metainfo ${ecm_metainfo} "org.kde." "org.kde.${PN}${SLOT/0*/}-"
+						mv_metainfo ${ecm_metainfo} "org.kde." "org.kde.${PN}${mainslot/0*/}-"
 						;;
 				esac
 			done
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-02-09 19:13 Andreas Sturmlechner
  0 siblings, 0 replies; 6663+ messages in thread
From: Andreas Sturmlechner @ 2025-02-09 19:13 UTC (permalink / raw
  To: gentoo-commits
commit:     2e24587327724df1b3124baa2e8360e0fcaa9870
Author:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
AuthorDate: Tue Dec 17 22:26:18 2024 +0000
Commit:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
CommitDate: Sun Feb  9 19:12:12 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=2e245873
ecm.eclass: Replace KDE_GCC_MINIMAL logic with tc-check-min_ver
Signed-off-by: Andreas Sturmlechner <asturm <AT> gentoo.org>
 eclass/ecm.eclass | 15 +++------------
 1 file changed, 3 insertions(+), 12 deletions(-)
diff --git a/eclass/ecm.eclass b/eclass/ecm.eclass
index e433952903e8..876039705288 100644
--- a/eclass/ecm.eclass
+++ b/eclass/ecm.eclass
@@ -488,18 +488,9 @@ _ecm_deprecated_check_gcc_version() {
 	if ver_test ${KFMIN} -ge 6.9; then
 		eqawarn "QA notice: ecm_pkg_${1} has become a no-op."
 		eqawarn "It is no longer being exported with KFMIN >=6.9.0."
-		return
-	fi
-	if [[ ${MERGE_TYPE} != binary && -v KDE_GCC_MINIMAL ]] && tc-is-gcc; then
-
-		local version=$(gcc-version)
-
-		debug-print "GCC version check activated"
-		debug-print "Version detected: ${version}"
-		debug-print "Version required: ${KDE_GCC_MINIMAL}"
-
-		ver_test ${version} -lt ${KDE_GCC_MINIMAL} &&
-			die "Sorry, but gcc-${KDE_GCC_MINIMAL} or later is required for this package (found ${version})."
+	else
+		[[ ${MERGE_TYPE} != binary && -v KDE_GCC_MINIMAL ]] &&
+			tc-check-min_ver gcc ${KDE_GCC_MINIMAL}
 	fi
 }
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-02-09 19:13 Andreas Sturmlechner
  0 siblings, 0 replies; 6663+ messages in thread
From: Andreas Sturmlechner @ 2025-02-09 19:13 UTC (permalink / raw
  To: gentoo-commits
commit:     a5c363d516d91502cc766e0f4c914944c2498882
Author:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
AuthorDate: Tue Dec 17 22:46:31 2024 +0000
Commit:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
CommitDate: Sun Feb  9 19:12:12 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=a5c363d5
ecm.eclass: Introduce _ecm_handbook_optional() to support BUILD_DOC
Signed-off-by: Andreas Sturmlechner <asturm <AT> gentoo.org>
 eclass/ecm.eclass | 16 ++++++++++++++--
 1 file changed, 14 insertions(+), 2 deletions(-)
diff --git a/eclass/ecm.eclass b/eclass/ecm.eclass
index 876039705288..826a32a17d08 100644
--- a/eclass/ecm.eclass
+++ b/eclass/ecm.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2024 Gentoo Authors
+# Copyright 1999-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: ecm.eclass
@@ -334,6 +334,18 @@ DEPEND+=" ${COMMONDEPEND}"
 RDEPEND+=" ${COMMONDEPEND}"
 unset COMMONDEPEND
 
+# @FUNCTION: _ecm_handbook_optional
+# @DESCRIPTION:
+# Use with ECM_HANDBOOK=optional; ticks either -DBUILD_DOC if available,
+# or -DCMAKE_DISABLE_FIND_PACKAGE_KF${_KFSLOT}DocTools
+_ecm_handbook_optional() {
+	if grep -Eq "option.*BUILD_DOC" CMakeLists.txt; then
+		echo "-DBUILD_DOC=$(usex handbook)"
+	else
+		echo "-DCMAKE_DISABLE_FIND_PACKAGE_KF${_KFSLOT}DocTools=$(usex !handbook)"
+	fi
+}
+
 # @FUNCTION: _ecm_strip_handbook_translations
 # @INTERNAL
 # @DESCRIPTION:
@@ -621,7 +633,7 @@ ecm_src_configure() {
 	fi
 
 	if [[ ${ECM_HANDBOOK} = optional ]] ; then
-		cmakeargs+=( -DCMAKE_DISABLE_FIND_PACKAGE_KF${_KFSLOT}DocTools=$(usex !handbook) )
+		cmakeargs+=( $(_ecm_handbook_optional) )
 	fi
 
 	if in_iuse designer && [[ ${ECM_DESIGNERPLUGIN} = true ]]; then
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-02-10  6:43 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-02-10  6:43 UTC (permalink / raw
  To: gentoo-commits
commit:     f73d399425c97f21f01096d5c4cb44d1b0e2f290
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Feb 10 06:42:04 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Feb 10 06:43:05 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=f73d3994
toolchain.eclass: fix TODO typo
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 205c0e5314db..f0a6caf56748 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1479,7 +1479,7 @@ toolchain_src_configure() {
 
 		confgcc+=(
 			# https://gcc.gnu.org/PR100289
-			# TOOD: Find a way to disable this just for stage1 cross?
+			# TODO: Find a way to disable this just for stage1 cross?
 			--disable-gcov
 
 			--disable-bootstrap
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-02-11  8:39 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-02-11  8:39 UTC (permalink / raw
  To: gentoo-commits
commit:     90cadf879253a7ef6b439f7a51809f0b0b835693
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Feb 11 08:38:44 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Feb 11 08:39:03 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=90cadf87
go-env.eclass: refine filter-lto workaround for checking GCCs
We want to cover unreleased GCC too as it'll have the same (or same enough)
level of checking/debug assertions for the purposes of this bug) problem.
Bug: https://bugs.gentoo.org/912152
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/go-env.eclass | 10 ++++++++--
 1 file changed, 8 insertions(+), 2 deletions(-)
diff --git a/eclass/go-env.eclass b/eclass/go-env.eclass
index 11fdf943e774..b2b240b5ef29 100644
--- a/eclass/go-env.eclass
+++ b/eclass/go-env.eclass
@@ -1,4 +1,4 @@
-# Copyright 2023-2024 Gentoo Authors
+# Copyright 2023-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: go-env.eclass
@@ -40,7 +40,13 @@ go-env_set_compile_environment() {
 	use x86 && export GO386=$(go-env_go386)
 
 	# XXX: Hack for checking ICE (bug #912152, gcc PR113204)
-	has_version -b "sys-devel/gcc[debug]" && filter-lto
+	if tc-is-gcc ; then
+		# For either USE=debug or an unreleased compiler, non-default
+		# checking will trigger.
+		if has_version -b "sys-devel/gcc[debug]" || [[ $(gcc-minor-version) -eq 0 ]] ; then
+			filter-lto
+		fi
+	fi
 
 	export CGO_CFLAGS="${CGO_CFLAGS:-$CFLAGS}"
 	export CGO_CPPFLAGS="${CGO_CPPFLAGS:-$CPPFLAGS}"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-02-11 11:29 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-02-11 11:29 UTC (permalink / raw
  To: gentoo-commits
commit:     e23bd20d99663797bbb9e974c8308386988fb3d8
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Tue Feb 11 11:26:27 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Tue Feb 11 11:29:31 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=e23bd20d
Add 21.0.0_pre20250211 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index 2cad858c64fe..77a194ed49f4 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -72,6 +72,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 			_LLVM_SOURCE_TYPE=snapshot
 
 			case ${PV} in
+				21.0.0_pre20250211)
+					EGIT_COMMIT=2cd8207b26ea4269630feba661f68554d7ae3c15
+					;;
 				21.0.0_pre20250208)
 					EGIT_COMMIT=6f241e36831927e3aea113cfc017c34fdeda340a
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-02-13  8:49 Patrick Lauer
  0 siblings, 0 replies; 6663+ messages in thread
From: Patrick Lauer @ 2025-02-13  8:49 UTC (permalink / raw
  To: gentoo-commits
commit:     af87264b9ddb60dac6d58b0bcca57122e58a23e7
Author:     Patrick Lauer <patrick <AT> gentoo <DOT> org>
AuthorDate: Thu Feb 13 08:47:36 2025 +0000
Commit:     Patrick Lauer <patrick <AT> gentoo <DOT> org>
CommitDate: Thu Feb 13 08:49:44 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=af87264b
postgres.eclass: Remove support for slot 12
12 has been EOL for a while
Signed-off-by: Patrick Lauer <patrick <AT> gentoo.org>
 eclass/postgres.eclass | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/eclass/postgres.eclass b/eclass/postgres.eclass
index 21490df1965e..d743c5d0d165 100644
--- a/eclass/postgres.eclass
+++ b/eclass/postgres.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2024 Gentoo Authors
+# Copyright 1999-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: postgres.eclass
@@ -27,7 +27,7 @@ _POSTGRES_ECLASS=1
 # @DESCRIPTION:
 # List of versions to reverse sort POSTGRES_COMPAT slots
 
-_POSTGRES_ALL_VERSIONS=( 9999 17 16 15 14 13 12 )
+_POSTGRES_ALL_VERSIONS=( 9999 17 16 15 14 13 )
 
 
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread
* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-02-13 17:18 Ulrich Müller
  0 siblings, 0 replies; 6663+ messages in thread
From: Ulrich Müller @ 2025-02-13 17:18 UTC (permalink / raw
  To: gentoo-commits
commit:     65cb33ec019e2ce8980f546a137ba27c55042c55
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Mon Feb 10 19:05:59 2025 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Thu Feb 13 17:17:58 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=65cb33ec
eapi9-ver.eclass: New eclass
This implements the ver_replacing command, as proposed for EAPI 9:
| Takes an operator and a version string as arguments, which follow
| the same specification as in ver_test. Iterates over the elements
| of REPLACING_VERSIONS, using ver_test to compare each element with
| the version string. Returns shell true (0) if the specified relation
| is fulfilled for any element. Note that if REPLACING_VERSIONS is
| empty, shell false (1) is returned. The command is only meaningful
| in phases where \t{REPLACING_VERSIONS} is defined.
Bug: https://bugs.gentoo.org/947530
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 eclass/eapi9-ver.eclass | 50 +++++++++++++++++++++++++++++++++++++++++++++++++
 1 file changed, 50 insertions(+)
diff --git a/eclass/eapi9-ver.eclass b/eclass/eapi9-ver.eclass
new file mode 100644
index 000000000000..9908fec37de8
--- /dev/null
+++ b/eclass/eapi9-ver.eclass
@@ -0,0 +1,50 @@
+# Copyright 2025 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+# @ECLASS: eapi9-ver.eclass
+# @MAINTAINER:
+# Ulrich Müller <ulm@gentoo.org>
+# @AUTHOR:
+# Ulrich Müller <ulm@gentoo.org>
+# @SUPPORTED_EAPIS: 7 8
+# @BLURB: Testing implementation of EAPI 9 ver_replacing
+# @DESCRIPTION:
+# A stand-alone implementation of the ver_replacing function aimed
+# for EAPI 9.  Intended to be used for wider testing of the proposed
+# function and to allow ebuilds to switch to the new model early, with
+# minimal change needed for the actual EAPI 9.
+#
+# @CODE
+# if ver_replacing -lt 1.2; then
+#     elog "The frobnicate command was dropped in version 1.2"
+# fi
+# @CODE
+
+case ${EAPI} in
+	7|8) ;;
+	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
+esac
+
+# @FUNCTION: ver_replacing
+# @USAGE: <op> <ver>
+# @RETURN: 0 if any element of REPLACING_VERSIONS qualifies, 1 otherwise
+# @DESCRIPTION:
+# Compare each element <v> of REPLACING_VERSIONS with version <ver>
+# using ver_test().  Return 0 (true) if any element <v> fulfills
+# "ver_test <v> <op> <ver>", 1 (false) otherwise.
+#
+# Note: If REPLACING_VERSIONS is empty, 1 (false) is returned.
+ver_replacing() {
+	case ${EBUILD_PHASE} in
+		pretend|setup|preinst|postinst) ;;
+		*) die "ver_replacing is meaningless in the ${EBUILD_PHASE} phase" ;;
+	esac
+
+	[[ $# -eq 2 ]] || die "Usage: ver_replacing <op> <ver>"
+
+	local v
+	for v in ${REPLACING_VERSIONS}; do
+		ver_test "${v}" "$@" && return 0
+	done
+	return 1
+}
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-02-13 17:51 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-02-13 17:51 UTC (permalink / raw
  To: gentoo-commits
commit:     23b50c6c1fe264b0e5dd9149e9a560b2b506b1de
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Feb 13 17:50:07 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Feb 13 17:51:16 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=23b50c6c
toolchain.eclass: drop gnat-gpl from *DEPEND
The binhost builder sometimes ends up trying to build gnat-gpl which
fails on some stuff like Fortran sometimes. It's not worth spending
time investigating, we have ada-bootstrap for a reason, including
dev-lang/ada-bootstrap-0_p2021-r1 which is the same as gnat-gpl was
but with the other languages stripped out.
Last-rites for gnat-gpl will follow in a little while.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 2 --
 1 file changed, 2 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index f0a6caf56748..458105d7a56c 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -424,7 +424,6 @@ if [[ ${PN} != gnat-gpl ]] && tc_has_feature ada ; then
 					sys-devel/gcc:${SLOT}[ada]
 					<sys-devel/gcc-${SLOT}[ada]
 					<dev-lang/ada-bootstrap-$((${SLOT} + 1))
-					dev-lang/gnat-gpl[ada]
 				)
 			)
 		"
@@ -435,7 +434,6 @@ if [[ ${PN} != gnat-gpl ]] && tc_has_feature ada ; then
                                         sys-devel/gcc:${SLOT}[ada]
                                         <sys-devel/gcc-${SLOT}[ada]
                                         <dev-lang/ada-bootstrap-${SLOT}
-                                        dev-lang/gnat-gpl[ada]
                                 )
                         )
                 "
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-02-15  7:38 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-02-15  7:38 UTC (permalink / raw
  To: gentoo-commits
commit:     4988e594294e6ae2f560ada7004a8affcd87033f
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Feb 15 07:19:47 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat Feb 15 07:38:14 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=4988e594
llvm.org.eclass: Remove old snapshot commits
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 9 ---------
 1 file changed, 9 deletions(-)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index 77a194ed49f4..9d66860d8b58 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -75,15 +75,6 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 				21.0.0_pre20250211)
 					EGIT_COMMIT=2cd8207b26ea4269630feba661f68554d7ae3c15
 					;;
-				21.0.0_pre20250208)
-					EGIT_COMMIT=6f241e36831927e3aea113cfc017c34fdeda340a
-					;;
-				21.0.0_pre20250201)
-					EGIT_COMMIT=bfa7edcc6652bdb37d53e0cec64926aab3f280eb
-					;;
-				20.0.0_pre20250125)
-					EGIT_COMMIT=1f26ac10ca1bef40a80be8f81a6f109713bc586f
-					;;
 				*)
 					die "Unknown snapshot: ${PV}"
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-02-15  9:04 Hans de Graaff
  0 siblings, 0 replies; 6663+ messages in thread
From: Hans de Graaff @ 2025-02-15  9:04 UTC (permalink / raw
  To: gentoo-commits
commit:     3dbaa2d94b19fa3109a5ab25450b9d2f113c1dff
Author:     Hans de Graaff <graaff <AT> gentoo <DOT> org>
AuthorDate: Sat Feb  8 08:01:58 2025 +0000
Commit:     Hans de Graaff <graaff <AT> gentoo <DOT> org>
CommitDate: Sat Feb 15 09:04:28 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=3dbaa2d9
eclass/apache-2.eclass: remove obsolete version check
Signed-off-by: Hans de Graaff <graaff <AT> gentoo.org>
 eclass/apache-2.eclass | 5 +----
 1 file changed, 1 insertion(+), 4 deletions(-)
diff --git a/eclass/apache-2.eclass b/eclass/apache-2.eclass
index 1e9edb998918..8572c7c195ac 100644
--- a/eclass/apache-2.eclass
+++ b/eclass/apache-2.eclass
@@ -132,10 +132,7 @@ _apache2_set_mpms() {
 _apache2_set_mpms
 unset -f _apache2_set_mpms
 
-NGHTTP2_VERSION=1.2.1
-if ver_test ${PV} -ge 2.4.55 ; then
-	NGHTTP2_VERSION=1.50.0
-fi
+NGHTTP2_VERSION=1.50.0
 
 # Dependencies
 RDEPEND="
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-02-15  9:04 Hans de Graaff
  0 siblings, 0 replies; 6663+ messages in thread
From: Hans de Graaff @ 2025-02-15  9:04 UTC (permalink / raw
  To: gentoo-commits
commit:     abe9aed9162cd2df4a420fdcd168c02c52f8ecda
Author:     Hans de Graaff <graaff <AT> gentoo <DOT> org>
AuthorDate: Sat Feb  8 08:00:49 2025 +0000
Commit:     Hans de Graaff <graaff <AT> gentoo <DOT> org>
CommitDate: Sat Feb 15 09:04:28 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=abe9aed9
eclass/apache-2.eclass: support EAPI 8
Signed-off-by: Hans de Graaff <graaff <AT> gentoo.org>
 eclass/apache-2.eclass | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/eclass/apache-2.eclass b/eclass/apache-2.eclass
index 352337f551d6..1e9edb998918 100644
--- a/eclass/apache-2.eclass
+++ b/eclass/apache-2.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2024 Gentoo Authors
+# Copyright 1999-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: apache-2.eclass
@@ -6,7 +6,7 @@
 # apache-bugs@gentoo.org
 # @AUTHOR:
 # polynomial-c@gentoo.org
-# @SUPPORTED_EAPIS: 7
+# @SUPPORTED_EAPIS: 7 8
 # @BLURB: Provides a common set of functions for apache-2.x ebuilds
 # @DESCRIPTION:
 # This eclass handles apache-2.x ebuild functions such as LoadModule generation
@@ -19,7 +19,7 @@ inherit autotools flag-o-matic lua-single multilib ssl-cert toolchain-funcs
 	&& die "Do not use this eclass with anything else than www-servers/apache ebuilds!"
 
 case ${EAPI} in
-	7) ;;
+	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-02-15  9:04 Hans de Graaff
  0 siblings, 0 replies; 6663+ messages in thread
From: Hans de Graaff @ 2025-02-15  9:04 UTC (permalink / raw
  To: gentoo-commits
commit:     305e47ed1a83c00a64da33035ddad2844c475efe
Author:     Hans de Graaff <graaff <AT> gentoo <DOT> org>
AuthorDate: Sat Feb  8 08:03:37 2025 +0000
Commit:     Hans de Graaff <graaff <AT> gentoo <DOT> org>
CommitDate: Sat Feb 15 09:04:28 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=305e47ed
eclass/apache-2.eclass: remove obsolete upgrade check
Signed-off-by: Hans de Graaff <graaff <AT> gentoo.org>
 eclass/apache-2.eclass | 22 ----------------------
 1 file changed, 22 deletions(-)
diff --git a/eclass/apache-2.eclass b/eclass/apache-2.eclass
index 8572c7c195ac..c62d19ed6b28 100644
--- a/eclass/apache-2.eclass
+++ b/eclass/apache-2.eclass
@@ -409,26 +409,6 @@ generate_load_module() {
 		"${GENTOO_PATCHDIR}"/conf/httpd.conf
 }
 
-# @FUNCTION: check_upgrade
-# @DESCRIPTION:
-# This internal function checks if the previous configuration file for built-in
-# modules exists in ROOT and prevents upgrade in this case. Users are supposed
-# to convert this file to the new APACHE2_MODULES USE_EXPAND variable and remove
-# it afterwards.
-check_upgrade() {
-	if [[ -e "${EROOT}"etc/apache2/apache2-builtin-mods ]]; then
-		eerror "The previous configuration file for built-in modules"
-		eerror "(${EROOT}etc/apache2/apache2-builtin-mods) exists on your"
-		eerror "system."
-		eerror
-		eerror "Please read https://wiki.gentoo.org/wiki/Project:Apache/Upgrading"
-		eerror "for detailed information how to convert this file to the new"
-		eerror "APACHE2_MODULES USE_EXPAND variable."
-		eerror
-		die "upgrade not possible with existing ${ROOT}etc/apache2/apache2-builtin-mods"
-	fi
-}
-
 # ==============================================================================
 # EXPORTED FUNCTIONS
 # ==============================================================================
@@ -439,8 +419,6 @@ check_upgrade() {
 # creates the apache user and group and informs about CONFIG_SYSVIPC being
 # needed (we don't depend on kernel sources and therefore cannot check).
 apache-2_pkg_setup() {
-	check_upgrade
-
 	setup_mpm
 	setup_modules
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-02-16 18:41 Mike Gilbert
  0 siblings, 0 replies; 6663+ messages in thread
From: Mike Gilbert @ 2025-02-16 18:41 UTC (permalink / raw
  To: gentoo-commits
commit:     a1e7d1e7a213a08d6acc94d6b10628259ba49517
Author:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
AuthorDate: Wed Feb  5 17:09:11 2025 +0000
Commit:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
CommitDate: Sun Feb 16 18:37:15 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=a1e7d1e7
toolchain-funcs.eclass: avoid using tc-getCPP in compiler checks
We usually want to invoke cc -E rather than cpp directly. We should not
rely on the quirk of tc-getCPP defaulting to "cc -E" when CPP is unset.
Resolves a warning when CPP is set to llvm-cpp, which does not accept
the -E option.
Closes: https://bugs.gentoo.org/949340
Signed-off-by: Mike Gilbert <floppym <AT> gentoo.org>
 eclass/toolchain-funcs.eclass | 12 ++++++------
 1 file changed, 6 insertions(+), 6 deletions(-)
diff --git a/eclass/toolchain-funcs.eclass b/eclass/toolchain-funcs.eclass
index 0abed5b8d75e..754d23f91c06 100644
--- a/eclass/toolchain-funcs.eclass
+++ b/eclass/toolchain-funcs.eclass
@@ -1,4 +1,4 @@
-# Copyright 2002-2024 Gentoo Authors
+# Copyright 2002-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: toolchain-funcs.eclass
@@ -900,7 +900,7 @@ tc-get-compiler-type() {
 	HAVE_GCC
 #endif
 '
-	local res=$($(tc-getCPP "$@") -E -P - <<<"${code}")
+	local res=$($(tc-getCC "$@") -E -P - <<<"${code}")
 
 	case ${res} in
 		*HAVE_PATHCC*)	echo pathcc;;
@@ -927,7 +927,7 @@ tc-is-clang() {
 # compilers rather than maintaining a --version flag matrix, bug #335943.
 _gcc_fullversion() {
 	local ver="$1"; shift
-	set -- $($(tc-getCPP "$@") -E -P - <<<"__GNUC__ __GNUC_MINOR__ __GNUC_PATCHLEVEL__")
+	set -- $($(tc-getCC "$@") -E -P - <<<"__GNUC__ __GNUC_MINOR__ __GNUC_PATCHLEVEL__")
 	eval echo "${ver}"
 }
 
@@ -960,7 +960,7 @@ gcc-micro-version() {
 # Internal func. Based on _gcc_fullversion() above.
 _clang_fullversion() {
 	local ver="$1"; shift
-	set -- $($(tc-getCPP "$@") -E -P - <<<"__clang_major__ __clang_minor__ __clang_patchlevel__")
+	set -- $($(tc-getCC "$@") -E -P - <<<"__clang_major__ __clang_minor__ __clang_patchlevel__")
 	eval echo "${ver}"
 }
 
@@ -1347,14 +1347,14 @@ tc-get-c-rtlib() {
 # @FUNCTION: tc-get-ptr-size
 # @RETURN: Size of a pointer in bytes for CHOST (e.g. 4 or 8).
 tc-get-ptr-size() {
-	$(tc-getCPP) -P - <<< __SIZEOF_POINTER__ ||
+	$(tc-getCC) -E -P - <<< __SIZEOF_POINTER__ ||
 		die "Could not determine CHOST pointer size"
 }
 
 # @FUNCTION: tc-get-build-ptr-size
 # @RETURN: Size of a pointer in bytes for CBUILD (e.g. 4 or 8).
 tc-get-build-ptr-size() {
-	$(tc-getBUILD_CPP) -P - <<< __SIZEOF_POINTER__ ||
+	$(tc-getBUILD_CC) -E -P - <<< __SIZEOF_POINTER__ ||
 		die "Could not determine CBUILD pointer size"
 }
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-02-17 21:52 Mike Gilbert
  0 siblings, 0 replies; 6663+ messages in thread
From: Mike Gilbert @ 2025-02-17 21:52 UTC (permalink / raw
  To: gentoo-commits
commit:     e914e98d160c0fe6945bb576f59c3fd427e8028c
Author:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
AuthorDate: Fri Jan 17 18:57:02 2025 +0000
Commit:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
CommitDate: Mon Feb 17 21:52:20 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=e914e98d
autotools.eclass: simplify WANT_AUTOCONF logic
Update WANT_AUTOMAKE atoms to match.
Drop 2.71 from _LATEST_AUTOCONF since 2.72 is stable.
Closes: https://bugs.gentoo.org/948125
Signed-off-by: Mike Gilbert <floppym <AT> gentoo.org>
 eclass/autotools.eclass | 21 ++++-----------------
 1 file changed, 4 insertions(+), 17 deletions(-)
diff --git a/eclass/autotools.eclass b/eclass/autotools.eclass
index 518f6addcc50..a36b6ba859be 100644
--- a/eclass/autotools.eclass
+++ b/eclass/autotools.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2024 Gentoo Authors
+# Copyright 1999-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: autotools.eclass
@@ -71,7 +71,7 @@ inherit gnuconfig libtool
 # Do NOT change this variable in your ebuilds!
 # If you want to force a newer minor version, you can specify the correct
 # WANT value by using a colon:  <PV>:<WANT_AUTOCONF>
-_LATEST_AUTOCONF=( 2.72-r1:2.72 2.71-r6:2.71 )
+_LATEST_AUTOCONF=( 2.72-r1:2.72 )
 
 # @ECLASS_VARIABLE: _LATEST_AUTOMAKE
 # @INTERNAL
@@ -109,14 +109,13 @@ if [[ -n ${WANT_AUTOMAKE} ]] ; then
 			unset _automake_atom_tmp
 			;;
 		*)
-			_automake_atom="=dev-build/automake-${WANT_AUTOMAKE}*"
+			_automake_atom="dev-build/automake:${WANT_AUTOMAKE}"
 			;;
 	esac
 	export WANT_AUTOMAKE
 fi
 
 if [[ -n ${WANT_AUTOCONF} ]] ; then
-	# TODO: Fix the slot mess here and just have proper PV-as-SLOT?
 	# TODO: Make _LATEST_AUTOCONF an assoc. array and instead iterate over
 	# its keys.
 	case ${WANT_AUTOCONF} in
@@ -124,25 +123,13 @@ if [[ -n ${WANT_AUTOCONF} ]] ; then
 			# some packages don't require autoconf at all
 			_autoconf_atom=""
 			;;
-		2.1)
-			_autoconf_atom=">=dev-build/autoconf-2.13-r7:2.1"
-			;;
-		2.5)
-			_autoconf_atom=">=dev-build/autoconf-2.71-r6:2.71"
-			;;
-		2.69)
-			_autoconf_atom=">=dev-build/autoconf-2.69-r9:2.69"
-			;;
-		2.71)
-			_autoconf_atom=">=dev-build/autoconf-2.71-r6:2.71"
-			;;
 		latest)
 			printf -v _autoconf_atom_tmp '>=dev-build/autoconf-%s:%s ' ${_LATEST_AUTOCONF[@]/:/ }
 			_autoconf_atom="|| ( ${_autoconf_atom_tmp} )"
 			unset _autoconf_atom_tmp
 			;;
 		*)
-			die "Invalid WANT_AUTOCONF value '${WANT_AUTOCONF}'"
+			_autoconf_atom="dev-build/autoconf:${WANT_AUTOCONF}"
 			;;
 	esac
 	export WANT_AUTOCONF
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-02-21  7:25 Petr Vaněk
  0 siblings, 0 replies; 6663+ messages in thread
From: Petr Vaněk @ 2025-02-21  7:25 UTC (permalink / raw
  To: gentoo-commits
commit:     82b72ff120e0a07661af80f7d1f37a6f1cce295e
Author:     Petr Vaněk <arkamar <AT> gentoo <DOT> org>
AuthorDate: Fri Feb 21 07:23:53 2025 +0000
Commit:     Petr Vaněk <arkamar <AT> gentoo <DOT> org>
CommitDate: Fri Feb 21 07:25:04 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=82b72ff1
mono.eclass: remove dead eclass
Closes: https://bugs.gentoo.org/372453
Closes: https://bugs.gentoo.org/374867
Signed-off-by: Petr Vaněk <arkamar <AT> gentoo.org>
 eclass/mono.eclass | 90 ------------------------------------------------------
 1 file changed, 90 deletions(-)
diff --git a/eclass/mono.eclass b/eclass/mono.eclass
deleted file mode 100644
index d4f45e5acf70..000000000000
--- a/eclass/mono.eclass
+++ /dev/null
@@ -1,90 +0,0 @@
-# Copyright 1999-2025 Gentoo Authors
-# Distributed under the terms of the GNU General Public License v2
-
-# @ECLASS: mono.eclass
-# @MAINTAINER:
-# maintainer-needed@gentoo.org
-# @SUPPORTED_EAPIS: 7
-# @BLURB: common settings and functions for mono and dotnet related packages
-# @DEAD
-# @DESCRIPTION:
-# The mono eclass contains common environment settings that are useful for
-# dotnet packages.  Currently, it provides no functions, just exports
-# MONO_SHARED_DIR and sets LC_ALL in order to prevent errors during compilation
-# of dotnet packages.
-
-case ${EAPI:-0} in
-	7) ;;
-	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
-esac
-
-if [[ -z ${_MONO_ECLASS} ]] ; then
-_MONO_ECLASS=1
-
-inherit multilib
-
-# >=mono-0.92 versions using mcs -pkg:foo-sharp require shared memory, so we set the
-# shared dir to ${T} so that ${T}/.wapi can be used during the install process.
-export MONO_SHARED_DIR="${T}"
-
-# Building mono, nant and many other dotnet packages is known to fail if LC_ALL
-# variable is not set to C. To prevent this all mono related packages will be
-# build with LC_ALL=C (see bugs #146424, #149817)
-export LC_ALL=C
-
-# Monodevelop-using applications need this to be set or they will try to create config
-# files in the user's ~ dir.
-
-export XDG_CONFIG_HOME="${T}"
-
-# Fix bug 83020:
-# "Access Violations Arise When Emerging Mono-Related Packages with MONO_AOT_CACHE"
-
-unset MONO_AOT_CACHE
-
-egacinstall() {
-	gacutil -i "${1}" \
-		-root "${ED}"/usr/$(get_libdir) \
-		-gacdir /usr/$(get_libdir) \
-		-package ${2:-${GACPN:-${PN}}} \
-		|| die "installing ${1} into the Global Assembly Cache failed"
-}
-
-mono_multilib_comply() {
-	local dir finddirs=() mv_command=${mv_command:-mv}
-	if [[ -d "${ED}/usr/lib" && "$(get_libdir)" != "lib" ]]
-	then
-		if ! [[ -d "${ED}"/usr/"$(get_libdir)" ]]
-		then
-			mkdir "${ED}"/usr/"$(get_libdir)" || die "Couldn't mkdir ${ED}/usr/$(get_libdir)"
-		fi
-		${mv_command} "${ED}"/usr/lib/* "${ED}"/usr/"$(get_libdir)"/ || die "Moving files into correct libdir failed"
-		rm -rf "${ED}"/usr/lib
-		for dir in "${ED}"/usr/"$(get_libdir)"/pkgconfig "${ED}"/usr/share/pkgconfig
-		do
-
-			if [[ -d "${dir}" && "$(find "${dir}" -name '*.pc')" != "" ]]
-			then
-				pushd "${dir}" &> /dev/null
-				sed  -i -r -e 's:/(lib)([^a-zA-Z0-9]|$):/'"$(get_libdir)"'\2:g' \
-					*.pc \
-					|| die "Sedding some sense into pkgconfig files failed."
-				popd "${dir}" &> /dev/null
-			fi
-		done
-		if [[ -d "${ED}/usr/bin" ]]
-		then
-			for exe in "${ED}/usr/bin"/*
-			do
-				if [[ "$(file -S "${exe}")" == *"shell script text"* ]]
-				then
-					sed -r -i -e ":/lib(/|$): s:/lib(/|$):/$(get_libdir)\1:" \
-						"${exe}" || die "Sedding some sense into ${exe} failed"
-				fi
-			done
-		fi
-
-	fi
-}
-
-fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-02-21 11:14 Arthur Zamarin
  0 siblings, 0 replies; 6663+ messages in thread
From: Arthur Zamarin @ 2025-02-21 11:14 UTC (permalink / raw
  To: gentoo-commits
commit:     2b197ab19755a400e431a3f0976f8093bac5c1b6
Author:     Matt Jolly <kangie <AT> gentoo <DOT> org>
AuthorDate: Thu Feb 13 03:05:36 2025 +0000
Commit:     Arthur Zamarin <arthurzam <AT> gentoo <DOT> org>
CommitDate: Fri Feb 21 11:13:15 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=2b197ab1
rust-toolchain.eclass: add rename param to `rust_all_arch_uris()`
Also update `rust_arch_uri` to also fetch the asc if we're renaming
so that we can use verify-sig.
Signed-off-by: Matt Jolly <kangie <AT> gentoo.org>
Signed-off-by: Arthur Zamarin <arthurzam <AT> gentoo.org>
 eclass/rust-toolchain.eclass | 34 +++++++++++++++++++---------------
 1 file changed, 19 insertions(+), 15 deletions(-)
diff --git a/eclass/rust-toolchain.eclass b/eclass/rust-toolchain.eclass
index 2d9c56b4d6b6..41fccb7c4a07 100644
--- a/eclass/rust-toolchain.eclass
+++ b/eclass/rust-toolchain.eclass
@@ -73,6 +73,7 @@ rust_abi() {
 rust_arch_uri() {
 	if [ -n "$3" ]; then
 		echo "${RUST_TOOLCHAIN_BASEURL}${2}-${1}.tar.xz -> ${3}-${1}.tar.xz"
+		echo "verify-sig? ( ${RUST_TOOLCHAIN_BASEURL}${2}-${1}.tar.xz.asc -> ${3}-${1}.tar.xz.asc )"
 	else
 		echo "${RUST_TOOLCHAIN_BASEURL}${2}-${1}.tar.xz"
 		echo "verify-sig? ( ${RUST_TOOLCHAIN_BASEURL}${2}-${1}.tar.xz.asc )"
@@ -80,7 +81,7 @@ rust_arch_uri() {
 }
 
 # @FUNCTION: rust_all_arch_uris
-# @USAGE: <base-uri> [alt-distfile-basename]
+# @USAGE: [alt-distfile-basename] [rust_arch_uri-rename-param]
 # @DESCRIPTION:
 # Outputs the URIs for SRC_URI to help fetch dependencies, using a base URI
 # provided as an argument. Optionally allows for distfile renaming via a specified
@@ -91,28 +92,31 @@ rust_arch_uri() {
 #
 rust_all_arch_uris()
 {
+	local alt_basename="$1"
+	local rename_param="$2"
+
 	echo "
-	abi_x86_32? ( elibc_glibc? ( $(rust_arch_uri i686-unknown-linux-gnu "$@") ) )
+	abi_x86_32? ( elibc_glibc? ( $(rust_arch_uri i686-unknown-linux-gnu "${alt_basename}" "${rename_param}") ) )
 	abi_x86_64? (
-		elibc_glibc? ( $(rust_arch_uri x86_64-unknown-linux-gnu  "$@") )
-		elibc_musl?  ( $(rust_arch_uri x86_64-unknown-linux-musl "$@") )
+		elibc_glibc? ( $(rust_arch_uri x86_64-unknown-linux-gnu  "${alt_basename}" "${rename_param}") )
+		elibc_musl?  ( $(rust_arch_uri x86_64-unknown-linux-musl "${alt_basename}" "${rename_param}") )
 	)
 	arm? ( elibc_glibc? (
-		$(rust_arch_uri arm-unknown-linux-gnueabi     "$@")
-		$(rust_arch_uri arm-unknown-linux-gnueabihf   "$@")
-		$(rust_arch_uri armv7-unknown-linux-gnueabihf "$@")
+		$(rust_arch_uri arm-unknown-linux-gnueabi     "${alt_basename}" "${rename_param}")
+		$(rust_arch_uri arm-unknown-linux-gnueabihf   "${alt_basename}" "${rename_param}")
+		$(rust_arch_uri armv7-unknown-linux-gnueabihf "${alt_basename}" "${rename_param}")
 	) )
 	arm64? (
-		elibc_glibc? ( $(rust_arch_uri aarch64-unknown-linux-gnu  "$@") )
-		elibc_musl?  ( $(rust_arch_uri aarch64-unknown-linux-musl "$@") )
+		elibc_glibc? ( $(rust_arch_uri aarch64-unknown-linux-gnu  "${alt_basename}" "${rename_param}") )
+		elibc_musl?  ( $(rust_arch_uri aarch64-unknown-linux-musl "${alt_basename}" "${rename_param}") )
 	)
-	ppc? ( elibc_glibc? ( $(rust_arch_uri powerpc-unknown-linux-gnu "$@") ) )
+	ppc? ( elibc_glibc? ( $(rust_arch_uri powerpc-unknown-linux-gnu "${alt_basename}" "${rename_param}") ) )
 	ppc64? (
-		big-endian?  ( elibc_glibc? ( $(rust_arch_uri powerpc64-unknown-linux-gnu   "$@") ) )
-		!big-endian? ( elibc_glibc? ( $(rust_arch_uri powerpc64le-unknown-linux-gnu "$@") ) )
+		big-endian?  ( elibc_glibc? ( $(rust_arch_uri powerpc64-unknown-linux-gnu   "${alt_basename}" "${rename_param}") ) )
+		!big-endian? ( elibc_glibc? ( $(rust_arch_uri powerpc64le-unknown-linux-gnu "${alt_basename}" "${rename_param}") ) )
 	)
-	riscv? ( elibc_glibc? ( $(rust_arch_uri riscv64gc-unknown-linux-gnu "$@") ) )
-	s390?  ( elibc_glibc? ( $(rust_arch_uri s390x-unknown-linux-gnu     "$@") ) )
-	loong? ( elibc_glibc? ( $(rust_arch_uri loongarch64-unknown-linux-gnu "$@") ) )
+	riscv? ( elibc_glibc? ( $(rust_arch_uri riscv64gc-unknown-linux-gnu "${alt_basename}" "${rename_param}") ) )
+	s390?  ( elibc_glibc? ( $(rust_arch_uri s390x-unknown-linux-gnu     "${alt_basename}" "${rename_param}") ) )
+	loong? ( elibc_glibc? ( $(rust_arch_uri loongarch64-unknown-linux-gnu "${alt_basename}" "${rename_param}") ) )
 	"
 }
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-02-21 11:14 Arthur Zamarin
  0 siblings, 0 replies; 6663+ messages in thread
From: Arthur Zamarin @ 2025-02-21 11:14 UTC (permalink / raw
  To: gentoo-commits
commit:     d2a4a993d6a35c1494d28b62d8b2bfd3544a987f
Author:     Matt Jolly <kangie <AT> gentoo <DOT> org>
AuthorDate: Tue Feb 11 06:03:25 2025 +0000
Commit:     Arthur Zamarin <arthurzam <AT> gentoo <DOT> org>
CommitDate: Fri Feb 21 11:13:15 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=d2a4a993
rust-toolchain.eclass: simplify `rust_all_arch_uris`
The `mips` logic has been moved into the one ebuild that it impacts,
and that ebuild is only required for one package - we'll try to
remove it from the tree soon.
Merge `loong` into `rust_all_arch_uris()` output unconditionally;
the check is now superfluous - all pre-1.71.0 rust versions
are out of the tree.
Signed-off-by: Matt Jolly <kangie <AT> gentoo.org>
Signed-off-by: Arthur Zamarin <arthurzam <AT> gentoo.org>
 eclass/rust-toolchain.eclass | 27 ++-------------------------
 1 file changed, 2 insertions(+), 25 deletions(-)
diff --git a/eclass/rust-toolchain.eclass b/eclass/rust-toolchain.eclass
index 89bca88b9e6b..2d9c56b4d6b6 100644
--- a/eclass/rust-toolchain.eclass
+++ b/eclass/rust-toolchain.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2024 Gentoo Authors
+# Copyright 1999-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: rust-toolchain.eclass
@@ -113,29 +113,6 @@ rust_all_arch_uris()
 	)
 	riscv? ( elibc_glibc? ( $(rust_arch_uri riscv64gc-unknown-linux-gnu "$@") ) )
 	s390?  ( elibc_glibc? ( $(rust_arch_uri s390x-unknown-linux-gnu     "$@") ) )
+	loong? ( elibc_glibc? ( $(rust_arch_uri loongarch64-unknown-linux-gnu "$@") ) )
 	"
-
-	# Upstream did not gain support for loong until v1.71.0.
-	# NOTE: Merge this into the block above after every <1.71.0 version is
-	# gone from tree.
-	local arg_version="${1##*-}"
-	arg_version="${arg_version:-$PV}"
-	if ver_test "${arg_version}" -ge 1.71.0; then
-		echo "loong? ( elibc_glibc? ( $(rust_arch_uri loongarch64-unknown-linux-gnu "$@") ) )"
-	fi
-
-	# until https://github.com/rust-lang/rust/pull/113274 is resolved, there
-	# will not be upstream-built mips artifacts
-	if ver_test "${arg_version}" -lt 1.72.0; then
-		echo "mips? (
-			abi_mips_o32? (
-				big-endian?  ( $(rust_arch_uri mips-unknown-linux-gnu   "$@") )
-				!big-endian? ( $(rust_arch_uri mipsel-unknown-linux-gnu "$@") )
-			)
-			abi_mips_n64? (
-				big-endian?  ( $(rust_arch_uri mips64-unknown-linux-gnuabi64   "$@") )
-				!big-endian? ( $(rust_arch_uri mips64el-unknown-linux-gnuabi64 "$@") )
-			)
-		)"
-	fi
 }
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-02-22 15:19 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-02-22 15:19 UTC (permalink / raw
  To: gentoo-commits
commit:     ca7fdae1054f17d87ac84e7c51955d13989e09df
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Feb 22 15:09:47 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat Feb 22 15:19:02 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=ca7fdae1
Add 21.0.0_pre20250221 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index 2dbb71a54334..ca18a41acd08 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -72,6 +72,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 			_LLVM_SOURCE_TYPE=snapshot
 
 			case ${PV} in
+				21.0.0_pre20250221)
+					EGIT_COMMIT=581599096e8a1a89ccd3e053a1209c69a9079083
+					;;
 				21.0.0_pre20250215)
 					EGIT_COMMIT=c30a7f459452d5766da244564bc1d5888346c364
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-02-22 22:08 Matt Jolly
  0 siblings, 0 replies; 6663+ messages in thread
From: Matt Jolly @ 2025-02-22 22:08 UTC (permalink / raw
  To: gentoo-commits
commit:     80aab9610438516303e213a5dc5692b88836d93c
Author:     Matt Jolly <kangie <AT> gentoo <DOT> org>
AuthorDate: Sat Feb 22 21:59:20 2025 +0000
Commit:     Matt Jolly <kangie <AT> gentoo <DOT> org>
CommitDate: Sat Feb 22 21:59:20 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=80aab961
rust.eclass: drop 1.84.0
Signed-off-by: Matt Jolly <kangie <AT> gentoo.org>
 eclass/rust.eclass | 2 --
 1 file changed, 2 deletions(-)
diff --git a/eclass/rust.eclass b/eclass/rust.eclass
index 9ead9d005706..d887970c34a7 100644
--- a/eclass/rust.eclass
+++ b/eclass/rust.eclass
@@ -71,7 +71,6 @@ declare -A -g -r _RUST_LLVM_MAP=(
 	["1.86.0"]=19
 	["1.85.0"]=19
 	["1.84.1"]=19
-	["1.84.0"]=19
 	["1.83.0"]=19
 	["1.82.0"]=19
 	["1.81.0"]=18
@@ -96,7 +95,6 @@ declare -a -g -r _RUST_SLOTS_ORDERED=(
 	"1.86.0"
 	"1.85.0"
 	"1.84.1"
-	"1.84.0"
 	"1.83.0"
 	"1.82.0"
 	"1.81.0"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread
* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-02-25  9:16 Matt Jolly
  0 siblings, 0 replies; 6663+ messages in thread
From: Matt Jolly @ 2025-02-25  9:16 UTC (permalink / raw
  To: gentoo-commits
commit:     f13c9d8e31c39070535a04d13a2f128f1b5b9999
Author:     Matt Jolly <kangie <AT> gentoo <DOT> org>
AuthorDate: Tue Feb 25 09:14:03 2025 +0000
Commit:     Matt Jolly <kangie <AT> gentoo <DOT> org>
CommitDate: Tue Feb 25 09:14:03 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=f13c9d8e
rust.eclass: add 1.84.0
This was removed after 1.84.0 was dropped however it
needs to remain in the eclass for a bit longer to provide
users who have not updated in a while the opportunity to use
an installed 1.84.0 to build 1.84.1 or 1.85.0.
Signed-off-by: Matt Jolly <kangie <AT> gentoo.org>
 eclass/rust.eclass | 2 ++
 1 file changed, 2 insertions(+)
diff --git a/eclass/rust.eclass b/eclass/rust.eclass
index d887970c34a7..9ead9d005706 100644
--- a/eclass/rust.eclass
+++ b/eclass/rust.eclass
@@ -71,6 +71,7 @@ declare -A -g -r _RUST_LLVM_MAP=(
 	["1.86.0"]=19
 	["1.85.0"]=19
 	["1.84.1"]=19
+	["1.84.0"]=19
 	["1.83.0"]=19
 	["1.82.0"]=19
 	["1.81.0"]=18
@@ -95,6 +96,7 @@ declare -a -g -r _RUST_SLOTS_ORDERED=(
 	"1.86.0"
 	"1.85.0"
 	"1.84.1"
+	"1.84.0"
 	"1.83.0"
 	"1.82.0"
 	"1.81.0"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread
* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-02-25 14:03 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-02-25 14:03 UTC (permalink / raw
  To: gentoo-commits
commit:     37aa7efe4f07cf5ed490cbf2705fe9b5597d267e
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Tue Feb 25 12:49:58 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Tue Feb 25 14:03:01 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=37aa7efe
Add 21.0.0_pre20250225 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index ca18a41acd08..ed8c6521d902 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -72,6 +72,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 			_LLVM_SOURCE_TYPE=snapshot
 
 			case ${PV} in
+				21.0.0_pre20250225)
+					EGIT_COMMIT=d254fa877f419e61e54709f0a6f2e891da893a60
+					;;
 				21.0.0_pre20250221)
 					EGIT_COMMIT=581599096e8a1a89ccd3e053a1209c69a9079083
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-02-25 16:36 Florian Schmaus
  0 siblings, 0 replies; 6663+ messages in thread
From: Florian Schmaus @ 2025-02-25 16:36 UTC (permalink / raw
  To: gentoo-commits
commit:     cfabc04a8241583e29634e447f831ef15bad6459
Author:     Florian Schmaus <flow <AT> gentoo <DOT> org>
AuthorDate: Thu Feb 20 08:41:33 2025 +0000
Commit:     Florian Schmaus <flow <AT> gentoo <DOT> org>
CommitDate: Tue Feb 25 16:35:58 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=cfabc04a
latex-package.eclass: introduce LATEX_ENGINE variable
Closes: https://bugs.gentoo.org/950021
Signed-off-by: Florian Schmaus <flow <AT> gentoo.org>
 eclass/latex-package.eclass | 14 +++++++++++++-
 1 file changed, 13 insertions(+), 1 deletion(-)
diff --git a/eclass/latex-package.eclass b/eclass/latex-package.eclass
index f23897d4315c..e35da30e1b44 100644
--- a/eclass/latex-package.eclass
+++ b/eclass/latex-package.eclass
@@ -79,6 +79,12 @@ TEXMF="/usr/share/texmf-site"
 # DESCRIPTION above)
 SUPPLIER="misc"
 
+# @ECLASS_VARIABLE: LATEX_ENGINE
+# @DESCRIPTION:
+# When compiling documentation (.tex/.dtx), use the specified engine,
+# e.g., lualatex, to build the documention. Defaults to pdflatex.
+: "${LATEX_ENGINE:=pdflatex}"
+
 # @ECLASS_VARIABLE: LATEX_DOC_ARGUMENTS
 # @DESCRIPTION:
 # When compiling documentation (.tex/.dtx), this variable will be passed
@@ -140,12 +146,18 @@ latex-package_src_doinstall() {
 
 						einfo "Making documentation: ${i}"
 						local mypdflatex=(
-							pdflatex
+							${LATEX_ENGINE}
 							${LATEX_DOC_ARGUMENTS}
 							--halt-on-error
 							--interaction=nonstopmode
 							"${i}"
 						)
+
+						if [[ ${LATEX_ENGINE} == "lualatex" ]]; then
+							# bug #950021
+							local -x TEXMFCACHE="${T}" TEXMFVAR="${T}"
+						fi
+
 						# some macros need compiler called twice, do it here.
 						if nonfatal edo "${mypdflatex[@]}"; then
 							edo "${mypdflatex[@]}"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-02-25 16:36 Florian Schmaus
  0 siblings, 0 replies; 6663+ messages in thread
From: Florian Schmaus @ 2025-02-25 16:36 UTC (permalink / raw
  To: gentoo-commits
commit:     e04e586ed5f7311a9fcae24bafc0c59b31a1ce98
Author:     Florian Schmaus <flow <AT> gentoo <DOT> org>
AuthorDate: Thu Feb 20 08:41:09 2025 +0000
Commit:     Florian Schmaus <flow <AT> gentoo <DOT> org>
CommitDate: Tue Feb 25 16:35:58 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=e04e586e
latex-package.eclass: use edo
Signed-off-by: Florian Schmaus <flow <AT> gentoo.org>
 eclass/latex-package.eclass | 10 ++++++----
 1 file changed, 6 insertions(+), 4 deletions(-)
diff --git a/eclass/latex-package.eclass b/eclass/latex-package.eclass
index dfef7fc2836f..f23897d4315c 100644
--- a/eclass/latex-package.eclass
+++ b/eclass/latex-package.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2024 Gentoo Authors
+# Copyright 1999-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: latex-package.eclass
@@ -60,6 +60,8 @@ esac
 if [[ -z ${_LATEX_PACKAGE_ECLASS} ]]; then
 _LATEX_PACKAGE_ECLASS=1
 
+inherit edo
+
 RDEPEND="virtual/latex-base"
 BDEPEND="${RDEPEND}
 	>=sys-apps/texinfo-4.2-r5"
@@ -145,11 +147,11 @@ latex-package_src_doinstall() {
 							"${i}"
 						)
 						# some macros need compiler called twice, do it here.
-						if "${mypdflatex[@]}"; then
-							"${mypdflatex[@]}"
+						if nonfatal edo "${mypdflatex[@]}"; then
+							edo "${mypdflatex[@]}"
 						else
 							einfo "pdflatex failed, trying texi2dvi"
-							texi2dvi -q -c --language=latex "${i}" || die
+							edo texi2dvi -q -c --language=latex "${i}"
 						fi
 					done < <(find -maxdepth 1 -type f -name "*.${1}" -print0)
 				fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-02-26  8:47 Ionen Wolkens
  0 siblings, 0 replies; 6663+ messages in thread
From: Ionen Wolkens @ 2025-02-26  8:47 UTC (permalink / raw
  To: gentoo-commits
commit:     55f38f43ec8b9562f5e48be2e8090ce20fc9b161
Author:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
AuthorDate: Wed Feb 26 04:12:51 2025 +0000
Commit:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
CommitDate: Wed Feb 26 08:45:31 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=55f38f43
qt6-build.eclass: allow objects-* to be installed again
Being installed to /usr/lib*/objects- rather than under qt6/ feels
very out of place (haven't found a variable to change this), but
lacking this does break a few cmake files even though they are not
"essential" and on second thought decided to allow it again.
Will instead delete unwanted objects-* dirs that are installed only
when tests are enabled in their own ebuilds (turns there is not that
many). The original goal was to reduce the list of things each ebuilds
had to tidy up, but this did not help that much.
Won't revbump over this, if actually need these files (e.g. pyside)
consider this to be fixed in upcoming 6.8.3 instead.
Signed-off-by: Ionen Wolkens <ionen <AT> gentoo.org>
 eclass/qt6-build.eclass | 8 +++-----
 1 file changed, 3 insertions(+), 5 deletions(-)
diff --git a/eclass/qt6-build.eclass b/eclass/qt6-build.eclass
index ae23f4e9bd82..1c13174804ad 100644
--- a/eclass/qt6-build.eclass
+++ b/eclass/qt6-build.eclass
@@ -203,11 +203,9 @@ qt6-build_src_install() {
 
 	_qt6-build_create_user_facing_links
 
-	# hack: trim typical junk with currently no known "proper" way
-	# to avoid that primarily happens with tests (e.g. qt5compat and
-	# qtsvg tests, but qtbase[gui,-test] currently does some too)
-	rm -rf -- "${D}${QT6_PREFIX}"/tests \
-		"${D}${QT6_LIBDIR}/objects-${CMAKE_BUILD_TYPE}" || die
+	# Qt often install unwanted files when tests are enabled and, while
+	# this does not cover everything, delete the common case.
+	rm -rf -- "${D}${QT6_PREFIX}"/tests || die
 }
 
 ######  Public helpers  ######
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-02-26 22:05 Andreas Sturmlechner
  0 siblings, 0 replies; 6663+ messages in thread
From: Andreas Sturmlechner @ 2025-02-26 22:05 UTC (permalink / raw
  To: gentoo-commits
commit:     ea4cfe35d6653d2c42b14d7441b323648fee1c58
Author:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
AuthorDate: Wed Feb 26 22:01:34 2025 +0000
Commit:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
CommitDate: Wed Feb 26 22:05:43 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=ea4cfe35
ecm.eclass: Improve _ecm_punt_kdoctools_install(), ecm_punt_po_install()
Allow for whitespace padding within kdoctools_install and ki18n_install.
Odd that this hasn't come up before.
Closes: https://bugs.gentoo.org/950317
Signed-off-by: Andreas Sturmlechner <asturm <AT> gentoo.org>
 eclass/ecm.eclass | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/eclass/ecm.eclass b/eclass/ecm.eclass
index 1f40dd69fc74..87284df4696e 100644
--- a/eclass/ecm.eclass
+++ b/eclass/ecm.eclass
@@ -477,7 +477,7 @@ ecm_punt_bogus_dep() {
 # @DESCRIPTION:
 # Disables kdoctools_install(po) call.
 _ecm_punt_kdoctools_install() {
-	sed -e "s/^ *kdoctools_install.*(po.*)/#& # disabled by ecm.eclass/" \
+	sed -e "s/^ *kdoctools_install.*(\s*po.*)/#& # disabled by ecm.eclass/" \
 		-i CMakeLists.txt || die
 }
 
@@ -487,7 +487,7 @@ _ecm_punt_kdoctools_install() {
 # is outsourcing common files to a ${PN}-common split package.
 ecm_punt_po_install() {
 	_ecm_punt_kdoctools_install
-	sed -e "s/^ *ki18n_install.*(po.*)/#& # disabled by ecm.eclass/" \
+	sed -e "s/^ *ki18n_install.*(\s*po.*)/#& # disabled by ecm.eclass/" \
 		-i CMakeLists.txt || die
 }
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-03-01 12:58 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-03-01 12:58 UTC (permalink / raw
  To: gentoo-commits
commit:     69847bfb130717e8697182af0c097705b40472e5
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Mar  1 12:55:59 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat Mar  1 12:58:17 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=69847bfb
Add 21.0.0_pre20250301 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index 2f041ac3c2c7..fe1fd555efbe 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -72,6 +72,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 			_LLVM_SOURCE_TYPE=snapshot
 
 			case ${PV} in
+				21.0.0_pre20250301)
+					EGIT_COMMIT=7e8a06cfa4a2951b8ee77e19e34926e6e535b4d1
+					;;
 				21.0.0_pre20250225)
 					EGIT_COMMIT=d254fa877f419e61e54709f0a6f2e891da893a60
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-03-03 17:47 Nowa Ammerlaan
  0 siblings, 0 replies; 6663+ messages in thread
From: Nowa Ammerlaan @ 2025-03-03 17:47 UTC (permalink / raw
  To: gentoo-commits
commit:     bb7b3f56b8d85bb1c96d9d0b85a10769fb497005
Author:     Nowa Ammerlaan <nowa <AT> gentoo <DOT> org>
AuthorDate: Sat Mar  1 12:09:25 2025 +0000
Commit:     Nowa Ammerlaan <nowa <AT> gentoo <DOT> org>
CommitDate: Mon Mar  3 17:45:54 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=bb7b3f56
dist-kernel-utils.eclass: pass on extra args to installkernel v56
Installkernel v56 has gained the capability of parsing optional
arguments. Adjust the helper functions here so ebuilds can pass on
these extra arguments directly to installkernel.
Signed-off-by: Nowa Ammerlaan <nowa <AT> gentoo.org>
 eclass/dist-kernel-utils.eclass | 72 ++++++++++++++++++++++++++++-------------
 1 file changed, 50 insertions(+), 22 deletions(-)
diff --git a/eclass/dist-kernel-utils.eclass b/eclass/dist-kernel-utils.eclass
index 3d7315e9e94e..49977c18795a 100644
--- a/eclass/dist-kernel-utils.eclass
+++ b/eclass/dist-kernel-utils.eclass
@@ -66,18 +66,37 @@ dist-kernel_get_image_path() {
 }
 
 # @FUNCTION: dist-kernel_install_kernel
-# @USAGE: <version> <image> <system.map>
+# @USAGE: [<version>] [<image>] [<system.map>] [<dir>] [<installkernel-args>...]
 # @DESCRIPTION:
-# Install kernel using installkernel tool.  <version> specifies
-# the kernel version, <image> full path to the image, <system.map>
-# full path to System.map.
+# Install kernel using installkernel. Takes the following arguments:
+#
+# <version> -- the target kernel version (default: ${KV_FULL})
+#
+# <image> -- the full path to the kernel image (default: the image
+# 	 	as reported by dist-kernel_get_image_path() in the ${KV_DIR})
+#
+# <system.map> -- the full path to the System.map
+# 		(default: ${KV_DIR}/System.map})
+#
+# <dir> -- the target directory to install to (default: ${EROOT}/boot)
+#
+# <installkernel-args> -- extra optional arguments for installkernel
+# 		see man kernel-install and man installkernel. Requires at
+# 		least version 56 of sys-kernel/installkernel.
 dist-kernel_install_kernel() {
 	debug-print-function ${FUNCNAME} "$@"
 
-	[[ ${#} -eq 3 ]] || die "${FUNCNAME}: invalid arguments"
-	local version=${1}
-	local image=${2}
-	local map=${3}
+	local version=${1:-${KV_FULL}}
+	local image=${2:-${KV_DIR}/$(dist-kernel_get_image_path)}
+	local map=${3:-${KV_DIR}/System.map}
+	local dir=${4:-${EROOT}/boot}
+
+	local installkernel_args=(
+		"${version}" "${image}" "${map}" "${dir}"
+	)
+	if has_version ">=sys-kernel/installkernel-56"; then
+		installkernel_args+=( "${@:5}" --verbose )
+	fi
 
 	local success=
 	# not an actual loop but allows error handling with 'break'
@@ -107,8 +126,7 @@ dist-kernel_install_kernel() {
 		ebegin "Installing the kernel via installkernel"
 		# note: .config is taken relatively to System.map;
 		# initrd relatively to bzImage
-		ARCH=$(tc-arch-kernel) installkernel "${version}" "${image}" "${map}" \
-			"${EROOT}/boot" || break
+		ARCH=$(tc-arch-kernel) installkernel "${installkernel_args[@]}" || break
 		eend ${?} || die -n "Installing the kernel failed"
 
 		success=1
@@ -129,39 +147,49 @@ dist-kernel_install_kernel() {
 		eerror "in the logs above and once you resolve the problems please"
 		eerror "run the equivalent of the following command to try again:"
 		eerror
-		eerror "    emerge --config ${kernel}"
+		if has --all "${installkernel_args[@]}"; then
+			eerror "    installkernel ${installkernel_args[*]}"
+		else
+			eerror "    emerge --config ${kernel}"
+		fi
 		die "Kernel install failed, please fix the problems and run emerge --config"
 	fi
 }
 
 # @FUNCTION: dist-kernel_reinstall_initramfs
-# @USAGE: <kv-dir> <kv-full>
+# @USAGE: [<kv-dir>] [<kv-full>] [<installkernel-args>...]
 # @DESCRIPTION:
 # Rebuild and install initramfs for the specified dist-kernel.
-# <kv-dir> is the kernel source directory (${KV_DIR} from linux-info),
-# while <kv-full> is the full kernel version (${KV_FULL}).
-# The function will determine whether <kernel-dir> is actually
-# a dist-kernel, and whether initramfs was used.
+# Takes the following arguments:
+#
+# <kv-dir> -- the full path to the target kernel (default: ${KV_DIR})
+#
+# <kv-full> -- the target kernel version (default: ${KV_FULL})
+#
+# <installkernel-args> -- extra optional arguments for installkernel
+# 		see man kernel-install and man installkernel. Requires at
+# 		least version 56 of sys-kernel/installkernel.
 #
 # This function is to be used in pkg_postinst() of ebuilds installing
-# kernel modules that are included in the initramfs.
+# kernel modules that are included in the initramfs. In order to
+# reinstall *all* distribution kernels currently installed on the
+# system add the --all argument (requires installkernel-56 or newer).
 dist-kernel_reinstall_initramfs() {
 	debug-print-function ${FUNCNAME} "$@"
 
-	[[ ${#} -eq 2 ]] || die "${FUNCNAME}: invalid arguments"
-	local kernel_dir=${1}
-	local ver=${2}
+	local kernel_dir=${1:-${KV_DIR}}
+	local ver=${2:-${KV_FULL}}
 
 	local image_path=${kernel_dir}/$(dist-kernel_get_image_path)
 	if [[ ! -f ${image_path} ]]; then
 		eerror "Kernel install missing, image not found:"
 		eerror "  ${image_path}"
-		eerror "Initramfs will not be updated.  Please reinstall your kernel."
+		eerror "Initramfs will not be updated.  Please reinstall kernel ${ver}."
 		return
 	fi
 
 	dist-kernel_install_kernel "${ver}" "${image_path}" \
-		"${kernel_dir}/System.map"
+		"${kernel_dir}/System.map" "${EROOT}/boot" "${@:3}"
 }
 
 # @FUNCTION: dist-kernel_PV_to_KV
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-03-03 17:47 Nowa Ammerlaan
  0 siblings, 0 replies; 6663+ messages in thread
From: Nowa Ammerlaan @ 2025-03-03 17:47 UTC (permalink / raw
  To: gentoo-commits
commit:     4a0f408ed58c36002ded30e0b0b702ecf5d147e4
Author:     Nowa Ammerlaan <nowa <AT> gentoo <DOT> org>
AuthorDate: Sun Mar  2 08:58:22 2025 +0000
Commit:     Nowa Ammerlaan <nowa <AT> gentoo <DOT> org>
CommitDate: Mon Mar  3 17:45:55 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=4a0f408e
kernel-install.eclass: cleanup dead symlinks after removal
Since we remove /usr/src/linux-KV_FULL but by design keep the
/lib/modules/KV_FULL, we end up with some dead symlinks after
depcleaning a dist-kernel. This has the unfortunate side effect of
tricking systemd's kernel-install into thinking that a kernel image
for this kernel still exists. Which leads to some ugliness further
down the line. We can easily resolve the problem by cleaning up these
dead symlinks.
Signed-off-by: Nowa Ammerlaan <nowa <AT> gentoo.org>
 eclass/kernel-install.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/kernel-install.eclass b/eclass/kernel-install.eclass
index cf34007844a8..67143278f368 100644
--- a/eclass/kernel-install.eclass
+++ b/eclass/kernel-install.eclass
@@ -808,6 +808,9 @@ kernel-install_pkg_postrm() {
 			find "${kernel_dir}" -depth -type d -empty -delete
 		eend ${?}
 	fi
+
+	# Clean up dead symlinks
+	find -L "${EROOT}/lib/modules/${KV_FULL}" -type l -delete
 }
 
 # @FUNCTION: kernel-install_pkg_config
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-03-03 19:27 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-03-03 19:27 UTC (permalink / raw
  To: gentoo-commits
commit:     55503135684b929613e6d432f4b1d4ee3851961d
Author:     Eric Joldasov <bratishkaerik <AT> landless-city <DOT> net>
AuthorDate: Sat Jan 18 17:04:54 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Mar  3 19:26:26 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=55503135
zig-utils.eclass: add function to get the rightmost flag from CFLAGS
Similar to `get-flag` from toolchain.eclass, but searches from the end,
uses only CFLAGS, and returns value only.
Signed-off-by: Eric Joldasov <bratishkaerik <AT> landless-city.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/zig-utils.eclass | 43 ++++++++++++++++++++++++++++++++++++-------
 1 file changed, 36 insertions(+), 7 deletions(-)
diff --git a/eclass/zig-utils.eclass b/eclass/zig-utils.eclass
index 5502d997935e..d92fd0724b17 100644
--- a/eclass/zig-utils.eclass
+++ b/eclass/zig-utils.eclass
@@ -202,6 +202,35 @@ fi
 # 0.13.0
 # @CODE
 
+# @FUNCTION: _get-c-option
+# @INTERNAL
+# @USAGE: <option-name>
+# @DESCRIPTION:
+# Gets value of some compiler option from CFLAGS, starting from the end.
+# Must be a full name, without "-" and "=..." part.
+#
+# Example:
+# @CODE
+# CFLAGS="-march=i686 -march=i586"
+# _get-c-option march # returns i586
+# @CODE
+_get-c-option() {
+	if [[ ${#} -ne 1 ]]; then
+		die "${FUNCNAME[0]}: expected 1 argument, got ${#}"
+	fi
+
+	local prefix="-${1}="
+	local c_flags=( ${CFLAGS} )
+	for (( i=${#c_flags[@]} - 1; i >= 0; i -= 1 )); do
+		local c_flag="${c_flags[i]}"
+		if [[ "${c_flag}" == ${prefix}* ]]; then
+			echo "${c_flag#${prefix}}"
+			return
+	    fi
+	done
+	echo ""
+}
+
 # @FUNCTION: zig-utils_c_env_to_zig_target
 # @USAGE: <C-style target tuple> <CFLAGS>
 # @DESCRIPTION:
@@ -224,8 +253,8 @@ zig-utils_c_env_to_zig_target() {
 	local c_arch="${c_tuple%%-*}"
 	local c_abi="${c_tuple##*-}"
 
-	local c_flags="${2}"
-	local c_flags_march="$(CFLAGS="${c_flags}" get-flag march)"
+	local -x CFLAGS="${2}"
+	local c_flags_march="$(_get-c-option march)"
 
 	local arch os abi
 
@@ -279,11 +308,11 @@ zig-utils_c_env_to_zig_cpu() {
 	local c_tuple="${1}"
 	local c_arch="${c_tuple%%-*}"
 
-	local c_flags="${2}"
-	local c_flags_mabi="$(CFLAGS="${c_flags}" get-flag mabi)"
-	local c_flags_march="$(CFLAGS="${c_flags}" get-flag march)"
-	local c_flags_mcpu="$(CFLAGS="${c_flags}" get-flag mcpu)"
-	local c_flags_mfpu="$(CFLAGS="${c_flags}" get-flag mfpu)"
+	local -x CFLAGS="${2}"
+	local c_flags_mabi="$(_get-c-option mabi)"
+	local c_flags_march="$(_get-c-option march)"
+	local c_flags_mcpu="$(_get-c-option mcpu)"
+	local c_flags_mfpu="$(_get-c-option mfpu)"
 
 	local base_cpu features=""
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-03-03 19:27 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-03-03 19:27 UTC (permalink / raw
  To: gentoo-commits
commit:     f68007349b216b75d31a7513e49b9813b24a993e
Author:     Eric Joldasov <bratishkaerik <AT> landless-city <DOT> net>
AuthorDate: Sat Jan 18 16:15:24 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Mar  3 19:26:27 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=f6800734
zig.eclass: allow unset `my_zbs_args`
Previously it was defined as empty string when not setting this variable,
which caused error during building because Zig treat it as a name of
non-existant step "".
Also fix DEFAULT_UNSET comment on `BUILD_DIR` and `my_zbs_args`.
Closes: https://bugs.gentoo.org/948168
Signed-off-by: Eric Joldasov <bratishkaerik <AT> landless-city.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/zig.eclass | 5 ++---
 1 file changed, 2 insertions(+), 3 deletions(-)
diff --git a/eclass/zig.eclass b/eclass/zig.eclass
index 2a0178e66d71..26b55bf05d7f 100644
--- a/eclass/zig.eclass
+++ b/eclass/zig.eclass
@@ -1,4 +1,4 @@
-# Copyright 2024 Gentoo Authors
+# Copyright 2024-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: zig.eclass
@@ -152,6 +152,7 @@ _zig_set_zbs_uris() {
 _zig_set_zbs_uris
 
 # @ECLASS_VARIABLE: my_zbs_args
+# @DEFAULT_UNSET
 # @DESCRIPTION:
 # Bash array with ebuild-specified arguments to pass to the
 # "zig build" after "src_configure".
@@ -170,7 +171,6 @@ _zig_set_zbs_uris
 # 	zig_src_configure
 # }
 # @CODE
-: "${my_zbs_args:=}"
 
 # @ECLASS_VARIABLE: ZBS_ARGS_EXTRA
 # @USER_VARIABLE
@@ -203,7 +203,6 @@ _zig_set_zbs_uris
 : "${ZBS_VERBOSE:=ON}"
 
 # @ECLASS_VARIABLE: BUILD_DIR
-# @DEFAULT_UNSET
 # @DESCRIPTION:
 # Directory where all "ezig build" calls will be proceeded.
 # Defaults to "${WORKDIR}/${P}-build" if not set.
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-03-04 22:09 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-03-04 22:09 UTC (permalink / raw
  To: gentoo-commits
commit:     99e8916184f287089caa9a0c70bb1912f278a328
Author:     Eric Joldasov <bratishkaerik <AT> landless-city <DOT> net>
AuthorDate: Tue Mar  4 03:31:30 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Mar  4 22:05:19 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=99e89161
zig-utils.eclass: add 0.14 to the list of supported versions
Signed-off-by: Eric Joldasov <bratishkaerik <AT> landless-city.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/zig-utils.eclass | 2 ++
 1 file changed, 2 insertions(+)
diff --git a/eclass/zig-utils.eclass b/eclass/zig-utils.eclass
index e9d91b8f5f52..b1a7e0801667 100644
--- a/eclass/zig-utils.eclass
+++ b/eclass/zig-utils.eclass
@@ -493,6 +493,8 @@ zig-utils_find_installation() {
 
 	local zig_supported_versions=(
 		"9999"
+		"0.14.1"
+		"0.14.0"
 		"0.13.1"
 		"0.13.0"
 	)
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-03-04 22:32 Andreas Sturmlechner
  0 siblings, 0 replies; 6663+ messages in thread
From: Andreas Sturmlechner @ 2025-03-04 22:32 UTC (permalink / raw
  To: gentoo-commits
commit:     68775036e48302acfdbc95919c39e1febb79fcb8
Author:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
AuthorDate: Tue Mar  4 21:04:30 2025 +0000
Commit:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
CommitDate: Tue Mar  4 22:31:36 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=68775036
ecm.eclass: ecm_src_install: Pass arguments to cmake_src_install
Signed-off-by: Andreas Sturmlechner <asturm <AT> gentoo.org>
 eclass/ecm.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/ecm.eclass b/eclass/ecm.eclass
index fe5c78e0d79e..9caaf59cb3fa 100644
--- a/eclass/ecm.eclass
+++ b/eclass/ecm.eclass
@@ -728,7 +728,7 @@ ecm_src_test() {
 ecm_src_install() {
 	debug-print-function ${FUNCNAME} "$@"
 
-	cmake_src_install
+	cmake_src_install "$@"
 
 	local f
 	# bug 621970
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-03-04 22:32 Andreas Sturmlechner
  0 siblings, 0 replies; 6663+ messages in thread
From: Andreas Sturmlechner @ 2025-03-04 22:32 UTC (permalink / raw
  To: gentoo-commits
commit:     70baa56d9bb80d8694f65ba177d76243d34e1196
Author:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
AuthorDate: Tue Mar  4 16:36:31 2025 +0000
Commit:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
CommitDate: Tue Mar  4 22:31:35 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=70baa56d
ecm.eclass: Fix missing arguments handover to cmake_src_test
This omission impressively goes back to initial kde overlay commit
8265e71f48675ee84f8c745734ee157cc74cea6a on 2008-08-04.
Bug: https://bugs.gentoo.org/946863
Signed-off-by: Andreas Sturmlechner <asturm <AT> gentoo.org>
 eclass/ecm.eclass | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/eclass/ecm.eclass b/eclass/ecm.eclass
index 87284df4696e..fe5c78e0d79e 100644
--- a/eclass/ecm.eclass
+++ b/eclass/ecm.eclass
@@ -695,7 +695,7 @@ ecm_src_test() {
 		fi
 
 		# KDE_DEBUG stops crash handlers from launching and hanging the test phase
-		KDE_DEBUG=1 cmake_src_test
+		KDE_DEBUG=1 cmake_src_test "$@"
 	}
 
 	local -x QT_QPA_PLATFORM=offscreen
@@ -707,9 +707,9 @@ ecm_src_test() {
 	unset DBUS_SESSION_BUS_ADDRESS DBUS_SESSION_BUS_PID
 
 	if [[ ${EAPI} == 8 ]] && [[ ${VIRTUALX_REQUIRED} = always || ${VIRTUALX_REQUIRED} = test ]]; then
-		virtx _test_runner
+		virtx _test_runner "$@"
 	else
-		_test_runner
+		_test_runner "$@"
 	fi
 
 	if [[ -n "${DBUS_SESSION_BUS_PID}" ]] ; then
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-03-07  0:58 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-03-07  0:58 UTC (permalink / raw
  To: gentoo-commits
commit:     5519c68288e98ecc1e136aa32c5e9bf2444ceb2e
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Mar  7 00:56:52 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Mar  7 00:56:52 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=5519c682
libtool.eclass: depend on >=app-portage/elt-patches-20250306
We want new elt-patches to be in use to pick up *especially* the
as-needed fix for libtool-2.5.0, see 5a78316867a58ea36c6f645c35ff931fe65c0aaf
and 9102b0eae958dc76afba2e7b5210745d4a51b60b.
It makes sense to do it here not just to propagate the fix and ensure people
are using the new version, but it also forces rebuilds in the binhost and
invalidates the affected binpkgs for us via changed-deps. Double win!
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/libtool.eclass | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/eclass/libtool.eclass b/eclass/libtool.eclass
index 8ffc06d6ff98..6565faf07e83 100644
--- a/eclass/libtool.eclass
+++ b/eclass/libtool.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2024 Gentoo Authors
+# Copyright 1999-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: libtool.eclass
@@ -22,7 +22,7 @@ case ${EAPI} in
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
-BDEPEND=">=app-portage/elt-patches-20240116"
+BDEPEND=">=app-portage/elt-patches-20250306"
 
 inherit toolchain-funcs
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-03-07  1:23 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-03-07  1:23 UTC (permalink / raw
  To: gentoo-commits
commit:     2b5a13c5a6b9f6e8d8fba44a1ad6577a35198459
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Mar  7 01:14:50 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Mar  7 01:15:54 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=2b5a13c5
autotools.eclass: conditionalize elt-patches (libtool.eclass) dependency
Use newly-added LIBTOOL_DEPEND so that LIBTOOL_AUTO_DEPEND=no doesn't
result in a useless dependency on elt-patches in the WANT_LIBTOOL=no case.
Prompted by a discussion with Eli Schwartz <eschwartz <AT> gentoo.org>.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/autotools.eclass | 2 ++
 1 file changed, 2 insertions(+)
diff --git a/eclass/autotools.eclass b/eclass/autotools.eclass
index a36b6ba859be..1545b88bc426 100644
--- a/eclass/autotools.eclass
+++ b/eclass/autotools.eclass
@@ -32,6 +32,7 @@ case ${EAPI} in
 esac
 
 GNUCONFIG_AUTO_DEPEND=no
+LIBTOOL_AUTO_DEPEND=no
 inherit gnuconfig libtool
 
 # @ECLASS_VARIABLE: WANT_AUTOCONF
@@ -152,6 +153,7 @@ fi
 # versions in *DEPEND format.
 AUTOTOOLS_DEPEND="
 	${GNUCONFIG_DEPEND}
+	${LIBTOOL_DEPEND}
 	${_automake_atom}
 	${_autoconf_atom}
 	${_libtool_atom}
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-03-07  1:23 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-03-07  1:23 UTC (permalink / raw
  To: gentoo-commits
commit:     83f46749d45ee192cfc575b0b2b94cf281ce97b9
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Mar  7 01:13:00 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Mar  7 01:15:51 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=83f46749
libtool.eclass: add LIBTOOL_DEPEND
The motivation here is to allow autotools.eclass consumers setting
AUTOTOOLS_AUTO_DEPEND=no to not have a useless app-portage/elt-patches dependency.
Prompted by a discussion with Eli Schwartz <eschwartz <AT> gentoo.org>.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/libtool.eclass | 17 +++++++++++++++--
 1 file changed, 15 insertions(+), 2 deletions(-)
diff --git a/eclass/libtool.eclass b/eclass/libtool.eclass
index 6565faf07e83..7f21ac11575a 100644
--- a/eclass/libtool.eclass
+++ b/eclass/libtool.eclass
@@ -22,10 +22,23 @@ case ${EAPI} in
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
-BDEPEND=">=app-portage/elt-patches-20250306"
-
 inherit toolchain-funcs
 
+# @ECLASS_VARIABLE: LIBTOOL_DEPEND
+# @OUTPUT_VARIABLE
+# @DESCRIPTION:
+# Contains dependency on app-portage/elt-patches in *DEPEND format.
+LIBTOOL_DEPEND="app-portage/elt-patches"
+
+# @ECLASS_VARIABLE: LIBTOOL_AUTO_DEPEND
+# @PRE_INHERIT
+# @DESCRIPTION:
+# Set to 'no' to disable automatically adding to DEPEND.  This lets
+# ebuilds form conditional depends by using ${LIBTOOL_DEPEND} in
+# their own DEPEND string.
+: "${LIBTOOL_AUTO_DEPEND:=yes}"
+[[ ${LIBTOOL_AUTO_DEPEND} != "no" ]] && BDEPEND=${LIBTOOL_DEPEND}
+
 # @FUNCTION: elibtoolize
 # @USAGE: [dirs] [--portage] [--reverse-deps] [--patch-only] [--remove-internal-dep=xxx] [--shallow] [--no-uclibc]
 # @DESCRIPTION:
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-03-07  1:25 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-03-07  1:25 UTC (permalink / raw
  To: gentoo-commits
commit:     c263fc4e410d5f260eeb0969a350cf7ef00da6ba
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Mar  7 01:25:08 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Mar  7 01:25:08 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=c263fc4e
libtool.eclass: tighten elt-patches dep again
Very, very briefly lost in 83f46749d45ee192cfc575b0b2b94cf281ce97b9 from
5519c68288e98ecc1e136aa32c5e9bf2444ceb2e.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/libtool.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/libtool.eclass b/eclass/libtool.eclass
index 7f21ac11575a..18596a922307 100644
--- a/eclass/libtool.eclass
+++ b/eclass/libtool.eclass
@@ -28,7 +28,7 @@ inherit toolchain-funcs
 # @OUTPUT_VARIABLE
 # @DESCRIPTION:
 # Contains dependency on app-portage/elt-patches in *DEPEND format.
-LIBTOOL_DEPEND="app-portage/elt-patches"
+LIBTOOL_DEPEND=">=app-portage/elt-patches-20250306"
 
 # @ECLASS_VARIABLE: LIBTOOL_AUTO_DEPEND
 # @PRE_INHERIT
^ permalink raw reply related	[flat|nested] 6663+ messages in thread
* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-03-07 18:32 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-03-07 18:32 UTC (permalink / raw
  To: gentoo-commits
commit:     24e2fdbb99bbaea415908cc78465a75d20eefbbe
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Mar  7 18:32:01 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Mar  7 18:32:14 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=24e2fdbb
toolchain.eclass: fix -Wstringop-overread filter
It was added in 11, not 10.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 693a356d54a8..5cffbd7428ca 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -2104,7 +2104,7 @@ gcc_do_filter_flags() {
 	# https://gcc.gnu.org/PR100431
 	filter-flags -Werror=format-security
 
-	if ver_test -lt 10.1 ; then
+	if ver_test -lt 11.1 ; then
 		filter-flags '-fdiagnostics-urls=*'
 		filter-flags '-Wstringop-overread'
 	fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-03-08 14:02 Arthur Zamarin
  0 siblings, 0 replies; 6663+ messages in thread
From: Arthur Zamarin @ 2025-03-08 14:02 UTC (permalink / raw
  To: gentoo-commits
commit:     8562c054ab313c75ce0bed12d2177f98e7020ae6
Author:     Arthur Zamarin <arthurzam <AT> gentoo <DOT> org>
AuthorDate: Fri Mar  7 07:49:19 2025 +0000
Commit:     Arthur Zamarin <arthurzam <AT> gentoo <DOT> org>
CommitDate: Sat Mar  8 14:02:29 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=8562c054
rust.eclass: add documentation for RUST_{SLOT,TYPE}
Signed-off-by: Arthur Zamarin <arthurzam <AT> gentoo.org>
 eclass/rust.eclass | 12 ++++++++++++
 1 file changed, 12 insertions(+)
diff --git a/eclass/rust.eclass b/eclass/rust.eclass
index f69ea466f502..41197ce4e3a3 100644
--- a/eclass/rust.eclass
+++ b/eclass/rust.eclass
@@ -144,6 +144,18 @@ declare -a -g -r _RUST_SLOTS_ORDERED=(
 # Lowest Rust slot supported by the package. Needs to be set before
 # rust_pkg_setup is called. If unset, no lower bound is assumed.
 
+# @ECLASS_VARIABLE: RUST_SLOT
+# @OUTPUT_VARIABLE
+# @DESCRIPTION:
+# The selected Rust slot for building, from the range defined by
+# RUST_MAX_VER and RUST_MIN_VER. This is set by rust_pkg_setup.
+
+# @ECLASS_VARIABLE: RUST_TYPE
+# @OUTPUT_VARIABLE
+# @DESCRIPTION:
+# The selected Rust type for building, either 'source' or 'binary'.
+# This is set by rust_pkg_setup.
+
 # @ECLASS_VARIABLE: RUST_NEEDS_LLVM
 # @DEFAULT_UNSET
 # @DESCRIPTION:
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-03-08 14:02 Arthur Zamarin
  0 siblings, 0 replies; 6663+ messages in thread
From: Arthur Zamarin @ 2025-03-08 14:02 UTC (permalink / raw
  To: gentoo-commits
commit:     8d23ae27d80c26f4e748bd66d489d859a630a8d1
Author:     Arthur Zamarin <arthurzam <AT> gentoo <DOT> org>
AuthorDate: Fri Mar  7 07:49:01 2025 +0000
Commit:     Arthur Zamarin <arthurzam <AT> gentoo <DOT> org>
CommitDate: Sat Mar  8 14:02:29 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=8d23ae27
rust.eclass: fix typos
Signed-off-by: Arthur Zamarin <arthurzam <AT> gentoo.org>
 eclass/rust.eclass | 24 ++++++++++++------------
 1 file changed, 12 insertions(+), 12 deletions(-)
diff --git a/eclass/rust.eclass b/eclass/rust.eclass
index 9ead9d005706..f69ea466f502 100644
--- a/eclass/rust.eclass
+++ b/eclass/rust.eclass
@@ -12,12 +12,12 @@
 # An eclass to reliably depend on a Rust or Rust/LLVM combination for
 # a given Rust slot. To use the eclass:
 #
-# 1. If required, set RUST_{MAX,MIN}_SLOT to the range of supported slots.
+# 1. If required, set RUST_{MAX,MIN}_VER to the range of supported slots.
 #
 # 2. If rust is optional, set RUST_OPTIONAL to a non-empty value then
-#    appropriately gate ${RUST_DEPEND}
+#    appropriately gate ${RUST_DEPEND}.
 #
-# 3. Use rust_pkg_setup, get_rust_prefix or RUST_SLOT.
+# 3. Use rust_pkg_setup, get_rust_prefix, or RUST_SLOT.
 
 # Example use for a package supporting Rust 1.72.0 to 1.82.0:
 # @CODE
@@ -116,7 +116,7 @@ declare -a -g -r _RUST_SLOTS_ORDERED=(
 # @USER_VARIABLE
 # @DESCRIPTION:
 # Specify the version (slot) of Rust to be used by the package. This is
-# useful for troubleshooting and debugging purposes; If unset, the newest
+# useful for troubleshooting and debugging purposes. If unset, the newest
 # acceptable Rust version will be used. May be combined with ERUST_TYPE_OVERRIDE.
 # This variable must not be set in ebuilds.
 
@@ -175,7 +175,7 @@ declare -a -g -r _RUST_SLOTS_ORDERED=(
 # @DEFAULT_UNSET
 # @DESCRIPTION:
 # If set to a non-empty value, the Rust dependency will not be added
-# to BDEPEND. This is useful for where packages need to gate rust behind
+# to BDEPEND. This is useful for packages that need to gate rust behind
 # certain USE themselves.
 
 # @ECLASS_VARIABLE: RUST_REQ_USE
@@ -303,12 +303,12 @@ unset -f _rust_set_globals
 # If -d is specified, the checks are performed relative to ESYSROOT,
 # and ESYSROOT-path is returned.
 #
-# If RUST_M{AX,IN}_SLOT is non-zero, then only Rust versions that
+# If RUST_M{AX,IN}_VER is non-zero, then only Rust versions that
 # are not newer or older than the specified slot(s) will be considered.
-# Otherwise, all Rust versions are be considered acceptable.
+# Otherwise, all Rust versions are considered acceptable.
 #
 # If the `rust_check_deps()` function is defined within the ebuild, it
-# will be called to verify whether a particular slot is accepable.
+# will be called to verify whether a particular slot is acceptable.
 # Within the function scope, RUST_SLOT and LLVM_SLOT will be defined.
 #
 # The function should return a true status if the slot is acceptable,
@@ -443,7 +443,7 @@ _get_rust_slot() {
 # @FUNCTION: get_rust_path
 # @USAGE: prefix slot rust_type
 # @DESCRIPTION:
-# Given argument of slot and rust_type, return an appropriate path
+# Given arguments of prefix, slot, and rust_type, return an appropriate path
 # for the Rust install. The rust_type should be either "source"
 # or "binary". If the rust_type is not one of these, the function
 # will die.
@@ -472,7 +472,7 @@ get_rust_path() {
 # and print an absolute path to it. If both -bin and regular Rust
 # are installed, the regular Rust is preferred.
 #
-# The options and behavior are the same as get_rust_slot.
+# The options and behavior are the same as _get_rust_slot.
 get_rust_prefix() {
 	debug-print-function ${FUNCNAME} "$@"
 
@@ -501,10 +501,10 @@ rust_prepend_path() {
 # `llvm-r1_pkg_setup` call should be made in addition to this function.
 # For path determination logic, please see the get_rust_prefix documentation.
 #
-# The highest acceptable Rust slot can be set in RUST_MAX_VER variable.
+# The highest acceptable Rust slot can be set in the RUST_MAX_VER variable.
 # If it is unset or empty, any slot is acceptable.
 #
-# The lowest acceptable Rust slot can be set in RUST_MIN_VER variable.
+# The lowest acceptable Rust slot can be set in the RUST_MIN_VER variable.
 # If it is unset or empty, any slot is acceptable.
 #
 # `CARGO` and `RUSTC` variables are set for the selected slot and exported.
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-03-08 14:02 Arthur Zamarin
  0 siblings, 0 replies; 6663+ messages in thread
From: Arthur Zamarin @ 2025-03-08 14:02 UTC (permalink / raw
  To: gentoo-commits
commit:     6a0dc5891347b3e5fef0fb4480ef0bbcaff4f15b
Author:     Arthur Zamarin <arthurzam <AT> gentoo <DOT> org>
AuthorDate: Fri Mar  7 07:48:50 2025 +0000
Commit:     Arthur Zamarin <arthurzam <AT> gentoo <DOT> org>
CommitDate: Sat Mar  8 14:02:29 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=6a0dc589
cargo.eclass: fix typos
Signed-off-by: Arthur Zamarin <arthurzam <AT> gentoo.org>
 eclass/cargo.eclass | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/eclass/cargo.eclass b/eclass/cargo.eclass
index 25a2127f6391..909321c355b8 100644
--- a/eclass/cargo.eclass
+++ b/eclass/cargo.eclass
@@ -181,7 +181,7 @@ ECARGO_VENDOR="${ECARGO_HOME}/gentoo"
 # functions will be exported.
 #
 # If you enable CARGO_OPTIONAL call at least cargo_gen_config manually
-# before using other src_functions or cargo_env of this eclass.
+# before using other src_* functions or cargo_env of this eclass.
 # Note that cargo_gen_config is automatically called by cargo_src_unpack.
 
 # @ECLASS_VARIABLE: myfeatures
@@ -779,7 +779,7 @@ cargo_src_compile() {
 # @FUNCTION: cargo_src_install
 # @DESCRIPTION:
 # Installs the binaries generated by cargo.
-# In come cases workspaces need an alternative --path parameter.
+# In some cases workspaces need an alternative --path parameter.
 # Defaults to '--path ./' if no path is specified.
 # '--path ./somedir' can be passed directly to cargo_src_install.
 cargo_src_install() {
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-03-08 14:02 Arthur Zamarin
  0 siblings, 0 replies; 6663+ messages in thread
From: Arthur Zamarin @ 2025-03-08 14:02 UTC (permalink / raw
  To: gentoo-commits
commit:     89ebdf7e00afd3c25a15c993993e9dc8f46498bb
Author:     swomf <swomf <AT> proton <DOT> me>
AuthorDate: Fri Mar  7 16:03:46 2025 +0000
Commit:     Arthur Zamarin <arthurzam <AT> gentoo <DOT> org>
CommitDate: Sat Mar  8 14:02:30 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=89ebdf7e
cargo.eclass: use static.crates.io cdn
Starting from 2024-03-12, cargo began to download crates directly from
static.crates.io CDN servers worldwide. See
https://blog.rust-lang.org/2024/03/11/crates-io-download-changes.html
Signed-off-by: swomf <swomf <AT> proton.me>
Closes: https://github.com/gentoo/gentoo/pull/40944
Signed-off-by: Arthur Zamarin <arthurzam <AT> gentoo.org>
 eclass/cargo.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/cargo.eclass b/eclass/cargo.eclass
index dae2b93f24f3..9edfff88aa22 100644
--- a/eclass/cargo.eclass
+++ b/eclass/cargo.eclass
@@ -269,7 +269,7 @@ _cargo_set_crate_uris() {
 			name="${BASH_REMATCH[1]}"
 			version="${BASH_REMATCH[2]}"
 		fi
-		url="https://crates.io/api/v1/crates/${name}/${version}/download -> ${name}-${version}.crate"
+		url="https://static.crates.io/api/v1/crates/${name}/${version}/download -> ${name}-${version}.crate"
 		CARGO_CRATE_URIS+="${url} "
 
 		# when invoked by pkgbump, avoid fetching all the crates
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-03-08 14:02 Arthur Zamarin
  0 siblings, 0 replies; 6663+ messages in thread
From: Arthur Zamarin @ 2025-03-08 14:02 UTC (permalink / raw
  To: gentoo-commits
commit:     3b573d2233ad0b6548c10435b6547eba40d0b9fb
Author:     Michal Rostecki <vadorovsky <AT> protonmail <DOT> com>
AuthorDate: Thu Feb 27 16:09:53 2025 +0000
Commit:     Arthur Zamarin <arthurzam <AT> gentoo <DOT> org>
CommitDate: Sat Mar  8 14:02:29 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=3b573d22
cargo.eclass: Enable dynamic linking by default
Rust defaults to static linking (`-C target-feature=+crt-static`) on
musl targets. We already patch dev-lang/rust to always prefer dynamic
linking, but to ensure that behavior with dev-lang/rust-bin, set the
opposite option (`-C target-feature=-crt-static`) in RUSTFLAGS.
Bug: https://bugs.gentoo.org/940722
Signed-off-by: Michal Rostecki <vadorovsky <AT> protonmail.com>
Closes: https://github.com/gentoo/gentoo/pull/40797
Signed-off-by: Arthur Zamarin <arthurzam <AT> gentoo.org>
 eclass/cargo.eclass | 7 ++++++-
 1 file changed, 6 insertions(+), 1 deletion(-)
diff --git a/eclass/cargo.eclass b/eclass/cargo.eclass
index 909321c355b8..dae2b93f24f3 100644
--- a/eclass/cargo.eclass
+++ b/eclass/cargo.eclass
@@ -745,10 +745,15 @@ cargo_env() {
 	# The default linker is "cc" so override by setting linker to CC in the
 	# RUSTFLAGS. The given linker cannot include any arguments, so split these
 	# into link-args along with LDFLAGS.
+	#
+	# Rust defaults to static linking (-C target-feature=+crt-static) on musl
+	# targets. We already patch dev-lang/rust to always prefer dynamic linking,
+	# but to ensure that behavior with dev-lang/rust-bin, set the opposite option
+	# (-C target-feature=-crt-static) in RUSTFLAGS.
 	local -x CARGO_BUILD_TARGET=$(rust_abi)
 	local TRIPLE=${CARGO_BUILD_TARGET//-/_}
 	local TRIPLE=${TRIPLE^^} LD_A=( $(tc-getCC) ${LDFLAGS} )
-	local -Ix CARGO_TARGET_"${TRIPLE}"_RUSTFLAGS+=" -C strip=none -C linker=${LD_A[0]}"
+	local -Ix CARGO_TARGET_"${TRIPLE}"_RUSTFLAGS+=" -C strip=none -C linker=${LD_A[0]} -C target-feature=-crt-static"
 	[[ ${#LD_A[@]} -gt 1 ]] && local CARGO_TARGET_"${TRIPLE}"_RUSTFLAGS+="$(printf -- ' -C link-arg=%s' "${LD_A[@]:1}")"
 	local CARGO_TARGET_"${TRIPLE}"_RUSTFLAGS+=" ${RUSTFLAGS}"
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-03-08 16:59 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-03-08 16:59 UTC (permalink / raw
  To: gentoo-commits
commit:     33cf31d11d5c81d59cc4ae36f44eaf0886547c16
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Mar  8 16:57:24 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat Mar  8 16:59:14 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=33cf31d1
cargo.eclass: Revert "use static.crates.io cdn"
CloudFront is giving us 403 Forbidden errors.
Reverts: 89ebdf7e00afd3c25a15c993993e9dc8f46498bb
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/cargo.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/cargo.eclass b/eclass/cargo.eclass
index 9edfff88aa22..dae2b93f24f3 100644
--- a/eclass/cargo.eclass
+++ b/eclass/cargo.eclass
@@ -269,7 +269,7 @@ _cargo_set_crate_uris() {
 			name="${BASH_REMATCH[1]}"
 			version="${BASH_REMATCH[2]}"
 		fi
-		url="https://static.crates.io/api/v1/crates/${name}/${version}/download -> ${name}-${version}.crate"
+		url="https://crates.io/api/v1/crates/${name}/${version}/download -> ${name}-${version}.crate"
 		CARGO_CRATE_URIS+="${url} "
 
 		# when invoked by pkgbump, avoid fetching all the crates
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-03-10  1:55 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-03-10  1:55 UTC (permalink / raw
  To: gentoo-commits
commit:     50d9cf48986effb0baf5d92103137e7902d6ae5d
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Mar 10 00:03:17 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Mar 10 01:54:29 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=50d9cf48
ada.eclass: drop gnat_2021 (dev-lang/gnat-gpl) support
dev-lang/gnat-gpl is being last-rited.
Bug: https://bugs.gentoo.org/951054
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/ada.eclass | 19 ++++++-------------
 1 file changed, 6 insertions(+), 13 deletions(-)
diff --git a/eclass/ada.eclass b/eclass/ada.eclass
index 3d22dd5d2a61..2732b4f57afd 100644
--- a/eclass/ada.eclass
+++ b/eclass/ada.eclass
@@ -1,4 +1,4 @@
-# Copyright 2019-2024 Gentoo Authors
+# Copyright 2019-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: ada.eclass
@@ -49,7 +49,7 @@ _ADA_ECLASS=1
 # Example value:
 # @CODE
 # ada_target_gcc_12? ( sys-devel/gcc:12[ada] )
-# ada_target_gnat_2021? ( dev-lang/gnat-gps:2021[ada] )
+# ada_target_gcc_13? ( sys-devel/gcc:13[ada] )
 # @CODE
 
 # @ECLASS_VARIABLE: _ADA_ALL_IMPLS
@@ -57,7 +57,7 @@ _ADA_ECLASS=1
 # @DESCRIPTION:
 # All supported Ada implementations, most preferred last.
 _ADA_ALL_IMPLS=(
-	gnat_2021 gcc_12 gcc_13 gcc_14 gcc_15
+	gcc_12 gcc_13 gcc_14 gcc_15
 )
 readonly _ADA_ALL_IMPLS
 
@@ -77,7 +77,7 @@ readonly _ADA_ALL_IMPLS
 #
 # Example value:
 # @CODE
-# ^^ ( ada_target_gnat_2021 ada_target_gcc_12 )
+# ^^ ( ada_target_gcc_12 ada_target_gcc_13 )
 # @CODE
 
 # @ECLASS_VARIABLE: ADA_USEDEP
@@ -119,7 +119,7 @@ _ada_impl_supported() {
 	# keep in sync with _ADA_ALL_IMPLS!
 	# (not using that list because inline patterns shall be faster)
 	case "${impl}" in
-		gnat_2021|gcc_12|gcc_13|gcc_14|gcc_15)
+		gcc_12|gcc_13|gcc_14|gcc_15)
 			return 0
 			;;
 		*)
@@ -213,7 +213,7 @@ ada_export() {
 	local impl var
 
 	case "${1}" in
-		gnat_2021|gcc_12|gcc_13|gcc_14|gcc_15)
+		gcc_12|gcc_13|gcc_14|gcc_15)
 			impl=${1}
 			shift
 			;;
@@ -229,10 +229,6 @@ ada_export() {
 	local gcc_pv
 	local slot
 	case "${impl}" in
-		gnat_2021)
-			gcc_pv=10
-			slot=10
-			;;
 		gcc_12)
 			gcc_pv=12
 			slot=12
@@ -299,9 +295,6 @@ ada_export() {
 				;;
 			ADA_PKG_DEP)
 				case "${impl}" in
-					gnat_2021)
-						ADA_PKG_DEP="dev-lang/gnat-gpl:${slot}[ada]"
-						;;
 					gcc_12|gcc_13|gcc_14|gcc_15)
 						ADA_PKG_DEP="sys-devel/gcc:${slot}[ada]"
 						;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-03-11  9:04 Ionen Wolkens
  0 siblings, 0 replies; 6663+ messages in thread
From: Ionen Wolkens @ 2025-03-11  9:04 UTC (permalink / raw
  To: gentoo-commits
commit:     cf6fc509603c5a0813fc6cacf73052ce6998e598
Author:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
AuthorDate: Thu Mar  6 15:04:23 2025 +0000
Commit:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
CommitDate: Tue Mar 11 09:03:19 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=cf6fc509
ffmpeg-compat.eclass: new eclass
Both the slotting method and eclass are meant to be as simple
as possible, and isolated so that it does not really need to
work with everything given non-slotted ffmpeg stays.
Did not want turn ffmpeg into a permanent slotting model with
a FFMPEG_SLOT use_expand, eselect, or such potentially turning
it into a special Gentoo-only thing that often need hacks.
Essentially just a way for broken packages to gain time without
blocking everyone's ffmpeg updates.
Signed-off-by: Ionen Wolkens <ionen <AT> gentoo.org>
 eclass/ffmpeg-compat.eclass | 67 +++++++++++++++++++++++++++++++++++++++++++++
 1 file changed, 67 insertions(+)
diff --git a/eclass/ffmpeg-compat.eclass b/eclass/ffmpeg-compat.eclass
new file mode 100644
index 000000000000..f91fe6eead31
--- /dev/null
+++ b/eclass/ffmpeg-compat.eclass
@@ -0,0 +1,67 @@
+# Copyright 2025 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+# @ECLASS: ffmpeg-compat.eclass
+# @MAINTAINER:
+# Ionen Wolkens <ionen@gentoo.org>
+# @AUTHOR:
+# Ionen Wolkens <ionen@gentoo.org>
+# @SUPPORTED_EAPIS: 8
+# @BLURB: Helper functions to link with slotted ffmpeg-compat libraries
+# @DESCRIPTION:
+# To use this, run ``ffmpeg_compat_setup <slot>`` before packages use
+# pkg-config, depend on media-video/ffmpeg-compat:<slot>=, and ensure
+# usage of both pkg-config --cflags and --libs (which adds -Wl,-rpath
+# to find libraries at runtime).
+#
+# This eclass is intended as a quick-to-setup alternative to setting
+# an upper bound on ffmpeg for packages broken with the latest version,
+# and thus allow users to upgrade their normal ffmpeg.
+#
+# This should still be a temporary measure, and it is recommended to
+# keep migration bugs open rather than consider this eclass as being
+# the "fix".
+#
+# Unlike LLVM_SLOT-style, this does not have USE to select the slot
+# and should instead pick only the highest one usable until package
+# is fixed and can use non-slotted ffmpeg again.
+#
+# Do *not* use both like ``|| ( <ffmpeg-<ver> ffmpeg-compat:<slot> )``,
+# the package manager cannot know which version it linked against
+# without USE flags.  Unfortunately means a period where users may
+# have two identical versions in stable before the newest major version
+# is stabilized, but idea is to not mangle normal ffmpeg with slotting
+# logic and make this an isolated temporary deal.
+
+case ${EAPI} in
+	8) ;;
+	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
+esac
+
+if [[ -z ${_FFMPEG_COMPAT_ECLASS} ]]; then
+_FFMPEG_COMPAT_ECLASS=1
+
+# @FUNCTION: ffmpeg_compat_get_prefix
+# @USAGE: <slot>
+# @DESCRIPTION:
+# Return prefix of the installed ffmpeg-compat:<slot>.  Binaries like
+# ffmpeg will be found under <prefix>/bin if needed.
+ffmpeg_compat_get_prefix() {
+	(( ${#} == 1 )) || die "Usage: ${FUNCNAME} <slot>"
+
+	echo "${EPREFIX}/usr/lib/ffmpeg${1}"
+}
+
+# @FUNCTION: ffmpeg_compat_setup
+# @USAGE: <slot>
+# @DESCRIPTION:
+# Add ESYSROOT's ffmpeg-compat:<slot> to PKG_CONFIG_PATH for the
+# current ABI.
+ffmpeg_compat_setup() {
+	(( ${#} == 1 )) || die "Usage: ${FUNCNAME} <slot>"
+
+	: "${SYSROOT}$(ffmpeg_compat_get_prefix "${1}")/$(get_libdir)/pkgconfig"
+	export PKG_CONFIG_PATH=${_}:${PKG_CONFIG_PATH}
+}
+
+fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-03-11 13:23 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-03-11 13:23 UTC (permalink / raw
  To: gentoo-commits
commit:     776c012c6e3b6dd66aeeff851aedb48851f93975
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Mar 11 13:20:00 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Mar 11 13:23:05 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=776c012c
toolchain.eclass: wire up libc++ support (!)
Since GCC 14 (*), GCC supports -stdlib=libc++ if --with-gxx-libcxx-include-dir
is passed when configuring it. Pass that to facilitate testing and debugging.
(*) Handling was adjusted in r14-4107-gce7a757fd9ecb9. It existed before
    that in r11-6333-g662b9c55cf06d3 but the logic for the configure option
    changed substantially in the former commit, and I don't want to test
    all branches, so >=14 it is.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 5 +++++
 1 file changed, 5 insertions(+)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index e9f56450a33e..24464c73c9a6 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1833,6 +1833,11 @@ toolchain_src_configure() {
 		fi
 	fi
 
+	if [[ ${CTARGET} != *-darwin* ]] && tc_version_is_at_least 14.1 ; then
+		# This allows passing -stdlib-=libc++ at runtime.
+		confgcc+=( --with-gxx-libcxx-include-dir="${ESYSROOT}"/usr/include/c++/v1 )
+	fi
+
 	# TODO: Ignore RCs here (but TOOLCHAIN_IS_RC isn't yet an eclass var)
 	if [[ ${PV} == *_p* && -f "${S}"/gcc/doc/gcc.info ]] ; then
 		# Safeguard against https://gcc.gnu.org/PR106899 being fixed
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-03-11 13:23 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-03-11 13:23 UTC (permalink / raw
  To: gentoo-commits
commit:     8238f31c5c8f4122ba30a0e425e55cef5bc366fe
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Mar 11 13:19:23 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Mar 11 13:23:04 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=8238f31c
toolchain.eclass: wire up COBOL
COBOL is dead, long live COBOL! Merged today, so will be available
in next 15 snapshot, or use 15.0.9999 if you really can't wait ;)
Be aware that it's a bit bumpy integration-wise still upstream and
lots of patches are flowing.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 9 ++++++++-
 1 file changed, 8 insertions(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 5cffbd7428ca..e9f56450a33e 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -340,6 +340,7 @@ if [[ ${PN} != kgcc64 && ${PN} != gcc-* ]] ; then
 	tc_version_is_at_least 14.0.0_pre20230423 ${PV} && IUSE+=" rust" TC_FEATURES+=( rust )
 	tc_version_is_at_least 14.2.1_p20241026 ${PV} && IUSE+=" time64"
 	tc_version_is_at_least 15.0.0_pre20241124 ${PV} && IUSE+=" libgdiagnostics"
+	tc_version_is_at_least 15.0.0_pre20250316 ${PV} && IUSE+=" cobol"
 fi
 
 if tc_version_is_at_least 10; then
@@ -1255,6 +1256,7 @@ toolchain_src_configure() {
 	is_f77 && GCC_LANG+=",f77"
 	is_f95 && GCC_LANG+=",f95"
 	is_ada && GCC_LANG+=",ada"
+	is_cobol && GCC_LANG+=",cobol"
 	is_modula2 && GCC_LANG+=",m2"
 	is_rust && GCC_LANG+=",rust"
 
@@ -2600,7 +2602,7 @@ toolchain_src_install() {
 	cd "${D}"${BINPATH} || die
 	# Ugh: we really need to auto-detect this list.
 	#      It's constantly out of date.
-	for x in cpp gcc gccrs g++ c++ gcov gdc g77 gfortran gccgo gnat* ; do
+	for x in cpp gcc gccrs g++ c++ gcobol gcov gdc g77 gfortran gccgo gnat* ; do
 		# For some reason, g77 gets made instead of ${CTARGET}-g77...
 		# this should take care of that
 		if [[ -f ${x} ]] ; then
@@ -3142,6 +3144,11 @@ is_objcxx() {
 	_tc_use_if_iuse cxx && _tc_use_if_iuse objc++
 }
 
+is_cobol() {
+	gcc-lang-supported cobol || return 1
+	_tc_use_if_iuse cobol
+}
+
 is_modula2() {
 	gcc-lang-supported m2 || return 1
 	_tc_use_if_iuse cxx && _tc_use_if_iuse modula2
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-03-11 14:56 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-03-11 14:56 UTC (permalink / raw
  To: gentoo-commits
commit:     9e3482fa5cb8441190991c67286abea12ee15e16
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Tue Mar 11 14:51:19 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Tue Mar 11 14:56:17 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=9e3482fa
Add 21.0.0_pre20250311 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index 5fea1ff55ee5..f4e2e239d5f8 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -72,6 +72,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 			_LLVM_SOURCE_TYPE=snapshot
 
 			case ${PV} in
+				21.0.0_pre20250311)
+					EGIT_COMMIT=cb7298f66d62a3548fcf3bd230304067ecf30d17
+					;;
 				21.0.0_pre20250301)
 					EGIT_COMMIT=7e8a06cfa4a2951b8ee77e19e34926e6e535b4d1
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-03-11 22:15 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-03-11 22:15 UTC (permalink / raw
  To: gentoo-commits
commit:     cb8e218ee7715aef543ed6ba98c67fb25e7ed7b3
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Mar 11 22:14:29 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Mar 11 22:14:29 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=cb8e218e
toolchain.eclass: fix minimum version for COBOL
Spotted by Eli (because the USE invalidated a binpkg for the last snapshot).
Fixes: 8238f31c5c8f4122ba30a0e425e55cef5bc366fe
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 24464c73c9a6..2d479c9c7267 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -340,7 +340,7 @@ if [[ ${PN} != kgcc64 && ${PN} != gcc-* ]] ; then
 	tc_version_is_at_least 14.0.0_pre20230423 ${PV} && IUSE+=" rust" TC_FEATURES+=( rust )
 	tc_version_is_at_least 14.2.1_p20241026 ${PV} && IUSE+=" time64"
 	tc_version_is_at_least 15.0.0_pre20241124 ${PV} && IUSE+=" libgdiagnostics"
-	tc_version_is_at_least 15.0.0_pre20250316 ${PV} && IUSE+=" cobol"
+	tc_version_is_at_least 15.0.1_pre20250316 ${PV} && IUSE+=" cobol"
 fi
 
 if tc_version_is_at_least 10; then
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-03-12 10:14 Ionen Wolkens
  0 siblings, 0 replies; 6663+ messages in thread
From: Ionen Wolkens @ 2025-03-12 10:14 UTC (permalink / raw
  To: gentoo-commits
commit:     69d5c34dca046b4fa55c390d75c456a942da360f
Author:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
AuthorDate: Wed Mar 12 08:49:53 2025 +0000
Commit:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
CommitDate: Wed Mar 12 10:11:41 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=69d5c34d
ffmpeg-compat.eclass: add ffmpeg_compat_add_flags helper
Most packages are fine, but then there's cmake.
Also some others doing -L/usr/lib64 *before* pkg-config flags.
Not great, but adding to CPPFLAGS/LDFLAGS directly tend to
workaround most issues and helper will spare repeating this.
Also emphasize on importance to verify libraries, e.g. it can
build against ffmpeg-compat:6 but the -L/usr/lib64 will make
it use ffmpeg-7 and this sometimes succeed even if package was
broken with ffmpeg-7 assuming no missing symbols. -rpath could
also have been lost and libraries be not found.
Signed-off-by: Ionen Wolkens <ionen <AT> gentoo.org>
 eclass/ffmpeg-compat.eclass | 24 +++++++++++++++++++++++-
 1 file changed, 23 insertions(+), 1 deletion(-)
diff --git a/eclass/ffmpeg-compat.eclass b/eclass/ffmpeg-compat.eclass
index f91fe6eead31..1835a8c7e95a 100644
--- a/eclass/ffmpeg-compat.eclass
+++ b/eclass/ffmpeg-compat.eclass
@@ -12,7 +12,8 @@
 # To use this, run ``ffmpeg_compat_setup <slot>`` before packages use
 # pkg-config, depend on media-video/ffmpeg-compat:<slot>=, and ensure
 # usage of both pkg-config --cflags and --libs (which adds -Wl,-rpath
-# to find libraries at runtime).
+# to find libraries at runtime).  Always verify that it is linked with
+# the right libraries after.
 #
 # This eclass is intended as a quick-to-setup alternative to setting
 # an upper bound on ffmpeg for packages broken with the latest version,
@@ -41,6 +42,27 @@ esac
 if [[ -z ${_FFMPEG_COMPAT_ECLASS} ]]; then
 _FFMPEG_COMPAT_ECLASS=1
 
+inherit flag-o-matic toolchain-funcs
+
+# @FUNCTION: ffmpeg_compat_add_flags
+# @DESCRIPTION:
+# Append ``pkg-config --cflags libavcodec`` to CPPFLAGS and
+# --libs-only-{L,other} to LDFLAGS for the current ABI.
+#
+# Must run ``ffmpeg_compat_setup <slot>`` first.
+#
+# Ideally this function should not be used, but can be useful when
+# packages do not use pkg-config properly or drop some flags (common
+# with cmake).
+#
+# For multilib, ebuild should preserve previous flags by doing e.g.
+# ``local -x CPPFLAGS=${CPPFLAGS} LDFLAGS=${LDFLAGS}`` first.
+ffmpeg_compat_add_flags() {
+	# should be no real need to check anything but libavcodec's flags
+	append-cppflags $($(tc-getPKG_CONFIG) --cflags libavcodec || die)
+	append-ldflags $($(tc-getPKG_CONFIG) --libs-only-{L,other} libavcodec || die)
+}
+
 # @FUNCTION: ffmpeg_compat_get_prefix
 # @USAGE: <slot>
 # @DESCRIPTION:
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-03-12 20:02 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-03-12 20:02 UTC (permalink / raw
  To: gentoo-commits
commit:     539606eab3df9987f76778505c08e190b42ddb0d
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Mar 12 20:01:34 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Mar 12 20:01:48 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=539606ea
toolchain.eclass: fix indentation
Reported by negril.
Fixes: 14e674bb7a8cb8aa50498582e392d0ecd21f2d4a
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 18 +++++++++---------
 1 file changed, 9 insertions(+), 9 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 2d479c9c7267..e365269d1c18 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -429,15 +429,15 @@ if [[ ${PN} != gnat-gpl ]] && tc_has_feature ada ; then
 			)
 		"
 	else
-                BDEPEND+="
-                        ada? (
-                                || (
-                                        sys-devel/gcc:${SLOT}[ada]
-                                        <sys-devel/gcc-${SLOT}[ada]
-                                        <dev-lang/ada-bootstrap-${SLOT}
-                                )
-                        )
-                "
+		BDEPEND+="
+			ada? (
+				|| (
+					sys-devel/gcc:${SLOT}[ada]
+					<sys-devel/gcc-${SLOT}[ada]
+					<dev-lang/ada-bootstrap-${SLOT}
+				)
+			)
+		"
 	fi
 fi
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-03-13 13:18 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-03-13 13:18 UTC (permalink / raw
  To: gentoo-commits
commit:     aba106695eda9ab637305e3035a85175a323357e
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Mar 13 13:17:01 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Mar 13 13:17:01 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=aba10669
xorg-3.eclass: depend on elt-patches where appropriate
Since 2b5a13c5a6b9f6e8d8fba44a1ad6577a35198459, autotools.eclass with
AUTOTOOLS_AUTO_DEPEND=no won't always depend on elt-patches.
Explicitly add it when not eautoreconf-ing to match what src_prepare
does (for how it decides to call elibtoolize).
Closes: https://bugs.gentoo.org/951291
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/xorg-3.eclass | 8 ++++++--
 1 file changed, 6 insertions(+), 2 deletions(-)
diff --git a/eclass/xorg-3.eclass b/eclass/xorg-3.eclass
index 2ca5959dd1e7..db2d8fa85df9 100644
--- a/eclass/xorg-3.eclass
+++ b/eclass/xorg-3.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2024 Gentoo Authors
+# Copyright 1999-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: xorg-3.eclass
@@ -135,7 +135,11 @@ if [[ ${PN} != util-macros ]] ; then
 	# Required even by xorg-server
 	[[ ${PN} == "font-util" ]] || EAUTORECONF_DEPEND+=" >=media-fonts/font-util-1.2.0"
 fi
-[[ ${XORG_EAUTORECONF} != no ]] && BDEPEND+=" ${EAUTORECONF_DEPEND}"
+if [[ ${XORG_EAUTORECONF} == no ]] ; then
+	BDEPEND+=" ${LIBTOOL_DEPEND}"
+else
+	BDEPEND+=" ${EAUTORECONF_DEPEND}"
+fi
 unset EAUTORECONF_DEPEND
 
 # @ECLASS_VARIABLE: FONT_DIR
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-03-13 17:21 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-03-13 17:21 UTC (permalink / raw
  To: gentoo-commits
commit:     87c9c1899a56f388493ecbec3b45d175d99581f2
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Mar 13 17:20:22 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Mar 13 17:20:22 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=87c9c189
toolchain.eclass: hackily fixup libstdc++.modules.json
Bug: https://bugs.gentoo.org/948394
Bug: https://gcc.gnu.org/PR119266
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 7 +++++++
 1 file changed, 7 insertions(+)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index e365269d1c18..b86da4cf9876 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -2646,6 +2646,13 @@ toolchain_src_install() {
 		fi
 	fi
 
+	# Hack for C++ modules
+	if ! is_crosscompile; then
+		# PR19266 (bug #948394)
+		sed -e 's,\.\./lib/gcc/${CHOST}/${GCCMAJOR}/include/,../../../../include/,' \
+			"${ED}"/usr/lib/gcc/${CHOST}/${GCCMAJOR}/libstdc++.modules.json || die
+	fi
+
 	# As gcc installs object files built against both ${CHOST} and ${CTARGET}
 	# ideally we will need to strip them using different tools:
 	# Using ${CHOST} tools:
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-03-13 18:02 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-03-13 18:02 UTC (permalink / raw
  To: gentoo-commits
commit:     221897e8182089a650784e019457d8525700a905
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Mar 13 18:01:46 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Mar 13 18:01:46 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=221897e8
toolchain.eclass: hackily fixup libstdc++.modules.json (more)
Fixes: 87c9c1899a56f388493ecbec3b45d175d99581f2
Bug: https://bugs.gentoo.org/948394
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index b86da4cf9876..382f899366d7 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -2649,7 +2649,7 @@ toolchain_src_install() {
 	# Hack for C++ modules
 	if ! is_crosscompile; then
 		# PR19266 (bug #948394)
-		sed -e 's,\.\./lib/gcc/${CHOST}/${GCCMAJOR}/include/,../../../../include/,' \
+		sed -i -e "s,\.\./lib/gcc/${CHOST}/${GCCMAJOR}/include/,../../../../include/," \
 			"${ED}"/usr/lib/gcc/${CHOST}/${GCCMAJOR}/libstdc++.modules.json || die
 	fi
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-03-13 18:11 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-03-13 18:11 UTC (permalink / raw
  To: gentoo-commits
commit:     5a8d9cd103fc03a30dbcf6c455b13cf31d8ee15e
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Mar 13 18:08:23 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Mar 13 18:09:57 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=5a8d9cd1
toolchain.eclass: another .json fixup
Bug: https://bugs.gentoo.org/948394
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 382f899366d7..d48d8cf78d06 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -2649,7 +2649,7 @@ toolchain_src_install() {
 	# Hack for C++ modules
 	if ! is_crosscompile; then
 		# PR19266 (bug #948394)
-		sed -i -e "s,\.\./lib/gcc/${CHOST}/${GCCMAJOR}/include/,../../../../include/," \
+		sed -i -e "s,\.\./lib/gcc/${CHOST}/${GCCMAJOR}/include/,include/," \
 			"${ED}"/usr/lib/gcc/${CHOST}/${GCCMAJOR}/libstdc++.modules.json || die
 	fi
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-03-14  2:50 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-03-14  2:50 UTC (permalink / raw
  To: gentoo-commits
commit:     9c4f5b81368474b9bb7fb8245945c7faba3cc3e5
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Mar 14 02:48:57 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Mar 14 02:49:51 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=9c4f5b81
toolchain.eclass: only sed .json for 15
... it doesn't exist in older versions.
Bug: https://bugs.gentoo.org/948394
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index d48d8cf78d06..bb8bb6512394 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -2647,7 +2647,7 @@ toolchain_src_install() {
 	fi
 
 	# Hack for C++ modules
-	if ! is_crosscompile; then
+	if ! is_crosscompile && tc_version_is_at_least 15.0.1_pre20250316 ${PV}; then
 		# PR19266 (bug #948394)
 		sed -i -e "s,\.\./lib/gcc/${CHOST}/${GCCMAJOR}/include/,include/," \
 			"${ED}"/usr/lib/gcc/${CHOST}/${GCCMAJOR}/libstdc++.modules.json || die
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-03-17 20:13 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-03-17 20:13 UTC (permalink / raw
  To: gentoo-commits
commit:     b299c0518e12776db2dc8ea0beb95ad0a17f98f3
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Mon Mar 17 17:57:13 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Mon Mar 17 20:13:12 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=b299c051
Add 21.0.0_pre20250317 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index f4e2e239d5f8..dd911b0b3560 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -72,6 +72,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 			_LLVM_SOURCE_TYPE=snapshot
 
 			case ${PV} in
+				21.0.0_pre20250317)
+					EGIT_COMMIT=1c3a9a853ce68c3c539e7cab21380b9d8b18f426
+					;;
 				21.0.0_pre20250311)
 					EGIT_COMMIT=cb7298f66d62a3548fcf3bd230304067ecf30d17
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-03-22  0:52 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-03-22  0:52 UTC (permalink / raw
  To: gentoo-commits
commit:     62624051074391f6c8d7c6cdb4a75a234220a326
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Mar 22 00:50:45 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Mar 22 00:52:04 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=62624051
toolchain.eclass: force-enable libphobos
libphobos/configure.tgt controls which targets automatically get libphobos;
it works on more than is listed there but requires testing to be added.
For e.g. hppa, our CHOST differs from Debian and doesn't match (will send
a patch). For sparc, it looks like it should work, but not listed. Let's
override it and then can handle any fallout from there.
(Otherwise, we end up e.g. building a gcc which can't then bootstrap
other gcc w/ D).
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index bb8bb6512394..bf883c5370fc 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1241,7 +1241,7 @@ toolchain_src_configure() {
 
 	local GCC_LANG="c"
 	is_cxx && GCC_LANG+=",c++"
-	is_d   && GCC_LANG+=",d"
+	is_d   && GCC_LANG+=",d" confgcc+=( --enable-libphobos )
 	is_go  && GCC_LANG+=",go"
 	if is_objc || is_objcxx ; then
 		GCC_LANG+=",objc"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-03-22 10:43 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-03-22 10:43 UTC (permalink / raw
  To: gentoo-commits
commit:     e44e3df2293fa6503c82ec57d8bd7fcb75d8fc69
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Mar 22 10:41:57 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat Mar 22 10:41:57 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=e44e3df2
llvm.org.eclass: Remove old snapshots
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 6 ------
 1 file changed, 6 deletions(-)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index 90a26937edfb..50de4a62af8f 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -78,12 +78,6 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 				21.0.0_pre20250317)
 					EGIT_COMMIT=1c3a9a853ce68c3c539e7cab21380b9d8b18f426
 					;;
-				21.0.0_pre20250311)
-					EGIT_COMMIT=cb7298f66d62a3548fcf3bd230304067ecf30d17
-					;;
-				21.0.0_pre20250301)
-					EGIT_COMMIT=7e8a06cfa4a2951b8ee77e19e34926e6e535b4d1
-					;;
 				*)
 					die "Unknown snapshot: ${PV}"
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-03-24  6:53 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-03-24  6:53 UTC (permalink / raw
  To: gentoo-commits
commit:     0dbde702f43e075d88332b42c93287b200028691
Author:     NRK <nrk <AT> disroot <DOT> org>
AuthorDate: Fri Mar 14 17:25:16 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Mar 24 06:52:56 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=0dbde702
unpacker.eclass: add support for app-arch/7zip
Signed-off-by: NRK <nrk <AT> disroot.org>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/unpacker.eclass | 15 +++++++++++++--
 1 file changed, 13 insertions(+), 2 deletions(-)
diff --git a/eclass/unpacker.eclass b/eclass/unpacker.eclass
index 91520a36d16a..2697b8d9d73e 100644
--- a/eclass/unpacker.eclass
+++ b/eclass/unpacker.eclass
@@ -375,10 +375,15 @@ unpack_7z() {
 	local p7z=$(find_unpackable_file "$1")
 	unpack_banner "${p7z}"
 
+	local cmd7z="7z"
+	if command -v 7zz 1>/dev/null 2>&1; then
+		cmd7z="7zz"
+	fi
+
 	# warning: putting local and command substitution in a single call
 	# discards the exit status!
 	local output
-	output="$(7z x -y "${p7z}")"
+	output="$($cmd7z x -y "${p7z}")"
 	if [ $? -ne 0 ]; then
 		echo "${output}" >&2
 		die "unpacking ${p7z} failed (arch=unpack_7z)"
@@ -610,7 +615,13 @@ unpacker_src_uri_depends() {
 		*.rar)
 			deps[rar]="app-arch/unrar" ;;
 		*.7z)
-			deps[7z]="app-arch/p7zip" ;;
+			deps[7z]="
+				|| (
+					app-arch/7zip
+					app-arch/p7zip
+				)
+			"
+			;;
 		*.xz)
 			deps[xz]="app-arch/xz-utils" ;;
 		*.zip)
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-03-24  6:55 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-03-24  6:55 UTC (permalink / raw
  To: gentoo-commits
commit:     abf2fd38e070e572203de3237df2c956299db934
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Mar 24 06:54:13 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Mar 24 06:54:13 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=abf2fd38
unpacker.eclass: crank copyright
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/unpacker.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/unpacker.eclass b/eclass/unpacker.eclass
index 2697b8d9d73e..0ace3ae53cb9 100644
--- a/eclass/unpacker.eclass
+++ b/eclass/unpacker.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2024 Gentoo Authors
+# Copyright 1999-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: unpacker.eclass
^ permalink raw reply related	[flat|nested] 6663+ messages in thread
* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-03-25  8:15 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-03-25  8:15 UTC (permalink / raw
  To: gentoo-commits
commit:     b0d848e9ff18dff2ec1a47d4c4487e010edd80c8
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Mar 25 08:14:22 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Mar 25 08:14:22 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=b0d848e9
unpacker.eclass: fix 7zip dep
We have to depend on the right minimum version (and USE=symlink) to get
'7z'.
Bug: https://bugs.gentoo.org/942397
Closes: https://bugs.gentoo.org/952020
Fixes: 0dbde702f43e075d88332b42c93287b200028691
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/unpacker.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/unpacker.eclass b/eclass/unpacker.eclass
index 0ace3ae53cb9..85ea9921e560 100644
--- a/eclass/unpacker.eclass
+++ b/eclass/unpacker.eclass
@@ -617,7 +617,7 @@ unpacker_src_uri_depends() {
 		*.7z)
 			deps[7z]="
 				|| (
-					app-arch/7zip
+					>=app-arch/7zip-24.09[symlink]
 					app-arch/p7zip
 				)
 			"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-03-26 22:54 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-03-26 22:54 UTC (permalink / raw
  To: gentoo-commits
commit:     d33762e29e5a768a25abd7ca895d7b55e6f5951d
Author:     NRK <nrk <AT> disroot <DOT> org>
AuthorDate: Tue Mar 25 12:51:39 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Mar 26 22:53:29 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=d33762e2
Revert "unpacker.eclass: fix 7zip dep"
unpacker already checks for 7zz (always provided by
app-arch/7zip) and uses it if available and thus 7z symlink was
not necessary.
the problem was in app-arch/lzma using EAPI=7, unpacker doesn't
handle 7z files when below EAPI=8
This reverts commit b0d848e9ff18dff2ec1a47d4c4487e010edd80c8.
[sam: Add more Bug: trailers.]
Bug: https://bugs.gentoo.org/942397
Bug: https://bugs.gentoo.org/952020
Signed-off-by: NRK <nrk <AT> disroot.org>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/unpacker.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/unpacker.eclass b/eclass/unpacker.eclass
index 85ea9921e560..0ace3ae53cb9 100644
--- a/eclass/unpacker.eclass
+++ b/eclass/unpacker.eclass
@@ -617,7 +617,7 @@ unpacker_src_uri_depends() {
 		*.7z)
 			deps[7z]="
 				|| (
-					>=app-arch/7zip-24.09[symlink]
+					app-arch/7zip
 					app-arch/p7zip
 				)
 			"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-03-28  9:24 Nowa Ammerlaan
  0 siblings, 0 replies; 6663+ messages in thread
From: Nowa Ammerlaan @ 2025-03-28  9:24 UTC (permalink / raw
  To: gentoo-commits
commit:     0ef4b71c4de1d7b9773d524d85b7eb97d3ccc883
Author:     Nowa Ammerlaan <nowa <AT> gentoo <DOT> org>
AuthorDate: Tue Mar 25 18:41:07 2025 +0000
Commit:     Nowa Ammerlaan <nowa <AT> gentoo <DOT> org>
CommitDate: Fri Mar 28 09:22:47 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=0ef4b71c
kernel-build.eclass: do not override MODULES_SIGN_KEY with temp key
The kernel build system expects the module signing key and
certificate in one file. In order to accommodate this we merge the
MODULES_SIGN_KEY and MODULES_SIGN_CERT into a temporary key in $T.
However, in doing so we override the MODULES_SIGN_KEY variable (but
not the MODULES_SIGN_CERT variable). This becomes a problem when
merging binpkgs because then the MODULES_SIGN_KEY variable points to
a temporary signing key that does not exist (whereas the untouched
MODULES_SIGN_CERT does exist). Usually this is not an issue except if
the MODULES_SIGN_KEY is to be used later in the binpkg merging process
such as is the case in, for example, the dkms installkernel hook.
Here we resolve this unfortunate situation by using a local variable
during the config merging process and not touching the original
MODULES_SIGN_KEY. Therefore, the MODULES_SIGN_KEY will now also
point us to an existing key if we are merging a binpkg of the kernel.
Signed-off-by: Nowa Ammerlaan <nowa <AT> gentoo.org>
Closes: https://github.com/gentoo/gentoo/pull/41286
Signed-off-by: Nowa Ammerlaan <nowa <AT> gentoo.org>
 eclass/kernel-build.eclass | 15 ++++++++-------
 1 file changed, 8 insertions(+), 7 deletions(-)
diff --git a/eclass/kernel-build.eclass b/eclass/kernel-build.eclass
index 65433d9fc9c0..1d8c396b9590 100644
--- a/eclass/kernel-build.eclass
+++ b/eclass/kernel-build.eclass
@@ -741,18 +741,19 @@ kernel-build_merge_configs() {
 	fi
 
 	if [[ ${KERNEL_IUSE_MODULES_SIGN} ]] && use modules-sign; then
+		local modules_sign_key=${MODULES_SIGN_KEY}
 		if [[ -n ${MODULES_SIGN_KEY_CONTENTS} ]]; then
-			(umask 066 && touch "${T}/kernel_key.pem" || die)
-			echo "${MODULES_SIGN_KEY_CONTENTS}" > "${T}/kernel_key.pem" || die
+			modules_sign_key="${T}/kernel_key.pem"
+			(umask 066 && touch "${modules_sign_key}" || die)
+			echo "${MODULES_SIGN_KEY_CONTENTS}" > "${modules_sign_key}" || die
 			unset MODULES_SIGN_KEY_CONTENTS
-			export MODULES_SIGN_KEY="${T}/kernel_key.pem"
 		fi
-		if [[ ${MODULES_SIGN_KEY} == pkcs11:* || -r ${MODULES_SIGN_KEY} ]]; then
-			echo "CONFIG_MODULE_SIG_KEY=\"${MODULES_SIGN_KEY}\"" \
+		if [[ ${modules_sign_key} == pkcs11:* || -r ${modules_sign_key} ]]; then
+			echo "CONFIG_MODULE_SIG_KEY=\"${modules_sign_key}\"" \
 				>> "${WORKDIR}/modules-sign-key.config"
 			merge_configs+=( "${WORKDIR}/modules-sign-key.config" )
-		elif [[ -n ${MODULES_SIGN_KEY} ]]; then
-			die "MODULES_SIGN_KEY=${MODULES_SIGN_KEY} not found or not readable!"
+		elif [[ -n ${modules_sign_key} ]]; then
+			die "MODULES_SIGN_KEY=${modules_sign_key} not found or not readable!"
 		fi
 	fi
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-03-28 15:06 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-03-28 15:06 UTC (permalink / raw
  To: gentoo-commits
commit:     1ff2a7c47139ede296cf89ceba629f17b865ff27
Author:     Florian Albrechtskirchinger <falbrechtskirchinger <AT> gmail <DOT> com>
AuthorDate: Fri Mar 28 10:52:22 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Mar 28 15:04:00 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=1ff2a7c4
flag-o-matic.eclass: allow -gz=type
-gz for producing compressed debug sections is already allowed; this
change permits -gz with an explicit type specifier (e.g., zlib or zstd).
Signed-off-by: Florian Albrechtskirchinger <falbrechtskirchinger <AT> gmail.com>
Closes: https://github.com/gentoo/gentoo/pull/41341
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/flag-o-matic.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/flag-o-matic.eclass b/eclass/flag-o-matic.eclass
index 9590192bb1f4..4765809e9118 100644
--- a/eclass/flag-o-matic.eclass
+++ b/eclass/flag-o-matic.eclass
@@ -77,7 +77,7 @@ _setup-allowed-flags() {
 		-ggdb '-ggdb[0-9]'
 		-gdwarf '-gdwarf-*'
 		-gstabs -gstabs+
-		-gz
+		-gz '-gz=*'
 		-glldb
 		'-fdebug-default-version=*'
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-03-29 10:27 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-03-29 10:27 UTC (permalink / raw
  To: gentoo-commits
commit:     ff76ce4fcb6835f31bde533618f11c23dfbd6b6f
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Mar 29 10:25:25 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat Mar 29 10:25:25 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=ff76ce4f
Add 21.0.0_pre20250329 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index 50de4a62af8f..7f0b26b734d1 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -72,6 +72,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 			_LLVM_SOURCE_TYPE=snapshot
 
 			case ${PV} in
+				21.0.0_pre20250329)
+					EGIT_COMMIT=21eeca3db0341fef4ab4a6464ffe38b2eba5810c
+					;;
 				21.0.0_pre20250322)
 					EGIT_COMMIT=1d133420dc512487e2be0e9d86755f2a7c3497a7
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-03-29 15:58 James Le Cuirot
  0 siblings, 0 replies; 6663+ messages in thread
From: James Le Cuirot @ 2025-03-29 15:58 UTC (permalink / raw
  To: gentoo-commits
commit:     6937fcb873120179a5bb32055b26612ac4a72c52
Author:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
AuthorDate: Sun Mar 23 11:12:00 2025 +0000
Commit:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
CommitDate: Sat Mar 29 15:57:39 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=6937fcb8
cargo.eclass: Only tell Cargo to cross-compile when actually needed
This avoids the build host vs target flag separation issue. Sometimes it
is important for the build host to use the right flags. We cannot fix
this for cross-compiling now, but it should at least work for native
builds.
Closes: https://bugs.gentoo.org/951740
Signed-off-by: James Le Cuirot <chewi <AT> gentoo.org>
 eclass/cargo.eclass | 8 +++++++-
 1 file changed, 7 insertions(+), 1 deletion(-)
diff --git a/eclass/cargo.eclass b/eclass/cargo.eclass
index dae2b93f24f3..95d485ab20c3 100644
--- a/eclass/cargo.eclass
+++ b/eclass/cargo.eclass
@@ -448,7 +448,9 @@ _cargo_gen_git_config() {
 # Return the directory within target that contains the build, e.g.
 # target/aarch64-unknown-linux-gnu/release.
 cargo_target_dir() {
-	echo "${CARGO_TARGET_DIR:-target}/$(rust_abi)/$(usex debug debug release)"
+	local abi
+	tc-is-cross-compiler && abi=/$(rust_abi)
+	echo "${CARGO_TARGET_DIR:-target}${abi}/$(usex debug debug release)"
 }
 
 # @FUNCTION: cargo_update_crates
@@ -762,6 +764,10 @@ cargo_env() {
 		# locally. Do this in a subshell so that they remain set afterwards.
 		unset CARGO_BUILD_RUSTFLAGS CARGO_ENCODED_RUSTFLAGS RUSTFLAGS
 
+		# Only tell Cargo to cross-compile when actually needed to avoid the
+		# aforementioned build host vs target flag separation issue.
+		tc-is-cross-compiler || unset CARGO_BUILD_TARGET
+
 		"${@}"
 	)
 }
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-01 13:58 Florian Schmaus
  0 siblings, 0 replies; 6663+ messages in thread
From: Florian Schmaus @ 2025-04-01 13:58 UTC (permalink / raw
  To: gentoo-commits
commit:     8643a627c63a350e0260b50769cd557272140d4e
Author:     Volkmar W. Pogatzki <gentoo <AT> pogatzki <DOT> net>
AuthorDate: Tue Nov 19 15:46:54 2024 +0000
Commit:     Florian Schmaus <flow <AT> gentoo <DOT> org>
CommitDate: Tue Apr  1 13:58:01 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=8643a627
java-pkg-simple.eclass: support Multi-Release JAR Files (JEP 238)
See https://openjdk.org/jeps/238
This commit adds basic support for building multi-release jar files.
A multi-release jar file has release-specific classes in directories
under META-INF/versions/ and its MANIFEST.MF contains a line with
'Multi-Release: true'.
The probably most common case of a multi-release jar file has only one
single such class which is 'META-INF/versions/9/module-info.class'.
To do so, we add JAVA_RELEASE_SRC_DIRS as a new eclass variable which
is also used as the condition to trigger the new functionality. A new
local variable 'multi_release' is added to the packaging section (the
part using the 'jar -create' command). Only when JAVA_RELEASE_SRC_DIRS
is set, additional actions take place:
- Compilation (those are the parts with 'ejavac') will additionally loop
  over the release-specific directories listed in JAVA_RELEASE_SRC_DIRS
  and compile the release-specific classes into corresponding directories
  under target/versions/.
- Packaging (the part using the 'jar -create' command) will add the
  details to the 'multi_release' variable so that the release-specific
  directories under target/versions/ can be packaged into the jar file.
This commit also adds funtionality to generate 'module-info.java' files.
It is useful for packages where module-info.java is not provided in the
sources but needs to be generated by the build system. We use the built-in
jdeps function with the --generate-module-info option which became available
with Java 11.
It generates the module-info.java file based on an intermediate jar file
and places it in the "${JAVA_MODULE_INFO_OUT}/${JAVA_INTERMEDIATE_JAR_NAME}/"
directory.
For this purpose we add three new eclass variables:
- JAVA_INTERMEDIATE_JAR_NAME
- JAVA_MODULE_INFO_OUT
- JAVA_MODULE_INFO_RELEASE
When both JAVA_MODULE_INFO_OUT and JAVA_INTERMEDIATE_JAR_NAME are defined in the
ebuild we
- compile the sources still without module-info
- package them as an intermediate {JAVA_INTERMEDIATE_JAR_NAME}.jar
- let java-pkg-simple_generate-module-info generate the module-info
- compile module-info.java with the --patch-module option
- package the final jar file including the module-info.class
When the JAVA_MODULE_INFO_RELEASE variable is set, module-info.java is
generated into a release specific directory
"${JAVA_MODULE_INFO_OUT}/${JAVA_INTERMEDIATE_JAR_NAME}/versions/{JAVA_MODULE_INFO_RELEASE}".
Bug: https://bugs.gentoo.org/900433
Signed-off-by: Volkmar W. Pogatzki <gentoo <AT> pogatzki.net>
Signed-off-by: Florian Schmaus <flow <AT> gentoo.org>
 eclass/java-pkg-simple.eclass | 335 +++++++++++++++++++++++++++++++++++++-----
 1 file changed, 297 insertions(+), 38 deletions(-)
diff --git a/eclass/java-pkg-simple.eclass b/eclass/java-pkg-simple.eclass
index ce4a62f048da..f3f67e7de408 100644
--- a/eclass/java-pkg-simple.eclass
+++ b/eclass/java-pkg-simple.eclass
@@ -1,4 +1,4 @@
-# Copyright 2004-2024 Gentoo Authors
+# Copyright 2004-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: java-pkg-simple.eclass
@@ -11,7 +11,9 @@
 # @DESCRIPTION:
 # This class is intended to build pure Java packages from Java sources
 # without the use of any build instructions shipped with the sources.
-# There is no support for generating source files, or for controlling
+# It can generate module-info.java files and supports adding the Main-Class
+# and the Automatic-Module-Name attributes to MANIFEST.MF. There is no
+# further support for generating source files, or for controlling
 # the META-INF of the resulting jar, although these issues may be
 # addressed by an ebuild by putting corresponding files into the target
 # directory before calling the src_compile function of this eclass.
@@ -111,7 +113,6 @@ fi
 #	)
 # @CODE
 
-# @DESCRIPTION:
 # @ECLASS_VARIABLE: JAVA_RESOURCE_DIRS
 # @DEFAULT_UNSET
 # @DESCRIPTION:
@@ -225,6 +226,50 @@ fi
 # @DESCRIPTION:
 # It is almost equivalent to ${JAVA_RESOURCE_DIRS} in src_test.
 
+# @ECLASS_VARIABLE: JAVA_INTERMEDIATE_JAR_NAME
+# @DEFAULT_UNSET
+# @DESCRIPTION:
+# Name of the intermediate jar file excluding the '.jar' suffix and also name of the
+# ejavac output directory which are needed by 'jdeps --generate-module-info'.
+# @CODE
+# Examples:
+# 	JAVA_INTERMEDIATE_JAR_NAME="org.apache.${PN/-/.}"
+# 	JAVA_INTERMEDIATE_JAR_NAME="com.github.marschall.memoryfilesystem"
+# @CODE
+
+# @ECLASS_VARIABLE: JAVA_MODULE_INFO_OUT
+# @DEFAULT_UNSET
+# @DESCRIPTION:
+# Used by java-pkg-simple_generate-module-info.
+# It is the directory where module-info.java will be created.
+# Only when this variable is set, module-info.java will be created.
+# @CODE
+# Example:
+# 	JAVA_MODULE_INFO_OUT="src/main"
+# @CODE
+
+# @ECLASS_VARIABLE: JAVA_MODULE_INFO_RELEASE
+# @DESCRIPTION:
+# Used by java-pkg-simple_generate-module-info.
+# Correlates to JAVA_RELEASE_SRC_DIRS.
+# When this variable is set, module-info.java will be placed in
+# ${JAVA_MODULE_INFO_OUT}/${JAVA_INTERMEDIATE_JAR_NAME}/versions/${JAVA_MODULE_INFO_RELEASE}
+
+# @ECLASS_VARIABLE: JAVA_RELEASE_SRC_DIRS
+# @DEFAULT_UNSET
+# @DESCRIPTION:
+# An associative array of directories with release-specific sources which are
+# used for building multi-release jar files.
+# @CODE
+# Example:
+#	JAVA_RELEASE_SRC_DIRS=(
+#		["9"]="prov/src/main/jdk1.9"
+#		["11"]="prov/src/main/jdk1.11"
+#		["15"]="prov/src/main/jdk1.15"
+#		["21"]="prov/src/main/jdk21"
+#	)
+# @CODE
+
 # @FUNCTION: java-pkg-simple_getclasspath
 # @USAGE: java-pkg-simple_getclasspath
 # @INTERNAL
@@ -276,6 +321,88 @@ java-pkg-simple_getclasspath() {
 	debug-print "CLASSPATH=${classpath}"
 }
 
+# @FUNCTION: java-pkg-simple_getmodulepath
+# @USAGE: java-pkg-simple_getmodulepath
+# @INTERNAL
+# @DESCRIPTION:
+# Cloned from java-pkg-simple_getclasspath, dropped 'deep_jars'
+# and replaced s/classpath/modulepath/g.
+#
+# It is needed for java-pkg-simple_generate-module-info where using classpath
+# would cause problems with '--with-dependencies'.
+# And it is also used for compilation.
+#
+# Note that the variable "modulepath" needs to be defined before
+# calling this function.
+java-pkg-simple_getmodulepath() {
+	debug-print-function ${FUNCNAME} $*
+
+	local dependency
+	local buildonly_jars="--build-only"
+
+	# the extra classes that are not installed by portage
+	modulepath+=":${JAVA_GENTOO_CLASSPATH_EXTRA}"
+
+	# the extra classes that are installed by portage
+	for dependency in ${JAVA_CLASSPATH_EXTRA}; do
+		modulepath="${modulepath}:$(java-pkg_getjars ${buildonly_jars} \
+			${dependency})"
+	done
+
+	# add test dependencies if USE FLAG 'test' is set
+	if has test ${JAVA_PKG_IUSE} && use test; then
+		for dependency in ${JAVA_TEST_GENTOO_CLASSPATH}; do
+			modulepath="${modulepath}:$(java-pkg_getjars ${buildonly_jars} \
+				${dependency})"
+		done
+	fi
+
+	# add the RUNTIME dependencies
+	for dependency in ${JAVA_GENTOO_CLASSPATH}; do
+		modulepath="${modulepath}:$(java-pkg_getjars ${dependency})"
+	done
+
+	# purify modulepath
+	while [[ $modulepath = *::* ]]; do modulepath="${modulepath//::/:}"; done
+	modulepath=${modulepath%:}
+	modulepath=${modulepath#:}
+
+	debug-print "modulepath=${modulepath}"
+}
+
+# @FUNCTION: java-pkg-simple_generate-module-info
+# @USAGE: java-pkg-simple_generate-module-info
+# @INTERNAL
+# @DESCRIPTION:
+# Calls jdeps --generate-module-info which generates module-info.java.
+# Requires an intermediate jar file to be named as "${JAVA_INTERMEDIATE_JAR_NAME}.jar".
+java-pkg-simple_generate-module-info() {
+	debug-print-function ${FUNCNAME} $*
+
+	local modulepath="" jdeps_args=""
+	java-pkg-simple_getmodulepath
+
+	# Default to release 9 in order to avoid having to set it in the ebuild.
+	: "${JAVA_MODULE_INFO_RELEASE:=9}"
+
+	if [[ ${JAVA_MODULE_INFO_RELEASE} ]]; then
+		jdeps_args="${jdeps_args} --multi-release ${JAVA_MODULE_INFO_RELEASE}"
+	fi
+
+	if [[ ${modulepath} ]]; then
+		jdeps_args="${jdeps_args} --module-path ${modulepath}"
+		jdeps_args="${jdeps_args} --add-modules=ALL-MODULE-PATH"
+	fi
+	debug-print "jdeps_args is ${jdeps_args}"
+
+	jdeps \
+		--generate-module-info "${JAVA_MODULE_INFO_OUT}" \
+		${jdeps_args} \
+		"${JAVA_INTERMEDIATE_JAR_NAME}.jar" || die
+
+	moduleinfo=$(find -type f -name module-info.java)
+}
+
 # @FUNCTION: java-pkg-simple_test_with_pkgdiff_
 # @INTERNAL
 # @DESCRIPTION:
@@ -374,50 +501,162 @@ java-pkg-simple_src_compile() {
 		java-pkg_gen-cp JAVA_GENTOO_CLASSPATH
 	fi
 
-	# gather sources
-	# if target < 9, we need to compile module-info.java separately
-	# as this feature is not supported before Java 9
-	local target="$(java-pkg_get-target)"
-	if [[ ${target#1.} -lt 9 ]]; then
-		find "${JAVA_SRC_DIR[@]}" -name \*.java ! -name module-info.java > ${sources}
-	else
-		find "${JAVA_SRC_DIR[@]}" -name \*.java > ${sources}
-	fi
-	moduleinfo=$(find "${JAVA_SRC_DIR[@]}" -name module-info.java)
+	# generate module-info.java only if JAVA_MODULE_INFO_OUT is defined in the ebuild
+	if [[ ${JAVA_MODULE_INFO_OUT} && ${JAVA_INTERMEDIATE_JAR_NAME} ]]; then
 
-	# create the target directory
-	mkdir -p ${classes} || die "Could not create target directory"
+		local jdk="$(depend-java-query --get-lowest "${DEPEND}")"
+		if [[ "${jdk#1.}" -lt 9 ]]; then
+			die "Wrong DEPEND, needs at least virtual/jdk-9"
+		fi
 
-	# compile
-	local classpath=""
-	java-pkg-simple_getclasspath
-	java-pkg-simple_prepend_resources ${classes} "${JAVA_RESOURCE_DIRS[@]}"
+		local classpath=""
+		java-pkg-simple_getclasspath
 
-	if [[ -z ${moduleinfo} ]] || [[ ${target#1.} -lt 9 ]]; then
+		# gather sources and compile classes for the intermediate jar file
+		find "${JAVA_SRC_DIR[@]}" -name \*.java ! -name module-info.java > ${sources}
 		ejavac -d ${classes} -encoding ${JAVA_ENCODING}\
 			${classpath:+-classpath ${classpath}} ${JAVAC_ARGS} @${sources}
-	else
-		ejavac -d ${classes} -encoding ${JAVA_ENCODING}\
-			${classpath:+--module-path ${classpath}} --module-version ${PV}\
-			${JAVAC_ARGS} @${sources}
+
+		java-pkg-simple_prepend_resources ${classes} "${JAVA_RESOURCE_DIRS[@]}"
+
+		# package the intermediate jar file
+		# The intermediate jar file is a precondition for jdeps to generate
+		# a module-info.java file.
+		jar cvf "${JAVA_INTERMEDIATE_JAR_NAME}.jar" \
+			-C target/classes . || die
+
+		# now, generate module-info.java
+		java-pkg-simple_generate-module-info
+		debug-print "generated moduleinfo is ${moduleinfo}"
+
+		# If JAVA_RELEASE_SRC_DIRS was not set in the ebuild, set it now:
+		if [[ ${JAVA_MODULE_INFO_RELEASE} && -z ${JAVA_RELEASE_SRC_DIRS[@]} ]]; then
+			# TODO: use JAVA_MODULE_INFO_RELEASE instead of fixed value.
+			JAVA_RELEASE_SRC_DIRS=( ["9"]=${JAVA_MODULE_INFO_OUT}/${JAVA_INTERMEDIATE_JAR_NAME}"/versions/9" )
+		fi
 	fi
 
-	# handle module-info.java separately as it needs at least JDK 9
-	if [[ -n ${moduleinfo} ]] && [[ ${target#1.} -lt 9 ]]; then
-		if java-pkg_is-vm-version-ge "9" ; then
-			local tmp_source=${JAVA_PKG_WANT_SOURCE} tmp_target=${JAVA_PKG_WANT_TARGET}
+	# JEP 238 multi-release support, https://openjdk.org/jeps/238 #900433
+	#
+	# Basic support for building multi-release jar files according to JEP 238.
+	# A multi-release jar file has release-specific classes in directories
+	# under META-INF/versions/.
+	# Its META-INF/MANIFEST.MF contains the line: 'Multi-Release: true'.
+	if [[ -n ${JAVA_RELEASE_SRC_DIRS[@]} ]]; then
+		# Ensure correct virtual/jdk version
+		# Initialize a variable to track the highest key
+		local highest_version=-1
+
+		# Loop through the keys of the associative array
+		for key in "${!JAVA_RELEASE_SRC_DIRS[@]}"; do
+		    # Compare the numeric value of the key
+		    if [[ key -gt highest_version ]]; then
+		        highest_version="$key"
+		    fi
+		done
 
-			JAVA_PKG_WANT_SOURCE="9"
-			JAVA_PKG_WANT_TARGET="9"
+		local jdk="$(depend-java-query --get-lowest "${DEPEND}")"
+		if [[ "${jdk#1.}" -lt "${highest_version}" ]]; then
+			die "Wrong DEPEND, needs at least virtual/jdk-${highest_version}"
+		fi
+
+		local classpath=""
+		java-pkg-simple_getclasspath
+
+		# An intermediate jar file might already exist from generation of the
+		# module-info.java file
+		if [[ ! $(find . -name ${JAVA_INTERMEDIATE_JAR_NAME}.jar) ]]; then
+			einfo "generating intermediate for multi-release"
+			# gather sources and compile classes for the intermediate jar file
+			find "${JAVA_SRC_DIR[@]}" -name \*.java ! -name module-info.java > ${sources}
 			ejavac -d ${classes} -encoding ${JAVA_ENCODING}\
-				${classpath:+--module-path ${classpath}} --module-version ${PV}\
-				${JAVAC_ARGS} "${moduleinfo}"
+				${classpath:+-classpath ${classpath}} ${JAVAC_ARGS} @${sources}
 
-			JAVA_PKG_WANT_SOURCE=${tmp_source}
-			JAVA_PKG_WANT_TARGET=${tmp_target}
+			java-pkg-simple_prepend_resources ${classes} "${JAVA_RESOURCE_DIRS[@]}"
+
+			# package the intermediate jar file
+			# The intermediate jar file is a precondition for jdeps to generate
+			# a module-info.java file.
+			jar cvf "${JAVA_INTERMEDIATE_JAR_NAME}.jar" \
+				-C target/classes . || die
+		fi
+
+		local tmp_source=${JAVA_PKG_WANT_SOURCE} tmp_target=${JAVA_PKG_WANT_TARGET}
+
+		# compile content of release-specific source directories
+		local version
+		for version in "${!JAVA_RELEASE_SRC_DIRS[@]}"; do
+			local release="${version}"
+			local reldir="${JAVA_RELEASE_SRC_DIRS[${version}]}"
+			debug-print "Release is ${release}, directory is ${reldir}"
+
+			JAVA_PKG_WANT_SOURCE="${release}"
+			JAVA_PKG_WANT_TARGET="${release}"
+
+			local modulepath=""
+			java-pkg-simple_getmodulepath
+
+			# compile sources in ${reldir}
+			ejavac \
+				-d target/versions/${release} \
+				-encoding ${JAVA_ENCODING} \
+				-classpath "${modulepath}:${JAVA_INTERMEDIATE_JAR_NAME}.jar" \
+				--module-path "${modulepath}:${JAVA_INTERMEDIATE_JAR_NAME}.jar" \
+				--module-version ${PV} \
+				--patch-module "${JAVA_INTERMEDIATE_JAR_NAME}"="${JAVA_INTERMEDIATE_JAR_NAME}.jar" \
+				${JAVAC_ARGS} $(find ${reldir} -type f -name '*.java')
+
+			JAVA_GENTOO_CLASSPATH_EXTRA+=":target/versions/${release}"
+		done
+
+		JAVA_PKG_WANT_SOURCE=${tmp_source}
+		JAVA_PKG_WANT_TARGET=${tmp_target}
+	else
+		# gather sources
+		# if target < 9, we need to compile module-info.java separately
+		# as this feature is not supported before Java 9
+		local target="$(java-pkg_get-target)"
+		if [[ ${target#1.} -lt 9 ]]; then
+			find "${JAVA_SRC_DIR[@]}" -name \*.java ! -name module-info.java > ${sources}
 		else
-			eqawarn "Need at least JDK 9 to compile module-info.java in src_compile."
-			eqawarn "Please adjust DEPEND accordingly. See https://bugs.gentoo.org/796875#c3"
+			find "${JAVA_SRC_DIR[@]}" -name \*.java > ${sources}
+		fi
+		moduleinfo=$(find "${JAVA_SRC_DIR[@]}" -name module-info.java)
+
+		# create the target directory
+		mkdir -p ${classes} || die "Could not create target directory"
+
+		# compile
+		local classpath=""
+		java-pkg-simple_getclasspath
+		java-pkg-simple_prepend_resources ${classes} "${JAVA_RESOURCE_DIRS[@]}"
+
+		if [[ -z ${moduleinfo} ]] || [[ ${target#1.} -lt 9 ]]; then
+			ejavac -d ${classes} -encoding ${JAVA_ENCODING}\
+				${classpath:+-classpath ${classpath}} ${JAVAC_ARGS} @${sources}
+		else
+			ejavac -d ${classes} -encoding ${JAVA_ENCODING}\
+				${classpath:+--module-path ${classpath}} --module-version ${PV}\
+				${JAVAC_ARGS} @${sources}
+		fi
+
+		# handle module-info.java separately as it needs at least JDK 9
+		if [[ -n ${moduleinfo} ]] && [[ ${target#1.} -lt 9 ]]; then
+			if java-pkg_is-vm-version-ge "9" ; then
+				local tmp_source=${JAVA_PKG_WANT_SOURCE} tmp_target=${JAVA_PKG_WANT_TARGET}
+
+				JAVA_PKG_WANT_SOURCE="9"
+				JAVA_PKG_WANT_TARGET="9"
+				ejavac -d ${classes} -encoding ${JAVA_ENCODING}\
+					${classpath:+--module-path ${classpath}} --module-version ${PV}\
+					${JAVAC_ARGS} "${moduleinfo}"
+
+				JAVA_PKG_WANT_SOURCE=${tmp_source}
+				JAVA_PKG_WANT_TARGET=${tmp_target}
+			else
+				eqawarn "Need at least JDK 9 to compile module-info.java in src_compile."
+				eqawarn "Please adjust DEPEND accordingly. See https://bugs.gentoo.org/796875#c3"
+			fi
 		fi
 	fi
 
@@ -442,14 +681,29 @@ java-pkg-simple_src_compile() {
 	fi
 
 	# package
-	local jar_args
+	local jar_args multi_release=""
+	if [[ -n ${JAVA_RELEASE_SRC_DIRS[@]} ]]; then
+		# Preparing the multi_release variable. From multi-release compilation
+		# the release-specific classes are sorted in target/versions/${release}
+		# directories.
+
+		# TODO:
+		# Could this possibly be simplified with printf?
+		pushd target/versions > /dev/null || die
+			for version in $(ls -d * | sort -g); do
+				debug-print "Version is ${version}"
+				multi_release="${multi_release} --release ${version} -C target/versions/${version} . "
+			done
+		popd > /dev/null || die
+	fi
+
 	if [[ -e ${classes}/META-INF/MANIFEST.MF ]]; then
 		sed '/Created-By: /Id' -i ${classes}/META-INF/MANIFEST.MF
 		jar_args="cfm ${JAVA_JAR_FILENAME} ${classes}/META-INF/MANIFEST.MF"
 	else
 		jar_args="cf ${JAVA_JAR_FILENAME}"
 	fi
-	jar ${jar_args} -C ${classes} . || die "jar failed"
+	jar ${jar_args} -C ${classes} . ${multi_release} || die "jar failed"
 	if  [[ -n "${JAVA_AUTOMATIC_MODULE_NAME}" ]]; then
 		echo "Automatic-Module-Name: ${JAVA_AUTOMATIC_MODULE_NAME}" \
 			>> "${T}/add-to-MANIFEST.MF" || die "adding module name failed"
@@ -463,6 +717,11 @@ java-pkg-simple_src_compile() {
 			|| die "updating MANIFEST.MF failed"
 		rm -f "${T}/add-to-MANIFEST.MF" || die "cannot remove"
 	fi
+
+	unset JAVA_INTERMEDIATE_JAR_NAME
+	unset JAVA_MODULE_INFO_OUT
+	unset JAVA_MODULE_INFO_RELEASE
+	unset JAVA_RELEASE_SRC_DIRS
 }
 
 # @FUNCTION: java-pkg-simple_src_install
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-02  7:06 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-04-02  7:06 UTC (permalink / raw
  To: gentoo-commits
commit:     c68108e4e7f72b6fe6254caf426929610e188f91
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Mon Mar 24 06:41:08 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Wed Apr  2 07:06:13 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=c68108e4
distutils-r1.eclass: Use unique setuptools build directories
Add a dynamic component to the build directory used by setuptools,
to enable calling distutils-r1_python_compile multiple times without
having the builds share the same build directory (and therefore end up
being combined).
Closes: https://bugs.gentoo.org/951853
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/distutils-r1.eclass | 6 +++++-
 1 file changed, 5 insertions(+), 1 deletion(-)
diff --git a/eclass/distutils-r1.eclass b/eclass/distutils-r1.eclass
index 27f2dcebc9f9..3e432101968a 100644
--- a/eclass/distutils-r1.eclass
+++ b/eclass/distutils-r1.eclass
@@ -1490,11 +1490,15 @@ distutils-r1_python_compile() {
 		*)
 			# we do this for all build systems, since other backends
 			# and custom hooks may wrap setuptools
+			#
+			# we are appending a dynamic component so that
+			# distutils-r1_python_compile can be called multiple
+			# times and don't end up combining resulting packages
 			mkdir -p "${BUILD_DIR}" || die
 			local -x DIST_EXTRA_CONFIG="${BUILD_DIR}/extra-setup.cfg"
 			cat > "${DIST_EXTRA_CONFIG}" <<-EOF || die
 				[build]
-				build_base = ${BUILD_DIR}/build
+				build_base = ${BUILD_DIR}/build${#DISTUTILS_WHEELS[@]}
 
 				[build_ext]
 				parallel = $(makeopts_jobs "${MAKEOPTS} ${*}")
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-02  7:06 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-04-02  7:06 UTC (permalink / raw
  To: gentoo-commits
commit:     11a288e9c2e243584423b2b5f62d7286fe62d718
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sun Mar 23 19:01:29 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Wed Apr  2 07:06:12 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=11a288e9
distutils-r1.eclass: Support the legacy "uv" backend too
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/distutils-r1.eclass | 5 ++++-
 1 file changed, 4 insertions(+), 1 deletion(-)
diff --git a/eclass/distutils-r1.eclass b/eclass/distutils-r1.eclass
index bbcd0b15b262..27f2dcebc9f9 100644
--- a/eclass/distutils-r1.eclass
+++ b/eclass/distutils-r1.eclass
@@ -1111,7 +1111,7 @@ _distutils-r1_backend_to_key() {
 		sipbuild.api)
 			echo sip
 			;;
-		uv_build)
+		uv_build|uv)
 			echo uv-build
 			;;
 		*)
@@ -1173,6 +1173,9 @@ _distutils-r1_get_backend() {
 				[[ ! ${legacy_fallback} ]] &&
 					new_backend=setuptools.build_meta
 				;;
+			uv)
+				new_backend=uv_build
+				;;
 		esac
 
 		if [[ -n ${new_backend} ]]; then
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-02  7:06 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-04-02  7:06 UTC (permalink / raw
  To: gentoo-commits
commit:     63092f0441a5516ebdc05c1648cc9d172d2263a7
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Mon Mar 24 10:36:48 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Wed Apr  2 07:06:15 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=63092f04
distutils-r1.eclass: Support overriding PEP517 build backend
Add a DISTUTILS_UPSTREAM_PEP517 variable that drives the build backend
check, and can be used to override it when it is desirable to override
the backend used.
Closes: https://bugs.gentoo.org/951944
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/distutils-r1.eclass | 30 ++++++++++++++++++++++--------
 1 file changed, 22 insertions(+), 8 deletions(-)
diff --git a/eclass/distutils-r1.eclass b/eclass/distutils-r1.eclass
index a313b94c3a0d..ad2eeb8dcd41 100644
--- a/eclass/distutils-r1.eclass
+++ b/eclass/distutils-r1.eclass
@@ -153,6 +153,20 @@
 # files are found in ${BUILD_DIR}/install after python_install(), they
 # will be merged into ${D}.
 
+# @ECLASS_VARIABLE: DISTUTILS_UPSTREAM_PEP517
+# @DESCRIPTION:
+# Specifies the PEP517 build backend used upstream.  It is used
+# by the eclass to verify the correctness of DISTUTILS_USE_PEP517,
+# and matches DISTUTILS_USE_PEP517 by default.  However, it can be
+# overriden to workaround the eclass check, when it is desirable
+# to build the wheel using other backend than the one used upstream.
+#
+# Please note that even in packages using PEP621 metadata, there can
+# be subtle differences between the behavior of different PEP517 build
+# backends, for example regarding finding package files.  When using
+# this option, please make sure that the package is installed correctly.
+: "${DISTUTILS_UPSTREAM_PEP517:=${DISTUTILS_USE_PEP517}}"
+
 # @ECLASS_VARIABLE: DISTUTILS_USE_SETUPTOOLS
 # @DEFAULT_UNSET
 # @PRE_INHERIT
@@ -1149,9 +1163,9 @@ _distutils-r1_get_backend() {
 		return
 	fi
 
-	# get the preferred backend from the eclass
-	local backend_to_use=$(_distutils-r1_key_to_backend "${DISTUTILS_USE_PEP517}")
-	if [[ ${backend_to_use} != ${build_backend} ]]; then
+	# verify that the ebuild correctly specifies the build backend
+	local expected_backend=$(_distutils-r1_key_to_backend "${DISTUTILS_UPSTREAM_PEP517}")
+	if [[ ${expected_backend} != ${build_backend} ]]; then
 		# special-case deprecated backends
 		case ${build_backend} in
 			flit.buildapi)
@@ -1165,9 +1179,9 @@ _distutils-r1_get_backend() {
 			uv)
 				;;
 			*)
-				eerror "DISTUTILS_USE_PEP517 does not match pyproject.toml!"
-				eerror "  DISTUTILS_USE_PEP517=${DISTUTILS_USE_PEP517}"
-				eerror "  implies backend: ${backend_to_use}"
+				eerror "DISTUTILS_UPSTREAM_PEP517 does not match pyproject.toml!"
+				eerror "  DISTUTILS_UPSTREAM_PEP517=${DISTUTILS_USE_PEP517}"
+				eerror "  implies backend: ${expected_backend}"
 				eerror "   pyproject.toml: ${build_backend}"
 				die "DISTUTILS_USE_PEP517 value incorrect"
 		esac
@@ -1176,12 +1190,12 @@ _distutils-r1_get_backend() {
 		if [[ ! -f ${T}/.distutils_deprecated_backend_warned ]]; then
 			eqawarn "${build_backend} backend is deprecated.  Please see:"
 			eqawarn "https://projects.gentoo.org/python/guide/qawarn.html#deprecated-pep-517-backends"
-			eqawarn "The eclass will be using ${backend_to_use} instead."
+			eqawarn "The project should use ${expected_backend} instead."
 			> "${T}"/.distutils_deprecated_backend_warned || die
 		fi
 	fi
 
-	echo "${backend_to_use}"
+	echo "$(_distutils-r1_key_to_backend "${DISTUTILS_USE_PEP517}")"
 }
 
 # @FUNCTION: distutils_wheel_install
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-02  7:06 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-04-02  7:06 UTC (permalink / raw
  To: gentoo-commits
commit:     455723727afbadc6212338c01f06e395dbbc7516
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Mon Mar 24 11:44:58 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Wed Apr  2 07:06:15 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=45572372
distutils-r1.eclass: Invert DISTUTILS_USE_PEP517 - backend mapping
Invert the eclass logic to map DISTUTILS_USE_PEP517 values to backends
rather than the other way around.  This is in preparation for making
it possible to override the backend used.  One side effect of this
is that in case of DISTUTILS_USE_PEP517 mismatch, we no longer provide
the "correct" value, and only indicate the backend used upstream.
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/distutils-r1.eclass | 122 +++++++++++++++++++++------------------------
 1 file changed, 56 insertions(+), 66 deletions(-)
diff --git a/eclass/distutils-r1.eclass b/eclass/distutils-r1.eclass
index 018c468f2065..a313b94c3a0d 100644
--- a/eclass/distutils-r1.eclass
+++ b/eclass/distutils-r1.eclass
@@ -1064,58 +1064,57 @@ _distutils-r1_copy_egg_info() {
 	find -name '*.egg-info' -type d -exec cp -R -p {} "${BUILD_DIR}"/ ';' || die
 }
 
-# @FUNCTION: _distutils-r1_backend_to_key
-# @USAGE: <backend>
+# @FUNCTION: _distutils-r1_key_to_backend
+# @USAGE: <key>
 # @INTERNAL
 # @DESCRIPTION:
-# Print the DISTUTILS_USE_PEP517 value corresponding to the backend
-# passed as the only argument.
-_distutils-r1_backend_to_key() {
+# Print the backend corresponding to the DISTUTILS_USE_PEP517 value.
+_distutils-r1_key_to_backend() {
 	debug-print-function ${FUNCNAME} "$@"
 
-	local backend=${1}
-	case ${backend} in
-		flit_core.buildapi|flit.buildapi)
-			echo flit
+	local key=${1}
+	case ${key} in
+		flit)
+			echo flit_core.buildapi
 			;;
-		flit_scm:buildapi)
-			echo flit_scm
+		flit_scm)
+			echo flit_scm:buildapi
 			;;
-		hatchling.build)
-			echo hatchling
+		hatchling)
+			echo hatchling.build
 			;;
-		jupyter_packaging.build_api)
-			echo jupyter
+		jupyter)
+			echo jupyter_packaging.build_api
 			;;
 		maturin)
 			echo maturin
 			;;
-		mesonpy)
-			echo meson-python
+		meson-python)
+			echo mesonpy
 			;;
-		pbr.build)
-			echo pbr
+		pbr)
+			echo pbr.build
 			;;
-		pdm.backend|pdm.pep517.api)
-			echo pdm-backend
+		pdm-backend)
+			echo pdm.backend
 			;;
-		poetry.core.masonry.api|poetry.masonry.api)
-			echo poetry
+		poetry)
+			echo poetry.core.masonry.api
 			;;
-		scikit_build_core.build)
-			echo scikit-build-core
+		scikit-build-core)
+			echo scikit_build_core.build
 			;;
-		setuptools.build_meta|setuptools.build_meta:__legacy__)
-			echo setuptools
+		setuptools)
+			echo setuptools.build_meta
 			;;
-		sipbuild.api)
-			echo sip
+		sip)
+			echo sipbuild.api
 			;;
-		uv_build|uv)
-			echo uv-build
+		uv-build)
+			echo uv_build
 			;;
 		*)
-			die "Unknown backend: ${backend}"
+			die "Unknown DISTUTILS_USE_PEP517 key: ${key}"
 			;;
 	esac
 }
@@ -1150,48 +1149,39 @@ _distutils-r1_get_backend() {
 		return
 	fi
 
-	# verify whether DISTUTILS_USE_PEP517 was set correctly
-	local expected_value=$(_distutils-r1_backend_to_key "${build_backend}")
-	if [[ ${DISTUTILS_USE_PEP517} != ${expected_value} ]]; then
-		eerror "DISTUTILS_USE_PEP517 does not match pyproject.toml!"
-		eerror "    have: DISTUTILS_USE_PEP517=${DISTUTILS_USE_PEP517}"
-		eerror "expected: DISTUTILS_USE_PEP517=${expected_value}"
-		eerror "(backend: ${build_backend})"
-		die "DISTUTILS_USE_PEP517 value incorrect"
-	fi
-
-	# fix deprecated backends up
-	local new_backend=
-	case ${build_backend} in
-		flit.buildapi)
-			new_backend=flit_core.buildapi
-			;;
-		pdm.pep517.api)
-			new_backend=pdm.backend
-			;;
-		poetry.masonry.api)
-			new_backend=poetry.core.masonry.api
-			;;
-		setuptools.build_meta:__legacy__)
-			# this backend should only be used as implicit fallback
-			new_backend=setuptools.build_meta
-			;;
-		uv)
-			new_backend=uv_build
-			;;
-	esac
+	# get the preferred backend from the eclass
+	local backend_to_use=$(_distutils-r1_key_to_backend "${DISTUTILS_USE_PEP517}")
+	if [[ ${backend_to_use} != ${build_backend} ]]; then
+		# special-case deprecated backends
+		case ${build_backend} in
+			flit.buildapi)
+				;;
+			pdm.pep517.api)
+				;;
+			poetry.masonry.api)
+				;;
+			setuptools.build_meta:__legacy__)
+				;;
+			uv)
+				;;
+			*)
+				eerror "DISTUTILS_USE_PEP517 does not match pyproject.toml!"
+				eerror "  DISTUTILS_USE_PEP517=${DISTUTILS_USE_PEP517}"
+				eerror "  implies backend: ${backend_to_use}"
+				eerror "   pyproject.toml: ${build_backend}"
+				die "DISTUTILS_USE_PEP517 value incorrect"
+		esac
 
-	if [[ -n ${new_backend} ]]; then
+		# if we didn't die, we're dealing with a deprecated backend
 		if [[ ! -f ${T}/.distutils_deprecated_backend_warned ]]; then
 			eqawarn "${build_backend} backend is deprecated.  Please see:"
 			eqawarn "https://projects.gentoo.org/python/guide/qawarn.html#deprecated-pep-517-backends"
-			eqawarn "The eclass will be using ${new_backend} instead."
+			eqawarn "The eclass will be using ${backend_to_use} instead."
 			> "${T}"/.distutils_deprecated_backend_warned || die
 		fi
-		build_backend=${new_backend}
 	fi
 
-	echo "${build_backend}"
+	echo "${backend_to_use}"
 }
 
 # @FUNCTION: distutils_wheel_install
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-02  7:06 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-04-02  7:06 UTC (permalink / raw
  To: gentoo-commits
commit:     a39b02289c9eee449378334792f75dc065409a0a
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Mon Mar 24 11:39:56 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Wed Apr  2 07:06:14 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=a39b0228
distutils-r1.eclass: Reflow _distutils-r1_backend_to_key()
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/distutils-r1.eclass | 100 +++++++++++++++++++++++----------------------
 1 file changed, 51 insertions(+), 49 deletions(-)
diff --git a/eclass/distutils-r1.eclass b/eclass/distutils-r1.eclass
index 3e432101968a..018c468f2065 100644
--- a/eclass/distutils-r1.eclass
+++ b/eclass/distutils-r1.eclass
@@ -1128,65 +1128,67 @@ _distutils-r1_backend_to_key() {
 _distutils-r1_get_backend() {
 	debug-print-function ${FUNCNAME} "$@"
 
-	local build_backend legacy_fallback
+	local build_backend
 	if [[ -f pyproject.toml ]]; then
 		# if pyproject.toml exists, try getting the backend from it
 		# NB: this could fail if pyproject.toml doesn't list one
 		build_backend=$("${EPYTHON}" -m gpep517 get-backend)
 	fi
-	if [[ -z ${build_backend} && ${DISTUTILS_USE_PEP517} == setuptools &&
-		-f setup.py ]]
-	then
-		# use the legacy setuptools backend as a fallback
-		build_backend=setuptools.build_meta:__legacy__
-		legacy_fallback=1
-	fi
 	if [[ -z ${build_backend} ]]; then
-		die "Unable to obtain build-backend from pyproject.toml"
-	fi
-
-	if [[ ${DISTUTILS_USE_PEP517} != standalone ]]; then
-		# verify whether DISTUTILS_USE_PEP517 was set correctly
-		local expected_value=$(_distutils-r1_backend_to_key "${build_backend}")
-		if [[ ${DISTUTILS_USE_PEP517} != ${expected_value} ]]; then
-			eerror "DISTUTILS_USE_PEP517 does not match pyproject.toml!"
-			eerror "    have: DISTUTILS_USE_PEP517=${DISTUTILS_USE_PEP517}"
-			eerror "expected: DISTUTILS_USE_PEP517=${expected_value}"
-			eerror "(backend: ${build_backend})"
-			die "DISTUTILS_USE_PEP517 value incorrect"
+		if [[ ${DISTUTILS_USE_PEP517} == setuptools && -f setup.py ]]
+		then
+			# use the legacy setuptools backend as a fallback
+			echo setuptools.build_meta:__legacy__
+			return
+		else
+			die "Unable to obtain build-backend from pyproject.toml"
 		fi
+	fi
 
-		# fix deprecated backends up
-		local new_backend=
-		case ${build_backend} in
-			flit.buildapi)
-				new_backend=flit_core.buildapi
-				;;
-			pdm.pep517.api)
-				new_backend=pdm.backend
-				;;
-			poetry.masonry.api)
-				new_backend=poetry.core.masonry.api
-				;;
-			setuptools.build_meta:__legacy__)
-				# this backend should only be used as implicit fallback
-				[[ ! ${legacy_fallback} ]] &&
-					new_backend=setuptools.build_meta
-				;;
-			uv)
-				new_backend=uv_build
-				;;
-		esac
+	if [[ ${DISTUTILS_USE_PEP517} == standalone ]]; then
+		echo "${build_backend}"
+		return
+	fi
 
-		if [[ -n ${new_backend} ]]; then
-			if [[ ! -f ${T}/.distutils_deprecated_backend_warned ]]; then
-				eqawarn "${build_backend} backend is deprecated.  Please see:"
-				eqawarn "https://projects.gentoo.org/python/guide/qawarn.html#deprecated-pep-517-backends"
-				eqawarn "The eclass will be using ${new_backend} instead."
-				> "${T}"/.distutils_deprecated_backend_warned || die
-			fi
-			build_backend=${new_backend}
+	# verify whether DISTUTILS_USE_PEP517 was set correctly
+	local expected_value=$(_distutils-r1_backend_to_key "${build_backend}")
+	if [[ ${DISTUTILS_USE_PEP517} != ${expected_value} ]]; then
+		eerror "DISTUTILS_USE_PEP517 does not match pyproject.toml!"
+		eerror "    have: DISTUTILS_USE_PEP517=${DISTUTILS_USE_PEP517}"
+		eerror "expected: DISTUTILS_USE_PEP517=${expected_value}"
+		eerror "(backend: ${build_backend})"
+		die "DISTUTILS_USE_PEP517 value incorrect"
+	fi
+
+	# fix deprecated backends up
+	local new_backend=
+	case ${build_backend} in
+		flit.buildapi)
+			new_backend=flit_core.buildapi
+			;;
+		pdm.pep517.api)
+			new_backend=pdm.backend
+			;;
+		poetry.masonry.api)
+			new_backend=poetry.core.masonry.api
+			;;
+		setuptools.build_meta:__legacy__)
+			# this backend should only be used as implicit fallback
+			new_backend=setuptools.build_meta
+			;;
+		uv)
+			new_backend=uv_build
+			;;
+	esac
+
+	if [[ -n ${new_backend} ]]; then
+		if [[ ! -f ${T}/.distutils_deprecated_backend_warned ]]; then
+			eqawarn "${build_backend} backend is deprecated.  Please see:"
+			eqawarn "https://projects.gentoo.org/python/guide/qawarn.html#deprecated-pep-517-backends"
+			eqawarn "The eclass will be using ${new_backend} instead."
+			> "${T}"/.distutils_deprecated_backend_warned || die
 		fi
+		build_backend=${new_backend}
 	fi
 
 	echo "${build_backend}"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-02  7:06 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-04-02  7:06 UTC (permalink / raw
  To: gentoo-commits
commit:     77bfc6a1cdc89204c0f2daa1544ee5f402195de7
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Mar 22 16:26:56 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Wed Apr  2 07:06:11 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=77bfc6a1
distutils-r1.eclass: Support uv-build backend
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/distutils-r1.eclass | 16 ++++++++++++++++
 1 file changed, 16 insertions(+)
diff --git a/eclass/distutils-r1.eclass b/eclass/distutils-r1.eclass
index 98e9dfb50985..bbcd0b15b262 100644
--- a/eclass/distutils-r1.eclass
+++ b/eclass/distutils-r1.eclass
@@ -137,6 +137,8 @@
 # - standalone - standalone build systems without external deps
 #   (used for bootstrapping).
 #
+# - uv-build - uv-build backend (using dev-python/uv)
+#
 # The variable needs to be set before the inherit line.  The eclass
 # adds appropriate build-time dependencies and verifies the value.
 #
@@ -316,6 +318,11 @@ _distutils_set_globals() {
 				;;
 			standalone)
 				;;
+			uv-build)
+				bdep+='
+					dev-python/uv-build[${PYTHON_USEDEP}]
+				'
+				;;
 			*)
 				die "Unknown DISTUTILS_USE_PEP517=${DISTUTILS_USE_PEP517}"
 				;;
@@ -905,6 +912,12 @@ _distutils-r1_print_package_versions() {
 					dev-python/sip
 				)
 				;;
+			uv-build)
+				packages+=(
+					dev-python/uv
+					dev-python/uv-build
+				)
+				;;
 		esac
 	else
 		case ${DISTUTILS_USE_SETUPTOOLS} in
@@ -1098,6 +1111,9 @@ _distutils-r1_backend_to_key() {
 		sipbuild.api)
 			echo sip
 			;;
+		uv_build)
+			echo uv-build
+			;;
 		*)
 			die "Unknown backend: ${backend}"
 			;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-02  7:06 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-04-02  7:06 UTC (permalink / raw
  To: gentoo-commits
commit:     e86bf6625871b1ab930ab78be38f114e5e172cd3
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Mon Mar 24 10:30:48 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Wed Apr  2 07:06:17 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=e86bf662
distutils-r1.eclass: Reflow distutils-r1_python_compile()
Reflow distutils-r1_python_compile() to remove duplicate conditions
and improve readability.
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/distutils-r1.eclass | 117 ++++++++++++++++++++++-----------------------
 1 file changed, 56 insertions(+), 61 deletions(-)
diff --git a/eclass/distutils-r1.eclass b/eclass/distutils-r1.eclass
index ad2eeb8dcd41..42e47a5b3028 100644
--- a/eclass/distutils-r1.eclass
+++ b/eclass/distutils-r1.eclass
@@ -1484,71 +1484,66 @@ distutils-r1_python_compile() {
 
 	_python_check_EPYTHON
 
-	case ${DISTUTILS_USE_PEP517:-unset} in
-		no)
-			return
-			;;
-		unset)
-			# legacy mode
-			_distutils-r1_copy_egg_info
-			esetup.py build -j "$(makeopts_jobs "${MAKEOPTS} ${*}")" "${@}"
-			;;
-		*)
-			# we do this for all build systems, since other backends
-			# and custom hooks may wrap setuptools
-			#
-			# we are appending a dynamic component so that
-			# distutils-r1_python_compile can be called multiple
-			# times and don't end up combining resulting packages
-			mkdir -p "${BUILD_DIR}" || die
-			local -x DIST_EXTRA_CONFIG="${BUILD_DIR}/extra-setup.cfg"
-			cat > "${DIST_EXTRA_CONFIG}" <<-EOF || die
-				[build]
-				build_base = ${BUILD_DIR}/build${#DISTUTILS_WHEELS[@]}
-
-				[build_ext]
-				parallel = $(makeopts_jobs "${MAKEOPTS} ${*}")
-			EOF
-			;;
-	esac
+	[[ ${DISTUTILS_USE_PEP517} == no ]] && return
 
-	if [[ ${DISTUTILS_USE_PEP517} ]]; then
-		if [[ ${DISTUTILS_ALLOW_WHEEL_REUSE} ]]; then
-			local whl
-			for whl in "${!DISTUTILS_WHEELS[@]}"; do
-				# use only wheels corresponding to the current directory
-				if [[ ${PWD} != ${DISTUTILS_WHEELS["${whl}"]} ]]; then
-					continue
-				fi
+	if [[ ! ${DISTUTILS_USE_PEP517} ]]; then
+		# legacy mode
+		_distutils-r1_copy_egg_info
+		esetup.py build -j "$(makeopts_jobs "${MAKEOPTS} ${*}")" "${@}"
+		return
+	fi
 
-				# 1. Use pure Python wheels only if we're not expected
-				# to build extensions.  Otherwise, we may end up
-				# not building the extension at all when e.g. PyPy3
-				# is built without one.
-				#
-				# 2. For CPython, we can reuse stable ABI wheels.  Note
-				# that this relies on the assumption that we're building
-				# from the oldest to the newest implementation,
-				# and the wheels are forward-compatible.
-				if [[
-					( ! ${DISTUTILS_EXT} && ${whl} == *py3-none-any* ) ||
-					(
-						${EPYTHON} == python* &&
-						# freethreading does not support stable ABI
-						# at the moment
-						${EPYTHON} != *t &&
-						${whl} == *-abi3-*
-					)
-				]]; then
-					distutils_wheel_install "${BUILD_DIR}/install" "${whl}"
-					return
-				fi
-			done
-		fi
+	# we do this for all build systems, since other backends
+	# and custom hooks may wrap setuptools
+	#
+	# we are appending a dynamic component so that
+	# distutils-r1_python_compile can be called multiple
+	# times and don't end up combining resulting packages
+	mkdir -p "${BUILD_DIR}" || die
+	local -x DIST_EXTRA_CONFIG="${BUILD_DIR}/extra-setup.cfg"
+	cat > "${DIST_EXTRA_CONFIG}" <<-EOF || die
+		[build]
+		build_base = ${BUILD_DIR}/build${#DISTUTILS_WHEELS[@]}
+
+		[build_ext]
+		parallel = $(makeopts_jobs "${MAKEOPTS} ${*}")
+	EOF
+
+	if [[ ${DISTUTILS_ALLOW_WHEEL_REUSE} ]]; then
+		local whl
+		for whl in "${!DISTUTILS_WHEELS[@]}"; do
+			# use only wheels corresponding to the current directory
+			if [[ ${PWD} != ${DISTUTILS_WHEELS["${whl}"]} ]]; then
+				continue
+			fi
 
-		distutils_pep517_install "${BUILD_DIR}/install"
-		DISTUTILS_WHEELS+=( "${DISTUTILS_WHEEL_PATH}" "${PWD}" )
+			# 1. Use pure Python wheels only if we're not expected
+			# to build extensions.  Otherwise, we may end up
+			# not building the extension at all when e.g. PyPy3
+			# is built without one.
+			#
+			# 2. For CPython, we can reuse stable ABI wheels.  Note
+			# that this relies on the assumption that we're building
+			# from the oldest to the newest implementation,
+			# and the wheels are forward-compatible.
+			if [[
+				( ! ${DISTUTILS_EXT} && ${whl} == *py3-none-any* ) ||
+				(
+					${EPYTHON} == python* &&
+					# freethreading does not support stable ABI
+					# at the moment
+					${EPYTHON} != *t &&
+					${whl} == *-abi3-*
+				)
+			]]; then
+				distutils_wheel_install "${BUILD_DIR}/install" "${whl}"
+				return
+			fi
+		done
 	fi
+
+	distutils_pep517_install "${BUILD_DIR}/install"
+	DISTUTILS_WHEELS+=( "${DISTUTILS_WHEEL_PATH}" "${PWD}" )
 }
 
 # @FUNCTION: _distutils-r1_wrap_scripts
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-02  7:06 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-04-02  7:06 UTC (permalink / raw
  To: gentoo-commits
commit:     67f008f6acc086e0a58dfebd1b019bcdad73620a
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Wed Mar 26 11:32:32 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Wed Apr  2 07:06:18 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=67f008f6
distutils-r1.eclass: Add a safety check for wheel install done
Add a safety check to verify that distutils_wheel_install is being
(usually indirectly) called in python_compile(), when using PEP517
build.  If it weren't, this usually indicates that
distutils-r1_python_compile (or distutils_pep517_install) was not
called.
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
Closes: https://github.com/gentoo/gentoo/pull/41222
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/distutils-r1.eclass | 7 +++++++
 1 file changed, 7 insertions(+)
diff --git a/eclass/distutils-r1.eclass b/eclass/distutils-r1.eclass
index 42e47a5b3028..e1672dd3c3b0 100644
--- a/eclass/distutils-r1.eclass
+++ b/eclass/distutils-r1.eclass
@@ -1246,6 +1246,8 @@ distutils_wheel_install() {
 		-o -path '*.dist-info/licenses' \
 		-o -path '*.dist-info/zip-safe' \
 		\) -delete || die
+
+	_DISTUTILS_WHL_INSTALLED=1
 }
 
 # @VARIABLE: DISTUTILS_WHEEL_PATH
@@ -2011,6 +2013,11 @@ _distutils-r1_compare_installed_files() {
 _distutils-r1_post_python_compile() {
 	debug-print-function ${FUNCNAME} "$@"
 
+	if [[ ! ${_DISTUTILS_WHL_INSTALLED} && ${DISTUTILS_USE_PEP517:-no} != no ]]
+	then
+		die "No wheel installed in python_compile(), did you call distutils-r1_python_compile?"
+	fi
+
 	local root=${BUILD_DIR}/install
 	if [[ ${DISTUTILS_USE_PEP517} && -d ${root} ]]; then
 		# copy executables to python-exec directory
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-04 17:08 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-04-04 17:08 UTC (permalink / raw
  To: gentoo-commits
commit:     8c2aba680ad0a767829c1133189792081671f54d
Author:     Eli Schwartz <eschwartz <AT> gentoo <DOT> org>
AuthorDate: Fri Apr  4 15:50:38 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Apr  4 17:08:32 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=8c2aba68
cargo.eclass: fix live unpack to use selected cargo
Eveywhere, we use ${CARGO} as set by the rust toolchain setup, except
one place. This caused issues such as erroring out in at least one
reported case with "cargo: command not found" (when using --root,
apparently). It would also certainly not respect RUST_MIN_VER /
RUST_MAX_VER.
Ensure we consistently use the variable referencing the $CARGO that is
definitely guaranteed to exist.
Signed-off-by: Eli Schwartz <eschwartz <AT> gentoo.org>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/cargo.eclass | 8 ++++----
 1 file changed, 4 insertions(+), 4 deletions(-)
diff --git a/eclass/cargo.eclass b/eclass/cargo.eclass
index 95d485ab20c3..d93ae1723470 100644
--- a/eclass/cargo.eclass
+++ b/eclass/cargo.eclass
@@ -603,12 +603,12 @@ cargo_live_src_unpack() {
 	export CARGO_HOME="${ECARGO_REGISTRY_DIR}"
 
 	# Absence of quotes around offline arg is intentional, as cargo bails out if it encounters ''
-	einfo "cargo fetch ${offline:+--offline}"
-	cargo fetch ${offline:+--offline} || die #nowarn
+	einfo "${CARGO} fetch ${offline:+--offline}"
+	"${CARGO}" fetch ${offline:+--offline} || die #nowarn
 
 	# Let cargo copy all required crates to "${WORKDIR}" for offline use in later phases.
-	einfo "cargo vendor ${offline:+--offline} ${ECARGO_VENDOR}"
-	cargo vendor ${offline:+--offline} "${ECARGO_VENDOR}" || die #nowarn
+	einfo "${CARGO} vendor ${offline:+--offline} ${ECARGO_VENDOR}"
+	"${CARGO}" vendor ${offline:+--offline} "${ECARGO_VENDOR}" || die #nowarn
 
 	# Users may have git checkouts made by cargo.
 	# While cargo vendors the sources, it still needs git checkout to be present.
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-05 12:24 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-04-05 12:24 UTC (permalink / raw
  To: gentoo-commits
commit:     dcd65bb64fe0c4000bc7d852362cd5748a222f71
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Apr  5 10:51:21 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat Apr  5 12:23:40 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=dcd65bb6
Add 21.0.0_pre20250405 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index 7f0b26b734d1..16802e37cd66 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -72,6 +72,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 			_LLVM_SOURCE_TYPE=snapshot
 
 			case ${PV} in
+				21.0.0_pre20250405)
+					EGIT_COMMIT=f3e6473df46fd920e09e06e57a5549eb8e3a8bd3
+					;;
 				21.0.0_pre20250329)
 					EGIT_COMMIT=21eeca3db0341fef4ab4a6464ffe38b2eba5810c
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-07 20:48 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-04-07 20:48 UTC (permalink / raw
  To: gentoo-commits
commit:     18ad0c1a648cfb97fde0f08f848f0ed75fc4c083
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Apr  7 20:44:57 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Apr  7 20:48:29 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=18ad0c1a
kernel-build.eclass: disable -Werror (for host tools at least)
WERROR=0 disables -Werror for host tools at least, so let's use that. I'll
also send a config change.
Bug: https://bugs.gentoo.org/939106
Bug: https://bugs.gentoo.org/940904
Bug: https://bugs.gentoo.org/942303
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/kernel-build.eclass | 1 +
 1 file changed, 1 insertion(+)
diff --git a/eclass/kernel-build.eclass b/eclass/kernel-build.eclass
index 1d8c396b9590..ee4cf1413a60 100644
--- a/eclass/kernel-build.eclass
+++ b/eclass/kernel-build.eclass
@@ -207,6 +207,7 @@ kernel-build_src_configure() {
 	tc-export_build_env
 	MAKEARGS=(
 		V=1
+		WERROR=0
 
 		HOSTCC="$(tc-getBUILD_CC)"
 		HOSTCXX="$(tc-getBUILD_CXX)"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-10  9:18 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-04-10  9:18 UTC (permalink / raw
  To: gentoo-commits
commit:     4be734dc69b6c3f20f25342be45d9c7d7e16f0cf
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Apr 10 09:17:10 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Apr 10 09:18:26 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=4be734dc
toolchain.eclass: support GDCFLAGS
Bug: https://bugs.gentoo.org/940470
Bug: https://bugs.gentoo.org/940750
Bug: https://gcc.gnu.org/PR116975
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index bf883c5370fc..933292d6ee2a 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -2325,6 +2325,8 @@ gcc_do_make() {
 		STAGE1_CFLAGS=${STAGE1_CFLAGS-"$(get_abi_CFLAGS ${TARGET_DEFAULT_ABI}) ${CFLAGS}"}
 		# multilib.eclass lacks get_abi_CXXFLAGS (bug #940501)
 		STAGE1_CXXFLAGS=${STAGE1_CXXFLAGS-"$(get_abi_CFLAGS ${TARGET_DEFAULT_ABI}) ${CXXFLAGS}"}
+		# Default to CFLAGS for GDCFLAGS if unset
+		STAGE1_GDCFLAGS=${STAGE1_GDCFLAGS-"$(get_abi_CFLAGS ${TARGET_DEFAULT_ABI}) ${CFLAGS}"}
 		STAGE1_LDFLAGS=${STAGE1_LDFLAGS-"${abi_ldflags} ${LDFLAGS}"}
 		BOOT_CFLAGS=${BOOT_CFLAGS-"$(get_abi_CFLAGS ${TARGET_DEFAULT_ABI}) ${CFLAGS}"}
 		BOOT_LDFLAGS=${BOOT_LDFLAGS-"${abi_ldflags} ${LDFLAGS}"}
@@ -2342,6 +2344,7 @@ gcc_do_make() {
 		emakeargs+=(
 			STAGE1_CFLAGS="${STAGE1_CFLAGS}"
 			STAGE1_CXXFLAGS="${STAGE1_CXXFLAGS}"
+			STAGE1_GDCFLAGS="${STAGE1_GDCFLAGS}"
 			STAGE1_LDFLAGS="${STAGE1_LDFLAGS}"
 			BOOT_CFLAGS="${BOOT_CFLAGS}"
 			BOOT_LDFLAGS="${BOOT_LDFLAGS}"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-10  9:28 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-04-10  9:28 UTC (permalink / raw
  To: gentoo-commits
commit:     58fc4051affdec8d2c5560654c1fce8b2fe15b8e
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Apr 10 09:22:41 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Apr 10 09:27:49 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=58fc4051
toolchain.eclass: pass -Wno-array-bounds in STAGE1_GDCFLAGS
Bug: https://bugs.gentoo.org/940750
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 24 ++++++++++++------------
 1 file changed, 12 insertions(+), 12 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 933292d6ee2a..273a2b9f92c9 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -2132,11 +2132,6 @@ gcc_do_filter_flags() {
 		filter-flags -fdiagnostics-set-output=text:experimental-nesting=yes
 	fi
 
-	if is_d ; then
-		# bug #940750
-		filter-flags -Warray-bounds
-	fi
-
 	# Please use USE=lto instead (bug #906007).
 	filter-lto
 
@@ -2332,13 +2327,18 @@ gcc_do_make() {
 		BOOT_LDFLAGS=${BOOT_LDFLAGS-"${abi_ldflags} ${LDFLAGS}"}
 		LDFLAGS_FOR_TARGET="${LDFLAGS_FOR_TARGET:-${LDFLAGS}}"
 
-		# If we need to in future, we could really simplify this
-		# to just be unconditional for stage1. It doesn't really
-		# matter there. If we want to go in the other direction
-		# and make this more conditional, we could check if
-		# the bootstrap compiler is < GCC 12. See bug #940470.
-		if _tc_use_if_iuse d && use hardened ; then
-			STAGE1_CXXFLAGS+=" -U_GLIBCXX_ASSERTIONS"
+		if _tc_use_if_iuse d ; then
+			# If we need to in future, we could really simplify this
+			# to just be unconditional for stage1. It doesn't really
+			# matter there. If we want to go in the other direction
+			# and make this more conditional, we could check if
+			# the bootstrap compiler is < GCC 12. See bug #940470.
+			if use hardened ; then
+				STAGE1_CXXFLAGS+=" -U_GLIBCXX_ASSERTIONS"
+			fi
+
+			# This can be dropped a while after 2025-03-31 (bug #940750).
+			STAGE1_GDCFLAGS+=" -Wno-array-bounds"
 		fi
 
 		emakeargs+=(
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-10 14:23 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-04-10 14:23 UTC (permalink / raw
  To: gentoo-commits
commit:     15a1fcd97f44599319b17b8ef0ddc7137838200c
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Apr 10 14:22:06 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Apr 10 14:22:54 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=15a1fcd9
flag-o-matic.eclass: add GDCFLAGS to all-flag-vars
This means e.g. toolchain.eclass can conveniently print it, but it
also enables a bunch of functions for GDCFLAGS.
Bug: https://bugs.gentoo.org/941680
Acked-by: Andrei Horodniceanu <a.horodniceanu <AT> proton.me>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/flag-o-matic.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/flag-o-matic.eclass b/eclass/flag-o-matic.eclass
index 4765809e9118..85274c91121f 100644
--- a/eclass/flag-o-matic.eclass
+++ b/eclass/flag-o-matic.eclass
@@ -24,7 +24,7 @@ inherit toolchain-funcs
 # @DESCRIPTION:
 # Return all the flag variables that our high level functions operate on.
 all-flag-vars() {
-	echo {ADA,C,CPP,CXX,CCAS,F,FC,LD}FLAGS
+	echo {ADA,C,CPP,CXX,CCAS,F,FC,GDC,LD}FLAGS
 }
 
 # @FUNCTION: setup-allowed-flags
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-12  8:59 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-04-12  8:59 UTC (permalink / raw
  To: gentoo-commits
commit:     e5e7b7ea1ea08813b8fa69c6dd371e591091d8de
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Apr 12 08:57:31 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat Apr 12 08:59:02 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=e5e7b7ea
Add 21.0.0_pre20250412 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index b7ec3a9c484f..a1e22f3203f6 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -72,6 +72,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 			_LLVM_SOURCE_TYPE=snapshot
 
 			case ${PV} in
+				21.0.0_pre20250412)
+					EGIT_COMMIT=fa4ac19f0fc937e30fd7711dad98d0fcdb34f8ba
+					;;
 				21.0.0_pre20250405)
 					EGIT_COMMIT=f3e6473df46fd920e09e06e57a5549eb8e3a8bd3
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-12 16:34 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-04-12 16:34 UTC (permalink / raw
  To: gentoo-commits
commit:     66e18dd329f4728409abced4138562a079b30ccd
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Apr 12 15:43:49 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Apr 12 16:34:09 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=66e18dd3
toolchain-funcs.eclass: update tc-get-cxx-stdlib for C++20
<ciso646> is gone from C++20, so use <version> for >= C++20.
See https://stackoverflow.com/a/31658120.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain-funcs.eclass | 7 ++++++-
 1 file changed, 6 insertions(+), 1 deletion(-)
diff --git a/eclass/toolchain-funcs.eclass b/eclass/toolchain-funcs.eclass
index ae21a18a14c2..baf032bbd4ec 100644
--- a/eclass/toolchain-funcs.eclass
+++ b/eclass/toolchain-funcs.eclass
@@ -1156,7 +1156,12 @@ tc-enables-ssp-all() {
 #
 # If the library is not recognized, the function returns 1.
 tc-get-cxx-stdlib() {
-	local code='#include <ciso646>
+	local code='
+#if __cplusplus >= 202002L
+	#include <version>
+#else
+	#include <ciso646>
+#endif
 
 #if defined(_LIBCPP_VERSION)
 	HAVE_LIBCXX
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-12 16:34 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-04-12 16:34 UTC (permalink / raw
  To: gentoo-commits
commit:     064d419ded17cb95eb12aa9478cad52e906dc6d4
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Apr 12 15:39:41 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Apr 12 16:34:09 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=064d419d
toolchain-funcs.eclass: drop deprecated gen_usr_ldscript and multilib inherit
Drop toolchain-funcs.eclass's gen_usr_ldscript and along with it, inheriting
multilib. gen_usr_ldscript is itself deprecaated but the version in toolchain-funcs
doubly so, as it was replaced by the one in usr-ldscript.eclass.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain-funcs.eclass | 135 ------------------------------------------
 1 file changed, 135 deletions(-)
diff --git a/eclass/toolchain-funcs.eclass b/eclass/toolchain-funcs.eclass
index 754d23f91c06..ae21a18a14c2 100644
--- a/eclass/toolchain-funcs.eclass
+++ b/eclass/toolchain-funcs.eclass
@@ -21,8 +21,6 @@ case ${EAPI} in
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
-inherit multilib
-
 # tc-getPROG <VAR [search vars]> <default> [tuple]
 _tc-getPROG() {
 	local tuple=$1
@@ -1147,139 +1145,6 @@ tc-enables-ssp-all() {
 	tc-cpp-is-true "defined(__SSP_ALL__)" ${CPPFLAGS} ${CFLAGS} ${CXXFLAGS}
 }
 
-
-# @FUNCTION: gen_usr_ldscript
-# @USAGE: [-a] <list of libs to create linker scripts for>
-# @DESCRIPTION:
-# This function is deprecated. Use the version from
-# usr-ldscript.eclass instead.
-gen_usr_ldscript() {
-	ewarn "${FUNCNAME}: Please migrate to usr-ldscript.eclass"
-
-	local lib libdir=$(get_libdir) output_format="" auto=false suffix=$(get_libname)
-
-	tc-is-static-only && return
-	use prefix && return
-
-	# We only care about stuffing / for the native ABI, bug #479448
-	if [[ $(type -t multilib_is_native_abi) == "function" ]] ; then
-		multilib_is_native_abi || return 0
-	fi
-
-	# Eventually we'd like to get rid of this func completely, bug #417451
-	case ${CTARGET:-${CHOST}} in
-		*-darwin*) ;;
-		*-android*) return 0 ;;
-		*linux*) use prefix && return 0 ;;
-		*) return 0 ;;
-	esac
-
-	# Just make sure it exists
-	dodir /usr/${libdir}
-
-	if [[ $1 == "-a" ]] ; then
-		auto=true
-		shift
-		dodir /${libdir}
-	fi
-
-	# OUTPUT_FORMAT gives hints to the linker as to what binary format
-	# is referenced ... makes multilib saner
-	local flags=( ${CFLAGS} ${LDFLAGS} -Wl,--verbose )
-	if $(tc-getLD) --version | grep -q 'GNU gold' ; then
-		# If they're using gold, manually invoke the old bfd, bug #487696
-		local d="${T}/bfd-linker"
-		mkdir -p "${d}"
-		ln -sf $(type -P ${CHOST}-ld.bfd) "${d}"/ld
-		flags+=( -B"${d}" )
-	fi
-	output_format=$($(tc-getCC) "${flags[@]}" 2>&1 | sed -n 's/^OUTPUT_FORMAT("\([^"]*\)",.*/\1/p')
-	[[ -n ${output_format} ]] && output_format="OUTPUT_FORMAT ( ${output_format} )"
-
-	for lib in "$@" ; do
-		local tlib
-		if ${auto} ; then
-			lib="lib${lib}${suffix}"
-		else
-			# Ensure /lib/${lib} exists to avoid dangling scripts/symlinks.
-			# This especially is for AIX where $(get_libname) can return ".a",
-			# so /lib/${lib} might be moved to /usr/lib/${lib} (by accident).
-			[[ -r ${ED}/${libdir}/${lib} ]] || continue
-			#TODO: better die here?
-		fi
-
-		case ${CTARGET:-${CHOST}} in
-		*-darwin*)
-			if ${auto} ; then
-				tlib=$(scanmacho -qF'%S#F' "${ED}"/usr/${libdir}/${lib})
-			else
-				tlib=$(scanmacho -qF'%S#F' "${ED}"/${libdir}/${lib})
-			fi
-			[[ -z ${tlib} ]] && die "unable to read install_name from ${lib}"
-			tlib=${tlib##*/}
-
-			if ${auto} ; then
-				mv "${ED}"/usr/${libdir}/${lib%${suffix}}.*${suffix#.} "${ED}"/${libdir}/ || die
-				# some install_names are funky: they encode a version
-				if [[ ${tlib} != ${lib%${suffix}}.*${suffix#.} ]] ; then
-					mv "${ED}"/usr/${libdir}/${tlib%${suffix}}.*${suffix#.} "${ED}"/${libdir}/ || die
-				fi
-				rm -f "${ED}"/${libdir}/${lib}
-			fi
-
-			# Mach-O files have an id, which is like a soname, it tells how
-			# another object linking against this lib should reference it.
-			# Since we moved the lib from usr/lib into lib this reference is
-			# wrong.  Hence, we update it here.  We don't configure with
-			# libdir=/lib because that messes up libtool files.
-			# Make sure we don't lose the specific version, so just modify the
-			# existing install_name
-			if [[ ! -w "${ED}/${libdir}/${tlib}" ]] ; then
-				chmod u+w "${ED}${libdir}/${tlib}" # needed to write to it
-				local nowrite=yes
-			fi
-			install_name_tool \
-				-id "${EPREFIX}"/${libdir}/${tlib} \
-				"${ED}"/${libdir}/${tlib} || die "install_name_tool failed"
-			[[ -n ${nowrite} ]] && chmod u-w "${ED}${libdir}/${tlib}"
-			# Now as we don't use GNU binutils and our linker doesn't
-			# understand linker scripts, just create a symlink.
-			pushd "${ED}/usr/${libdir}" > /dev/null
-			ln -snf "../../${libdir}/${tlib}" "${lib}"
-			popd > /dev/null
-			;;
-		*)
-			if ${auto} ; then
-				tlib=$(scanelf -qF'%S#F' "${ED}"/usr/${libdir}/${lib})
-				[[ -z ${tlib} ]] && die "unable to read SONAME from ${lib}"
-				mv "${ED}"/usr/${libdir}/${lib}* "${ED}"/${libdir}/ || die
-				# some SONAMEs are funky: they encode a version before the .so
-				if [[ ${tlib} != ${lib}* ]] ; then
-					mv "${ED}"/usr/${libdir}/${tlib}* "${ED}"/${libdir}/ || die
-				fi
-				rm -f "${ED}"/${libdir}/${lib}
-			else
-				tlib=${lib}
-			fi
-			cat > "${ED}/usr/${libdir}/${lib}" <<-END_LDSCRIPT
-			/* GNU ld script
-			   Since Gentoo has critical dynamic libraries in /lib, and the static versions
-			   in /usr/lib, we need to have a "fake" dynamic lib in /usr/lib, otherwise we
-			   run into linking problems.  This "fake" dynamic lib is a linker script that
-			   redirects the linker to the real lib.  And yes, this works in the cross-
-			   compiling scenario as the sysroot-ed linker will prepend the real path.
-
-			   See bug https://bugs.gentoo.org/4411 for more info.
-			 */
-			${output_format}
-			GROUP ( ${EPREFIX}/${libdir}/${tlib} )
-			END_LDSCRIPT
-			;;
-		esac
-		fperms a+x "/usr/${libdir}/${lib}" || die "could not change perms on ${lib}"
-	done
-}
-
 # @FUNCTION: tc-get-cxx-stdlib
 # @DESCRIPTION:
 # Attempt to identify the C++ standard library used by the compiler.
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-13  9:14 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-04-13  9:14 UTC (permalink / raw
  To: gentoo-commits
commit:     ec9bab0bb3d2a800ece37b8144aa97ee6161b4ee
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Apr 13 09:12:59 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Apr 13 09:12:59 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=ec9bab0b
llvm-r2.eclass: inherit multilib
This worked by chance before 064d419ded17cb95eb12aa9478cad52e906dc6d4: llvm-r2
uses get_all_abis and get_abi_CHOST, so inherit multilib explicitly.
Closes: https://bugs.gentoo.org/953755
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/llvm-r2.eclass | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/eclass/llvm-r2.eclass b/eclass/llvm-r2.eclass
index 4dda9aedc7c6..5370e5dbd8d5 100644
--- a/eclass/llvm-r2.eclass
+++ b/eclass/llvm-r2.eclass
@@ -1,4 +1,4 @@
-# Copyright 2024 Gentoo Authors
+# Copyright 2024-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: llvm-r2.eclass
@@ -54,7 +54,7 @@ esac
 if [[ -z ${_LLVM_R2_ECLASS} ]]; then
 _LLVM_R2_ECLASS=1
 
-inherit llvm-utils
+inherit llvm-utils multilib
 
 # == internal control knobs ==
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-13 11:45 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-04-13 11:45 UTC (permalink / raw
  To: gentoo-commits
commit:     b6706bf513d4ddfd48b16871ecb062746aab6dec
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Apr 13 11:44:34 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Apr 13 11:45:17 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=b6706bf5
toolchain.eclass: fix GCC 8 with USE=jit
This has been broken for a year(!) since 28fca56a1639578fc58de1e8310b7c94a5e12e09.
Bug: https://bugs.gentoo.org/926953
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 5 ++++-
 1 file changed, 4 insertions(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 273a2b9f92c9..b6cc4df5364a 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1921,10 +1921,13 @@ toolchain_src_configure() {
 			# respect USE=graphite here in case the user passes some
 			# graphite flags rather than try strip them out.
 			$(use_with graphite isl)
-			$(use_with zstd)
 			--with-system-zlib
 		)
 
+		if tc_has_feature zstd ; then
+			confgcc_jit+=( $(use_with zstd) )
+		fi
+
 		if tc_version_is_at_least 15.0.0_pre20241124 ${PV} ; then
 			confgcc_jit+=( $(use_enable libgdiagnostics) )
 		fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-14 16:07 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-04-14 16:07 UTC (permalink / raw
  To: gentoo-commits
commit:     5fb9704cb52708ae6407ae514e3e157d090f2af5
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Apr 14 16:06:02 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Apr 14 16:06:23 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=5fb9704c
toolchain.eclass: filter -Warray-bounds more again
Older branches are still broken for Ada and D, though for Ada, trunk
seems fine while the upstream bug is still open (not looked into that).
Bug: https://bugs.gentoo.org/940750
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 15 ++++++---------
 1 file changed, 6 insertions(+), 9 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index b6cc4df5364a..d96c4acabbe2 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -2125,8 +2125,6 @@ gcc_do_filter_flags() {
 			-fharden-control-flow-redundancy -fno-harden-control-flow-redundancy \
 			-fhardcfr-skip-leaf -fhardcfr-check-exceptions \
 			-fhardcfr-check-returning-calls '-fhardcfr-check-noreturn-calls=*'
-
-		# New in GCC 14.
 		filter-flags -Walloc-size
 	fi
 
@@ -2135,6 +2133,10 @@ gcc_do_filter_flags() {
 		filter-flags -fdiagnostics-set-output=text:experimental-nesting=yes
 	fi
 
+	# Ada: PR116226
+	# D: PR117002 (bug #940750)
+	filter-flags -Warray-bounds
+
 	# Please use USE=lto instead (bug #906007).
 	filter-lto
 
@@ -2330,18 +2332,13 @@ gcc_do_make() {
 		BOOT_LDFLAGS=${BOOT_LDFLAGS-"${abi_ldflags} ${LDFLAGS}"}
 		LDFLAGS_FOR_TARGET="${LDFLAGS_FOR_TARGET:-${LDFLAGS}}"
 
-		if _tc_use_if_iuse d ; then
+		if _tc_use_if_iuse d && use hardened ; then
 			# If we need to in future, we could really simplify this
 			# to just be unconditional for stage1. It doesn't really
 			# matter there. If we want to go in the other direction
 			# and make this more conditional, we could check if
 			# the bootstrap compiler is < GCC 12. See bug #940470.
-			if use hardened ; then
-				STAGE1_CXXFLAGS+=" -U_GLIBCXX_ASSERTIONS"
-			fi
-
-			# This can be dropped a while after 2025-03-31 (bug #940750).
-			STAGE1_GDCFLAGS+=" -Wno-array-bounds"
+			STAGE1_CXXFLAGS+=" -U_GLIBCXX_ASSERTIONS"
 		fi
 
 		emakeargs+=(
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-15 10:15 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-04-15 10:15 UTC (permalink / raw
  To: gentoo-commits
commit:     8c620ce4281edd37b52ee8c4d6b04acddefd1f74
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Tue Apr 15 10:05:40 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Tue Apr 15 10:15:27 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=8c620ce4
llvm.org.eclass: Add 21.0.0_pre20250415 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index a1e22f3203f6..34eda7eee351 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -72,6 +72,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 			_LLVM_SOURCE_TYPE=snapshot
 
 			case ${PV} in
+				21.0.0_pre20250415)
+					EGIT_COMMIT=1cf9f764ac41fb3492e10c78640dd50e616388db
+					;;
 				21.0.0_pre20250412)
 					EGIT_COMMIT=fa4ac19f0fc937e30fd7711dad98d0fcdb34f8ba
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-15 14:24 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-04-15 14:24 UTC (permalink / raw
  To: gentoo-commits
commit:     d4ccb328184df4fcf18b4286dbbce3fe07287ac6
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sun Apr  6 08:40:39 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Tue Apr 15 14:19:37 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=d4ccb328
distutils-r1.eclass: Bump minimum setuptools version
Bump minimum setuptools version, as >=77 introduced a deprecation
warning, with a suggested solution that only works with >=77, so now
a growing number of packages require that version.
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/distutils-r1.eclass | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/eclass/distutils-r1.eclass b/eclass/distutils-r1.eclass
index 96ac77d04dad..020fe57a4378 100644
--- a/eclass/distutils-r1.eclass
+++ b/eclass/distutils-r1.eclass
@@ -322,7 +322,7 @@ _distutils_set_globals() {
 				;;
 			setuptools)
 				bdep+='
-					>=dev-python/setuptools-75.8.2[${PYTHON_USEDEP}]
+					>=dev-python/setuptools-78.1.0[${PYTHON_USEDEP}]
 				'
 				;;
 			sip)
@@ -347,7 +347,7 @@ _distutils_set_globals() {
 			eqawarn "is enabled."
 		fi
 	else
-		local setuptools_dep='>=dev-python/setuptools-75.8.2[${PYTHON_USEDEP}]'
+		local setuptools_dep='>=dev-python/setuptools-78.1.0[${PYTHON_USEDEP}]'
 
 		case ${DISTUTILS_USE_SETUPTOOLS:-bdepend} in
 			no|manual)
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-15 14:24 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-04-15 14:24 UTC (permalink / raw
  To: gentoo-commits
commit:     c52c80dbda6796c20475a04f9e5b35957e291e8d
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Wed Apr  9 10:57:16 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Tue Apr 15 14:19:39 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=c52c80db
distutils-r1.eclass: Add verbose `det setup.py` deprecation warning
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/distutils-r1.eclass | 4 +++-
 1 file changed, 3 insertions(+), 1 deletion(-)
diff --git a/eclass/distutils-r1.eclass b/eclass/distutils-r1.eclass
index f863872330c2..7f5546a2c2a7 100644
--- a/eclass/distutils-r1.eclass
+++ b/eclass/distutils-r1.eclass
@@ -599,7 +599,7 @@ distutils_enable_sphinx() {
 #
 # - pytest: dev-python/pytest
 #
-# - setup.py: setup.py test (no deps included)
+# - setup.py: setup.py test (no deps included; deprecated)
 #
 # - unittest: for built-in Python unittest module
 #
@@ -645,6 +645,8 @@ distutils_enable_tests() {
 			fi
 			;;
 		setup.py)
+			eqawarn "'distutils_enable_tests setup.py' is deprecated and will be removed."
+			eqawarn "Please use unittest or pytest instead."
 			;;
 		unittest)
 			;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-15 14:24 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-04-15 14:24 UTC (permalink / raw
  To: gentoo-commits
commit:     721eefaa104d85bc45628bd3527b8e9f075da4e4
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sun Apr  6 08:37:34 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Tue Apr 15 14:19:36 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=721eefaa
distutils-r1.eclass: Make DISTUTILS_UPSTREAM_PEP517 default-unset
Instead of setting DISTUTILS_UPSTREAM_PEP517 to DISTUTILS_USE_PEP517
in global scope, make it fall back to that variable when used.  This
way, we don't have to override both variables when multiple values
need to be used in an ebuild.
Bug: https://bugs.gentoo.org/953285
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/distutils-r1.eclass | 9 ++++++---
 1 file changed, 6 insertions(+), 3 deletions(-)
diff --git a/eclass/distutils-r1.eclass b/eclass/distutils-r1.eclass
index e1672dd3c3b0..96ac77d04dad 100644
--- a/eclass/distutils-r1.eclass
+++ b/eclass/distutils-r1.eclass
@@ -154,10 +154,11 @@
 # will be merged into ${D}.
 
 # @ECLASS_VARIABLE: DISTUTILS_UPSTREAM_PEP517
+# @DEFAULT_UNSET
 # @DESCRIPTION:
 # Specifies the PEP517 build backend used upstream.  It is used
 # by the eclass to verify the correctness of DISTUTILS_USE_PEP517,
-# and matches DISTUTILS_USE_PEP517 by default.  However, it can be
+# and defaults to ${DISTUTILS_USE_PEP517}.  However, it can be
 # overriden to workaround the eclass check, when it is desirable
 # to build the wheel using other backend than the one used upstream.
 #
@@ -165,7 +166,6 @@
 # be subtle differences between the behavior of different PEP517 build
 # backends, for example regarding finding package files.  When using
 # this option, please make sure that the package is installed correctly.
-: "${DISTUTILS_UPSTREAM_PEP517:=${DISTUTILS_USE_PEP517}}"
 
 # @ECLASS_VARIABLE: DISTUTILS_USE_SETUPTOOLS
 # @DEFAULT_UNSET
@@ -1164,7 +1164,10 @@ _distutils-r1_get_backend() {
 	fi
 
 	# verify that the ebuild correctly specifies the build backend
-	local expected_backend=$(_distutils-r1_key_to_backend "${DISTUTILS_UPSTREAM_PEP517}")
+	local expected_backend=$(
+		_distutils-r1_key_to_backend \
+			"${DISTUTILS_UPSTREAM_PEP517:-${DISTUTILS_USE_PEP517}}"
+	)
 	if [[ ${expected_backend} != ${build_backend} ]]; then
 		# special-case deprecated backends
 		case ${build_backend} in
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-15 14:24 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-04-15 14:24 UTC (permalink / raw
  To: gentoo-commits
commit:     b736b0c09f09cce408ebb8a6508291c28fbbc41f
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Wed Apr  9 07:22:25 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Tue Apr 15 14:19:38 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=b736b0c0
distutils-r1.eclass: Remove unittest-or-fail deps
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/distutils-r1.eclass | 6 ------
 1 file changed, 6 deletions(-)
diff --git a/eclass/distutils-r1.eclass b/eclass/distutils-r1.eclass
index 020fe57a4378..f863872330c2 100644
--- a/eclass/distutils-r1.eclass
+++ b/eclass/distutils-r1.eclass
@@ -647,12 +647,6 @@ distutils_enable_tests() {
 		setup.py)
 			;;
 		unittest)
-			# unittest-or-fail is needed in py<3.12
-			local test_pkgs="$(python_gen_cond_dep '
-					dev-python/unittest-or-fail[${PYTHON_USEDEP}]
-				' 3.10 3.11
-			)"
-			[[ -n ${test_pkgs} ]] && test_deps+=" ${test_pkgs}"
 			;;
 		*)
 			die "${FUNCNAME}: unsupported argument: ${1}"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-15 14:24 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-04-15 14:24 UTC (permalink / raw
  To: gentoo-commits
commit:     6651290a7f9e0d22738a71c1c471952b60dfffb2
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Wed Apr  9 07:19:06 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Tue Apr 15 14:19:37 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=6651290a
python-utils-r1.eclass: Remove unittest-or-fail use
Remove the use of dev-python/unittest-or-fail in favor of using stdlib
unittest runner for all implementations.  While technically the latter
doesn't error out on "no tests" on Python 3.11 and older, this doesn't
really matter, because we're going to detect broken invocations while
testing on 3.12+.
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/python-utils-r1.eclass | 8 ++------
 1 file changed, 2 insertions(+), 6 deletions(-)
diff --git a/eclass/python-utils-r1.eclass b/eclass/python-utils-r1.eclass
index affb8e55a50d..79097765167f 100644
--- a/eclass/python-utils-r1.eclass
+++ b/eclass/python-utils-r1.eclass
@@ -1481,7 +1481,7 @@ epytest() {
 # @FUNCTION: eunittest
 # @USAGE: [<args>...]
 # @DESCRIPTION:
-# Run unit tests using dev-python/unittest-or-fail, passing the standard
+# Run unit tests using unittest, passing the standard
 # set of options, followed by user-specified options.
 #
 # This command dies on failure and respects nonfatal.
@@ -1492,11 +1492,7 @@ eunittest() {
 	_python_check_occluded_packages
 
 	# unittest fails with "no tests" correctly since Python 3.12
-	local runner=unittest
-	if _python_impl_matches "${EPYTHON}" 3.{9..11}; then
-		runner=unittest_or_fail
-	fi
-	set -- "${EPYTHON}" -m "${runner}" discover -v "${@}"
+	set -- "${EPYTHON}" -m unittest discover -v "${@}"
 
 	echo "${@}" >&2
 	"${@}" || die -n "Tests failed with ${EPYTHON}"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-15 14:24 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-04-15 14:24 UTC (permalink / raw
  To: gentoo-commits
commit:     4fab54a77187e818fd00e8aa55b5e45091a49632
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Wed Apr  9 11:18:34 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Tue Apr 15 14:19:40 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=4fab54a7
distutils-r1.eclass: Add verbose legacy mode deprecation warning
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/distutils-r1.eclass | 14 +++++---------
 1 file changed, 5 insertions(+), 9 deletions(-)
diff --git a/eclass/distutils-r1.eclass b/eclass/distutils-r1.eclass
index 7f5546a2c2a7..6e477823ce02 100644
--- a/eclass/distutils-r1.eclass
+++ b/eclass/distutils-r1.eclass
@@ -388,6 +388,11 @@ _distutils_set_globals() {
 			DISTUTILS_DEPS=${bdep}
 			readonly DISTUTILS_DEPS
 		fi
+	else
+		eqawarn "distutils-r1.eclass legacy mode is deprecated and will be removed."
+		eqawarn "Please migrate your ebuilds to use DISTUTILS_USE_PEP517 (common values"
+		eqawarn "are 'setuptools' for packages using setuptools/distutils,"
+		eqawarn "and 'no' for packages using non-PEP517 build systems)."
 	fi
 
 	if [[ ! ${DISTUTILS_OPTIONAL} ]]; then
@@ -977,15 +982,6 @@ distutils-r1_python_prepare_all() {
 	if [[ ! ${DISTUTILS_USE_PEP517} ]]; then
 		_distutils-r1_disable_ez_setup
 		_distutils-r1_handle_pyproject_toml
-
-		case ${DISTUTILS_USE_SETUPTOOLS} in
-			no)
-				eqawarn "Non-PEP517 builds are deprecated for ebuilds using plain distutils."
-				eqawarn "Please migrate to DISTUTILS_USE_PEP517=setuptools."
-				eqawarn "Please see Python Guide for more details:"
-				eqawarn "  https://projects.gentoo.org/python/guide/distutils.html"
-				;;
-		esac
 	fi
 
 	if [[ ${DISTUTILS_IN_SOURCE_BUILD} && ! ${DISTUTILS_SINGLE_IMPL} ]]
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-16  2:42 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-04-16  2:42 UTC (permalink / raw
  To: gentoo-commits
commit:     44dbc63d9c4778fb098cde0b4c99efd6fe7c2759
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Apr 16 02:41:06 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Apr 16 02:41:48 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=44dbc63d
toolchain.eclass: fix libgdiagnostics path without USE=-jit
We would configure but not build & install with USE="libgdiagnostics -jit".
This doesn't fix bug #953823 yet though.
Bug: https://bugs.gentoo.org/953823
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 12 +++++++-----
 1 file changed, 7 insertions(+), 5 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index d96c4acabbe2..ebb63901fba5 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -2352,7 +2352,7 @@ gcc_do_make() {
 		)
 	fi
 
-	if is_jit ; then
+	if is_jit || _tc_use_if_iuse libgdiagnostics ; then
 		# TODO: docs for jit?
 		einfo "Building JIT"
 		emake -C "${WORKDIR}"/build-jit "${emakeargs[@]}"
@@ -2554,7 +2554,7 @@ toolchain_src_install() {
 		done < <(find gcc/include*/ -name '*.h')
 	fi
 
-	if is_jit ; then
+	if is_jit || _tc_use_if_iuse libgdiagnostics ; then
 		# See https://gcc.gnu.org/onlinedocs/gcc-11.3.0/jit/internals/index.html#packaging-notes
 		# and bug #843341.
 		#
@@ -2781,9 +2781,11 @@ gcc_movelibs() {
 
 	# libgccjit gets installed to /usr/lib, not /usr/$(get_libdir). Probably
 	# due to a bug in gcc build system.
-	if [[ ${PWD} == "${WORKDIR}"/build-jit ]] && is_jit ; then
-		dodir "${LIBPATH#${EPREFIX}}"
-		mv "${ED}"/usr/lib/libgccjit* "${D}${LIBPATH}" || die
+	if [[ ${PWD} == "${WORKDIR}"/build-jit ]] ; then
+		if is_jit || _tc_use_if_iuse libgdiagnostics ; then
+			dodir "${LIBPATH#${EPREFIX}}"
+			mv "${ED}"/usr/lib/libgccjit* "${D}${LIBPATH}" || die
+		fi
 	fi
 
 	# For all the libs that are built for CTARGET, move them into the
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-17  1:27 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-04-17  1:27 UTC (permalink / raw
  To: gentoo-commits
commit:     6335bd10dfd41fa1f1a508c9e4d3458b6ae39a91
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Apr 17 01:25:50 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Apr 17 01:26:19 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=6335bd10
toolchain.eclass: extend JIT location hack to libgdiagnostics too
libgccjit is strange in that it's a non-internal library installed
by GCC and isn't intended to be interacted with via some magic options
like -fopenmp or whatever, but just linked like a regular library.
libgdiagnostics is the same, so extend the same treatment to it.
Thanks to tdr for testing.
Closes: https://bugs.gentoo.org/953823
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 9 +++++++--
 1 file changed, 7 insertions(+), 2 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index ebb63901fba5..df6ed170fe1f 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -2782,10 +2782,15 @@ gcc_movelibs() {
 	# libgccjit gets installed to /usr/lib, not /usr/$(get_libdir). Probably
 	# due to a bug in gcc build system.
 	if [[ ${PWD} == "${WORKDIR}"/build-jit ]] ; then
-		if is_jit || _tc_use_if_iuse libgdiagnostics ; then
-			dodir "${LIBPATH#${EPREFIX}}"
+		dodir "${LIBPATH#${EPREFIX}}"
+
+		if is_jit ; then
 			mv "${ED}"/usr/lib/libgccjit* "${D}${LIBPATH}" || die
 		fi
+
+		if _tc_use_if_iuse libgdiagnostics ; then
+			mv "${ED}"/usr/lib/libgdiagnostics* "${D}${LIBPATH}" || die
+		fi
 	fi
 
 	# For all the libs that are built for CTARGET, move them into the
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-19  1:31 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-04-19  1:31 UTC (permalink / raw
  To: gentoo-commits
commit:     ba3dffd3228188acf098b06d73059f1b02e69cfc
Author:     Christopher Fore <csfore <AT> posteo <DOT> net>
AuthorDate: Sun Apr 13 00:53:50 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Apr 19 01:30:37 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=ba3dffd3
cargo.eclass: Add _cargo_check_initialized to cargo_live_src_unpack
Currently cargo.eclass does not check if rust_pkg_setup was called in
cargo_live_src_unpack, leading to situations where vague build errors
can show up.
Closes: https://bugs.gentoo.org/953532
Bug: https://bugs.gentoo.org/953515
Signed-off-by: Christopher Fore <csfore <AT> posteo.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/cargo.eclass | 2 ++
 1 file changed, 2 insertions(+)
diff --git a/eclass/cargo.eclass b/eclass/cargo.eclass
index ad15da2b51a9..428341d568db 100644
--- a/eclass/cargo.eclass
+++ b/eclass/cargo.eclass
@@ -561,6 +561,8 @@ cargo_live_src_unpack() {
 	[[ "${PV}" == *9999* ]] || die "${FUNCNAME} only allowed in live/9999 ebuilds"
 	[[ "${EBUILD_PHASE}" == unpack ]] || die "${FUNCNAME} only allowed in src_unpack"
 
+	_cargo_check_initialized
+
 	mkdir -p "${S}" || die
 	mkdir -p "${ECARGO_VENDOR}" || die
 	mkdir -p "${ECARGO_HOME}" || die
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-19  1:31 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-04-19  1:31 UTC (permalink / raw
  To: gentoo-commits
commit:     e7aa0ac74a17f3b404103a42cfd24525c1e9cc2f
Author:     Christopher Fore <csfore <AT> posteo <DOT> net>
AuthorDate: Sun Apr 13 00:53:49 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Apr 19 01:30:31 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=e7aa0ac7
cargo.eclass: Pull check for rust_pkg_setup into its own function
This reduces repetitiveness and allows for easier maintainability in the
future.
Bug: https://bugs.gentoo.org/953515
Bug: https://bugs.gentoo.org/953532
Signed-off-by: Christopher Fore <csfore <AT> posteo.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/cargo.eclass | 26 ++++++++++++++------------
 1 file changed, 14 insertions(+), 12 deletions(-)
diff --git a/eclass/cargo.eclass b/eclass/cargo.eclass
index d93ae1723470..ad15da2b51a9 100644
--- a/eclass/cargo.eclass
+++ b/eclass/cargo.eclass
@@ -245,6 +245,16 @@ ECARGO_VENDOR="${ECARGO_HOME}/gentoo"
 # @DESCRIPTION:
 # List of URIs to put in SRC_URI created from CRATES variable.
 
+# @FUNCTION: _cargo_check_initialized
+# @INTERNAL
+# @DESCRIPTION:
+# Checks if rust_pkg_setup has been run.
+_cargo_check_initialized() {
+	if [[ -z "${CARGO}" ]]; then
+		die "CARGO is not set; was rust_pkg_setup run?"
+	fi
+}
+
 # @FUNCTION: _cargo_set_crate_uris
 # @USAGE: <crates>
 # @DESCRIPTION:
@@ -468,9 +478,7 @@ cargo_target_dir() {
 cargo_update_crates () {
 	debug-print-function ${FUNCNAME} "$@"
 
-	if [[ -z ${CARGO} ]]; then
-		die "CARGO is not set; was rust_pkg_setup run?"
-	fi
+	_cargo_check_initialized
 
 	local path=${1:-"${S}/Cargo.toml"}
 	if [[ $# -gt 1 ]]; then
@@ -778,9 +786,7 @@ cargo_env() {
 cargo_src_compile() {
 	debug-print-function ${FUNCNAME} "$@"
 
-	if [[ -z "${CARGO}" ]]; then
-		die "CARGO is not set; was rust_pkg_setup run?"
-	fi
+	_cargo_check_initialized
 
 	set -- "${CARGO}" build $(usex debug "" --release) ${ECARGO_ARGS[@]} "$@"
 	einfo "${@}"
@@ -796,9 +802,7 @@ cargo_src_compile() {
 cargo_src_install() {
 	debug-print-function ${FUNCNAME} "$@"
 
-	if [[ -z "${CARGO}" ]]; then
-		die "CARGO is not set; was rust_pkg_setup run?"
-	fi
+	_cargo_check_initialized
 
 	set -- "${CARGO}" install $(has --path ${@} || echo --path ./) \
 		--root "${ED}/usr" \
@@ -818,9 +822,7 @@ cargo_src_install() {
 cargo_src_test() {
 	debug-print-function ${FUNCNAME} "$@"
 
-	if [[ -z "${CARGO}" ]]; then
-		die "CARGO is not set; was rust_pkg_setup run?"
-	fi
+	_cargo_check_initialized
 
 	set -- "${CARGO}" test $(usex debug "" --release) ${ECARGO_ARGS[@]} "$@"
 	einfo "${@}"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-19  8:37 Hans de Graaff
  0 siblings, 0 replies; 6663+ messages in thread
From: Hans de Graaff @ 2025-04-19  8:37 UTC (permalink / raw
  To: gentoo-commits
commit:     27df2e633f8f65a5199e281d539bf3685f8611c0
Author:     Hans de Graaff <graaff <AT> gentoo <DOT> org>
AuthorDate: Tue Mar 25 13:30:57 2025 +0000
Commit:     Hans de Graaff <graaff <AT> gentoo <DOT> org>
CommitDate: Sat Apr 19 08:36:50 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=27df2e63
eclass/ruby*: disable ruby31
Signed-off-by: Hans de Graaff <graaff <AT> gentoo.org>
 eclass/ruby-ng.eclass    | 4 ++--
 eclass/ruby-utils.eclass | 4 ++--
 2 files changed, 4 insertions(+), 4 deletions(-)
diff --git a/eclass/ruby-ng.eclass b/eclass/ruby-ng.eclass
index f3745b5d3eab..87337dc7f173 100644
--- a/eclass/ruby-ng.eclass
+++ b/eclass/ruby-ng.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2024 Gentoo Authors
+# Copyright 1999-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: ruby-ng.eclass
@@ -110,7 +110,7 @@ _ruby_get_all_impls() {
 	for i in ${USE_RUBY}; do
 		case ${i} in
 			# removed implementations
-			ruby19|ruby2[0-7]|ruby30|jruby)
+			ruby19|ruby2[0-7]|ruby3[0-1]|jruby)
 				;;
 			*)
 				found_valid_impl=1
diff --git a/eclass/ruby-utils.eclass b/eclass/ruby-utils.eclass
index 4bd3e6ba1292..f55fcb29af74 100644
--- a/eclass/ruby-utils.eclass
+++ b/eclass/ruby-utils.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2024 Gentoo Authors
+# Copyright 1999-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: ruby-utils.eclass
@@ -33,7 +33,7 @@ esac
 # provide for a better first installation experience.
 
 # All stable RUBY_TARGETS
-RUBY_TARGETS_PREFERENCE="ruby32 ruby31 "
+RUBY_TARGETS_PREFERENCE="ruby32 "
 
 # All other active ruby targets
 RUBY_TARGETS_PREFERENCE+="ruby33 ruby34"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-19 10:28 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-04-19 10:28 UTC (permalink / raw
  To: gentoo-commits
commit:     e6ed2822fad7b7be6e5e889e0799834566ae9de3
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Apr 19 06:39:37 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat Apr 19 10:28:10 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=e6ed2822
llvm.org.eclass: Remove old snapshots
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 6 ------
 1 file changed, 6 deletions(-)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index 34eda7eee351..ad7663a1ab67 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -75,12 +75,6 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 				21.0.0_pre20250415)
 					EGIT_COMMIT=1cf9f764ac41fb3492e10c78640dd50e616388db
 					;;
-				21.0.0_pre20250412)
-					EGIT_COMMIT=fa4ac19f0fc937e30fd7711dad98d0fcdb34f8ba
-					;;
-				21.0.0_pre20250405)
-					EGIT_COMMIT=f3e6473df46fd920e09e06e57a5549eb8e3a8bd3
-					;;
 				*)
 					die "Unknown snapshot: ${PV}"
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-19 19:16 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-04-19 19:16 UTC (permalink / raw
  To: gentoo-commits
commit:     73fda26842575668580ad90e98ef93cdb73cd329
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Apr 19 19:12:39 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Apr 19 19:14:36 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=73fda268
toolchain.eclass: only enable JIT with USE=jit
My fix in 6335bd10dfd41fa1f1a508c9e4d3458b6ae39a91 exposed another
issue with USE="-jit libgdiagnostics" that was being obscured by the
issue I fixed in that commit: with USE=-jit, as long as we were still
doing the separate host-shared build (with USE=libgdiagnostics), we were
still passing --enable-languages=jit.
Bug: https://bugs.gentoo.org/953823
Closes: https://bugs.gentoo.org/954077
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 7 ++++++-
 1 file changed, 6 insertions(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index df6ed170fe1f..0857395b4234 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1915,7 +1915,6 @@ toolchain_src_configure() {
 			--disable-systemtap
 
 			--enable-host-shared
-			--enable-languages=jit
 
 			# Might be used for the just-built GCC. Easier to just
 			# respect USE=graphite here in case the user passes some
@@ -1924,6 +1923,12 @@ toolchain_src_configure() {
 			--with-system-zlib
 		)
 
+		if is_jit ; then
+			confgcc_jit+=( --enable-languages=jit )
+		else
+			confgcc_jit+=( --enable-languages=c,c++ )
+		fi
+
 		if tc_has_feature zstd ; then
 			confgcc_jit+=( $(use_with zstd) )
 		fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-20 11:50 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-04-20 11:50 UTC (permalink / raw
  To: gentoo-commits
commit:     05489fb3fdf30d457d95483c41d62dbb475c31e9
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sun Apr 20 11:49:14 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sun Apr 20 11:49:14 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=05489fb3
Add 21.0.0_pre20250420 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index ad7663a1ab67..180aef8f89a1 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -72,6 +72,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 			_LLVM_SOURCE_TYPE=snapshot
 
 			case ${PV} in
+				21.0.0_pre20250420)
+					EGIT_COMMIT=ac8fc09688e10e983b99224b5dc5cbbeeedb1879
+					;;
 				21.0.0_pre20250415)
 					EGIT_COMMIT=1cf9f764ac41fb3492e10c78640dd50e616388db
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-21  2:38 Ionen Wolkens
  0 siblings, 0 replies; 6663+ messages in thread
From: Ionen Wolkens @ 2025-04-21  2:38 UTC (permalink / raw
  To: gentoo-commits
commit:     3f72e677e174de7decb9f3e6f1695d093eddf954
Author:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
AuthorDate: Sat Apr 19 05:18:48 2025 +0000
Commit:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
CommitDate: Mon Apr 21 01:52:49 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=3f72e677
wine.eclass: new eclass
Trying to keep Wine ebuilds in sync between wine-vanilla, wine-staging,
and wine-proton which each have several ebuilds been giving headaches,
and the addition of arm64 support is not helping.
Goal is to offload only the gritty toolchain and slotting bits, and
leave ebuilds to deal with normal dependencies and configure options.
Could've put these in the eclass too, but it'd likely become messy as
dependencies get added/removed between versions (want to avoid too many
${PV} -gt rules). Also want to avoid these to allow overlays to use
this to package their own variants with more freedom.
Note there is some difference compared to current ebuilds:
- arm64 support using https://github.com/gentoo/gentoo/pull/41650
  as a guideline (not tested myself, pending keywording)
- no support for non-PE builds to simplify and having less to
  test, wine-proton was already doing this to match what upstream
  Proton does
- ^ may be a bit misleading but if USE=-mingw, will still do PE
  builds but using clang (less tested, so +mingw remains default),
  debated USE=clang and dropping USE=mingw instead but that feels
  confusing for other reasons
- drop REQUIRED_USE that prevented USE="wow64 -mingw"
- drop workaround that ensured man pages were installed for
  a pure (non-default) 64bit build (feels not worth it, and
  no longer needed for >=10.2)
- no support for <wine-9 (pre --enable-archs), will likely
  drop these once they start causing problems and not worth
  extra eclass logic
- bit of refactoring that could well be broken
In the future may have the eclass handle extra things like basic tests
too (full testsuite is nightmare), but leaving that out for now.
Closes: https://github.com/gentoo/gentoo/pull/41650
Closes: https://github.com/gentoo/gentoo/pull/41660
Thanks-to: Sasha Finkelstein <fnkl.kernel <AT> gmail.com>
Signed-off-by: Ionen Wolkens <ionen <AT> gentoo.org>
 eclass/wine.eclass | 413 +++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 file changed, 413 insertions(+)
diff --git a/eclass/wine.eclass b/eclass/wine.eclass
new file mode 100644
index 000000000000..b82dd469c191
--- /dev/null
+++ b/eclass/wine.eclass
@@ -0,0 +1,413 @@
+# Copyright 2025 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+# @ECLASS: wine.eclass
+# @MAINTAINER:
+# Wine <wine@gentoo.org>
+# @AUTHOR:
+# Ionen Wolkens <ionen@gentoo.org>
+# @SUPPORTED_EAPIS: 8
+# @BLURB: Common functions for app-emuluation/wine-* ebuilds
+# @DESCRIPTION:
+# Given the large amount of Wine ebuilds (and variants) that need
+# duplicated code, this is used to offload the more complex bits
+# (primarily toolchain and slotting) and leave ebuilds to only need
+# to deal with dependencies and configure options like any other.
+#
+# Note to overlays: this can be used to package other variants of
+# Wine, but there is currently no garantee that eclass changes may
+# not break these ebuilds now and then without real warnings
+
+case ${EAPI} in
+	8) ;;
+	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
+esac
+
+if [[ -z ${_WINE_ECLASS} ]]; then
+_WINE_ECLASS=1
+
+inherit autotools flag-o-matic multilib prefix toolchain-funcs wrapper
+
+# @ECLASS_VARIABLE: WINE_USEDEP
+# @DESCRIPTION:
+# Meant be used like multilib-build.eclass' MULTILIB_USEDEP.  Handled
+# specially here given Wine ebuilds are not *really* multilib and are
+# abusing abi_x86_* with some specific requirements.
+#
+# TODO: when the *new* wow64 mode (aka USE=wow64) is mature enough to
+# be preferred over abi_x86_32, this should be removed and support for
+# 32bit-only-on-64bit be dropped matching how /no-multilib/ handles it
+readonly WINE_USEDEP="abi_x86_32(-)?,abi_x86_64(-)?"
+
+IUSE="
+	+abi_x86_32 +abi_x86_64 crossdev-mingw custom-cflags
+	+mingw +strip wow64
+"
+REQUIRED_USE="
+	|| ( abi_x86_32 abi_x86_64 arm64 )
+	crossdev-mingw? ( mingw )
+	wow64? ( abi_x86_64 !abi_x86_32 )
+"
+
+BDEPEND="
+	|| (
+		sys-devel/binutils:*
+		llvm-core/lld:*
+	)
+	dev-lang/perl
+	mingw? (
+		!crossdev-mingw? (
+			dev-util/mingw64-toolchain[${WINE_USEDEP}]
+			wow64? ( dev-util/mingw64-toolchain[abi_x86_32] )
+		)
+	)
+	!mingw? (
+		llvm-core/clang:*[${WINE_USEDEP}]
+		strip? ( llvm-core/llvm:* )
+	)
+"
+IDEPEND=">=app-eselect/eselect-wine-2"
+
+# @ECLASS_VARIABLE: WINE_SKIP_INSTALL
+# @DESCRIPTION:
+# Array of files to delete from the installation relative
+# to ${ED}, must be set before running wine_src_install.
+WINE_SKIP_INSTALL=()
+
+# @FUNCTION: wine_pkg_pretend
+# @DESCRIPTION:
+# Verifies if crossdev-mingw is used properly, ignored if
+# ``MINGW_BYPASS`` is set.
+wine_pkg_pretend() {
+	[[ ${MERGE_TYPE} == binary ]] && return
+
+	if use crossdev-mingw && [[ ! -v MINGW_BYPASS ]]; then
+		local arches=(
+			$(usev abi_x86_64 x86_64)
+			$(usev abi_x86_32 i686)
+			$(usev wow64 i686)
+			$(usev arm64 aarch64)
+		)
+
+		local mingw
+		for mingw in "${arches[@]/%/-w64-mingw32}"; do
+			if ! type -P ${mingw}-gcc >/dev/null; then
+				eerror "With USE=crossdev-mingw, you must prepare the MinGW toolchain"
+				eerror "yourself by installing sys-devel/crossdev then running:"
+				eerror
+				eerror "    crossdev --target ${mingw}"
+				eerror
+				eerror "For more information, please see: https://wiki.gentoo.org/wiki/Mingw"
+				die "USE=crossdev-mingw is enabled, but ${mingw}-gcc was not found"
+			fi
+		done
+	fi
+}
+
+# @FUNCTION: wine_src_prepare
+# @DESCRIPTION:
+# Apply various minor adjustments, run eautoreconf, make_requests, and
+# perform a version mismatch sanity check if WINE_GECKO and WINE_MONO
+# are set.
+#
+# If need more than make_requests, it should be either handled in
+# the ebuild or (for users) optionally through portage hooks, e.g.
+#
+# @CODE
+# echo "post_src_prepare() { tools/make_specfiles || die; }" \
+#    > /etc/portage/env/app-emulation/wine-vanilla
+# @CODE
+wine_src_prepare() {
+	default
+
+	if [[ ${WINE_GECKO} && ${WINE_MONO} ]]; then
+		# sanity check, bumping these has a history of oversights
+		local geckomono=$(sed -En '/^#define (GECKO|MONO)_VER/{s/[^0-9.]//gp}' \
+			dlls/appwiz.cpl/addons.c || die)
+
+		if [[ ${WINE_GECKO}$'\n'${WINE_MONO} != "${geckomono}" ]]; then
+			local gmfatal=
+			has live ${PROPERTIES} && gmfatal=nonfatal
+			${gmfatal} die -n "gecko/mono mismatch in ebuild, has: " ${geckomono} " (please file a bug)"
+		fi
+	fi
+
+	if tc-is-clang && use mingw; then
+		# -mabi=ms was ignored by <clang:16 then turned error in :17
+		# if used without --target *-windows, then gets used in install
+		# phase despite USE=mingw, drop as a quick fix for now
+		sed -i '/MSVCRTFLAGS=/s/-mabi=ms//' configure.ac || die
+	fi
+
+	# ensure .desktop calls this variant + slot
+	sed -i "/^Exec=/s/wine /${P} /" loader/wine.desktop || die
+
+	# needed to find wine-mono on prefix
+	hprefixify -w /get_mono_path/ dlls/mscoree/metahost.c
+
+	# always update for patches (including user's wrt #432348)
+	eautoreconf
+	tools/make_requests || die # perl
+}
+
+# @FUNCTION: wine_src_configure
+# @DESCRIPTION:
+# Setup toolchain and run ./configure by passing the ``wineconfargs``
+# array.
+#
+# The following options are handled automatically and do not need
+# to be passed: --prefix (and similar), --enable-archs, --enable-win64
+# --with-mingw, and --with-wine64
+#
+# Not truly supported, but cross toolchain can be customised using
+# CROSSCC, CROSSCC_amd64/x86/arm64, CROSSCFLAGS and CROSSLDFLAGS
+# (based on what wine's configure also recognize, or used to for CC).
+wine_src_configure() {
+	WINE_PREFIX=/usr/lib/${P}
+	WINE_DATADIR=/usr/share/${P}
+	WINE_INCLUDEDIR=/usr/include/${P}
+
+	local conf=(
+		--prefix="${EPREFIX}"${WINE_PREFIX}
+		--datadir="${EPREFIX}"${WINE_DATADIR}
+		--includedir="${EPREFIX}"${WINE_INCLUDEDIR}
+		--libdir="${EPREFIX}"${WINE_PREFIX}
+		--mandir="${EPREFIX}"${WINE_DATADIR}/man
+	)
+
+	# strip-flags due to being generally fragile
+	use custom-cflags || strip-flags
+
+	# longstanding failing to build with lto, filter unconditionally
+	filter-lto
+
+	# may segfault at runtime if used (bug #931329)
+	filter-flags -Wl,--gc-sections
+
+	# avoid gcc-15's c23 default for now (bug #943849)
+	# TODO: verify if still needed and limit to old until cleanup
+	append-cflags -std=gnu17
+
+	# Wine uses many linker tricks that are unlikely to work
+	# with anything but bfd or lld (bug #867097)
+	if ! tc-ld-is-bfd && ! tc-ld-is-lld; then
+		has_version -b sys-devel/binutils &&
+			append-ldflags -fuse-ld=bfd ||
+			append-ldflags -fuse-ld=lld
+		strip-unsupported-flags
+	fi
+
+	if use mingw; then
+		conf+=( --with-mingw )
+
+		use !crossdev-mingw &&
+			! has_version -b 'dev-util/mingw64-toolchain[bin-symlinks]' &&
+			PATH=${BROOT}/usr/lib/mingw64-toolchain/bin:${PATH}
+
+		# TODO?: llvm-mingw support if ever packaged and wanted
+		local wcc_amd64=${CROSSCC:-${CROSSCC_amd64:-x86_64-w64-mingw32-gcc}}
+		local wcc_x86=${CROSSCC:-${CROSSCC_x86:-i686-w64-mingw32-gcc}}
+		# no mingw64-toolchain ~arm64, but "may" be usable with crossdev
+		# (aarch64- rather than arm64- given it is what Wine searches for)
+		local wcc_arm64=${CROSSCC:-${CROSSCC_arm64:-aarch64-w64-mingw32-gcc}}
+		local -n wcc_test=wcc_$(usex arm64 arm64 $(usex abi_x86_64 amd64 x86))
+	else
+		conf+=( --with-mingw=clang )
+
+		# not building for ${CHOST} so $(tc-getCC) is not quite right, but
+		# *should* support -target *-windows regardless
+		tc-is-clang && local clang=$(tc-getCC) || local clang=clang
+		local wcc_amd64=${CROSSCC:-${CROSSCC_amd64:-${clang}}}
+		local wcc_x86=${CROSSCC:-${CROSSCC_x86:-${clang}}}
+		local wcc_arm64=${CROSSCC:-${CROSSCC_arm64:-${clang}}}
+		local wcc_test="${clang} -target $(usex arm64 aarch64 $(usex abi_x86_64 x86_64 i386))-windows"
+
+		# do not copy from regular LDFLAGS given odds are they all are
+		# incompatible, and difficult to test linking without llvm-mingw
+		: "${CROSSLDFLAGS:= }"
+	fi
+
+	conf+=(
+		ac_cv_prog_x86_64_CC="${wcc_amd64}"
+		ac_cv_prog_i386_CC="${wcc_x86}"
+		ac_cv_prog_aarch64_CC="${wcc_arm64}"
+
+		CROSSCFLAGS="${CROSSCFLAGS:-$(
+			# many hardening options are unlikely to work right
+			filter-flags '-fstack-protector*' #870136
+			filter-flags '-mfunction-return=thunk*' #878849
+
+			# bashrc-mv users often do CFLAGS="${LDFLAGS}" and then
+			# compile-only tests miss stripping unsupported linker flags
+			filter-flags '-Wl,*'
+
+			# -mavx with mingw-gcc has a history of problems and still see
+			# users have issues despite Wine's -mpreferred-stack-boundary=2
+			use mingw && append-cflags -mno-avx
+
+			CC=${wcc_test} test-flags-CC ${CFLAGS:--O2}
+		)}"
+		CROSSLDFLAGS="${CROSSLDFLAGS:-$(
+			# let compiler figure out the right linker for cross
+			filter-flags '-fuse-ld=*'
+
+			CC=${wcc_test} test-flags-CCLD ${LDFLAGS}
+		)}"
+	)
+
+	if use abi_x86_64 && use abi_x86_32 && use !wow64; then
+		# multilib dual build method for "old" wow64 (must do 64 first)
+		local bits
+		for bits in 64 32; do
+		(
+			einfo "Configuring for ${bits}bits in ${WORKDIR}/build${bits} ..."
+
+			mkdir ../build${bits} || die
+			cd ../build${bits} || die
+
+			if (( bits == 64 )); then
+				conf+=( --enable-win64 )
+			else
+				conf+=(
+					--with-wine64=../build64
+					TARGETFLAGS=-m32 # for widl
+				)
+
+				# optional, but prefer over Wine's auto-detect (+#472038)
+				multilib_toolchain_setup x86
+			fi
+
+			ECONF_SOURCE=${S} econf "${conf[@]}" "${wineconfargs[@]}"
+		)
+		done
+	else
+		# new --enable-archs method, or 32bit-only
+		local archs=(
+			$(usev abi_x86_64 x86_64)
+			$(usev wow64 i386) # 32-on-64bit "new" wow64
+			$(usev arm64 aarch64)
+		)
+		conf+=( ${archs:+--enable-archs="${archs[*]}"} )
+
+		econf "${conf[@]}" "${wineconfargs[@]}"
+	fi
+}
+
+# @FUNCTION: wine_src_compile
+# @DESCRIPTION:
+# Handle running emake.
+wine_src_compile() {
+	if use abi_x86_64 && use abi_x86_32 && use !wow64; then
+		emake -C ../build64 # do first
+		emake -C ../build32
+	else
+		emake
+	fi
+}
+
+# @FUNCTION: wine_src_install
+# @DESCRIPTION:
+# Handle running emake install, creating slot wrappers, and
+# stripping binaries built for Windows.
+wine_src_install() {
+	if use abi_x86_64 && use abi_x86_32 && use !wow64; then
+		emake DESTDIR="${D}" -C ../build32 install
+		emake DESTDIR="${D}" -C ../build64 install # do last
+	else
+		emake DESTDIR="${D}" install
+	fi
+
+	if use abi_x86_64 || use arm64; then
+		if ver_test -ge 10.2; then
+			# wine64 was removed, but keep a symlink for old scripts
+			# TODO: can remove this -e guard eventually, only there to
+			# avoid overwriting 9999's wine64 if go into <10.2 commits
+			[[ ! -e ${ED}${WINE_PREFIX}/bin/wine64 ]] &&
+				dosym wine ${WINE_PREFIX}/bin/wine64
+		else
+			# <wine-10.2 did not have a unified wine(1) and could miss
+			# wine64 or wine depending on USE, ensure both are are there
+			if [[ -e ${ED}${WINE_PREFIX}/bin/wine64 && ! -e ${ED}${WINE_PREFIX}/bin/wine ]]; then
+				dosym wine64 ${WINE_PREFIX}/bin/wine
+				dosym wine64-preloader ${WINE_PREFIX}/bin/wine-preloader
+			elif [[ ! -e ${ED}${WINE_PREFIX}/bin/wine64 && -e ${ED}${WINE_PREFIX}/bin/wine ]]; then
+				dosym wine ${WINE_PREFIX}/bin/wine64
+				dosym wine-preloader ${WINE_PREFIX}/bin/wine64-preloader
+			fi
+		fi
+	fi
+
+	# delete unwanted files if requested, not done directly in ebuilds
+	# given must be done after install and before wrappers
+	if (( ${#WINE_SKIP_INSTALL[@]} )); then
+		rm -- "${WINE_SKIP_INSTALL[@]/#/${ED}}" || die
+	fi
+
+	# create variant wrappers for eselect-wine
+	local bin
+	for bin in "${ED}"${WINE_PREFIX}/bin/*; do
+		make_wrapper "${bin##*/}-${P#wine-}" "${bin#"${ED}"}"
+	done
+
+	# don't let the package manager try to strip Windows files with
+	# potentially the wrong strip executable and instead handle it here
+	dostrip -x ${WINE_PREFIX}/wine/{x86_64,i386,aarch64}-windows
+
+	if use strip; then
+		ebegin "Stripping Windows binaries"
+		if use mingw; then
+			: "$(usex arm64 aarch64 $(usex abi_x86_64 x86_64 i686)-w64-mingw32-strip)"
+			find "${ED}"${WINE_PREFIX}/wine/*-windows -regex '.*\.\(a\|dll\|exe\)' \
+				-exec ${_} --strip-unneeded {} +
+		else
+			# llvm-strip errors on .a, and CHOST binutils strip could mangle
+			find "${ED}"${WINE_PREFIX}/wine/*-windows -regex '.*\.\(dll\|exe\)' \
+				-exec llvm-strip --strip-unneeded {} +
+		fi
+		eend ${?} || die
+	fi
+}
+
+# @FUNCTION: wine_pkg_postinst
+# @DESCRIPTION:
+# Provide generic warnings about missing 32bit support,
+# and run eselect wine update.
+wine_pkg_postinst() {
+	if use !abi_x86_32 && use !wow64; then
+		ewarn "32bit support is disabled. While 64bit applications themselves will"
+		ewarn "work, be warned that it is not unusual that installers or other helpers"
+		ewarn "will attempt to use 32bit and fail. If do not want full USE=abi_x86_32,"
+		ewarn "note the experimental USE=wow64 can allow 32bit without full multilib."
+	fi
+
+	# difficult to tell what is needed from here, but try to warn anyway
+	if use abi_x86_32 && { use opengl || use vulkan; }; then
+		if has_version 'x11-drivers/nvidia-drivers'; then
+			if has_version 'x11-drivers/nvidia-drivers[-abi_x86_32]'; then
+				ewarn "x11-drivers/nvidia-drivers is installed but is built without"
+				ewarn "USE=abi_x86_32 (ABI_X86=32), hardware acceleration with 32bit"
+				ewarn "applications under ${PN} will likely not be usable."
+				ewarn "Multi-card setups may need this on media-libs/mesa as well."
+			fi
+		elif has_version 'media-libs/mesa[-abi_x86_32]'; then
+			ewarn "media-libs/mesa seems to be in use but is built without"
+			ewarn "USE=abi_x86_32 (ABI_X86=32), hardware acceleration with 32bit"
+			ewarn "applications under ${PN} will likely not be usable."
+		fi
+	fi
+
+	eselect wine update --if-unset || die
+}
+
+# @FUNCTION: wine_pkg_postrm
+# @DESCRIPTION:
+# Run eselect wine update if available.
+wine_pkg_postrm() {
+	if has_version -b app-eselect/eselect-wine; then
+		eselect wine update --if-unset || die
+	fi
+}
+
+fi
+
+EXPORT_FUNCTIONS pkg_pretend src_prepare src_configure src_compile src_install pkg_postinst pkg_postrm
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-22 11:24 Ionen Wolkens
  0 siblings, 0 replies; 6663+ messages in thread
From: Ionen Wolkens @ 2025-04-22 11:24 UTC (permalink / raw
  To: gentoo-commits
commit:     0198811d44b0014d1b04033c835e788163b782fb
Author:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
AuthorDate: Tue Apr 22 11:19:53 2025 +0000
Commit:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
CommitDate: Tue Apr 22 11:23:40 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=0198811d
wine.eclass: require lld w/ wow64 w/o mingw, drop clang[abi_x86_32]
Wine forces -fuse-ld=lld with -target *-windows.
clang[${WINE_USEDEP}] was kind of copied from mingw64-toolchain
but makes no sense here, afaik this is just for libclang which
we do not need. It's possible need some abi_x86_32 on some other
llvm-runtimes/* or clang-runtime (untested), but given wine
provides its own runtimes that sounds unlikely (our packages
aren't for windows).
Not closing bug #954211 given cause hasn't been confirmed yet.
While here also deduplicate the mingw64-toolchain dep with !wow64.
Bug: https://bugs.gentoo.org/954211
Signed-off-by: Ionen Wolkens <ionen <AT> gentoo.org>
 eclass/wine.eclass | 5 +++--
 1 file changed, 3 insertions(+), 2 deletions(-)
diff --git a/eclass/wine.eclass b/eclass/wine.eclass
index b82dd469c191..cb4852b99c60 100644
--- a/eclass/wine.eclass
+++ b/eclass/wine.eclass
@@ -57,12 +57,13 @@ BDEPEND="
 	dev-lang/perl
 	mingw? (
 		!crossdev-mingw? (
-			dev-util/mingw64-toolchain[${WINE_USEDEP}]
 			wow64? ( dev-util/mingw64-toolchain[abi_x86_32] )
+			!wow64? ( dev-util/mingw64-toolchain[${WINE_USEDEP}] )
 		)
 	)
 	!mingw? (
-		llvm-core/clang:*[${WINE_USEDEP}]
+		llvm-core/clang:*
+		llvm-core/lld:*
 		strip? ( llvm-core/llvm:* )
 	)
 "
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-23 11:37 Matt Jolly
  0 siblings, 0 replies; 6663+ messages in thread
From: Matt Jolly @ 2025-04-23 11:37 UTC (permalink / raw
  To: gentoo-commits
commit:     7c06fc841e0504a3031feab008b40cec64a4cc5d
Author:     Matt Jolly <kangie <AT> gentoo <DOT> org>
AuthorDate: Mon Apr 21 02:20:05 2025 +0000
Commit:     Matt Jolly <kangie <AT> gentoo <DOT> org>
CommitDate: Wed Apr 23 11:36:03 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=7c06fc84
rust.eclass: add 1.87.0
Signed-off-by: Matt Jolly <kangie <AT> gentoo.org>
Closes: https://github.com/gentoo/gentoo/pull/41680
Signed-off-by: Matt Jolly <kangie <AT> gentoo.org>
 eclass/rust.eclass | 2 ++
 1 file changed, 2 insertions(+)
diff --git a/eclass/rust.eclass b/eclass/rust.eclass
index a9ccfed4cf8f..2cc0dd7d23d8 100644
--- a/eclass/rust.eclass
+++ b/eclass/rust.eclass
@@ -68,6 +68,7 @@ fi
 # Definitive list of Rust slots and the associated LLVM slot, newest first.
 declare -A -g -r _RUST_LLVM_MAP=(
 	["9999"]=20
+	["1.87.0"]=20
 	["1.86.0"]=19
 	["1.85.1"]=19
 	["1.85.0"]=19
@@ -94,6 +95,7 @@ declare -A -g -r _RUST_LLVM_MAP=(
 # this array is used to store the Rust slots in a more convenient order for iteration.
 declare -a -g -r _RUST_SLOTS_ORDERED=(
 	"9999"
+	"1.87.0"
 	"1.86.0"
 	"1.85.1"
 	"1.85.0"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread
* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-23 15:09 Ulrich Müller
  0 siblings, 0 replies; 6663+ messages in thread
From: Ulrich Müller @ 2025-04-23 15:09 UTC (permalink / raw
  To: gentoo-commits
commit:     3ba318e113caaa573ee6c2ce8360a8c6f5b1167d
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Mon Apr 21 11:41:47 2025 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Wed Apr 23 15:02:18 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=3ba318e1
elisp-common.eclass: Add lexbind cookie to site-init files
This is needed for individual site-init files to be loaded, since Emacs
from Git now complains about missing lexical-binding cookies.
Drop any initial blank lines when installing site-init files in
elisp-site-file-install. Instead, insert blank lines when concatenating
the files in elisp-site-regen.
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 eclass/elisp-common.eclass | 24 ++++++++++++++----------
 1 file changed, 14 insertions(+), 10 deletions(-)
diff --git a/eclass/elisp-common.eclass b/eclass/elisp-common.eclass
index 117544e94b35..654b302bb39a 100644
--- a/eclass/elisp-common.eclass
+++ b/eclass/elisp-common.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2024 Gentoo Authors
+# Copyright 1999-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: elisp-common.eclass
@@ -626,12 +626,12 @@ elisp-modules-install() {
 
 elisp-site-file-install() {
 	local sf="${1##*/}" my_pn="${2:-${PN}}" modules ret
-	local add_header="1 {
-		# Find first non-empty line
-		:x; /^\$/ { n; bx; }
-		# Insert a header, unless we already look at one
-		/^;.*${PN}/I! s/^/;;; ${PN} site-lisp configuration\n\n/
-		1 s/^/\n/
+	local add_header="0,/\S/ {
+		# Delete any leading blank lines
+		/\S/! d
+		# Insert a header, unless we are already looking at one
+		/^;.*${PN}/I! \
+			i ;;; ${PN} site-lisp configuration  -*-lexical-binding:t-*-\n
 	}"
 
 	[[ ${sf} == [0-9][0-9]*-gentoo*.el ]] \
@@ -711,11 +711,15 @@ elisp-site-regen() {
 	;; DO NOT EDIT THIS FILE
 
 	;;; Code:
+
 	EOF
-	# Use sed instead of cat here, since files may miss a trailing newline.
-	sed '$q' "${sflist[@]}" </dev/null >>"${T}"/site-gentoo.el || ret=$?
+	# Concatenate all site initialisation files.
+	# 1{/^;/s/\s*-\*-.*-\*-//} deletes file-local-var cookies from line 1.
+	# /\S/,$!d deletes any leading blank lines.
+	# $G inserts a blank line after each file.
+	sed -s '1{/^;/s/\s*-\*-.*-\*-//};/\S/,$!d;$G' "${sflist[@]}" \
+		</dev/null >>"${T}"/site-gentoo.el || ret=$?
 	cat <<-EOF >>"${T}"/site-gentoo.el || ret=$?
-
 	${page}
 	(provide 'site-gentoo)
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-23 15:18 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-04-23 15:18 UTC (permalink / raw
  To: gentoo-commits
commit:     e0d9ef4199426dace9136289832e59e49d8c1460
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Apr 23 10:09:20 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Apr 23 15:15:12 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=e0d9ef41
autotools.eclass: use 'QA Notice:' prefix in eqawarn
This makes life easier for tinderboxes, but we should improve this in some future
EAPI.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/autotools.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/autotools.eclass b/eclass/autotools.eclass
index 1545b88bc426..f37b8482781f 100644
--- a/eclass/autotools.eclass
+++ b/eclass/autotools.eclass
@@ -598,7 +598,7 @@ autotools_run_tool() {
 	done
 
 	if [[ ${EBUILD_PHASE_FUNC} != "src_prepare" ]] ; then
-		eqawarn "Running '${1}' in ${EBUILD_PHASE_FUNC} phase"
+		eqawarn "QA Notice: Running '${1}' in ${EBUILD_PHASE_FUNC} phase"
 	fi
 
 	if ${missing_ok} && ! type -P ${1} >/dev/null ; then
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-23 15:18 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-04-23 15:18 UTC (permalink / raw
  To: gentoo-commits
commit:     a24673569d3d66f4c554e6c7dfb12e01912172e5
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Apr 23 09:50:36 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Apr 23 15:15:11 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=a2467356
python-utils-r1.eclass: add 'QA Notice:' prefix to eqawarn
We need to fix this properly at some point in Portage/PMS but whatever,
for now, add the 'QA Prefix:' prefix to eqawarn so tinderboxes pick
these up and report them.
Bug: https://bugs.gentoo.org/954151
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/python-utils-r1.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/python-utils-r1.eclass b/eclass/python-utils-r1.eclass
index 79097765167f..458c0b0b2387 100644
--- a/eclass/python-utils-r1.eclass
+++ b/eclass/python-utils-r1.eclass
@@ -1279,7 +1279,7 @@ _python_check_occluded_packages() {
 			)
 
 			if [[ -n ${diff} ]]; then
-				eqawarn "The directory ${fn} occludes package installed for ${EPYTHON}."
+				eqawarn "QA Notice: The directory ${fn} occludes package installed for ${EPYTHON}."
 				eqawarn "The installed package includes additional files:"
 				eqawarn
 				while IFS= read -r l; do
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-23 15:18 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-04-23 15:18 UTC (permalink / raw
  To: gentoo-commits
commit:     32bbaebe4b727997e483d6b78c8d71cf9fde6b7e
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Apr 23 09:47:48 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Apr 23 15:15:09 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=32bbaebe
distutils-r1.eclass: add 'QA Notice:' prefix to eqawarn
We need to fix this properly at some point in Portage/PMS but whatever,
for now, add the 'QA Prefix:' prefix to eqawarn so tinderboxes pick
these up and report them.
Bug: https://bugs.gentoo.org/954151
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/distutils-r1.eclass | 10 +++++-----
 1 file changed, 5 insertions(+), 5 deletions(-)
diff --git a/eclass/distutils-r1.eclass b/eclass/distutils-r1.eclass
index 6e477823ce02..02fe41aa388f 100644
--- a/eclass/distutils-r1.eclass
+++ b/eclass/distutils-r1.eclass
@@ -389,7 +389,7 @@ _distutils_set_globals() {
 			readonly DISTUTILS_DEPS
 		fi
 	else
-		eqawarn "distutils-r1.eclass legacy mode is deprecated and will be removed."
+		eqawarn "QA Notice: distutils-r1.eclass legacy mode is deprecated and will be removed."
 		eqawarn "Please migrate your ebuilds to use DISTUTILS_USE_PEP517 (common values"
 		eqawarn "are 'setuptools' for packages using setuptools/distutils,"
 		eqawarn "and 'no' for packages using non-PEP517 build systems)."
@@ -650,7 +650,7 @@ distutils_enable_tests() {
 			fi
 			;;
 		setup.py)
-			eqawarn "'distutils_enable_tests setup.py' is deprecated and will be removed."
+			eqawarn "QA Notice: 'distutils_enable_tests setup.py' is deprecated and will be removed."
 			eqawarn "Please use unittest or pytest instead."
 			;;
 		unittest)
@@ -1183,7 +1183,7 @@ _distutils-r1_get_backend() {
 
 		# if we didn't die, we're dealing with a deprecated backend
 		if [[ ! -f ${T}/.distutils_deprecated_backend_warned ]]; then
-			eqawarn "${build_backend} backend is deprecated.  Please see:"
+			eqawarn "QA Notice: ${build_backend} backend is deprecated.  Please see:"
 			eqawarn "https://projects.gentoo.org/python/guide/qawarn.html#deprecated-pep-517-backends"
 			eqawarn "The project should use ${expected_backend} instead."
 			> "${T}"/.distutils_deprecated_backend_warned || die
@@ -1991,7 +1991,7 @@ _distutils-r1_compare_installed_files() {
 			--exclude="*$(get_modname)" \
 			"${_DISTUTILS_PREVIOUS_SITE}" "${sitedir}"
 		if [[ ${?} -ne 0 ]]; then
-			eqawarn "Package creating at least one pure Python wheel installs different"
+			eqawarn "QA Notice: Package creating at least one pure Python wheel installs different"
 			eqawarn "Python files between implementations.  See diff in build log, above"
 			eqawarn "this message."
 		fi
@@ -2182,7 +2182,7 @@ _distutils-r1_post_python_install() {
 		if [[ ! ${DISTUTILS_EXT} && ! ${_DISTUTILS_EXT_WARNED} ]]; then
 			if [[ $(find "${sitedir}" -name "*$(get_modname)" | head -n 1) ]]
 			then
-				eqawarn "Python extension modules (*$(get_modname)) found installed. Please set:"
+				eqawarn "QA Notice: Python extension modules (*$(get_modname)) found installed. Please set:"
 				eqawarn "  DISTUTILS_EXT=1"
 				eqawarn "in the ebuild."
 				_DISTUTILS_EXT_WARNED=1
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-23 15:18 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-04-23 15:18 UTC (permalink / raw
  To: gentoo-commits
commit:     636db84c297674e57df06eb9c318d508d94a7da5
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Apr 23 09:50:23 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Apr 23 15:15:10 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=636db84c
python-r1.eclass: add 'QA Notice:' prefix to eqawarn
We need to fix this properly at some point in Portage/PMS but whatever,
for now, add the 'QA Prefix:' prefix to eqawarn so tinderboxes pick
these up and report them.
Bug: https://bugs.gentoo.org/954151
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/python-r1.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/python-r1.eclass b/eclass/python-r1.eclass
index 02d7215320a2..7be8b5ac8d45 100644
--- a/eclass/python-r1.eclass
+++ b/eclass/python-r1.eclass
@@ -620,7 +620,7 @@ python_foreach_impl() {
 			[[ ! ${_DISTUTILS_CALLING_FOREACH_IMPL} &&
 				! ${_DISTUTILS_FOREACH_IMPL_WARNED} ]]
 		then
-			eqawarn "python_foreach_impl has been called directly while using distutils-r1."
+			eqawarn "QA Notice: python_foreach_impl has been called directly while using distutils-r1."
 			eqawarn "Please redefine python_*() phase functions to meet your expectations"
 			eqawarn "instead."
 			_DISTUTILS_FOREACH_IMPL_WARNED=1
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-23 15:18 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-04-23 15:18 UTC (permalink / raw
  To: gentoo-commits
commit:     e5ef944fb0fed952cd0344f67c052c0d7ecdbfea
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Apr 23 10:11:14 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Apr 23 15:15:15 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=e5ef944f
cmake.eclass: use 'QA Notice:' prefix in eqawarn
This makes life easier for tinderboxes, but we should improve this in some future
EAPI.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/cmake.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/cmake.eclass b/eclass/cmake.eclass
index e1bad4cbd16f..c97f74e8a2ed 100644
--- a/eclass/cmake.eclass
+++ b/eclass/cmake.eclass
@@ -303,7 +303,7 @@ _cmake_check_build_dir() {
 		# TODO: For EAPI > 8, we should ban S=WORKDIR for CMake.
 		# See bug #889420.
 		if [[ ${S} == "${WORKDIR}" && ${BUILD_DIR} == "${WORKDIR}_build" ]] ; then
-			eqawarn "QA notice: S=WORKDIR is deprecated for cmake.eclass."
+			eqawarn "QA Notice: S=WORKDIR is deprecated for cmake.eclass."
 			eqawarn "Please relocate the sources in src_unpack."
 			BUILD_DIR="${WORKDIR}"/${P}_build
 		fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-23 15:18 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-04-23 15:18 UTC (permalink / raw
  To: gentoo-commits
commit:     042dd75e47316fb12f038af9ffca128570c1d7f4
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Apr 23 10:11:59 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Apr 23 15:15:18 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=042dd75e
haskell-cabal.eclass: use 'QA Notice:' prefix in eqawarn
This makes life easier for tinderboxes, but we should improve this in some future
EAPI.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/haskell-cabal.eclass | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/eclass/haskell-cabal.eclass b/eclass/haskell-cabal.eclass
index 7895d9256eba..2e77bc648b16 100644
--- a/eclass/haskell-cabal.eclass
+++ b/eclass/haskell-cabal.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2023 Gentoo Authors
+# Copyright 1999-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: haskell-cabal.eclass
@@ -342,7 +342,7 @@ cabal-bootstrap() {
 	elif [[ -f "${S}/Setup.hs" ]]; then
 		setupmodule="${S}/Setup.hs"
 	else
-		eqawarn "No Setup.lhs or Setup.hs found. Either add Setup.hs to package or call cabal-mksetup from ebuild"
+		eqawarn "QA Notice: No Setup.lhs or Setup.hs found. Either add Setup.hs to package or call cabal-mksetup from ebuild"
 		cabal-mksetup
 		setupmodule="${S}/Setup.hs"
 	fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-23 15:18 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-04-23 15:18 UTC (permalink / raw
  To: gentoo-commits
commit:     7887b31c379b29c20bfd87a2783c36930a251f37
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Apr 23 10:12:05 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Apr 23 15:15:19 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=7887b31c
java-pkg-simple.eclass: use 'QA Notice:' prefix in eqawarn
This makes life easier for tinderboxes, but we should improve this in some future
EAPI.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/java-pkg-simple.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/java-pkg-simple.eclass b/eclass/java-pkg-simple.eclass
index f3f67e7de408..0cce6a2cdfa8 100644
--- a/eclass/java-pkg-simple.eclass
+++ b/eclass/java-pkg-simple.eclass
@@ -654,7 +654,7 @@ java-pkg-simple_src_compile() {
 				JAVA_PKG_WANT_SOURCE=${tmp_source}
 				JAVA_PKG_WANT_TARGET=${tmp_target}
 			else
-				eqawarn "Need at least JDK 9 to compile module-info.java in src_compile."
+				eqawarn "QA Notice: Need at least JDK 9 to compile module-info.java in src_compile."
 				eqawarn "Please adjust DEPEND accordingly. See https://bugs.gentoo.org/796875#c3"
 			fi
 		fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-23 15:18 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-04-23 15:18 UTC (permalink / raw
  To: gentoo-commits
commit:     58f5fbfc451abada67792ad4db5efd07c5bdad2b
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Apr 23 10:11:49 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Apr 23 15:15:17 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=58f5fbfc
go-module.eclass: use 'QA Notice:' prefix in eqawarn
This makes life easier for tinderboxes, but we should improve this in some future
EAPI.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/go-module.eclass | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/eclass/go-module.eclass b/eclass/go-module.eclass
index 73e9ee51c7d5..14e0aad9dd2a 100644
--- a/eclass/go-module.eclass
+++ b/eclass/go-module.eclass
@@ -1,4 +1,4 @@
-# Copyright 2019-2024 Gentoo Authors
+# Copyright 2019-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: go-module.eclass
@@ -371,7 +371,7 @@ go-module_src_unpack() {
 	fi
 	GOFLAGS="${GOFLAGS} -p=$(makeopts_jobs)"
 	if [[ "${#EGO_SUM[@]}" -gt 0 ]]; then
-		eqawarn "This ebuild uses EGO_SUM which is deprecated"
+		eqawarn "QA Notice: This ebuild uses EGO_SUM which is deprecated"
 		eqawarn "Please migrate to a dependency tarball"
 		eqawarn "This will become a fatal error in the future"
 		_go-module_src_unpack_gosum
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-23 15:18 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-04-23 15:18 UTC (permalink / raw
  To: gentoo-commits
commit:     67aac5e5170384b9253773ad2ee2843784326c96
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Apr 23 10:12:17 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Apr 23 15:15:21 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=67aac5e5
ruby-ng.eclass: use 'QA Notice:' prefix in eqawarn
This makes life easier for tinderboxes, but we should improve this in some future
EAPI.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/ruby-ng.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/ruby-ng.eclass b/eclass/ruby-ng.eclass
index 87337dc7f173..c7425aae434c 100644
--- a/eclass/ruby-ng.eclass
+++ b/eclass/ruby-ng.eclass
@@ -725,7 +725,7 @@ ruby-ng_rspec() {
 	fi
 
 	if [[ "${DEPEND}${BDEPEND}" != *"dev-ruby/rspec"* ]]; then
-		eqawarn "Missing test dependency dev-ruby/rspec"
+		eqawarn "QA Notice: Missing test dependency dev-ruby/rspec"
 	fi
 
 	local rspec_params=
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-23 15:18 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-04-23 15:18 UTC (permalink / raw
  To: gentoo-commits
commit:     cf77b6d8733067d4fb5a564212ca324da55fcc5e
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Apr 23 10:12:11 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Apr 23 15:15:20 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=cf77b6d8
rpm.eclass: use 'QA Notice:' prefix in eqawarn
This makes life easier for tinderboxes, but we should improve this in some future
EAPI.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/rpm.eclass | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/eclass/rpm.eclass b/eclass/rpm.eclass
index c9c21aa6ebbd..e00332e55ca0 100644
--- a/eclass/rpm.eclass
+++ b/eclass/rpm.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2024 Gentoo Authors
+# Copyright 1999-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: rpm.eclass
@@ -31,9 +31,9 @@ rpm_unpack() {
 		if [[ ${a} == ./* ]] ; then
 			: # nothing to do -- path is local
 		elif [[ ${a} == "${DISTDIR}"/* ]] ; then
-			eqawarn 'do not use ${DISTDIR} with rpm_unpack -- it is added for you'
+			eqawarn 'QA Notice: do not use ${DISTDIR} with rpm_unpack -- it is added for you'
 		elif [[ ${a} == /* ]] ; then
-			eqawarn 'do not use full paths with rpm_unpack -- use ./ paths instead'
+			eqawarn 'QA Notice: do not use full paths with rpm_unpack -- use ./ paths instead'
 		else
 			a="${DISTDIR}/${a}"
 		fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-23 15:18 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-04-23 15:18 UTC (permalink / raw
  To: gentoo-commits
commit:     db16f59d43b278ec7047deda4e7faa3c82940892
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Apr 23 10:11:26 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Apr 23 15:15:16 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=db16f59d
ecm.eclass: use 'QA Notice:' prefix in eqawarn
This makes life easier for tinderboxes, but we should improve this in some future
EAPI.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/ecm.eclass | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/eclass/ecm.eclass b/eclass/ecm.eclass
index 9caaf59cb3fa..7a3d51c9913a 100644
--- a/eclass/ecm.eclass
+++ b/eclass/ecm.eclass
@@ -498,7 +498,7 @@ if [[ ${EAPI} == 8 ]]; then
 # Determine if the current GCC version is acceptable, otherwise die.
 _ecm_deprecated_check_gcc_version() {
 	if ver_test ${KFMIN} -ge 6.9; then
-		eqawarn "QA notice: ecm_pkg_${1} has become a no-op."
+		eqawarn "QA Notice: ecm_pkg_${1} has become a no-op."
 		eqawarn "It is no longer being exported with KFMIN >=6.9.0."
 	else
 		[[ ${MERGE_TYPE} != binary && -v KDE_GCC_MINIMAL ]] &&
@@ -592,7 +592,7 @@ ecm_src_prepare() {
 				diff -Naur ${f}.old ${f} 1>>${pf}
 				rm ${f}.old || die "Failed to clean up"
 			done
-			eqawarn "QA notice: Build system modified by ECM_TEST=forceoptional-recursive."
+			eqawarn "QA Notice: Build system modified by ECM_TEST=forceoptional-recursive."
 			eqawarn "Unified diff file ready for pickup in:"
 			eqawarn "  ${pf}"
 			eqawarn "Push it upstream to make this message go away."
@@ -780,7 +780,7 @@ if [[ ${EAPI} == 8 ]]; then
 # Carryall for ecm_pkg_preinst, ecm_pkg_postinst and ecm_pkg_postrm.
 _ecm_nongui_deprecated() {
 	if ver_test ${KFMIN} -ge 6.9; then
-		eqawarn "QA notice: ecm_pkg_${1} has become a no-op."
+		eqawarn "QA Notice: ecm_pkg_${1} has become a no-op."
 		eqawarn "It is no longer being exported with KFMIN >=6.9.0."
 	else
 		case ${ECM_NONGUI} in
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-23 15:18 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-04-23 15:18 UTC (permalink / raw
  To: gentoo-commits
commit:     3b09bec0f02bea369af769c038290b72ea798962
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Apr 23 10:09:40 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Apr 23 15:15:14 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=3b09bec0
chromium-2.eclass: use 'QA Notice:' prefix in eqawarn
This makes life easier for tinderboxes, but we should improve this in some future
EAPI.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/chromium-2.eclass | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/eclass/chromium-2.eclass b/eclass/chromium-2.eclass
index 0831f1f17aa5..e8f471e2178f 100644
--- a/eclass/chromium-2.eclass
+++ b/eclass/chromium-2.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2023 Gentoo Authors
+# Copyright 1999-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: chromium-2.eclass
@@ -83,7 +83,7 @@ chromium_remove_language_paks() {
 	# Look for missing pak files.
 	for lang in ${CHROMIUM_LANGS}; do
 		if [[ ! -e ${lang}.pak ]]; then
-			eqawarn "L10N warning: no .pak file for ${lang} (${lang}.pak not found)"
+			eqawarn "QA Notice: L10N warning: no .pak file for ${lang} (${lang}.pak not found)"
 		fi
 	done
 
@@ -101,7 +101,7 @@ chromium_remove_language_paks() {
 		fi
 
 		if ! has ${lang} ${CHROMIUM_LANGS}; then
-			eqawarn "L10N warning: no ${lang} in LANGS"
+			eqawarn "QA Notice: L10N warning: no ${lang} in LANGS"
 			continue
 		fi
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-23 15:18 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-04-23 15:18 UTC (permalink / raw
  To: gentoo-commits
commit:     f41ee85b85c4f4b953e71f9dcee4d0b87e9a2943
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Apr 23 10:09:28 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Apr 23 15:15:13 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=f41ee85b
cargo.eclass: use 'QA Notice:' prefix in eqawarn
This makes life easier for tinderboxes, but we should improve this in some future
EAPI.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/cargo.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/cargo.eclass b/eclass/cargo.eclass
index 428341d568db..247d1bf535b9 100644
--- a/eclass/cargo.eclass
+++ b/eclass/cargo.eclass
@@ -542,7 +542,7 @@ cargo_src_unpack() {
 		popd >/dev/null || die
 
 		if [[ ${#crates[@]} -ge 300 ]]; then
-			eqawarn "This package uses a very large number of CRATES.  Please provide"
+			eqawarn "QA Notice: This package uses a very large number of CRATES.  Please provide"
 			eqawarn "a crate tarball instead and fetch it via SRC_URI.  You can use"
 			eqawarn "'pycargoebuild --crate-tarball' to create one."
 		fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-23 15:18 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-04-23 15:18 UTC (permalink / raw
  To: gentoo-commits
commit:     b0069f0657e482aec72f596056c9d6ab71385786
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Apr 23 10:12:23 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Apr 23 15:15:22 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=b0069f06
toolchain.eclass: use 'QA Notice:' prefix in eqawarn
This makes life easier for tinderboxes, but we should improve this in some future
EAPI.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 0857395b4234..2e9350f3f596 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1842,7 +1842,7 @@ toolchain_src_configure() {
 	if [[ ${PV} == *_p* && -f "${S}"/gcc/doc/gcc.info ]] ; then
 		# Safeguard against https://gcc.gnu.org/PR106899 being fixed
 		# without corresponding ebuild changes.
-		eqawarn "Snapshot release with pre-generated info pages found!"
+		eqawarn "QA Notice: Snapshot release with pre-generated info pages found!"
 		eqawarn "The BDEPEND in the ebuild should be updated to drop texinfo."
 	fi
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-23 15:18 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-04-23 15:18 UTC (permalink / raw
  To: gentoo-commits
commit:     04e7124c3992c34a7bd39770f772510d77e8ac48
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Apr 23 10:12:32 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Apr 23 15:15:25 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=04e7124c
xorg-3.eclass: use 'QA Notice:' prefix in eqawarn
This makes life easier for tinderboxes, but we should improve this in some future
EAPI.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/xorg-3.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/xorg-3.eclass b/eclass/xorg-3.eclass
index db2d8fa85df9..4947cb86b8b0 100644
--- a/eclass/xorg-3.eclass
+++ b/eclass/xorg-3.eclass
@@ -429,7 +429,7 @@ xorg-3_src_install() {
 
 	# Many X11 libraries unconditionally install developer documentation
 	if [[ -d "${D}"/usr/share/man/man3 ]]; then
-		! in_iuse doc && eqawarn "ebuild should set XORG_DOC=doc since package installs library documentation"
+		! in_iuse doc && eqawarn "QA Notice: ebuild should set XORG_DOC=doc since package installs library documentation"
 	fi
 
 	if in_iuse doc && ! use doc; then
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-23 15:18 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-04-23 15:18 UTC (permalink / raw
  To: gentoo-commits
commit:     58e42b882ac5fc00a7a3dd5fc241b566c63cc470
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Apr 23 10:12:28 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Apr 23 15:15:24 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=58e42b88
wxwidgets.eclass: use 'QA Notice:' prefix in eqawarn
This makes life easier for tinderboxes, but we should improve this in some future
EAPI.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/wxwidgets.eclass | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/eclass/wxwidgets.eclass b/eclass/wxwidgets.eclass
index 0a58c44bbf40..7afea401a646 100644
--- a/eclass/wxwidgets.eclass
+++ b/eclass/wxwidgets.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2023 Gentoo Authors
+# Copyright 1999-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: wxwidgets.eclass
@@ -69,7 +69,7 @@ setup-wxwidgets() {
 	case ${WX_GTK_VER} in
 		3.0-gtk3 | 3.2-gtk3) wxtoolkit=gtk3 ;;
 		3.0)      wxtoolkit=gtk2
-		          eqawarn "This package relies on the deprecated GTK 2 slot, which will go away soon (https://bugs.gentoo.org/618642)"
+		          eqawarn "QA Notice: This package relies on the deprecated GTK 2 slot, which will go away soon (https://bugs.gentoo.org/618642)"
 		          ;;
 	esac
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-24 20:44 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-04-24 20:44 UTC (permalink / raw
  To: gentoo-commits
commit:     b11d38f11dc7ef3cdc2b71197678b5cded075062
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Apr 24 20:44:07 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Apr 24 20:44:21 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=b11d38f1
toolchain.eclass: fix typo in comment
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 2e9350f3f596..8254b60873f1 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1834,7 +1834,7 @@ toolchain_src_configure() {
 	fi
 
 	if [[ ${CTARGET} != *-darwin* ]] && tc_version_is_at_least 14.1 ; then
-		# This allows passing -stdlib-=libc++ at runtime.
+		# This allows passing -stdlib=libc++ at runtime.
 		confgcc+=( --with-gxx-libcxx-include-dir="${ESYSROOT}"/usr/include/c++/v1 )
 	fi
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-26 17:52 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-04-26 17:52 UTC (permalink / raw
  To: gentoo-commits
commit:     987c1b6aba48cd3a48945188e2dafc04eff57a7f
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Apr 26 17:47:17 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Apr 26 17:51:23 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=987c1b6a
toolchain.eclass: reset STAGE1_GDCFLAGS too
... just in case it leaks into other parts of the build. Noticed when
looking at Jannik's reported comparison failure.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 2 ++
 1 file changed, 2 insertions(+)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 8254b60873f1..01106d8923f4 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -2316,6 +2316,7 @@ gcc_do_make() {
 		if ! tc-is-gcc || ver_test $(gcc-fullversion) -lt 10 ; then
 			STAGE1_CFLAGS="-O0"
 			STAGE1_CXXFLAGS="-O0"
+			STAGE1_GDCFLAGS="-O0"
 		# We have a very good host compiler but it may be a bit too good, and
 		# know about flags that the version we are compiling does not know
 		# about. In principle we could check e.g. which gnat1 we are using as
@@ -2323,6 +2324,7 @@ gcc_do_make() {
 		elif _tc_use_if_iuse ada || _tc_use_if_iuse d; then
 			STAGE1_CFLAGS="-O2"
 			STAGE1_CXXFLAGS="-O2"
+			STAGE1_GDCFLAGS="-O2"
 		fi
 
 		# We only want to use the system's CFLAGS if not building a
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-26 18:03 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-04-26 18:03 UTC (permalink / raw
  To: gentoo-commits
commit:     52d3c7d126947f699095a771dfb3f8eea15ae12f
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Apr 26 18:02:06 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Apr 26 18:03:03 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=52d3c7d1
toolchain.eclass: log more *FLAGS vars
* Log STAGE{1,2,3}_${var}, BOOT_${var}, ${var}_FOR_{TARGET,BUILD}.
* Only show the flag if it's non-empty.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 20 +++++++++++++++++++-
 1 file changed, 19 insertions(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 01106d8923f4..cb697c3c8813 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1191,7 +1191,25 @@ toolchain_src_configure() {
 
 	local flag
 	for flag in $(all-flag-vars) ; do
-		einfo "${flag}=\"${!flag}\""
+		[[ -n ${!flag} ]] && einfo "${flag}=\"${!flag}\""
+
+		local stage_flag="STAGE1_${flag}"
+		[[ -n ${!stage_flag} ]] && einfo "${stage_flag}=\"${!stage_flag}\""
+
+		stage_flag="STAGE2_${flag}"
+		[[ -n ${!stage_flag} ]] && einfo "${stage_flag}=\"${!stage_flag}\""
+
+		stage_flag="STAGE3_${flag}"
+		[[ -n ${!stage_flag} ]] && einfo "${stage_flag}=\"${!stage_flag}\""
+
+		local boot_flag="BOOT_${flag}"
+		[[ -n ${!boot_flag} ]] && einfo "${boot_flag}=\"${!boot_flag}\""
+
+		local target_flag="${flag}_FOR_TARGET"
+		[[ -n ${!target_flag} ]] && einfo "${target_flag}=\"${!target_flag}\""
+
+		local build_flag="${flag}_FOR_BUILD"
+		[[ -n ${!build_flag} ]] && einfo "${build_flag}=\"${!build_flag}\""
 	done
 
 	local confgcc=( --host=${CHOST} )
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-26 18:09 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-04-26 18:09 UTC (permalink / raw
  To: gentoo-commits
commit:     b5f77e470ae5ac6187c4629afe51e002fca797d3
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Apr 26 18:09:17 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Apr 26 18:09:17 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=b5f77e47
toolchain.eclass: add some 'einfo' calls for flag mangling
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 5 ++++-
 1 file changed, 4 insertions(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index cb697c3c8813..93d4792af4d6 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -2332,6 +2332,7 @@ gcc_do_make() {
 		# to keep this bound somewhat fresh just to avoid problems. Ultimately,
 		# using not-O0 is just a build-time speed improvement anyway.
 		if ! tc-is-gcc || ver_test $(gcc-fullversion) -lt 10 ; then
+			einfo "Resetting STAGE1_*FLAGS to -O0 because of old or non-GCC bootstrap compiler"
 			STAGE1_CFLAGS="-O0"
 			STAGE1_CXXFLAGS="-O0"
 			STAGE1_GDCFLAGS="-O0"
@@ -2339,7 +2340,8 @@ gcc_do_make() {
 		# know about flags that the version we are compiling does not know
 		# about. In principle we could check e.g. which gnat1 we are using as
 		# a bootstrap. It's simpler to do it unconditionally for now.
-		elif _tc_use_if_iuse ada || _tc_use_if_iuse d; then
+		elif _tc_use_if_iuse ada || _tc_use_if_iuse d ; then
+			einfo "Resetting STAGE1_*FLAGS to -O2 for Ada/D bootstrapping"
 			STAGE1_CFLAGS="-O2"
 			STAGE1_CXXFLAGS="-O2"
 			STAGE1_GDCFLAGS="-O2"
@@ -2363,6 +2365,7 @@ gcc_do_make() {
 			# matter there. If we want to go in the other direction
 			# and make this more conditional, we could check if
 			# the bootstrap compiler is < GCC 12. See bug #940470.
+			einfo "Adding -U_GLIBCXX_ASSERTIONS workaround to STAGE1_CXXFLAGS for D/hardened"
 			STAGE1_CXXFLAGS+=" -U_GLIBCXX_ASSERTIONS"
 		fi
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-27  8:27 Ionen Wolkens
  0 siblings, 0 replies; 6663+ messages in thread
From: Ionen Wolkens @ 2025-04-27  8:27 UTC (permalink / raw
  To: gentoo-commits
commit:     975e8d62dca9a13c2e0097f1d3d0352043786fd2
Author:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
AuthorDate: Sun Apr 27 06:58:06 2025 +0000
Commit:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
CommitDate: Sun Apr 27 08:26:24 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=975e8d62
wine.eclass: add USE=wow64 build support for arm64
Only saying "build" given technically won't work out of the
box without the user setting up xtajit.dll themselves.
The 32bit warning could make sense on arm64 too, but given
it's off-by-default and does not work out of the box, nagging
about this every installs would just be annoying.
(the aarch64_CFLAGS changes & friends from the linked PR
were done in a previous commit)
Untested given do not have arm64 hardware, please report if
I overlooked anything.
While here, also add spacing to the warnings for visibility
and to split them if get more than one message.
Closes: https://github.com/gentoo/gentoo/pull/41752
Thanks-to: Sasha Finkelstein <fnkl.kernel <AT> gmail.com>
Signed-off-by: Ionen Wolkens <ionen <AT> gentoo.org>
 eclass/wine.eclass | 17 +++++++++++++++--
 1 file changed, 15 insertions(+), 2 deletions(-)
diff --git a/eclass/wine.eclass b/eclass/wine.eclass
index 223c83f1c4a5..9cf9a1b443ee 100644
--- a/eclass/wine.eclass
+++ b/eclass/wine.eclass
@@ -37,6 +37,7 @@ inherit autotools flag-o-matic multilib prefix toolchain-funcs wrapper
 # TODO: when the *new* wow64 mode (aka USE=wow64) is mature enough to
 # be preferred over abi_x86_32, this should be removed and support for
 # 32bit-only-on-64bit be dropped matching how /no-multilib/ handles it
+# (USE=wow64 should be enabled by default on amd64 then, but not arm64)
 readonly WINE_USEDEP="abi_x86_32(-)?,abi_x86_64(-)?"
 
 IUSE="
@@ -46,7 +47,7 @@ IUSE="
 REQUIRED_USE="
 	|| ( abi_x86_32 abi_x86_64 arm64 )
 	crossdev-mingw? ( mingw )
-	wow64? ( abi_x86_64 !abi_x86_32 )
+	wow64? ( !arm64? ( abi_x86_64 !abi_x86_32 ) )
 "
 
 BDEPEND="
@@ -384,7 +385,10 @@ wine_src_install() {
 # Provide generic warnings about missing 32bit support,
 # and run eselect wine update.
 wine_pkg_postinst() {
-	if use !abi_x86_32 && use !wow64; then
+	# on amd64, users sometime disable the default 32bit support due to being
+	# annoyed by the requirements without realizing that they need it
+	if use amd64 && use !abi_x86_32 && use !wow64; then
+		ewarn
 		ewarn "32bit support is disabled. While 64bit applications themselves will"
 		ewarn "work, be warned that it is not unusual that installers or other helpers"
 		ewarn "will attempt to use 32bit and fail. If do not want full USE=abi_x86_32,"
@@ -395,18 +399,27 @@ wine_pkg_postinst() {
 	if use abi_x86_32 && { use opengl || use vulkan; }; then
 		if has_version 'x11-drivers/nvidia-drivers'; then
 			if has_version 'x11-drivers/nvidia-drivers[-abi_x86_32]'; then
+				ewarn
 				ewarn "x11-drivers/nvidia-drivers is installed but is built without"
 				ewarn "USE=abi_x86_32 (ABI_X86=32), hardware acceleration with 32bit"
 				ewarn "applications under ${PN} will likely not be usable."
 				ewarn "Multi-card setups may need this on media-libs/mesa as well."
 			fi
 		elif has_version 'media-libs/mesa[-abi_x86_32]'; then
+			ewarn
 			ewarn "media-libs/mesa seems to be in use but is built without"
 			ewarn "USE=abi_x86_32 (ABI_X86=32), hardware acceleration with 32bit"
 			ewarn "applications under ${PN} will likely not be usable."
 		fi
 	fi
 
+	if use arm64 && use wow64; then
+		ewarn
+		ewarn "${PN} does not include an x86 emulator, running x86 binaries"
+		ewarn "with USE=wow64 on arm64 requires manually setting up xtajit.dll"
+		ewarn "(not packaged) in the Wine prefix."
+	fi
+
 	eselect wine update --if-unset || die
 }
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-27  8:27 Ionen Wolkens
  0 siblings, 0 replies; 6663+ messages in thread
From: Ionen Wolkens @ 2025-04-27  8:27 UTC (permalink / raw
  To: gentoo-commits
commit:     2db20f2eb03fee5ff43a677016c43a7b8d48d97d
Author:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
AuthorDate: Sun Apr 27 05:48:35 2025 +0000
Commit:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
CommitDate: Sun Apr 27 08:22:30 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=2db20f2e
wine.eclass: split *FLAGS handling per-arch
Previously would test flags for only one arch as a best effort, but
this gets messier if adding --enable-archs=i386,aarch64 support where
the two are more likely to need different flags.
Using a function inside $() to avoid the need to preserve CHOST
*FLAGS and also allow e.g. filter-flags -Wl,* (from CFLAGS...)
without mangling LDFLAGS given filter-cflags does not exist.
Adapted from https://github.com/gentoo/gentoo/pull/41752
Thanks-to: Sasha Finkelstein <fnkl.kernel <AT> gmail.com>
Signed-off-by: Ionen Wolkens <ionen <AT> gentoo.org>
 eclass/wine.eclass | 120 +++++++++++++++++++++++++++++++++++++----------------
 1 file changed, 85 insertions(+), 35 deletions(-)
diff --git a/eclass/wine.eclass b/eclass/wine.eclass
index cb4852b99c60..223c83f1c4a5 100644
--- a/eclass/wine.eclass
+++ b/eclass/wine.eclass
@@ -160,9 +160,11 @@ wine_src_prepare() {
 # to be passed: --prefix (and similar), --enable-archs, --enable-win64
 # --with-mingw, and --with-wine64
 #
-# Not truly supported, but cross toolchain can be customised using
-# CROSSCC, CROSSCC_amd64/x86/arm64, CROSSCFLAGS and CROSSLDFLAGS
-# (based on what wine's configure also recognize, or used to for CC).
+# Can adjust cross toolchain using CROSSCC, CROSSCC_amd64/x86/arm64,
+# CROSS{C,LD}FLAGS, and CROSS{C,LD}FLAGS_amd64/x86/arm64 (variable
+# naming is mostly historical because wine itself used to recognize
+# CROSSCC). By default it attempts to use same {C,LD}FLAGS as the
+# main toolchain but will strip known unsupported flags.
 wine_src_configure() {
 	WINE_PREFIX=/usr/lib/${P}
 	WINE_DATADIR=/usr/share/${P}
@@ -198,6 +200,10 @@ wine_src_configure() {
 		strip-unsupported-flags
 	fi
 
+	# wcc_* variables are used by _wine_flags(), see that
+	# function if need to adjust *FLAGS only for cross
+	local wcc_{amd64,x86,arm64}{,_testflags}
+	# TODO?: llvm-mingw support if ever packaged and wanted
 	if use mingw; then
 		conf+=( --with-mingw )
 
@@ -205,23 +211,24 @@ wine_src_configure() {
 			! has_version -b 'dev-util/mingw64-toolchain[bin-symlinks]' &&
 			PATH=${BROOT}/usr/lib/mingw64-toolchain/bin:${PATH}
 
-		# TODO?: llvm-mingw support if ever packaged and wanted
-		local wcc_amd64=${CROSSCC:-${CROSSCC_amd64:-x86_64-w64-mingw32-gcc}}
-		local wcc_x86=${CROSSCC:-${CROSSCC_x86:-i686-w64-mingw32-gcc}}
+		wcc_amd64=${CROSSCC:-${CROSSCC_amd64:-x86_64-w64-mingw32-gcc}}
+		wcc_x86=${CROSSCC:-${CROSSCC_x86:-i686-w64-mingw32-gcc}}
 		# no mingw64-toolchain ~arm64, but "may" be usable with crossdev
 		# (aarch64- rather than arm64- given it is what Wine searches for)
-		local wcc_arm64=${CROSSCC:-${CROSSCC_arm64:-aarch64-w64-mingw32-gcc}}
-		local -n wcc_test=wcc_$(usex arm64 arm64 $(usex abi_x86_64 amd64 x86))
+		wcc_arm64=${CROSSCC:-${CROSSCC_arm64:-aarch64-w64-mingw32-gcc}}
 	else
 		conf+=( --with-mingw=clang )
 
 		# not building for ${CHOST} so $(tc-getCC) is not quite right, but
-		# *should* support -target *-windows regardless
+		# *should* support -target *-windows regardless (testflags is only
+		# used by _wine_flags(), wine handles -target by itself)
 		tc-is-clang && local clang=$(tc-getCC) || local clang=clang
-		local wcc_amd64=${CROSSCC:-${CROSSCC_amd64:-${clang}}}
-		local wcc_x86=${CROSSCC:-${CROSSCC_x86:-${clang}}}
-		local wcc_arm64=${CROSSCC:-${CROSSCC_arm64:-${clang}}}
-		local wcc_test="${clang} -target $(usex arm64 aarch64 $(usex abi_x86_64 x86_64 i386))-windows"
+		wcc_amd64=${CROSSCC:-${CROSSCC_amd64:-${clang}}}
+		wcc_amd64_testflags="-target x86_64-windows"
+		wcc_x86=${CROSSCC:-${CROSSCC_x86:-${clang}}}
+		wcc_x86_testflags="-target i386-windows"
+		wcc_arm64=${CROSSCC:-${CROSSCC_arm64:-${clang}}}
+		wcc_arm64_testflags="-target aarch64-windows"
 
 		# do not copy from regular LDFLAGS given odds are they all are
 		# incompatible, and difficult to test linking without llvm-mingw
@@ -232,30 +239,33 @@ wine_src_configure() {
 		ac_cv_prog_x86_64_CC="${wcc_amd64}"
 		ac_cv_prog_i386_CC="${wcc_x86}"
 		ac_cv_prog_aarch64_CC="${wcc_arm64}"
-
-		CROSSCFLAGS="${CROSSCFLAGS:-$(
-			# many hardening options are unlikely to work right
-			filter-flags '-fstack-protector*' #870136
-			filter-flags '-mfunction-return=thunk*' #878849
-
-			# bashrc-mv users often do CFLAGS="${LDFLAGS}" and then
-			# compile-only tests miss stripping unsupported linker flags
-			filter-flags '-Wl,*'
-
-			# -mavx with mingw-gcc has a history of problems and still see
-			# users have issues despite Wine's -mpreferred-stack-boundary=2
-			use mingw && append-cflags -mno-avx
-
-			CC=${wcc_test} test-flags-CC ${CFLAGS:--O2}
-		)}"
-		CROSSLDFLAGS="${CROSSLDFLAGS:-$(
-			# let compiler figure out the right linker for cross
-			filter-flags '-fuse-ld=*'
-
-			CC=${wcc_test} test-flags-CCLD ${LDFLAGS}
-		)}"
 	)
 
+	if ver_test -ge 10; then
+		# TODO: merge with the av_cv array above when <wine-10 is gone
+		conf+=(
+			# if set, use CROSS*FLAGS as-is without filtering
+			x86_64_CFLAGS="${CROSSCFLAGS_amd64:-${CROSSCFLAGS:-$(_wine_flags c amd64)}}"
+			x86_64_LDFLAGS="${CROSSLDFLAGS_amd64:-${CROSSLDFLAGS:-$(_wine_flags ld amd64)}}"
+			i386_CFLAGS="${CROSSCFLAGS_x86:-${CROSSCFLAGS:-$(_wine_flags c x86)}}"
+			i386_LDFLAGS="${CROSSLDFLAGS_x86:-${CROSSLDFLAGS:-$(_wine_flags ld x86)}}"
+			aarch64_CFLAGS="${CROSSCFLAGS_arm64:-${CROSSCFLAGS:-$(_wine_flags c arm64)}}"
+			aarch64_LDFLAGS="${CROSSLDFLAGS_arm64:-${CROSSLDFLAGS:-$(_wine_flags ld arm64)}}"
+		)
+	elif use abi_x86_64; then
+		conf+=(
+			# per-arch flags are only respected with >=wine-9,
+			# do a one-arch best effort fallback
+			CROSSCFLAGS="${CROSSCFLAGS_amd64:-${CROSSCFLAGS:-$(_wine_flags c amd64)}}"
+			CROSSLDFLAGS="${CROSSLDFLAGS_amd64:-${CROSSLDFLAGS:-$(_wine_flags ld amd64)}}"
+		)
+	elif use abi_x86_32; then
+		conf+=(
+			CROSSCFLAGS="${CROSSCFLAGS_x86:-${CROSSCFLAGS:-$(_wine_flags c x86)}}"
+			CROSSLDFLAGS="${CROSSLDFLAGS_x86:-${CROSSLDFLAGS:-$(_wine_flags ld x86)}}"
+		)
+	fi
+
 	if use abi_x86_64 && use abi_x86_32 && use !wow64; then
 		# multilib dual build method for "old" wow64 (must do 64 first)
 		local bits
@@ -409,6 +419,46 @@ wine_pkg_postrm() {
 	fi
 }
 
+# @FUNCTION: _wine_flags
+# @USAGE: <c|ld> <arch>
+# @INTERNAL
+# @DESCRIPTION:
+# Filter and test current {C,LD}FLAGS for usage with the cross
+# toolchain (using ``wcc_*`` variables, see wine_src_configure),
+# and echo back working flags.
+#
+# Note that this ignores checking USE for simplicity, if compiler
+# is unusable (e.g. not found) then it will return empty flags
+# which is fine.
+_wine_flags() {
+	local -n wcc=wcc_${2} wccflags=wcc_${2}_testflags
+
+	case ${1} in
+		c)
+			# many hardening options are unlikely to work right
+			filter-flags '-fstack-protector*' #870136
+			filter-flags '-mfunction-return=thunk*' #878849
+
+			# bashrc-mv users often do CFLAGS="${LDFLAGS}" and then
+			# compile-only tests miss stripping unsupported linker flags
+			filter-flags '-Wl,*'
+
+			# -mavx with mingw-gcc has a history of problems and still see
+			# users have issues despite Wine's -mpreferred-stack-boundary=2
+			use mingw && append-cflags -mno-avx
+
+			# same as strip-unsupported-flags but echos only for CC
+			CC="${wcc} ${wccflags}" test-flags-CC ${CFLAGS}
+		;;
+		ld)
+			# let compiler figure out the right linker for cross
+			filter-flags '-fuse-ld=*'
+
+			CC="${wcc} ${wccflags}" test-flags-CCLD ${LDFLAGS}
+		;;
+	esac
+}
+
 fi
 
 EXPORT_FUNCTIONS pkg_pretend src_prepare src_configure src_compile src_install pkg_postinst pkg_postrm
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-27 10:52 Ionen Wolkens
  0 siblings, 0 replies; 6663+ messages in thread
From: Ionen Wolkens @ 2025-04-27 10:52 UTC (permalink / raw
  To: gentoo-commits
commit:     f8577f63f858ee47d88d7dac4c6e693fe07897a9
Author:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
AuthorDate: Sun Apr 27 10:49:18 2025 +0000
Commit:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
CommitDate: Sun Apr 27 10:49:35 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=f8577f63
wine.eclass: fix typo in comment
Signed-off-by: Ionen Wolkens <ionen <AT> gentoo.org>
 eclass/wine.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/wine.eclass b/eclass/wine.eclass
index 9cf9a1b443ee..1f5885d89c6f 100644
--- a/eclass/wine.eclass
+++ b/eclass/wine.eclass
@@ -255,7 +255,7 @@ wine_src_configure() {
 		)
 	elif use abi_x86_64; then
 		conf+=(
-			# per-arch flags are only respected with >=wine-9,
+			# per-arch flags are only respected with >=wine-10,
 			# do a one-arch best effort fallback
 			CROSSCFLAGS="${CROSSCFLAGS_amd64:-${CROSSCFLAGS:-$(_wine_flags c amd64)}}"
 			CROSSLDFLAGS="${CROSSLDFLAGS_amd64:-${CROSSLDFLAGS:-$(_wine_flags ld amd64)}}"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-27 13:17 Ionen Wolkens
  0 siblings, 0 replies; 6663+ messages in thread
From: Ionen Wolkens @ 2025-04-27 13:17 UTC (permalink / raw
  To: gentoo-commits
commit:     43f4f47e30691eaf374714fbe5c5d4927da756a3
Author:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
AuthorDate: Sun Apr 27 13:08:14 2025 +0000
Commit:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
CommitDate: Sun Apr 27 13:16:50 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=43f4f47e
ffmpeg-compat.eclass: fix typo
Signed-off-by: Ionen Wolkens <ionen <AT> gentoo.org>
 eclass/ffmpeg-compat.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/ffmpeg-compat.eclass b/eclass/ffmpeg-compat.eclass
index 1835a8c7e95a..ce8878d10c55 100644
--- a/eclass/ffmpeg-compat.eclass
+++ b/eclass/ffmpeg-compat.eclass
@@ -10,7 +10,7 @@
 # @BLURB: Helper functions to link with slotted ffmpeg-compat libraries
 # @DESCRIPTION:
 # To use this, run ``ffmpeg_compat_setup <slot>`` before packages use
-# pkg-config, depend on media-video/ffmpeg-compat:<slot>=, and ensure
+# pkg-config, depend on media-video/ffmpeg-compat:<slot>, and ensure
 # usage of both pkg-config --cflags and --libs (which adds -Wl,-rpath
 # to find libraries at runtime).  Always verify that it is linked with
 # the right libraries after.
^ permalink raw reply related	[flat|nested] 6663+ messages in thread
* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-04-27 22:53 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-04-27 22:53 UTC (permalink / raw
  To: gentoo-commits
commit:     6a3c96862f287e1f1c9040846293e04dde199810
Author:     Alfred Wingate <parona <AT> protonmail <DOT> com>
AuthorDate: Sun Apr 27 14:56:01 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Apr 27 22:52:27 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=6a3c9686
gstreamer-meson.eclass: enable py3.13
Closes: https://bugs.gentoo.org/951610
Signed-off-by: Alfred Wingate <parona <AT> protonmail.com>
Part-of: https://github.com/gentoo/gentoo/pull/41795
Closes: https://github.com/gentoo/gentoo/pull/41795
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/gstreamer-meson.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/gstreamer-meson.eclass b/eclass/gstreamer-meson.eclass
index 15b0a6390a42..1f43749baed3 100644
--- a/eclass/gstreamer-meson.eclass
+++ b/eclass/gstreamer-meson.eclass
@@ -35,7 +35,7 @@ case "${EAPI:-0}" in
 		;;
 esac
 
-PYTHON_COMPAT=( python3_{10..12} )
+PYTHON_COMPAT=( python3_{10..13} )
 [[ ${EAPI} == 8 ]] && inherit python-any-r1
 
 # multilib-minimal goes last
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-05-01 11:36 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-05-01 11:36 UTC (permalink / raw
  To: gentoo-commits
commit:     cb29d30827b95294692cfbdc471dbd7d201ce0ea
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Tue Apr 22 10:42:03 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Thu May  1 11:36:15 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=cb29d308
distutils-r1.eclass: Remove obsolete PyPy 3.10 code
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
Part-of: https://github.com/gentoo/gentoo/pull/41697
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/distutils-r1.eclass | 1 -
 1 file changed, 1 deletion(-)
diff --git a/eclass/distutils-r1.eclass b/eclass/distutils-r1.eclass
index 02fe41aa388f..880e33cd741f 100644
--- a/eclass/distutils-r1.eclass
+++ b/eclass/distutils-r1.eclass
@@ -1717,7 +1717,6 @@ distutils-r1_python_install() {
 		# python likes to compile any module it sees, which triggers sandbox
 		# failures if some packages haven't compiled their modules yet.
 		addpredict "${EPREFIX}/usr/lib/${EPYTHON}"
-		addpredict "${EPREFIX}/usr/lib/pypy3.10"
 		addpredict "${EPREFIX}/usr/local" # bug 498232
 
 		if [[ ! ${DISTUTILS_SINGLE_IMPL} ]]; then
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-05-02 16:01 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-05-02 16:01 UTC (permalink / raw
  To: gentoo-commits
commit:     ab3254155cec0944b6f0fa0916ec52d72ac3425b
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Fri May  2 15:43:15 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Fri May  2 16:01:01 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=ab325415
kernel-build.eclass: Remove py3.10 from PYTHON_COMPAT
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/kernel-build.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/kernel-build.eclass b/eclass/kernel-build.eclass
index ee4cf1413a60..b4e29a58bc48 100644
--- a/eclass/kernel-build.eclass
+++ b/eclass/kernel-build.eclass
@@ -36,7 +36,7 @@ esac
 if [[ -z ${_KERNEL_BUILD_ECLASS} ]]; then
 _KERNEL_BUILD_ECLASS=1
 
-PYTHON_COMPAT=( python3_{10..13} )
+PYTHON_COMPAT=( python3_{11..13} )
 if [[ ${KERNEL_IUSE_MODULES_SIGN} ]]; then
 	inherit secureboot
 fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-05-03  5:28 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-05-03  5:28 UTC (permalink / raw
  To: gentoo-commits
commit:     36d4028db62cee4a64ea56c0b3273528957a0c4e
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat May  3 05:27:03 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat May  3 05:27:03 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=36d4028d
qt5-build.eclass: disable reduce-relocations
For Qt 5, it's best to just disable reduce-relocations, because it
doesn't (unlike Qt 6) support -mno-direct-extern-access, which means
CMake applications building against Qt 5 are prone to all the issues
mentioned in the bug.
Bug: https://bugs.gentoo.org/754021
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/qt5-build.eclass | 10 +++++-----
 1 file changed, 5 insertions(+), 5 deletions(-)
diff --git a/eclass/qt5-build.eclass b/eclass/qt5-build.eclass
index 1a0335b9d2b6..7f79cd8e4063 100644
--- a/eclass/qt5-build.eclass
+++ b/eclass/qt5-build.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2024 Gentoo Authors
+# Copyright 1999-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: qt5-build.eclass
@@ -679,10 +679,10 @@ qt5_base_configure() {
 		# link-time code generation is not something we want to enable by default
 		-no-ltcg
 
-		# reduced relocations cause major breakage on at least arm and ppc, so
-		# don't specify anything and let the configure figure out if they are
-		# supported; see also https://bugreports.qt.io/browse/QTBUG-36129
-		#-reduce-relocations
+		# Qt 5 doesn't support -mno-direct-extern-access, so uses
+		# -Bsymbolic, which causes issues for consumers if not linking
+		# corectly (bug #754021).
+		-no-reduce-relocations
 
 		# use the system linker (gold will be selected automagically otherwise)
 		$(tc-ld-is-gold && echo -use-gold-linker || echo -no-use-gold-linker)
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-05-03 19:42 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-05-03 19:42 UTC (permalink / raw
  To: gentoo-commits
commit:     c5ccc7350f5a146f0525df482ad7e993cb7997f9
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat May  3 19:30:31 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat May  3 19:41:51 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=c5ccc735
Add 21.0.0_pre20250503 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index b4c9e252685b..30519d337629 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -72,6 +72,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 			_LLVM_SOURCE_TYPE=snapshot
 
 			case ${PV} in
+				21.0.0_pre20250503)
+					EGIT_COMMIT=d1e38eab95b07b422194427474521623916bbf29
+					;;
 				21.0.0_pre20250426)
 					EGIT_COMMIT=b9e32749d273a957e60170d6e7ef205fd1fb1834
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-05-05 15:32 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-05-05 15:32 UTC (permalink / raw
  To: gentoo-commits
commit:     a3b3428e8a96ff4541f9193c2c70c6cb492bdc4c
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon May  5 15:31:43 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon May  5 15:32:19 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=a3b3428e
toolchain.eclass: pass -fno-stack-protector for HPPA GNAT bootstrap
For HPPA, the ada-bootstrap binaries seem to default to -fstack-protector still
(maybe because of cross-building) so we need to override it for <13
(which ignores -fstack-protector) as SSP doesn't exist there. The GNAT
configure test gets confused by GCC warning about this otherwise.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 9 +++++++++
 1 file changed, 9 insertions(+)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 93d4792af4d6..a0085b22d659 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -2345,6 +2345,15 @@ gcc_do_make() {
 			STAGE1_CFLAGS="-O2"
 			STAGE1_CXXFLAGS="-O2"
 			STAGE1_GDCFLAGS="-O2"
+
+			if ver_test $(gcc-fullversion) -lt 13 && [[ ${CTARGET} == hppa* ]] ; then
+				# For HPPA, the ada-bootstrap binaries seem to default
+				# to -fstack-protector still (maybe because of cross-building)
+				# so we need to override it for <13 (which ignores -fstack-protector)
+				# as SSP doesn't exist there. The GNAT configure test gets confused
+				# by GCC warning about this otherwise.
+				STAGE1_CFLAGS+=" -fno-stack-protector"
+			fi
 		fi
 
 		# We only want to use the system's CFLAGS if not building a
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-05-05 15:45 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-05-05 15:45 UTC (permalink / raw
  To: gentoo-commits
commit:     12e4c095bcab11d29aa9808ec150c90437d9d950
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon May  5 15:44:33 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon May  5 15:44:33 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=12e4c095
toolchain.eclass: move hppa workaround to CC
... as it must always be passed whenever -specs is.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 18 +++++++++---------
 1 file changed, 9 insertions(+), 9 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index a0085b22d659..b4a4124ce8fe 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1139,6 +1139,15 @@ toolchain_setup_ada() {
 	! tc-is-cross-compiler && _toolchain_make_gnat_wrappers
 
 	export CC="$(tc-getCC) -specs=${T}/ada.spec"
+
+	if ver_test $(gcc-fullversion) -lt 13 && [[ ${CTARGET} == hppa* ]] ; then
+		# For HPPA, the ada-bootstrap binaries seem to default
+		# to -fstack-protector still (maybe because of cross-building)
+		# so we need to override it for <13 (which ignores -fstack-protector)
+		# as SSP doesn't exist there. The GNAT configure test gets confused
+		# by GCC warning about this otherwise.
+		CC+=" -fno-stack-protector"
+	fi
 }
 
 # @FUNCTION: toolchain_setup_d
@@ -2345,15 +2354,6 @@ gcc_do_make() {
 			STAGE1_CFLAGS="-O2"
 			STAGE1_CXXFLAGS="-O2"
 			STAGE1_GDCFLAGS="-O2"
-
-			if ver_test $(gcc-fullversion) -lt 13 && [[ ${CTARGET} == hppa* ]] ; then
-				# For HPPA, the ada-bootstrap binaries seem to default
-				# to -fstack-protector still (maybe because of cross-building)
-				# so we need to override it for <13 (which ignores -fstack-protector)
-				# as SSP doesn't exist there. The GNAT configure test gets confused
-				# by GCC warning about this otherwise.
-				STAGE1_CFLAGS+=" -fno-stack-protector"
-			fi
 		fi
 
 		# We only want to use the system's CFLAGS if not building a
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-05-05 15:56 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-05-05 15:56 UTC (permalink / raw
  To: gentoo-commits
commit:     524897aa59ee794c55efd0c341c65163aa673455
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon May  5 15:55:09 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon May  5 15:55:09 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=524897aa
toolchain.eclass: check current version for HPPA workaround
As the GCC version being used for stage1 may not be the version we think
it is with the bootstrap compiler (i.e. $(gcc-full-version) may not
reflect what we're using because of ada-bootstrap).
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index b4a4124ce8fe..6d76823fb549 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1140,7 +1140,7 @@ toolchain_setup_ada() {
 
 	export CC="$(tc-getCC) -specs=${T}/ada.spec"
 
-	if ver_test $(gcc-fullversion) -lt 13 && [[ ${CTARGET} == hppa* ]] ; then
+	if ver_test ${PV} -lt 13 && [[ ${CTARGET} == hppa* ]] ; then
 		# For HPPA, the ada-bootstrap binaries seem to default
 		# to -fstack-protector still (maybe because of cross-building)
 		# so we need to override it for <13 (which ignores -fstack-protector)
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-05-06 17:41 Eli Schwartz
  0 siblings, 0 replies; 6663+ messages in thread
From: Eli Schwartz @ 2025-05-06 17:41 UTC (permalink / raw
  To: gentoo-commits
commit:     a13d692939efda7afb29c1d8a2cb1d5717972b89
Author:     Eli Schwartz <eschwartz <AT> gentoo <DOT> org>
AuthorDate: Tue May  6 15:53:40 2025 +0000
Commit:     Eli Schwartz <eschwartz <AT> gentoo <DOT> org>
CommitDate: Tue May  6 17:40:28 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=a13d6929
flag-o-matic.eclass: allow -ffat-lto-objects in strip-flags
This flag is "safe" for the same reason `-flto` is "safe". Furthermore,
the new dot-a.eclass relies on setting this flag, which `strip-flags` then
deletes again in the event that a package uses both `lto-guarantee-fat` and
`strip-flags`.
End result: static libraries that contain neither LTO nor regular object
code.
Example package that does this: dev-libs/nss
Acked-by: Sam James <sam <AT> gentoo.org>
Signed-off-by: Eli Schwartz <eschwartz <AT> gentoo.org>
 eclass/flag-o-matic.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/flag-o-matic.eclass b/eclass/flag-o-matic.eclass
index 85274c91121f..f22854c646c7 100644
--- a/eclass/flag-o-matic.eclass
+++ b/eclass/flag-o-matic.eclass
@@ -46,7 +46,7 @@ setup-allowed-flags() {
 _setup-allowed-flags() {
 	ALLOWED_FLAGS=(
 		-pipe -O '-O[123szg]' '-mcpu=*' '-march=*' '-mtune=*' '-mfpmath=*'
-		-flto '-flto=*' -fno-lto
+		-flto '-flto=*' -fno-lto -ffat-lto-objects
 
 		# Hardening flags
 		'-fstack-protector*'
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-05-08 12:35 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-05-08 12:35 UTC (permalink / raw
  To: gentoo-commits
commit:     aff1a7696b6fe7b83374ea20c2e08772b7186cc2
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Tue May  6 09:18:06 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Thu May  8 12:32:48 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=aff1a769
python-utils-r1.eclass: Switch python_optimize to use -s
Switch `python_optimize()` to use a combination of `-s` and `-p` options
instead of `-d`, since the latter does not seem to work correctly
in some cases, e.g. with `www-servers/uwsgi`:
```
The stripdir path '/tmp/portage/www-servers/uwsgi-2.0.27/image/usr/lib/python3.13/site-packages/' is not a valid prefix for source path '/tmp/portage/www-servers/uwsgi-2.0.27/image/usr/lib/python3.13/site-packages/uwsgidecorators.py'; ignoring
```
These options are supported in all Python versions the eclasses
currently do support.
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/python-utils-r1.eclass | 8 +++-----
 1 file changed, 3 insertions(+), 5 deletions(-)
diff --git a/eclass/python-utils-r1.eclass b/eclass/python-utils-r1.eclass
index b61bf730b8c4..4fedd2b8a790 100644
--- a/eclass/python-utils-r1.eclass
+++ b/eclass/python-utils-r1.eclass
@@ -624,13 +624,11 @@ python_optimize() {
 	local jobs=$(makeopts_jobs)
 	local d
 	for d; do
-		# make sure to get a nice path without //
-		local instpath=${d#${D}}
-		instpath=/${instpath##/}
-
 		einfo "Optimize Python modules for ${instpath}"
+		# NB: '-s' makes the path relative, so we need '-p /' to make it
+		# absolute again; https://github.com/python/cpython/issues/133503
 		"${PYTHON}" -m compileall -j "${jobs}" -o 0 -o 1 -o 2 \
-			--hardlink-dupes -q -f -d "${instpath}" "${d}"
+			--hardlink-dupes -q -f -s "${D}" -p / "${d}"
 	done
 }
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-05-08 12:35 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-05-08 12:35 UTC (permalink / raw
  To: gentoo-commits
commit:     327899889ff0d4841870c0a81fa5adaa4b3fada0
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Tue May  6 09:00:03 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Thu May  8 12:32:47 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=32789988
python-utils-r1.eclass: Remove old code paths for python_optimize
Remove the old code paths that used to provide `python_optimize()`
for Python 3.8 and Python 2.7 / PyPy.  I thought we were keeping them
for dev-lang/pypy ebuilds but apparently we're calling compileall
directly there.
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/python-utils-r1.eclass | 20 ++------------------
 1 file changed, 2 insertions(+), 18 deletions(-)
diff --git a/eclass/python-utils-r1.eclass b/eclass/python-utils-r1.eclass
index 3a4a3f19a1be..b61bf730b8c4 100644
--- a/eclass/python-utils-r1.eclass
+++ b/eclass/python-utils-r1.eclass
@@ -629,24 +629,8 @@ python_optimize() {
 		instpath=/${instpath##/}
 
 		einfo "Optimize Python modules for ${instpath}"
-		case "${EPYTHON}" in
-			python3.8)
-				# both levels of optimization are separate since 3.5
-				"${PYTHON}" -m compileall -j "${jobs}" -q -f -d "${instpath}" "${d}"
-				"${PYTHON}" -O -m compileall -j "${jobs}" -q -f -d "${instpath}" "${d}"
-				"${PYTHON}" -OO -m compileall -j "${jobs}" -q -f -d "${instpath}" "${d}"
-				;;
-			python*|pypy3*)
-				# Python 3.9+
-				"${PYTHON}" -m compileall -j "${jobs}" -o 0 -o 1 -o 2 --hardlink-dupes -q -f -d "${instpath}" "${d}"
-				;;
-			pypy|jython2.7)
-				"${PYTHON}" -m compileall -q -f -d "${instpath}" "${d}"
-				;;
-			*)
-				die "${FUNCNAME}: unexpected EPYTHON=${EPYTHON}"
-				;;
-		esac
+		"${PYTHON}" -m compileall -j "${jobs}" -o 0 -o 1 -o 2 \
+			--hardlink-dupes -q -f -d "${instpath}" "${d}"
 	done
 }
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-05-08 12:35 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-05-08 12:35 UTC (permalink / raw
  To: gentoo-commits
commit:     692aa86d5794a44b765bd95be3c3557a1288239a
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat May  3 05:35:11 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Thu May  8 12:29:18 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=692aa86d
distutils-r1.eclass: Quote DISTUTILS_ALLOW_WHEEL_REUSE
Reported-by: Ionen Wolkens <ionen <AT> gentoo.org>
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/distutils-r1.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/distutils-r1.eclass b/eclass/distutils-r1.eclass
index 880e33cd741f..799206f7eb03 100644
--- a/eclass/distutils-r1.eclass
+++ b/eclass/distutils-r1.eclass
@@ -215,7 +215,7 @@
 # This is an optimization that can avoid the overhead of calling into
 # the build system in pure Python packages and packages using the stable
 # Python ABI.
-: ${DISTUTILS_ALLOW_WHEEL_REUSE=1}
+: "${DISTUTILS_ALLOW_WHEEL_REUSE=1}"
 
 # @ECLASS_VARIABLE: BUILD_DIR
 # @OUTPUT_VARIABLE
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-05-08 12:35 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-05-08 12:35 UTC (permalink / raw
  To: gentoo-commits
commit:     6cbb421176a66579552a24a722a5b68230c92ec3
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Fri May  2 18:36:42 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Thu May  8 12:29:17 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=6cbb4211
python-utils-r1.eclass: Simplify _python_impl_matches
Remove special case for '3.10' in _python_impl_matches -- it was only
necessary because we needed to handle 'pypy3' target specially,
and that is no longer the case.  Technically, the code checks for
'pypy3_10' but that's not a problem, since there is no such a thing.
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/python-utils-r1.eclass | 4 +---
 1 file changed, 1 insertion(+), 3 deletions(-)
diff --git a/eclass/python-utils-r1.eclass b/eclass/python-utils-r1.eclass
index ef05a58e1b13..3a4a3f19a1be 100644
--- a/eclass/python-utils-r1.eclass
+++ b/eclass/python-utils-r1.eclass
@@ -230,9 +230,7 @@ _python_impl_matches() {
 				fi
 				return 0
 				;;
-			3.10)
-				;;
-			3.8|3.9|3.1[1-3])
+			3.[89]|3.1[0-3])
 				[[ ${impl%t} == python${pattern/./_} || ${impl} == pypy${pattern/./_} ]] &&
 					return 0
 				;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-05-10  1:54 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-05-10  1:54 UTC (permalink / raw
  To: gentoo-commits
commit:     ff1f410ec18385497f00dd86f2a64d60b1ed4b1a
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat May 10 01:52:52 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat May 10 01:53:27 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=ff1f410e
toolchain.eclass: set QA_PRESTRIPPED for now for Go
As slyfox analysed on the bug, Portage shouldn't be warning on these
files as they're not executables. We should look at fixing Portage
but set QA_PRESTRIPPED for now to avoid noise and potentially missing
other actual warnings.
Bug: https://bugs.gentoo.org/793770
Closes: https://bugs.gentoo.org/795810
Closes: https://bugs.gentoo.org/955240
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 2 ++
 1 file changed, 2 insertions(+)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 6d76823fb549..f0a0b377dc56 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -2789,6 +2789,8 @@ toolchain_src_install() {
 	# Don't scan .gox files for executable stacks - false positives
 	export QA_EXECSTACK="usr/lib*/go/*/*.gox"
 	export QA_WX_LOAD="usr/lib*/go/*/*.gox"
+	# Workaround bug #793770
+	export QA_PRESTRIPPED="usr/lib*/go/*/*.gox"
 
 	# Disable RANDMMAP so PCH works, bug #301299
 	pax-mark -r "${ED}/libexec/gcc/${CTARGET}/${GCC_CONFIG_VER}/cc1"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-05-10 12:57 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-05-10 12:57 UTC (permalink / raw
  To: gentoo-commits
commit:     f2cc9eb192a986d517b341785031e233f7b3b0b2
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat May 10 12:45:37 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat May 10 12:57:15 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=f2cc9eb1
distutils-r1.eclass: Allow DISTUTILS_UPSTREAM_PEP517=standalone
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/distutils-r1.eclass | 35 +++++++++++++++++++++++++++++------
 1 file changed, 29 insertions(+), 6 deletions(-)
diff --git a/eclass/distutils-r1.eclass b/eclass/distutils-r1.eclass
index d32e5929177e..7dfc8c7a3c30 100644
--- a/eclass/distutils-r1.eclass
+++ b/eclass/distutils-r1.eclass
@@ -134,13 +134,20 @@
 #
 # - sip - sipbuild backend
 #
-# - standalone - standalone build systems without external deps
-#   (used for bootstrapping).
+# - standalone - standalone/local build systems
 #
 # - uv-build - uv-build backend (using dev-python/uv)
 #
-# The variable needs to be set before the inherit line.  The eclass
-# adds appropriate build-time dependencies and verifies the value.
+# The variable needs to be set before the inherit line.  If another
+# value than "standalone" and "no" is used, The eclass adds appropriate
+# build-time dependencies, verifies the value and calls the appropriate
+# modern entry point for the backend.  With DISTUTILS_UPSTREAM_PEP517,
+# this variable can be used to override the upstream build backend.
+#
+# The value of "standalone" indicates that upstream is using a custom,
+# local build backend.  In this mode, the eclass does not add any
+# dependencies, disables build backend verification and uses the exact
+# entry point listed in pyproject.toml.
 #
 # The special value "no" indicates that the package has no build system.
 # This is not equivalent to unset DISTUTILS_USE_PEP517 (legacy mode).
@@ -162,6 +169,12 @@
 # overriden to workaround the eclass check, when it is desirable
 # to build the wheel using other backend than the one used upstream.
 #
+# When using it, ideally it should list the build backend actually used
+# upstream, so the eclass will throw an error if that backend changes
+# (and therefore overrides may need to change as well).  As a special
+# case, setting it to "standalone" disables the check entirely (while
+# still forcing the backend, unlike DISTUTILS_USE_PEP517=standalone).
+#
 # Please note that even in packages using PEP621 metadata, there can
 # be subtle differences between the behavior of different PEP517 build
 # backends, for example regarding finding package files.  When using
@@ -1150,11 +1163,23 @@ _distutils-r1_get_backend() {
 		fi
 	fi
 
+	# if DISTUTILS_USE_PEP517 is "standalone", we respect the exact
+	# backend used in pyproject.toml; otherwise we force the backend
+	# based on DISTUTILS_USE_PEP517
 	if [[ ${DISTUTILS_USE_PEP517} == standalone ]]; then
 		echo "${build_backend}"
 		return
 	fi
 
+	# we can output it early, even if we die below
+	echo "$(_distutils-r1_key_to_backend "${DISTUTILS_USE_PEP517}")"
+
+	# skip backend verification if DISTUTILS_UPSTREAM_PEP517
+	# is "standalone"
+	if [[ ${DISTUTILS_UPSTREAM_PEP517} == standalone ]]; then
+		return
+	fi
+
 	# verify that the ebuild correctly specifies the build backend
 	local expected_backend=$(
 		_distutils-r1_key_to_backend \
@@ -1189,8 +1214,6 @@ _distutils-r1_get_backend() {
 			> "${T}"/.distutils_deprecated_backend_warned || die
 		fi
 	fi
-
-	echo "$(_distutils-r1_key_to_backend "${DISTUTILS_USE_PEP517}")"
 }
 
 # @FUNCTION: distutils_wheel_install
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-05-10 12:57 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-05-10 12:57 UTC (permalink / raw
  To: gentoo-commits
commit:     3adc7e900eba944aafa51675355df21de79be358
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat May 10 12:27:49 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat May 10 12:57:14 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=3adc7e90
distutils-r1.eclass: Fix pyvenv correctly for Python 3.14
Python 3.14 cleaned up the venv logic, and we have been apparently
relying on some hacks that worked by accident.  More specifically:
1. pyvenv.cfg location is used explicitly as sys.prefix, so we can
   no longer put it inside bin/ subdirectory (no clue why we did that
   -- probably a long chain of historical reasons).
2. "home =" must always be present for venv detection to work.
With these changes, Python 3.14 seems now able to correctly detect
the venv and set prefixes accordingly.  Since they improve correctness,
they should also be fine for other Python versions.
Apparently, the pyvenv.cfg file was moved into bindir back in 2022,
for the trivial reason of using a single directory for all created
files.  Mea culpa!
Fixes: d5b7d1b42500509d31a385fbae77facab02769b7
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/distutils-r1.eclass | 10 ++++++----
 1 file changed, 6 insertions(+), 4 deletions(-)
diff --git a/eclass/distutils-r1.eclass b/eclass/distutils-r1.eclass
index cced2b8ffef7..d32e5929177e 100644
--- a/eclass/distutils-r1.eclass
+++ b/eclass/distutils-r1.eclass
@@ -1662,7 +1662,7 @@ distutils-r1_python_install() {
 		# let's explicitly verify these assumptions
 
 		# remove files that we've created explicitly
-		rm "${reg_scriptdir}"/{"${EPYTHON}",python3,python,pyvenv.cfg} || die
+		rm "${reg_scriptdir}"/{"${EPYTHON}",python3,python,../pyvenv.cfg} || die
 
 		# Automagically do the QA check to avoid issues when bootstrapping
 		# prefix.
@@ -2030,9 +2030,11 @@ _distutils-r1_post_python_compile() {
 		ln -s "${PYTHON}" "${bindir}/${EPYTHON}" || die
 		ln -s "${EPYTHON}" "${bindir}/python3" || die
 		ln -s "${EPYTHON}" "${bindir}/python" || die
-		# python3.14t seems to require "home" being present
-		# (though it does not seem to care about the actual value)
-		cat > "${bindir}"/pyvenv.cfg <<-EOF || die
+		# python3.14 changed venv logic so that:
+		# 1) pyvenv.cfg location explicitly determines prefix
+		#    (i.e. we no longer can be put in bin/)
+		# 2) "home =" key must be present
+		cat > "${bindir}"/../pyvenv.cfg <<-EOF || die
 			home = ${EPREFIX}/usr/bin
 			include-system-site-packages = true
 		EOF
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-05-10 13:03 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-05-10 13:03 UTC (permalink / raw
  To: gentoo-commits
commit:     6a1ca7dee4d385efa69f00ef6cf1f4bfc675948f
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat May 10 12:58:43 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat May 10 12:58:43 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=6a1ca7de
Add 21.0.0_pre20250510 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index 30519d337629..a1c252f2cbf7 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -72,6 +72,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 			_LLVM_SOURCE_TYPE=snapshot
 
 			case ${PV} in
+				21.0.0_pre20250510)
+					EGIT_COMMIT=fcb4bda9dcfcdb64d8b069e8416c75d7a1a62e52
+					;;
 				21.0.0_pre20250503)
 					EGIT_COMMIT=d1e38eab95b07b422194427474521623916bbf29
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-05-10 20:04 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-05-10 20:04 UTC (permalink / raw
  To: gentoo-commits
commit:     e45c2d0d0a9f22439eb2fcd1c99235ba6d1070a2
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat May 10 18:52:29 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat May 10 18:52:29 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=e45c2d0d
distutils-r1.eclass: workaround bash-5.3* bug
Bug: https://lists.gnu.org/archive/html/bug-bash/2025-05/msg00005.html
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/distutils-r1.eclass | 3 ++-
 1 file changed, 2 insertions(+), 1 deletion(-)
diff --git a/eclass/distutils-r1.eclass b/eclass/distutils-r1.eclass
index 7dfc8c7a3c30..62e092b6231f 100644
--- a/eclass/distutils-r1.eclass
+++ b/eclass/distutils-r1.eclass
@@ -1685,7 +1685,8 @@ distutils-r1_python_install() {
 		# let's explicitly verify these assumptions
 
 		# remove files that we've created explicitly
-		rm "${reg_scriptdir}"/{"${EPYTHON}",python3,python,../pyvenv.cfg} || die
+		rm "${reg_scriptdir}"/{"${EPYTHON}",python3,python} || die
+		rm "${reg_scriptdir}"/../pyvenv.cfg || die
 
 		# Automagically do the QA check to avoid issues when bootstrapping
 		# prefix.
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-05-11  4:34 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-05-11  4:34 UTC (permalink / raw
  To: gentoo-commits
commit:     abbb1a0e6aabd91d6d4c71216b6b9e20d25322d1
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun May 11 04:01:19 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun May 11 04:34:08 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=abbb1a0e
toolchain.eclass: tweak Go path for QA_PRESTRIPPED
Not sure if the others are right or obsolete now, or what, but
for me, the "prestripped" (but not) files are at e.g.
usr/lib/go/15/x86_64-pc-linux-gnu/crypto.gox.
Followup to ff1f410ec18385497f00dd86f2a64d60b1ed4b1a.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index f0a0b377dc56..2d903f992b17 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -2790,7 +2790,7 @@ toolchain_src_install() {
 	export QA_EXECSTACK="usr/lib*/go/*/*.gox"
 	export QA_WX_LOAD="usr/lib*/go/*/*.gox"
 	# Workaround bug #793770
-	export QA_PRESTRIPPED="usr/lib*/go/*/*.gox"
+	export QA_PRESTRIPPED="usr/lib*/go/*/*/*.gox"
 
 	# Disable RANDMMAP so PCH works, bug #301299
 	pax-mark -r "${ED}/libexec/gcc/${CTARGET}/${GCC_CONFIG_VER}/cc1"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-05-15  7:11 Arsen Arsenović
  0 siblings, 0 replies; 6663+ messages in thread
From: Arsen Arsenović @ 2025-05-15  7:11 UTC (permalink / raw
  To: gentoo-commits
commit:     78beda50cf5b46f553803b31e294569a1317aa1b
Author:     hololeap <hololeap <AT> protonmail <DOT> com>
AuthorDate: Sat Apr 12 17:41:40 2025 +0000
Commit:     Arsen Arsenović <arsen <AT> gentoo <DOT> org>
CommitDate: Thu May 15 07:09:53 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=78beda50
haskell-cabal.eclass: Output ghc version in src_configure
This will provide valuable ghc version info in build logs
Signed-off-by: hololeap <hololeap <AT> protonmail.com>
Part-of: https://github.com/gentoo/gentoo/pull/41562
Signed-off-by: Arsen Arsenović <arsen <AT> gentoo.org>
 eclass/haskell-cabal.eclass | 2 ++
 1 file changed, 2 insertions(+)
diff --git a/eclass/haskell-cabal.eclass b/eclass/haskell-cabal.eclass
index 2e77bc648b16..e228d7fbc1bc 100644
--- a/eclass/haskell-cabal.eclass
+++ b/eclass/haskell-cabal.eclass
@@ -711,6 +711,8 @@ haskell-cabal_src_prepare() {
 }
 
 haskell-cabal_src_configure() {
+	einfo "GHC version: $(ghc-version) $(ghc-pm-version)"
+
 	cabal-is-dummy-lib && return
 
 	pushd "${S}" > /dev/null || die
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-05-15  7:11 Arsen Arsenović
  0 siblings, 0 replies; 6663+ messages in thread
From: Arsen Arsenović @ 2025-05-15  7:11 UTC (permalink / raw
  To: gentoo-commits
commit:     8ae4c6d315b09451163b0f8fdc95b52ce1f1374c
Author:     hololeap <hololeap <AT> protonmail <DOT> com>
AuthorDate: Sat Apr 12 17:41:40 2025 +0000
Commit:     Arsen Arsenović <arsen <AT> gentoo <DOT> org>
CommitDate: Thu May 15 07:09:53 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=8ae4c6d3
haskell-cabal.eclass: Add early check for invalid GHC cache
If the GHC cache is invalid, it can create a confusing error during
src_compile. Add a check in haskell-cabal-pkg_setup that checks for
and fixes an invalid cache.
Closes: https://bugs.gentoo.org/916785
Closes: https://bugs.gentoo.org/916971
Closes: https://bugs.gentoo.org/920879
Closes: https://github.com/gentoo-haskell/gentoo-haskell/issues/1469
Thanks-to: Tom Gillespie <tgbugs <AT> gmail.com>
Signed-off-by: hololeap <hololeap <AT> protonmail.com>
Part-of: https://github.com/gentoo/gentoo/pull/41562
Closes: https://github.com/gentoo/gentoo/pull/41562
Signed-off-by: Arsen Arsenović <arsen <AT> gentoo.org>
 eclass/haskell-cabal.eclass | 24 ++++++++++++++++++++++++
 1 file changed, 24 insertions(+)
diff --git a/eclass/haskell-cabal.eclass b/eclass/haskell-cabal.eclass
index e228d7fbc1bc..bb73c0e4881d 100644
--- a/eclass/haskell-cabal.eclass
+++ b/eclass/haskell-cabal.eclass
@@ -661,6 +661,23 @@ cabal-is-dummy-lib() {
 	return 1
 }
 
+# @FUNCTION: cabal-check-cache
+# @DESCRIPTION:
+# Check the state of the GHC cache by running 'ghc-pkg check' and looking
+# for the string "WARNING: cache is out of date". If the string is not found,
+# the cache is considered valid and the function returns 0. If it is found,
+# the cache is considered invalid and the function returns 1.
+cabal-check-cache() {
+	if $(ghc-getghcpkg) check 2>&1 \
+		| grep -q 'WARNING: cache is out of date'
+	then
+		ewarn 'GHC cache is out of date!'
+		return 1
+	else
+		return 0
+	fi
+}
+
 # exported function: check if cabal is correctly installed for
 # the currently active ghc (we cannot guarantee this with portage)
 haskell-cabal_pkg_setup() {
@@ -672,6 +689,13 @@ haskell-cabal_pkg_setup() {
 	fi
 	if cabal-is-dummy-lib; then
 		einfo "${P} is included in ghc-${CABAL_CORE_LIB_GHC_PV}, nothing to install."
+	else
+		# bug 916785
+		if ! cabal-check-cache; then
+			# avoid running ghc-recache-db so as not to set _GHC_RECACHE_CALLED
+			einfo "Recaching GHC package DB"
+			$(ghc-getghcpkg) recache
+		fi
 	fi
 }
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-05-15  7:11 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-05-15  7:11 UTC (permalink / raw
  To: gentoo-commits
commit:     fa1b0ff46e9a6039cf6d205b22250ca72ae5ab56
Author:     Alfred Wingate <parona <AT> protonmail <DOT> com>
AuthorDate: Wed May 14 00:53:57 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu May 15 07:11:02 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=fa1b0ff4
dot-a.eclass: exit early if static-libs use disabled
Otherwise it will try to run inside the build directory if there is a
static-libs use flag which is disabled.
llvm-bitcode-strip: error: './build/obj/lib/x509_x509path.o': The file was not recognized as a valid object file
Signed-off-by: Alfred Wingate <parona <AT> protonmail.com>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/dot-a.eclass | 2 ++
 1 file changed, 2 insertions(+)
diff --git a/eclass/dot-a.eclass b/eclass/dot-a.eclass
index 541c5b5c1269..f82e5da5be89 100644
--- a/eclass/dot-a.eclass
+++ b/eclass/dot-a.eclass
@@ -84,6 +84,8 @@ strip-lto-bytecode() {
 			# so we expect to be called on *something*, but nothing was explicitly
 			# passed. Try scanning ${ED} automatically.
 			set -- "${ED}"
+		else
+			return
 		fi
 	fi
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-05-16  2:00 Ionen Wolkens
  0 siblings, 0 replies; 6663+ messages in thread
From: Ionen Wolkens @ 2025-05-16  2:00 UTC (permalink / raw
  To: gentoo-commits
commit:     0db5ce887b5732e201af1a8434d3fe719bb291fa
Author:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
AuthorDate: Fri May 16 01:18:26 2025 +0000
Commit:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
CommitDate: Fri May 16 01:59:37 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=0db5ce88
wine.eclass: limit -std=gnu17 to <wine-10
chiitoo mentioned that (at least) 10.7 works without this, and
that the last needed fixes were in 10.0-rc1, so I tried 10.0
and it was also fine.
vanilla-9.0.1 does not seem to have received a hotfix for this and
still fails, there's also proton-9.0.4 to worry about so will just
keep passing it for <10 until they're gone.
Signed-off-by: Ionen Wolkens <ionen <AT> gentoo.org>
 eclass/wine.eclass | 5 ++---
 1 file changed, 2 insertions(+), 3 deletions(-)
diff --git a/eclass/wine.eclass b/eclass/wine.eclass
index 1f5885d89c6f..6d4de6d87183 100644
--- a/eclass/wine.eclass
+++ b/eclass/wine.eclass
@@ -188,9 +188,8 @@ wine_src_configure() {
 	# may segfault at runtime if used (bug #931329)
 	filter-flags -Wl,--gc-sections
 
-	# avoid gcc-15's c23 default for now (bug #943849)
-	# TODO: verify if still needed and limit to old until cleanup
-	append-cflags -std=gnu17
+	# avoid gcc-15's c23 default with older wine (bug #943849)
+	ver_test -lt 10 && append-cflags -std=gnu17
 
 	# Wine uses many linker tricks that are unlikely to work
 	# with anything but bfd or lld (bug #867097)
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-05-16  9:31 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-05-16  9:31 UTC (permalink / raw
  To: gentoo-commits
commit:     0bc152f3577be686e775ae1476de9cfb3f9e80ac
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Thu May 15 19:32:11 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Fri May 16 09:30:54 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=0bc152f3
llvm.org.eclass: Require new OpenPGP keys
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index a1c252f2cbf7..edc86c1ee659 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -273,7 +273,7 @@ llvm.org_set_globals() {
 			fi
 			BDEPEND+="
 				verify-sig? (
-					>=sec-keys/openpgp-keys-llvm-18.1.6
+					>=sec-keys/openpgp-keys-llvm-20.1.5
 				)
 			"
 			VERIFY_SIG_OPENPGP_KEY_PATH=/usr/share/openpgp-keys/llvm.asc
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-05-16  9:59 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-05-16  9:59 UTC (permalink / raw
  To: gentoo-commits
commit:     63d033755d8c75aea10c6bdff41deaa533cd6cdd
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri May 16 09:53:33 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May 16 09:57:01 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=63d03375
Revert "rust.eclass: revert simplified dependency simplification"
This reverts commit 34b74faa06a90bf9d4f62ecfca746b380d60517a, i.e.
reapplies the simplified dependency specification.
We had to revert this before because of the collision issues when
switching to slotted Rust where the same Rust version existed before
in a non-slotted variant. We have a sanity check and workaround for that
in pkg_postinst for affected versions now, so there shouldn't be a reason
we can't do this.
This may ease depcleaning older Rust in some cases w/o having to rebuild
packages against new Rust.
Bug: https://bugs.gentoo.org/943143
Bug: https://bugs.gentoo.org/943206
Bug: https://bugs.gentoo.org/953884
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/rust.eclass | 27 +++++++++++++++------------
 1 file changed, 15 insertions(+), 12 deletions(-)
diff --git a/eclass/rust.eclass b/eclass/rust.eclass
index e99fca94ac3d..2ab5b7dfe00d 100644
--- a/eclass/rust.eclass
+++ b/eclass/rust.eclass
@@ -248,22 +248,25 @@ _rust_set_globals() {
 	local usedep="${RUST_REQ_USE+[${RUST_REQ_USE}]}"
 
 	# If we're not using LLVM, we can just generate a simple Rust dependency
-	# In time we need to implement trivial dependencies
-	# (>=RUST_MIN_VER) where RUST_MAX_VER isnt't set,
-	# however the previous attempt to do this ran into issues
-	# where `emerge ... --keep-going` ate legacy non-slotted
-	# Rust blockers resutling in the non-slotted version never
-	# being removed and breaking builds. #943206 #943143
 	if [[ -z "${RUST_NEEDS_LLVM}" ]]; then
 		rust_dep=( "|| (" )
-		# depend on each slot between RUST_MIN_VER and RUST_MAX_VER; it's a bit specific but
-		# won't hurt as we only ever add newer Rust slots.
-		for slot in "${_RUST_SLOTS[@]}"; do
+		# We can be more flexible if we generate a simpler, open-ended dependency
+		# when we don't have a max version set.
+		if [[ -z "${RUST_MAX_VER}" ]]; then
 			rust_dep+=(
-				"dev-lang/rust-bin:${slot}${usedep}"
-				"dev-lang/rust:${slot}${usedep}"
+				">=dev-lang/rust-bin-${RUST_MIN_VER}:*${usedep}"
+				">=dev-lang/rust-${RUST_MIN_VER}:*${usedep}"
 			)
-		done
+		else
+			# depend on each slot between RUST_MIN_VER and RUST_MAX_VER; it's a bit specific but
+			# won't hurt as we only ever add newer Rust slots.
+			for slot in "${_RUST_SLOTS[@]}"; do
+				rust_dep+=(
+					"dev-lang/rust-bin:${slot}${usedep}"
+					"dev-lang/rust:${slot}${usedep}"
+				)
+			done
+		fi
 		rust_dep+=( ")" )
 		RUST_DEPEND="${rust_dep[*]}"
 	else
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-05-17 12:59 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-05-17 12:59 UTC (permalink / raw
  To: gentoo-commits
commit:     418ada73563c0df7f99c65eb269b8aae483d445a
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat May 17 12:48:27 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat May 17 12:58:50 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=418ada73
Add 21.0.0_pre20250517 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index 9a3657f9f4f5..b3dd4e697f01 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -72,6 +72,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 			_LLVM_SOURCE_TYPE=snapshot
 
 			case ${PV} in
+				21.0.0_pre20250517)
+					EGIT_COMMIT=aaaae99663dbb220c6c27fa9cacf93fcb8f20e7c
+					;;
 				21.0.0_pre20250510)
 					EGIT_COMMIT=fcb4bda9dcfcdb64d8b069e8416c75d7a1a62e52
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-05-17 12:59 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-05-17 12:59 UTC (permalink / raw
  To: gentoo-commits
commit:     636ecd8b171f598601ea98bbe196330e82056682
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat May 17 12:47:53 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat May 17 12:58:49 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=636ecd8b
Remove old snapshots
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 9 ---------
 1 file changed, 9 deletions(-)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index edc86c1ee659..9a3657f9f4f5 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -75,15 +75,6 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 				21.0.0_pre20250510)
 					EGIT_COMMIT=fcb4bda9dcfcdb64d8b069e8416c75d7a1a62e52
 					;;
-				21.0.0_pre20250503)
-					EGIT_COMMIT=d1e38eab95b07b422194427474521623916bbf29
-					;;
-				21.0.0_pre20250426)
-					EGIT_COMMIT=b9e32749d273a957e60170d6e7ef205fd1fb1834
-					;;
-				21.0.0_pre20250420)
-					EGIT_COMMIT=ac8fc09688e10e983b99224b5dc5cbbeeedb1879
-					;;
 				*)
 					die "Unknown snapshot: ${PV}"
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-05-19 15:22 Matt Turner
  0 siblings, 0 replies; 6663+ messages in thread
From: Matt Turner @ 2025-05-19 15:22 UTC (permalink / raw
  To: gentoo-commits
commit:     378f828927b322320d4c7672d4314bfe51064752
Author:     Matt Turner <mattst88 <AT> gentoo <DOT> org>
AuthorDate: Sat Feb 22 02:30:50 2025 +0000
Commit:     Matt Turner <mattst88 <AT> gentoo <DOT> org>
CommitDate: Mon May 19 15:21:58 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=378f8289
eclass: Add xorg-meson eclass
To be used by X.Org packages with a meson build system. Largely a copy
of xorg-3.eclass with changes necessary to switch from autotools to
meson.
Compared with xorg-3, I've dropped a few things that I don't think are
necessary (at least initially), namely:
- font support (media-libs/font-* packages); packages change very
  rarely and don't have meson build systems upstream.
- XORG_DOC dependencies. This actually looks wrong in xorg-3?
    - asciidoc is used to generate docbook documentation (which I
      don't think we ever do in the ebuilds)
    - xmlto is used to create some man pages from XML, but the man pages
      are checked into git so we don't ever need to generate them
Signed-off-by: Matt Turner <mattst88 <AT> gentoo.org>
 eclass/xorg-meson.eclass | 209 +++++++++++++++++++++++++++++++++++++++++++++++
 1 file changed, 209 insertions(+)
diff --git a/eclass/xorg-meson.eclass b/eclass/xorg-meson.eclass
new file mode 100644
index 000000000000..afb77e348618
--- /dev/null
+++ b/eclass/xorg-meson.eclass
@@ -0,0 +1,209 @@
+# Copyright 2025 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+# @ECLASS: xorg-meson.eclass
+# @MAINTAINER:
+# x11@gentoo.org
+# @AUTHOR:
+# Author: Matt Turner <mattst88@gentoo.org>
+# @SUPPORTED_EAPIS: 8
+# @PROVIDES: meson meson-multilib
+# @BLURB: Reduces code duplication in the X11 ebuilds.
+# @DESCRIPTION:
+# This eclass makes trivial X ebuilds possible for apps, drivers,
+# and more. Many things that would normally be done in various functions
+# can be accessed by setting variables instead, such as patching,
+# passing options to meson and installing docs.
+#
+# All you need to do in a basic ebuild is inherit this eclass and set
+# DESCRIPTION, KEYWORDS and RDEPEND/DEPEND. If your package is hosted
+# with the other X packages, you don't need to set SRC_URI. Pretty much
+# everything else should be automatic.
+
+case ${EAPI} in
+	8) ;;
+	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
+esac
+
+if [[ -z ${_XORG_MESON_ECLASS} ]]; then
+_XORG_MESON_ECLASS=1
+
+inherit flag-o-matic
+
+if [[ ${PV} == *9999* ]]; then
+	inherit git-r3
+fi
+
+# @ECLASS_VARIABLE: XORG_MULTILIB
+# @PRE_INHERIT
+# @DESCRIPTION:
+# If set to 'yes', multilib support for package will be enabled. Set
+# before inheriting this eclass.
+: "${XORG_MULTILIB:="no"}"
+
+[[ ${XORG_MULTILIB} == yes ]] && inherit meson-multilib || inherit meson
+
+# @ECLASS_VARIABLE: XORG_BASE_INDIVIDUAL_URI
+# @PRE_INHERIT
+# @DESCRIPTION:
+# Set up SRC_URI for individual releases. If set to an empty
+# string, no SRC_URI will be provided by the eclass.
+: "${XORG_BASE_INDIVIDUAL_URI="https://www.x.org/releases/individual"}"
+
+# @ECLASS_VARIABLE: XORG_MODULE
+# @PRE_INHERIT
+# @DESCRIPTION:
+# The subdirectory to download source from. Possible settings are app,
+# doc, data, util, driver, font, lib, proto, xserver. Set above the
+# inherit to override the default autoconfigured module.
+: "${XORG_MODULE:="auto"}"
+if [[ ${XORG_MODULE} == auto ]]; then
+	case "${CATEGORY}/${P}" in
+		app-doc/*)               XORG_MODULE=doc/     ;;
+		media-fonts/*)           XORG_MODULE=font/    ;;
+		x11-apps/*|x11-wm/*)     XORG_MODULE=app/     ;;
+		x11-misc/*|x11-themes/*) XORG_MODULE=util/    ;;
+		x11-base/*)              XORG_MODULE=xserver/ ;;
+		x11-drivers/*)           XORG_MODULE=driver/  ;;
+		x11-libs/*)              XORG_MODULE=lib/     ;;
+		*)                       XORG_MODULE=         ;;
+	esac
+fi
+
+# @ECLASS_VARIABLE: XORG_PACKAGE_NAME
+# @PRE_INHERIT
+# @DESCRIPTION:
+# For git checkout the git repository might differ from package name.
+# This variable can be used for proper directory specification
+: "${XORG_PACKAGE_NAME:=${PN}}"
+
+HOMEPAGE="https://www.x.org/wiki/ https://gitlab.freedesktop.org/xorg/${XORG_MODULE}${XORG_PACKAGE_NAME}"
+
+# @ECLASS_VARIABLE: XORG_TARBALL_SUFFIX
+# @PRE_INHERIT
+# @DESCRIPTION:
+# Most X11 projects provide tarballs as tar.xz. This eclass defaults to xz.
+: "${XORG_TARBALL_SUFFIX:="xz"}"
+
+if [[ ${PV} == *9999* ]]; then
+	: "${EGIT_REPO_URI:="https://gitlab.freedesktop.org/xorg/${XORG_MODULE}${XORG_PACKAGE_NAME}.git"}"
+elif [[ -n ${XORG_BASE_INDIVIDUAL_URI} ]]; then
+	SRC_URI="${XORG_BASE_INDIVIDUAL_URI}/${XORG_MODULE}${P}.tar.${XORG_TARBALL_SUFFIX}"
+fi
+
+: "${SLOT:=0}"
+
+# Set the license for the package. This can be overridden by setting
+# LICENSE after the inherit. Nearly all freedesktop-hosted X packages
+# are under the MIT license.
+: "${LICENSE:=MIT}"
+
+if [[ ${PN} == xf86-video-* || ${PN} == xf86-input-* ]]; then
+	DEPEND+="  x11-base/xorg-proto"
+	DEPEND+="  >=x11-base/xorg-server-1.20:=[xorg]"
+	RDEPEND+=" >=x11-base/xorg-server-1.20:=[xorg]"
+	if [[ ${PN} == xf86-video-* ]]; then
+		DEPEND+="  >=x11-libs/libpciaccess-0.14"
+		RDEPEND+=" >=x11-libs/libpciaccess-0.14"
+	fi
+fi
+BDEPEND+=" virtual/pkgconfig"
+
+# @ECLASS_VARIABLE: XORG_DOC
+# @PRE_INHERIT
+# @DESCRIPTION:
+# Controls the installation of man3 developer documentation. Possible values
+# are the name of the useflag or "no". Default value is "no".
+: "${XORG_DOC:="no"}"
+
+case ${XORG_DOC} in
+	no)
+		;;
+	*)
+		IUSE+=" ${XORG_DOC}"
+		;;
+esac
+
+debug-print "${LINENO} ${ECLASS} ${FUNCNAME}: DEPEND=${DEPEND}"
+debug-print "${LINENO} ${ECLASS} ${FUNCNAME}: RDEPEND=${RDEPEND}"
+debug-print "${LINENO} ${ECLASS} ${FUNCNAME}: PDEPEND=${PDEPEND}"
+debug-print "${LINENO} ${ECLASS} ${FUNCNAME}: BDEPEND=${BDEPEND}"
+
+# @FUNCTION: xorg-meson_src_unpack
+# @DESCRIPTION:
+# Simply unpack source code.
+xorg-meson_src_unpack() {
+	debug-print-function ${FUNCNAME} "$@"
+
+	if [[ ${PV} == *9999* ]]; then
+		git-r3_src_unpack
+	else
+		unpack ${A}
+	fi
+}
+
+# @FUNCTION: xorg-meson_flags_setup
+# @INTERNAL
+# @DESCRIPTION:
+# Set up CFLAGS for a debug build
+xorg-meson_flags_setup() {
+	debug-print-function ${FUNCNAME} "$@"
+
+	# Hardened flags break module autoloading et al (also fixes #778494)
+	if [[ ${PN} == xorg-server || ${PN} == xf86-video-* || ${PN} == xf86-input-* ]]; then
+		filter-flags -fno-plt
+		append-ldflags -Wl,-z,lazy
+	fi
+}
+
+# @VARIABLE: XORG_CONFIGURE_OPTIONS
+# @DEFAULT_UNSET
+# @DESCRIPTION:
+# Array of an additional options to pass to meson setup.
+
+# @FUNCTION: xorg-meson_src_configure
+# @DESCRIPTION:
+# Perform any necessary pre-configuration steps, then run configure
+xorg-meson_src_configure() {
+	debug-print-function ${FUNCNAME} "$@"
+
+	xorg-meson_flags_setup
+
+	local emesonargs=(
+		-Ddefault_library=shared
+		"${XORG_CONFIGURE_OPTIONS[@]}"
+	)
+
+	if [[ ${XORG_MULTILIB} == yes ]]; then
+		meson-multilib_src_configure "$@"
+	else
+		meson_src_configure "$@"
+	fi
+}
+
+# @FUNCTION: xorg-meson_src_install
+# @DESCRIPTION:
+# Install a built package to ${ED}, performing any necessary steps.
+xorg-meson_src_install() {
+	debug-print-function ${FUNCNAME} "$@"
+
+	if [[ ${XORG_MULTILIB} == yes ]]; then
+		meson-multilib_src_install "$@"
+	else
+		meson_src_install "$@"
+	fi
+
+	# Many X11 libraries unconditionally install developer documentation
+	if ! in_iuse doc && [[ -d "${ED}"/usr/share/man/man3 ]]; then
+		eqawarn "ebuild should set XORG_DOC=doc since package installs man3 documentation"
+	fi
+
+	if in_iuse doc && ! use doc; then
+		rm -rf "${ED}"/usr/share/man/man3 || die
+		find "${ED}"/usr -type d -empty -delete || die
+	fi
+}
+
+fi
+
+EXPORT_FUNCTIONS src_unpack src_configure src_install
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-05-20 22:55 Ionen Wolkens
  0 siblings, 0 replies; 6663+ messages in thread
From: Ionen Wolkens @ 2025-05-20 22:55 UTC (permalink / raw
  To: gentoo-commits
commit:     239671750ed95f648027a2b32c3c57380658e296
Author:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
AuthorDate: Tue May 20 22:52:49 2025 +0000
Commit:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
CommitDate: Tue May 20 22:55:41 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=23967175
wine.eclass: fix 32bit-only builds on amd64
Oversight, (at least) needed to set PKG_CONFIG_PATH properly.
>=wine-10 can figure it out by itself, but still want to keep
this to setup everything properly rather than leave it to fate.
Signed-off-by: Ionen Wolkens <ionen <AT> gentoo.org>
 eclass/wine.eclass | 6 ++++++
 1 file changed, 6 insertions(+)
diff --git a/eclass/wine.eclass b/eclass/wine.eclass
index 6d4de6d87183..6561e4019568 100644
--- a/eclass/wine.eclass
+++ b/eclass/wine.eclass
@@ -300,6 +300,12 @@ wine_src_configure() {
 		)
 		conf+=( ${archs:+--enable-archs="${archs[*]}"} )
 
+		if use amd64 && use !abi_x86_64; then
+			# same as above for 32bit-only on 64bit (allowed for wine)
+			conf+=( TARGETFLAGS=-m32 )
+			multilib_toolchain_setup x86
+		fi
+
 		econf "${conf[@]}" "${wineconfargs[@]}"
 	fi
 }
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-05-21 19:21 Andreas Sturmlechner
  0 siblings, 0 replies; 6663+ messages in thread
From: Andreas Sturmlechner @ 2025-05-21 19:21 UTC (permalink / raw
  To: gentoo-commits
commit:     3e48742e698388b7135365bcf032867213f66ecd
Author:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
AuthorDate: Wed May 21 18:16:02 2025 +0000
Commit:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
CommitDate: Wed May 21 19:21:10 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=3e48742e
kodi-addon.eclass: cmake consumer never ported to EAPI-7, now its DEAD
All revdeps were ported away from this triviality.
Bug: https://bugs.gentoo.org/939660
Signed-off-by: Andreas Sturmlechner <asturm <AT> gentoo.org>
 eclass/kodi-addon.eclass | 1 +
 1 file changed, 1 insertion(+)
diff --git a/eclass/kodi-addon.eclass b/eclass/kodi-addon.eclass
index b7678485795e..992f506c3879 100644
--- a/eclass/kodi-addon.eclass
+++ b/eclass/kodi-addon.eclass
@@ -7,6 +7,7 @@
 # @SUPPORTED_EAPIS: 7
 # @PROVIDES: cmake
 # @BLURB: Helper for correct building and (importantly) installing Kodi addon packages.
+# @DEAD
 # @DESCRIPTION:
 # Provides a src_configure function for correct CMake configuration
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread
* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-05-22 19:39 Mike Gilbert
  0 siblings, 0 replies; 6663+ messages in thread
From: Mike Gilbert @ 2025-05-22 19:39 UTC (permalink / raw
  To: gentoo-commits
commit:     0f5b1abe6af8e4158491d11370748edc9a004223
Author:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
AuthorDate: Mon May 19 19:00:34 2025 +0000
Commit:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
CommitDate: Thu May 22 19:38:32 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=0f5b1abe
acct-user.eclass: handle ACCT_USER_HOME_OWNER when ROOT is not empty
We need to resolve the user and group names to numeric ids before
calling fowners.
Closes: https://bugs.gentoo.org/956026
Closes: https://github.com/gentoo/gentoo/pull/42158
Signed-off-by: Mike Gilbert <floppym <AT> gentoo.org>
 eclass/acct-user.eclass | 22 ++++++++++++++--------
 1 file changed, 14 insertions(+), 8 deletions(-)
diff --git a/eclass/acct-user.eclass b/eclass/acct-user.eclass
index b3bcff7e550c..12a2110b1a87 100644
--- a/eclass/acct-user.eclass
+++ b/eclass/acct-user.eclass
@@ -1,4 +1,4 @@
-# Copyright 2019-2024 Gentoo Authors
+# Copyright 2019-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: acct-user.eclass
@@ -370,14 +370,20 @@ acct-user_pkg_preinst() {
 
 	if [[ ${_ACCT_USER_HOME} != /dev/null ]]; then
 		# default ownership to user:group
-		if [[ -z ${_ACCT_USER_HOME_OWNER} ]]; then
-			if [[ -n ${ROOT} ]]; then
-				local euid=$(egetent passwd ${ACCT_USER_NAME} | cut -d: -f3)
-				local egid=$(egetent passwd ${ACCT_USER_NAME} | cut -d: -f4)
-				_ACCT_USER_HOME_OWNER=${euid}:${egid}
-			else
-				_ACCT_USER_HOME_OWNER=${ACCT_USER_NAME}:${groups[0]}
+		local user=${ACCT_USER_NAME}
+		local group=${groups[0]}
+		if [[ -n ${ROOT} ]]; then
+			# resolve user:group to uid:gid
+			if [[ -n ${_ACCT_USER_HOME_OWNER} ]]; then
+				user=${_ACCT_USER_HOME_OWNER%:*}
+				group=${_ACCT_USER_HOME_OWNER#*:}
 			fi
+			local euid= egid=
+			[[ -z ${user} ]] || euid=$(egetent passwd "${user}" | cut -d: -f3)
+			[[ -z ${group} ]] || egid=$(egetent group "${group}" | cut -d: -f3)
+			_ACCT_USER_HOME_OWNER=${euid}:${egid}
+		elif [[ -z ${_ACCT_USER_HOME_OWNER} ]]; then
+			_ACCT_USER_HOME_OWNER=${user}:${group}
 		fi
 		# Path might be missing due to INSTALL_MASK, etc.
 		# https://bugs.gentoo.org/691478
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-05-23 15:42 Ionen Wolkens
  0 siblings, 0 replies; 6663+ messages in thread
From: Ionen Wolkens @ 2025-05-23 15:42 UTC (permalink / raw
  To: gentoo-commits
commit:     df41b9e1a25573053a6bc39759083666e67d3691
Author:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
AuthorDate: Fri May 23 15:22:27 2025 +0000
Commit:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
CommitDate: Fri May 23 15:41:45 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=df41b9e1
qt6-build.eclass: use dot-a if QT6_HAS_STATIC_LIBS=1
Only relevant with USE=custom-cflags at the moment until we
potentially remove the filter-lto.
Considered QT_FEATURE_ltcg so QtModuleHelpers.cmake handles adding
-ffat-lto-objects *only* for static libs (less wasteful) but
1. FEATURE_ltcg is typo'ed there (lacks QT_), 2. it is only
activated with GCC (not clang), and 3. not 100% sure -ffat is passed
everywhere that it needs to be that way. May revisit.
Also considered adding this to ebuilds directly, but there is 5
that need this and it needs defining 1 or even 2 phases in some.
(not putting this behind USE=custom-cflags so that it will not need
adjusting if we remove filter-lto later)
Signed-off-by: Ionen Wolkens <ionen <AT> gentoo.org>
 eclass/qt6-build.eclass | 13 +++++++++++++
 1 file changed, 13 insertions(+)
diff --git a/eclass/qt6-build.eclass b/eclass/qt6-build.eclass
index 858f33f2592e..e0f85283dfc2 100644
--- a/eclass/qt6-build.eclass
+++ b/eclass/qt6-build.eclass
@@ -23,6 +23,7 @@ _QT6_BUILD_ECLASS=1
 
 inherit cmake flag-o-matic toolchain-funcs
 [[ ${EAPI} == 8 ]] && inherit eapi9-pipestatus
+[[ ${QT6_HAS_STATIC_LIBS} ]] && inherit dot-a
 
 # @ECLASS_VARIABLE: QT6_BUILD_TYPE
 # @DESCRIPTION:
@@ -38,6 +39,14 @@ inherit cmake flag-o-matic toolchain-funcs
 # Used for SRC_URI and EGIT_REPO_URI.
 : "${QT6_MODULE:=${PN}}"
 
+# @ECLASS_VARIABLE: QT6_HAS_STATIC_LIBS
+# @DEFAULT_UNSET
+# @PRE_INHERIT
+# @DESCRIPTION:
+# Should be set to a non-empty value if static libraries may be
+# installed so that dot-a.eclass will be used.  Using either way
+# is mostly harmless but still a bit wasteful, thus the variable.
+
 # @ECLASS_VARIABLE: QT6_RESTRICT_TESTS
 # @DEFAULT_UNSET
 # @PRE_INHERIT
@@ -135,6 +144,8 @@ qt6-build_src_prepare() {
 		# issues only happen with GCC.
 		filter-lto
 	fi
+
+	[[ ${QT6_HAS_STATIC_LIBS} ]] && lto-guarantee-fat
 }
 
 # @FUNCTION: qt6-build_src_configure
@@ -192,6 +203,8 @@ qt6-build_src_test() {
 qt6-build_src_install() {
 	cmake_src_install
 
+	[[ ${QT6_HAS_STATIC_LIBS} ]] && strip-lto-bytecode "${D}${QT6_LIBDIR}"
+
 	_qt6-build_create_user_facing_links
 
 	# Qt often install unwanted files when tests are enabled and, while
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-05-24 11:11 Andreas K. Hüttel
  0 siblings, 0 replies; 6663+ messages in thread
From: Andreas K. Hüttel @ 2025-05-24 11:11 UTC (permalink / raw
  To: gentoo-commits
commit:     8b3988e62bd6da7c46f8f85eda280aa47e59d9f1
Author:     Andreas K. Hüttel <dilfridge <AT> gentoo <DOT> org>
AuthorDate: Sat May 24 11:07:46 2025 +0000
Commit:     Andreas K. Hüttel <dilfridge <AT> gentoo <DOT> org>
CommitDate: Sat May 24 11:10:42 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=8b3988e6
toolchain.eclass: further improvements for bug 948394 (libstdc++.module.json path setting)
* Make sure that multilib subdirs get the same include path
* Do not fail if no json file is in the main directory (relevant
  for riscv multilib)
Bug: https://bugs.gentoo.org/948394
Signed-off-by: Andreas K. Hüttel <dilfridge <AT> gentoo.org>
 eclass/toolchain.eclass | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 2d903f992b17..bc10e7e62d1f 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -2689,8 +2689,8 @@ toolchain_src_install() {
 	# Hack for C++ modules
 	if ! is_crosscompile && tc_version_is_at_least 15.0.1_pre20250316 ${PV}; then
 		# PR19266 (bug #948394)
-		sed -i -e "s,\.\./lib/gcc/${CHOST}/${GCCMAJOR}/include/,include/," \
-			"${ED}"/usr/lib/gcc/${CHOST}/${GCCMAJOR}/libstdc++.modules.json || die
+		find "${ED}"/usr/lib/gcc/${CHOST}/${GCCMAJOR} -name libstdc++.modules.json \
+			-exec sed -i -e "s,\"source-path\": \".*gcc/${CHOST}/${GCCMAJOR}/include/,\"source-path\": \"include/," "{}" + || die
 	fi
 
 	# As gcc installs object files built against both ${CHOST} and ${CTARGET}
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-05-24 11:56 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-05-24 11:56 UTC (permalink / raw
  To: gentoo-commits
commit:     b6edde5688c46de4d522ecb53389b01427fd5e57
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat May 24 10:53:53 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat May 24 11:56:14 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=b6edde56
llvm.org.eclass: Add 21.0.0_pre20250523 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index b3dd4e697f01..9d828d4e5b80 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -72,6 +72,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 			_LLVM_SOURCE_TYPE=snapshot
 
 			case ${PV} in
+				21.0.0_pre20250523)
+					EGIT_COMMIT=7dc7c155251c0008d5d59b84f0c9056365740f11
+					;;
 				21.0.0_pre20250517)
 					EGIT_COMMIT=aaaae99663dbb220c6c27fa9cacf93fcb8f20e7c
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-05-24 17:08 Mike Gilbert
  0 siblings, 0 replies; 6663+ messages in thread
From: Mike Gilbert @ 2025-05-24 17:08 UTC (permalink / raw
  To: gentoo-commits
commit:     8b4146d87806731a0d63c0c2b8352a88deb2a31b
Author:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
AuthorDate: Sat May 24 17:07:24 2025 +0000
Commit:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
CommitDate: Sat May 24 17:07:24 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=8b4146d8
acct-user.eclass: ensure groups is set in pkg_preinst
Signed-off-by: Mike Gilbert <floppym <AT> gentoo.org>
 eclass/acct-user.eclass | 3 ++-
 1 file changed, 2 insertions(+), 1 deletion(-)
diff --git a/eclass/acct-user.eclass b/eclass/acct-user.eclass
index 12a2110b1a87..5160a6d21e1d 100644
--- a/eclass/acct-user.eclass
+++ b/eclass/acct-user.eclass
@@ -337,10 +337,11 @@ acct-user_pkg_preinst() {
 		return
 	fi
 
+	local groups=( ${_ACCT_USER_GROUPS} )
+
 	if egetent passwd "${ACCT_USER_NAME}" >/dev/null; then
 		elog "User ${ACCT_USER_NAME} already exists"
 	else
-		local groups=( ${_ACCT_USER_GROUPS} )
 		local aux_groups=${groups[*]:1}
 		local opts=(
 			--system
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-05-24 23:50 Mike Gilbert
  0 siblings, 0 replies; 6663+ messages in thread
From: Mike Gilbert @ 2025-05-24 23:50 UTC (permalink / raw
  To: gentoo-commits
commit:     484e7450d7df7739fd0902b8f17118110872a852
Author:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
AuthorDate: Sat May 24 23:48:44 2025 +0000
Commit:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
CommitDate: Sat May 24 23:50:24 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=484e7450
acct-user.eclass: handle ACCT_USER_HOME_OWNER with no group
Signed-off-by: Mike Gilbert <floppym <AT> gentoo.org>
 eclass/acct-user.eclass | 11 +++++++++--
 1 file changed, 9 insertions(+), 2 deletions(-)
diff --git a/eclass/acct-user.eclass b/eclass/acct-user.eclass
index 5160a6d21e1d..8cf56cb697a6 100644
--- a/eclass/acct-user.eclass
+++ b/eclass/acct-user.eclass
@@ -380,8 +380,15 @@ acct-user_pkg_preinst() {
 				group=${_ACCT_USER_HOME_OWNER#*:}
 			fi
 			local euid= egid=
-			[[ -z ${user} ]] || euid=$(egetent passwd "${user}" | cut -d: -f3)
-			[[ -z ${group} ]] || egid=$(egetent group "${group}" | cut -d: -f3)
+			if [[ -n ${user} ]]; then
+				euid=$(egetent passwd "${user}" | cut -d: -f3)
+				if [[ -z ${group} ]]; then
+					egid=$(egetent passwd "${user}" | cut -d: -f4)
+				fi
+			fi
+			if [[ -n ${group} ]]; then
+				egid=$(egetent group "${group}" | cut -d: -f3)
+			fi
 			_ACCT_USER_HOME_OWNER=${euid}:${egid}
 		elif [[ -z ${_ACCT_USER_HOME_OWNER} ]]; then
 			_ACCT_USER_HOME_OWNER=${user}:${group}
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-05-25 16:41 Mike Gilbert
  0 siblings, 0 replies; 6663+ messages in thread
From: Mike Gilbert @ 2025-05-25 16:41 UTC (permalink / raw
  To: gentoo-commits
commit:     8232c3efbc7befa22763043a0bfd5a0b894db342
Author:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
AuthorDate: Sun May 25 16:39:06 2025 +0000
Commit:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
CommitDate: Sun May 25 16:40:35 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=8232c3ef
acct-user.eclass: handle ROOT != "" and ACCT_USER_HOME_OWNER != *:*
Signed-off-by: Mike Gilbert <floppym <AT> gentoo.org>
 eclass/acct-user.eclass | 5 ++++-
 1 file changed, 4 insertions(+), 1 deletion(-)
diff --git a/eclass/acct-user.eclass b/eclass/acct-user.eclass
index 8cf56cb697a6..5e34a7efcfb0 100644
--- a/eclass/acct-user.eclass
+++ b/eclass/acct-user.eclass
@@ -375,9 +375,12 @@ acct-user_pkg_preinst() {
 		local group=${groups[0]}
 		if [[ -n ${ROOT} ]]; then
 			# resolve user:group to uid:gid
-			if [[ -n ${_ACCT_USER_HOME_OWNER} ]]; then
+			if [[ ${_ACCT_USER_HOME_OWNER} == *:* ]]; then
 				user=${_ACCT_USER_HOME_OWNER%:*}
 				group=${_ACCT_USER_HOME_OWNER#*:}
+			elif [[ -n ${_ACCT_USER_HOME_OWNER} ]]; then
+				user=${_ACCT_USER_HOME_OWNER}
+				group=
 			fi
 			local euid= egid=
 			if [[ -n ${user} ]]; then
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-05-26  9:43 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-05-26  9:43 UTC (permalink / raw
  To: gentoo-commits
commit:     5bad3f3c548d366cb1cf3aa8c8dc7a62b5f7fc9e
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon May 26 09:39:14 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon May 26 09:42:28 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=5bad3f3c
wxwidgets.eclass: handle new wxGTK naming/versioning scheme
Previously, we installed with names like 'gtk3-unicode-3.2-gtk3'
which came from our 'versionator' seds which also broke version scripts
and symbol versioning.
Instead, follow upstream naming which yields e.g. 'gtk3-unicode-3.2' instead
(i.e. no extra toolkit suffix). Add a `has_version` to check for wxGTK ebuilds
following the old scheme, and if that doesn't fire, strip out the suffix.
Trying to make the old scheme semi-work wasn't feasible (and I did try).
Bug: https://bugs.gentoo.org/955936
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/wxwidgets.eclass | 10 +++++++++-
 1 file changed, 9 insertions(+), 1 deletion(-)
diff --git a/eclass/wxwidgets.eclass b/eclass/wxwidgets.eclass
index 7afea401a646..c861189b6551 100644
--- a/eclass/wxwidgets.eclass
+++ b/eclass/wxwidgets.eclass
@@ -84,7 +84,15 @@ setup-wxwidgets() {
 		wxtoolkit="base"
 	fi
 
-	wxconf="${wxtoolkit}-unicode-${WX_GTK_VER}"
+	# Older versions used e.g. 'gtk3-unicode-3.2-gtk3', while we've
+	# migrated to the upstream layout of 'gtk3-unicode-3.2' for newer
+	# versions when fixing bug #955936.
+	if has_version -d "<x11-libs/wxGTK-3.2.8.1:3.2-gtk3"; then
+		wxconf="${wxtoolkit}-unicode-${WX_GTK_VER}"
+	else
+		wxconf="${wxtoolkit}-unicode-${WX_GTK_VER%%-*}"
+	fi
+
 	for w in "${CHOST:-${CBUILD}}-${wxconf}" "${wxconf}"; do
 		[[ -f ${ESYSROOT}/usr/$(get_libdir)/wx/config/${w} ]] && wxconf=${w} && break
 	done || die "Failed to find configuration ${wxconf}"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-05-27 18:17 Mike Gilbert
  0 siblings, 0 replies; 6663+ messages in thread
From: Mike Gilbert @ 2025-05-27 18:17 UTC (permalink / raw
  To: gentoo-commits
commit:     f37f80a04ae26ee655325e7108de54718e0288aa
Author:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
AuthorDate: Mon May 26 15:48:57 2025 +0000
Commit:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
CommitDate: Tue May 27 18:14:49 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=f37f80a0
ssl-cert.eclass: fix dependencies
RDEPEND is sometimes needed to support pkg_config use.
IDEPEND is the most common need, but requires EAPI 8.
Signed-off-by: Mike Gilbert <floppym <AT> gentoo.org>
 eclass/ssl-cert.eclass | 15 ++++++++++-----
 1 file changed, 10 insertions(+), 5 deletions(-)
diff --git a/eclass/ssl-cert.eclass b/eclass/ssl-cert.eclass
index dd95200dbc4a..bc1e3ab9db5e 100644
--- a/eclass/ssl-cert.eclass
+++ b/eclass/ssl-cert.eclass
@@ -44,10 +44,16 @@ inherit edo
 
 if [[ "${SSL_DEPS_SKIP}" == "0" ]]; then
 	if [[ "${SSL_CERT_MANDATORY}" == "0" ]]; then
-		BDEPEND="${SSL_CERT_USE}? ( dev-libs/openssl )"
+		RDEPEND="${SSL_CERT_USE}? ( dev-libs/openssl )"
+		if [[ ${EAPI} != 7 ]]; then
+			IDEPEND="${SSL_CERT_USE}? ( dev-libs/openssl )"
+		fi
 		IUSE="${SSL_CERT_USE}"
 	else
-		BDEPEND="dev-libs/openssl"
+		RDEPEND="dev-libs/openssl"
+		if [[ ${EAPI} != 7 ]]; then
+			IDEPEND="dev-libs/openssl"
+		fi
 	fi
 fi
 
@@ -204,9 +210,8 @@ install_cert() {
 	fi
 
 	case ${EBUILD_PHASE} in
-	unpack|prepare|configure|compile|test|install)
-		die "install_cert cannot be called in ${EBUILD_PHASE}"
-		;;
+		config|preinst|postinst) ;;
+		*) die "install_cert cannot be called in ${EBUILD_PHASE}" ;;
 	esac
 
 	# Generate a CA environment #164601
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-05-27 18:17 Mike Gilbert
  0 siblings, 0 replies; 6663+ messages in thread
From: Mike Gilbert @ 2025-05-27 18:17 UTC (permalink / raw
  To: gentoo-commits
commit:     bf8a9809c6529960579264d2102ced61c9779960
Author:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
AuthorDate: Mon May 26 03:07:43 2025 +0000
Commit:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
CommitDate: Tue May 27 18:14:49 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=bf8a9809
ssl-cert.eclass: do not pass -rand to openssl
Let openssl find a suitable entropy source instead of using some random
log files for "random" bytes.
Bug: https://bugs.gentoo.org/956442
Signed-off-by: Mike Gilbert <floppym <AT> gentoo.org>
 eclass/ssl-cert.eclass | 6 +-----
 1 file changed, 1 insertion(+), 5 deletions(-)
diff --git a/eclass/ssl-cert.eclass b/eclass/ssl-cert.eclass
index b4f5f921c119..dd95200dbc4a 100644
--- a/eclass/ssl-cert.eclass
+++ b/eclass/ssl-cert.eclass
@@ -63,9 +63,6 @@ gen_cnf() {
 	SSL_CONF="${T}/${$}ssl.cnf"
 	# Location of the CA serial file
 	SSL_SERIAL="${T}/${$}ca.ser"
-	# Location of some random files OpenSSL can use: don't use
-	# /dev/u?random here -- doesn't work properly on all platforms
-	SSL_RANDOM="${T}/environment:${T}/eclass-debug.log:/etc/resolv.conf"
 
 	# These can be overridden in the ebuild
 	SSL_DAYS="${SSL_DAYS:-730}"
@@ -128,8 +125,7 @@ get_base() {
 gen_key() {
 	local base=$(get_base "$1")
 	nonfatal edob -m "Generating ${SSL_BITS} bit RSA key${1:+ for CA}" \
-		openssl genrsa -rand "${SSL_RANDOM}" \
-			-out "${base}.key" "${SSL_BITS}"
+		openssl genrsa -out "${base}.key" "${SSL_BITS}"
 	return $?
 }
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-05-27 18:17 Mike Gilbert
  0 siblings, 0 replies; 6663+ messages in thread
From: Mike Gilbert @ 2025-05-27 18:17 UTC (permalink / raw
  To: gentoo-commits
commit:     511c5d9c5f92f4b2994f11435e3936b7286318be
Author:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
AuthorDate: Sun May 25 16:49:21 2025 +0000
Commit:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
CommitDate: Tue May 27 18:14:48 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=511c5d9c
ssl-cert.eclass: use edob for openssl calls
Bug: https://bugs.gentoo.org/956442
Signed-off-by: Mike Gilbert <floppym <AT> gentoo.org>
 eclass/ssl-cert.eclass | 40 ++++++++++++++++++----------------------
 1 file changed, 18 insertions(+), 22 deletions(-)
diff --git a/eclass/ssl-cert.eclass b/eclass/ssl-cert.eclass
index 240f9f12cc91..b4f5f921c119 100644
--- a/eclass/ssl-cert.eclass
+++ b/eclass/ssl-cert.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2023 Gentoo Authors
+# Copyright 1999-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: ssl-cert.eclass
@@ -22,6 +22,8 @@ esac
 if [[ -z ${_SSL_CERT_ECLASS} ]]; then
 _SSL_CERT_ECLASS=1
 
+inherit edo
+
 # @ECLASS_VARIABLE: SSL_CERT_MANDATORY
 # @PRE_INHERIT
 # @DESCRIPTION:
@@ -125,11 +127,9 @@ get_base() {
 #
 gen_key() {
 	local base=$(get_base "$1")
-	ebegin "Generating ${SSL_BITS} bit RSA key${1:+ for CA}"
+	nonfatal edob -m "Generating ${SSL_BITS} bit RSA key${1:+ for CA}" \
 		openssl genrsa -rand "${SSL_RANDOM}" \
-			-out "${base}.key" "${SSL_BITS}" &> /dev/null
-	eend $?
-
+			-out "${base}.key" "${SSL_BITS}"
 	return $?
 }
 
@@ -142,11 +142,9 @@ gen_key() {
 #
 gen_csr() {
 	local base=$(get_base "$1")
-	ebegin "Generating Certificate Signing Request${1:+ for CA}"
-	openssl req -config "${SSL_CONF}" -new \
-		-key "${base}.key" -out "${base}.csr" &>/dev/null
-	eend $?
-
+	nonfatal edob -m "Generating Certificate Signing Request${1:+ for CA}" \
+		openssl req -config "${SSL_CONF}" -new \
+			-key "${base}.key" -out "${base}.csr"
 	return $?
 }
 
@@ -162,21 +160,19 @@ gen_csr() {
 gen_crt() {
 	local base=$(get_base "$1")
 	if [ "${1}" ] ; then
-		ebegin "Generating self-signed X.509 Certificate for CA"
-		openssl x509 -extfile "${SSL_CONF}" \
-			-${SSL_MD} \
-			-days ${SSL_DAYS} -req -signkey "${base}.key" \
-			-in "${base}.csr" -out "${base}.crt" &>/dev/null
+		nonfatal edob -m "Generating self-signed X.509 Certificate for CA" \
+			openssl x509 -extfile "${SSL_CONF}" \
+				-${SSL_MD} \
+				-days ${SSL_DAYS} -req -signkey "${base}.key" \
+				-in "${base}.csr" -out "${base}.crt"
 	else
 		local ca=$(get_base 1)
-		ebegin "Generating authority-signed X.509 Certificate"
-		openssl x509 -extfile "${SSL_CONF}" \
-			-days ${SSL_DAYS} -req -CAserial "${SSL_SERIAL}" \
-			-CAkey "${ca}.key" -CA "${ca}.crt" -${SSL_MD} \
-			-in "${base}.csr" -out "${base}.crt" &>/dev/null
+		nonfatal edob -m "Generating authority-signed X.509 Certificate" \
+			openssl x509 -extfile "${SSL_CONF}" \
+				-days ${SSL_DAYS} -req -CAserial "${SSL_SERIAL}" \
+				-CAkey "${ca}.key" -CA "${ca}.crt" -${SSL_MD} \
+				-in "${base}.csr" -out "${base}.crt"
 	fi
-	eend $?
-
 	return $?
 }
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-05-28  3:36 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-05-28  3:36 UTC (permalink / raw
  To: gentoo-commits
commit:     d3b235ae7c79b5437f93be791fcba7aa3ec5eec7
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed May 28 03:30:49 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed May 28 03:31:20 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=d3b235ae
autotools.eclass: update _LATEST_AUTOMAKE for 1.18
... and 1.17 is stable already, so update for that too.
Bug: https://bugs.gentoo.org/956404
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/autotools.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/autotools.eclass b/eclass/autotools.eclass
index f37b8482781f..f179d5f950e7 100644
--- a/eclass/autotools.eclass
+++ b/eclass/autotools.eclass
@@ -93,7 +93,7 @@ _LATEST_AUTOCONF=( 2.72-r1:2.72 )
 # Do NOT change this variable in your ebuilds!
 # If you want to force a newer minor version, you can specify the correct
 # WANT value by using a colon:  <PV>:<WANT_AUTOMAKE>
-_LATEST_AUTOMAKE=( 1.17-r1:1.17 1.16.5:1.16 )
+_LATEST_AUTOMAKE=( 1.18:1.18 1.17-r1:1.17 )
 
 _automake_atom="dev-build/automake"
 _autoconf_atom="dev-build/autoconf"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread
* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-05-28 11:54 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-05-28 11:54 UTC (permalink / raw
  To: gentoo-commits
commit:     04f71c1ab6e9cadec3b5d73d66405c4c690e2be2
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Wed May 28 10:51:35 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Wed May 28 11:53:40 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=04f71c1a
llvm.org.eclass: Add 21.0.0_pre20250528 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index d1e02410e5c8..d5f73ec37033 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -72,6 +72,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 			_LLVM_SOURCE_TYPE=snapshot
 
 			case ${PV} in
+				21.0.0_pre20250528)
+					EGIT_COMMIT=f8ca9e59cb438bd35b29a6d7cf6d72f50673aec9
+					;;
 				21.0.0_pre20250523)
 					EGIT_COMMIT=7dc7c155251c0008d5d59b84f0c9056365740f11
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-05-28 11:54 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-05-28 11:54 UTC (permalink / raw
  To: gentoo-commits
commit:     c825af558c7c5253db8c1e385efdcd749f1dfeb8
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Wed May 28 10:51:07 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Wed May 28 11:53:39 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=c825af55
llvm.org.eclass: Remove old snapshots
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 6 ------
 1 file changed, 6 deletions(-)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index 9d828d4e5b80..d1e02410e5c8 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -75,12 +75,6 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 				21.0.0_pre20250523)
 					EGIT_COMMIT=7dc7c155251c0008d5d59b84f0c9056365740f11
 					;;
-				21.0.0_pre20250517)
-					EGIT_COMMIT=aaaae99663dbb220c6c27fa9cacf93fcb8f20e7c
-					;;
-				21.0.0_pre20250510)
-					EGIT_COMMIT=fcb4bda9dcfcdb64d8b069e8416c75d7a1a62e52
-					;;
 				*)
 					die "Unknown snapshot: ${PV}"
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-05-29  2:47 Ionen Wolkens
  0 siblings, 0 replies; 6663+ messages in thread
From: Ionen Wolkens @ 2025-05-29  2:47 UTC (permalink / raw
  To: gentoo-commits
commit:     f31b583e6e20a29b47b0cfb3a28b3dc2b2f215f6
Author:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
AuthorDate: Thu May 29 02:31:30 2025 +0000
Commit:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
CommitDate: Thu May 29 02:45:22 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=f31b583e
qt6-build.eclass: fix x86-64-v4 detection with gcc-16
Could probably improve the detection method if needed, but going
with the simplest solution unless there's more problems.
May need to revisiting if clang follows suit to match gcc (or if
gcc-16 changes something before release) given x86-64-v4 now means
something different.
Closes: https://bugs.gentoo.org/956750
Signed-off-by: Ionen Wolkens <ionen <AT> gentoo.org>
 eclass/qt6-build.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/qt6-build.eclass b/eclass/qt6-build.eclass
index e0f85283dfc2..d0c29871f35b 100644
--- a/eclass/qt6-build.eclass
+++ b/eclass/qt6-build.eclass
@@ -336,6 +336,9 @@ _qt6-build_sanitize_cpu_flags() {
 			x86-64-v2
 			#  if (__AVX__ + __AVX2__ + __BMI__ + __BMI2__ + __F16C__ + __FMA__ + __LZCNT__ + __MOVBE__ + __XSAVE__) == 9
 			x86-64-v3
+			#    if !defined(__EVEX512__) && !defined(__clang__) && __GNUC__ >= 16
+			#      define __EVEX512__ 1 /* removed in gcc-16 (bug #956750) */
+			#    endif
 			#    if (__AVX512BW__ + __AVX512CD__ + __AVX512DQ__ + __AVX512F__ + __AVX512VL__ + __EVEX256__ + __EVEX512__) == 7
 			x86-64-v4
 			#    endif
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-05-29 12:24 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-05-29 12:24 UTC (permalink / raw
  To: gentoo-commits
commit:     63f8947e8f7dcdbef199aca7794000da12dd17ba
Author:     orbea <orbea <AT> riseup <DOT> net>
AuthorDate: Thu Mar 13 15:12:06 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu May 29 12:24:17 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=63f8947e
autotools.eclass: add slibtool dir for aclocal
When using slibtoolize it needs the /usr/share/slibtool/slibtool.m4 file
to properly create the configure script. The current method of using it
is to set AT_SYS_M4DIR in make.conf, while this works for most cases it
does not work for app-crypt/tpm2-tss which uses ACLOCAL_AMFLAGS with the
'--install' argument in Makefile.am which results in it trying to
install .m4 files to /usr/share/slibtool. This thankfully fails due to
sandbox.
To solve this problem the /usr/share/slibtool path can be directly
added to "${T}"/aclocal/dirlist if the LIBTOOLIZE variable is set to
'slibtoolize'.
Closes: https://bugs.gentoo.org/950648
Signed-off-by: orbea <orbea <AT> riseup.net>
Part-of: https://github.com/gentoo/gentoo/pull/41062
Closes: https://github.com/gentoo/gentoo/pull/41062
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/autotools.eclass | 9 ++++++++-
 1 file changed, 8 insertions(+), 1 deletion(-)
diff --git a/eclass/autotools.eclass b/eclass/autotools.eclass
index f179d5f950e7..1866bb5fa629 100644
--- a/eclass/autotools.eclass
+++ b/eclass/autotools.eclass
@@ -378,7 +378,14 @@ eaclocal() {
 	# See bug #677002
 	if [[ ! -f "${T}"/aclocal/dirlist ]] ; then
 		mkdir "${T}"/aclocal || die
-		cat <<- EOF > "${T}"/aclocal/dirlist || die
+		if [[ "${LIBTOOLIZE:-}" == 'slibtoolize' ]]; then
+			cat <<- EOF > "${T}"/aclocal/dirlist || die
+				${BROOT}/usr/share/slibtool
+				${ESYSROOT}/usr/share/slibtool
+			EOF
+		fi
+
+		cat <<- EOF >> "${T}"/aclocal/dirlist || die
 			${BROOT}/usr/share/aclocal
 			${ESYSROOT}/usr/share/aclocal
 		EOF
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-05-30  6:33 Hans de Graaff
  0 siblings, 0 replies; 6663+ messages in thread
From: Hans de Graaff @ 2025-05-30  6:33 UTC (permalink / raw
  To: gentoo-commits
commit:     04349ec849e048ea2e0dde6fbe9e4a689bb2f821
Author:     Hans de Graaff <graaff <AT> gentoo <DOT> org>
AuthorDate: Fri May 30 06:29:30 2025 +0000
Commit:     Hans de Graaff <graaff <AT> gentoo <DOT> org>
CommitDate: Fri May 30 06:32:46 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=04349ec8
eclass/ruby-fakegem.eclass: drop ruby31 workaround
Signed-off-by: Hans de Graaff <graaff <AT> gentoo.org>
 eclass/ruby-fakegem.eclass | 14 +-------------
 1 file changed, 1 insertion(+), 13 deletions(-)
diff --git a/eclass/ruby-fakegem.eclass b/eclass/ruby-fakegem.eclass
index c358015902bb..309f88ce0937 100644
--- a/eclass/ruby-fakegem.eclass
+++ b/eclass/ruby-fakegem.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2024 Gentoo Authors
+# Copyright 1999-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: ruby-fakegem.eclass
@@ -23,8 +23,6 @@ case ${EAPI} in
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
-# flag-o-matic is only required for ruby31 support.
-inherit flag-o-matic
 inherit ruby-ng
 
 # @ECLASS_VARIABLE: RUBY_FAKEGEM_NAME
@@ -426,16 +424,6 @@ EOF
 each_fakegem_configure() {
 	debug-print-function ${FUNCNAME} "$@"
 
-	# Ruby 3.1 has a varargs implementation that is not compatible with
-	# gnu23. Ruby 3.1 is EOL in March 2025 and will be removed shortly
-	# after that.
-	case ${RUBY} in
-		*ruby31)
-			append-flags -std=gnu17
-			filter-flags -std=gnu23
-			;;
-	esac
-
 	tc-export PKG_CONFIG
 	for extension in "${RUBY_FAKEGEM_EXTENSIONS[@]}" ; do
 		CC=$(tc-getCC) ${RUBY} --disable=did_you_mean -C ${extension%/*} ${extension##*/} --with-cflags="${CFLAGS}" --with-ldflags="${LDFLAGS}" ${RUBY_FAKEGEM_EXTENSION_OPTIONS} || die
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-06-01 15:13 Ionen Wolkens
  0 siblings, 0 replies; 6663+ messages in thread
From: Ionen Wolkens @ 2025-06-01 15:13 UTC (permalink / raw
  To: gentoo-commits
commit:     d1794094b300d9c8c926dde038b88fd06854ae6d
Author:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
AuthorDate: Sun Jun  1 15:04:28 2025 +0000
Commit:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
CommitDate: Sun Jun  1 15:13:03 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=d1794094
linux-mod-r1.eclass: disable CONFIG_OBJTOOL_WERROR
New in 6.15 and notably causes nvidia-drivers[-kernel-open] to fail.
It's off-by-default in the kernel, but description does say to enable
it if unsure so some users may enable it.
(skipping ML review, rather trivial)
Signed-off-by: Ionen Wolkens <ionen <AT> gentoo.org>
 eclass/linux-mod-r1.eclass | 1 +
 1 file changed, 1 insertion(+)
diff --git a/eclass/linux-mod-r1.eclass b/eclass/linux-mod-r1.eclass
index 16c280219ef8..786e0fb79619 100644
--- a/eclass/linux-mod-r1.eclass
+++ b/eclass/linux-mod-r1.eclass
@@ -1259,6 +1259,7 @@ _modules_set_makeargs() {
 		# unrealistic when building modules that often have slow releases,
 		# but note that the kernel will still pass some -Werror=bad-thing
 		CONFIG_WERROR=
+		CONFIG_OBJTOOL_WERROR=
 
 		# these are only needed if using these arguments for installing, lets
 		# eclass handle strip, sign, compress, and depmod (CONFIG_ should
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-06-03  1:32 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-06-03  1:32 UTC (permalink / raw
  To: gentoo-commits
commit:     9a86a9fc6063dde52eb174dbe9d638f18172798e
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Jun  3 01:03:50 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jun  3 01:31:39 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=9a86a9fc
tree-sitter-grammar.eclass: enable py3.14
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/tree-sitter-grammar.eclass | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/eclass/tree-sitter-grammar.eclass b/eclass/tree-sitter-grammar.eclass
index 499f1c7259a0..7c2593f8bd4d 100644
--- a/eclass/tree-sitter-grammar.eclass
+++ b/eclass/tree-sitter-grammar.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2024 Gentoo Authors
+# Copyright 1999-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: tree-sitter-grammar.eclass
@@ -47,7 +47,7 @@ for _BINDING in "${TS_BINDINGS[@]}"; do
 			DISTUTILS_EXT=1
 			DISTUTILS_OPTIONAL=1
 			DISTUTILS_USE_PEP517=setuptools
-			PYTHON_COMPAT=( python3_{10..13} )
+			PYTHON_COMPAT=( python3_{11..14} )
 			inherit distutils-r1
 
 			IUSE+=" python"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-06-03 17:01 Andreas Sturmlechner
  0 siblings, 0 replies; 6663+ messages in thread
From: Andreas Sturmlechner @ 2025-06-03 17:01 UTC (permalink / raw
  To: gentoo-commits
commit:     36eee9f1329af293a276cba164e0f6256af2d1d5
Author:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
AuthorDate: Sat May 17 17:09:31 2025 +0000
Commit:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
CommitDate: Tue Jun  3 17:00:06 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=36eee9f1
cmake.eclass: Add recursive CMakeLists.txt unsupported version detection
We need to ramp up detection of unsupported CMake build systems with
CMake 4. This will detect CMakeLists.txt files setting insufficient
cmake_minimum_required VERSION level even in project subdirectories,
putting out appropriate eqawarn message about the need to fix ${PN}.
That makes us not rely on tinderbox runs w/ unmasked cmake-4 slowly
being able to build everything up to leaf packages, and also helps
detect insufficient subproject minimums that could otherwise be masked
by USE flag choice.
Problems fixed along the way:
- Make sed case-insensitive
- CMake version range may have double- or triple-dots
- Exit after first match
	We don't want more than one version for the subsequent ver_test.
	Besides, any follow-up cmake_minimum_required call will most likely
	be conditional for some type of workarounds.
Thanks-to: Sam James <sam <AT> gentoo.org>
Thanks-to: Ionen Wolkens <ionen <AT> gentoo.org>
Thanks-to: Michał Górny <mgorny <AT> gentoo.org>
Bug: https://bugs.gentoo.org/951350
Signed-off-by: Andreas Sturmlechner <asturm <AT> gentoo.org>
 eclass/cmake.eclass | 21 +++++++++++++++++++++
 1 file changed, 21 insertions(+)
diff --git a/eclass/cmake.eclass b/eclass/cmake.eclass
index c97f74e8a2ed..4c91afa160d9 100644
--- a/eclass/cmake.eclass
+++ b/eclass/cmake.eclass
@@ -445,6 +445,17 @@ cmake_src_configure() {
 	# Fix xdg collision with sandbox
 	xdg_environment_reset
 
+	local file ver cmreq_isold
+	while read -d '' -r file ; do
+		ver=$(sed -ne "/cmake_minimum_required/I{s/.*\(\.\.\.*\|\s\)\([0-9.]*\)\([)]\|\s\).*$/\2/p;q}" \
+			"${file}" 2>/dev/null \
+		)
+
+		if [[ -n $ver ]] && ver_test $ver -lt "3.5"; then
+			cmreq_isold=true
+		fi
+	done < <(find "${CMAKE_USE_DIR}" -type f -iname "CMakeLists.txt" -print0)
+
 	# Prepare Gentoo override rules (set valid compiler, append CPPFLAGS etc.)
 	local build_rules=${BUILD_DIR}/gentoo_rules.cmake
 
@@ -625,6 +636,16 @@ cmake_src_configure() {
 		cmakeargs+=( -C "${CMAKE_EXTRA_CACHE_FILE}" )
 	fi
 
+	if [[ ${cmreq_isold} ]]; then
+		eqawarn "QA Notice: Compatibility with CMake < 3.5 has been removed from CMake 4,"
+		eqawarn "${CATEGORY}/${PN} will fail to build w/o a fix."
+		eqawarn "See also tracker bug #951350; check existing bug or file a new one for"
+		eqawarn "this package, and take it upstream."
+		if [[ ${EAPI} == 7 ]]; then
+			eqawarn "QA Notice: EAPI=7 detected; this package is now a prime last-rites target."
+		fi
+	fi
+
 	pushd "${BUILD_DIR}" > /dev/null || die
 	debug-print "${LINENO} ${ECLASS} ${FUNCNAME}: mycmakeargs is ${mycmakeargs_local[*]}"
 	echo "${CMAKE_BINARY}" "${cmakeargs[@]}" "${CMAKE_USE_DIR}"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-06-03 17:01 Andreas Sturmlechner
  0 siblings, 0 replies; 6663+ messages in thread
From: Andreas Sturmlechner @ 2025-06-03 17:01 UTC (permalink / raw
  To: gentoo-commits
commit:     4f0e629df3f6e44565becf3dc238d6d65ae9c102
Author:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
AuthorDate: Mon May 19 16:36:57 2025 +0000
Commit:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
CommitDate: Tue Jun  3 17:00:07 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=4f0e629d
cmake.eclass: If CMake 4 is detected, build w/ compat cmake arg
-DCMAKE_POLICY_VERSION_MINIMUM=3.5
Signed-off-by: Andreas Sturmlechner <asturm <AT> gentoo.org>
 eclass/cmake.eclass | 5 +++++
 1 file changed, 5 insertions(+)
diff --git a/eclass/cmake.eclass b/eclass/cmake.eclass
index 4c91afa160d9..b538af80a4b1 100644
--- a/eclass/cmake.eclass
+++ b/eclass/cmake.eclass
@@ -644,6 +644,11 @@ cmake_src_configure() {
 		if [[ ${EAPI} == 7 ]]; then
 			eqawarn "QA Notice: EAPI=7 detected; this package is now a prime last-rites target."
 		fi
+		if has_version -b ">=dev-build/cmake-4"; then
+			eqawarn "QA Notice: CMake 4 detected; building with -DCMAKE_POLICY_VERSION_MINIMUM=3.5"
+			eqawarn "This is merely a workaround and *not* a permanent fix."
+			cmakeargs+=( -DCMAKE_POLICY_VERSION_MINIMUM=3.5 )
+		fi
 	fi
 
 	pushd "${BUILD_DIR}" > /dev/null || die
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-06-03 17:01 Andreas Sturmlechner
  0 siblings, 0 replies; 6663+ messages in thread
From: Andreas Sturmlechner @ 2025-06-03 17:01 UTC (permalink / raw
  To: gentoo-commits
commit:     c61429856424975f5afc1d55d8f153fb3639ab18
Author:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
AuthorDate: Mon May 19 18:37:02 2025 +0000
Commit:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
CommitDate: Tue Jun  3 17:00:08 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=c6142985
cmake.eclass: Add CMAKE_QA_COMPAT_SKIP flag to skip compat checks
Signed-off-by: Andreas Sturmlechner <asturm <AT> gentoo.org>
 eclass/cmake.eclass | 26 +++++++++++++++++---------
 1 file changed, 17 insertions(+), 9 deletions(-)
diff --git a/eclass/cmake.eclass b/eclass/cmake.eclass
index b538af80a4b1..f327521e9fc1 100644
--- a/eclass/cmake.eclass
+++ b/eclass/cmake.eclass
@@ -117,6 +117,12 @@ fi
 # for econf and is needed to pass TRY_RUN results when cross-compiling.
 # Should be set by user in a per-package basis in /etc/portage/package.env.
 
+# @ECLASS_VARIABLE: CMAKE_QA_COMPAT_SKIP
+# @DEFAULT_UNSET
+# @DESCRIPTION:
+# If set, skip detection of CMakeLists.txt unsupported in CMake 4 in case of
+# false positives (e.g. unused outdated bundled libs).
+
 # @ECLASS_VARIABLE: CMAKE_QA_SRC_DIR_READONLY
 # @USER_VARIABLE
 # @DEFAULT_UNSET
@@ -446,15 +452,17 @@ cmake_src_configure() {
 	xdg_environment_reset
 
 	local file ver cmreq_isold
-	while read -d '' -r file ; do
-		ver=$(sed -ne "/cmake_minimum_required/I{s/.*\(\.\.\.*\|\s\)\([0-9.]*\)\([)]\|\s\).*$/\2/p;q}" \
-			"${file}" 2>/dev/null \
-		)
-
-		if [[ -n $ver ]] && ver_test $ver -lt "3.5"; then
-			cmreq_isold=true
-		fi
-	done < <(find "${CMAKE_USE_DIR}" -type f -iname "CMakeLists.txt" -print0)
+	if ! [[ ${CMAKE_QA_COMPAT_SKIP} ]]; then
+		while read -d '' -r file ; do
+			ver=$(sed -ne "/cmake_minimum_required/I{s/.*\(\.\.\.*\|\s\)\([0-9.]*\)\([)]\|\s\).*$/\2/p;q}" \
+				"${file}" 2>/dev/null \
+			)
+
+			if [[ -n $ver ]] && ver_test $ver -lt "3.5"; then
+				cmreq_isold=true
+			fi
+		done < <(find "${CMAKE_USE_DIR}" -type f -iname "CMakeLists.txt" -print0)
+	fi
 
 	# Prepare Gentoo override rules (set valid compiler, append CPPFLAGS etc.)
 	local build_rules=${BUILD_DIR}/gentoo_rules.cmake
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-06-04  8:48 Hans de Graaff
  0 siblings, 0 replies; 6663+ messages in thread
From: Hans de Graaff @ 2025-06-04  8:48 UTC (permalink / raw
  To: gentoo-commits
commit:     56128d17913f59c876abcc02b9278c8f32081c93
Author:     Hans de Graaff <graaff <AT> gentoo <DOT> org>
AuthorDate: Sun Jun  1 11:13:32 2025 +0000
Commit:     Hans de Graaff <graaff <AT> gentoo <DOT> org>
CommitDate: Wed Jun  4 08:48:09 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=56128d17
eclass/apache-2.eclass: use fcaps to set capabilities
Closes: https://bugs.gentoo.org/930455
Signed-off-by: Hans de Graaff <graaff <AT> gentoo.org>
 eclass/apache-2.eclass | 8 +++++++-
 1 file changed, 7 insertions(+), 1 deletion(-)
diff --git a/eclass/apache-2.eclass b/eclass/apache-2.eclass
index c62d19ed6b28..5ac8b7d9fccb 100644
--- a/eclass/apache-2.eclass
+++ b/eclass/apache-2.eclass
@@ -13,7 +13,7 @@
 # and inter-module dependency checking.
 
 LUA_COMPAT=( lua5-{1..4} )
-inherit autotools flag-o-matic lua-single multilib ssl-cert toolchain-funcs
+inherit autotools fcaps flag-o-matic lua-single multilib ssl-cert toolchain-funcs
 
 [[ ${CATEGORY}/${PN} != www-servers/apache ]] \
 	&& die "Do not use this eclass with anything else than www-servers/apache ebuilds!"
@@ -640,6 +640,8 @@ apache-2_src_install() {
 			fperms 4710 /usr/sbin/suexec
 			# provide legacy symlink for suexec, bug 177697
 			dosym /usr/sbin/suexec /usr/sbin/suexec2
+		else
+			FILECAPS=( cap_setgid,cap_setuid=ep usr/sbin/suexec )
 		fi
 	fi
 
@@ -659,6 +661,10 @@ apache-2_src_install() {
 # because the default webroot is a copy of the files that exist elsewhere and we
 # don't want them to be managed/removed by portage when apache is upgraded.
 apache-2_pkg_postinst() {
+	if use suexec && use suexec-syslog && use suexec-caps ; then
+		fcaps_pkg_postinst
+	fi
+
 	if use ssl && [[ ! -e "${EROOT}/etc/ssl/apache2/server.pem" ]]; then
 		SSL_ORGANIZATION="${SSL_ORGANIZATION:-Apache HTTP Server}"
 		install_cert /etc/ssl/apache2/server
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-06-05 10:56 James Le Cuirot
  0 siblings, 0 replies; 6663+ messages in thread
From: James Le Cuirot @ 2025-06-05 10:56 UTC (permalink / raw
  To: gentoo-commits
commit:     8dd431f54fa807b44b23777066a2284c685a51f2
Author:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
AuthorDate: Thu May 22 13:40:53 2025 +0000
Commit:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
CommitDate: Thu Jun  5 10:55:03 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=8dd431f5
linux-mod-r1.eclass: Fix building with different arch than KV_OUT_DIR
The kernel we're building against may have had its tools (e.g. modpost)
built for the target arch or even some other arch than the we're
building with now. To work around this, rebuild those tools with make
modules_prepare when necessary.
Doing this in pkg_setup is not ideal, but some ebuilds have their own
src_configure and src_compile functions. It will not trigger in the vast
majority of cases, and it is not done when installing binary packages.
Signed-off-by: James Le Cuirot <chewi <AT> gentoo.org>
 eclass/linux-mod-r1.eclass | 32 ++++++++++++++++++++++++++++++++
 1 file changed, 32 insertions(+)
diff --git a/eclass/linux-mod-r1.eclass b/eclass/linux-mod-r1.eclass
index 786e0fb79619..91dca82c8f35 100644
--- a/eclass/linux-mod-r1.eclass
+++ b/eclass/linux-mod-r1.eclass
@@ -351,6 +351,8 @@ linux-mod-r1_pkg_setup() {
 
 	_modules_set_makeargs
 
+	_modules_prepare_cross
+
 	_modules_sanity_gccplugins
 }
 
@@ -668,6 +670,36 @@ _modules_check_migration() {
 	# - ECONF_PARAMS: documented but was a no-op in linux-mod too
 }
 
+# @FUNCTION: _modules_prepare_cross
+# @INTERNAL
+# @DESCRIPTION:
+# Checks whether modpost works locally as it might have been built for a
+# different architecture.  If it doesn't work, it is built in a new
+# environment and KV_OUT_DIR is repointed there.
+_modules_prepare_cross() {
+	# modpost should do nothing successfully when called without args.
+	if ! "${KV_OUT_DIR}"/scripts/mod/modpost &>/dev/null; then
+		# Try to run make modules_prepare in a new separate output directory.
+		# This cannot be done if the source directory is not clean. In that
+		# case, copy the whole source directory.
+		if [[ -e ${KV_DIR}/.config ]]; then
+			cp -rLT --reflink=auto -- "${KV_DIR}" "${WORKDIR}"/extmod-build || die
+			emake -C "${WORKDIR}"/extmod-build "${MODULES_MAKEARGS[@]}" modules_prepare \
+				KBUILD_OUTPUT=
+		else
+			mkdir -- "${WORKDIR}"/extmod-build || die
+			cp -- "${KV_OUT_DIR}"/{.config,Module.symvers} "${WORKDIR}"/extmod-build || die
+			# KV_OUT_DIR may have been prepared with install-extmod-build, which
+			# doesn't include all the files needed to call make modules_prepare,
+			# so use the Makefile from the full kernel sources.
+			emake -C "${WORKDIR}"/extmod-build "${MODULES_MAKEARGS[@]}" modules_prepare \
+				KBUILD_OUTPUT="${WORKDIR}"/extmod-build -f "${KERNEL_MAKEFILE}"
+		fi
+		KV_OUT_DIR=${WORKDIR}/extmod-build
+		KBUILD_OUTPUT=${KBUILD_OUTPUT+${KV_OUT_DIR}}
+	fi
+}
+
 # @FUNCTION: _modules_prepare_kernel
 # @INTERNAL
 # @DESCRIPTION:
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-06-05 10:56 James Le Cuirot
  0 siblings, 0 replies; 6663+ messages in thread
From: James Le Cuirot @ 2025-06-05 10:56 UTC (permalink / raw
  To: gentoo-commits
commit:     582a2c2f0756c68d4a51be7a4f408eb71d5797a6
Author:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
AuthorDate: Fri May 23 09:40:55 2025 +0000
Commit:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
CommitDate: Thu Jun  5 10:55:07 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=582a2c2f
linux-info.eclass: Don't try to read KBUILD_OUTPUT from the Makefile
This code originates from 21 years ago, but I don't think it ever made
sense. KBUILD_OUTPUT was never written anywhere until last year. Now it
is written to the Makefile in the output directory, which is what we're
trying to locate in the first place!
Signed-off-by: James Le Cuirot <chewi <AT> gentoo.org>
 eclass/linux-info.eclass | 27 ---------------------------
 1 file changed, 27 deletions(-)
diff --git a/eclass/linux-info.eclass b/eclass/linux-info.eclass
index c395eca9ee85..067c94ccdc1f 100644
--- a/eclass/linux-info.eclass
+++ b/eclass/linux-info.eclass
@@ -464,25 +464,6 @@ kernel_is() {
 		"${1:-${KV_MAJOR:-0}}.${2:-${KV_MINOR:-0}}.${3:-${KV_PATCH:-0}}"
 }
 
-# @FUNCTION: get_makefile_extract_function
-# @INTERNAL
-# @DESCRIPTION:
-# Check if the Makefile is valid for direct parsing.
-# Check status results:
-# - PASS, use 'getfilevar' to extract values
-# - FAIL, use 'getfilevar_noexec' to extract values
-# The check may fail if:
-# - make is not present
-# - corruption exists in the kernel makefile
-get_makefile_extract_function() {
-	[[ -n ${SKIP_KERNEL_CHECK} ]] && return
-	local a='' b='' mkfunc='getfilevar'
-	a="$(getfilevar VERSION ${KERNEL_MAKEFILE})"
-	b="$(getfilevar_noexec VERSION ${KERNEL_MAKEFILE})"
-	[[ "${a}" != "${b}" ]] && mkfunc='getfilevar_noexec'
-	echo "${mkfunc}"
-}
-
 # @ECLASS_VARIABLE: get_version_warning_done
 # @INTERNAL
 # @DESCRIPTION:
@@ -567,14 +548,6 @@ get_version() {
 	# Do we pass KBUILD_OUTPUT on the CLI?
 	local OUTPUT_DIR=${KBUILD_OUTPUT}
 
-	if [[ -z ${OUTPUT_DIR} ]]; then
-		# Decide the function used to extract makefile variables.
-		local mkfunc=$(get_makefile_extract_function "${KERNEL_MAKEFILE}")
-
-		# And if we didn't pass it, we can take a nosey in the Makefile.
-		OUTPUT_DIR=$(${mkfunc} KBUILD_OUTPUT "${KERNEL_MAKEFILE}")
-	fi
-
 	# And contrary to existing functions, I feel we shouldn't trust the
 	# directory name to find version information as this seems insane.
 	# So we parse ${KERNEL_MAKEFILE}.
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-06-05 10:56 James Le Cuirot
  0 siblings, 0 replies; 6663+ messages in thread
From: James Le Cuirot @ 2025-06-05 10:56 UTC (permalink / raw
  To: gentoo-commits
commit:     ff94210dd4ee1cd7163b788c8164a38ca83c5205
Author:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
AuthorDate: Thu May 22 16:01:33 2025 +0000
Commit:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
CommitDate: Thu Jun  5 10:55:06 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=ff94210d
linux-info.eclass: Pass an empty KBUILD_OUTPUT to make in getfilevar
If KBUILD_OUTPUT is set but doesn't exist, the Makefile will try to
create it, which will probably fail due to permissions issues. We don't
actually want to write anything here, so there is no need to set it.
Signed-off-by: James Le Cuirot <chewi <AT> gentoo.org>
 eclass/linux-info.eclass | 3 ++-
 1 file changed, 2 insertions(+), 1 deletion(-)
diff --git a/eclass/linux-info.eclass b/eclass/linux-info.eclass
index 42cde638cf27..c395eca9ee85 100644
--- a/eclass/linux-info.eclass
+++ b/eclass/linux-info.eclass
@@ -234,10 +234,11 @@ getfilevar() {
 		basedname="$(dirname ${2})"
 
 		# We use nonfatal because we want the caller to take care of things #373151
+		# Pass KBUILD_OUTPUT= because this will probably break if it doesn't exist.
 		# Pass need-config= to make to avoid config check in kernel Makefile.
 		# Pass dot-config=0 to avoid the config check in kernels prior to 5.4.
 		echo -e "e:\\n\\t@echo \$(${1})\\ninclude ${basefname}" | \
-			nonfatal emake -C "${basedname}" --no-print-directory M="${T}" \
+			nonfatal emake -C "${basedname}" --no-print-directory M="${T}" KBUILD_OUTPUT= \
 			ARCH="$(tc-arch-kernel)" dot-config=0 need-config= need-compiler= -s -f - 2>/dev/null
 	fi
 }
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-06-05 10:56 James Le Cuirot
  0 siblings, 0 replies; 6663+ messages in thread
From: James Le Cuirot @ 2025-06-05 10:56 UTC (permalink / raw
  To: gentoo-commits
commit:     0aa27096d9614b631e016586a8f6eb4df696ff75
Author:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
AuthorDate: Tue May 20 16:30:34 2025 +0000
Commit:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
CommitDate: Thu Jun  5 10:55:05 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=0aa27096
linux-info.eclass: Set the correct ARCH for make in getfilevar
Currently, it unsets ARCH, so it uses the build architecture. This is
fine if you have the full kernel sources, which is usually the case.
However, an install-extmod-build script was added to Linux fairly
recently that installs just the files needed to build out-of-tree
modules in a distro-neutral manner. It saves space by only including the
arch files for the target architecture.
I checked the history, and tc-arch-kernel didn't exist when the unset
line was added. If it had, this approach probably would have been taken
at the time.
Signed-off-by: James Le Cuirot <chewi <AT> gentoo.org>
 eclass/linux-info.eclass | 7 ++-----
 1 file changed, 2 insertions(+), 5 deletions(-)
diff --git a/eclass/linux-info.eclass b/eclass/linux-info.eclass
index c7950b4e2292..42cde638cf27 100644
--- a/eclass/linux-info.eclass
+++ b/eclass/linux-info.eclass
@@ -219,7 +219,7 @@ qeerror() { qout eerror "${@}" ; }
 # done by including the 'configfile', and printing the variable with Make.
 # It WILL break if your makefile has missing dependencies!
 getfilevar() {
-	local ERROR basefname basedname myARCH="${ARCH}"
+	local ERROR basefname basedname
 	ERROR=0
 
 	[[ -z "${1}" ]] && ERROR=1
@@ -232,16 +232,13 @@ getfilevar() {
 	else
 		basefname="$(basename ${2})"
 		basedname="$(dirname ${2})"
-		unset ARCH
 
 		# We use nonfatal because we want the caller to take care of things #373151
 		# Pass need-config= to make to avoid config check in kernel Makefile.
 		# Pass dot-config=0 to avoid the config check in kernels prior to 5.4.
 		echo -e "e:\\n\\t@echo \$(${1})\\ninclude ${basefname}" | \
 			nonfatal emake -C "${basedname}" --no-print-directory M="${T}" \
-			dot-config=0 need-config= need-compiler= -s -f - 2>/dev/null
-
-		ARCH=${myARCH}
+			ARCH="$(tc-arch-kernel)" dot-config=0 need-config= need-compiler= -s -f - 2>/dev/null
 	fi
 }
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-06-05 10:56 James Le Cuirot
  0 siblings, 0 replies; 6663+ messages in thread
From: James Le Cuirot @ 2025-06-05 10:56 UTC (permalink / raw
  To: gentoo-commits
commit:     a8ecc34b1aa9e625fc953130f5b5082df0bb60d7
Author:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
AuthorDate: Tue May 20 16:28:45 2025 +0000
Commit:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
CommitDate: Thu Jun  5 10:55:04 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=a8ecc34b
linux-info.eclass: Drop unused myARCH variable in getfilevar_noexec
This was copied from getfilevar but never used.
Signed-off-by: James Le Cuirot <chewi <AT> gentoo.org>
 eclass/linux-info.eclass | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/eclass/linux-info.eclass b/eclass/linux-info.eclass
index 0f6138150144..c7950b4e2292 100644
--- a/eclass/linux-info.eclass
+++ b/eclass/linux-info.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2024 Gentoo Authors
+# Copyright 1999-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: linux-info.eclass
@@ -253,7 +253,7 @@ getfilevar() {
 # This is done with sed matching an expression only. If the variable is defined,
 # you will run into problems. See getfilevar for those cases.
 getfilevar_noexec() {
-	local ERROR basefname basedname mycat myARCH="${ARCH}"
+	local ERROR basefname basedname mycat
 	ERROR=0
 	mycat='cat'
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-06-05 10:56 James Le Cuirot
  0 siblings, 0 replies; 6663+ messages in thread
From: James Le Cuirot @ 2025-06-05 10:56 UTC (permalink / raw
  To: gentoo-commits
commit:     d21683ba377a5b2e5bc253e2f825ca7083c5188e
Author:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
AuthorDate: Thu May 22 17:34:25 2025 +0000
Commit:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
CommitDate: Thu Jun  5 10:55:08 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=d21683ba
linux-info.eclass: Rework get_version and fix output directory detection
get_version used to detect the output directory under /lib/modules if
KBUILD_OUTPUT wasn't explicitly set, but this broke when bug #662772 was
fixed. The code is still there but effectively does nothing as
OUTPUT_DIR is already used to set KV_OUT_DIR above.
Bug: https://bugs.gentoo.org/662772
Signed-off-by: James Le Cuirot <chewi <AT> gentoo.org>
 eclass/linux-info.eclass | 59 ++++++++++++++++++++++++------------------------
 1 file changed, 29 insertions(+), 30 deletions(-)
diff --git a/eclass/linux-info.eclass b/eclass/linux-info.eclass
index 067c94ccdc1f..a2b38d604b21 100644
--- a/eclass/linux-info.eclass
+++ b/eclass/linux-info.eclass
@@ -485,8 +485,6 @@ get_version() {
 		die "${FUNCNAME}() called on non-Linux system, please fix the ebuild"
 	fi
 
-	local tmplocal
-
 	[[ -n ${SKIP_KERNEL_CHECK} ]] && return
 
 	# No need to execute this twice assuming KV_FULL is populated.
@@ -541,13 +539,6 @@ get_version() {
 		return 1
 	fi
 
-	# OK so now we know our sources directory, but they might be using
-	# KBUILD_OUTPUT, and we need this for .config and localversions-*
-	# so we better find it, eh?
-	#
-	# Do we pass KBUILD_OUTPUT on the CLI?
-	local OUTPUT_DIR=${KBUILD_OUTPUT}
-
 	# And contrary to existing functions, I feel we shouldn't trust the
 	# directory name to find version information as this seems insane.
 	# So we parse ${KERNEL_MAKEFILE}.
@@ -565,13 +556,35 @@ get_version() {
 		return 1
 	fi
 
-	[[ -d "${OUTPUT_DIR}" ]] && KV_OUT_DIR="${OUTPUT_DIR}"
-	if [[ -n "${KV_OUT_DIR}" ]]; then
+	# Assume there is no local version to begin with.
+	KV_FULL=${KV_MAJOR}.${KV_MINOR}.${KV_PATCH}${KV_EXTRA}
+
+	# There may be separate source and output directories. Has the user set
+	# KBUILD_OUTPUT? If not, automatically fall back to finding the most
+	# relevant output directory. If so, but it doesn't exist, don't fall back as
+	# that's probably undesirable.
+	if [[ -n ${KBUILD_OUTPUT} ]]; then
+		if [[ -d ${KBUILD_OUTPUT} ]]; then
+			KV_OUT_DIR=${KBUILD_OUTPUT}
+		else
+			die "KBUILD_OUTPUT is set to ${KBUILD_OUTPUT} but it doesn't exist"
+		fi
+	else
+		for KV_OUT_DIR in "${SYSROOT}" "${ROOT}" ""; do
+			# We cannot use the local version to find the output directory
+			# because that is where it is written to.
+			KV_OUT_DIR+="/lib/modules/${KV_FULL}/build"
+			[[ -d ${KV_OUT_DIR} ]] && break
+		done
+	fi
+
+	if [[ -d ${KV_OUT_DIR} ]]; then
 		qeinfo "Found kernel object directory:"
 		qeinfo "    ${KV_OUT_DIR}"
+	else
+		# Just use KV_DIR as a last resort.
+		KV_OUT_DIR=${KV_DIR}
 	fi
-	# and if we STILL have not got it, then we better just set it to KV_DIR
-	KV_OUT_DIR="${KV_OUT_DIR:-${KV_DIR}}"
 
 	# Grab the kernel release from the output directory.
 	# TODO: we MUST detect kernel.release being out of date, and 'return 1' from
@@ -585,7 +598,7 @@ get_version() {
 	fi
 
 	# KV_LOCAL currently contains the full release; discard the first bits.
-	tmplocal=${KV_LOCAL#${KV_MAJOR}.${KV_MINOR}.${KV_PATCH}${KV_EXTRA}}
+	local tmplocal=${KV_LOCAL#"${KV_FULL}"}
 
 	# If the updated local version was not changed, the tree is not prepared.
 	# Clear out KV_LOCAL in that case.
@@ -597,22 +610,8 @@ get_version() {
 		KV_LOCAL=${tmplocal}
 	fi
 
-	# and in newer versions, we can also pull LOCALVERSION if it is set.
-	# but before we do this, we need to find if we use a different object directory.
-	# This *WILL* break if the user is using localversions, but we assume it was
-	# caught before this if they are.
-	if [[ -z ${OUTPUT_DIR} ]] ; then
-		# Try to locate a kernel that is most relevant for us.
-		for OUTPUT_DIR in "${SYSROOT}" "${ROOT}" "" ; do
-			OUTPUT_DIR+="/lib/modules/${KV_MAJOR}.${KV_MINOR}.${KV_PATCH}${KV_EXTRA}${KV_LOCAL}/build"
-			if [[ -e ${OUTPUT_DIR} ]] ; then
-				break
-			fi
-		done
-	fi
-
-	# And we should set KV_FULL to the full expanded version
-	KV_FULL="${KV_MAJOR}.${KV_MINOR}.${KV_PATCH}${KV_EXTRA}${KV_LOCAL}"
+	# Append the local version now that we (maybe) have it.
+	KV_FULL+=${KV_LOCAL}
 
 	qeinfo "Found sources for kernel version:"
 	qeinfo "    ${KV_FULL}"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-06-05 11:11 James Le Cuirot
  0 siblings, 0 replies; 6663+ messages in thread
From: James Le Cuirot @ 2025-06-05 11:11 UTC (permalink / raw
  To: gentoo-commits
commit:     91978cc8887eec401380546bcb9c31737247ac92
Author:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
AuthorDate: Fri May  9 17:16:15 2025 +0000
Commit:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
CommitDate: Thu Jun  5 11:06:59 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=91978cc8
waf-utils.eclass: Use a sysroot wrapper script when appropriate
waf supports executing binaries via a wrapper for cross-compiling.
I have used this to cross-compile Samba and its waf-based dependencies.
Signed-off-by: James Le Cuirot <chewi <AT> gentoo.org>
 eclass/waf-utils.eclass | 9 +++++++--
 1 file changed, 7 insertions(+), 2 deletions(-)
diff --git a/eclass/waf-utils.eclass b/eclass/waf-utils.eclass
index 377b455de736..ac3b3534169d 100644
--- a/eclass/waf-utils.eclass
+++ b/eclass/waf-utils.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2024 Gentoo Authors
+# Copyright 1999-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: waf-utils.eclass
@@ -23,7 +23,7 @@ esac
 if [[ -z ${_WAF_UTILS_ECLASS} ]]; then
 _WAF_UTILS_ECLASS=1
 
-inherit multilib toolchain-funcs multiprocessing
+inherit multilib sysroot toolchain-funcs multiprocessing
 
 # @ECLASS_VARIABLE: WAF_VERBOSE
 # @USER_VARIABLE
@@ -95,6 +95,11 @@ waf-utils_src_configure() {
 		conf_args+=( --mandir="${EPREFIX}"/usr/share/man )
 	fi
 
+	local sysroot_run_prefixed
+	if sysroot_run_prefixed=$(sysroot_make_run_prefixed); then
+		conf_args+=( --cross-compile --cross-execute="${sysroot_run_prefixed}" )
+	fi
+
 	tc-export AR CC CPP CXX RANLIB
 
 	local CMD=(
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-06-05 11:11 James Le Cuirot
  0 siblings, 0 replies; 6663+ messages in thread
From: James Le Cuirot @ 2025-06-05 11:11 UTC (permalink / raw
  To: gentoo-commits
commit:     fc1a2004794575b7935e8716501ec9f1d63ed95e
Author:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
AuthorDate: Fri May  9 17:11:09 2025 +0000
Commit:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
CommitDate: Thu Jun  5 11:06:58 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=fc1a2004
sysroot.eclass: New eclass for using a different sysroot
I also intend to add another wrapper script generation function for
running executables while changing the root directory.
Signed-off-by: James Le Cuirot <chewi <AT> gentoo.org>
 eclass/sysroot.eclass | 85 +++++++++++++++++++++++++++++++++++++++++++++++++++
 1 file changed, 85 insertions(+)
diff --git a/eclass/sysroot.eclass b/eclass/sysroot.eclass
new file mode 100644
index 000000000000..73d353fd9914
--- /dev/null
+++ b/eclass/sysroot.eclass
@@ -0,0 +1,85 @@
+# Copyright 2025 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+# @ECLASS: sysroot.eclass
+# @MAINTAINER:
+# cross@gentoo.org
+# @AUTHOR:
+# James Le Cuirot <chewi@gentoo.org>
+# @SUPPORTED_EAPIS: 7 8
+# @BLURB: Common functions for using a different sysroot (e.g. cross-compiling)
+
+case ${EAPI} in
+	7|8) ;;
+	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
+esac
+
+# @FUNCTION: qemu_arch
+# @DESCRIPTION:
+# Return the QEMU architecture name for the given target or CHOST. This name is
+# used in qemu-user binary filenames, e.g. qemu-ppc64le.
+qemu_arch() {
+	local target=${1:-${CHOST}}
+	case ${target} in
+		armeb*) echo armeb ;;
+		arm*) echo arm ;;
+		hppa*) echo hppa ;;
+		i?86*) echo i386 ;;
+		m68*) echo m68k ;;
+		mips64el*-gnuabi64) echo mips64el ;;
+		mips64el*-gnuabin32) echo mipsn32el ;;
+		mips64*-gnuabi64) echo mips64 ;;
+		mips64*-gnuabin32) echo mipsn32 ;;
+		powerpc64le*) echo ppc64le ;;
+		powerpc64*) echo ppc64 ;;
+		powerpc*) echo ppc ;;
+		*) echo "${target%%-*}" ;;
+	esac
+}
+
+# @FUNCTION: sysroot_make_run_prefixed
+# @DESCRIPTION:
+# Create a wrapper script for directly running executables within a sysroot
+# without changing the root directory. The path to that script is returned. If
+# no sysroot has been set, then this function returns unsuccessfully.
+#
+# The script explicitly uses QEMU if this is necessary and it is available in
+# this environment. It may otherwise implicitly use a QEMU outside this
+# environment if binfmt_misc has been used with the F flag. It is not feasible
+# to add a conditional dependency on QEMU.
+sysroot_make_run_prefixed() {
+	[[ -z ${SYSROOT} ]] && return 1
+
+	local SCRIPT="${T}"/sysroot-run-prefixed
+	local QEMU_ARCH=$(qemu_arch)
+
+	# Both methods below might need help to find GCC's libraries. GCC might not
+	# even be installed in the SYSROOT. Note that Clang supports this flag too.
+	local LIBGCC=$($(tc-getCC) ${CPPFLAGS} ${CFLAGS} ${LDFLAGS} -print-libgcc-file-name)
+
+	if [[ ${QEMU_ARCH} == $(qemu_arch "${CBUILD}") ]]; then
+		# glibc: ld.so is a symlink, ldd is a binary.
+		# musl: ld.so doesn't exist, ldd is a symlink.
+		local DLINKER=$(find "${ESYSROOT}"/usr/bin/{ld.so,ldd} -type l -print -quit 2>/dev/null || die "failed to find dynamic linker")
+
+		# musl symlinks ldd to ld-musl.so to libc.so. We want the ld-musl.so
+		# path, not the libc.so path, so don't resolve the symlinks entirely.
+		DLINKER=$(readlink -ev "${DLINKER}" || die "failed to find dynamic linker")
+
+		# Using LD_LIBRARY_PATH to set the prefix is not perfect, as it doesn't
+		# adjust RUNPATHs, but it is probably good enough.
+		install -m0755 /dev/stdin "${SCRIPT}" <<-EOF || die
+			#!/bin/sh
+			LD_LIBRARY_PATH="\${LD_LIBRARY_PATH}\${LD_LIBRARY_PATH+:}${LIBGCC%/*}:${ESYSROOT}/$(get_libdir):${ESYSROOT}/usr/$(get_libdir)" exec "${DLINKER}" "\${@}"
+		EOF
+	else
+		# Use QEMU's environment variables rather than its command line
+		# arguments to cover both explicit and implicit QEMU usage.
+		install -m0755 /dev/stdin "${SCRIPT}" <<-EOF || die
+			#!/bin/sh
+			QEMU_SET_ENV="\${QEMU_SET_ENV}\${QEMU_SET_ENV+,}LD_LIBRARY_PATH=\${LD_LIBRARY_PATH}\${LD_LIBRARY_PATH+:}${LIBGCC%/*}" QEMU_LD_PREFIX="${SYSROOT}" exec $(type -P "qemu-${QEMU_ARCH}") "\${@}"
+		EOF
+	fi
+
+	echo "${SCRIPT}"
+}
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-06-07 11:18 Ionen Wolkens
  0 siblings, 0 replies; 6663+ messages in thread
From: Ionen Wolkens @ 2025-06-07 11:18 UTC (permalink / raw
  To: gentoo-commits
commit:     300ee9b77d46f3e728c8f27fab5e549a4cc2ec8e
Author:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
AuthorDate: Sat Jun  7 11:12:25 2025 +0000
Commit:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
CommitDate: Sat Jun  7 11:17:41 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=300ee9b7
qt6-build.eclass: set CMAKE_QA_COMPAT_SKIP=1
Bug: https://bugs.gentoo.org/957476
Bug: https://bugs.gentoo.org/957475
Signed-off-by: Ionen Wolkens <ionen <AT> gentoo.org>
 eclass/qt6-build.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/qt6-build.eclass b/eclass/qt6-build.eclass
index d0c29871f35b..f8b01845a4c9 100644
--- a/eclass/qt6-build.eclass
+++ b/eclass/qt6-build.eclass
@@ -178,6 +178,9 @@ qt6-build_src_configure() {
 		local mycmakeargs=("${defaultcmakeargs[@]}")
 	fi
 
+	# Qt has quite a lot of unused (false positive) CMakeLists.txt
+	local CMAKE_QA_COMPAT_SKIP=1
+
 	cmake_src_configure
 }
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-06-07 18:05 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-06-07 18:05 UTC (permalink / raw
  To: gentoo-commits
commit:     c716b6cf4e79054aa3c6e58cbf6735f1c2c373ca
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Jun  7 17:35:01 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat Jun  7 18:05:12 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=c716b6cf
llvm.org.eclass: Add 21.0.0_pre20250607 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index 484018d4e179..412e3a0edcea 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -75,6 +75,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 				21.0.0_pre20250528)
 					EGIT_COMMIT=f8ca9e59cb438bd35b29a6d7cf6d72f50673aec9
 					;;
+				21.0.0_pre20250607)
+					EGIT_COMMIT=23d0c7348aacdfcb145a69e533a14131bae830cc
+					;;
 				*)
 					die "Unknown snapshot: ${PV}"
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-06-07 18:05 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-06-07 18:05 UTC (permalink / raw
  To: gentoo-commits
commit:     c14975ca50cf6d3de2674994009ff0b68cbb99bd
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Jun  7 17:32:44 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat Jun  7 18:05:11 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=c14975ca
llvm.org.eclass: Remove old snapshots
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 ---
 1 file changed, 3 deletions(-)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index d5f73ec37033..484018d4e179 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -75,9 +75,6 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 				21.0.0_pre20250528)
 					EGIT_COMMIT=f8ca9e59cb438bd35b29a6d7cf6d72f50673aec9
 					;;
-				21.0.0_pre20250523)
-					EGIT_COMMIT=7dc7c155251c0008d5d59b84f0c9056365740f11
-					;;
 				*)
 					die "Unknown snapshot: ${PV}"
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-06-08 12:03 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-06-08 12:03 UTC (permalink / raw
  To: gentoo-commits
commit:     8518239ce8b650b9792d128c5bb96cc6e36d694f
Author:     Sasha Finkelstein <fnkl.kernel <AT> gmail <DOT> com>
AuthorDate: Thu May  1 12:42:48 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Jun  8 12:02:50 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=8518239c
wine.eclass: Install xtajit.dll if requested
Signed-off-by: Sasha Finkelstein <fnkl.kernel <AT> gmail.com>
Part-of: https://github.com/gentoo/gentoo/pull/42493
Closes: https://github.com/gentoo/gentoo/pull/42493
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/wine.eclass | 16 +++++++---------
 1 file changed, 7 insertions(+), 9 deletions(-)
diff --git a/eclass/wine.eclass b/eclass/wine.eclass
index 6561e4019568..36d3b505f39a 100644
--- a/eclass/wine.eclass
+++ b/eclass/wine.eclass
@@ -50,6 +50,7 @@ REQUIRED_USE="
 	wow64? ( !arm64? ( abi_x86_64 !abi_x86_32 ) )
 "
 
+RDEPEND="arm64? ( wow64? ( app-emulation/fex-xtajit ) )"
 BDEPEND="
 	|| (
 		sys-devel/binutils:*
@@ -354,6 +355,10 @@ wine_src_install() {
 		fi
 	fi
 
+	use arm64 && use wow64 &&
+	    dosym -r /usr/lib/fex-xtajit/libwow64fex.dll \
+				${WINE_PREFIX}/wine/aarch64-windows/xtajit.dll
+
 	# delete unwanted files if requested, not done directly in ebuilds
 	# given must be done after install and before wrappers
 	if (( ${#WINE_SKIP_INSTALL[@]} )); then
@@ -375,11 +380,11 @@ wine_src_install() {
 		if use mingw; then
 			: "$(usex arm64 aarch64 $(usex abi_x86_64 x86_64 i686)-w64-mingw32-strip)"
 			find "${ED}"${WINE_PREFIX}/wine/*-windows -regex '.*\.\(a\|dll\|exe\)' \
-				-exec ${_} --strip-unneeded {} +
+				-type f -exec ${_} --strip-unneeded {} +
 		else
 			# llvm-strip errors on .a, and CHOST binutils strip could mangle
 			find "${ED}"${WINE_PREFIX}/wine/*-windows -regex '.*\.\(dll\|exe\)' \
-				-exec llvm-strip --strip-unneeded {} +
+				-type f -exec llvm-strip --strip-unneeded {} +
 		fi
 		eend ${?} || die
 	fi
@@ -418,13 +423,6 @@ wine_pkg_postinst() {
 		fi
 	fi
 
-	if use arm64 && use wow64; then
-		ewarn
-		ewarn "${PN} does not include an x86 emulator, running x86 binaries"
-		ewarn "with USE=wow64 on arm64 requires manually setting up xtajit.dll"
-		ewarn "(not packaged) in the Wine prefix."
-	fi
-
 	eselect wine update --if-unset || die
 }
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-06-09  8:07 Ionen Wolkens
  0 siblings, 0 replies; 6663+ messages in thread
From: Ionen Wolkens @ 2025-06-09  8:07 UTC (permalink / raw
  To: gentoo-commits
commit:     adb4fddd6851e2baf715ad0ce7ae80184aba7792
Author:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
AuthorDate: Mon Jun  9 07:33:53 2025 +0000
Commit:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
CommitDate: Mon Jun  9 08:04:41 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=adb4fddd
qt6-build.eclass: cleanup obsolete <6.8.3 block
Signed-off-by: Ionen Wolkens <ionen <AT> gentoo.org>
 eclass/qt6-build.eclass | 18 ------------------
 1 file changed, 18 deletions(-)
diff --git a/eclass/qt6-build.eclass b/eclass/qt6-build.eclass
index f8b01845a4c9..c60a56f84203 100644
--- a/eclass/qt6-build.eclass
+++ b/eclass/qt6-build.eclass
@@ -239,24 +239,6 @@ _qt6-build_create_user_facing_links() {
 	# even if no links (empty), if missing will assume that it is an error
 	[[ ${PN} == qttranslations ]] && return
 
-	# TODO: drop when <6.8.3 is gone, unneeded version with relative paths
-	if ver_test -lt 6.8.3; then
-		local link
-		while IFS= read -r link; do
-			if [[ -z ${link} ]]; then
-				continue
-			elif [[ ${link} =~ ^("${QT6_PREFIX}"/.+)\ ("${QT6_PREFIX}"/bin/.+) ]]
-			then
-				dosym -r "${BASH_REMATCH[1]#"${EPREFIX}"}" \
-					"${BASH_REMATCH[2]#"${EPREFIX}"}"
-			else
-				die "unrecognized user_facing_tool_links.txt line: ${link}"
-			fi
-		done < "${BUILD_DIR}"/user_facing_tool_links.txt || die
-
-		return
-	fi
-
 	local link
 	while IFS= read -r link; do
 		if [[ -z ${link} ]]; then
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-06-09 20:30 James Le Cuirot
  0 siblings, 0 replies; 6663+ messages in thread
From: James Le Cuirot @ 2025-06-09 20:30 UTC (permalink / raw
  To: gentoo-commits
commit:     4145a2143b536676dd9372cc0c7e4994eac9203f
Author:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
AuthorDate: Fri Jun  6 10:17:15 2025 +0000
Commit:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
CommitDate: Mon Jun  9 20:27:51 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=4145a214
linux-info.eclass: Fix building modules when /lib/modules is locked down
/lib/modules/*/build is often a symlink. get_version is usually run in
pkg_setup as root, so fully resolve it then in case the unprivileged
user doesn't have permission to do it later.
Closes: https://bugs.gentoo.org/957187
Signed-off-by: James Le Cuirot <chewi <AT> gentoo.org>
 eclass/linux-info.eclass | 7 ++++++-
 1 file changed, 6 insertions(+), 1 deletion(-)
diff --git a/eclass/linux-info.eclass b/eclass/linux-info.eclass
index a2b38d604b21..6dd3f81a6dfb 100644
--- a/eclass/linux-info.eclass
+++ b/eclass/linux-info.eclass
@@ -574,7 +574,12 @@ get_version() {
 			# We cannot use the local version to find the output directory
 			# because that is where it is written to.
 			KV_OUT_DIR+="/lib/modules/${KV_FULL}/build"
-			[[ -d ${KV_OUT_DIR} ]] && break
+			# build is often a symlink. This function is usually run in
+			# pkg_setup as root, so fully resolve it now in case the
+			# unprivileged user doesn't have permission to do it later. If we
+			# don't have permission now, then this will fall back to KV_DIR
+			# below, which is probably where the build symlink points to anyway.
+			KV_OUT_DIR=$(realpath -q -e "${KV_OUT_DIR}") && break
 		done
 	fi
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-06-09 20:47 Andreas Sturmlechner
  0 siblings, 0 replies; 6663+ messages in thread
From: Andreas Sturmlechner @ 2025-06-09 20:47 UTC (permalink / raw
  To: gentoo-commits
commit:     56ea6c5ef6574d8d7e6b083c15c72ca6dbf0ded4
Author:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
AuthorDate: Wed Jun  4 19:52:22 2025 +0000
Commit:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
CommitDate: Mon Jun  9 20:47:16 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=56ea6c5e
qt5-build.eclass: Drop support for old versions
Signed-off-by: Andreas Sturmlechner <asturm <AT> gentoo.org>
 eclass/qt5-build.eclass | 11 ++---------
 1 file changed, 2 insertions(+), 9 deletions(-)
diff --git a/eclass/qt5-build.eclass b/eclass/qt5-build.eclass
index 7f79cd8e4063..49d020e2a0b0 100644
--- a/eclass/qt5-build.eclass
+++ b/eclass/qt5-build.eclass
@@ -109,7 +109,7 @@ if [[ ${PN} != qtwebengine ]]; then
 		*9999 )
 			inherit kde.org # kde/5.15 branch
 			;;
-		5.15.[5-9]* | 5.15.??* )
+		5.15.??* )
 			# official stable release
 			_QT5_P=${QT5_MODULE}-everywhere-opensource-src-${PV}
 			HOMEPAGE="https://www.qt.io/"
@@ -125,14 +125,7 @@ if [[ ${PN} != qtwebengine ]]; then
 fi
 
 if [[ ${QT5_MODULE} == qtbase ]]; then
-	case ${PV} in
-		5.15.13)
-			_QT5_GENTOOPATCHSET_REV=5
-			;;
-		*)
-			_QT5_GENTOOPATCHSET_REV=6
-			;;
-	esac
+	_QT5_GENTOOPATCHSET_REV=6
 	SRC_URI+=" https://dev.gentoo.org/~asturm/distfiles/qtbase-5.15-gentoo-patchset-${_QT5_GENTOOPATCHSET_REV}.tar.xz"
 fi
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-06-10  8:02 Ionen Wolkens
  0 siblings, 0 replies; 6663+ messages in thread
From: Ionen Wolkens @ 2025-06-10  8:02 UTC (permalink / raw
  To: gentoo-commits
commit:     2cdd1dcd1f3b5507e4d831fa4b2adbf93cd0dd96
Author:     James Calligeros <jcalligeros99 <AT> gmail <DOT> com>
AuthorDate: Tue Jun 10 07:22:43 2025 +0000
Commit:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
CommitDate: Tue Jun 10 08:02:06 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=2cdd1dcd
wine.eclass: warn about missing amd64 when ARM64 && WoW64
Due to 40+ years of sloppy nomenclature in the Wintel ecosystem,
folks are going to expect "x86 emulation" to include not only
i386/x86/x32, but also amd64/x86_64/x64. Since we currently don't
(and can't) build libarm64ecfex.dll or WINE's ARM64EC support, we
cannot provide amd64 emulation yet.
Warn users about the lack of amd64 emulation and ask them not to
file bugs about it.
Signed-off-by: James Calligeros <jcalligeros99 <AT> gmail.com>
Part-of: https://github.com/gentoo/gentoo/pull/42529
Closes: https://github.com/gentoo/gentoo/pull/42529
Signed-off-by: Ionen Wolkens <ionen <AT> gentoo.org>
 eclass/wine.eclass | 8 ++++++++
 1 file changed, 8 insertions(+)
diff --git a/eclass/wine.eclass b/eclass/wine.eclass
index 36d3b505f39a..185d3bf4ec59 100644
--- a/eclass/wine.eclass
+++ b/eclass/wine.eclass
@@ -423,6 +423,14 @@ wine_pkg_postinst() {
 		fi
 	fi
 
+	if use arm64 && use wow64; then
+		ewarn
+		ewarn "You have enabled x86 emulation via FEX-Emu's xtajit implementation."
+		ewarn "This currently *does not* include amd64/x86_64/x64 emulation. Only i386"
+		ewarn "and ARM64 Windows applications are supported at this time. Please do not"
+		ewarn "file bugs about amd64 applications."
+	fi
+
 	eselect wine update --if-unset || die
 }
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-06-11  1:48 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-06-11  1:48 UTC (permalink / raw
  To: gentoo-commits
commit:     6d83bd7e35dd8246330c9379929c8ee9d0ec741f
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Jun 11 01:47:46 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Jun 11 01:47:46 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=6d83bd7e
zig.eclass: fix typos
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/zig.eclass | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/eclass/zig.eclass b/eclass/zig.eclass
index 0de7ee9eb47a..0b5a2426e732 100644
--- a/eclass/zig.eclass
+++ b/eclass/zig.eclass
@@ -20,7 +20,7 @@
 # libraries, objects), source codes, assets, tests, scripts etc.   But
 # many authors also use it to write Zig "modules", build logic
 # and/or bindings/wrappers for C/C++ libraries.  They install nothing
-# and are only used at build-time, so it's unneccessary and mostly
+# and are only used at build-time, so it's unnecessary and mostly
 # useless to make ebuilds for them.
 # 2) Have required `target`, `cpu` and optional `optimize` options in
 # build.zig that accept standard Zig-style target and optimize mode.
@@ -246,9 +246,9 @@ zig_get_jobs() {
 # Package manager option is managed by "zig_src_prepare",
 # ebuild and user options are added by "zig_src_configure".
 #
-# This function is used by "zig_pkg_setup", and it is neccessary
+# This function is used by "zig_pkg_setup", and it is necessary
 # that args are available as early as possible, so that ebuilds
-# could use them in steps like "src_unpack" if neccessary, while
+# could use them in steps like "src_unpack" if necessary, while
 # still having verbosity and amount of jobs from user respected.
 #
 #
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-06-11 15:30 Andreas Sturmlechner
  0 siblings, 0 replies; 6663+ messages in thread
From: Andreas Sturmlechner @ 2025-06-11 15:30 UTC (permalink / raw
  To: gentoo-commits
commit:     148073078951b779c56ac2f9c44f60c9953d203a
Author:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
AuthorDate: Wed Jun  4 14:54:33 2025 +0000
Commit:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
CommitDate: Wed Jun 11 15:29:50 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=14807307
gear.kde.org.eclass: Add kde-apps/kig to post 25.07.50 SLOT=5 blocklist
Closes: https://bugs.gentoo.org/957852
Signed-off-by: Andreas Sturmlechner <asturm <AT> gentoo.org>
 eclass/gear.kde.org.eclass | 3 ++-
 1 file changed, 2 insertions(+), 1 deletion(-)
diff --git a/eclass/gear.kde.org.eclass b/eclass/gear.kde.org.eclass
index 9e216e7e02be..9d7cd9557c80 100644
--- a/eclass/gear.kde.org.eclass
+++ b/eclass/gear.kde.org.eclass
@@ -303,7 +303,8 @@ fi
 # list of applications ported to KF6 post-25.04 having to block SLOT=5
 if $(ver_test -gt 25.07.50); then
 	case ${PN} in
-		artikulate)
+		artikulate | \
+		kig)
 			RDEPEND+=" !${CATEGORY}/${PN}:5" ;;
 		*) ;;
 	esac
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-06-12 11:58 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-06-12 11:58 UTC (permalink / raw
  To: gentoo-commits
commit:     6d9162a93410fff29ead70a1a421ed7f8db7b974
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Jun 12 11:54:26 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Jun 12 11:54:26 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=6d9162a9
apache-2.eclass: set PCRE_CONFIG as well
Bug: https://bugs.gentoo.org/932162
Bug: https://bugs.gentoo.org/938091
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/apache-2.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/apache-2.eclass b/eclass/apache-2.eclass
index 5ac8b7d9fccb..74965b28f60e 100644
--- a/eclass/apache-2.eclass
+++ b/eclass/apache-2.eclass
@@ -554,8 +554,8 @@ apache-2_src_configure() {
 		--enable-layout=Gentoo
 	)
 
+	export PCRE_CONFIG="${T}"/pcre2-config
 	export ac_cv_prog_ac_ct_PCRE_CONFIG="${T}"/pcre2-config
-
 	MY_CONF+=(
 		--without-pcre
 		--with-pcre2="${T}"/pcre2-config
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-06-12 19:20 Andreas K. Hüttel
  0 siblings, 0 replies; 6663+ messages in thread
From: Andreas K. Hüttel @ 2025-06-12 19:20 UTC (permalink / raw
  To: gentoo-commits
commit:     dc98ced8ef0ff5784b8fe79b031c959526156fd1
Author:     Andreas K. Hüttel <dilfridge <AT> gentoo <DOT> org>
AuthorDate: Thu Jun 12 19:18:20 2025 +0000
Commit:     Andreas K. Hüttel <dilfridge <AT> gentoo <DOT> org>
CommitDate: Thu Jun 12 19:19:43 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=dc98ced8
toolchain.eclass: Add temporary solution for m68k -malign-int profiles (evil integers!)
Signed-off-by: Andreas K. Hüttel <dilfridge <AT> gentoo.org>
 eclass/toolchain.eclass | 13 +++++++++++++
 1 file changed, 13 insertions(+)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 418ca888f14b..12a1ec24132b 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -772,6 +772,19 @@ do_gcc_gentoo_patches() {
 			eapply "${WORKDIR}"/musl/{,nocross/}*.patch
 			${shopt_save}
 		fi
+
+		#
+		# THIS IS A TEMPORARY SOLUTION AND SHOULD BE REPLACED BY A PROPER FIX.
+		# Adding it so we can already build stages for further testing. -dilfridge
+		#
+		if [[ ${CTARGET} == m68*-aligned-* ]]; then
+			einfo "Hard-wiring m68k -malign-int switch into gcc"
+			echo '#define DRIVER_SELF_SPECS "-malign-int"' >> "${S}/gcc/config/m68k/m68k.h" || die
+		fi
+		#
+		# END TEMPORARY SOLUTION
+		#
+
 	fi
 }
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-06-13 23:11 Mike Gilbert
  0 siblings, 0 replies; 6663+ messages in thread
From: Mike Gilbert @ 2025-06-13 23:11 UTC (permalink / raw
  To: gentoo-commits
commit:     9acc90f195babd6be689ea30a5b6dbdb42ba55a1
Author:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
AuthorDate: Fri Jun 13 23:07:34 2025 +0000
Commit:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
CommitDate: Fri Jun 13 23:07:34 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=9acc90f1
user-info.eclass: fix egetgroups when ROOT is not empty
Closes: https://bugs.gentoo.org/958022
Signed-off-by: Mike Gilbert <floppym <AT> gentoo.org>
 eclass/user-info.eclass | 17 +++++++++++------
 1 file changed, 11 insertions(+), 6 deletions(-)
diff --git a/eclass/user-info.eclass b/eclass/user-info.eclass
index 1cc7b8250309..848622fe94e9 100644
--- a/eclass/user-info.eclass
+++ b/eclass/user-info.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2023 Gentoo Authors
+# Copyright 1999-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: user-info.eclass
@@ -165,13 +165,18 @@ egetgroups() {
 	[[ $# -eq 1 ]] || die "usage: egetgroups <user>"
 
 	local egroups_arr
+
 	if [[ -n "${ROOT}" ]]; then
-		local pgroup=$(egetent passwd "$1" | cut -d: -f1)
+		local pgid=$(egetent passwd "$1" | cut -d: -f4)
+		local pgroup=$(egetent group "${pgid}" | cut -d: -f1)
 		local sgroups=( $(grep -E ":([^:]*,)?$1(,[^:]*)?$" "${ROOT}/etc/group" | cut -d: -f1) )
-
-		# Remove primary group from list
-		sgroups=${sgroups#${pgroup}}
-		egroups_arr=( ${pgroup} ${sgroups[@]} )
+		egroups_arr=( "${pgroup}" )
+		local sg
+		for sg in "${sgroups[@]}"; do
+			if [[ ${sg} != ${pgroup} ]]; then
+				egroups_arr+=( "${sg}" )
+			fi
+		done
 	else
 		read -r -a egroups_arr < <(id -G -n "$1")
 	fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-06-14  9:06 Nowa Ammerlaan
  0 siblings, 0 replies; 6663+ messages in thread
From: Nowa Ammerlaan @ 2025-06-14  9:06 UTC (permalink / raw
  To: gentoo-commits
commit:     18e8604589afe5cf44ded6bee84c4fe8cf5080be
Author:     Nowa Ammerlaan <nowa <AT> gentoo <DOT> org>
AuthorDate: Thu Jun  5 12:07:45 2025 +0000
Commit:     Nowa Ammerlaan <nowa <AT> gentoo <DOT> org>
CommitDate: Sat Jun 14 09:06:16 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=18e86045
kernel-build.eclass: fix signing non-zboot image for secureboot
If the kernel has been built without EFI_ZBOOT support (requires 6.1+)
then the resulting kernel image will be an Image.gz that we cannot
sign with sbsign (on arm64 and riscv). So, uncompress this image,
then add the signature, and finally recompress it with the same
options that the kernel Makefiles use.
Signed-off-by: Nowa Ammerlaan <nowa <AT> gentoo.org>
Part-of: https://github.com/gentoo/gentoo/pull/42457
Closes: https://github.com/gentoo/gentoo/pull/42457
Signed-off-by: Nowa Ammerlaan <nowa <AT> gentoo.org>
 eclass/kernel-build.eclass | 10 +++++++++-
 1 file changed, 9 insertions(+), 1 deletion(-)
diff --git a/eclass/kernel-build.eclass b/eclass/kernel-build.eclass
index d2d634591fe1..77faf6f651e5 100644
--- a/eclass/kernel-build.eclass
+++ b/eclass/kernel-build.eclass
@@ -497,7 +497,15 @@ kernel-build_src_install() {
 	fi
 
 	if [[ ${KERNEL_IUSE_MODULES_SIGN} ]]; then
-		secureboot_sign_efi_file "${image}"
+		if [[ ${image} == *.gz ]]; then
+			# Backwards compatibility with pre-zboot images
+			gunzip "${image}" || die
+			secureboot_sign_efi_file "${image%.gz}"
+			# Use same gzip options as the kernel Makefile
+			gzip -n -f -9 "${image%.gz}" || die
+		else
+			secureboot_sign_efi_file "${image}"
+		fi
 	fi
 
 	if [[ ${KERNEL_IUSE_GENERIC_UKI} ]]; then
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-06-14  9:06 Nowa Ammerlaan
  0 siblings, 0 replies; 6663+ messages in thread
From: Nowa Ammerlaan @ 2025-06-14  9:06 UTC (permalink / raw
  To: gentoo-commits
commit:     d7c42d994b1c54e9a66947bd2a7252a91f372bad
Author:     Nowa Ammerlaan <nowa <AT> gentoo <DOT> org>
AuthorDate: Fri Jun  6 10:15:23 2025 +0000
Commit:     Nowa Ammerlaan <nowa <AT> gentoo <DOT> org>
CommitDate: Sat Jun 14 09:06:15 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=d7c42d99
kernel-build.eclass: include systemd-cryptsetup in generic UKI
Closes: https://bugs.gentoo.org/957110
Signed-off-by: Nowa Ammerlaan <nowa <AT> gentoo.org>
Part-of: https://github.com/gentoo/gentoo/pull/42471
Closes: https://github.com/gentoo/gentoo/pull/42471
Signed-off-by: Nowa Ammerlaan <nowa <AT> gentoo.org>
 eclass/kernel-build.eclass | 8 ++++----
 1 file changed, 4 insertions(+), 4 deletions(-)
diff --git a/eclass/kernel-build.eclass b/eclass/kernel-build.eclass
index b4e29a58bc48..d2d634591fe1 100644
--- a/eclass/kernel-build.eclass
+++ b/eclass/kernel-build.eclass
@@ -514,10 +514,10 @@ kernel-build_src_install() {
 				kernel-network-modules kernel-modules-extra lunmask lvm nbd
 				mdraid modsign network network-manager nfs nvdimm nvmf pcsc
 				pkcs11 plymouth qemu qemu-net resume rngd rootfs-block shutdown
-				systemd systemd-ac-power systemd-ask-password systemd-initrd
-				systemd-integritysetup systemd-pcrphase systemd-sysusers
-				systemd-udevd systemd-veritysetup terminfo tpm2-tss udev-rules
-				uefi-lib usrmount virtiofs
+				systemd systemd-ac-power systemd-ask-password systemd-cryptsetup
+				systemd-initrd systemd-integritysetup systemd-pcrphase
+				systemd-sysusers systemd-udevd systemd-veritysetup terminfo
+				tpm2-tss udev-rules uefi-lib usrmount virtiofs
 			)
 
 			local dracut_args=(
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-06-14 14:26 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-06-14 14:26 UTC (permalink / raw
  To: gentoo-commits
commit:     ed6c96b8c2ea3dbc37057b678ee8585dbaa4625c
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Jun 14 14:26:07 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jun 14 14:26:07 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=ed6c96b8
llvm-r2.eclass: update _LLVM_NEWEST_STABLE to 20
Bug: https://bugs.gentoo.org/958081
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/llvm-r2.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/llvm-r2.eclass b/eclass/llvm-r2.eclass
index 5370e5dbd8d5..b1d1e9734c43 100644
--- a/eclass/llvm-r2.eclass
+++ b/eclass/llvm-r2.eclass
@@ -70,7 +70,7 @@ _LLVM_OLDEST_SLOT=15
 # @DESCRIPTION:
 # The newest stable LLVM version.  Versions newer than that won't
 # be automatically enabled via USE defaults.
-_LLVM_NEWEST_STABLE=19
+_LLVM_NEWEST_STABLE=20
 
 # == control variables ==
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread
* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-06-14 14:26 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-06-14 14:26 UTC (permalink / raw
  To: gentoo-commits
commit:     f66f6a38a2dc79da1b81e156f03e740d7211303a
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Jun 14 14:26:18 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jun 14 14:26:18 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=f66f6a38
llvm-r1.eclass: update _LLVM_NEWEST_STABLE to 20
Bug: https://bugs.gentoo.org/958081
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/llvm-r1.eclass | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/eclass/llvm-r1.eclass b/eclass/llvm-r1.eclass
index e59bd9c317b9..8b78a4381114 100644
--- a/eclass/llvm-r1.eclass
+++ b/eclass/llvm-r1.eclass
@@ -1,4 +1,4 @@
-# Copyright 2024 Gentoo Authors
+# Copyright 2024-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: llvm-r1.eclass
@@ -63,7 +63,7 @@ _LLVM_OLDEST_SLOT=15
 # @DESCRIPTION:
 # The newest stable LLVM version.  Versions newer than that won't
 # be automatically enabled via USE defaults.
-_LLVM_NEWEST_STABLE=19
+_LLVM_NEWEST_STABLE=20
 
 # == control variables ==
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread
* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-06-15 17:39 Andreas Sturmlechner
  0 siblings, 0 replies; 6663+ messages in thread
From: Andreas Sturmlechner @ 2025-06-15 17:39 UTC (permalink / raw
  To: gentoo-commits
commit:     f2a0b0c592e8ce1f20ef56000c2ded5a8d8e7873
Author:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
AuthorDate: Mon Dec 23 05:49:09 2024 +0000
Commit:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
CommitDate: Sun Jun 15 17:26:36 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=f2a0b0c5
frameworks.kde.org.eclass: Drop SRC_URI support for KF5 PortingAids
Bug: https://bugs.gentoo.org/755956
Signed-off-by: Andreas Sturmlechner <asturm <AT> gentoo.org>
 eclass/frameworks.kde.org.eclass | 18 +-----------------
 1 file changed, 1 insertion(+), 17 deletions(-)
diff --git a/eclass/frameworks.kde.org.eclass b/eclass/frameworks.kde.org.eclass
index 522211a23ab2..d14037de0af3 100644
--- a/eclass/frameworks.kde.org.eclass
+++ b/eclass/frameworks.kde.org.eclass
@@ -65,25 +65,9 @@ KDE_ORG_SCHEDULE_URI+="/Frameworks"
 # @INTERNAL
 # @DESCRIPTION:
 # Helper variable to construct release group specific SRC_URI.
-_KDE_SRC_URI="mirror://kde/"
+_KDE_SRC_URI="mirror://kde/stable/frameworks/${KDE_CATV}/"
 
-# TODO: Remove after last KF5 PortingAid treecleaned; bug 755956
 if [[ ${KDE_BUILD_TYPE} != live && -z ${KDE_ORG_COMMIT} ]]; then
-	_KDE_SRC_URI+="stable/frameworks/${KDE_CATV}/"
-	case ${KDE_ORG_NAME} in
-		kdelibs4support | \
-		kdesignerplugin | \
-		kdewebkit | \
-		khtml | \
-		kjs | \
-		kjsembed | \
-		kmediaplayer | \
-		kross | \
-		kxmlrpcclient)
-			_KDE_SRC_URI+="portingAids/"
-			;;
-	esac
-
 	SRC_URI="${_KDE_SRC_URI}${KDE_ORG_TAR_PN}-${PV}.tar.xz"
 fi
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-06-18  7:26 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-06-18  7:26 UTC (permalink / raw
  To: gentoo-commits
commit:     8fe607898ee5928079884c274a17baf38c26c5af
Author:     Krzesimir Nowak <knowak <AT> microsoft <DOT> com>
AuthorDate: Wed Jun 18 07:17:25 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Jun 18 07:26:33 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=8fe60789
eclass/dot-a: Make a variable local
Signed-off-by: Krzesimir Nowak <knowak <AT> microsoft.com>
Part-of: https://github.com/gentoo/gentoo/pull/42649
Closes: https://github.com/gentoo/gentoo/pull/42649
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/dot-a.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/dot-a.eclass b/eclass/dot-a.eclass
index f82e5da5be89..ffd34d9e08aa 100644
--- a/eclass/dot-a.eclass
+++ b/eclass/dot-a.eclass
@@ -91,7 +91,7 @@ strip-lto-bytecode() {
 
 	mapfile -t -d '' files < <(find -H "${@}" -type f \( -name '*.a' -or -name '*.o' \) -print0)
 
-	toolchain_type=
+	local toolchain_type=
 	tc-is-gcc && toolchain_type=gnu
 	tc-is-clang && toolchain_type=llvm
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-06-21 10:07 David Seifert
  0 siblings, 0 replies; 6663+ messages in thread
From: David Seifert @ 2025-06-21 10:07 UTC (permalink / raw
  To: gentoo-commits
commit:     a7ff1b405cd658f7d4c80a482948585f793af57c
Author:     David Seifert <soap <AT> gentoo <DOT> org>
AuthorDate: Sat Jun 21 10:07:34 2025 +0000
Commit:     David Seifert <soap <AT> gentoo <DOT> org>
CommitDate: Sat Jun 21 10:07:34 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=a7ff1b40
wxwidgets.eclass: only support WX_GTK_VER="3.2-gtk3"
Part-of: https://github.com/gentoo/gentoo/pull/42243
Signed-off-by: David Seifert <soap <AT> gentoo.org>
 eclass/wxwidgets.eclass | 20 ++++----------------
 1 file changed, 4 insertions(+), 16 deletions(-)
diff --git a/eclass/wxwidgets.eclass b/eclass/wxwidgets.eclass
index c861189b6551..a558a37189c0 100644
--- a/eclass/wxwidgets.eclass
+++ b/eclass/wxwidgets.eclass
@@ -34,16 +34,11 @@ _WXWIDGETS_ECLASS=1
 # @REQUIRED
 # @DESCRIPTION:
 # The SLOT of the x11-libs/wxGTK you're targeting.  Needs to be defined before
-# inheriting the eclass.  Can be either "3.0" or "3.0-gtk3".
+# inheriting the eclass.  Currently only "3.2-gtk3" is supported.
 case ${WX_GTK_VER} in
-	3.0-gtk3 | 3.2-gtk3) ;;
-	3.0)
-		if [[ ${EAPI} != 7 ]]; then
-			die "${ECLASS}: GTK 2 no longer supported in EAPI ${EAPI}"
-		fi
-		;;
+	3.2-gtk3) ;;
 	"") die "WX_GTK_VER not declared" ;;
-	*)  die "Invalid WX_GTK_VER: must be set to a valid wxGTK SLOT ('3.0', '3.0-gtk3', or '3.2-gtk3')" ;;
+	*)  die "Invalid WX_GTK_VER: must be set to a valid wxGTK SLOT ('3.2-gtk3')" ;;
 esac
 readonly WX_GTK_VER
 
@@ -64,14 +59,7 @@ inherit flag-o-matic
 #
 # See: https://docs.wxwidgets.org/trunk/overview_debugging.html
 setup-wxwidgets() {
-	local w wxtoolkit wxconf
-
-	case ${WX_GTK_VER} in
-		3.0-gtk3 | 3.2-gtk3) wxtoolkit=gtk3 ;;
-		3.0)      wxtoolkit=gtk2
-		          eqawarn "QA Notice: This package relies on the deprecated GTK 2 slot, which will go away soon (https://bugs.gentoo.org/618642)"
-		          ;;
-	esac
+	local w wxtoolkit=gtk3 wxconf
 
 	if [[ -z ${WX_DISABLE_NDEBUG} ]]; then
 		{ in_iuse debug && use debug; } || append-cppflags -DNDEBUG
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-06-21 10:07 David Seifert
  0 siblings, 0 replies; 6663+ messages in thread
From: David Seifert @ 2025-06-21 10:07 UTC (permalink / raw
  To: gentoo-commits
commit:     dfe34b480bd25b3a218760fef35570f5a355d703
Author:     David Seifert <soap <AT> gentoo <DOT> org>
AuthorDate: Sat Jun 21 10:07:35 2025 +0000
Commit:     David Seifert <soap <AT> gentoo <DOT> org>
CommitDate: Sat Jun 21 10:07:35 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=dfe34b48
wxwidgets.eclass: remove EAPI 7 support
Closes: https://github.com/gentoo/gentoo/pull/42243
Signed-off-by: David Seifert <soap <AT> gentoo.org>
 eclass/wxwidgets.eclass | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/eclass/wxwidgets.eclass b/eclass/wxwidgets.eclass
index a558a37189c0..427884a846e1 100644
--- a/eclass/wxwidgets.eclass
+++ b/eclass/wxwidgets.eclass
@@ -4,7 +4,7 @@
 # @ECLASS: wxwidgets.eclass
 # @MAINTAINER:
 # wxwidgets@gentoo.org
-# @SUPPORTED_EAPIS: 7 8
+# @SUPPORTED_EAPIS: 8
 # @BLURB: Manages build configuration for wxGTK-using packages.
 # @DESCRIPTION:
 # This eclass sets up the proper environment for ebuilds using the wxGTK
@@ -22,7 +22,7 @@
 # wxGTK was built with.
 
 case ${EAPI} in
-	7|8) ;;
+	8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-06-22 10:58 Andreas Sturmlechner
  0 siblings, 0 replies; 6663+ messages in thread
From: Andreas Sturmlechner @ 2025-06-22 10:58 UTC (permalink / raw
  To: gentoo-commits
commit:     9787d328acbbb1bf149b05cc4a4023b2fa9c311d
Author:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
AuthorDate: Tue Jun  3 22:50:47 2025 +0000
Commit:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
CommitDate: Sun Jun 22 10:57:08 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=9787d328
cmake.eclass: Improve _cmake_modify-cmakelists(), consolidate the sed
50% less find
50% less grep
100% less cut
Thanks-to: Michał Górny <mgorny <AT> gentoo.org>
Thanks-to: Sam James <sam <AT> gentoo.org>
Signed-off-by: Andreas Sturmlechner <asturm <AT> gentoo.org>
 eclass/cmake.eclass | 26 +++++++++++++++-----------
 1 file changed, 15 insertions(+), 11 deletions(-)
diff --git a/eclass/cmake.eclass b/eclass/cmake.eclass
index f327521e9fc1..ea5a769b4cb4 100644
--- a/eclass/cmake.eclass
+++ b/eclass/cmake.eclass
@@ -333,17 +333,21 @@ _cmake_modify-cmakelists() {
 	grep -qs "<<< Gentoo configuration >>>" "${CMAKE_USE_DIR}"/CMakeLists.txt && return 0
 
 	# Comment out all set (<some_should_be_user_defined_variable> value)
-	find "${CMAKE_USE_DIR}" -name CMakeLists.txt -exec sed \
-		-e '/^[[:space:]]*set[[:space:]]*([[:space:]]*CMAKE_BUILD_TYPE\([[:space:]].*)\|)\)/I{s/^/#_cmake_modify_IGNORE /g}' \
-		-e '/^[[:space:]]*set[[:space:]]*([[:space:]]*CMAKE_COLOR_MAKEFILE[[:space:]].*)/I{s/^/#_cmake_modify_IGNORE /g}' \
-		-e '/^[[:space:]]*set[[:space:]]*([[:space:]]*CMAKE_INSTALL_PREFIX[[:space:]].*)/I{s/^/#_cmake_modify_IGNORE /g}' \
-		-e '/^[[:space:]]*set[[:space:]]*([[:space:]]*CMAKE_VERBOSE_MAKEFILE[[:space:]].*)/I{s/^/#_cmake_modify_IGNORE /g}' \
-		-i {} + || die "${LINENO}: failed to disable hardcoded settings"
-	local x
-	for x in $(find "${CMAKE_USE_DIR}" -name CMakeLists.txt -exec grep -l "^#_cmake_modify_IGNORE" {} +;); do
-		einfo "Hardcoded definition(s) removed in $(echo "${x}" | cut -c $((${#CMAKE_USE_DIR}+2))-):"
-		einfo "$(grep -se '^#_cmake_modify_IGNORE' ${x} | cut -c 22-99)"
-	done
+	local file
+	while read -d '' -r file ; do
+		sed \
+			-e '/^[[:space:]]*set[[:space:]]*([[:space:]]*CMAKE_BUILD_TYPE\([[:space:]].*)\|)\)/I{s/^/#_cmake_modify_IGNORE /g}' \
+			-e '/^[[:space:]]*set[[:space:]]*([[:space:]]*CMAKE_\(COLOR_MAKEFILE\|INSTALL_PREFIX\|VERBOSE_MAKEFILE\)[[:space:]].*)/I{s/^/#_cmake_modify_IGNORE /g}' \
+			-i "${file}" || die "failed to disable hardcoded settings"
+		readarray -t mod_lines < <(grep -se "^#_cmake_modify_IGNORE" "${file}")
+		if [[ ${#mod_lines[*]} -gt 0 ]]; then
+			einfo "Hardcoded definition(s) removed in ${file/${CMAKE_USE_DIR%\/}\//}:"
+			local mod_line
+			for mod_line in "${mod_lines[@]}"; do
+				einfo "${mod_line:22:99}"
+			done
+		fi
+	done < <(find "${CMAKE_USE_DIR}" -type f -iname "CMakeLists.txt" -print0 || die)
 
 	# NOTE Append some useful summary here
 	cat >> "${CMAKE_USE_DIR}"/CMakeLists.txt <<- _EOF_ || die
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-06-22 10:58 Andreas Sturmlechner
  0 siblings, 0 replies; 6663+ messages in thread
From: Andreas Sturmlechner @ 2025-06-22 10:58 UTC (permalink / raw
  To: gentoo-commits
commit:     cc2d8f761caf42ffe401a250b6b81b6ff4263fa5
Author:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
AuthorDate: Fri Jun 13 14:42:37 2025 +0000
Commit:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
CommitDate: Sun Jun 22 10:57:09 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=cc2d8f76
cmake.eclass: mv _CMAKE_MINREQVER_UNSUPPORTED detection to src_prepare
- _cmake_minverreq-lt(): New function for reusability of regex
- Optimise #1: Reuse existing loop over CMakeLists.txt files
- Optimise #2: If _CMAKE_MINREQVER_UNSUPPORTED is already set, then no
  further run of _cmake_minverreq-lt is necessary since we currently throw
  away the info on affected files
- Relegate "CMake 4 detected; ..." to be a non-QA Notice, it is just an
  addendum
Signed-off-by: Andreas Sturmlechner <asturm <AT> gentoo.org>
 eclass/cmake.eclass | 70 ++++++++++++++++++++++++++++++++---------------------
 1 file changed, 42 insertions(+), 28 deletions(-)
diff --git a/eclass/cmake.eclass b/eclass/cmake.eclass
index 4104882005a3..ffd11bc0c863 100644
--- a/eclass/cmake.eclass
+++ b/eclass/cmake.eclass
@@ -126,7 +126,8 @@ fi
 # @ECLASS_VARIABLE: _CMAKE_MINREQVER_UNSUPPORTED
 # @DEFAULT_UNSET
 # @DESCRIPTION:
-# Is set to true if an unsupported cmake_minimum_required value was detected.
+# Internal status set by _cmake_minreqver-lt(); is true if an unsupported
+# cmake_minimum_required value was detected.
 
 # @ECLASS_VARIABLE: CMAKE_QA_SRC_DIR_READONLY
 # @USER_VARIABLE
@@ -326,6 +327,25 @@ _cmake_check_build_dir() {
 	mkdir -p "${BUILD_DIR}" || die
 }
 
+# @FUNCTION: _cmake_minreqver-lt
+# @USAGE: <lt-version> <path>
+# @INTERNAL
+# @DESCRIPTION:
+# Internal function for detecting occurrence of lower-than-specified
+# <lt-version> in cmake_minimum_required of a given CMake file <path>.
+# Returns 0 if the regex matched (a lower-than-specified version found).
+_cmake_minreqver-lt() {
+	local ver chk=1
+	ver=$(sed -ne "/cmake_minimum_required/I{s/.*\(\.\.\.*\|\s\)\([0-9.]*\)\([)]\|\s\).*$/\2/p;q}" \
+		"${2}" 2>/dev/null \
+	)
+	if [[ -n ${ver} ]] && ver_test "${ver}" -lt "${1}"; then
+		_CMAKE_MINREQVER_UNSUPPORTED=true
+		chk=0
+	fi
+	return ${chk}
+}
+
 # @FUNCTION: _cmake_modify-cmakelists
 # @INTERNAL
 # @DESCRIPTION:
@@ -337,9 +357,9 @@ _cmake_modify-cmakelists() {
 	# Only edit the files once
 	grep -qs "<<< Gentoo configuration >>>" "${CMAKE_USE_DIR}"/CMakeLists.txt && return 0
 
-	# Comment out all set (<some_should_be_user_defined_variable> value)
 	local file
 	while read -d '' -r file ; do
+		# Comment out all set (<some_should_be_user_defined_variable> value)
 		sed \
 			-e '/^[[:space:]]*set[[:space:]]*([[:space:]]*CMAKE_BUILD_TYPE\([[:space:]].*)\|)\)/I{s/^/#_cmake_modify_IGNORE /g}' \
 			-e '/^[[:space:]]*set[[:space:]]*([[:space:]]*CMAKE_\(COLOR_MAKEFILE\|INSTALL_PREFIX\|VERBOSE_MAKEFILE\)[[:space:]].*)/I{s/^/#_cmake_modify_IGNORE /g}' \
@@ -352,6 +372,10 @@ _cmake_modify-cmakelists() {
 				einfo "${mod_line:22:99}"
 			done
 		fi
+		# Detect unsupported minimum CMake versions unless CMAKE_QA_COMPAT_SKIP is set
+		if [[ -z ${_CMAKE_MINREQVER_UNSUPPORTED} ]] && ! [[ ${CMAKE_QA_COMPAT_SKIP} ]]; then
+			_cmake_minreqver-lt "3.5" "${file}"
+		fi
 	done < <(find "${CMAKE_USE_DIR}" -type f -iname "CMakeLists.txt" -print0 || die)
 
 	# NOTE Append some useful summary here
@@ -412,6 +436,20 @@ cmake_src_prepare() {
 	# Remove dangerous things.
 	_cmake_modify-cmakelists
 
+	if [[ ${_CMAKE_MINREQVER_UNSUPPORTED} ]]; then
+		eqawarn "QA Notice: Compatibility with CMake < 3.5 has been removed from CMake 4,"
+		eqawarn "${CATEGORY}/${PN} will fail to build w/o a fix."
+		eqawarn "See also tracker bug #951350; check existing bug or file a new one for"
+		eqawarn "this package, and take it upstream."
+		if has_version -b ">=dev-build/cmake-4"; then
+			eqawarn "CMake 4 detected; building with -DCMAKE_POLICY_VERSION_MINIMUM=3.5"
+			eqawarn "This is merely a workaround and *not* a permanent fix."
+		fi
+		if [[ ${EAPI} == 7 ]]; then
+			eqawarn "QA Notice: EAPI=7 detected; this package is now a prime last-rites target."
+		fi
+	fi
+
 	if [[ ${EAPI} == 7 ]]; then
 		popd > /dev/null || die
 	fi
@@ -460,19 +498,6 @@ cmake_src_configure() {
 	# Fix xdg collision with sandbox
 	xdg_environment_reset
 
-	local file ver
-	if ! [[ ${CMAKE_QA_COMPAT_SKIP} ]]; then
-		while read -d '' -r file ; do
-			ver=$(sed -ne "/cmake_minimum_required/I{s/.*\(\.\.\.*\|\s\)\([0-9.]*\)\([)]\|\s\).*$/\2/p;q}" \
-				"${file}" 2>/dev/null \
-			)
-
-			if [[ -n $ver ]] && ver_test $ver -lt "3.5"; then
-				_CMAKE_MINREQVER_UNSUPPORTED=true
-			fi
-		done < <(find "${CMAKE_USE_DIR}" -type f -iname "CMakeLists.txt" -print0)
-	fi
-
 	# Prepare Gentoo override rules (set valid compiler, append CPPFLAGS etc.)
 	local build_rules=${BUILD_DIR}/gentoo_rules.cmake
 
@@ -653,19 +678,8 @@ cmake_src_configure() {
 		cmakeargs+=( -C "${CMAKE_EXTRA_CACHE_FILE}" )
 	fi
 
-	if [[ ${_CMAKE_MINREQVER_UNSUPPORTED} ]]; then
-		eqawarn "QA Notice: Compatibility with CMake < 3.5 has been removed from CMake 4,"
-		eqawarn "${CATEGORY}/${PN} will fail to build w/o a fix."
-		eqawarn "See also tracker bug #951350; check existing bug or file a new one for"
-		eqawarn "this package, and take it upstream."
-		if [[ ${EAPI} == 7 ]]; then
-			eqawarn "QA Notice: EAPI=7 detected; this package is now a prime last-rites target."
-		fi
-		if has_version -b ">=dev-build/cmake-4"; then
-			eqawarn "QA Notice: CMake 4 detected; building with -DCMAKE_POLICY_VERSION_MINIMUM=3.5"
-			eqawarn "This is merely a workaround and *not* a permanent fix."
-			cmakeargs+=( -DCMAKE_POLICY_VERSION_MINIMUM=3.5 )
-		fi
+	if [[ ${_CMAKE_MINREQVER_UNSUPPORTED} ]] && has_version -b ">=dev-build/cmake-4"; then
+		cmakeargs+=( -DCMAKE_POLICY_VERSION_MINIMUM=3.5 )
 	fi
 
 	pushd "${BUILD_DIR}" > /dev/null || die
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-06-22 10:58 Andreas Sturmlechner
  0 siblings, 0 replies; 6663+ messages in thread
From: Andreas Sturmlechner @ 2025-06-22 10:58 UTC (permalink / raw
  To: gentoo-commits
commit:     5389fe4759e97d094afff61aef65bfb97698c5f4
Author:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
AuthorDate: Fri Jun 13 16:14:00 2025 +0000
Commit:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
CommitDate: Sun Jun 22 10:57:09 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=5389fe47
cmake.eclass: Add src_install() check for CMake-4-incompatible modules
See examples:
https://bugs.gentoo.org/953075
https://bugs.gentoo.org/957670
https://bugs.gentoo.org/957671
https://bugs.gentoo.org/957803
Signed-off-by: Andreas Sturmlechner <asturm <AT> gentoo.org>
 eclass/cmake.eclass | 19 +++++++++++++++++++
 1 file changed, 19 insertions(+)
diff --git a/eclass/cmake.eclass b/eclass/cmake.eclass
index d61992576565..109227edfe02 100644
--- a/eclass/cmake.eclass
+++ b/eclass/cmake.eclass
@@ -807,6 +807,25 @@ cmake_src_install() {
 		einstalldocs
 		popd > /dev/null || die
 	fi
+
+	local file files=()
+	while read -d '' -r file ; do
+		# Detect unsupported minimum CMake versions unless CMAKE_QA_COMPAT_SKIP is set
+		if ! [[ ${CMAKE_QA_COMPAT_SKIP} ]]; then
+			_cmake_minreqver-lt "3.5" "${file}" && files+=( "${file#"${D}"}" )
+		fi
+	done < <(find "${D}" -type f -iname "*.cmake" -print0 || die)
+	if [[ ${#files[*]} -gt 0 ]]; then
+		eqawarn "QA Notice: Package installs CMake module(s) incompatible with CMake 4,"
+		eqawarn "breaking any packages relying on it:"
+		eqawarn
+		for file in "${files[@]}"; do
+			eqawarn "    ${file}"
+		done
+		eqawarn
+		eqawarn "See also tracker bug #951350; check existing bug or file a new one for"
+		eqawarn "this package, and take it upstream."
+	fi
 }
 
 fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-06-22 10:58 Andreas Sturmlechner
  0 siblings, 0 replies; 6663+ messages in thread
From: Andreas Sturmlechner @ 2025-06-22 10:58 UTC (permalink / raw
  To: gentoo-commits
commit:     5c7a21e66f4de43322dd706a4517c27b796ebcc0
Author:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
AuthorDate: Fri Jun 13 15:26:53 2025 +0000
Commit:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
CommitDate: Sun Jun 22 10:57:09 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=5c7a21e6
cmake.eclass: Avoid none-detection by ensuring match starts w/ digit
Thanks-to: Ionen Wolkens <ionen <AT> gentoo.org>
Closes: https://bugs.gentoo.org/957990
Bug: https://bugs.gentoo.org/958051
Signed-off-by: Andreas Sturmlechner <asturm <AT> gentoo.org>
 eclass/cmake.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/cmake.eclass b/eclass/cmake.eclass
index ffd11bc0c863..d61992576565 100644
--- a/eclass/cmake.eclass
+++ b/eclass/cmake.eclass
@@ -336,7 +336,7 @@ _cmake_check_build_dir() {
 # Returns 0 if the regex matched (a lower-than-specified version found).
 _cmake_minreqver-lt() {
 	local ver chk=1
-	ver=$(sed -ne "/cmake_minimum_required/I{s/.*\(\.\.\.*\|\s\)\([0-9.]*\)\([)]\|\s\).*$/\2/p;q}" \
+	ver=$(sed -ne "/cmake_minimum_required/I{s/.*\(\.\.\.*\|\s\)\([0-9][0-9.]*\)\([)]\|\s\).*$/\2/p;q}" \
 		"${2}" 2>/dev/null \
 	)
 	if [[ -n ${ver} ]] && ver_test "${ver}" -lt "${1}"; then
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-06-24 19:44 Andreas Sturmlechner
  0 siblings, 0 replies; 6663+ messages in thread
From: Andreas Sturmlechner @ 2025-06-24 19:44 UTC (permalink / raw
  To: gentoo-commits
commit:     da8dbff8c15a12c4dc1f3e3bbc3995b58786491e
Author:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
AuthorDate: Sun Jun 22 21:08:48 2025 +0000
Commit:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
CommitDate: Tue Jun 24 19:44:05 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=da8dbff8
cmake.eclass: Avoid false positives by ensuring we find a function call
Otherwise the regex might pick up a query of the resulting version var, e.g.:
> if(CMAKE_MINIMUM_REQUIRED_VERSION VERSION_LESS 2.8.12)
Closes: https://bugs.gentoo.org/958923
Closes: https://bugs.gentoo.org/958974
Signed-off-by: Andreas Sturmlechner <asturm <AT> gentoo.org>
 eclass/cmake.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/cmake.eclass b/eclass/cmake.eclass
index 109227edfe02..2e799f14352e 100644
--- a/eclass/cmake.eclass
+++ b/eclass/cmake.eclass
@@ -336,7 +336,7 @@ _cmake_check_build_dir() {
 # Returns 0 if the regex matched (a lower-than-specified version found).
 _cmake_minreqver-lt() {
 	local ver chk=1
-	ver=$(sed -ne "/cmake_minimum_required/I{s/.*\(\.\.\.*\|\s\)\([0-9][0-9.]*\)\([)]\|\s\).*$/\2/p;q}" \
+	ver=$(sed -ne "/^\s*cmake_minimum_required/I{s/.*\(\.\.\.*\|\s\)\([0-9][0-9.]*\)\([)]\|\s\).*$/\2/p;q}" \
 		"${2}" 2>/dev/null \
 	)
 	if [[ -n ${ver} ]] && ver_test "${ver}" -lt "${1}"; then
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-06-25  4:35 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-06-25  4:35 UTC (permalink / raw
  To: gentoo-commits
commit:     d909a4e5c4828969e1af52d6199d1539f238a04a
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sun Jun 15 14:58:22 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Wed Jun 25 04:35:37 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=d909a4e5
python-utils-r1.eclass: epytest, create junit xml
Request pytest to output junit format xml files that could be used
for further machine processing of test results.  Use xunit1 format
since it includes filenames that are useful for decoding the `classname`
attribute.  The potential use cases include automatically generating
`EPYTEST_DESELECT` from test failures and verifying the existing lists
for stale values.
We use `mktemp` to create unique filenames, to account for `epytest`
being called multiple times in a single test phase.
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/python-utils-r1.eclass | 7 +++++++
 1 file changed, 7 insertions(+)
diff --git a/eclass/python-utils-r1.eclass b/eclass/python-utils-r1.eclass
index c535a79cb48e..6c887626cbd1 100644
--- a/eclass/python-utils-r1.eclass
+++ b/eclass/python-utils-r1.eclass
@@ -1324,6 +1324,9 @@ epytest() {
 	local color=yes
 	[[ ${NO_COLOR} ]] && color=no
 
+	mkdir -p "${T}/pytest-xml" || die
+	local junit_xml=$(mktemp "${T}/pytest-xml/${EPYTHON}-XXX.xml" || die)
+
 	local args=(
 		# verbose progress reporting and tracebacks
 		-vv
@@ -1345,6 +1348,10 @@ epytest() {
 		# we don't need to preserve them
 		-o tmp_path_retention_count=0
 		-o tmp_path_retention_policy=failed
+		# write a junit .xml file to aid machine processing of results
+		--junit-xml="${junit_xml}"
+		# use xunit1 format as that includes an explicit path
+		-o junit_family=xunit1
 	)
 
 	if has_version ">=dev-python/pytest-8.4.0"; then
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-06-25  4:35 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-06-25  4:35 UTC (permalink / raw
  To: gentoo-commits
commit:     1cab1b738232b8ffa9f6834e4af8177cdbc15f27
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sun Jun 15 14:37:54 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Wed Jun 25 04:35:36 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=1cab1b73
python-utils-r1.eclass: epytest, pass --force-short-summary
Pass `--force-short-summary` when pytest is new enough to accept it,
in order to shorten the long (possibly multi-line) exception messages
that make the "short summary" hard to read.  The complete exception
messages are available along with the backtraces anyway.
This option is available with >=dev-python/pytest-8.4.0, and it restores
the behavior of older dev-python/pytest versions.
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/python-utils-r1.eclass | 9 +++++++++
 1 file changed, 9 insertions(+)
diff --git a/eclass/python-utils-r1.eclass b/eclass/python-utils-r1.eclass
index 840b820d0056..c535a79cb48e 100644
--- a/eclass/python-utils-r1.eclass
+++ b/eclass/python-utils-r1.eclass
@@ -1347,6 +1347,15 @@ epytest() {
 		-o tmp_path_retention_policy=failed
 	)
 
+	if has_version ">=dev-python/pytest-8.4.0"; then
+		args+=(
+			# do not repeat (potentially multi-line) exception messages
+			# in the "short summary" section to make it more readable;
+			# we have them in the backtraces anyway
+			--force-short-summary
+		)
+	fi
+
 	if [[ ! ${PYTEST_DISABLE_PLUGIN_AUTOLOAD} ]]; then
 		args+=(
 			# disable the undesirable-dependency plugins by default to
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-06-25  4:35 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-06-25  4:35 UTC (permalink / raw
  To: gentoo-commits
commit:     d566ed631d80b9a4d53d3df1d9ff154b056a0878
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Jun 21 10:16:20 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Wed Jun 25 04:35:38 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=d566ed63
python-utils-r1.eclass: Introduce EPYTEST_PLUGINS
Introduce a new EPYTEST_PLUGINS variable that can be used to control
which plugins are used by epytest.  It provides a convenient method
to disable plugin autoloading, as well as specify which plugins to load.
It accepts package names, and includes a mapping from package names
to `-p` argumetns for a number of plugins currently in ::gentoo.
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/python-utils-r1.eclass | 131 +++++++++++++++++++++++++++++++++++++++++-
 1 file changed, 130 insertions(+), 1 deletion(-)
diff --git a/eclass/python-utils-r1.eclass b/eclass/python-utils-r1.eclass
index 6c887626cbd1..4ce75b962957 100644
--- a/eclass/python-utils-r1.eclass
+++ b/eclass/python-utils-r1.eclass
@@ -1273,6 +1273,78 @@ _python_check_occluded_packages() {
 # parameter, when calling epytest.  The listed files will be entirely
 # skipped from test collection.
 
+# @ECLASS_VARIABLE: EPYTEST_PLUGINS
+# @DEFAULT_UNSET
+# @DESCRIPTION:
+# An array of pytest plugin package names (without categories) to use
+# for the package.  It has a twofold purpose:
+#
+# 1. When set prior to calling distutils_enable_tests, it causes
+#    dependencies on the specified pytest plugins to be added.
+#
+# 2. When plugin autoloading is disabled, it causes "-p" arguments
+#    loading specified plugins to be added.
+#
+# Defaults to an empty list.
+#
+# The eclasses explicitly handle a number of pytest plugins, and assume
+# the default of "dev-python/${package}" and "-p ${package}" for others.
+# If this is incorrect for some plugin package, please report a bug
+# to have it added.
+#
+# This is not a perfect solution, and may not be sufficient for some
+# packages.  In these cases, either plugin autoloading should be used
+# or PYTEST_PLUGINS environment variable may be used directly (see
+# pytest documentation).
+#
+# For pytest-timeout and pytest-xdist plugins, it is generally
+# preferable to use EPYTEST_TIMEOUT and EPYTEST_XDIST options
+# that handle passing all needed options.
+
+# @ECLASS_VARIABLE: EPYTEST_PLUGIN_AUTOLOAD
+# @DEFAULT_UNSET
+# @DESCRIPTION:
+# If set to a non-empty value, permits pytest plugin autoloading.
+# Otherwise, PYTEST_DISABLE_PLUGIN_AUTOLOAD=1 is set to disable it.
+#
+# If EPYTEST_PLUGINS is set explicitly or EAPI is 9 or later,
+# defaults to disabled.  Otherwise, defaults to enabled.
+# The recommended way to disable it in EAPI 8 or earlier is to set
+# EPYTEST_PLUGINS (possibly to an empty array).
+
+# @FUNCTION: _set_epytest_plugins
+# @INTERNAL
+# @DESCRIPTION:
+# Check if EPYTEST_PLUGINS is set correctly, and set the default
+# if it is not.
+_set_epytest_plugins() {
+	debug-print-function ${FUNCNAME} "$@"
+
+	# TODO: drop BASH_VERSINFO check when we require EAPI 8
+	if [[ ${BASH_VERSINFO[0]} -ge 5 ]]; then
+		[[ ${EPYTEST_PLUGINS@a} == *a* ]]
+	else
+		[[ $(declare -p EPYTEST_PLUGINS) == "declare -a"* ]]
+	fi
+	if [[ ${?} -eq 0 ]]; then
+		# EPYTEST_PLUGINS set explicitly -- disable autoloading
+		: "${EPYTEST_PLUGIN_AUTOLOAD:=}"
+	else
+		if ! declare -p EPYTEST_PLUGINS &>/dev/null; then
+			# EPYTEST_PLUGINS unset -- default to empty.
+			# EPYTEST_PLUGIN_AUTOLOAD default depends on EAPI.
+			EPYTEST_PLUGINS=()
+			if [[ ${EAPI} != [78] ]]; then
+				: "${EPYTEST_PLUGIN_AUTOLOAD:=}"
+			else
+				: "${EPYTEST_PLUGIN_AUTOLOAD:=1}"
+			fi
+		else
+			die 'EPYTEST_PLUGINS must be an array.'
+		fi
+	fi
+}
+
 # @ECLASS_VARIABLE: EPYTEST_TIMEOUT
 # @DEFAULT_UNSET
 # @DESCRIPTION:
@@ -1363,7 +1435,64 @@ epytest() {
 		)
 	fi
 
-	if [[ ! ${PYTEST_DISABLE_PLUGIN_AUTOLOAD} ]]; then
+	_set_epytest_plugins
+	if [[ ! ${EPYTEST_PLUGIN_AUTOLOAD} ]]; then
+		local -x PYTEST_DISABLE_PLUGIN_AUTOLOAD=1
+	fi
+
+	if [[ ${PYTEST_DISABLE_PLUGIN_AUTOLOAD} ]]; then
+		local plugin
+		for plugin in "${EPYTEST_PLUGINS[@]}"; do
+			case ${plugin} in
+				# special cases
+				hypothesis)
+					plugin=hypothesispytest
+					;;
+				noseofyeti)
+					plugin=nose_of_yeti
+					;;
+				pytest-helpers-namespace)
+					plugin=helpers_namespace
+					;;
+				pytest-lazy-fixtures)
+					plugin=pytest_lazyfixture
+					;;
+				pytest-testinfra)
+					plugin=pytest11.testinfra
+					;;
+				# "generic" cases
+				betamax)
+					plugin=pytest-${plugin}
+					;;
+				pyfakefs)
+					plugin=pytest_${plugin}
+					;;
+				# pytest-x-y-z -> x-y-z
+				pytest-aiohttp         | pytest-asyncio  | pytest-check     | \
+				pytest-console-scripts | pytest-django   | pytest-env       | \
+				pytest-freezer         | pytest-home     | pytest-httpbin   | \
+				pytest-import-check    | pytest-localftpserver              | \
+				pytest-localserver     | pytest-plus     | pytest-recording | \
+				pytest-regressions     | pytest-repeat   | pytest-reraise   | \
+				pytest-rerunfailures   | pytest-reserial                    | \
+				pytest-shell-utilities | pytest-skip-markers                | \
+				pytest-subtests        | pytest-timeout  | pytest-tornasync | \
+				pytest-trio            | pytext-xdist    | pytest-xprocess  | \
+				pytest-xvfb                                                 )
+					plugin=${plugin#pytest-}
+					;;
+				# foo-bar-baz unchanged
+				pytest-datadir         | pytest-qt       | pytest-subprocess)
+					;;
+				# foo-bar-baz -> foo_bar_baz
+				*)
+					plugin=${plugin//-/_}
+					;;
+			esac
+
+			args+=( -p "${plugin}" )
+		done
+	else
 		args+=(
 			# disable the undesirable-dependency plugins by default to
 			# trigger missing argument strips.  strip options that require
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-06-25  4:35 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-06-25  4:35 UTC (permalink / raw
  To: gentoo-commits
commit:     3229e9f67a15f5a4e9031cb7813be36556537b58
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Jun 21 10:28:28 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Wed Jun 25 04:35:39 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=3229e9f6
distutils-r1.eclass: Add dependencies for EPYTEST_PLUGINS
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/distutils-r1.eclass | 14 ++++++++++++++
 1 file changed, 14 insertions(+)
diff --git a/eclass/distutils-r1.eclass b/eclass/distutils-r1.eclass
index ba97a95f5798..b9366d187555 100644
--- a/eclass/distutils-r1.eclass
+++ b/eclass/distutils-r1.eclass
@@ -561,6 +561,20 @@ distutils_enable_tests() {
 				test_pkgs+=' dev-python/pytest-xdist[${PYTHON_USEDEP}]'
 			fi
 
+			local plugin
+			_set_epytest_plugins
+			for plugin in "${EPYTEST_PLUGINS[@]}"; do
+				case ${plugin} in
+					pkgcore)
+						plugin=sys-apps/${plugin}
+						;;
+					*)
+						plugin=dev-python/${plugin}
+						;;
+				esac
+				test_pkgs+=" ${plugin}[\${PYTHON_USEDEP}]"
+			done
+
 			if [[ ! ${DISTUTILS_SINGLE_IMPL} ]]; then
 				test_deps+=" ${test_pkgs//'${PYTHON_USEDEP}'/${PYTHON_USEDEP}}"
 			else
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-06-28 15:03 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-06-28 15:03 UTC (permalink / raw
  To: gentoo-commits
commit:     e1643d4b6d7d78b8e4b80e14a1fe0f6f72f6c468
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Jun 28 14:56:02 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat Jun 28 14:56:02 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=e1643d4b
llvm.org.eclass: Add 21.0.0_pre20250628 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index 28fa6d6d1024..f835b0d2dc0d 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -72,6 +72,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 			_LLVM_SOURCE_TYPE=snapshot
 
 			case ${PV} in
+				21.0.0_pre20250628)
+					EGIT_COMMIT=e34e02128ec5eb89e36a8f0f7307dcbcfecabbee
+					;;
 				21.0.0_pre20250614)
 					EGIT_COMMIT=814ac2e3735e52c1162ac495c24158e0ac256520
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-06-28 15:03 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-06-28 15:03 UTC (permalink / raw
  To: gentoo-commits
commit:     3c320510fbc9c9a9f33b5c7415e7736bbeb246a3
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Jun 28 14:55:27 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat Jun 28 14:55:27 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=3c320510
llvm.org.eclass: Remove old snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 ---
 1 file changed, 3 deletions(-)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index f7eefbe86c4c..28fa6d6d1024 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -75,9 +75,6 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 				21.0.0_pre20250614)
 					EGIT_COMMIT=814ac2e3735e52c1162ac495c24158e0ac256520
 					;;
-				21.0.0_pre20250607)
-					EGIT_COMMIT=23d0c7348aacdfcb145a69e533a14131bae830cc
-					;;
 				*)
 					die "Unknown snapshot: ${PV}"
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-06-29  3:20 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-06-29  3:20 UTC (permalink / raw
  To: gentoo-commits
commit:     5d8cc9a83de7eec8350aebcccd091c6b6c9ff2a5
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Wed Jun 25 14:34:23 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sun Jun 29 03:20:52 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=5d8cc9a8
python-utils-r1.eclass: Find plugin args via entry points
Rather than hardcoding a list of "-p" arguments for various plugins,
iterate through entry points to find them.  This should be quite
reliable, given that we require PN to match Python project names,
and we can add a mapping for the few outliers.
Suggested-by: Anna Vyalkova
See-also: https://public-inbox.gentoo.org/gentoo-dev/4503EEA7-3610-4556-AF74-A4D850C64D5C <AT> gentoo.org/T/#m3487af520bfaec9dbaba0ea800bb0aca5fb2fcdc
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/python-utils-r1.eclass | 73 +++++++++++--------------------------------
 1 file changed, 19 insertions(+), 54 deletions(-)
diff --git a/eclass/python-utils-r1.eclass b/eclass/python-utils-r1.eclass
index 4ce75b962957..dce565b8b036 100644
--- a/eclass/python-utils-r1.eclass
+++ b/eclass/python-utils-r1.eclass
@@ -1288,9 +1288,9 @@ _python_check_occluded_packages() {
 # Defaults to an empty list.
 #
 # The eclasses explicitly handle a number of pytest plugins, and assume
-# the default of "dev-python/${package}" and "-p ${package}" for others.
-# If this is incorrect for some plugin package, please report a bug
-# to have it added.
+# the default of "dev-python/${package}" and obtain "-p" via entry
+# points.  If this is incorrect for some plugin package, please report
+# a bug.
 #
 # This is not a perfect solution, and may not be sufficient for some
 # packages.  In these cases, either plugin autoloading should be used
@@ -1441,57 +1441,22 @@ epytest() {
 	fi
 
 	if [[ ${PYTEST_DISABLE_PLUGIN_AUTOLOAD} ]]; then
-		local plugin
-		for plugin in "${EPYTEST_PLUGINS[@]}"; do
-			case ${plugin} in
-				# special cases
-				hypothesis)
-					plugin=hypothesispytest
-					;;
-				noseofyeti)
-					plugin=nose_of_yeti
-					;;
-				pytest-helpers-namespace)
-					plugin=helpers_namespace
-					;;
-				pytest-lazy-fixtures)
-					plugin=pytest_lazyfixture
-					;;
-				pytest-testinfra)
-					plugin=pytest11.testinfra
-					;;
-				# "generic" cases
-				betamax)
-					plugin=pytest-${plugin}
-					;;
-				pyfakefs)
-					plugin=pytest_${plugin}
-					;;
-				# pytest-x-y-z -> x-y-z
-				pytest-aiohttp         | pytest-asyncio  | pytest-check     | \
-				pytest-console-scripts | pytest-django   | pytest-env       | \
-				pytest-freezer         | pytest-home     | pytest-httpbin   | \
-				pytest-import-check    | pytest-localftpserver              | \
-				pytest-localserver     | pytest-plus     | pytest-recording | \
-				pytest-regressions     | pytest-repeat   | pytest-reraise   | \
-				pytest-rerunfailures   | pytest-reserial                    | \
-				pytest-shell-utilities | pytest-skip-markers                | \
-				pytest-subtests        | pytest-timeout  | pytest-tornasync | \
-				pytest-trio            | pytext-xdist    | pytest-xprocess  | \
-				pytest-xvfb                                                 )
-					plugin=${plugin#pytest-}
-					;;
-				# foo-bar-baz unchanged
-				pytest-datadir         | pytest-qt       | pytest-subprocess)
-					;;
-				# foo-bar-baz -> foo_bar_baz
-				*)
-					plugin=${plugin//-/_}
-					;;
-			esac
-
-			args+=( -p "${plugin}" )
-		done
+		if [[ ${EPYTEST_PLUGINS[@]} ]]; then
+			local plugin_args=()
+			readarray -t -d '' plugin_args < <(
+				"${EPYTHON}" - "${EPYTEST_PLUGINS[@]}" <<-EOF || die
+					import sys
+					from importlib.metadata import distribution, entry_points
+					packages = {distribution(x).name for x in sys.argv[1:]}
+					eps = {
+						f"-p{x.name}" for x in entry_points(group="pytest11")
+						if x.dist.name in packages
+					}
+					sys.stdout.write("\\0".join(sorted(eps)))
+				EOF
+			)
+			args+=( "${plugin_args[@]}" )
+		fi
 	else
 		args+=(
 			# disable the undesirable-dependency plugins by default to
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-06-29 22:57 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-06-29 22:57 UTC (permalink / raw
  To: gentoo-commits
commit:     28b60013d6c03a8d25143efd9b9901cdad9f8af1
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Jun 29 22:55:55 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Jun 29 22:55:55 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=28b60013
perl-module.eclass: move DIST_MAKE setting into perl-module_src_configure
Quoting https://bugs.gentoo.org/959230#c1
> What's interesting is, in https://bugs.gentoo.org/943847#c3, I added -std=gnu17
> (because dev-perl/Tk is kind of a mess, loads of pending PRs upstream for Modern C fixes),
> but that seems to not be working now with EAPI 8 because of some perl-module.eclass changes.
Move DIST_MAKE into perl-module_src_configure so that append-flags
in src_configure works. Acked by dilfridge on IRC.
Bug: https://bugs.gentoo.org/943847
Closes: https://bugs.gentoo.org/959230
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/perl-module.eclass | 9 +++++----
 1 file changed, 5 insertions(+), 4 deletions(-)
diff --git a/eclass/perl-module.eclass b/eclass/perl-module.eclass
index 27cd053f0ea7..29b4959bfa98 100644
--- a/eclass/perl-module.eclass
+++ b/eclass/perl-module.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2024 Gentoo Authors
+# Copyright 1999-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: perl-module.eclass
@@ -190,9 +190,6 @@ LICENSE="${LICENSE:-|| ( Artistic GPL-1+ )}"
 # (EAPI=8 and later) This Bash array contains parameters to the make call
 # from ExtUtils::MakeMaker. Replaces mymake in EAPI=7 and earlier.
 # Defaults to ( OPTIMIZE="${CFLAGS}" )
-if [[ $(declare -p DIST_MAKE 2>&-) != "declare -a DIST_MAKE="* ]]; then
-	DIST_MAKE=( OPTIMIZE="${CFLAGS}" )
-fi
 
 DIST_NAME=${DIST_NAME:-${PN}}
 DIST_P=${DIST_NAME}-${DIST_VERSION:-${PV}}
@@ -234,6 +231,10 @@ perl-module_src_prepare() {
 perl-module_src_configure() {
 	debug-print-function ${FUNCNAME} "$@"
 
+	if [[ $(declare -p DIST_MAKE 2>&-) != "declare -a DIST_MAKE="* ]]; then
+		DIST_MAKE=( OPTIMIZE="${CFLAGS}" )
+	fi
+
 	# Perl runs LD with LDFLAGS
 	export CCLD=$(tc-getCC)
 	unset LD
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-06-30  6:09 Ionen Wolkens
  0 siblings, 0 replies; 6663+ messages in thread
From: Ionen Wolkens @ 2025-06-30  6:09 UTC (permalink / raw
  To: gentoo-commits
commit:     6960652425ec59424a7eca66caf625ab13a67476
Author:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
AuthorDate: Mon Jun 30 04:59:03 2025 +0000
Commit:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
CommitDate: Mon Jun 30 06:08:01 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=69606524
qt6-build.eclass: move CMAKE_QA_COMPAT_SKIP=1 to src_prepare
This was changed in cmake.eclass, could move it global but kind of
prefer to avoid this in an eclass and it has the minor bonus of
letting the src_install QA check still happen which we have no
reason to skip on such a large dev-qt/*:6 scale.
Signed-off-by: Ionen Wolkens <ionen <AT> gentoo.org>
 eclass/qt6-build.eclass | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/eclass/qt6-build.eclass b/eclass/qt6-build.eclass
index c60a56f84203..462de4e0b1ad 100644
--- a/eclass/qt6-build.eclass
+++ b/eclass/qt6-build.eclass
@@ -118,6 +118,9 @@ qt6-build_src_unpack() {
 # QT6_PREFIX, QT6_LIBDIR, and others), and handle anything else
 # generic as needed.
 qt6-build_src_prepare() {
+	# Qt has quite a lot of unused (false positive) CMakeLists.txt
+	local CMAKE_QA_COMPAT_SKIP=1
+
 	cmake_src_prepare
 
 	if [[ -e CMakeLists.txt ]]; then
@@ -178,9 +181,6 @@ qt6-build_src_configure() {
 		local mycmakeargs=("${defaultcmakeargs[@]}")
 	fi
 
-	# Qt has quite a lot of unused (false positive) CMakeLists.txt
-	local CMAKE_QA_COMPAT_SKIP=1
-
 	cmake_src_configure
 }
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-07-02  8:20 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-07-02  8:20 UTC (permalink / raw
  To: gentoo-commits
commit:     c7f15c0c01477466bae965eec6bb1d624e87e439
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Wed Jul  2 06:19:31 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Wed Jul  2 08:12:17 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=c7f15c0c
verify-sig.eclass: Fix multi-file verify-sig_verify_signed_checksums
Fix a regression in verify-sig_verify_signed_checksums() that caused
it to incorrectly explode arguments when multiple filenames were
passed to the `files` argument.
Fixes: 6f570b3d2d9f (verify-sig.eclass: add app-crypt/signify support)
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/verify-sig.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/verify-sig.eclass b/eclass/verify-sig.eclass
index 12b689f0f4b2..1cd3e1010ae5 100644
--- a/eclass/verify-sig.eclass
+++ b/eclass/verify-sig.eclass
@@ -412,7 +412,7 @@ verify-sig_verify_signed_checksums() {
 	case ${VERIFY_SIG_METHOD} in
 		openpgp)
 			_gpg_verify_signed_checksums \
-				"${checksum_file}" "${algo}" "${files[@]}" "${key}"
+				"${checksum_file}" "${algo}" "${files[*]}" "${key}"
 			;;
 		signify)
 			signify -C -p "${key}" \
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-07-02 10:53 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-07-02 10:53 UTC (permalink / raw
  To: gentoo-commits
commit:     16438fc626362dab42efb1ae691ec9204c824f61
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Wed Jul  2 10:53:15 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Wed Jul  2 10:53:37 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=16438fc6
kernel-build.eclass: Enable py3.14
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/kernel-build.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/kernel-build.eclass b/eclass/kernel-build.eclass
index 77faf6f651e5..67c074495000 100644
--- a/eclass/kernel-build.eclass
+++ b/eclass/kernel-build.eclass
@@ -36,7 +36,7 @@ esac
 if [[ -z ${_KERNEL_BUILD_ECLASS} ]]; then
 _KERNEL_BUILD_ECLASS=1
 
-PYTHON_COMPAT=( python3_{11..13} )
+PYTHON_COMPAT=( python3_{11..14} )
 if [[ ${KERNEL_IUSE_MODULES_SIGN} ]]; then
 	inherit secureboot
 fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-07-02 17:38 Andreas Sturmlechner
  0 siblings, 0 replies; 6663+ messages in thread
From: Andreas Sturmlechner @ 2025-07-02 17:38 UTC (permalink / raw
  To: gentoo-commits
commit:     0b74aad38d7f8a797e0338cb6102946cc2cd5802
Author:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
AuthorDate: Wed Jul  2 17:32:06 2025 +0000
Commit:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
CommitDate: Wed Jul  2 17:38:20 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=0b74aad3
ecm.eclass: Move dev-qt/qttools:6[assistant] behind IUSE doc again
Closes: https://bugs.gentoo.org/959142
Signed-off-by: Andreas Sturmlechner <asturm <AT> gentoo.org>
 eclass/ecm.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/ecm.eclass b/eclass/ecm.eclass
index cafdf034329d..31315f2b8d75 100644
--- a/eclass/ecm.eclass
+++ b/eclass/ecm.eclass
@@ -284,7 +284,7 @@ case ${ECM_QTHELP} in
 		COMMONDEPEND+=" doc? ( dev-qt/qt-docs:${_KFSLOT} )"
 		BDEPEND+=" doc? ( >=app-text/doxygen-1.8.13-r1 )"
 		if [[ ${_KFSLOT} == 6 ]]; then
-			BDEPEND+=" dev-qt/qttools:${_KFSLOT}[assistant]"
+			BDEPEND+=" doc? ( dev-qt/qttools:${_KFSLOT}[assistant] )"
 		else
 			BDEPEND+=" doc? ( dev-qt/qthelp:${_KFSLOT} )"
 		fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-07-04  3:26 Eli Schwartz
  0 siblings, 0 replies; 6663+ messages in thread
From: Eli Schwartz @ 2025-07-04  3:26 UTC (permalink / raw
  To: gentoo-commits
commit:     7801ce6a69b8b59022d005bc077d58f2068fcc2b
Author:     Eli Schwartz <eschwartz <AT> gentoo <DOT> org>
AuthorDate: Thu Jul  3 21:56:20 2025 +0000
Commit:     Eli Schwartz <eschwartz <AT> gentoo <DOT> org>
CommitDate: Fri Jul  4 03:20:45 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=7801ce6a
dot-a.eclass: make strip-lto remember if guarantee-fat ran
The current implementation checks repeatedly if `tc-is-lto` is true.  In
addition to running a small compile check redundantly, this has a
potential correctness downside. An ebuild could do this:
```
lto-guarantee-fat
tc-is-lto && myeconfargs+=( --enable-lto )
filter-lto
```
The idea is, the configure script has special handling and simply adding
-flto is too "simple" to work. e.g. not all sources build with LTO.
When this happens, strip-lto-bytecode "thinks" we didn't build with LTO
at all, and returns early. By tracking state across functions -- and
across phases -- we can reliably tell if `lto-guarantee-fat` actually
"succeeded".
Bug: https://bugs.gentoo.org/958412
Acked-by: Sam James <sam <AT> gentoo.org>
Signed-off-by: Eli Schwartz <eschwartz <AT> gentoo.org>
 eclass/dot-a.eclass | 11 ++++++++++-
 1 file changed, 10 insertions(+), 1 deletion(-)
diff --git a/eclass/dot-a.eclass b/eclass/dot-a.eclass
index ffd34d9e08aa..8d866e6dedb2 100644
--- a/eclass/dot-a.eclass
+++ b/eclass/dot-a.eclass
@@ -50,6 +50,12 @@ _DOT_A_ECLASS=1
 
 inherit flag-o-matic toolchain-funcs
 
+# @VARIABLE: _DOT_A_IS_LTO
+# @INTERNAL
+# @DESCRIPTION:
+# Records the state of tc-is-lto across eclass function calls.
+_DOT_A_IS_LTO=0
+
 # TODO: QA check
 
 # @FUNCTION: lto-guarantee-fat
@@ -59,6 +65,7 @@ inherit flag-o-matic toolchain-funcs
 lto-guarantee-fat() {
 	tc-is-lto || return
 
+	_DOT_A_IS_LTO=1
 	# We add this for all languages as LTO obviously can't be done
 	# if different compilers are used for e.g. C vs C++ anyway.
 	append-flags $(test-flags-CC -ffat-lto-objects)
@@ -73,7 +80,9 @@ lto-guarantee-fat() {
 # As an optimisation, if USE=static-libs exists for a package and is disabled,
 # the default-searching behaviour with no arguments is suppressed.
 strip-lto-bytecode() {
-	tc-is-lto || return
+	if [[ ${_DOT_A_IS_LTO} != 1 ]] && ! tc-is-lto; then
+		return
+	fi
 
 	local files=()
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-07-05  7:16 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-07-05  7:16 UTC (permalink / raw
  To: gentoo-commits
commit:     1f14d47e71be09731dc65f2547455921972539be
Author:     Sv. Lockal <lockalsash <AT> gmail <DOT> com>
AuthorDate: Sun Jun 22 14:32:01 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jul  5 07:14:12 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=1f14d47e
toolchain-funcs.eclass: add tc-getHIPCXX function
This allows to find compiler for HIP language files.
Environment variable HIPCXX is used by CMake[1].
In recent releases of CMake, it strictly requires clang++, not hipcc.
When not defined, CMake uses multiple methods to find HIP compiler, hipconfig is one of them[2].
[1] https://cmake.org/cmake/help/latest/envvar/HIPCXX.html
[2] https://gitlab.kitware.com/cmake/cmake/-/blob/master/Modules/CMakeDetermineHIPCompiler.cmake
Bug: https://bugs.gentoo.org/957893
Signed-off-by: Sv. Lockal <lockalsash <AT> gmail.com>
Part-of: https://github.com/gentoo/gentoo/pull/42691
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain-funcs.eclass | 4 ++++
 1 file changed, 4 insertions(+)
diff --git a/eclass/toolchain-funcs.eclass b/eclass/toolchain-funcs.eclass
index baf032bbd4ec..1f3f958badee 100644
--- a/eclass/toolchain-funcs.eclass
+++ b/eclass/toolchain-funcs.eclass
@@ -73,6 +73,10 @@ tc-getCPP() { tc-getPROG CPP "${CC:-gcc} -E" "$@"; }
 # @USAGE: [toolchain prefix]
 # @RETURN: name of the C++ compiler
 tc-getCXX() { tc-getPROG CXX g++ "$@"; }
+# @FUNCTION: tc-getHIPCXX
+# @USAGE: [toolchain prefix]
+# @RETURN: name of the HIP compiler
+tc-getHIPCXX() { tc-getPROG HIPCXX "$(hipconfig --hipclangpath)/clang++" "$@"; }
 # @FUNCTION: tc-getLD
 # @USAGE: [toolchain prefix]
 # @RETURN: name of the linker
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-07-05  7:16 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-07-05  7:16 UTC (permalink / raw
  To: gentoo-commits
commit:     74d25eedd9c327fe91048b06ad81b86eb14d9cb7
Author:     Sv. Lockal <lockalsash <AT> gmail <DOT> com>
AuthorDate: Sun Jun 22 14:41:48 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jul  5 07:14:13 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=74d25eed
flag-o-matic.eclass: Add functions for testing/stipping HIPFLAGS
HIPFLAFS allows to specify default compilation flags to be used when compiling HIP files.
As environment variable, it is supported in CMake for all projects that specify HIP as language[1][2].
Some flags like -mtls-dialect=* are not supported by HIP compiler; test-flags-HIPCXX can be used to test flags.
[1] https://cmake.org/cmake/help/latest/envvar/HIPFLAGS.html
[2] https://rocm.docs.amd.com/en/latest/conceptual/cmake-packages.html#using-the-hip-single-source-programming-model
Bug: https://bugs.gentoo.org/957893
Signed-off-by: Sv. Lockal <lockalsash <AT> gmail.com>
Part-of: https://github.com/gentoo/gentoo/pull/42691
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/flag-o-matic.eclass | 26 +++++++++++++++++++++++++-
 1 file changed, 25 insertions(+), 1 deletion(-)
diff --git a/eclass/flag-o-matic.eclass b/eclass/flag-o-matic.eclass
index f22854c646c7..1c9abe1280b6 100644
--- a/eclass/flag-o-matic.eclass
+++ b/eclass/flag-o-matic.eclass
@@ -636,6 +636,11 @@ _test-flag-PROG() {
 
 			cmdline_extra+=(-xc)
 			;;
+		hip)
+			in_ext='hip'
+			in_src='int main(void) { return 0; }'
+			cmdline_extra+=(-xhip -c)
+			;;
 	esac
 	local test_in=${T}/test-flag.${in_ext}
 	local test_out=${T}/test-flag.exe
@@ -707,6 +712,12 @@ test-flag-FC() { _test-flag-PROG FC f95 "$@"; }
 # Returns shell true if <flag> is supported by the C compiler and linker, else returns shell false.
 test-flag-CCLD() { _test-flag-PROG CC c+ld "$@"; }
 
+# @FUNCTION: test-flag-HIPCXX
+# @USAGE: <flag>
+# @DESCRIPTION:
+# Returns shell true if <flag> is supported by the HIP compiler, else returns shell false.
+test-flag-HIPCXX() { _test-flag-PROG HIPCXX hip "$@"; }
+
 # @FUNCTION: test-flags-PROG
 # @USAGE: <compiler> <flag> [more flags...]
 # @INTERNAL
@@ -788,6 +799,12 @@ test-flags-FC() { _test-flags-PROG FC "$@"; }
 # Returns shell true if <flags> are supported by the C compiler and default linker, else returns shell false.
 test-flags-CCLD() { _test-flags-PROG CCLD "$@"; }
 
+# @FUNCTION: test-flags-HIPCXX
+# @USAGE: <flags>
+# @DESCRIPTION:
+# Returns shell true if <flags> are supported by the HIP compiler and default linker, else returns shell false.
+test-flags-HIPCXX() { _test-flags-PROG HIPCXX "$@"; }
+
 # @FUNCTION: test-flags
 # @USAGE: <flags>
 # @DESCRIPTION:
@@ -810,7 +827,7 @@ test_version_info() {
 
 # @FUNCTION: strip-unsupported-flags
 # @DESCRIPTION:
-# Strip {C,CXX,F,FC}FLAGS of any flags not supported by the active toolchain.
+# Strip {C,CXX,F,FC,HIP}FLAGS of any flags not supported by the active toolchain.
 strip-unsupported-flags() {
 	[[ $# -ne 0 ]] && die "strip-unsupported-flags takes no arguments"
 	export CFLAGS=$(test-flags-CC ${CFLAGS})
@@ -818,6 +835,7 @@ strip-unsupported-flags() {
 	export FFLAGS=$(test-flags-F77 ${FFLAGS})
 	export FCFLAGS=$(test-flags-FC ${FCFLAGS})
 	export LDFLAGS=$(test-flags-CCLD ${LDFLAGS})
+	export HIPFLAGS=$(test-flags-HIPCXX ${HIPFLAGS})
 }
 
 # @FUNCTION: get-flag
@@ -1008,6 +1026,12 @@ test-compile() {
 			args+=(${FCFLAGS[@]} ${LDFLAGS[@]} -xf95)
 			libs+=(${LIBS[@]})
 			;;
+		hip)
+			compiler="$(tc-getHIPCXX)"
+			filename_in="${T}/test.hip"
+			filename_out="${T}/test.o"
+			args+=(${CFLAGS[@]} -xhip -c)
+			;;
 		*)
 			die "Unknown compiled language ${lang}"
 			;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-07-05  7:16 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-07-05  7:16 UTC (permalink / raw
  To: gentoo-commits
commit:     2acae82eccef3486ca64d4dd2121be8fd92518ea
Author:     Sv. Lockal <lockalsash <AT> gmail <DOT> com>
AuthorDate: Sun Jun 22 14:54:15 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jul  5 07:14:13 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=2acae82e
rocm.eclass: add rocm_use_clang and strip flags in a better way
In recent releases some ROCm packages switched from hipcc to clang++
(as hipcc is now mostly a simple wrapper that calls clang++).
New rocm_use_clang function allows to switch compiler to HIP-compatible clang.
Both hipcc and clang reject some flags when compiling *.hip files;
to clean incompatible CXXFLAGS new test-flags-HIPCXX function is used.
Bug: https://bugs.gentoo.org/957893
Signed-off-by: Sv. Lockal <lockalsash <AT> gmail.com>
Part-of: https://github.com/gentoo/gentoo/pull/42691
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/rocm.eclass | 29 ++++++++++++++++++++++++++++-
 1 file changed, 28 insertions(+), 1 deletion(-)
diff --git a/eclass/rocm.eclass b/eclass/rocm.eclass
index 65726a0bc621..a7601bf43f2d 100644
--- a/eclass/rocm.eclass
+++ b/eclass/rocm.eclass
@@ -246,6 +246,18 @@ check_amdgpu() {
 
 fi
 
+# @FUNCTION: _rocm_strip_unsupported_flags
+# @INTERNAL
+# @DESCRIPTION:
+# Clean flags that are not compatible with 'amdgcn-amd-amdhsa' target.
+_rocm_strip_unsupported_flags() {
+	strip-unsupported-flags
+
+	# FLAGS like -mtls-dialect=* pass test-flags-CXX check, but are not supported
+	# bug #957893
+	export CXXFLAGS=$(test-flags-HIPCXX ${CXXFLAGS})
+}
+
 # @FUNCTION: rocm_use_hipcc
 # @USAGE: rocm_use_hipcc
 # @DESCRIPTION:
@@ -267,5 +279,20 @@ rocm_use_hipcc() {
 	# Export updated CC and CXX. Note that CC is needed even if no C code used,
 	# as CMake checks that C compiler can compile a simple test program.
 	export CC=hipcc CXX=hipcc
-	strip-unsupported-flags
+	_rocm_strip_unsupported_flags
+}
+
+# @FUNCTION: rocm_use_clang
+# @USAGE: rocm_use_clang
+# @DESCRIPTION:
+# switch active C and C++ compilers to clang/clang++, clean unsupported flags
+rocm_use_clang() {
+	local hipclangpath
+	if ! hipclangpath=$(hipconfig --hipclangpath); then
+        die "Error: \"hipconfig --hipclangpath\" failed"
+    fi
+	
+	export CC="${hipclangpath}/${CHOST}-clang"
+	export CXX="${hipclangpath}/${CHOST}-clang++"
+	_rocm_strip_unsupported_flags
 }
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-07-05  7:59 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-07-05  7:59 UTC (permalink / raw
  To: gentoo-commits
commit:     ab0bc645e7ed3450121c7ae8b47ca86421315196
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Jul  5 07:57:47 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jul  5 07:58:34 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=ab0bc645
nginx.eclass: drop unversioned Perl virtual deps
These are provided by Perl itself and we're trying to phase out use
of virtuals w/ no version for these because they're by definition already
avaiable as part of dev-lang/perl.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/nginx.eclass | 3 ---
 1 file changed, 3 deletions(-)
diff --git a/eclass/nginx.eclass b/eclass/nginx.eclass
index 968b3101dfd1..d538078f096e 100644
--- a/eclass/nginx.eclass
+++ b/eclass/nginx.eclass
@@ -308,9 +308,6 @@ unset -f _ngx_populate_iuse
 BDEPEND="
 	test? (
 		dev-lang/perl
-		virtual/perl-IO-Compress
-		virtual/perl-Test-Simple
-		virtual/perl-Test-Harness
 	)
 "
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread
* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-07-05  8:18 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-07-05  8:18 UTC (permalink / raw
  To: gentoo-commits
commit:     5f861877cf5c818395641f073edd5735b3489f42
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Jul  5 08:14:28 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jul  5 08:18:44 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=5f861877
nginx-module.eclass: drop unversioned Perl virtual dep
This is provided by Perl itself and we're trying to phase out use
of virtuals w/ no version for these because they're by definition already
avaiable as part of dev-lang/perl.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/nginx-module.eclass | 1 -
 1 file changed, 1 deletion(-)
diff --git a/eclass/nginx-module.eclass b/eclass/nginx-module.eclass
index 55fa58e52133..ee2071cbf77b 100644
--- a/eclass/nginx-module.eclass
+++ b/eclass/nginx-module.eclass
@@ -522,7 +522,6 @@ _ngx_mod_set_test_env() {
 	RESTRICT="!test? ( test )"
 	BDEPEND+=" test? (
 		dev-perl/Test-Nginx
-		virtual/perl-Test-Harness
 	)
 	"
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-07-05 12:44 Ionen Wolkens
  0 siblings, 0 replies; 6663+ messages in thread
From: Ionen Wolkens @ 2025-07-05 12:44 UTC (permalink / raw
  To: gentoo-commits
commit:     50155ff507b8196cbeb10b2d929f0710f55212d3
Author:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
AuthorDate: Sat Jul  5 11:51:23 2025 +0000
Commit:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
CommitDate: Sat Jul  5 12:42:26 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=50155ff5
qt6-build.eclass: assert the qtdeclarative dependency with USE=qml
Unclear what really happened in bug #959567, but either way
I think it wouldn't hurt to add this so that we can either stop
suspecting portage, or catch the issue in a clearer way.
Bug: https://bugs.gentoo.org/959567
Signed-off-by: Ionen Wolkens <ionen <AT> gentoo.org>
 eclass/qt6-build.eclass | 13 +++++++++++++
 1 file changed, 13 insertions(+)
diff --git a/eclass/qt6-build.eclass b/eclass/qt6-build.eclass
index 462de4e0b1ad..8af563a432fd 100644
--- a/eclass/qt6-build.eclass
+++ b/eclass/qt6-build.eclass
@@ -118,6 +118,19 @@ qt6-build_src_unpack() {
 # QT6_PREFIX, QT6_LIBDIR, and others), and handle anything else
 # generic as needed.
 qt6-build_src_prepare() {
+	# There is a suspicion that there "may" still be portage ordering issues
+	# when Qt's complex depgraph is involved, e.g. build a package with USE=qml
+	# before (matching) qtdeclarative version is updated despite all these
+	# packages DEPEND on ~qtdeclarative-${PV}. Tentatively assert to see if
+	# if the issue really exists (bug #959567).
+	if in_iuse qml && use qml && ! has_version -d "~dev-qt/qtdeclarative-${PV}"
+	then
+		eerror "${CATEGORY}/${PN}[qml] depends on ~dev-qt/qtdeclarative-${PV}"
+		eerror "but it has not been upgraded/installed yet, implies that there"
+		eerror "is a bug in the package manager assuming normal usage."
+		die "aborting to avoid installing a broken package"
+	fi
+
 	# Qt has quite a lot of unused (false positive) CMakeLists.txt
 	local CMAKE_QA_COMPAT_SKIP=1
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-07-05 22:35 Ionen Wolkens
  0 siblings, 0 replies; 6663+ messages in thread
From: Ionen Wolkens @ 2025-07-05 22:35 UTC (permalink / raw
  To: gentoo-commits
commit:     3f82af63c6196e4e9a461f31fbff6eb28c9df9f6
Author:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
AuthorDate: Sat Jul  5 22:33:24 2025 +0000
Commit:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
CommitDate: Sat Jul  5 22:33:27 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=3f82af63
qt6-build.eclass: ignore qtwayland for the dependency assert
Oversight, the only one where the qml? is conditional. Could add
fancier logic but feel it's not worth it for compositor bits.
If get an error about "qtwayland depends on qtdeclarative", please
ignore it and --sync.
Signed-off-by: Ionen Wolkens <ionen <AT> gentoo.org>
 eclass/qt6-build.eclass | 3 ++-
 1 file changed, 2 insertions(+), 1 deletion(-)
diff --git a/eclass/qt6-build.eclass b/eclass/qt6-build.eclass
index 8af563a432fd..0f65ffe0abc6 100644
--- a/eclass/qt6-build.eclass
+++ b/eclass/qt6-build.eclass
@@ -123,7 +123,8 @@ qt6-build_src_prepare() {
 	# before (matching) qtdeclarative version is updated despite all these
 	# packages DEPEND on ~qtdeclarative-${PV}. Tentatively assert to see if
 	# if the issue really exists (bug #959567).
-	if in_iuse qml && use qml && ! has_version -d "~dev-qt/qtdeclarative-${PV}"
+	if in_iuse qml && use qml && [[ ${PN} != qtwayland ]] &&
+		! has_version -d "~dev-qt/qtdeclarative-${PV}"
 	then
 		eerror "${CATEGORY}/${PN}[qml] depends on ~dev-qt/qtdeclarative-${PV}"
 		eerror "but it has not been upgraded/installed yet, implies that there"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-07-07 11:46 Louis Sautier
  0 siblings, 0 replies; 6663+ messages in thread
From: Louis Sautier @ 2025-07-07 11:46 UTC (permalink / raw
  To: gentoo-commits
commit:     482a88ab3e2346bb89fe1eea0c40c2b96e8d04d4
Author:     Louis Sautier <sbraz <AT> gentoo <DOT> org>
AuthorDate: Sun Jul  6 19:57:07 2025 +0000
Commit:     Louis Sautier <sbraz <AT> gentoo <DOT> org>
CommitDate: Mon Jul  7 11:45:57 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=482a88ab
nginx.eclass: make /run/nginx/nginx.pid the default pidfile
This restores pre-eclass behavior, when
108a642ef4da9fa6ae4f0d33580a05cea3f70678 moved the pidfile to a
subfolder of /run.
Signed-off-by: Louis Sautier <sbraz <AT> gentoo.org>
Bug: https://bugs.gentoo.org/939560
Bug: https://bugs.gentoo.org/959651
 eclass/nginx.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/nginx.eclass b/eclass/nginx.eclass
index d538078f096e..170e7f152af8 100644
--- a/eclass/nginx.eclass
+++ b/eclass/nginx.eclass
@@ -591,7 +591,7 @@ nginx_src_configure() {
 		--conf-path="${EPREFIX}/etc/nginx/nginx.conf"
 		--error-log-path="${EPREFIX}/var/log/nginx/error.log"
 		--http-log-path="${EPREFIX}/var/log/nginx/access.log"
-		--pid-path="${EPREFIX}/run/nginx.pid"
+		--pid-path="${EPREFIX}/run/nginx/nginx.pid"
 		--lock-path="${EPREFIX}/run/lock/nginx.lock"
 		--user=nginx
 		--group=nginx
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-07-07 20:58 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-07-07 20:58 UTC (permalink / raw
  To: gentoo-commits
commit:     ce548775e7a22d17639dcabc9b834b60bd1a01b1
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Jul  7 15:52:15 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Jul  7 20:57:20 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=ce548775
toolchain.eclass: link to wiki page in src_test messages
Bug: https://bugs.gentoo.org/959688
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 1 +
 1 file changed, 1 insertion(+)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 12a1ec24132b..8d495776ab43 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -2575,6 +2575,7 @@ toolchain_src_test() {
 		# the failures are tolerable or not, so we bail out.
 		eerror "No reference test data at ${manifest}!"
 		eerror "GCC's tests require a baseline to compare with for any reasonable interpretation of results."
+		eerror "See https://wiki.gentoo.org/wiki/Project:Toolchain/sys-devel/gcc#Test_suite for details."
 
 		if [[ -n ${GCC_TESTS_IGNORE_NO_BASELINE} ]] ; then
 			eerror "GCC_TESTS_IGNORE_NO_BASELINE is set, ignoring test result and creating a new baseline..."
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-07-07 22:25 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-07-07 22:25 UTC (permalink / raw
  To: gentoo-commits
commit:     f414b6c3a528feae0d6006b54870067f27babd94
Author:     Zurab Kvachadze <zurabid2016 <AT> gmail <DOT> com>
AuthorDate: Sat Jul  5 23:47:39 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Jul  7 22:24:31 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=f414b6c3
nginx{,-module}.eclass: do not fail if econf_ngx --help is called
NGINX's ./configure return 1 if "--help" is passed. edo does not like it
and thinks the command failed. The previous code was incorrect in how it
handled the "--help" case.
edo actually never failed (since it was always called with nonfatal,
even when no "--help" was passed), only showed the edo's "Failed to run
command" message.
This commit fixes the --help and all other cases altogether, making
econf_ngx fail when necessary and shut when not.
Signed-off-by: Zurab Kvachadze <zurabid2016 <AT> gmail.com>
Part-of: https://github.com/gentoo/gentoo/pull/42895
Closes: https://github.com/gentoo/gentoo/pull/42895
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/nginx-module.eclass | 13 ++++++++-----
 eclass/nginx.eclass        | 13 ++++++++-----
 2 files changed, 16 insertions(+), 10 deletions(-)
diff --git a/eclass/nginx-module.eclass b/eclass/nginx-module.eclass
index ee2071cbf77b..d25c961af8fd 100644
--- a/eclass/nginx-module.eclass
+++ b/eclass/nginx-module.eclass
@@ -109,12 +109,15 @@ econf_ngx() {
 	debug-print-function "${FUNCNAME[0]}" "$@"
 	[[ ! -x ./configure ]] &&
 		die "./configure is not present in the current working directory or is not executable"
-	nonfatal edo ./configure "$@"
-	# For some reason, NGINX's ./configure returns 1 if it is used with the
-	# '--help' argument.
-	if [[ $? -ne 0 && "$1" != --help ]]; then
-		die -n "./configure ${*@Q} failed"
+	if [[ $1 == --help ]]; then
+		# For some reason, NGINX ./configure returns 1 if it is used with the
+		# '--help' argument.
+		#
+		# Executing this without edo gets rid of the "Failed to run" message.
+		./configure "$@"
+		return
 	fi
+	edo ./configure "$@"
 }
 
 # @FUNCTION: ngx_mod_pkg_to_sonames
diff --git a/eclass/nginx.eclass b/eclass/nginx.eclass
index 170e7f152af8..86ebe194b157 100644
--- a/eclass/nginx.eclass
+++ b/eclass/nginx.eclass
@@ -267,12 +267,15 @@ econf_ngx() {
 	debug-print-function "${FUNCNAME[0]}" "$@"
 	[[ -x ./configure ]] ||
 		die "./configure is not present in the current working directory or is not executable"
-	nonfatal edo ./configure "$@"
-	# For some reason, NGINX ./configure returns 1 if it is used with the
-	# '--help' argument.
-	if [[ $? -ne 0 && $1 != --help ]]; then
-		die -n "./configure ${*@Q} failed"
+	if [[ $1 == --help ]]; then
+		# For some reason, NGINX ./configure returns 1 if it is used with the
+		# '--help' argument.
+		#
+		# Executing this without edo gets rid of the "Failed to run" message.
+		./configure "$@"
+		return
 	fi
+	edo ./configure "$@"
 }
 
 #-----> USE logic <-----
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-07-07 22:51 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-07-07 22:51 UTC (permalink / raw
  To: gentoo-commits
commit:     e6711fad89621867b8277c033920653f36522d8e
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Jul  7 22:50:58 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Jul  7 22:50:58 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=e6711fad
toolchain.eclass: update -fdiagnostics-details version
Didn't make it into 15, hopefully will into 16. Also, drop the
old name (-fdiagnostics-explain-harder) -- though it may be changing
name again, we'll see.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 5 ++++-
 1 file changed, 4 insertions(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 8d495776ab43..ae7a0bf46cce 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -2174,10 +2174,13 @@ gcc_do_filter_flags() {
 	fi
 
 	if ver_test -lt 15.1 ; then
-		filter-flags -fdiagnostics-explain-harder -fdiagnostics-details
 		filter-flags -fdiagnostics-set-output=text:experimental-nesting=yes
 	fi
 
+	if ver_test -lt 16.1 ; then
+		filter-flags -fdiagnostics-details
+	fi
+
 	# Ada: PR116226
 	# D: PR117002 (bug #940750)
 	filter-flags -Warray-bounds
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-07-08 23:35 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-07-08 23:35 UTC (permalink / raw
  To: gentoo-commits
commit:     1f516d68b80369bdf06faec58ba4c552aba0043d
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Jul  8 23:34:34 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Jul  8 23:34:34 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=1f516d68
toolchain.eclass: disable coredump handlers in src_test
Use the magic value of 1 which avoids invoking coredump handlers
like systemd-coredumpd which can be really slow when we have many
intentional or expected crashes.
This trick was suggested by Alexander Monakov.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 5 +++++
 1 file changed, 5 insertions(+)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index ae7a0bf46cce..bcbdd1305cfa 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -2450,6 +2450,11 @@ toolchain_src_test() {
 	# From opensuse's spec file: "asan needs a whole shadow address space"
 	ulimit -v unlimited
 
+	# Use the magic value of 1 which avoids invoking coredump handlers
+	# like systemd-coredumpd which can be really slow when we have many
+	# intentional or expected crashes.
+	prlimit -c=1 -p $$
+
 	# 'asan' wants to be preloaded first, so does 'sandbox'.
 	# To make asan tests work, we disable sandbox for all of test suite.
 	# The 'backtrace' tests also do not like the presence of 'libsandbox.so'.
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-07-09 11:22 James Le Cuirot
  0 siblings, 0 replies; 6663+ messages in thread
From: James Le Cuirot @ 2025-07-09 11:22 UTC (permalink / raw
  To: gentoo-commits
commit:     fdd48738b3e03a92be3b234c1834241504c3765e
Author:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
AuthorDate: Tue Jul  1 10:56:32 2025 +0000
Commit:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
CommitDate: Wed Jul  9 11:21:57 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=fdd48738
sysroot.eclass: Adapt sysroot_make_run_prefixed to work in pkg_* phases
Sometimes this is necessary, such as when doing openssl fipsinstall in
pkg_preinst. With hindsight, I maybe should have called this
root.eclass but oh well.
Signed-off-by: James Le Cuirot <chewi <AT> gentoo.org>
 eclass/sysroot.eclass | 45 ++++++++++++++++++++++++++++++++++-----------
 1 file changed, 34 insertions(+), 11 deletions(-)
diff --git a/eclass/sysroot.eclass b/eclass/sysroot.eclass
index 73d353fd9914..6d1b88232eeb 100644
--- a/eclass/sysroot.eclass
+++ b/eclass/sysroot.eclass
@@ -7,7 +7,11 @@
 # @AUTHOR:
 # James Le Cuirot <chewi@gentoo.org>
 # @SUPPORTED_EAPIS: 7 8
-# @BLURB: Common functions for using a different sysroot (e.g. cross-compiling)
+# @BLURB: Common functions for using a different (sys)root
+# @DESCRIPTION:
+# This eclass provides common functions to run executables within a different
+# root or sysroot, with or without emulation by QEMU. Despite the name, these
+# functions can be used in src_* or pkg_* phase functions.
 
 case ${EAPI} in
 	7|8) ;;
@@ -39,7 +43,7 @@ qemu_arch() {
 
 # @FUNCTION: sysroot_make_run_prefixed
 # @DESCRIPTION:
-# Create a wrapper script for directly running executables within a sysroot
+# Create a wrapper script for directly running executables within a (sys)root
 # without changing the root directory. The path to that script is returned. If
 # no sysroot has been set, then this function returns unsuccessfully.
 #
@@ -48,19 +52,38 @@ qemu_arch() {
 # environment if binfmt_misc has been used with the F flag. It is not feasible
 # to add a conditional dependency on QEMU.
 sysroot_make_run_prefixed() {
-	[[ -z ${SYSROOT} ]] && return 1
+	local QEMU_ARCH=$(qemu_arch) SCRIPT MYROOT MYEROOT LIBGCC
+
+	if [[ ${EBUILD_PHASE_FUNC} == src_* ]]; then
+		[[ -z ${SYSROOT} ]] && return 1
+		SCRIPT="${T}"/sysroot-run-prefixed
+		MYROOT=${SYSROOT}
+		MYEROOT=${ESYSROOT}
 
-	local SCRIPT="${T}"/sysroot-run-prefixed
-	local QEMU_ARCH=$(qemu_arch)
+		# Both methods below might need help to find GCC's libs. GCC might not
+		# be installed in the SYSROOT. Note that Clang supports this flag too.
+		LIBGCC=$($(tc-getCC) ${CPPFLAGS} ${CFLAGS} ${LDFLAGS} -print-libgcc-file-name)
+		LIBGCC=${LIBGCC%/*}
+	else
+		[[ -z ${ROOT} ]] && return 1
+		SCRIPT="${T}"/root-run-prefixed
+		MYROOT=${ROOT}
+		MYEROOT=${EROOT}
 
-	# Both methods below might need help to find GCC's libraries. GCC might not
-	# even be installed in the SYSROOT. Note that Clang supports this flag too.
-	local LIBGCC=$($(tc-getCC) ${CPPFLAGS} ${CFLAGS} ${LDFLAGS} -print-libgcc-file-name)
+		# Both methods below might need help to find GCC's libs. libc++ systems
+		# won't have this file, but it's not needed in that case.
+		if [[ -f ${EROOT}/etc/ld.so.conf.d/05gcc-${CHOST}.conf ]]; then
+			local LIBGCC_A
+			mapfile -t LIBGCC_A < "${EROOT}/etc/ld.so.conf.d/05gcc-${CHOST}.conf"
+			LIBGCC=$(printf "%s:" "${LIBGCC_A[@]/#/${ROOT}}")
+			LIBGCC=${LIBGCC%:}
+		fi
+	fi
 
 	if [[ ${QEMU_ARCH} == $(qemu_arch "${CBUILD}") ]]; then
 		# glibc: ld.so is a symlink, ldd is a binary.
 		# musl: ld.so doesn't exist, ldd is a symlink.
-		local DLINKER=$(find "${ESYSROOT}"/usr/bin/{ld.so,ldd} -type l -print -quit 2>/dev/null || die "failed to find dynamic linker")
+		local DLINKER=$(find "${MYEROOT}"/usr/bin/{ld.so,ldd} -type l -print -quit 2>/dev/null || die "failed to find dynamic linker")
 
 		# musl symlinks ldd to ld-musl.so to libc.so. We want the ld-musl.so
 		# path, not the libc.so path, so don't resolve the symlinks entirely.
@@ -70,14 +93,14 @@ sysroot_make_run_prefixed() {
 		# adjust RUNPATHs, but it is probably good enough.
 		install -m0755 /dev/stdin "${SCRIPT}" <<-EOF || die
 			#!/bin/sh
-			LD_LIBRARY_PATH="\${LD_LIBRARY_PATH}\${LD_LIBRARY_PATH+:}${LIBGCC%/*}:${ESYSROOT}/$(get_libdir):${ESYSROOT}/usr/$(get_libdir)" exec "${DLINKER}" "\${@}"
+			LD_LIBRARY_PATH="\${LD_LIBRARY_PATH}\${LD_LIBRARY_PATH+:}${LIBGCC}:${MYEROOT}/$(get_libdir):${MYEROOT}/usr/$(get_libdir)" exec "${DLINKER}" "\${@}"
 		EOF
 	else
 		# Use QEMU's environment variables rather than its command line
 		# arguments to cover both explicit and implicit QEMU usage.
 		install -m0755 /dev/stdin "${SCRIPT}" <<-EOF || die
 			#!/bin/sh
-			QEMU_SET_ENV="\${QEMU_SET_ENV}\${QEMU_SET_ENV+,}LD_LIBRARY_PATH=\${LD_LIBRARY_PATH}\${LD_LIBRARY_PATH+:}${LIBGCC%/*}" QEMU_LD_PREFIX="${SYSROOT}" exec $(type -P "qemu-${QEMU_ARCH}") "\${@}"
+			QEMU_SET_ENV="\${QEMU_SET_ENV}\${QEMU_SET_ENV+,}LD_LIBRARY_PATH=\${LD_LIBRARY_PATH}\${LD_LIBRARY_PATH+:}${LIBGCC}" QEMU_LD_PREFIX="${MYROOT}" exec $(type -P "qemu-${QEMU_ARCH}") "\${@}"
 		EOF
 	fi
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-07-09 11:22 James Le Cuirot
  0 siblings, 0 replies; 6663+ messages in thread
From: James Le Cuirot @ 2025-07-09 11:22 UTC (permalink / raw
  To: gentoo-commits
commit:     68f87a7fe8498f8fd45fef8817e5de596d302cdf
Author:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
AuthorDate: Tue Jul  1 11:05:34 2025 +0000
Commit:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
CommitDate: Wed Jul  9 11:21:58 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=68f87a7f
sysroot.eclass: Add sysroot_run_prefixed convenience function
This is for simple cases where you just need to run a command
immediately rather than pass a wrapper to a build tool.
Signed-off-by: James Le Cuirot <chewi <AT> gentoo.org>
 eclass/sysroot.eclass | 13 +++++++++++++
 1 file changed, 13 insertions(+)
diff --git a/eclass/sysroot.eclass b/eclass/sysroot.eclass
index 6d1b88232eeb..f17d6bcec2b4 100644
--- a/eclass/sysroot.eclass
+++ b/eclass/sysroot.eclass
@@ -106,3 +106,16 @@ sysroot_make_run_prefixed() {
 
 	echo "${SCRIPT}"
 }
+
+# @FUNCTION: sysroot_run_prefixed
+# @DESCRIPTION:
+# Create a wrapper script with sysroot_make_run_prefixed if necessary, and use
+# it to execute the given command, otherwise just execute the command directly.
+sysroot_run_prefixed() {
+	local script
+	if script=$(sysroot_make_run_prefixed); then
+		"${script}" "${@}"
+	else
+		"${@}"
+	fi
+}
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-07-10  7:51 Miroslav Šulc
  0 siblings, 0 replies; 6663+ messages in thread
From: Miroslav Šulc @ 2025-07-10  7:51 UTC (permalink / raw
  To: gentoo-commits
commit:     e7bcf9b35099a85fed4fd6182b8949b02a7a15c7
Author:     Volkmar W. Pogatzki <gentoo <AT> pogatzki <DOT> net>
AuthorDate: Tue May  6 15:02:48 2025 +0000
Commit:     Miroslav Šulc <fordfrog <AT> gentoo <DOT> org>
CommitDate: Thu Jul 10 07:50:56 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=e7bcf9b3
java-utils-2.eclass: automatic dependency on java-dep-check
When emerging a java package with JAVA_PKG_STRICT enabled, there are
messages telling the user to install java-dep-check and javatoolkit for
running further checks:
  "Install dev-java/java-dep-check for dependency checking"
  "Unable to perform class version checks as"
  "class-version-verify.py is unavailable"
  "Please install dev-java/javatoolkit."
This commit adds both java-dep-check and javatoolkit to BDEPEND.
To avoid circular dependencies with java-dep-check, it also adds a new
eclass variable JAVA_DISABLE_DEPEND_ON_JAVA_DEP_CHECK to be put pre-inherit
to dependencies of java-dep-check.
Closes: https://bugs.gentoo.org/831341
Signed-off-by: Volkmar W. Pogatzki <gentoo <AT> pogatzki.net>
Part-of: https://github.com/gentoo/gentoo/pull/42182
Signed-off-by: Miroslav Šulc <fordfrog <AT> gentoo.org>
 eclass/java-utils-2.eclass | 19 ++++++++++++++++++-
 1 file changed, 18 insertions(+), 1 deletion(-)
diff --git a/eclass/java-utils-2.eclass b/eclass/java-utils-2.eclass
index e2af63819839..c11f1652fc5a 100644
--- a/eclass/java-utils-2.eclass
+++ b/eclass/java-utils-2.eclass
@@ -1,4 +1,4 @@
-# Copyright 2004-2024 Gentoo Authors
+# Copyright 2004-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: java-utils-2.eclass
@@ -295,6 +295,13 @@ JAVA_PKG_COMPILERS_CONF=${JAVA_PKG_COMPILERS_CONF:="/etc/java-config-2/build/com
 #	)
 # @CODE
 
+# @ECLASS_VARIABLE: JAVA_DISABLE_DEPEND_ON_JAVA_DEP_CHECK
+# @PRE_INHERIT
+# @DEFAULT_UNSET
+# @DESCRIPTION:
+# Helper variable to be used in packages which would otherwise have circular
+# dependencies with dev-java/java-dep-check once this is forced to BDEPEND.
+
 # @FUNCTION: java-pkg_doexamples
 # @USAGE: [--subdir <subdir>] <file1/dir1> [<file2> ...]
 # @DESCRIPTION:
@@ -2996,6 +3003,16 @@ is-java-strict() {
 	return $?
 }
 
+# Avoid having to emerge them separately every time
+if is-java-strict; then
+	# Needed for java-pkg_verify-classes
+	BDEPEND="${BDEPEND} dev-java/javatoolkit"
+	if [[ -z "${JAVA_DISABLE_DEPEND_ON_JAVA_DEP_CHECK}" ]]; then
+		# Needed for java-utils-2_pkg_preinst
+		BDEPEND="${BDEPEND} dev-java/java-dep-check:0" || die
+	fi
+fi
+
 # @FUNCTION: java-pkg_clean
 # @DESCRIPTION:
 # Java package cleaner function. This will remove all *.class and *.jar
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-07-12  5:05 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-07-12  5:05 UTC (permalink / raw
  To: gentoo-commits
commit:     394e3796c6324436920b4406006d23e043d69204
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Jul  5 06:06:42 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat Jul 12 05:05:18 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=394e3796
python-utils-r1.eclass: epytest, avoid dupes w/ PYTEST_PLUGINS
Avoid adding duplicate `-p` arguments when the plugin in question
is already loaded via `PYTEST_PLUGINS`.  This avoids errors when
combining dependency adding via `EPYTEST_PLUGINS` with explicit loading
via `PYTEST_PLUGINS` (as needed for plugin tests themselves).
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
Part-of: https://github.com/gentoo/gentoo/pull/42876
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/python-utils-r1.eclass | 5 ++++-
 1 file changed, 4 insertions(+), 1 deletion(-)
diff --git a/eclass/python-utils-r1.eclass b/eclass/python-utils-r1.eclass
index 9e94acf34edf..bbb57901f281 100644
--- a/eclass/python-utils-r1.eclass
+++ b/eclass/python-utils-r1.eclass
@@ -1445,12 +1445,15 @@ epytest() {
 			local plugin_args=()
 			readarray -t -d '' plugin_args < <(
 				"${EPYTHON}" - "${EPYTEST_PLUGINS[@]}" <<-EOF || die
+					import os
 					import sys
 					from importlib.metadata import distribution, entry_points
+
+					env_plugins = os.environ.get("PYTEST_PLUGINS", "").split(",")
 					packages = {distribution(x).name for x in sys.argv[1:]}
 					eps = {
 						f"-p{x.name}" for x in entry_points(group="pytest11")
-						if x.dist.name in packages
+						if x.dist.name in packages and x.value not in env_plugins
 					}
 					sys.stdout.write("\\0".join(sorted(eps)))
 				EOF
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-07-12  5:05 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-07-12  5:05 UTC (permalink / raw
  To: gentoo-commits
commit:     4bc191233cf98231275dc7a997e6cb67f8c81481
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Jul  5 05:48:05 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat Jul 12 05:05:17 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=4bc19123
python-utils-r1.eclass: epytest, support --hypothesis-profile=gentoo
Support using the "gentoo" hypothesis profile, as installed
by dev-python/hypothesis-gentoo, to disable all Hypothesis health
checks.  This avoids spurious test failures, e.g. when the system is
under load and the strategies are underperforming.
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
Part-of: https://github.com/gentoo/gentoo/pull/42876
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/python-utils-r1.eclass | 11 +++++++++++
 1 file changed, 11 insertions(+)
diff --git a/eclass/python-utils-r1.eclass b/eclass/python-utils-r1.eclass
index dce565b8b036..9e94acf34edf 100644
--- a/eclass/python-utils-r1.eclass
+++ b/eclass/python-utils-r1.eclass
@@ -1518,6 +1518,17 @@ epytest() {
 		fi
 	fi
 
+	# If we are using hypothesis (require use via EPYTEST_PLUGINS, since
+	# ebuilds may disable autoloading manually) *and* hypothesis-gentoo
+	# is available, use it to disable all health checks, to prevent the tests
+	# from failing randomly under load.
+	if has hypothesis "${EPYTEST_PLUGINS[@]}" &&
+		"${EPYTHON}" -c 'import hypothesis_gentoo' 2>/dev/null &&
+		[[ ! ${HYPOTHESIS_NO_PLUGINS} ]]
+	then
+		args+=( --hypothesis-profile=gentoo )
+	fi
+
 	local x
 	for x in "${EPYTEST_DESELECT[@]}"; do
 		args+=( --deselect "${x}" )
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-07-12  5:05 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-07-12  5:05 UTC (permalink / raw
  To: gentoo-commits
commit:     ec67342e2635049fcba3755a0efaab3e02bbbecc
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Jul  5 06:31:02 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat Jul 12 05:05:19 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=ec67342e
python-utils-r1.eclass: Add EPYTEST_PLUGIN_LOAD_VIA_ENV
Add an `EPYTEST_PLUGIN_LOAD_VIA_ENV` option to explicitly load plugins
via `PYTEST_PLUGINS` environment variable rather than `-p` options.
This is useful for testing pytest plugins.
While the use case is not very common and therefore may not deserve
explicit eclass support, the value of `PYTEST_PLUGINS` consists
of Python import names that are not trivial to find and have
historically changed across package versions.
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
Part-of: https://github.com/gentoo/gentoo/pull/42876
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/python-utils-r1.eclass | 62 +++++++++++++++++++++++++++++++------------
 1 file changed, 45 insertions(+), 17 deletions(-)
diff --git a/eclass/python-utils-r1.eclass b/eclass/python-utils-r1.eclass
index bbb57901f281..68faa9e2adf9 100644
--- a/eclass/python-utils-r1.eclass
+++ b/eclass/python-utils-r1.eclass
@@ -1312,6 +1312,15 @@ _python_check_occluded_packages() {
 # The recommended way to disable it in EAPI 8 or earlier is to set
 # EPYTEST_PLUGINS (possibly to an empty array).
 
+# @ECLASS_VARIABLE: EPYTEST_PLUGIN_LOAD_VIA_ENV
+# @DEFAULT_UNSET
+# @DESCRIPTION:
+# If set to a non-empty value, plugins will be loaded via PYTEST_PLUGINS
+# environment variable rather than explicit "-p" options.  This ensures
+# that plugins are passed down to subprocess, which may be necessary
+# when testing pytest plugins.  However, this is also more likely
+# to cause duplicate plugin errors.
+
 # @FUNCTION: _set_epytest_plugins
 # @INTERNAL
 # @DESCRIPTION:
@@ -1442,23 +1451,39 @@ epytest() {
 
 	if [[ ${PYTEST_DISABLE_PLUGIN_AUTOLOAD} ]]; then
 		if [[ ${EPYTEST_PLUGINS[@]} ]]; then
-			local plugin_args=()
-			readarray -t -d '' plugin_args < <(
-				"${EPYTHON}" - "${EPYTEST_PLUGINS[@]}" <<-EOF || die
-					import os
-					import sys
-					from importlib.metadata import distribution, entry_points
-
-					env_plugins = os.environ.get("PYTEST_PLUGINS", "").split(",")
-					packages = {distribution(x).name for x in sys.argv[1:]}
-					eps = {
-						f"-p{x.name}" for x in entry_points(group="pytest11")
-						if x.dist.name in packages and x.value not in env_plugins
-					}
-					sys.stdout.write("\\0".join(sorted(eps)))
-				EOF
-			)
-			args+=( "${plugin_args[@]}" )
+			if [[ ${EPYTEST_PLUGIN_LOAD_VIA_ENV} ]]; then
+				local -x PYTEST_PLUGINS=$(
+					"${EPYTHON}" - "${EPYTEST_PLUGINS[@]}" <<-EOF || die
+						import sys
+						from importlib.metadata import distribution, entry_points
+
+						packages = {distribution(x).name for x in sys.argv[1:]}
+						plugins = {
+							x.value for x in entry_points(group="pytest11")
+							if x.dist.name in packages
+						}
+						sys.stdout.write(",".join(sorted(plugins)))
+					EOF
+				)
+			else
+				local plugin_args=()
+				readarray -t -d '' plugin_args < <(
+					"${EPYTHON}" - "${EPYTEST_PLUGINS[@]}" <<-EOF || die
+						import os
+						import sys
+						from importlib.metadata import distribution, entry_points
+
+						env_plugins = os.environ.get("PYTEST_PLUGINS", "").split(",")
+						packages = {distribution(x).name for x in sys.argv[1:]}
+						eps = {
+							f"-p{x.name}" for x in entry_points(group="pytest11")
+							if x.dist.name in packages and x.value not in env_plugins
+						}
+						sys.stdout.write("\\0".join(sorted(eps)))
+					EOF
+				)
+				args+=( "${plugin_args[@]}" )
+			fi
 		fi
 	else
 		args+=(
@@ -1541,6 +1566,9 @@ epytest() {
 	done
 	set -- "${EPYTHON}" -m pytest "${args[@]}" "${@}" ${EPYTEST_FLAGS}
 
+	if [[ ${PYTEST_PLUGINS} ]]; then
+		einfo "PYTEST_PLUGINS=${PYTEST_PLUGINS}"
+	fi
 	echo "${@}" >&2
 	"${@}"
 	local ret=${?}
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-07-13  5:08 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-07-13  5:08 UTC (permalink / raw
  To: gentoo-commits
commit:     f9ea59b479b0a2564383d347e4778d4dd71e5bc9
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Jul 13 05:06:34 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Jul 13 05:06:34 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=f9ea59b4
golang-base.eclass: drop RESTRICT=strip
Any bugs I've been able to find that would justify keeping this were
fixed long ago and other distributions seem to be stripping Go binaries
just fine.
(Arguably not really worth doing golang-base.eclass as it's obsolete
but let's just do it.)
Bug: https://bugs.gentoo.org/926841
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/golang-base.eclass | 5 +----
 1 file changed, 1 insertion(+), 4 deletions(-)
diff --git a/eclass/golang-base.eclass b/eclass/golang-base.eclass
index a2996e3b0683..cad737fdeaca 100644
--- a/eclass/golang-base.eclass
+++ b/eclass/golang-base.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2024 Gentoo Authors
+# Copyright 1999-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: golang-base.eclass
@@ -31,9 +31,6 @@ fi
 # Do not complain about CFLAGS etc since go projects do not use them.
 QA_FLAGS_IGNORED='.*'
 
-# Upstream does not support stripping go packages
-RESTRICT="strip"
-
 # force GO111MODULE to be auto for bug https://bugs.gentoo.org/771129
 export GO111MODULE=auto
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread
* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-07-13  5:08 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-07-13  5:08 UTC (permalink / raw
  To: gentoo-commits
commit:     dc9f739ba2e4016af2c9a0ba0a9dad59fe8343c4
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Jul 13 05:05:29 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Jul 13 05:05:29 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=dc9f739b
go-module.eclass: drop RESTRICT=strip
Any bugs I've been able to find that would justify keeping this were
fixed long ago and other distributions seem to be stripping Go binaries
just fine.
Closes: https://bugs.gentoo.org/926841
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/go-module.eclass | 3 ---
 1 file changed, 3 deletions(-)
diff --git a/eclass/go-module.eclass b/eclass/go-module.eclass
index 14e0aad9dd2a..411d0cd8ea58 100644
--- a/eclass/go-module.eclass
+++ b/eclass/go-module.eclass
@@ -104,9 +104,6 @@ export GOFLAGS="-buildvcs=false -modcacherw -v -x"
 # Do not complain about CFLAGS etc since go projects do not use them.
 QA_FLAGS_IGNORED='.*'
 
-# Go packages should not be stripped with strip(1).
-RESTRICT+=" strip"
-
 # @ECLASS_VARIABLE: EGO_SUM
 # @DEPRECATED: none
 # @DESCRIPTION:
^ permalink raw reply related	[flat|nested] 6663+ messages in thread
* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-07-13 11:20 Nowa Ammerlaan
  0 siblings, 0 replies; 6663+ messages in thread
From: Nowa Ammerlaan @ 2025-07-13 11:20 UTC (permalink / raw
  To: gentoo-commits
commit:     8f7a9128db5bbd61671568fe6dba50db36ffa1da
Author:     Nowa Ammerlaan <nowa <AT> gentoo <DOT> org>
AuthorDate: Sun Jul 13 10:43:32 2025 +0000
Commit:     Nowa Ammerlaan <nowa <AT> gentoo <DOT> org>
CommitDate: Sun Jul 13 10:43:32 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=8f7a9128
kernel-build.eclass: error out early if generic-uki but no zboot
Signed-off-by: Nowa Ammerlaan <nowa <AT> gentoo.org>
 eclass/kernel-build.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/kernel-build.eclass b/eclass/kernel-build.eclass
index 67c074495000..3296f2c6ad75 100644
--- a/eclass/kernel-build.eclass
+++ b/eclass/kernel-build.eclass
@@ -263,6 +263,9 @@ kernel-build_src_configure() {
 	# on the name of the output image. Set this variable to track this setting.
 	if grep -q "CONFIG_EFI_ZBOOT=y" .config; then
 		KERNEL_EFI_ZBOOT=1
+	elif { use arm64 || use riscv || use loong ;} &&
+		[[ ${KERNEL_IUSE_GENERIC_UKI} ]] && use generic-uki; then
+			die "USE=generic-uki requires enabling CONFIG_EFI_ZBOOT"
 	fi
 
 	mkdir -p "${WORKDIR}"/modprep || die
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-07-13 20:03 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-07-13 20:03 UTC (permalink / raw
  To: gentoo-commits
commit:     7fc033f3373e1e9ea9c0a010447d4e950efba705
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sun Jul 13 20:00:05 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sun Jul 13 20:03:44 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=7fc033f3
llvm.org.eclass: Remove old snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 ---
 1 file changed, 3 deletions(-)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index fff4445c02c9..885132550b1c 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -78,9 +78,6 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 				21.0.0_pre20250628)
 					EGIT_COMMIT=e34e02128ec5eb89e36a8f0f7307dcbcfecabbee
 					;;
-				21.0.0_pre20250614)
-					EGIT_COMMIT=814ac2e3735e52c1162ac495c24158e0ac256520
-					;;
 				*)
 					die "Unknown snapshot: ${PV}"
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-07-14 18:55 Andreas K. Hüttel
  0 siblings, 0 replies; 6663+ messages in thread
From: Andreas K. Hüttel @ 2025-07-14 18:55 UTC (permalink / raw
  To: gentoo-commits
commit:     2233039b76561d014626c535123b8392177638bf
Author:     Andreas K. Hüttel <dilfridge <AT> gentoo <DOT> org>
AuthorDate: Mon Jul 14 15:25:01 2025 +0000
Commit:     Andreas K. Hüttel <dilfridge <AT> gentoo <DOT> org>
CommitDate: Mon Jul 14 18:49:54 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=2233039b
toolchain{,-funcs}.eclass: Ensure hf/sf detection works for t64 CHOSTs
Signed-off-by: Andreas K. Hüttel <dilfridge <AT> gentoo.org>
 eclass/toolchain-funcs.eclass | 2 +-
 eclass/toolchain.eclass       | 2 +-
 2 files changed, 2 insertions(+), 2 deletions(-)
diff --git a/eclass/toolchain-funcs.eclass b/eclass/toolchain-funcs.eclass
index 1f3f958badee..fa2820035cb7 100644
--- a/eclass/toolchain-funcs.eclass
+++ b/eclass/toolchain-funcs.eclass
@@ -292,7 +292,7 @@ tc-tuple-is-softfloat() {
 			echo "yes" ;;
 		*-softfp-*)
 			echo "softfp" ;;
-		arm*-hardfloat-*|arm*eabihf)
+		arm*-hardfloat-*|arm*eabihf*)
 			echo "no" ;;
 		# bare-metal targets have their defaults. bug #666896
 		*-newlib|*-elf|*-eabi)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index bcbdd1305cfa..274789559d5e 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1596,7 +1596,7 @@ toolchain_src_configure() {
 			# If they've explicitly opt-ed in, do hardfloat,
 			# otherwise let the gcc default kick in.
 			case ${CTARGET//_/-} in
-				*-hardfloat-*|*eabihf)
+				*-hardfloat-*|*eabihf*)
 					confgcc+=( --with-float=hard )
 				;;
 			esac
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-07-18  4:39 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-07-18  4:39 UTC (permalink / raw
  To: gentoo-commits
commit:     5d977ed349465ab3cdc376194d03424cbb2cb9c8
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Tue Jul 15 05:00:20 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Fri Jul 18 04:39:07 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=5d977ed3
distutils-r1.eclass: Skip dep on ${PN} in EPYTEST_PLUGINS
When `EPYTEST_PLUGINS` contains `${PN}`, skip it when adding
dependencies.  This avoids a self-dependency, while making it possible
to easily test pytest plugins themselves without having to append to
`EPYTEST_PLUGINS` locally.
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
Part-of: https://github.com/gentoo/gentoo/pull/43007
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/distutils-r1.eclass | 4 ++++
 1 file changed, 4 insertions(+)
diff --git a/eclass/distutils-r1.eclass b/eclass/distutils-r1.eclass
index b9366d187555..7b025261eb2b 100644
--- a/eclass/distutils-r1.eclass
+++ b/eclass/distutils-r1.eclass
@@ -565,6 +565,10 @@ distutils_enable_tests() {
 			_set_epytest_plugins
 			for plugin in "${EPYTEST_PLUGINS[@]}"; do
 				case ${plugin} in
+					${PN})
+						# don't add a dependency on self
+						continue
+						;;
 					pkgcore)
 						plugin=sys-apps/${plugin}
 						;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-07-18  4:39 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-07-18  4:39 UTC (permalink / raw
  To: gentoo-commits
commit:     cc63aaba87ed789e8155d0eb1f3f9f2b5a77b67f
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Tue Jul 15 05:23:30 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Fri Jul 18 04:39:10 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=cc63aaba
python-utils-r1.eclass: Preserve order in PYTEST_PLUGINS
Do not sort entry points when adding them to `PYTEST_PLUGINS`.
Apparently, the order of loading does matter, and reordering
the entry points from `dev-python/pytest-xdist` leads to warnings
that break the test suite of `dev-python/inline-snapshot`.
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
Part-of: https://github.com/gentoo/gentoo/pull/43007
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/python-utils-r1.eclass | 8 +++++---
 1 file changed, 5 insertions(+), 3 deletions(-)
diff --git a/eclass/python-utils-r1.eclass b/eclass/python-utils-r1.eclass
index 68faa9e2adf9..9cdfdc87019f 100644
--- a/eclass/python-utils-r1.eclass
+++ b/eclass/python-utils-r1.eclass
@@ -1458,11 +1458,13 @@ epytest() {
 						from importlib.metadata import distribution, entry_points
 
 						packages = {distribution(x).name for x in sys.argv[1:]}
-						plugins = {
+						# In packages defining multiple entry points, we must
+						# list them in the same order!
+						plugins = (
 							x.value for x in entry_points(group="pytest11")
 							if x.dist.name in packages
-						}
-						sys.stdout.write(",".join(sorted(plugins)))
+						)
+						sys.stdout.write(",".join(plugins))
 					EOF
 				)
 			else
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-07-19 11:35 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-07-19 11:35 UTC (permalink / raw
  To: gentoo-commits
commit:     14eea9ea21093c6c29a354c9649d04072ae38df8
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Jul 19 09:53:37 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jul 19 11:35:10 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=14eea9ea
llvm.org.eclass: add comment explaining syntax choice
See pkgcheck.git commit 7056ff780f7ba4b16adfca5c155fe3cc50fd1a06. UncheckableDep
can fire on complex structures like [x?,y?,z?,...?,...,...?].
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/llvm.org.eclass | 2 ++
 1 file changed, 2 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index 0fec50a95e2b..62dd440e320d 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -343,6 +343,8 @@ llvm.org_set_globals() {
 			REQUIRED_USE+=" || ( ${ALL_LLVM_TARGET_FLAGS[*]} )"
 			;;&
 		llvm)
+			# We do x? ( ... ) instead of [x?,y?,...] to workaround
+			# a pkgcheck bug: https://github.com/pkgcore/pkgcheck/pull/423
 			local dep=
 			for x in "${ALL_LLVM_TARGET_FLAGS[@]}"; do
 				dep+="
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-07-19 11:35 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-07-19 11:35 UTC (permalink / raw
  To: gentoo-commits
commit:     885a91ff28725c3f7d3c8a1b198e03340668b252
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Jul 19 08:27:57 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jul 19 11:35:10 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=885a91ff
llvm.org.eclass: extend LLVM_USE_TARGETS
Add an additional 'llvm+eq' value which works the same as LLVM_USE_TARGETS=llvm,
but with matching use= deps on LLVM_TARGETS. Needed for packages
which automagically use available targets via e.g. LLVM's InitializeAllTargets.
This sets us on a path to dropping the package.use.force entries
for LLVM_TARGETS.
Bug: https://bugs.gentoo.org/767700
Bug: https://bugs.gentoo.org/768267
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/llvm.org.eclass | 15 ++++++++++++++-
 1 file changed, 14 insertions(+), 1 deletion(-)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index eaec1b8a3a5f..0fec50a95e2b 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -140,6 +140,10 @@ fi
 #   on matching llvm-core/llvm versions with requested flags will
 #   be added.
 #
+# - llvm+eq - this package automagically uses targets from LLVM by using
+#   a function like InitializeAllTargets.  Same behavior as =llvm, but
+#   with matching use= deps for targets.
+#
 # Note that you still need to pass enabled targets to the build system,
 # usually grabbing them from ${LLVM_TARGETS} (via USE_EXPAND).
 
@@ -334,7 +338,7 @@ llvm.org_set_globals() {
 	case ${LLVM_USE_TARGETS:-__unset__} in
 		__unset__)
 			;;
-		provide|llvm)
+		provide|llvm|llvm+eq)
 			IUSE+=" ${ALL_LLVM_TARGET_FLAGS[*]}"
 			REQUIRED_USE+=" || ( ${ALL_LLVM_TARGET_FLAGS[*]} )"
 			;;&
@@ -347,6 +351,15 @@ llvm.org_set_globals() {
 			RDEPEND+=" ${dep}"
 			DEPEND+=" ${dep}"
 			;;
+		llvm+eq)
+			local dep=
+			for x in "${ALL_LLVM_TARGET_FLAGS[@]}"; do
+				dep+="
+					${x}? ( ~llvm-core/llvm-${PV}[${x}=] )"
+			done
+			RDEPEND+=" ${dep}"
+			DEPEND+=" ${dep}"
+			;;
 	esac
 
 	# === useful defaults for cmake-based packages ===
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-07-20 18:10 Nowa Ammerlaan
  0 siblings, 0 replies; 6663+ messages in thread
From: Nowa Ammerlaan @ 2025-07-20 18:10 UTC (permalink / raw
  To: gentoo-commits
commit:     c1992bfafece7b495785d4838a2d5ccb19a80b71
Author:     Nowa Ammerlaan <nowa <AT> gentoo <DOT> org>
AuthorDate: Sun Jul 20 18:08:26 2025 +0000
Commit:     Nowa Ammerlaan <nowa <AT> gentoo <DOT> org>
CommitDate: Sun Jul 20 18:10:40 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=c1992bfa
kernel-install.eclass: support test of bin kernel with signed modules
The gentoo-kernel-bin does not have IUSE=modules-sign, but it does
have signed modules if it was built with KERNEL_IUSE_MODULES_SIGN.
Enforce signature verification in the test phase for this case.
Signed-off-by: Nowa Ammerlaan <nowa <AT> gentoo.org>
 eclass/kernel-install.eclass | 6 +++++-
 1 file changed, 5 insertions(+), 1 deletion(-)
diff --git a/eclass/kernel-install.eclass b/eclass/kernel-install.eclass
index 67143278f368..e753592c46fc 100644
--- a/eclass/kernel-install.eclass
+++ b/eclass/kernel-install.eclass
@@ -478,7 +478,11 @@ kernel-install_test() {
 	esac
 
 	if [[ ${KERNEL_IUSE_MODULES_SIGN} ]]; then
-		use modules-sign && qemu_extra_append+=" module.sig_enforce=1"
+		# If KERNEL_IUSE_MODULES_SIGN, but no IUSE=modules-sign,
+		# then this is gentoo-kernel-bin test phase with signed mods.
+		if ! in_iuse modules-sign || use modules-sign; then
+			qemu_extra_append+=" module.sig_enforce=1"
+		fi
 	fi
 
 	cat > run.sh <<-EOF || die
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-07-23 11:57 Petr Vaněk
  0 siblings, 0 replies; 6663+ messages in thread
From: Petr Vaněk @ 2025-07-23 11:57 UTC (permalink / raw
  To: gentoo-commits
commit:     790bbc296c0607d3fdd1bc3ffcb374dd428a7a4f
Author:     Petr Vaněk <arkamar <AT> gentoo <DOT> org>
AuthorDate: Wed Jul  2 10:37:02 2025 +0000
Commit:     Petr Vaněk <arkamar <AT> gentoo <DOT> org>
CommitDate: Wed Jul 23 11:53:52 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=790bbc29
sgml-catalog-r1.eclass: add EAPI 8 support
Signed-off-by: Petr Vaněk <arkamar <AT> gentoo.org>
 eclass/sgml-catalog-r1.eclass | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/eclass/sgml-catalog-r1.eclass b/eclass/sgml-catalog-r1.eclass
index eff6db31062f..4b4d5334670b 100644
--- a/eclass/sgml-catalog-r1.eclass
+++ b/eclass/sgml-catalog-r1.eclass
@@ -1,4 +1,4 @@
-# Copyright 2019-2023 Gentoo Authors
+# Copyright 2019-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: sgml-catalog-r1.eclass
@@ -6,14 +6,14 @@
 # Michał Górny <mgorny@gentoo.org>
 # @AUTHOR:
 # Michał Górny <mgorny@gentoo.org>
-# @SUPPORTED_EAPIS: 7
+# @SUPPORTED_EAPIS: 7 8
 # @BLURB: Functions for installing SGML catalogs
 # @DESCRIPTION:
 # This eclass regenerates /etc/sgml/catalog as necessary for the DocBook
 # tooling. This is done via exported pkg_postinst and pkg_postrm phases.
 
 case ${EAPI} in
-	7) ;;
+	7|8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-07-23 20:38 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-07-23 20:38 UTC (permalink / raw
  To: gentoo-commits
commit:     166dd3575927fedab8de9a79b448b0eaf76325d9
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Jul 23 20:35:52 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Jul 23 20:37:41 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=166dd357
toolchain.eclass: adapt -fdiagnostics-details filter again
The flag is now named -fdiagnostics-show-context=N.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 274789559d5e..dbdd9b24c01b 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -2178,7 +2178,7 @@ gcc_do_filter_flags() {
 	fi
 
 	if ver_test -lt 16.1 ; then
-		filter-flags -fdiagnostics-details
+		filter-flags '-fdiagnostics-show-context=*'
 	fi
 
 	# Ada: PR116226
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-07-24 16:03 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-07-24 16:03 UTC (permalink / raw
  To: gentoo-commits
commit:     5f5a72715819f43db6ecff2a834f7c8ccb3917f1
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Thu Jul 24 16:00:56 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Thu Jul 24 16:02:59 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=5f5a7271
kernel-build.eclass: Force GNU tar for kernel builds
Override the tar executable used by kernel Makefiles to force GNU tar.
This is necessary since some of the scripts use options specific
to GNU tar, and therefore fail with other choices for
app-alternatives/tar.  That said, this override works only with the most
recent version of sys-kernel/gentoo-kernel.  It doesn't cover all
upstream uses of tar, but it does cover these that fail with other tar
implementations.
Closes: https://bugs.gentoo.org/951102
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/kernel-build.eclass | 2 ++
 1 file changed, 2 insertions(+)
diff --git a/eclass/kernel-build.eclass b/eclass/kernel-build.eclass
index 3296f2c6ad75..7a5c80cfd6a6 100644
--- a/eclass/kernel-build.eclass
+++ b/eclass/kernel-build.eclass
@@ -47,6 +47,7 @@ BDEPEND="
 	${PYTHON_DEPS}
 	app-alternatives/cpio
 	app-alternatives/bc
+	app-arch/tar
 	dev-lang/perl
 	sys-devel/bison
 	sys-devel/flex
@@ -226,6 +227,7 @@ kernel-build_src_configure() {
 		OBJCOPY="$(tc-getOBJCOPY)"
 		OBJDUMP="$(tc-getOBJDUMP)"
 		READELF="$(tc-getREADELF)"
+		TAR=gtar
 
 		# we need to pass it to override colliding Gentoo envvar
 		ARCH=$(tc-arch-kernel)
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-07-25  5:57 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-07-25  5:57 UTC (permalink / raw
  To: gentoo-commits
commit:     87a034bd840d2d9095bccb29e7cc0922ec29b4ad
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Mon Jul 21 12:40:20 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Fri Jul 25 05:56:44 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=87a034bd
python-utils-r1.eclass: Add EPYTEST_RERUNS
Add EPYTEST_RERUNS variable to enable pytest-rerunfailures with
a specified rerun count.  This should provide a more streamlined
approach to handling flaky test suites.
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
Part-of: https://github.com/gentoo/gentoo/pull/43094
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/distutils-r1.eclass    |  3 +++
 eclass/python-utils-r1.eclass | 22 ++++++++++++++++++++++
 2 files changed, 25 insertions(+)
diff --git a/eclass/distutils-r1.eclass b/eclass/distutils-r1.eclass
index 7b025261eb2b..c59bdce17581 100644
--- a/eclass/distutils-r1.eclass
+++ b/eclass/distutils-r1.eclass
@@ -554,6 +554,9 @@ distutils_enable_tests() {
 			;&
 		pytest)
 			test_pkgs+=' >=dev-python/pytest-7.4.4[${PYTHON_USEDEP}]'
+			if [[ -n ${EPYTEST_RERUNS} ]]; then
+				test_pkgs+=' dev-python/pytest-rerunfailures[${PYTHON_USEDEP}]'
+			fi
 			if [[ -n ${EPYTEST_TIMEOUT} ]]; then
 				test_pkgs+=' dev-python/pytest-timeout[${PYTHON_USEDEP}]'
 			fi
diff --git a/eclass/python-utils-r1.eclass b/eclass/python-utils-r1.eclass
index 9cdfdc87019f..13ed87501200 100644
--- a/eclass/python-utils-r1.eclass
+++ b/eclass/python-utils-r1.eclass
@@ -1354,6 +1354,16 @@ _set_epytest_plugins() {
 	fi
 }
 
+# @ECLASS_VARIABLE: EPYTEST_RERUNS
+# @DEFAULT_UNSET
+# @DESCRIPTION:
+# If set to a non-empty value, enables pytest-rerunfailures plugin
+# and sets rerun count to the specified value.  This variable can be
+# either set in ebuilds with flaky tests, or by user to try if it helps.
+# If this variable is set prior to calling distutils_enable_tests
+# in distutils-r1, a test dependency on dev-python/pytest-rerunfailures
+# is added automatically.
+
 # @ECLASS_VARIABLE: EPYTEST_TIMEOUT
 # @DEFAULT_UNSET
 # @DESCRIPTION:
@@ -1517,6 +1527,18 @@ epytest() {
 		)
 	fi
 
+	if [[ -n ${EPYTEST_RERUNS} ]]; then
+		if [[ ${PYTEST_PLUGINS} != *pytest_rerunfailures* ]]; then
+			args+=(
+				-p rerunfailures
+			)
+		fi
+
+		args+=(
+			"--reruns=${EPYTEST_RERUNS}"
+		)
+	fi
+
 	if [[ -n ${EPYTEST_TIMEOUT} ]]; then
 		if [[ ${PYTEST_PLUGINS} != *pytest_timeout* ]]; then
 			args+=(
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-07-25  8:21 Nowa Ammerlaan
  0 siblings, 0 replies; 6663+ messages in thread
From: Nowa Ammerlaan @ 2025-07-25  8:21 UTC (permalink / raw
  To: gentoo-commits
commit:     42eddd2bb0c152f2247810e74d2a643358b7ad66
Author:     Nowa Ammerlaan <nowa <AT> gentoo <DOT> org>
AuthorDate: Fri Jul 25 08:14:53 2025 +0000
Commit:     Nowa Ammerlaan <nowa <AT> gentoo <DOT> org>
CommitDate: Fri Jul 25 08:21:16 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=42eddd2b
dist-kernel-utils.eclass: reinstall_initramfs() zboot support
If the config still exists, check it for CONFIG_EFI_ZBOOT, if it is
then the name of the kernel image will be different. We already
introduced the KERNEL_EFI_ZBOOT=1 variable to instruct the
dist-kernel_get_image_path() function to look for this different name.
We however forgot to add some logic to set it for the
reinstall_initramfs() path which is called via linux-mod-r1.eclass
by for example sys-fs/zfs-kmod[dist-kernel,initramfs]. This ebuild
has no information on whether the target kernel was built with ZBOOT
enabled or not. So we add now some logic to the eclass to check this.
Closes: https://bugs.gentoo.org/960603
Signed-off-by: Nowa Ammerlaan <nowa <AT> gentoo.org>
 eclass/dist-kernel-utils.eclass | 7 +++++++
 1 file changed, 7 insertions(+)
diff --git a/eclass/dist-kernel-utils.eclass b/eclass/dist-kernel-utils.eclass
index 49977c18795a..975efd2d63c8 100644
--- a/eclass/dist-kernel-utils.eclass
+++ b/eclass/dist-kernel-utils.eclass
@@ -180,7 +180,14 @@ dist-kernel_reinstall_initramfs() {
 	local kernel_dir=${1:-${KV_DIR}}
 	local ver=${2:-${KV_FULL}}
 
+	# If this is set it will have an effect on the name of the output
+	# image. Set this variable to track this setting.
+	if grep -q "CONFIG_EFI_ZBOOT=y" "${kernel_dir}/.config"; then
+		KERNEL_EFI_ZBOOT=1
+	fi
+
 	local image_path=${kernel_dir}/$(dist-kernel_get_image_path)
+
 	if [[ ! -f ${image_path} ]]; then
 		eerror "Kernel install missing, image not found:"
 		eerror "  ${image_path}"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-07-25 12:48 Alfredo Tupone
  0 siblings, 0 replies; 6663+ messages in thread
From: Alfredo Tupone @ 2025-07-25 12:48 UTC (permalink / raw
  To: gentoo-commits
commit:     c646e2faa6e53df2001549c1c9e57eb10f3745f8
Author:     Alfredo Tupone <tupone <AT> gentoo <DOT> org>
AuthorDate: Fri Jul 25 12:46:54 2025 +0000
Commit:     Alfredo Tupone <tupone <AT> gentoo <DOT> org>
CommitDate: Fri Jul 25 12:46:54 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=c646e2fa
cuda.eclass: add sandbox exclusion for /proc/self/task
Signed-off-by: Alfredo Tupone <tupone <AT> gentoo.org>
 eclass/cuda.eclass | 7 ++++++-
 1 file changed, 6 insertions(+), 1 deletion(-)
diff --git a/eclass/cuda.eclass b/eclass/cuda.eclass
index e54560197a8f..ca8e3aea381d 100644
--- a/eclass/cuda.eclass
+++ b/eclass/cuda.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2023 Gentoo Authors
+# Copyright 1999-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: cuda.eclass
@@ -154,6 +154,11 @@ cuda_add_sandbox() {
 			addpredict $i
 		fi
 	done
+	if [[ $1 == '-w' ]]; then
+		addwrite /proc/self/task
+	else
+		addpredict /proc/self/task
+	fi
 }
 
 # @FUNCTION: cuda_toolkit_version
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-07-26 19:53 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-07-26 19:53 UTC (permalink / raw
  To: gentoo-commits
commit:     ce79aa2ff8fd784baf714512239d3def04d557b6
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Jul 26 19:21:58 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat Jul 26 19:21:58 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=ce79aa2f
llvm.org.eclass: Add 22.0.0_pre20250726 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index 967d431b5b03..1b3517902d13 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -72,6 +72,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 			_LLVM_SOURCE_TYPE=snapshot
 
 			case ${PV} in
+				22.0.0_pre20250726)
+					EGIT_COMMIT=190fcc28af585cb06480b026afd14ed87b18adb8
+					;;
 				22.0.0_pre20250722)
 					EGIT_COMMIT=b956f049b186fafafebc88b861982644ec3f5291
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-07-27  1:51 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-07-27  1:51 UTC (permalink / raw
  To: gentoo-commits
commit:     d21fa97e8f841a8782764b5a48223694d440b6c8
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Jul 27 01:50:38 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Jul 27 01:50:38 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=d21fa97e
gstreamer-meson.eclass: drop unversioned virtual Perl dep
... as it's provided by dev-lang/perl itself.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/gstreamer-meson.eclass | 1 -
 1 file changed, 1 deletion(-)
diff --git a/eclass/gstreamer-meson.eclass b/eclass/gstreamer-meson.eclass
index 1f43749baed3..22626f1b82b8 100644
--- a/eclass/gstreamer-meson.eclass
+++ b/eclass/gstreamer-meson.eclass
@@ -210,7 +210,6 @@ RDEPEND="
 "
 BDEPEND="
 	virtual/pkgconfig
-	virtual/perl-JSON-PP
 "
 [[ ${EAPI} == 8 ]] && BDEPEND="${BDEPEND} ${PYTHON_DEPS}"
 # gst-plugins-{base,good} splits all require glib-utils due to gnome.mkenums_simple meson calls in gst-libs
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-07-27 12:39 Florian Schmaus
  0 siblings, 0 replies; 6663+ messages in thread
From: Florian Schmaus @ 2025-07-27 12:39 UTC (permalink / raw
  To: gentoo-commits
commit:     50d9713fb4dd2de462f62c630b4e260bd346f16f
Author:     Florian Schmaus <flow <AT> gentoo <DOT> org>
AuthorDate: Sat Jul 26 11:25:25 2025 +0000
Commit:     Florian Schmaus <flow <AT> gentoo <DOT> org>
CommitDate: Sun Jul 27 12:39:41 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=50d9713f
greadme.eclass: drop "file exists" check on append
In hindsight, this check is too restrictive. The check makes it
impossible to have a completely optional README.gentoo created. For
example, a README.gentoo where all the content is conditional on USE
flags.
To address this, we drop the "file exists" check on append. The rest of
the eclass already correctly handles cases where README.gentoo might not
exist.
Signed-off-by: Florian Schmaus <flow <AT> gentoo.org>
 eclass/greadme.eclass | 6 +-----
 1 file changed, 1 insertion(+), 5 deletions(-)
diff --git a/eclass/greadme.eclass b/eclass/greadme.eclass
index a4335b1a6286..49aba1d89389 100644
--- a/eclass/greadme.eclass
+++ b/eclass/greadme.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2024 Gentoo Authors
+# Copyright 1999-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: greadme.eclass
@@ -80,10 +80,6 @@ greadme_stdin() {
 	[[ $# -eq 0 ]] || die "${FUNCNAME[0]}: Bad parameters: $*"
 
 	if [[ -n ${append} ]]; then
-		if [[ ! -f ${_GREADME_TMP_FILE} ]]; then
-			die "Gentoo README does not exist when trying to append to it"
-		fi
-
 		cat >> "${_GREADME_TMP_FILE}" || die
 	else
 		cat > "${_GREADME_TMP_FILE}" || die
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-07-28  5:00 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-07-28  5:00 UTC (permalink / raw
  To: gentoo-commits
commit:     96c789720745edbfefb924e9c2d94c2961c2cae8
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Jul 28 04:59:31 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Jul 28 04:59:31 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=96c78972
toolchain.eclass: support bootstrap-asan and bootstrap-ubsan
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 2 ++
 1 file changed, 2 insertions(+)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index dbdd9b24c01b..efa78f613670 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1199,6 +1199,8 @@ toolchain_setup_d() {
 toolchain_src_configure() {
 	BUILD_CONFIG_TARGETS=()
 	is-flagq '-O3' && BUILD_CONFIG_TARGETS+=( bootstrap-O3 )
+	is-flagq '-fsanitize=address' && BUILD_CONFIG_TARGETS+=( bootstrap-asan )
+	is-flagq '-fsanitize=undefined' && BUILD_CONFIG_TARGETS+=( bootstrap-ubsan )
 
 	downgrade_arch_flags
 	gcc_do_filter_flags
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-07-29  5:34 Ionen Wolkens
  0 siblings, 0 replies; 6663+ messages in thread
From: Ionen Wolkens @ 2025-07-29  5:34 UTC (permalink / raw
  To: gentoo-commits
commit:     bcebdbdbeb4dad9e922f1d91326af00f38f8a252
Author:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
AuthorDate: Tue Jul 29 04:56:47 2025 +0000
Commit:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
CommitDate: Tue Jul 29 05:33:41 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=bcebdbdb
wine.eclass: do not pass CFLAGS as CROSSCFLAGS for mingw by default
Desktop integration tab wrt bug #960825 is not *that* big of an issue,
but these kind of issues with CROSSCFLAGS="-march=native ..." keep
coming back and I'd rather this not be done anymore unless
USE=custom-cflags so regular users do not have to deal with this.
Very few people/distros set CROSSCFLAGS and by default wine will use
just -O2 rather than try to copy CFLAGS which results in a lot of
(not really) "Gentoo"-specific obscure issues.
Closing bug given not currently planning to change this even if that
specific issue is fixed in upstream gcc/wine, but feel free to
re-open/repurpose if someone wants to pursue this further.
Technically needs revbumps, but letting this propagate on wine bumps
should be sufficient, wine should still mostly work albeit the exact
extend of issues beyond the desktop integration tab is unknown. Please
rebuild manually if affected and want this fixed now.
Leaving this alone for clang (USE=-mingw), no issues that I'm aware
of yet (or at least not specific to *FLAGS, it is generally less
tested with wine and may have other unrelated issues).
Closes: https://bugs.gentoo.org/960825
Thanks-to: GoldsrcSource
Signed-off-by: Ionen Wolkens <ionen <AT> gentoo.org>
 eclass/wine.eclass | 38 +++++++++++++++++++++++++++-----------
 1 file changed, 27 insertions(+), 11 deletions(-)
diff --git a/eclass/wine.eclass b/eclass/wine.eclass
index 185d3bf4ec59..a92f01f9e37c 100644
--- a/eclass/wine.eclass
+++ b/eclass/wine.eclass
@@ -459,17 +459,33 @@ _wine_flags() {
 
 	case ${1} in
 		c)
-			# many hardening options are unlikely to work right
-			filter-flags '-fstack-protector*' #870136
-			filter-flags '-mfunction-return=thunk*' #878849
-
-			# bashrc-mv users often do CFLAGS="${LDFLAGS}" and then
-			# compile-only tests miss stripping unsupported linker flags
-			filter-flags '-Wl,*'
-
-			# -mavx with mingw-gcc has a history of problems and still see
-			# users have issues despite Wine's -mpreferred-stack-boundary=2
-			use mingw && append-cflags -mno-avx
+			if use mingw && use !custom-cflags; then
+				# Changing CROSSCFLAGS is not very tested and often cause
+				# problems even with simple things like -march=native/-O3 when
+				# using mingw-gcc (thus -mno-avx below, also bug #960825), only
+				# inherit basic flags from CFLAGS unless USE=custom-cflags.
+				#
+				# Note that users setting CROSSCFLAGS directly (unfiltered)
+				# are on their own just like with USE=custom-cflags.
+				local flag flags=${CFLAGS} CFLAGS=-O2
+				# not get-flag() given it returns only the first occurence
+				for flag in ${flags}; do
+					[[ ${flag} == @(-g*|-O[0-1g]) ]] && CFLAGS+=" ${flag}"
+				done
+			else
+				# many hardening options are unlikely to work right
+				filter-flags '-fstack-protector*' #870136
+				filter-flags '-mfunction-return=thunk*' #878849
+
+				# bashrc-mv users often do CFLAGS="${LDFLAGS}" and then
+				# compile-only tests miss stripping unsupported linker flags
+				filter-flags '-Wl,*'
+
+				# -mavx with mingw-gcc has a history of problems and still see
+				# users have issues despite Wine's -mpreferred-stack-boundary=2
+				# (kept even with USE=custom-cflags wrt bug #912268)
+				use mingw && append-cflags -mno-avx
+			fi
 
 			# same as strip-unsupported-flags but echos only for CC
 			CC="${wcc} ${wccflags}" test-flags-CC ${CFLAGS}
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-07-29  8:36 Matt Jolly
  0 siblings, 0 replies; 6663+ messages in thread
From: Matt Jolly @ 2025-07-29  8:36 UTC (permalink / raw
  To: gentoo-commits
commit:     19e4eb1d5f5229dfc0ec1f4bcf3cbb0c9ca4af5d
Author:     Matt Jolly <kangie <AT> gentoo <DOT> org>
AuthorDate: Tue Jul 29 05:16:16 2025 +0000
Commit:     Matt Jolly <kangie <AT> gentoo <DOT> org>
CommitDate: Tue Jul 29 08:19:58 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=19e4eb1d
eclass: rust: add 1.89.0 to available slots
Signed-off-by: Matt Jolly <kangie <AT> gentoo.org>
 eclass/rust.eclass | 2 ++
 1 file changed, 2 insertions(+)
diff --git a/eclass/rust.eclass b/eclass/rust.eclass
index 183d5cd4efab..3c9693e00f59 100644
--- a/eclass/rust.eclass
+++ b/eclass/rust.eclass
@@ -68,6 +68,7 @@ fi
 # Definitive list of Rust slots and the associated LLVM slot, newest first.
 declare -A -g -r _RUST_LLVM_MAP=(
 	["9999"]=20
+	["1.89.0"]=20
 	["1.88.0"]=20
 	["1.87.0"]=20
 	["1.86.0"]=19
@@ -95,6 +96,7 @@ declare -A -g -r _RUST_LLVM_MAP=(
 # this array is used to store the Rust slots in a more convenient order for iteration.
 declare -a -g -r _RUST_SLOTS_ORDERED=(
 	"9999"
+	"1.89.0"
 	"1.88.0"
 	"1.87.0"
 	"1.86.0"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread
* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-07-30  5:06 Eli Schwartz
  0 siblings, 0 replies; 6663+ messages in thread
From: Eli Schwartz @ 2025-07-30  5:06 UTC (permalink / raw
  To: gentoo-commits
commit:     4422a601583bdfadbe80a18115f5873c4a08f456
Author:     Eli Schwartz <eschwartz <AT> gentoo <DOT> org>
AuthorDate: Wed Nov 27 20:09:21 2024 +0000
Commit:     Eli Schwartz <eschwartz <AT> gentoo <DOT> org>
CommitDate: Wed Jul 30 05:06:30 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=4422a601
sec-keys.eclass: new eclass
The current state of verify-sig support is a bit awkward. We rely on
validating distfiles against a known trusted keyring, but creating the
known trusted keyring is basically all manual verification. We somehow
decide an ascii armored key is good enough without any portage
assistance, then arrange to download it and trust it by Manifest hash.
How do we know when updating a key is actually safe?
This eclass handles the problem in a manner inspired in part by pacman.
We require an eclass variable that lists all permitted PGP fingerprints,
and the eclass is responsible checking that list against the keys we
will install. It comes with a mechanism for computing SRC_URI for a
couple of well known locations, or you can append your own in the
ebuild.
Key rotations, both expected and malicious, are easily detected by
checking the git log for changes to declared fingerprints in a bump. The
former can be rationalized in the commit message. So can the latter, but
in most cases those will be rejected during peer review.
Signed-off-by: Eli Schwartz <eschwartz <AT> gentoo.org>
 eclass/sec-keys.eclass | 206 +++++++++++++++++++++++++++++++++++++++++++++++++
 1 file changed, 206 insertions(+)
diff --git a/eclass/sec-keys.eclass b/eclass/sec-keys.eclass
new file mode 100644
index 000000000000..ce0396be414a
--- /dev/null
+++ b/eclass/sec-keys.eclass
@@ -0,0 +1,206 @@
+# Copyright 2024-2025 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+# @ECLASS: sec-keys.eclass
+# @MAINTAINER:
+# Eli Schwartz <eschwartz@gentoo.org>
+# @AUTHOR:
+# Eli Schwartz <eschwartz@gentoo.org>
+# @SUPPORTED_EAPIS: 8
+# @BLURB: Provides a uniform way of handling ebuilds which package PGP key material
+# @DESCRIPTION:
+# This eclass provides a streamlined approach to finding suitable source
+# material for OpenPGP keys used by the verify-sig eclass.  Its primary
+# purpose is to permit developers to easily and securely package new
+# sec-keys/* packages.  The eclass removes the risk of developers
+# accidentally packaging malformed key material, or neglecting to
+# notice when PGP identities have changed.
+#
+# To use the eclass, define SEC_KEYS_VALIDPGPKEYS to contain the
+# fingerprint of the key and the short name of the key's owner.
+#
+# @EXAMPLE:
+# Example use:
+#
+# @CODE
+# SEC_KEYS_VALIDPGPKEYS=(
+#	'3DB7F3CA6C1D90B99FE25B38D4B476A4D175C54F:bjones:ubuntu'
+#	'4EC8A4DB7D2E01C00AF36C49E5C587B5E286C65A:jsmith:github,openpgp'
+#	# key only available on personal website, use manual SRC_URI
+#	'5FD9B5EC8E3F12D11BA47D50F6D698C6F397D76B:awhite:manual'
+# )
+#
+# inherit sec-keys
+#
+# SRC_URI+="https://awhite.com/awhite.gpg -> awhite-${PV}.gpg"
+# @CODE
+
+case ${EAPI} in
+	8) ;;
+	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
+esac
+
+if [[ ! ${_SEC_KEYS_ECLASS} ]]; then
+_SEC_KEYS_ECLASS=1
+
+inherit eapi9-pipestatus edo
+
+# @ECLASS_VARIABLE: SEC_KEYS_VALIDPGPKEYS
+# @PRE_INHERIT
+# @DEFAULT_UNSET
+# @DESCRIPTION:
+# Mapping of fingerprints, name, and optional locations of PGP keys to
+# include, separated by colons.  The allowed values for a location are:
+#
+#  - gentoo -- fetch key by fingerprint from https://keys.gentoo.org
+#
+#  - github -- fetch key from github.com/${name}.pgp
+#
+#  - openpgp -- fetch key by fingerprint from https://keys.openpgp.org
+#
+#  - ubuntu -- fetch key by fingerprint from http://keyserver.ubuntu.com
+#
+#  - manual -- do not add to SRC_URI, the ebuild will provide a custom
+#    download location
+_sec_keys_set_globals() {
+	local key fingerprint name loc locations=() remote
+
+	for key in "${SEC_KEYS_VALIDPGPKEYS[@]}"; do
+		fingerprint=${key%%:*}
+		name=${key#${fingerprint}:}; name=${name%%:*}
+		IFS=, read -r -a locations <<<"${key##*:}"
+		[[ ${locations[@]} ]] || die "${ECLASS}: ${name}: PGP key remote is mandatory"
+		for loc in "${locations[@]}"; do
+			case ${loc} in
+				gentoo) remote="https://keys.gentoo.org/pks/lookup?op=get&search=0x${fingerprint}";;
+				github) remote="https://github.com/${name}.gpg";;
+				openpgp) remote="https://keys.openpgp.org/vks/v1/by-fingerprint/${fingerprint}";;
+				ubuntu) remote="https://keyserver.ubuntu.com/pks/lookup?op=get&search=0x${fingerprint}";;
+				# provided via manual SRC_URI
+				manual) continue;;
+				*) die "${ECLASS}: unknown PGP key remote: ${loc}";;
+			esac
+			SRC_URI+="
+				${remote} -> openpgp-keys-${name}-${loc}-${PV}.asc
+			"
+		done
+	done
+}
+_sec_keys_set_globals
+unset -f _sec_keys_set_globals
+
+S=${WORKDIR}
+
+LICENSE="public-domain"
+SLOT="0"
+
+IUSE="test"
+PROPERTIES="test_network"
+RESTRICT="!test? ( test )"
+
+BDEPEND="
+	app-crypt/gnupg
+	test? ( app-crypt/pgpdump )
+"
+
+
+
+# @FUNCTION: sec-keys_src_compile
+# @DESCRIPTION:
+# Default src_compile override that:
+#
+# - imports all public keys into a keyring
+#
+# - validates that they are listed in SEC_KEYS_VALIDPGPKEYS
+#
+# - minifies and exports them back into a unified keyfile
+sec-keys_src_compile() {
+	local -x GNUPGHOME=${WORKDIR}/gnupg
+	local fingerprint
+	local gpg_command=(gpg --export-options export-minimal)
+
+	mkdir -m700 -p "${GNUPGHOME}" || die
+	cat <<- EOF > "${GNUPGHOME}"/gpg.conf || die
+	no-secmem-warning
+	EOF
+
+	pushd "${DISTDIR}" >/dev/null || die
+	gpg --import ${A} || die
+	popd >/dev/null || die
+
+	local line imported_keys=() found=0
+	while IFS=: read -r -a line; do
+		if [[ ${line[0]} = pub ]]; then
+			# new key
+			found=0
+		elif [[ ${found} = 0 && ${line[0]} = fpr ]]; then
+			# primary fingerprint
+			imported_keys+=("${line[9]}")
+			found=1
+		fi
+	done < <(gpg --batch --list-keys --with-colons || die)
+
+	printf '%s\n' "${imported_keys[@]}" | sort > imported_keys.list || die
+	printf '%s\n' "${SEC_KEYS_VALIDPGPKEYS[@]%%:*}" | sort > allowed_keys.list || die
+
+	local extra_keys=($(comm -23 imported_keys.list allowed_keys.list || die))
+	local missing_keys=($(comm -13 imported_keys.list allowed_keys.list || die))
+
+	if [[ ${#extra_keys[@]} != 0 ]]; then
+		die "Too many keys found. Suspicious keys: ${extra_keys[@]}"
+	fi
+	if [[ ${#missing_keys[@]} != 0 ]]; then
+		die "Too few keys found. Unavailable keys: ${missing_keys[@]}"
+	fi
+
+	for fingerprint in "${SEC_KEYS_VALIDPGPKEYS[@]%%:*}"; do
+		local uids=()
+		mapfile -t uids < <("${gpg_command[@]}" --list-key --with-colons ${fingerprint} | awk -F: '/^uid/{print $10}' || die)
+		edo "${gpg_command[@]}" "${uids[@]/#/--comment=}" --export --armor "${fingerprint}" > "${fingerprint}.asc"
+		cat ${fingerprint}.asc >> ${PN#openpgp-keys-}.asc || die
+	done
+}
+
+sec-keys_src_test() {
+	local -x GNUPGHOME=${WORKDIR}/gnupg
+	local key fingerprint name server
+	local gpg_command=(gpg --export-options export-minimal)
+
+	# Best-effort attempt to check for updates. keyservers can and usually
+	# do fail for weird reasons, (such as being unable to import a key
+	# without a uid) as well as normal reasons, like the key being exclusive
+	# to a different keyserver. this isn't a reason to fail src_test.
+	for server in keys.gentoo.org keys.openpgp.org keyserver.ubuntu.com; do
+		gpg --refresh-keys --keyserver "hkps://${server}"
+	done
+	for key in "${SEC_KEYS_VALIDPGPKEYS[@]}"; do
+		if [[ ${key##*:} = *github* ]]; then
+			name=${key#*:}; name=${name%%:*}
+			wget -qO- https://github.com/${name}.gpg | gpg --import
+			pipestatus || die
+		fi
+	done
+
+	for fingerprint in "${SEC_KEYS_VALIDPGPKEYS[@]%%:*}"; do
+		pgpdump "${fingerprint}.asc" > "${fingerprint}.pgpdump" || die
+
+		"${gpg_command[@]}" --export "${fingerprint}" | pgpdump > "${fingerprint}.pgpdump.new"
+		pipestatus || die
+
+		diff -u "${fingerprint}.pgpdump" "${fingerprint}.pgpdump.new" || die "updates available for PGP key: ${fingerprint}"
+	done
+
+}
+
+# @FUNCTION: sec-keys_src_install
+# @DESCRIPTION:
+# Default src_install override that installs an ascii-armored keyfile
+# installed to the standard /usr/share/openpgp-keys.
+sec-keys_src_install() {
+	insinto /usr/share/openpgp-keys
+	doins ${PN#openpgp-keys-}.asc
+}
+
+fi
+
+EXPORT_FUNCTIONS src_compile src_test src_install
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-08-02 10:29 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-08-02 10:29 UTC (permalink / raw
  To: gentoo-commits
commit:     2fd2a909c86228d0252359d39fffe5797219ce3c
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Aug  2 10:19:05 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat Aug  2 10:28:51 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=2fd2a909
llvm.org.eclass: Add 22.0.0_pre20250802 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index d5620a445376..ed1f2c22dba3 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -72,6 +72,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 			_LLVM_SOURCE_TYPE=snapshot
 
 			case ${PV} in
+				22.0.0_pre20250802)
+					EGIT_COMMIT=b075dadbd3e0e928bdeddb3d36af64e8a383e305
+					;;
 				22.0.0_pre20250726)
 					EGIT_COMMIT=190fcc28af585cb06480b026afd14ed87b18adb8
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-08-02 10:29 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-08-02 10:29 UTC (permalink / raw
  To: gentoo-commits
commit:     c0993ffa4fea7e19d3ab31f3d3ff8da79b6dda4e
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Aug  2 10:18:38 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat Aug  2 10:28:50 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=c0993ffa
llvm.org.eclass: Remove old snapshots
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 6 ------
 1 file changed, 6 deletions(-)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index 1b3517902d13..d5620a445376 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -75,12 +75,6 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 				22.0.0_pre20250726)
 					EGIT_COMMIT=190fcc28af585cb06480b026afd14ed87b18adb8
 					;;
-				22.0.0_pre20250722)
-					EGIT_COMMIT=b956f049b186fafafebc88b861982644ec3f5291
-					;;
-				21.0.0_pre20250713)
-					EGIT_COMMIT=b6313b381ac0e83012ea11b4549cd8cb39b686d2
-					;;
 				*)
 					die "Unknown snapshot: ${PV}"
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-08-09  9:47 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-08-09  9:47 UTC (permalink / raw
  To: gentoo-commits
commit:     38e8fb5addf6297f236aa3679ae4d6b869145e6a
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Aug  9 09:43:23 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat Aug  9 09:46:48 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=38e8fb5a
llvm.org.eclass: Add 22.0.0_pre20250809 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index ed1f2c22dba3..78b62ee9e82b 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -72,6 +72,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 			_LLVM_SOURCE_TYPE=snapshot
 
 			case ${PV} in
+				22.0.0_pre20250809)
+					EGIT_COMMIT=92164faf17d553359418b9f49c1a41d680d0de49
+					;;
 				22.0.0_pre20250802)
 					EGIT_COMMIT=b075dadbd3e0e928bdeddb3d36af64e8a383e305
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-08-09 16:49 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-08-09 16:49 UTC (permalink / raw
  To: gentoo-commits
commit:     7297f99fe2ccfed6490f66e6f5b7e2e3a8e8a8a7
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Aug  2 18:05:51 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat Aug  9 16:44:58 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=7297f99f
distutils-r1.eclass: Update scikit-build-core options
Once again switch to the newer scikit-build-core `build.verbose` option
to fix compatibility with packages requiring the newer version, and let
us stop patching ebuilds.  Upstream fixed the behavior to allow using
newer options in `config_settings`.
Bug: https://github.com/scikit-build/scikit-build-core/issues/912
Pull-Request: https://github.com/scikit-build/scikit-build-core/pull/1054
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
Part-of: https://github.com/gentoo/gentoo/pull/43299
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/distutils-r1.eclass | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/eclass/distutils-r1.eclass b/eclass/distutils-r1.eclass
index c59bdce17581..e9826f4cf3df 100644
--- a/eclass/distutils-r1.eclass
+++ b/eclass/distutils-r1.eclass
@@ -292,7 +292,7 @@ _distutils_set_globals() {
 			;;
 		scikit-build-core)
 			bdep+='
-				>=dev-python/scikit-build-core-0.10.7[${PYTHON_USEDEP}]
+				>=dev-python/scikit-build-core-0.11.5[${PYTHON_USEDEP}]
 			'
 			;;
 		setuptools)
@@ -1145,9 +1145,9 @@ distutils_pep517_install() {
 					ninjaopts = shlex.split(os.environ["NINJAOPTS"])
 					print(json.dumps({
 						"build.tool-args": ninjaopts,
+						"build.verbose": True,
 						"cmake.args": ";".join(sys.argv[1:]),
 						"cmake.build-type": "${CMAKE_BUILD_TYPE}",
-						"cmake.verbose": True,
 						"install.strip": False,
 					}))
 				EOF
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-08-11  5:38 Eli Schwartz
  0 siblings, 0 replies; 6663+ messages in thread
From: Eli Schwartz @ 2025-08-11  5:38 UTC (permalink / raw
  To: gentoo-commits
commit:     198cd3866a8de98f7e324f20bd83f9f70aab49a8
Author:     Eli Schwartz <eschwartz <AT> gentoo <DOT> org>
AuthorDate: Fri Aug  8 19:15:33 2025 +0000
Commit:     Eli Schwartz <eschwartz <AT> gentoo <DOT> org>
CommitDate: Mon Aug 11 05:35:25 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=198cd386
sec-keys.eclass: make test_network actually be respected
Apparently this PROPERTIES has the insidious effect of requiring
multiple moving parts to actually have the desired effect:
- PROPERTIES="test_network"
  Add network access, always, and run tests without comment.
- PROPERTIES="test_network" RESTRICT="test"
  Don't run tests, but if tests ran, they would have network.
- PROPERTIES="test_network" RESTRICT="test" ALLOW_TEST="network"
  Disable RESTRICT, and run tests.
- PROPERTIES="test_network" RESTRICT="!test? ( test )" ALLOW_TEST="network"
  Run tests without build dependencies installed, if USE="-test" is set.
- eclass:
      PROPERTIES="test_network" RESTRICT="!test? ( test ) test" ALLOW_TEST="network"
  ebuild:
      RESTRICT="test" # tests broken, see bug #xxxxxx
  Run broken tests, which fail. Sorry, you're not allowed to communicate
  the desired intent. Don't use eclasses.
This is a total mess, but apparently it is what we must do anyways in
order to have the eclass behave as intended. So, switch from the first
configuration to the fifth, and let's simply pray nobody ever wants to
restrict tests for *any* reason for the package subset known as
"sec-keys/*" and we can safely co-opt its meaning.
Signed-off-by: Eli Schwartz <eschwartz <AT> gentoo.org>
 eclass/sec-keys.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/sec-keys.eclass b/eclass/sec-keys.eclass
index ce0396be414a..ed53adb5dbae 100644
--- a/eclass/sec-keys.eclass
+++ b/eclass/sec-keys.eclass
@@ -96,7 +96,7 @@ SLOT="0"
 
 IUSE="test"
 PROPERTIES="test_network"
-RESTRICT="!test? ( test )"
+RESTRICT="!test? ( test ) test"
 
 BDEPEND="
 	app-crypt/gnupg
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-08-11  5:38 Eli Schwartz
  0 siblings, 0 replies; 6663+ messages in thread
From: Eli Schwartz @ 2025-08-11  5:38 UTC (permalink / raw
  To: gentoo-commits
commit:     1e43bb001bc0bc61603fd35ce4da7f2d2597e002
Author:     Eli Schwartz <eschwartz <AT> gentoo <DOT> org>
AuthorDate: Thu Aug  7 04:44:09 2025 +0000
Commit:     Eli Schwartz <eschwartz <AT> gentoo <DOT> org>
CommitDate: Mon Aug 11 05:35:27 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=1e43bb00
sec-keys.eclass: for SLOT= packages, add slot to filename
Seen for example with apache-tomcat. It has separate keys per major
version, parallel installable, with different release managers.
Although that ebuild doesn't use "apache-tomcat" as the filename base,
handling SLOT is necessary before considering to do so.
Signed-off-by: Eli Schwartz <eschwartz <AT> gentoo.org>
 eclass/sec-keys.eclass | 6 +++++-
 1 file changed, 5 insertions(+), 1 deletion(-)
diff --git a/eclass/sec-keys.eclass b/eclass/sec-keys.eclass
index ed53adb5dbae..ccc9dfcccfe1 100644
--- a/eclass/sec-keys.eclass
+++ b/eclass/sec-keys.eclass
@@ -198,7 +198,11 @@ sec-keys_src_test() {
 # installed to the standard /usr/share/openpgp-keys.
 sec-keys_src_install() {
 	insinto /usr/share/openpgp-keys
-	doins ${PN#openpgp-keys-}.asc
+
+	case ${SLOT} in
+		0) doins ${PN#openpgp-keys-}.asc;;
+		*) newins ${PN#openpgp-keys-}.asc ${PN#openpgp-keys-}-${SLOT}.asc;;
+	esac
 }
 
 fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-08-13 11:01 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-08-13 11:01 UTC (permalink / raw
  To: gentoo-commits
commit:     904ccfd6d5510b85ee320b004b1ac36fc5019673
Author:     Volkmar W. Pogatzki <gentoo <AT> pogatzki <DOT> net>
AuthorDate: Sat Jul 26 18:46:08 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Aug 13 11:00:41 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=904ccfd6
junit5.eclass: add '--build-only' to java-pkg_getjars
There were QA complaints about junit-5 not found with a slot in DEPEND.
Signed-off-by: Volkmar W. Pogatzki <gentoo <AT> pogatzki.net>
Part-of: https://github.com/gentoo/gentoo/pull/43318
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/junit5.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/junit5.eclass b/eclass/junit5.eclass
index 4fb04894e963..d031e521e1ff 100755
--- a/eclass/junit5.eclass
+++ b/eclass/junit5.eclass
@@ -152,7 +152,7 @@ ejunit5() {
 	fi
 
 	local junit="junit-5"
-	local cp=$(java-pkg_getjars --with-dependencies ${junit}${pkgs})
+	local cp=$(java-pkg_getjars --build-only --with-dependencies ${junit}${pkgs})
 	if [[ ${1} = -cp || ${1} = -classpath ]]; then
 		cp="${2}:${cp}"
 		shift 2
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-08-13 11:01 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-08-13 11:01 UTC (permalink / raw
  To: gentoo-commits
commit:     d43ac38daeb41415490eac23bbc6e2aa6ba69099
Author:     Volkmar W. Pogatzki <gentoo <AT> pogatzki <DOT> net>
AuthorDate: Mon Jun 23 13:41:18 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Aug 13 11:00:41 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=d43ac38d
java-pkg-junit-5.eclass: new eclass
Thanks to Yuan Liao <liaoyuan <AT> gmail.com> for providing this excellent
work. Copied from https://github.com/Leo3418/junit-5-ebuild-repo
Signed-off-by: Yuan Liao <liaoyuan <AT> gmail.com>
Co-authored-by: Volkmar W. Pogatzki <gentoo <AT> pogatzki.net>
Part-of: https://github.com/gentoo/gentoo/pull/43318
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/java-pkg-junit-5.eclass | 500 +++++++++++++++++++++++++++++++++++++++++
 1 file changed, 500 insertions(+)
diff --git a/eclass/java-pkg-junit-5.eclass b/eclass/java-pkg-junit-5.eclass
new file mode 100755
index 000000000000..cd3101f3eccd
--- /dev/null
+++ b/eclass/java-pkg-junit-5.eclass
@@ -0,0 +1,500 @@
+# Copyright 2022-2025 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+# @ECLASS: java-pkg-junit-5.eclass
+# @MAINTAINER:
+# Yuan Liao <liaoyuan@gmail.com>
+# @AUTHOR:
+# Yuan Liao <liaoyuan@gmail.com>
+# @SUPPORTED_EAPIS: 8
+# @BLURB: Experimental eclass to add support for testing on the JUnit Platform
+# @DESCRIPTION:
+# This eclass runs tests on the JUnit Platform (which is a JUnit 5 sub-project)
+# during the src_test phase.  It is an experimental eclass whose code should
+# eventually be merged into java-utils-2.eclass and/or java-pkg-simple.eclass
+# when it is mature.
+
+if [[ ! ${_JAVA_PKG_JUNIT_5_ECLASS} ]]; then
+
+case ${EAPI} in
+	8) ;;
+	*) die "${ECLASS}: EAPI ${EAPI} unsupported." ;;
+esac
+
+inherit java-pkg-simple
+
+# @ECLASS_VARIABLE: JAVA_TEST_SELECTION_METHOD
+# @DESCRIPTION:
+# A string that represents the method to discover and select test classes to
+# run on the JUnit Platform.  These values are accepted:
+#
+# - "traditional" (default): Use the same method as java-pkg-simple.eclass.
+#
+# - "scan-classpath": Rely on the JUnit Platform's ConsoleLauncher's
+#   '--scan-classpath' option to discover tests, and run these discovered
+#   tests.  JAVA_TEST_RUN_ONLY and JAVA_TEST_EXCLUDES are both honored.
+#
+# - "scan-classpath+pattern": Rely on the JUnit Platform's ConsoleLauncher's
+#   '--scan-classpath' option to discover tests, but also select the same tests
+#   that java-pkg-simple.eclass would select from the discovered tests.
+#   JAVA_TEST_RUN_ONLY and JAVA_TEST_EXCLUDES are both honored.
+#
+# - "console-args": Do not perform any test discovery or test selection;
+#   instead, pass the JAVA_JUNIT_CONSOLE_ARGS variable's value to the JUnit
+#   Platform's ConsoleLauncher.  In this case, JAVA_JUNIT_CONSOLE_ARGS should
+#   contain arguments to ConsoleLauncher that select tests to run.  Neither
+#   JAVA_TEST_RUN_ONLY nor JAVA_TEST_EXCLUDES is honored.
+#
+# If multiple values separated by white-space characters are included, then
+# this eclass will use every method to run tests once and print a comparison of
+# the number of tests each method ran at the end.  However, this should only be
+# used in development for comparing and evaluating the methods.
+#
+# Example values:
+# @CODE
+# JAVA_TEST_SELECTION_METHOD="scan-classpath+pattern"
+# JAVA_TEST_SELECTION_METHOD="traditional scan-classpath"
+# @CODE
+: ${JAVA_TEST_SELECTION_METHOD:=traditional}
+
+# @ECLASS_VARIABLE: JAVA_JUNIT_CONSOLE_ARGS
+# @DEFAULT_UNSET
+# @DESCRIPTION:
+# Extra arguments to pass to JUnit Platform's ConsoleLauncher only when
+# JAVA_TEST_SELECTION_METHOD contains "console-args".  Any white-space
+# character in this variable's value will separate tokens into different
+# arguments.
+
+# @ECLASS_VARIABLE: JAVA_JUNIT_CONSOLE_COLOR
+# @USER_VARIABLE
+# @DEFAULT_UNSET
+# @DESCRIPTION:
+# If this variable's value is not empty, enable color in the JUnit Platform's
+# ConsoleLauncher's output.
+
+# @ECLASS_VARIABLE: _JAVA_JUNIT_REPORTS_DIR
+# @INTERNAL
+# @DESCRIPTION:
+# The output path of JUnit Platform test reports.  The reports contain
+# information about test executions that are useful to QA checks and analysis.
+_JAVA_JUNIT_REPORTS_DIR="${T}/junit-5-reports"
+
+if has test ${JAVA_PKG_IUSE}; then
+	DEPEND="test? (
+		dev-java/junit:5
+	)"
+fi
+
+java-pkg-junit-5_pkg_setup() {
+	java-pkg-2_pkg_setup
+	[[ ${MERGE_TYPE} == binary ]] && return
+
+	# Note: Each method must have a "_java-pkg-junit-5_src_test_${method}"
+	# function in this eclass
+	local accepted_methods="
+		traditional
+		scan-classpath
+		scan-classpath+pattern
+		console-args
+	"
+
+	show_accepted_methods_and_die() {
+		eerror "Accepted methods are:"
+		local m
+		for m in ${accepted_methods}; do
+			eerror "- ${m}"
+		done
+		die "Invalid JAVA_TEST_SELECTION_METHOD value: ${JAVA_TEST_SELECTION_METHOD}"
+	}
+
+	local methods=()
+	local method
+	for method in ${JAVA_TEST_SELECTION_METHOD}; do
+		if has ${method} ${accepted_methods}; then
+			methods+=( ${method} )
+		else
+			eerror "Unknown test selection method: ${method}"
+			show_accepted_methods_and_die
+		fi
+	done
+	if [[ ${#methods[@]} -eq 1 ]]; then
+		einfo "Using JUnit Platform test selection method: ${methods[@]}"
+	elif [[ ${#methods[@]} -gt 1 ]]; then
+		einfo "Using multiple JUnit Platform test selection methods,"
+		einfo "which should only be used for development purposes:"
+		for method in "${methods[@]}"; do
+			einfo "- ${method}"
+		done
+	else
+		eerror "No valid JUnit Platform test selection method specified"
+		show_accepted_methods_and_die
+	fi
+
+	_JAVA_PKG_JUNIT_5_PKG_SETUP=1
+}
+
+# @FUNCTION: ejunit5
+# @USAGE: [-cp <classpath>|-classpath <classpath>] <classes>
+# @DESCRIPTION:
+# Using the specified classpath, launches a JVM instance to run the specified
+# test classes by invoking the JUnit Platform's ConsoleLauncher.
+#
+# This function's interface is consistent with the existing 'ejunit' and
+# 'ejunit4' functions in java-utils-2.eclass.
+ejunit5() {
+	debug-print-function ${FUNCNAME} $*
+
+	local pkgs
+	if [[ -f ${JAVA_PKG_DEPEND_FILE} ]]; then
+		for atom in $(cat ${JAVA_PKG_DEPEND_FILE} | tr : ' '); do
+			pkgs=${pkgs},$(echo ${atom} | sed -re "s/^.*@//")
+		done
+	fi
+
+	local junit="junit-5"
+	local cp=$(java-pkg_getjars --with-dependencies ${junit}${pkgs})
+	if [[ ${1} = -cp || ${1} = -classpath ]]; then
+		cp="${2}:${cp}"
+		shift 2
+	else
+		cp=".:${cp}"
+	fi
+
+	_java-pkg-junit-5_ConsoleLauncher "${cp}"$(printf -- ' -c=%q' "${@}")
+}
+
+# @FUNCTION: _java-pkg-junit-5_ConsoleLauncher
+# @INTERNAL
+# @USAGE: <classpath> [args]
+# @DESCRIPTION:
+# Invokes the JUnit Platform's ConsoleLauncher on the specified classpath,
+# using the specified arguments.
+_java-pkg-junit-5_ConsoleLauncher() {
+	debug-print-function ${FUNCNAME} $*
+
+	local cp=${1}
+	shift 1
+
+	# Save test reports, which contain information about
+	# the test execution that can be useful to QA checks
+	mkdir -p "${_JAVA_JUNIT_REPORTS_DIR}" ||
+		die "Failed to create JUnit report directory"
+
+	local runner=org.junit.platform.console.ConsoleLauncher
+	local runner_args=(
+		--reports-dir="${_JAVA_JUNIT_REPORTS_DIR}"
+		--fail-if-no-tests
+
+		# By default, remove ANSI escape code for coloring
+		# to make log files more readable
+		$([[ ${JAVA_JUNIT_CONSOLE_COLOR} ]] || echo --disable-ansi-colors)
+
+		${JAVA_PKG_DEBUG:+--details=verbose}
+	)
+
+	local args=(
+		-cp "${cp}"
+		-Djava.io.tmpdir="${T}"
+		-Djava.awt.headless=true
+		"${JAVA_TEST_EXTRA_ARGS[@]}"
+		${runner}
+		"${runner_args[@]}"
+		"${JAVA_TEST_RUNNER_EXTRA_ARGS[@]}"
+		"${@}"
+	)
+
+	set -- java "${args[@]}"
+	debug-print "Calling: ${*}"
+	echo "${@}" >&2
+	"${@}"
+	local ret=${?}
+	[[ ${ret} -eq 2 ]] && die "No JUnit tests found"
+	[[ ${ret} -eq 0 ]] || die "ConsoleLauncher failed"
+}
+
+java-pkg-junit-5_src_test() {
+	if ! has test ${JAVA_PKG_IUSE}; then
+		return
+	elif ! use test; then
+		return
+	fi
+
+	if [[ ! ${_JAVA_PKG_JUNIT_5_PKG_SETUP} ]]; then
+		eqawarn "java-pkg-junit-5.eclass is inherited, but the"
+		eqawarn "java-pkg-junit-5_pkg_setup function has not been called."
+		eqawarn "Please add the function call to pkg_setup."
+	fi
+
+	local junit_5_classpath="junit-5"
+	JAVA_TEST_GENTOO_CLASSPATH+=" ${junit_5_classpath}"
+	java-pkg-simple_src_test
+	elog "java-pkg-simple.eclass might have printed a \"No suitable function found\""
+	elog "message.  This is OK, as java-pkg-junit-5.eclass will handle JUnit 5..."
+
+	local classes="target/test-classes"
+	local classpath="${classes}:${JAVA_JAR_FILENAME}"
+	java-pkg-simple_getclasspath
+	java-pkg-simple_prepend_resources ${classes} "${JAVA_TEST_RESOURCE_DIRS[@]}"
+
+	local method
+	declare -A num_tests
+	for method in ${JAVA_TEST_SELECTION_METHOD}; do
+		local method_func="_java-pkg-junit-5_src_test_${method}"
+		declare -F ${method_func} > /dev/null ||
+			die "Function for \"${method}\" method not found: ${method_func}"
+		${method_func}
+		num_tests[${method}]="$(\
+			cat "${_JAVA_JUNIT_REPORTS_DIR}"/TEST-*.xml |
+			grep -c '</testcase>')"
+	done
+
+	_java-pkg-junit-5_post_test_qa_check_use_dep
+
+	if [[ ${#num_tests[@]} -gt 1 ]]; then
+		einfo "Number of tests each test selection method selected:"
+		for method in "${!num_tests[@]}"; do
+			einfo "- ${method}: ${num_tests[${method}]}"
+		done
+	fi
+}
+
+# @FUNCTION: _java-pkg-junit-5_post_test_qa_check_use_dep
+# @INTERNAL
+# @DESCRIPTION:
+# Checks whether the dev-java/junit:5 atom's USE dependency in DEPEND includes
+# all USE flags that are required by the tests.  This function should only be
+# called after the tests on the JUnit Platform have run.
+#
+# This function helps ebuild authors determine the correct USE dependency for
+# dev-java/junit:5.  Consider the following situation:
+#
+# Suppose an ebuild author has already installed dev-java/junit:5 with the
+# 'suite' USE flag enabled, and they are creating a new ebuild that has tests
+# to run on the junit-platform-suite test engine.  If the author had disabled
+# the 'suite' USE flag, some tests might fail due to the missing JUnit 5
+# modules, so the author could realize that the ebuild needs to depend on
+# dev-java/junit:5[suite].  However, the USE flag is enabled, so it is possible
+# that all tests pass in the author's environment, thus the author thinks the
+# ebuild does not have issues and publishes it.
+#
+# When another person gets the ebuild and tries to run the tests in an
+# environment where dev-java/junit:5's 'suite' USE flag is _not_ enabled, the
+# tests _will_ launch and then fail.  The dev-java/junit:5[suite] dependency is
+# not declared, so the package manager will not enforce it.
+_java-pkg-junit-5_post_test_qa_check_use_dep() {
+	local flag
+
+	# If a test engine ran any tests, its report will contain a
+	# '<testcase ...>...</testcase>' XML entry for each test it ran
+	local engines_with_tests=$(grep -l '</testcase>' \
+		"${_JAVA_JUNIT_REPORTS_DIR}"/TEST-junit-*.xml)
+	# A test engine's report filename format is "TEST-${engine_id}.xml"
+	engines_with_tests="${engines_with_tests//"${_JAVA_JUNIT_REPORTS_DIR}/TEST-"}"
+	engines_with_tests="${engines_with_tests//.xml}"
+
+	local engine
+	local unexpected_engines=()
+	for engine in ${engines_with_tests}; do
+		case ${engine} in
+			junit-jupiter)
+				# Built unconditionally in dev-java/junit:5; no USE flag needed
+				;;
+			junit-platform-suite)
+				flag=suite
+				;;
+			junit-vintage)
+				flag=vintage
+				;;
+		esac
+		[[ -z ${flag} ]] || _java-pkg-junit-5_dep_has_use "${flag}" ||
+			unexpected_engines+=( "${engine}: dev-java/junit:5[${flag}]" )
+	done
+	if [[ -n ${unexpected_engines[@]} ]]; then
+		eqawarn "Some tests ran on a JUnit Platform test engine whose USE flag"
+		eqawarn "is not enabled by the dev-java/junit:5 atom in DEPEND."
+		eqawarn "Please check the following test engine list and add the"
+		eqawarn "mentioned USE dependencies into DEPEND=\"test? ( ... )\":"
+		for engine in "${unexpected_engines[@]}"; do
+			eqawarn "- ${engine}"
+		done
+	fi
+
+	einfo "Verifying test classes' dependencies"
+
+	local jdeps_output="${T}/test-classes-jdeps.txt"
+	find "${classes}" -type f -name '*.class' -exec \
+		"$(java-config --jdk-home)/bin/jdeps" {} + > "${jdeps_output}" ||
+		die "jdeps failed"
+	declare -A junit_5_flag_to_package=(
+		[migration-support]=org.junit.jupiter.migrationsupport
+		[test-kit]=org.junit.platform.testkit.engine
+	)
+	local package
+	local unexpected_packages=()
+	for flag in "${!junit_5_flag_to_package[@]}"; do
+		package="${junit_5_flag_to_package[${flag}]}"
+		_java-pkg-junit-5_dep_has_use "${flag}" ||
+			! grep -q -F "${package}" "${jdeps_output}" ||
+			unexpected_packages+=( "${package}: dev-java/junit:5[${flag}]" )
+	done
+	if [[ -n ${unexpected_packages[@]} ]]; then
+		eqawarn "Some tests used an optional JUnit 5 module whose USE flag"
+		eqawarn "is not enabled by the dev-java/junit:5 atom in DEPEND."
+		eqawarn "Please check the following Java package list and add the"
+		eqawarn "mentioned USE dependencies into DEPEND=\"test? ( ... )\":"
+		for package in "${unexpected_packages[@]}"; do
+			eqawarn "- ${package}"
+		done
+	fi
+}
+
+# @FUNCTION: _java-pkg-junit-5_dep_has_use
+# @INTERNAL
+# @USAGE: <flag>
+# @DESCRIPTION:
+# Checks whether dev-java/junit:5 is declared with USE dependency on the
+# specified USE flag (i.e. dev-java/junit:5[<flag>]) in DEPEND.
+# @RETURN: Shell true if the check passed, shell false otherwise
+_java-pkg-junit-5_dep_has_use() {
+	debug-print-function ${FUNCNAME} $*
+
+	local flag=${1}
+
+	local re="\bdev-java/junit(-[0-9].*)?:5\[[^]]*\b${flag}\b[^]]*\]"
+	# Do not match "dev-java/junit:5[-${flag}]"
+	local n_re1="\bdev-java/junit(-[0-9].*)?:5\[[^]]*-\b${flag}\b[^]]*\]"
+	[[ ${DEPEND} =~ ${re} && ! ${DEPEND} =~ ${n_re1} ]]
+}
+
+# @FUNCTION: _java-pkg-junit-5_src_test_traditional
+# @INTERNAL
+# @DESCRIPTION:
+# Finds tests to run using the traditional method that java-pkg-simple.eclass
+# utilizes, then runs these tests on the JUnit Platform.
+#
+# The method to find tests is:
+# 1. If JAVA_TEST_RUN_ONLY is defined, run only the tests listed in it, and
+#    skip the rest steps.
+# 2. Use the 'find' command to gather a list of Java source files whose
+#    filename matches a preset pattern.
+# 3. Remove any tests in JAVA_TEST_EXCLUDES from the list.  Run tests that are
+#    still in the list after the removal.
+_java-pkg-junit-5_src_test_traditional() {
+	debug-print-function ${FUNCNAME} $*
+
+	local tests_to_run
+	# grab a set of tests that testing framework will run
+	if [[ -n ${JAVA_TEST_RUN_ONLY} ]]; then
+		tests_to_run="${JAVA_TEST_RUN_ONLY[@]}"
+	else
+		pushd "${JAVA_TEST_SRC_DIR}" > /dev/null || die
+		tests_to_run=$(find * -type f\
+			\( -name "*Test.java"\
+			-o -name "Test*.java"\
+			-o -name "*Tests.java"\
+			-o -name "*TestCase.java" \)\
+			! -name "*Abstract*"\
+			! -name "*BaseTest*"\
+			! -name "*TestTypes*"\
+			! -name "*TestUtils*"\
+			! -name "*\$*")
+		tests_to_run=${tests_to_run//"${classes}"\/}
+		tests_to_run=${tests_to_run//.java}
+		tests_to_run=${tests_to_run//\//.}
+		popd > /dev/null || die
+
+		# exclude extra test classes, usually corner cases
+		# that the code above cannot handle
+		local class
+		for class in "${JAVA_TEST_EXCLUDES[@]}"; do
+			tests_to_run=${tests_to_run//${class}}
+		done
+	fi
+
+	ejunit5 -classpath "${classpath}" ${tests_to_run}
+}
+
+# @FUNCTION: _java-pkg-junit-5_src_test_scan-classpath
+# @INTERNAL
+# @DESCRIPTION:
+# If JAVA_TEST_RUN_ONLY is defined, runs only the tests listed in it on the
+# JUnit Platform.
+# Otherwise, runs the JUnit Platform's ConsoleLauncher with the
+# '--scan-classpath' to let the JUnit Platform automatically detect, select,
+# and run tests.  JAVA_TEST_EXCLUDES is still honored in this case.
+_java-pkg-junit-5_src_test_scan-classpath() {
+	debug-print-function ${FUNCNAME} $*
+
+	if [[ -n ${JAVA_TEST_RUN_ONLY} ]]; then
+		ejunit5 -classpath "${classpath}" ${JAVA_TEST_RUN_ONLY[@]}
+	else
+		local args=(
+			--scan-classpath
+		)
+
+		# 'includes' and 'excludes' may be set by another function.
+		#
+		# The 'classname' options take a regular expression for a class's
+		# fully qualified name, which contains the class's package.
+		# '^(.*\.)*' matches the package part in the class name;
+		# '[^.]*$' prevents the pattern for a class name to match any part of
+		# the package name.
+		local pattern
+		for pattern in "${includes[@]}"; do
+			args+=( --include-classname="^(.*\\.)*${pattern}[^.]*\$" )
+		done
+		for pattern in "${excludes[@]}"; do
+			args+=( --exclude-classname="^(.*\\.)*${pattern}[^.]*\$" )
+		done
+
+		local class
+		for class in "${JAVA_TEST_EXCLUDES[@]}"; do
+			args+=( --exclude-classname="^${class//./\\.}\$" )
+		done
+
+		_java-pkg-junit-5_ConsoleLauncher "${classpath}" "${args[@]}"
+	fi
+}
+
+# @FUNCTION: _java-pkg-junit-5_src_test_scan-classpath+pattern
+# @INTERNAL
+# @DESCRIPTION:
+# If JAVA_TEST_RUN_ONLY is defined, runs only the tests listed in it on the
+# JUnit Platform.
+# Otherwise, finds tests to run using the JUnit Platform's ConsoleLauncher's
+# '--scan-classpath' option, and also includes and excludes class names based
+# on the test class name patterns that java-pkg-simple.eclass uses.  Then, runs
+# the found tests on the JUnit Platform.
+_java-pkg-junit-5_src_test_scan-classpath+pattern() {
+	debug-print-function ${FUNCNAME} $*
+
+	local includes=(
+		'.*Test'
+		'Test.*'
+		'.*Tests'
+		'.*TestCase'
+	)
+	local excludes=(
+		'.*Abstract.*'
+		'.*BaseTest.*'
+		'.*TestTypes.*'
+		'.*TestUtils.*'
+		'.*\$.*'
+	)
+	_java-pkg-junit-5_src_test_scan-classpath
+}
+
+# @FUNCTION: _java-pkg-junit-5_src_test_console-args
+# @INTERNAL
+# @DESCRIPTION:
+# Does not do anything with regards to test selection at all; instead, passes
+# JAVA_JUNIT_CONSOLE_ARGS to JUnit Platform's ConsoleLauncher, and lets the
+# arguments in JAVA_JUNIT_CONSOLE_ARGS control test selection.
+_java-pkg-junit-5_src_test_console-args() {
+	_java-pkg-junit-5_ConsoleLauncher "${classpath}" ${JAVA_JUNIT_CONSOLE_ARGS}
+}
+
+_JAVA_PKG_JUNIT_5_ECLASS=1
+fi
+
+EXPORT_FUNCTIONS pkg_setup src_test
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-08-13 11:01 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-08-13 11:01 UTC (permalink / raw
  To: gentoo-commits
commit:     392965e1c961775b4783c8b8364dc72fc395fa02
Author:     Volkmar W. Pogatzki <gentoo <AT> pogatzki <DOT> net>
AuthorDate: Mon Jun 23 13:49:31 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Aug 13 11:00:41 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=392965e1
junit5.eclass: renamed java-pkg-junit-5.eclass -> junit5.eclass
Signed-off-by: Volkmar W. Pogatzki <gentoo <AT> pogatzki.net>
Part-of: https://github.com/gentoo/gentoo/pull/43318
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/{java-pkg-junit-5.eclass => junit5.eclass} | 68 +++++++++++------------
 1 file changed, 34 insertions(+), 34 deletions(-)
diff --git a/eclass/java-pkg-junit-5.eclass b/eclass/junit5.eclass
similarity index 89%
rename from eclass/java-pkg-junit-5.eclass
rename to eclass/junit5.eclass
index cd3101f3eccd..4fb04894e963 100755
--- a/eclass/java-pkg-junit-5.eclass
+++ b/eclass/junit5.eclass
@@ -1,9 +1,9 @@
 # Copyright 2022-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
-# @ECLASS: java-pkg-junit-5.eclass
+# @ECLASS: junit5.eclass
 # @MAINTAINER:
-# Yuan Liao <liaoyuan@gmail.com>
+# java@gentoo.org
 # @AUTHOR:
 # Yuan Liao <liaoyuan@gmail.com>
 # @SUPPORTED_EAPIS: 8
@@ -14,7 +14,7 @@
 # eventually be merged into java-utils-2.eclass and/or java-pkg-simple.eclass
 # when it is mature.
 
-if [[ ! ${_JAVA_PKG_JUNIT_5_ECLASS} ]]; then
+if [[ ! ${_JUNIT5_ECLASS} ]]; then
 
 case ${EAPI} in
 	8) ;;
@@ -85,11 +85,11 @@ if has test ${JAVA_PKG_IUSE}; then
 	)"
 fi
 
-java-pkg-junit-5_pkg_setup() {
+junit5_pkg_setup() {
 	java-pkg-2_pkg_setup
 	[[ ${MERGE_TYPE} == binary ]] && return
 
-	# Note: Each method must have a "_java-pkg-junit-5_src_test_${method}"
+	# Note: Each method must have a "_junit5_src_test_${method}"
 	# function in this eclass
 	local accepted_methods="
 		traditional
@@ -130,7 +130,7 @@ java-pkg-junit-5_pkg_setup() {
 		show_accepted_methods_and_die
 	fi
 
-	_JAVA_PKG_JUNIT_5_PKG_SETUP=1
+	_JUNIT5_PKG_SETUP=1
 }
 
 # @FUNCTION: ejunit5
@@ -160,16 +160,16 @@ ejunit5() {
 		cp=".:${cp}"
 	fi
 
-	_java-pkg-junit-5_ConsoleLauncher "${cp}"$(printf -- ' -c=%q' "${@}")
+	_junit5_ConsoleLauncher "${cp}"$(printf -- ' -c=%q' "${@}")
 }
 
-# @FUNCTION: _java-pkg-junit-5_ConsoleLauncher
+# @FUNCTION: _junit5_ConsoleLauncher
 # @INTERNAL
 # @USAGE: <classpath> [args]
 # @DESCRIPTION:
 # Invokes the JUnit Platform's ConsoleLauncher on the specified classpath,
 # using the specified arguments.
-_java-pkg-junit-5_ConsoleLauncher() {
+_junit5_ConsoleLauncher() {
 	debug-print-function ${FUNCNAME} $*
 
 	local cp=${1}
@@ -212,16 +212,16 @@ _java-pkg-junit-5_ConsoleLauncher() {
 	[[ ${ret} -eq 0 ]] || die "ConsoleLauncher failed"
 }
 
-java-pkg-junit-5_src_test() {
+junit5_src_test() {
 	if ! has test ${JAVA_PKG_IUSE}; then
 		return
 	elif ! use test; then
 		return
 	fi
 
-	if [[ ! ${_JAVA_PKG_JUNIT_5_PKG_SETUP} ]]; then
-		eqawarn "java-pkg-junit-5.eclass is inherited, but the"
-		eqawarn "java-pkg-junit-5_pkg_setup function has not been called."
+	if [[ ! ${_JUNIT5_PKG_SETUP} ]]; then
+		eqawarn "junit5.eclass is inherited, but the"
+		eqawarn "junit5_pkg_setup function has not been called."
 		eqawarn "Please add the function call to pkg_setup."
 	fi
 
@@ -229,7 +229,7 @@ java-pkg-junit-5_src_test() {
 	JAVA_TEST_GENTOO_CLASSPATH+=" ${junit_5_classpath}"
 	java-pkg-simple_src_test
 	elog "java-pkg-simple.eclass might have printed a \"No suitable function found\""
-	elog "message.  This is OK, as java-pkg-junit-5.eclass will handle JUnit 5..."
+	elog "message.  This is OK, as junit5.eclass will handle JUnit 5..."
 
 	local classes="target/test-classes"
 	local classpath="${classes}:${JAVA_JAR_FILENAME}"
@@ -239,7 +239,7 @@ java-pkg-junit-5_src_test() {
 	local method
 	declare -A num_tests
 	for method in ${JAVA_TEST_SELECTION_METHOD}; do
-		local method_func="_java-pkg-junit-5_src_test_${method}"
+		local method_func="_junit5_src_test_${method}"
 		declare -F ${method_func} > /dev/null ||
 			die "Function for \"${method}\" method not found: ${method_func}"
 		${method_func}
@@ -248,7 +248,7 @@ java-pkg-junit-5_src_test() {
 			grep -c '</testcase>')"
 	done
 
-	_java-pkg-junit-5_post_test_qa_check_use_dep
+	_junit5_post_test_qa_check_use_dep
 
 	if [[ ${#num_tests[@]} -gt 1 ]]; then
 		einfo "Number of tests each test selection method selected:"
@@ -258,7 +258,7 @@ java-pkg-junit-5_src_test() {
 	fi
 }
 
-# @FUNCTION: _java-pkg-junit-5_post_test_qa_check_use_dep
+# @FUNCTION: _junit5_post_test_qa_check_use_dep
 # @INTERNAL
 # @DESCRIPTION:
 # Checks whether the dev-java/junit:5 atom's USE dependency in DEPEND includes
@@ -281,7 +281,7 @@ java-pkg-junit-5_src_test() {
 # environment where dev-java/junit:5's 'suite' USE flag is _not_ enabled, the
 # tests _will_ launch and then fail.  The dev-java/junit:5[suite] dependency is
 # not declared, so the package manager will not enforce it.
-_java-pkg-junit-5_post_test_qa_check_use_dep() {
+_junit5_post_test_qa_check_use_dep() {
 	local flag
 
 	# If a test engine ran any tests, its report will contain a
@@ -306,7 +306,7 @@ _java-pkg-junit-5_post_test_qa_check_use_dep() {
 				flag=vintage
 				;;
 		esac
-		[[ -z ${flag} ]] || _java-pkg-junit-5_dep_has_use "${flag}" ||
+		[[ -z ${flag} ]] || _junit5_dep_has_use "${flag}" ||
 			unexpected_engines+=( "${engine}: dev-java/junit:5[${flag}]" )
 	done
 	if [[ -n ${unexpected_engines[@]} ]]; then
@@ -333,7 +333,7 @@ _java-pkg-junit-5_post_test_qa_check_use_dep() {
 	local unexpected_packages=()
 	for flag in "${!junit_5_flag_to_package[@]}"; do
 		package="${junit_5_flag_to_package[${flag}]}"
-		_java-pkg-junit-5_dep_has_use "${flag}" ||
+		_junit5_dep_has_use "${flag}" ||
 			! grep -q -F "${package}" "${jdeps_output}" ||
 			unexpected_packages+=( "${package}: dev-java/junit:5[${flag}]" )
 	done
@@ -348,14 +348,14 @@ _java-pkg-junit-5_post_test_qa_check_use_dep() {
 	fi
 }
 
-# @FUNCTION: _java-pkg-junit-5_dep_has_use
+# @FUNCTION: _junit5_dep_has_use
 # @INTERNAL
 # @USAGE: <flag>
 # @DESCRIPTION:
 # Checks whether dev-java/junit:5 is declared with USE dependency on the
 # specified USE flag (i.e. dev-java/junit:5[<flag>]) in DEPEND.
 # @RETURN: Shell true if the check passed, shell false otherwise
-_java-pkg-junit-5_dep_has_use() {
+_junit5_dep_has_use() {
 	debug-print-function ${FUNCNAME} $*
 
 	local flag=${1}
@@ -366,7 +366,7 @@ _java-pkg-junit-5_dep_has_use() {
 	[[ ${DEPEND} =~ ${re} && ! ${DEPEND} =~ ${n_re1} ]]
 }
 
-# @FUNCTION: _java-pkg-junit-5_src_test_traditional
+# @FUNCTION: _junit5_src_test_traditional
 # @INTERNAL
 # @DESCRIPTION:
 # Finds tests to run using the traditional method that java-pkg-simple.eclass
@@ -379,7 +379,7 @@ _java-pkg-junit-5_dep_has_use() {
 #    filename matches a preset pattern.
 # 3. Remove any tests in JAVA_TEST_EXCLUDES from the list.  Run tests that are
 #    still in the list after the removal.
-_java-pkg-junit-5_src_test_traditional() {
+_junit5_src_test_traditional() {
 	debug-print-function ${FUNCNAME} $*
 
 	local tests_to_run
@@ -414,7 +414,7 @@ _java-pkg-junit-5_src_test_traditional() {
 	ejunit5 -classpath "${classpath}" ${tests_to_run}
 }
 
-# @FUNCTION: _java-pkg-junit-5_src_test_scan-classpath
+# @FUNCTION: _junit5_src_test_scan-classpath
 # @INTERNAL
 # @DESCRIPTION:
 # If JAVA_TEST_RUN_ONLY is defined, runs only the tests listed in it on the
@@ -422,7 +422,7 @@ _java-pkg-junit-5_src_test_traditional() {
 # Otherwise, runs the JUnit Platform's ConsoleLauncher with the
 # '--scan-classpath' to let the JUnit Platform automatically detect, select,
 # and run tests.  JAVA_TEST_EXCLUDES is still honored in this case.
-_java-pkg-junit-5_src_test_scan-classpath() {
+_junit5_src_test_scan-classpath() {
 	debug-print-function ${FUNCNAME} $*
 
 	if [[ -n ${JAVA_TEST_RUN_ONLY} ]]; then
@@ -452,11 +452,11 @@ _java-pkg-junit-5_src_test_scan-classpath() {
 			args+=( --exclude-classname="^${class//./\\.}\$" )
 		done
 
-		_java-pkg-junit-5_ConsoleLauncher "${classpath}" "${args[@]}"
+		_junit5_ConsoleLauncher "${classpath}" "${args[@]}"
 	fi
 }
 
-# @FUNCTION: _java-pkg-junit-5_src_test_scan-classpath+pattern
+# @FUNCTION: _junit5_src_test_scan-classpath+pattern
 # @INTERNAL
 # @DESCRIPTION:
 # If JAVA_TEST_RUN_ONLY is defined, runs only the tests listed in it on the
@@ -465,7 +465,7 @@ _java-pkg-junit-5_src_test_scan-classpath() {
 # '--scan-classpath' option, and also includes and excludes class names based
 # on the test class name patterns that java-pkg-simple.eclass uses.  Then, runs
 # the found tests on the JUnit Platform.
-_java-pkg-junit-5_src_test_scan-classpath+pattern() {
+_junit5_src_test_scan-classpath+pattern() {
 	debug-print-function ${FUNCNAME} $*
 
 	local includes=(
@@ -481,20 +481,20 @@ _java-pkg-junit-5_src_test_scan-classpath+pattern() {
 		'.*TestUtils.*'
 		'.*\$.*'
 	)
-	_java-pkg-junit-5_src_test_scan-classpath
+	_junit5_src_test_scan-classpath
 }
 
-# @FUNCTION: _java-pkg-junit-5_src_test_console-args
+# @FUNCTION: _junit5_src_test_console-args
 # @INTERNAL
 # @DESCRIPTION:
 # Does not do anything with regards to test selection at all; instead, passes
 # JAVA_JUNIT_CONSOLE_ARGS to JUnit Platform's ConsoleLauncher, and lets the
 # arguments in JAVA_JUNIT_CONSOLE_ARGS control test selection.
-_java-pkg-junit-5_src_test_console-args() {
-	_java-pkg-junit-5_ConsoleLauncher "${classpath}" ${JAVA_JUNIT_CONSOLE_ARGS}
+_junit5_src_test_console-args() {
+	_junit5_ConsoleLauncher "${classpath}" ${JAVA_JUNIT_CONSOLE_ARGS}
 }
 
-_JAVA_PKG_JUNIT_5_ECLASS=1
+_JUNIT5_ECLASS=1
 fi
 
 EXPORT_FUNCTIONS pkg_setup src_test
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-08-13 12:03 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-08-13 12:03 UTC (permalink / raw
  To: gentoo-commits
commit:     3569dfc72dc6aba486bdd4598ac73cd86859d6ee
Author:     Volkmar W. Pogatzki <gentoo <AT> pogatzki <DOT> net>
AuthorDate: Wed Jul 30 14:34:32 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Aug 13 12:02:57 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=3569dfc7
java-utils-2.eclass: drop EAPI 7
Signed-off-by: Volkmar W. Pogatzki <gentoo <AT> pogatzki.net>
Part-of: https://github.com/gentoo/gentoo/pull/43246
Closes: https://github.com/gentoo/gentoo/pull/43246
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/java-utils-2.eclass | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/eclass/java-utils-2.eclass b/eclass/java-utils-2.eclass
index c11f1652fc5a..3b2b9d6a5b24 100644
--- a/eclass/java-utils-2.eclass
+++ b/eclass/java-utils-2.eclass
@@ -6,7 +6,7 @@
 # java@gentoo.org
 # @AUTHOR:
 # Thomas Matthijs <axxo@gentoo.org>, Karl Trygve Kalleberg <karltk@gentoo.org>
-# @SUPPORTED_EAPIS: 7 8
+# @SUPPORTED_EAPIS: 8
 # @BLURB: Base eclass for Java packages
 # @DESCRIPTION:
 # This eclass provides functionality which is used by java-pkg-2.eclass and
@@ -20,7 +20,7 @@ if [[ -z ${_JAVA_UTILS_2_ECLASS} ]] ; then
 _JAVA_UTILS_2_ECLASS=1
 
 case ${EAPI} in
-	7|8) ;;
+	8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-08-13 12:03 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-08-13 12:03 UTC (permalink / raw
  To: gentoo-commits
commit:     528b99658a59955f36055f2529ebe189dae556d1
Author:     Volkmar W. Pogatzki <gentoo <AT> pogatzki <DOT> net>
AuthorDate: Wed Jul 30 14:30:28 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Aug 13 12:02:57 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=528b9965
java-pkg-opt-2.eclass: drop EAPI 7
Signed-off-by: Volkmar W. Pogatzki <gentoo <AT> pogatzki.net>
Part-of: https://github.com/gentoo/gentoo/pull/43246
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/java-pkg-opt-2.eclass | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/eclass/java-pkg-opt-2.eclass b/eclass/java-pkg-opt-2.eclass
index 7b3e79749fb6..47594c3b7024 100644
--- a/eclass/java-pkg-opt-2.eclass
+++ b/eclass/java-pkg-opt-2.eclass
@@ -1,4 +1,4 @@
-# Copyright 2004-2023 Gentoo Authors
+# Copyright 2004-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: java-pkg-opt-2.eclass
@@ -6,7 +6,7 @@
 # java@gentoo.org
 # @AUTHOR:
 # Thomas Matthijs <axxo@gentoo.org>
-# @SUPPORTED_EAPIS: 7 8
+# @SUPPORTED_EAPIS: 8
 # @PROVIDES: java-utils-2
 # @BLURB: Eclass for package with optional Java support
 # @DESCRIPTION:
@@ -14,7 +14,7 @@
 # support.
 
 case ${EAPI} in
-	7|8) ;;
+	8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-08-14  8:09 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-08-14  8:09 UTC (permalink / raw
  To: gentoo-commits
commit:     4f66d70cdab6ce727525e47859654cf14d990e18
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Aug 14 08:08:04 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Aug 14 08:08:04 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=4f66d70c
junit5.eclass: drop -x
Reported by selckin.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/junit5.eclass | 0
 1 file changed, 0 insertions(+), 0 deletions(-)
diff --git a/eclass/junit5.eclass b/eclass/junit5.eclass
old mode 100755
new mode 100644
^ permalink raw reply	[flat|nested] 6663+ messages in thread
* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-08-14 16:33 Mike Gilbert
  0 siblings, 0 replies; 6663+ messages in thread
From: Mike Gilbert @ 2025-08-14 16:33 UTC (permalink / raw
  To: gentoo-commits
commit:     4af5eb5ed970584d3f80489659f74c5623042695
Author:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
AuthorDate: Thu Aug  7 18:10:39 2025 +0000
Commit:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
CommitDate: Thu Aug 14 16:27:41 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=4af5eb5e
fcaps.eclass: handle FCAPS_DENY_WORLD_READ via a separate chmod call
This simplifies the logic needed to apply the ebuild-supplied mode.
Signed-off-by: Mike Gilbert <floppym <AT> gentoo.org>
 eclass/fcaps.eclass | 13 ++++++-------
 1 file changed, 6 insertions(+), 7 deletions(-)
diff --git a/eclass/fcaps.eclass b/eclass/fcaps.eclass
index 5cb781a7a75d..884b3c63c5f9 100644
--- a/eclass/fcaps.eclass
+++ b/eclass/fcaps.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2024 Gentoo Authors
+# Copyright 1999-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: fcaps.eclass
@@ -105,11 +105,6 @@ fcaps() {
 	local mode=u+s
 	local caps_mode=
 
-	if [[ -n ${FCAPS_DENY_WORLD_READ} ]]; then
-		mode=u+s,go-r
-		caps_mode=go-r
-	fi
-
 	while [[ $# -gt 0 ]] ; do
 		case $1 in
 		-o) owner=$2; shift;;
@@ -143,12 +138,16 @@ fcaps() {
 	for file ; do
 		[[ ${file} != /* ]] && file="${root}/${file}"
 
+		# Remove the read bits if requested.
+		if [[ -n ${FCAPS_DENY_WORLD_READ} ]]; then
+			chmod go-r "${file}" || die
+		fi
+
 		if use filecaps ; then
 			# Try to set capabilities.  Ignore errors when the
 			# fs doesn't support it, but abort on all others.
 			debug-print "${FUNCNAME}: setting caps '${caps}' on '${file}'"
 
-			# Remove the read bits if requested.
 			if [[ -n ${caps_mode} ]]; then
 				chmod ${caps_mode} "${file}" || die
 			fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-08-14 16:33 Mike Gilbert
  0 siblings, 0 replies; 6663+ messages in thread
From: Mike Gilbert @ 2025-08-14 16:33 UTC (permalink / raw
  To: gentoo-commits
commit:     2e32af007cf8a21bd77002ca45c9bccc711a2bd0
Author:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
AuthorDate: Thu Aug  7 18:16:03 2025 +0000
Commit:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
CommitDate: Thu Aug 14 16:27:44 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=2e32af00
fcaps.eclass: do not set suid bit as a fallback
This behavior often catches devs by suprise, leading to unintended suid
binaries. Pass -m u+s explicitly to maintain the previous behavior.
Bug: https://bugs.gentoo.org/811105
Signed-off-by: Mike Gilbert <floppym <AT> gentoo.org>
 eclass/fcaps.eclass | 23 +++++++++++++----------
 1 file changed, 13 insertions(+), 10 deletions(-)
diff --git a/eclass/fcaps.eclass b/eclass/fcaps.eclass
index 884b3c63c5f9..81c1ca62368c 100644
--- a/eclass/fcaps.eclass
+++ b/eclass/fcaps.eclass
@@ -84,13 +84,16 @@ esac
 # appropriate path var ($D/$ROOT/etc...) will be prefixed based on the current
 # ebuild phase.
 #
-# The caps mode (default 711) is used to set the permission on the file if
-# capabilities were properly set on the file.
+# The caps mode is used to set the permission on the file if capabilities
+# were properly set on the file.  No change is applied by default.
 #
 # If the system is unable to set capabilities, it will use the specified user,
-# group, and mode (presumably to make the binary set*id).  The defaults there
-# are 0:0 and 4711.  Otherwise, the ownership and permissions will be
-# unchanged.
+# group, and mode.  The user and group default to 0.  If mode is unspecified, no
+# change is applied.
+#
+# For example, "-m u+s" may be used to enable suid as a fallback when file caps
+# are unavailable.  This should be used with care, typically when the
+# application is written to handle dropping privileges itself.
 fcaps() {
 	debug-print-function ${FUNCNAME} "$@"
 
@@ -102,7 +105,7 @@ fcaps() {
 	# Process the user options first.
 	local owner='0'
 	local group='0'
-	local mode=u+s
+	local mode=
 	local caps_mode=
 
 	while [[ $# -gt 0 ]] ; do
@@ -181,11 +184,11 @@ fcaps() {
 		fi
 
 		# If we're still here, setcaps failed.
-		if [[ -n ${owner} || -n ${group} ]]; then
-			debug-print "${FUNCNAME}: setting owner on '${file}'"
-			chown "${owner}:${group}" "${file}" || die
-		fi
 		if [[ -n ${mode} ]]; then
+			if [[ -n ${owner} || -n ${group} ]]; then
+				debug-print "${FUNCNAME}: setting owner on '${file}'"
+				chown "${owner}:${group}" "${file}" || die
+			fi
 			debug-print "${FUNCNAME}: setting mode on '${file}'"
 			chmod ${mode} "${file}" || die
 		fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-08-16 13:51 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-08-16 13:51 UTC (permalink / raw
  To: gentoo-commits
commit:     396157ac9593b8e58bd5bb91af8b53b93f93c229
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Aug 16 13:03:21 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat Aug 16 13:50:39 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=396157ac
llvm.org.eclass: Add 22.0.0_pre20250815 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index 78b62ee9e82b..37111988e331 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -72,6 +72,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 			_LLVM_SOURCE_TYPE=snapshot
 
 			case ${PV} in
+				22.0.0_pre20250815)
+					EGIT_COMMIT=1c7720ef78dc5eb9196d6c178afe03b60f201b78
+					;;
 				22.0.0_pre20250809)
 					EGIT_COMMIT=92164faf17d553359418b9f49c1a41d680d0de49
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-08-18 17:58 Andreas Sturmlechner
  0 siblings, 0 replies; 6663+ messages in thread
From: Andreas Sturmlechner @ 2025-08-18 17:58 UTC (permalink / raw
  To: gentoo-commits
commit:     68855b1774f443481c103a98faf8ff7a084e0040
Author:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
AuthorDate: Sat Aug 16 12:44:06 2025 +0000
Commit:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
CommitDate: Mon Aug 18 17:57:49 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=68855b17
cmake-multilib.eclass: Drop EAPI-7 support
Signed-off-by: Andreas Sturmlechner <asturm <AT> gentoo.org>
 eclass/cmake-multilib.eclass | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/eclass/cmake-multilib.eclass b/eclass/cmake-multilib.eclass
index 826f0ffcd967..8c4b524e0964 100644
--- a/eclass/cmake-multilib.eclass
+++ b/eclass/cmake-multilib.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2023 Gentoo Authors
+# Copyright 1999-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: cmake-multilib.eclass
@@ -6,7 +6,7 @@
 # Michał Górny <mgorny@gentoo.org>
 # @AUTHOR:
 # Author: Michał Górny <mgorny@gentoo.org>
-# @SUPPORTED_EAPIS: 7 8
+# @SUPPORTED_EAPIS: 8
 # @PROVIDES: cmake multilib-minimal
 # @BLURB: cmake wrapper for multilib builds
 # @DESCRIPTION:
@@ -27,7 +27,7 @@
 : "${CMAKE_ECLASS:=cmake}"
 
 case ${EAPI} in
-	7|8)
+	8)
 		case ${CMAKE_ECLASS} in
 			cmake) ;;
 			*)
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-08-18 17:58 Andreas Sturmlechner
  0 siblings, 0 replies; 6663+ messages in thread
From: Andreas Sturmlechner @ 2025-08-18 17:58 UTC (permalink / raw
  To: gentoo-commits
commit:     8f6c2079733c4dff49d0fbef9ee36717112a90e8
Author:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
AuthorDate: Mon Aug 18 15:42:51 2025 +0000
Commit:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
CommitDate: Mon Aug 18 17:57:51 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=8f6c2079
kodi-addon.eclass: Cleanup last-rited eclass
Bug: https://bugs.gentoo.org/939660
Signed-off-by: Andreas Sturmlechner <asturm <AT> gentoo.org>
 eclass/kodi-addon.eclass | 33 ---------------------------------
 1 file changed, 33 deletions(-)
diff --git a/eclass/kodi-addon.eclass b/eclass/kodi-addon.eclass
deleted file mode 100644
index 992f506c3879..000000000000
--- a/eclass/kodi-addon.eclass
+++ /dev/null
@@ -1,33 +0,0 @@
-# Copyright 1999-2023 Gentoo Authors
-# Distributed under the terms of the GNU General Public License v2
-
-# @ECLASS: kodi-addon.eclass
-# @MAINTAINER:
-# candrews@gentoo.org
-# @SUPPORTED_EAPIS: 7
-# @PROVIDES: cmake
-# @BLURB: Helper for correct building and (importantly) installing Kodi addon packages.
-# @DEAD
-# @DESCRIPTION:
-# Provides a src_configure function for correct CMake configuration
-
-case ${EAPI} in
-	7) ;;
-	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
-esac
-
-inherit cmake
-
-# @FUNCTION: kodi-addon_src_configure
-# @DESCRIPTION:
-# Configure handling for Kodi addons
-kodi-addon_src_configure() {
-
-	mycmakeargs+=(
-		-DCMAKE_INSTALL_LIBDIR="${EPREFIX}/usr/$(get_libdir)/kodi"
-	)
-
-	cmake_src_configure
-}
-
-EXPORT_FUNCTIONS src_configure
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-08-20 22:29 James Le Cuirot
  0 siblings, 0 replies; 6663+ messages in thread
From: James Le Cuirot @ 2025-08-20 22:29 UTC (permalink / raw
  To: gentoo-commits
commit:     3496df638fca284c97927d42ed27a76763b60f36
Author:     Matt Whitlock <gentoo <AT> mattwhitlock <DOT> name>
AuthorDate: Sun Aug  3 13:24:04 2025 +0000
Commit:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
CommitDate: Wed Aug 20 22:26:47 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=3496df63
multilib.eclass: respect SYSROOT when overriding PKG_CONFIG_* vars
In multilib.eclass, multilib_toolchain_setup() overrides the environment
variables PKG_CONFIG_LIBDIR, PKG_CONFIG_PATH,
PKG_CONFIG_SYSTEM_INCLUDE_PATH, and PKG_CONFIG_SYSTEM_LIBRARY_PATH so
that the .pc files for the correct ABI will be found and used.
As a reminder, pkgconfig is normally called upon to find packages that
have been installed into the *host* system — i.e., packages listed in
DEPEND. The "Ebuild writing: Variables" page[1] describes the SYSROOT
variable as "The absolute path to the root directory containing build
dependencies satisfied by DEPEND" and ESYSROOT as "The same as either
EROOT, BROOT or SYSROOT depending on the value of SYSROOT. Commonly used
to reference the location of headers and libraries at build time."
In order to support the use case of setting SYSROOT to a path other than
"/" while building packages for ABIs other than the default ABI, change
multilib.eclass so that it prefixes the PKG_CONFIG_* vars with
${ESYSROOT} rather than ${EPREFIX}.
For Gentoo users who do not set SYSROOT, this change will have no
bearing.
This change could conceivably affect crossdev users, but I think
typically crossdev sysroots do not support multilib anyway, so this
change wouldn't affect them either.
[1] https://devmanual.gentoo.org/ebuild-writing/variables/
Closes: https://bugs.gentoo.org/945108
Signed-off-by: Matt Whitlock <gentoo <AT> mattwhitlock.name>
Part-of: https://github.com/gentoo/gentoo/pull/43088
Closes: https://github.com/gentoo/gentoo/pull/43088
Signed-off-by: James Le Cuirot <chewi <AT> gentoo.org>
 eclass/multilib.eclass | 10 +++++-----
 1 file changed, 5 insertions(+), 5 deletions(-)
diff --git a/eclass/multilib.eclass b/eclass/multilib.eclass
index f19ad20af8fd..c28fee7aa1ef 100644
--- a/eclass/multilib.eclass
+++ b/eclass/multilib.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2024 Gentoo Authors
+# Copyright 1999-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: multilib.eclass
@@ -552,10 +552,10 @@ multilib_toolchain_setup() {
 		export STRIP="$(tc-getSTRIP)" # Avoid 'strip', use '${CHOST}-strip'
 
 		export CHOST=$(get_abi_CHOST $1)
-		export PKG_CONFIG_LIBDIR=${EPREFIX}/usr/$(get_libdir)/pkgconfig
-		export PKG_CONFIG_PATH=${EPREFIX}/usr/share/pkgconfig
-		export PKG_CONFIG_SYSTEM_INCLUDE_PATH=${EPREFIX}/usr/include
-		export PKG_CONFIG_SYSTEM_LIBRARY_PATH=${EPREFIX}/$(get_libdir):${EPREFIX}/usr/$(get_libdir)
+		export PKG_CONFIG_LIBDIR=${ESYSROOT}/usr/$(get_libdir)/pkgconfig
+		export PKG_CONFIG_PATH=${ESYSROOT}/usr/share/pkgconfig
+		export PKG_CONFIG_SYSTEM_INCLUDE_PATH=${ESYSROOT}/usr/include
+		export PKG_CONFIG_SYSTEM_LIBRARY_PATH=${ESYSROOT}/$(get_libdir):${ESYSROOT}/usr/$(get_libdir)
 	fi
 }
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-08-21  8:18 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-08-21  8:18 UTC (permalink / raw
  To: gentoo-commits
commit:     37e2dd0be7f804e9eed9ebb3edc7aab192e13afc
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Thu Aug 21 08:10:58 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Thu Aug 21 08:10:58 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=37e2dd0b
llvm.org.eclass: Add 22.0.0_pre20250820 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index 37111988e331..2eb0e65331c0 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -72,6 +72,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 			_LLVM_SOURCE_TYPE=snapshot
 
 			case ${PV} in
+				22.0.0_pre20250820)
+					EGIT_COMMIT=d76bb2bb894a4641ed62447327b40a347a6ae883
+					;;
 				22.0.0_pre20250815)
 					EGIT_COMMIT=1c7720ef78dc5eb9196d6c178afe03b60f201b78
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-08-21  8:22 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-08-21  8:22 UTC (permalink / raw
  To: gentoo-commits
commit:     a802d52dbdbbff04040a420ff6e8cc0bc39385c6
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Thu Aug 21 08:20:29 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Thu Aug 21 08:20:29 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=a802d52d
llvm.org.eclass: Remove old snapshots
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 9 ---------
 1 file changed, 9 deletions(-)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index 2eb0e65331c0..cc55b87bec23 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -78,15 +78,6 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 				22.0.0_pre20250815)
 					EGIT_COMMIT=1c7720ef78dc5eb9196d6c178afe03b60f201b78
 					;;
-				22.0.0_pre20250809)
-					EGIT_COMMIT=92164faf17d553359418b9f49c1a41d680d0de49
-					;;
-				22.0.0_pre20250802)
-					EGIT_COMMIT=b075dadbd3e0e928bdeddb3d36af64e8a383e305
-					;;
-				22.0.0_pre20250726)
-					EGIT_COMMIT=190fcc28af585cb06480b026afd14ed87b18adb8
-					;;
 				*)
 					die "Unknown snapshot: ${PV}"
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-08-22  5:31 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-08-22  5:31 UTC (permalink / raw
  To: gentoo-commits
commit:     dbf172b8effc65a7bb133af829d1478bf6fc4736
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Aug 22 05:20:40 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Aug 22 05:20:53 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=dbf172b8
toolchain.eclass: simplify some version strings for pre-release comparisons
No need to have these be so verbose now.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 18 +++++++++---------
 1 file changed, 9 insertions(+), 9 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index efa78f613670..bb5d6665116d 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -307,7 +307,7 @@ if [[ ${PN} != kgcc64 && ${PN} != gcc-* ]] ; then
 
 	# Stop forcing openmp on by default in the eclass. Gradually phase it out.
 	# See bug #890999.
-	if tc_version_is_at_least 13.0.0_pre20221218 ; then
+	if tc_version_is_at_least 13.1 ; then
 		IUSE+=" openmp"
 	else
 		IUSE+=" +openmp"
@@ -333,14 +333,14 @@ if [[ ${PN} != kgcc64 && ${PN} != gcc-* ]] ; then
 	tc_version_is_at_least 12 && IUSE+=" ieee-long-double"
 	tc_version_is_at_least 12.2.1_p20221203 ${PV} && IUSE+=" default-znow"
 	tc_version_is_at_least 12.2.1_p20221203 ${PV} && IUSE+=" default-stack-clash-protection"
-	tc_version_is_at_least 13.0.0_pre20221218 ${PV} && IUSE+=" modula2"
+	tc_version_is_at_least 13.1 ${PV} && IUSE+=" modula2"
 	# See https://gcc.gnu.org/pipermail/gcc-patches/2023-April/615944.html
 	# and https://rust-gcc.github.io/2023/04/24/gccrs-and-gcc13-release.html for why
 	# it was disabled in 13.
-	tc_version_is_at_least 14.0.0_pre20230423 ${PV} && IUSE+=" rust" TC_FEATURES+=( rust )
+	tc_version_is_at_least 14.1 ${PV} && IUSE+=" rust" TC_FEATURES+=( rust )
 	tc_version_is_at_least 13.3.1_p20250522 ${PV} && IUSE+=" time64"
-	tc_version_is_at_least 15.0.0_pre20241124 ${PV} && IUSE+=" libgdiagnostics"
-	tc_version_is_at_least 15.0.1_pre20250316 ${PV} && IUSE+=" cobol"
+	tc_version_is_at_least 15.1 ${PV} && IUSE+=" libgdiagnostics"
+	tc_version_is_at_least 15.1 ${PV} && IUSE+=" cobol"
 fi
 
 if tc_version_is_at_least 10; then
@@ -450,7 +450,7 @@ if tc_has_feature d && tc_version_is_at_least 12.0 ; then
 	BDEPEND+=" d? ( || ( sys-devel/gcc:${SLOT}[d(-)] <sys-devel/gcc-${SLOT}[d(-)] <sys-devel/gcc-12[d(-)] ) )"
 fi
 
-if tc_has_feature rust && tc_version_is_at_least 14.0.0_pre20230421 ; then
+if tc_has_feature rust && tc_version_is_at_least 14.1 ; then
 	# This was added upstream in r14-9968-g3e1e73fc995844 as a temporary measure.
 	# See https://inbox.sourceware.org/gcc/34fec7ea-8762-4cac-a1c8-ff54e20e31ed@embecosm.com/
 	BDEPEND+=" rust? ( ${RUST_DEPEND} )"
@@ -1825,12 +1825,12 @@ toolchain_src_configure() {
 	if in_iuse pie ; then
 		confgcc+=( $(use_enable pie default-pie) )
 
-		if tc_version_is_at_least 14.0.0_pre20230612 ${PV} ; then
+		if tc_version_is_at_least 14.1 ${PV} ; then
 			confgcc+=( --enable-host-pie )
 		fi
 	fi
 
-	if in_iuse default-znow && tc_version_is_at_least 14.0.0_pre20230619 ${PV}; then
+	if in_iuse default-znow && tc_version_is_at_least 14.1 ${PV}; then
 		# See https://gcc.gnu.org/git/?p=gcc.git;a=commit;h=33ebb0dff9bb022f1e0709e0e73faabfc3df7931.
 		# TODO: Add to LDFLAGS_FOR_TARGET?
 		confgcc+=(
@@ -1975,7 +1975,7 @@ toolchain_src_configure() {
 			confgcc_jit+=( $(use_with zstd) )
 		fi
 
-		if tc_version_is_at_least 15.0.0_pre20241124 ${PV} ; then
+		if tc_version_is_at_least 15.1 ${PV} ; then
 			confgcc_jit+=( $(use_enable libgdiagnostics) )
 		fi
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-08-22  5:36 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-08-22  5:36 UTC (permalink / raw
  To: gentoo-commits
commit:     b5a8c093e958bfa141a5fa7c140a068fca7e470a
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Aug 22 05:36:08 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Aug 22 05:36:08 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=b5a8c093
toolchain.eclass: pass --enable-host-pie/--enable-host-bind-now for 13 now too
Followup to 168e41a3d471d02b82e8647e7ecd24ff12e00b7f.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index bb5d6665116d..b54f78320f02 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1825,12 +1825,12 @@ toolchain_src_configure() {
 	if in_iuse pie ; then
 		confgcc+=( $(use_enable pie default-pie) )
 
-		if tc_version_is_at_least 14.1 ${PV} ; then
+		if tc_version_is_at_least 14.1 ${PV} || tc_version_is_at_least 13.4.1_p20250814 ${PV} ; then
 			confgcc+=( --enable-host-pie )
 		fi
 	fi
 
-	if in_iuse default-znow && tc_version_is_at_least 14.1 ${PV}; then
+	if in_iuse default-znow && { tc_version_is_at_least 14.1 ${PV} || tc_version_is_at_least 13.4.1_p20250814 ${PV} ; } ; then
 		# See https://gcc.gnu.org/git/?p=gcc.git;a=commit;h=33ebb0dff9bb022f1e0709e0e73faabfc3df7931.
 		# TODO: Add to LDFLAGS_FOR_TARGET?
 		confgcc+=(
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-08-26 22:10 James Le Cuirot
  0 siblings, 0 replies; 6663+ messages in thread
From: James Le Cuirot @ 2025-08-26 22:10 UTC (permalink / raw
  To: gentoo-commits
commit:     2572fa3e3c83f81355d0365c7d4d62a0c0577221
Author:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
AuthorDate: Sat Aug 23 20:05:45 2025 +0000
Commit:     James Le Cuirot <chewi <AT> gentoo <DOT> org>
CommitDate: Tue Aug 26 22:03:11 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=2572fa3e
chromium-2.eclass: Handle non-standard _ suffixes in locale .pak files
These were recently added by Chromium for gender-based translations. _
is not a valid language tag character, so we strip this suffix when
checking the USE flag, thereby grouping such files with their
non-suffixed counterparts.
Signed-off-by: James Le Cuirot <chewi <AT> gentoo.org>
 eclass/chromium-2.eclass | 8 ++++++--
 1 file changed, 6 insertions(+), 2 deletions(-)
diff --git a/eclass/chromium-2.eclass b/eclass/chromium-2.eclass
index e8f471e2178f..f1f5b3a7b35a 100644
--- a/eclass/chromium-2.eclass
+++ b/eclass/chromium-2.eclass
@@ -78,7 +78,7 @@ fi
 # not selected via the L10N variable.
 # Also performs QA checks to ensure CHROMIUM_LANGS has been set correctly.
 chromium_remove_language_paks() {
-	local lang pak
+	local lang pak suffixed
 
 	# Look for missing pak files.
 	for lang in ${CHROMIUM_LANGS}; do
@@ -93,8 +93,12 @@ chromium_remove_language_paks() {
 
 	# Look for extra pak files.
 	# Remove pak files that the user does not want.
+	# Chromium includes pak files with non-standard _ suffixes. _ is not a valid
+	# language tag character, so we strip this suffix when checking the USE
+	# flag, thereby grouping such files with their non-suffixed counterparts.
 	for pak in *.pak; do
-		lang=${pak%.pak}
+		suffixed=${pak%.pak}
+		lang=${suffixed%%_*}
 
 		if [[ ${lang} == en-US ]]; then
 			continue
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-08-30 13:07 Ionen Wolkens
  0 siblings, 0 replies; 6663+ messages in thread
From: Ionen Wolkens @ 2025-08-30 13:07 UTC (permalink / raw
  To: gentoo-commits
commit:     1c4f0ec775955c5fa1563d49bfa8f3757a430754
Author:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
AuthorDate: Sat Aug 30 13:02:00 2025 +0000
Commit:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
CommitDate: Sat Aug 30 13:05:25 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=1c4f0ec7
wine.eclass: keep -std=* for cross flags
Closes: https://bugs.gentoo.org/962175
Signed-off-by: Ionen Wolkens <ionen <AT> gentoo.org>
 eclass/wine.eclass | 3 ++-
 1 file changed, 2 insertions(+), 1 deletion(-)
diff --git a/eclass/wine.eclass b/eclass/wine.eclass
index a92f01f9e37c..9db7c18a4e26 100644
--- a/eclass/wine.eclass
+++ b/eclass/wine.eclass
@@ -469,8 +469,9 @@ _wine_flags() {
 				# are on their own just like with USE=custom-cflags.
 				local flag flags=${CFLAGS} CFLAGS=-O2
 				# not get-flag() given it returns only the first occurence
+				# TODO: can drop |-std=* when <wine-10 is gone
 				for flag in ${flags}; do
-					[[ ${flag} == @(-g*|-O[0-1g]) ]] && CFLAGS+=" ${flag}"
+					[[ ${flag} == @(-g*|-O[0-1g]|-std=*) ]] && CFLAGS+=" ${flag}"
 				done
 			else
 				# many hardening options are unlikely to work right
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-08-31 13:28 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-08-31 13:28 UTC (permalink / raw
  To: gentoo-commits
commit:     1444b436a57b1ba5eadb3c9633594740060d6a4b
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sun Aug 31 13:23:01 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sun Aug 31 13:23:01 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=1444b436
llvm.org.eclass: Remove old snapshot support
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 ---
 1 file changed, 3 deletions(-)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index 728d07d310a3..2fd7ee92883b 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -75,9 +75,6 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 				22.0.0_pre20250820)
 					EGIT_COMMIT=d76bb2bb894a4641ed62447327b40a347a6ae883
 					;;
-				22.0.0_pre20250815)
-					EGIT_COMMIT=1c7720ef78dc5eb9196d6c178afe03b60f201b78
-					;;
 				*)
 					die "Unknown snapshot: ${PV}"
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-08-31 13:28 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-08-31 13:28 UTC (permalink / raw
  To: gentoo-commits
commit:     2c492728688a78a1a6943aec6f66469e04322d10
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sun Aug 31 13:23:37 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sun Aug 31 13:23:37 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=2c492728
llvm.org.eclass: Add 22.0.0_pre20250831 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index 2fd7ee92883b..71dff62b180d 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -75,6 +75,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 				22.0.0_pre20250820)
 					EGIT_COMMIT=d76bb2bb894a4641ed62447327b40a347a6ae883
 					;;
+				22.0.0_pre20250831)
+					EGIT_COMMIT=1d8fdda7b0a9f47c443600bca6af2bc141e4abf7
+					;;
 				*)
 					die "Unknown snapshot: ${PV}"
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-09-01 10:31 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-09-01 10:31 UTC (permalink / raw
  To: gentoo-commits
commit:     4e4f14bd8a75bde610272a92067f1c4d2cedd251
Author:     Eric Joldasov <bratishkaerik <AT> landless-city <DOT> net>
AuthorDate: Sun Aug 31 15:29:21 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Sep  1 10:31:15 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=4e4f14bd
zig-utils.eclass: add 0.15 to the list of supported versions
Signed-off-by: Eric Joldasov <bratishkaerik <AT> landless-city.net>
Part-of: https://github.com/gentoo/gentoo/pull/43623
Closes: https://github.com/gentoo/gentoo/pull/43623
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/zig-utils.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/zig-utils.eclass b/eclass/zig-utils.eclass
index b1a7e0801667..41d6fd2f3973 100644
--- a/eclass/zig-utils.eclass
+++ b/eclass/zig-utils.eclass
@@ -491,8 +491,11 @@ zig-utils_find_installation() {
 
 	einfo "Searching Zig ${ZIG_SLOT}..."
 
+	# Upstream skipped releasing 0.15.0
 	local zig_supported_versions=(
 		"9999"
+		"0.15.2"
+		"0.15.1"
 		"0.14.1"
 		"0.14.0"
 		"0.13.1"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-09-02 20:05 Eli Schwartz
  0 siblings, 0 replies; 6663+ messages in thread
From: Eli Schwartz @ 2025-09-02 20:05 UTC (permalink / raw
  To: gentoo-commits
commit:     e23d5c3ac3f48e28784350597cc888e4cea6bf6a
Author:     Eli Schwartz <eschwartz <AT> gentoo <DOT> org>
AuthorDate: Tue Sep  2 19:25:54 2025 +0000
Commit:     Eli Schwartz <eschwartz <AT> gentoo <DOT> org>
CommitDate: Tue Sep  2 20:05:19 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=e23d5c3a
toolchain.eclass: ada/d: bdepend on ${PN}:${SLOT} only as a last resort
In general, there are *preferred* versus *workable* bootstrap compilers,
and it is *preferred* to build ${lang} with an already built copy of
that compiler, e.g. to get bugfixes and so on. So, for iteration order
when setting up the compilation environment, we prefer our own SLOT, if
multiple bootstrap compilers are available after `src_*` phases start
running.
As a separate matter, the dependency merge graph must pull in at least
one *workable* compiler, and it would be nice if it is a *preferred*
one. Portage solves for dependencies favoring leftmost if it is
necessary to merge an additional dependency. So, ordering from
most-preferred to least-preferred is plausibly reasonable.
Problem: given an installed *workable* but least-preferred compiler,
triggering autounmask of USE=ada causes portage to ignore a *workable*
compiler if the leftmost dependency is already in the merge graph. It
then reports a cycle, where the current package to build depends on
itself:
```
 * Error: circular dependencies:
(sys-devel/gcc-14.3.0:14/14::gentoo, ebuild scheduled for merge) depends on
 (sys-devel/gcc-14.3.0:14/14::gentoo, ebuild scheduled for merge) (buildtime)
```
It turns out, the order in the any-of group matters. If:
- item 1 is ${PN}:${SLOT}
- item 2 is <${PN}-${SLOT}
- item 3 is installed (ada-bootstrap)
The merge graph wants to build item 1, item 2 would build a ton of
versions and eventually need item 3, item 3 simply works without fuss.
But item 1 *cannot* be uninstalled, yet still get merged in this
transaction to satisfy the deps. And if it is already installed, we
don't need leftmost-associativity to force the preferred compiler to be
merged for building excellent machine code.
Conversely, if item 1 is moved to the end, portage... doesn't try to
autounmask item 2 (now item 1), even if item 3 (ada-bootstrap) is *not*
installed. Although without autounmasking, if "sys-devel/gcc ada" is in
package.use, it does build a large chain of gcc[ada]'s, since it can and
is leftmost.
But for autounmask, instead, it installs item 3 (ada-bootstrap) if
necessary, since it can do so without further autounmask. The incorrect
cycle is broken.
Make this change, because it only affects cycle-breaking and doesn't
affect iteration order in src_configure.
Bug: https://bugs.gentoo.org/962273
Acked-by: Sam James <sam <AT> gentoo.org>
Signed-off-by: Eli Schwartz <eschwartz <AT> gentoo.org>
 eclass/toolchain.eclass | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index b54f78320f02..9e79d3de9f28 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -422,9 +422,9 @@ if [[ ${PN} != gnat-gpl ]] && tc_has_feature ada ; then
 		BDEPEND+="
 			ada? (
 				|| (
-					sys-devel/gcc:${SLOT}[ada]
 					<sys-devel/gcc-${SLOT}[ada]
 					<dev-lang/ada-bootstrap-$((${SLOT} + 1))
+					sys-devel/gcc:${SLOT}[ada]
 				)
 			)
 		"
@@ -432,9 +432,9 @@ if [[ ${PN} != gnat-gpl ]] && tc_has_feature ada ; then
 		BDEPEND+="
 			ada? (
 				|| (
-					sys-devel/gcc:${SLOT}[ada]
 					<sys-devel/gcc-${SLOT}[ada]
 					<dev-lang/ada-bootstrap-${SLOT}
+					sys-devel/gcc:${SLOT}[ada]
 				)
 			)
 		"
@@ -447,7 +447,7 @@ if tc_has_feature d && tc_version_is_at_least 12.0 ; then
 	# D in 12+ is self-hosting and needs D to bootstrap.
 	# TODO: package some binary we can use, like for Ada
 	# bug #840182
-	BDEPEND+=" d? ( || ( sys-devel/gcc:${SLOT}[d(-)] <sys-devel/gcc-${SLOT}[d(-)] <sys-devel/gcc-12[d(-)] ) )"
+	BDEPEND+=" d? ( || ( <sys-devel/gcc-${SLOT}[d(-)] <sys-devel/gcc-12[d(-)] sys-devel/gcc:${SLOT}[d(-)] ) )"
 fi
 
 if tc_has_feature rust && tc_version_is_at_least 14.1 ; then
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-09-03  1:28 Ionen Wolkens
  0 siblings, 0 replies; 6663+ messages in thread
From: Ionen Wolkens @ 2025-09-03  1:28 UTC (permalink / raw
  To: gentoo-commits
commit:     d09547ebed8a69cbbda2494c324c46beed064e2e
Author:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
AuthorDate: Wed Sep  3 01:22:39 2025 +0000
Commit:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
CommitDate: Wed Sep  3 01:23:40 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=d09547eb
wine.eclass: fix spacing
Signed-off-by: Ionen Wolkens <ionen <AT> gentoo.org>
 eclass/wine.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/wine.eclass b/eclass/wine.eclass
index 9db7c18a4e26..ae009e3635ad 100644
--- a/eclass/wine.eclass
+++ b/eclass/wine.eclass
@@ -356,7 +356,7 @@ wine_src_install() {
 	fi
 
 	use arm64 && use wow64 &&
-	    dosym -r /usr/lib/fex-xtajit/libwow64fex.dll \
+		dosym -r /usr/lib/fex-xtajit/libwow64fex.dll \
 				${WINE_PREFIX}/wine/aarch64-windows/xtajit.dll
 
 	# delete unwanted files if requested, not done directly in ebuilds
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-09-03  1:32 Ionen Wolkens
  0 siblings, 0 replies; 6663+ messages in thread
From: Ionen Wolkens @ 2025-09-03  1:32 UTC (permalink / raw
  To: gentoo-commits
commit:     2c3256ac8d37dfc90c680d59dd864cd71873c5c3
Author:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
AuthorDate: Wed Sep  3 01:31:39 2025 +0000
Commit:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
CommitDate: Wed Sep  3 01:32:07 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=2c3256ac
wine.eclass: fix spacing further
Missed the line below also had a tab too many.
Signed-off-by: Ionen Wolkens <ionen <AT> gentoo.org>
 eclass/wine.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/wine.eclass b/eclass/wine.eclass
index ae009e3635ad..1336b8642f23 100644
--- a/eclass/wine.eclass
+++ b/eclass/wine.eclass
@@ -357,7 +357,7 @@ wine_src_install() {
 
 	use arm64 && use wow64 &&
 		dosym -r /usr/lib/fex-xtajit/libwow64fex.dll \
-				${WINE_PREFIX}/wine/aarch64-windows/xtajit.dll
+			${WINE_PREFIX}/wine/aarch64-windows/xtajit.dll
 
 	# delete unwanted files if requested, not done directly in ebuilds
 	# given must be done after install and before wrappers
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-09-03 16:48 Jason Zaman
  0 siblings, 0 replies; 6663+ messages in thread
From: Jason Zaman @ 2025-09-03 16:48 UTC (permalink / raw
  To: gentoo-commits
commit:     3cfb78659af6d60b94e4576af82944e8c0f16526
Author:     Jason Zaman <perfinion <AT> gentoo <DOT> org>
AuthorDate: Wed Sep  3 16:12:10 2025 +0000
Commit:     Jason Zaman <perfinion <AT> gentoo <DOT> org>
CommitDate: Wed Sep  3 16:47:53 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=3cfb7865
selinux-policy-2.eclass: Drop support for <policycoreutils-2.5
Older policycoreutils has been removed from the tree for many many years
now. It required a separate argument for base.pp but is now just making
things more complicated than needed. This way the command printed to
users is much simpler.
Signed-off-by: Jason Zaman <perfinion <AT> gentoo.org>
 eclass/selinux-policy-2.eclass | 18 +++++++-----------
 1 file changed, 7 insertions(+), 11 deletions(-)
diff --git a/eclass/selinux-policy-2.eclass b/eclass/selinux-policy-2.eclass
index e8b7ef863ad4..1c5106ead129 100644
--- a/eclass/selinux-policy-2.eclass
+++ b/eclass/selinux-policy-2.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2024 Gentoo Authors
+# Copyright 1999-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # Eclass for installing SELinux policy, and optionally
@@ -109,10 +109,10 @@ PATCHBUNDLE="${DISTDIR}/patchbundle-selinux-base-policy-${BASEPOL}.tar.bz2"
 # Modules should always depend on at least the first release of the
 # selinux-base-policy for which they are generated.
 if [[ -n ${BASEPOL} ]]; then
-	RDEPEND=">=sys-apps/policycoreutils-2.0.82
+	RDEPEND=">=sys-apps/policycoreutils-2.5
 		>=sec-policy/selinux-base-policy-${BASEPOL}"
 else
-	RDEPEND=">=sys-apps/policycoreutils-2.0.82
+	RDEPEND=">=sys-apps/policycoreutils-2.5
 		>=sec-policy/selinux-base-policy-${PV}"
 fi
 
@@ -279,15 +279,11 @@ selinux-policy-2_pkg_postinst() {
 		semodule ${root_opts} -s ${i} -i ${COMMAND}
 		if [[ $? -ne 0 ]]; then
 			ewarn "SELinux module load failed. Trying full reload...";
-			local COMMAND_base="-i base.pp"
-			if has_version "<sys-apps/policycoreutils-2.5"; then
-				COMMAND_base="-b base.pp"
-			fi
 
 			if [[ "${i}" == "targeted" ]]; then
-				semodule ${root_opts} -s ${i} ${COMMAND_base} -i $(ls *.pp | grep -v base.pp);
+				semodule ${root_opts} -s ${i} -i *.pp
 			else
-				semodule ${root_opts} -s ${i} ${COMMAND_base} -i $(ls *.pp | grep -v base.pp | grep -v unconfined.pp);
+				semodule ${root_opts} -s ${i} -i $(ls *.pp | grep -v unconfined.pp);
 			fi
 			if [[ $? -ne 0 ]]; then
 				ewarn "Failed to reload SELinux policies."
@@ -302,9 +298,9 @@ selinux-policy-2_pkg_postinst() {
 				ewarn "command finished successfully."
 				ewarn ""
 				ewarn "To reload, run the following command from within /usr/share/selinux/${i}:"
-				ewarn "  semodule ${COMMAND_base} -i \$(ls *.pp | grep -v base.pp)"
+				ewarn "  semodule -i *.pp"
 				ewarn "or"
-				ewarn "  semodule ${COMMAND_base} -i \$(ls *.pp | grep -v base.pp | grep -v unconfined.pp)"
+				ewarn "  semodule -i \$(ls *.pp | grep -v unconfined.pp)"
 				ewarn "depending on if you need the unconfined domain loaded as well or not."
 			else
 				einfo "SELinux modules reloaded successfully."
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-09-03 16:48 Jason Zaman
  0 siblings, 0 replies; 6663+ messages in thread
From: Jason Zaman @ 2025-09-03 16:48 UTC (permalink / raw
  To: gentoo-commits
commit:     e129a067e6e23eb794af2716fa8ab0f04c651c8e
Author:     Jason Zaman <perfinion <AT> gentoo <DOT> org>
AuthorDate: Wed Sep  3 16:46:59 2025 +0000
Commit:     Jason Zaman <perfinion <AT> gentoo <DOT> org>
CommitDate: Wed Sep  3 16:47:54 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=e129a067
selinux-policy-2.eclass: Document PATCHBUNDLE var
Signed-off-by: Jason Zaman <perfinion <AT> gentoo.org>
 eclass/selinux-policy-2.eclass | 5 +++++
 1 file changed, 5 insertions(+)
diff --git a/eclass/selinux-policy-2.eclass b/eclass/selinux-policy-2.eclass
index 1c5106ead129..5ec7ff99ed74 100644
--- a/eclass/selinux-policy-2.eclass
+++ b/eclass/selinux-policy-2.eclass
@@ -104,6 +104,11 @@ fi
 LICENSE="GPL-2"
 SLOT="0"
 S="${WORKDIR}/"
+
+# @ECLASS_VARIABLE: PATCHBUNDLE
+# @INTERNAL
+# @DESCRIPTION:
+# Path to Gentoo Hardened Refpol patch to apply on top of upstream
 PATCHBUNDLE="${DISTDIR}/patchbundle-selinux-base-policy-${BASEPOL}.tar.bz2"
 
 # Modules should always depend on at least the first release of the
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-09-06  7:01 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-09-06  7:01 UTC (permalink / raw
  To: gentoo-commits
commit:     919f4aabde1fea3150a41ce1407fd30bfbf2692a
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sun Aug 24 17:36:10 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat Sep  6 07:00:49 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=919f4aab
pypi.eclass: Fix eclassdoc typo; <package> → <project>
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
Part-of: https://github.com/gentoo/gentoo/pull/43549
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/pypi.eclass | 8 ++++----
 1 file changed, 4 insertions(+), 4 deletions(-)
diff --git a/eclass/pypi.eclass b/eclass/pypi.eclass
index 47d40449d13a..c460d4618ad0 100644
--- a/eclass/pypi.eclass
+++ b/eclass/pypi.eclass
@@ -1,4 +1,4 @@
-# Copyright 2023-2024 Gentoo Authors
+# Copyright 2023-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: pypi.eclass
@@ -161,7 +161,7 @@ _pypi_sdist_url() {
 # generated using build systems that did not follow PEP 625
 # (i.e. the sdist name contains uppercase letters, hyphens or dots).
 #
-# If <package> is unspecified, it defaults to ${PYPI_PN}.  The package
+# If <project> is unspecified, it defaults to ${PYPI_PN}.  The package
 # name is normalized according to the specification unless
 # `--no-normalize` is passed.
 #
@@ -183,7 +183,7 @@ pypi_sdist_url() {
 # @DESCRIPTION:
 # Output the wheel filename for the specified project/version tuple.
 #
-# If <package> is unspecified, it defaults to ${PYPI_PN}.  The package
+# If <project> is unspecified, it defaults to ${PYPI_PN}.  The package
 # name is normalized according to the wheel specification.
 #
 # If <version> is unspecified, it defaults to ${PV} translated
@@ -221,7 +221,7 @@ pypi_wheel_name() {
 # the wheel contents will be unpacked straight into ${WORKDIR}.
 # You need to add a BDEPEND on app-arch/unzip.
 #
-# If <package> is unspecified, it defaults to ${PYPI_PN}.
+# If <project> is unspecified, it defaults to ${PYPI_PN}.
 #
 # If <version> is unspecified, it defaults to ${PV} translated
 # via pypi_translate_version.  If it is specified, then it is used
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-09-06  7:01 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-09-06  7:01 UTC (permalink / raw
  To: gentoo-commits
commit:     07446fc250c157ce77518bcf61f30c405f9433ef
Author:     Eli Schwartz <eschwartz <AT> gentoo <DOT> org>
AuthorDate: Thu Sep  4 18:24:48 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat Sep  6 07:00:53 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=07446fc2
python-utils-r1.eclass: replace 2to3 with "unsupported" wrapper for 3.13+
It has been removed upstream. Due to the use of a symlink for wrapping
it (as opposed to a shell script like python / python-config) this meant
searching PATH didn't find the broken symlink, and instead found
/usr/bin/2to3-3.12 with a 3.13 impl.
Check the version of EPYTHON and add it to nonsupp wrappers instead of
making a symlink.
Reported-by: Paul Zander <negril.nx+gentoo <AT> gmail.com>
Signed-off-by: Eli Schwartz <eschwartz <AT> gentoo.org>
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
Part-of: https://github.com/gentoo/gentoo/pull/43549
Closes: https://github.com/gentoo/gentoo/pull/43549
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/python-utils-r1.eclass | 8 ++++++--
 1 file changed, 6 insertions(+), 2 deletions(-)
diff --git a/eclass/python-utils-r1.eclass b/eclass/python-utils-r1.eclass
index 13ed87501200..f454a066a352 100644
--- a/eclass/python-utils-r1.eclass
+++ b/eclass/python-utils-r1.eclass
@@ -929,8 +929,12 @@ _python_wrapper_setup() {
 			chmod +x "${workdir}/bin/python-config" \
 				"${workdir}/bin/python3-config" || die
 
-			# Python 2.6+.
-			ln -s "${PYTHON/python/2to3-}" "${workdir}"/bin/2to3 || die
+			# Python 2.6+. Deprecated in 3.11, removed in 3.13.
+			if ver_test ${EPYTHON#python} -lt 3.13; then
+				ln -s "${PYTHON/python/2to3-}" "${workdir}"/bin/2to3 || die
+			else
+				nonsupp+=( 2to3 )
+			fi
 
 			# Python 2.7+.
 			ln -s "${EPREFIX}"/usr/$(get_libdir)/pkgconfig/${EPYTHON/n/n-}.pc \
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-09-06  7:01 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-09-06  7:01 UTC (permalink / raw
  To: gentoo-commits
commit:     cd8b6bacbec940e1b503c01b54a0d83e69735bc6
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sun Aug 24 17:38:55 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat Sep  6 07:00:50 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=cd8b6bac
pypi.eclass: Update the @DESCRIPTION
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
Part-of: https://github.com/gentoo/gentoo/pull/43549
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/pypi.eclass | 10 ++++++----
 1 file changed, 6 insertions(+), 4 deletions(-)
diff --git a/eclass/pypi.eclass b/eclass/pypi.eclass
index c460d4618ad0..75d15917a766 100644
--- a/eclass/pypi.eclass
+++ b/eclass/pypi.eclass
@@ -11,16 +11,18 @@
 # @DESCRIPTION:
 # The pypi.eclass can be used to easily obtain URLs for artifacts
 # uploaded to PyPI.org.  When inherited, the eclass defaults SRC_URI
-# and S to fetch .tar.gz sdist.  The project filename is normalized
-# by default (unless PYPI_NO_NORMALIZE is set prior to inheriting
-# the eclass), and the version is translated using
+# and S to fetch .tar.gz sdist.  The eclass defaults to using ${PN}
+# as PyPI project name; PYPI_PN can be set prior to inheriting it
+# to override that.  The source distribution filename is assumed
+# to be normalized by default; PYPI_NO_NORMALIZE can be set prior
+# to inherit to override that.  The version is translated using
 # pypi_translate_version.
 #
 # If necessary, SRC_URI and S can be overridden by the ebuild.  Two
 # helper functions, pypi_sdist_url and pypi_wheel_url are provided
 # to generate URLs to artifacts of specified type, with customizable
 # URL components.  Additionally, pypi_wheel_name can be used to generate
-# wheel filename.
+# the wheel filename.
 #
 # pypi_normalize_name can be used to normalize an arbitrary project name
 # according to sdist/wheel normalization rules.  pypi_translate_version
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-09-06 15:13 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-09-06 15:13 UTC (permalink / raw
  To: gentoo-commits
commit:     e89cf625f2ab67664083dfbeb31bbc8c7302631c
Author:     Sv. Lockal <lockalsash <AT> gmail <DOT> com>
AuthorDate: Sun Aug 10 18:36:48 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Sep  6 15:12:49 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=e89cf625
rocm.eclass: update targets for rocm >= 6.4.3 libraries
According to "System requirements" webpage, gfx1101/gfx1200/gfx1201 are now supported.
From the source code few libraries have gfx1103/gfx1150/gfx1151 support, which is not officially announced.
Some released components fail to compile on gfx1150/gfx1151 - for these components live ebuilds should be introduced.
Bug: https://bugs.gentoo.org/949494
Signed-off-by: Sv. Lockal <lockalsash <AT> gmail.com>
Part-of: https://github.com/gentoo/gentoo/pull/43406
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/rocm.eclass | 12 +++++++++++-
 1 file changed, 11 insertions(+), 1 deletion(-)
diff --git a/eclass/rocm.eclass b/eclass/rocm.eclass
index a7601bf43f2d..3cdcd44c0ae2 100644
--- a/eclass/rocm.eclass
+++ b/eclass/rocm.eclass
@@ -184,7 +184,7 @@ _rocm_set_globals() {
 				gfx906 gfx908 gfx90a gfx942 gfx1030 gfx1100
 			)
 			;;
-		6.*|9999)
+		6.4.[0-2])
 			unofficial_amdgpu_targets=(
 				gfx803 gfx900 gfx906 gfx940 gfx941
 				gfx1010 gfx1011 gfx1012
@@ -194,6 +194,16 @@ _rocm_set_globals() {
 				gfx908 gfx90a gfx942 gfx1030 gfx1100
 			)
 			;;
+		6.*|9999)
+			unofficial_amdgpu_targets=(
+				gfx803 gfx900 gfx906 gfx940 gfx941
+				gfx1010 gfx1011 gfx1012
+				gfx1031 gfx1102 gfx1103 gfx1150 gfx1151
+			)
+			official_amdgpu_targets=(
+				gfx908 gfx90a gfx942 gfx1030 gfx1100 gfx1101 gfx1200 gfx1201
+			)
+			;;
 		*)
 			die "Unknown ROCm major version! Please update rocm.eclass before bumping to new ebuilds"
 			;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-09-06 20:02 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-09-06 20:02 UTC (permalink / raw
  To: gentoo-commits
commit:     62e01e8436ab74804779a55431e1f023b5a61716
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Sep  6 20:00:56 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Sep  6 20:01:51 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=62e01e84
usr-ldscript.eclass: spell 'GNU Binutils' consistently
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/usr-ldscript.eclass | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/eclass/usr-ldscript.eclass b/eclass/usr-ldscript.eclass
index e52de9e658d4..389714a3aa77 100644
--- a/eclass/usr-ldscript.eclass
+++ b/eclass/usr-ldscript.eclass
@@ -1,4 +1,4 @@
-# Copyright 2019-2023 Gentoo Authors
+# Copyright 2019-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: usr-ldscript.eclass
@@ -131,7 +131,7 @@ gen_usr_ldscript() {
 			if [[ -n ${nowrite} ]] ; then
 				chmod u-w "${ED}/${libdir}/${tlib}" || die
 			fi
-			# Now as we don't use GNU binutils and our linker doesn't
+			# Now as we don't use GNU Binutils and our linker doesn't
 			# understand linker scripts, just create a symlink.
 			pushd "${ED}/usr/${libdir}" > /dev/null
 			ln -snf "../../${libdir}/${tlib}" "${lib}"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-09-06 20:02 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-09-06 20:02 UTC (permalink / raw
  To: gentoo-commits
commit:     438d1f0f312d57db29380154d2c7939063375551
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Sep  6 20:00:30 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Sep  6 20:01:50 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=438d1f0f
apache-2.eclass: spell 'GNU Binutils' consistently
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/apache-2.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/apache-2.eclass b/eclass/apache-2.eclass
index 74965b28f60e..0ff76bd2dcf1 100644
--- a/eclass/apache-2.eclass
+++ b/eclass/apache-2.eclass
@@ -451,7 +451,7 @@ apache-2_src_prepare() {
 	# idea for everyone
 	case ${CHOST} in
 		*-linux-gnu|*-solaris*)
-			# do nothing, these use GNU binutils
+			# do nothing, these use GNU Binutils
 			:
 		;;
 		*-darwin*)
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-09-06 20:43 Ionen Wolkens
  0 siblings, 0 replies; 6663+ messages in thread
From: Ionen Wolkens @ 2025-09-06 20:43 UTC (permalink / raw
  To: gentoo-commits
commit:     4a056f17b0e9e65d74a8008c9eaf32db3759aeb3
Author:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
AuthorDate: Sat Sep  6 20:36:23 2025 +0000
Commit:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
CommitDate: Sat Sep  6 20:43:35 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=4a056f17
linux-mod-r1.eclass: silence spurious warning with _p* kernels
Like noted in the comment, ideally would want to check for the
actual matching version but we'd need to test+sanitize KV_EXTRA
and figure out if it's really a version component as it could be
anything.
_p being used should be a rare event and it shouldn't be a big
deal if the check ignores it.
Skipping ML review given trivial and is just about a warning.
Signed-off-by: Ionen Wolkens <ionen <AT> gentoo.org>
 eclass/linux-mod-r1.eclass | 5 ++++-
 1 file changed, 4 insertions(+), 1 deletion(-)
diff --git a/eclass/linux-mod-r1.eclass b/eclass/linux-mod-r1.eclass
index 91dca82c8f35..3e6bd159819e 100644
--- a/eclass/linux-mod-r1.eclass
+++ b/eclass/linux-mod-r1.eclass
@@ -1224,8 +1224,11 @@ _modules_sanity_kernelversion() {
 		fi
 	fi
 
+	# wrt *, KV_EXTRA can have e.g. -p1 used by dist-kernel's version as
+	# _p1, ideally would check it too but this string can contain about
+	# anything so ignore it rather than try to figure out what it is
 	if use dist-kernel &&
-		! has_version "~virtual/dist-kernel-${KV_MAJOR}.${KV_MINOR}.${KV_PATCH}"
+		! has_version "=virtual/dist-kernel-${KV_MAJOR}.${KV_MINOR}.${KV_PATCH}*"
 	then
 		ewarn
 		ewarn "The kernel modules in ${CATEGORY}/${PN} are being built for"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-09-06 21:32 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-09-06 21:32 UTC (permalink / raw
  To: gentoo-commits
commit:     e9e6d8c367fdf02b14f9cb2a59489833975d1445
Author:     Nicolas PARLANT <nicolas.parlant <AT> parhuet <DOT> fr>
AuthorDate: Fri Mar  7 15:53:35 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Sep  6 21:29:14 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=e9e6d8c3
toolchain.eclass: drop support EAPI 7
should only supports EAPI=8 since rust was introduced in inherit.
Signed-off-by: Nicolas PARLANT <nicolas.parlant <AT> parhuet.fr>
Part-of: https://github.com/gentoo/gentoo/pull/40954
Closes: https://github.com/gentoo/gentoo/pull/40954
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 14 ++++----------
 1 file changed, 4 insertions(+), 10 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 9e79d3de9f28..5d7bf2a67547 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -4,7 +4,7 @@
 # @ECLASS: toolchain.eclass
 # @MAINTAINER:
 # Toolchain Ninjas <toolchain@gentoo.org>
-# @SUPPORTED_EAPIS: 7 8
+# @SUPPORTED_EAPIS: 8
 # @BLURB: Common code for sys-devel/gcc ebuilds
 # @DESCRIPTION:
 # Common code for sys-devel/gcc ebuilds (and occasionally GCC forks, like
@@ -17,7 +17,7 @@ _TOOLCHAIN_ECLASS=1
 RUST_OPTIONAL="1"
 
 case ${EAPI} in
-	7|8) ;;
+	8) ;;
 	*) die "${ECLASS}: EAPI ${EAPI:-0} not supported" ;;
 esac
 
@@ -463,13 +463,8 @@ PDEPEND=">=sys-devel/gcc-config-2.11"
 # @ECLASS_VARIABLE: TOOLCHAIN_PATCH_SUFFIX
 # @DESCRIPTION:
 # Used to override compression used for for patchsets.
-# Default is xz for EAPI 8+ and bz2 for older EAPIs.
-if [[ ${EAPI} == 8 ]] ; then
+# Default is xz for EAPI 8+.
 	: "${TOOLCHAIN_PATCH_SUFFIX:=xz}"
-else
-	# Older EAPIs
-	: "${TOOLCHAIN_PATCH_SUFFIX:=bz2}"
-fi
 
 # @ECLASS_VARIABLE: TOOLCHAIN_SET_S
 # @DESCRIPTION:
@@ -766,11 +761,10 @@ do_gcc_gentoo_patches() {
 				fi
 			fi
 
-			local shopt_save=$(shopt -p nullglob)
+			local -
 			shopt -s nullglob
 			einfo "Applying musl patches ..."
 			eapply "${WORKDIR}"/musl/{,nocross/}*.patch
-			${shopt_save}
 		fi
 
 		#
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-09-07 19:47 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-09-07 19:47 UTC (permalink / raw
  To: gentoo-commits
commit:     b733942032697ad28b29e89b67482d059e153813
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sun Sep  7 19:15:42 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sun Sep  7 19:47:14 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=b7339420
llvm.org.eclass: Add 22.0.0_pre20250907 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index 71dff62b180d..962e290506ed 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -78,6 +78,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 				22.0.0_pre20250831)
 					EGIT_COMMIT=1d8fdda7b0a9f47c443600bca6af2bc141e4abf7
 					;;
+				22.0.0_pre20250907)
+					EGIT_COMMIT=645dd324d1b7d028745c2a4045b69e745df2ae6a
+					;;
 				*)
 					die "Unknown snapshot: ${PV}"
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-09-08 18:15 Arthur Zamarin
  0 siblings, 0 replies; 6663+ messages in thread
From: Arthur Zamarin @ 2025-09-08 18:15 UTC (permalink / raw
  To: gentoo-commits
commit:     8a15b6664b3b87708f5a5fddaf6c785132c8b96b
Author:     Arthur Zamarin <arthurzam <AT> gentoo <DOT> org>
AuthorDate: Mon Sep  8 18:08:37 2025 +0000
Commit:     Arthur Zamarin <arthurzam <AT> gentoo <DOT> org>
CommitDate: Mon Sep  8 18:15:00 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=8a15b666
acct-{group,user}.eclass: destable hppa and sparc
Signed-off-by: Arthur Zamarin <arthurzam <AT> gentoo.org>
 eclass/acct-group.eclass | 4 ++--
 eclass/acct-user.eclass  | 2 +-
 2 files changed, 3 insertions(+), 3 deletions(-)
diff --git a/eclass/acct-group.eclass b/eclass/acct-group.eclass
index ac6dc960ca24..f62d6244b168 100644
--- a/eclass/acct-group.eclass
+++ b/eclass/acct-group.eclass
@@ -1,4 +1,4 @@
-# Copyright 2019-2024 Gentoo Authors
+# Copyright 2019-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: acct-group.eclass
@@ -78,7 +78,7 @@ ACCT_GROUP_NAME=${PN}
 # << Boilerplate ebuild variables >>
 : "${DESCRIPTION:="System group: ${ACCT_GROUP_NAME}"}"
 : "${SLOT:=0}"
-: "${KEYWORDS:=~alpha amd64 arm arm64 hppa ~loong ~m68k ~mips ppc ppc64 ~riscv ~s390 sparc x86 ~amd64-linux ~x86-linux ~arm64-macos ~ppc-macos ~x64-macos ~x64-solaris}"
+: "${KEYWORDS:=~alpha amd64 arm arm64 ~hppa ~loong ~m68k ~mips ppc ppc64 ~riscv ~s390 ~sparc x86 ~amd64-linux ~x86-linux ~arm64-macos ~ppc-macos ~x64-macos ~x64-solaris}"
 S=${WORKDIR}
 
 
diff --git a/eclass/acct-user.eclass b/eclass/acct-user.eclass
index 5e34a7efcfb0..79fc2d1a4cbd 100644
--- a/eclass/acct-user.eclass
+++ b/eclass/acct-user.eclass
@@ -144,7 +144,7 @@ ACCT_USER_NAME=${PN}
 # << Boilerplate ebuild variables >>
 : "${DESCRIPTION:="System user: ${ACCT_USER_NAME}"}"
 : "${SLOT:=0}"
-: "${KEYWORDS:=~alpha amd64 arm arm64 hppa ~loong ~m68k ~mips ppc ppc64 ~riscv ~s390 sparc x86 ~amd64-linux ~x86-linux ~arm64-macos ~ppc-macos ~x64-macos ~x64-solaris}"
+: "${KEYWORDS:=~alpha amd64 arm arm64 ~hppa ~loong ~m68k ~mips ppc ppc64 ~riscv ~s390 ~sparc x86 ~amd64-linux ~x86-linux ~arm64-macos ~ppc-macos ~x64-macos ~x64-solaris}"
 S=${WORKDIR}
 
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-09-11  9:51 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-09-11  9:51 UTC (permalink / raw
  To: gentoo-commits
commit:     43c15cb26af8df9537cc7f9051e0d4ab26f33514
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Sep 11 09:50:42 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Sep 11 09:51:13 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=43c15cb2
cargo.eclass: fix RUST_MIN_VER typo in error
Prompted by 986f9e9faf926fd9f882fe4636889434023e6e3c.
Bug: https://bugs.gentoo.org/961500
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/cargo.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/cargo.eclass b/eclass/cargo.eclass
index 247d1bf535b9..5c2b89b6a718 100644
--- a/eclass/cargo.eclass
+++ b/eclass/cargo.eclass
@@ -43,7 +43,7 @@ case ${EAPI} in
 			# than the oldest in-tree in future.
 			if [[ -z ${CARGO_BOOTSTRAP} ]]; then
 				if ver_test "${RUST_MIN_VER}" -lt "${_CARGO_ECLASS_RUST_MIN_VER}"; then
-					die "RUST_MIN_VERSION must be at least ${_CARGO_ECLASS_RUST_MIN_VER}"
+					die "RUST_MIN_VER must be at least ${_CARGO_ECLASS_RUST_MIN_VER}"
 				fi
 			fi
 		else
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-09-11 16:49 Nowa Ammerlaan
  0 siblings, 0 replies; 6663+ messages in thread
From: Nowa Ammerlaan @ 2025-09-11 16:49 UTC (permalink / raw
  To: gentoo-commits
commit:     45367fd36d1b1be24cefc3d6266012258b3c3068
Author:     Nowa Ammerlaan <nowa <AT> gentoo <DOT> org>
AuthorDate: Thu Sep 11 16:44:21 2025 +0000
Commit:     Nowa Ammerlaan <nowa <AT> gentoo <DOT> org>
CommitDate: Thu Sep 11 16:44:21 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=45367fd3
kernel-build.eclass: replace cert with pubkey in generic-uki .pcrpkey
This is the final piece in the Measured Boot puzzle, we have been
putting the full certificate in the pcrpkey section. But though the
certificate does contain the public key, the tools downstream get
confused by the incorrect format. We now resolve the problem by
extracting the public key from the certificate and using that instead.
See-also: https://github.com/systemd/systemd/issues/38833
Closes: https://bugs.gentoo.org/960276
Signed-off-by: Nowa Ammerlaan <nowa <AT> gentoo.org>
 eclass/kernel-build.eclass | 17 +++++++++--------
 1 file changed, 9 insertions(+), 8 deletions(-)
diff --git a/eclass/kernel-build.eclass b/eclass/kernel-build.eclass
index 7a5c80cfd6a6..2b16d0a226dd 100644
--- a/eclass/kernel-build.eclass
+++ b/eclass/kernel-build.eclass
@@ -609,14 +609,13 @@ kernel-build_src_install() {
 			done
 
 			if [[ ${KERNEL_IUSE_MODULES_SIGN} ]] && use secureboot; then
-				# --pcrpkey is appended as is. If the certificate and key
-				# are in the same file, we could accidentally leak the key
-				# into the UKI. Pass the certificate through openssl to ensure
-				# that it truly contains *only* the certificate.
+				# The PCR public key option should contain *only* the
+				# public key, not the full certificate containing the
+				# public key. Bug #960276
 				openssl x509 \
 					-in "${SECUREBOOT_SIGN_CERT}" -inform PEM \
-					-out "${T}/pcrpkey.pem" -outform PEM ||
-						die "Failed to extract certificate"
+					-noout -pubkey > "${T}/pcrpkey.pem" ||
+						die "Failed to extract public key"
 				ukify_args+=(
 					--secureboot-private-key="${SECUREBOOT_SIGN_KEY}"
 					--secureboot-certificate="${SECUREBOOT_SIGN_CERT}"
@@ -627,17 +626,19 @@ kernel-build_src_install() {
 					ukify_args+=(
 						--signing-engine="pkcs11"
 						--pcr-private-key="${SECUREBOOT_SIGN_KEY}"
-						--pcr-public-key="${SECUREBOOT_SIGN_CERT}"
+						--pcr-public-key="${T}/pcrpkey.pem"
 						--phases="enter-initrd"
 						--pcr-private-key="${SECUREBOOT_SIGN_KEY}"
-						--pcr-public-key="${SECUREBOOT_SIGN_CERT}"
+						--pcr-public-key="${T}/pcrpkey.pem"
 						--phases="enter-initrd:leave-initrd enter-initrd:leave-initrd:sysinit enter-initrd:leave-initrd:sysinit:ready"
 					)
 				else
 					ukify_args+=(
 						--pcr-private-key="${SECUREBOOT_SIGN_KEY}"
+						--pcr-public-key="${T}/pcrpkey.pem"
 						--phases="enter-initrd"
 						--pcr-private-key="${SECUREBOOT_SIGN_KEY}"
+						--pcr-public-key="${T}/pcrpkey.pem"
 						--phases="enter-initrd:leave-initrd enter-initrd:leave-initrd:sysinit enter-initrd:leave-initrd:sysinit:ready"
 					)
 				fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-09-11 19:48 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-09-11 19:48 UTC (permalink / raw
  To: gentoo-commits
commit:     1e27682401ad7a2edd7e4831cf3e7cf363870959
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Thu Sep 11 18:01:09 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Thu Sep 11 19:47:55 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=1e276824
kernel-build.eclass: Revert "replace cert with pubkey in..."
This change broke at least arm64 dist-kernel builds:
```
Could not find certificate from /var/tmp/portage/sys-kernel/gentoo-kernel-6.16.7/temp/pcrpkey
 * ERROR: sys-kernel/gentoo-kernel-6.16.7::gentoo failed (postinst phase):
 *   Failed to convert pcrpkey to PEM format
```
Reverts: 45367fd36d1b1be24cefc3d6266012258b3c3068
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/kernel-build.eclass | 17 ++++++++---------
 1 file changed, 8 insertions(+), 9 deletions(-)
diff --git a/eclass/kernel-build.eclass b/eclass/kernel-build.eclass
index 2b16d0a226dd..7a5c80cfd6a6 100644
--- a/eclass/kernel-build.eclass
+++ b/eclass/kernel-build.eclass
@@ -609,13 +609,14 @@ kernel-build_src_install() {
 			done
 
 			if [[ ${KERNEL_IUSE_MODULES_SIGN} ]] && use secureboot; then
-				# The PCR public key option should contain *only* the
-				# public key, not the full certificate containing the
-				# public key. Bug #960276
+				# --pcrpkey is appended as is. If the certificate and key
+				# are in the same file, we could accidentally leak the key
+				# into the UKI. Pass the certificate through openssl to ensure
+				# that it truly contains *only* the certificate.
 				openssl x509 \
 					-in "${SECUREBOOT_SIGN_CERT}" -inform PEM \
-					-noout -pubkey > "${T}/pcrpkey.pem" ||
-						die "Failed to extract public key"
+					-out "${T}/pcrpkey.pem" -outform PEM ||
+						die "Failed to extract certificate"
 				ukify_args+=(
 					--secureboot-private-key="${SECUREBOOT_SIGN_KEY}"
 					--secureboot-certificate="${SECUREBOOT_SIGN_CERT}"
@@ -626,19 +627,17 @@ kernel-build_src_install() {
 					ukify_args+=(
 						--signing-engine="pkcs11"
 						--pcr-private-key="${SECUREBOOT_SIGN_KEY}"
-						--pcr-public-key="${T}/pcrpkey.pem"
+						--pcr-public-key="${SECUREBOOT_SIGN_CERT}"
 						--phases="enter-initrd"
 						--pcr-private-key="${SECUREBOOT_SIGN_KEY}"
-						--pcr-public-key="${T}/pcrpkey.pem"
+						--pcr-public-key="${SECUREBOOT_SIGN_CERT}"
 						--phases="enter-initrd:leave-initrd enter-initrd:leave-initrd:sysinit enter-initrd:leave-initrd:sysinit:ready"
 					)
 				else
 					ukify_args+=(
 						--pcr-private-key="${SECUREBOOT_SIGN_KEY}"
-						--pcr-public-key="${T}/pcrpkey.pem"
 						--phases="enter-initrd"
 						--pcr-private-key="${SECUREBOOT_SIGN_KEY}"
-						--pcr-public-key="${T}/pcrpkey.pem"
 						--phases="enter-initrd:leave-initrd enter-initrd:leave-initrd:sysinit enter-initrd:leave-initrd:sysinit:ready"
 					)
 				fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-09-11 20:19 Nowa Ammerlaan
  0 siblings, 0 replies; 6663+ messages in thread
From: Nowa Ammerlaan @ 2025-09-11 20:19 UTC (permalink / raw
  To: gentoo-commits
commit:     123b8e97f3293ef36b19159489182e0fdf142f80
Author:     Nowa Ammerlaan <nowa <AT> gentoo <DOT> org>
AuthorDate: Thu Sep 11 16:47:47 2025 +0000
Commit:     Nowa Ammerlaan <nowa <AT> gentoo <DOT> org>
CommitDate: Thu Sep 11 20:18:47 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=123b8e97
kernel-build.eclass: replace cert with pubkey in generic-uki .pcrpkey
This is the final piece in the Measured Boot puzzle, we have been
putting the full certificate in the pcrpkey section. But though the
certificate does contain the public key, the tools downstream get
confused by the incorrect format. We now resolve the problem by
extracting the public key from the certificate and using that instead.
See-also: https://github.com/systemd/systemd/issues/38833
Closes: https://bugs.gentoo.org/960276
Signed-off-by: Nowa Ammerlaan <nowa <AT> gentoo.org>
 eclass/kernel-build.eclass | 17 +++++++++--------
 1 file changed, 9 insertions(+), 8 deletions(-)
diff --git a/eclass/kernel-build.eclass b/eclass/kernel-build.eclass
index 7a5c80cfd6a6..2b16d0a226dd 100644
--- a/eclass/kernel-build.eclass
+++ b/eclass/kernel-build.eclass
@@ -609,14 +609,13 @@ kernel-build_src_install() {
 			done
 
 			if [[ ${KERNEL_IUSE_MODULES_SIGN} ]] && use secureboot; then
-				# --pcrpkey is appended as is. If the certificate and key
-				# are in the same file, we could accidentally leak the key
-				# into the UKI. Pass the certificate through openssl to ensure
-				# that it truly contains *only* the certificate.
+				# The PCR public key option should contain *only* the
+				# public key, not the full certificate containing the
+				# public key. Bug #960276
 				openssl x509 \
 					-in "${SECUREBOOT_SIGN_CERT}" -inform PEM \
-					-out "${T}/pcrpkey.pem" -outform PEM ||
-						die "Failed to extract certificate"
+					-noout -pubkey > "${T}/pcrpkey.pem" ||
+						die "Failed to extract public key"
 				ukify_args+=(
 					--secureboot-private-key="${SECUREBOOT_SIGN_KEY}"
 					--secureboot-certificate="${SECUREBOOT_SIGN_CERT}"
@@ -627,17 +626,19 @@ kernel-build_src_install() {
 					ukify_args+=(
 						--signing-engine="pkcs11"
 						--pcr-private-key="${SECUREBOOT_SIGN_KEY}"
-						--pcr-public-key="${SECUREBOOT_SIGN_CERT}"
+						--pcr-public-key="${T}/pcrpkey.pem"
 						--phases="enter-initrd"
 						--pcr-private-key="${SECUREBOOT_SIGN_KEY}"
-						--pcr-public-key="${SECUREBOOT_SIGN_CERT}"
+						--pcr-public-key="${T}/pcrpkey.pem"
 						--phases="enter-initrd:leave-initrd enter-initrd:leave-initrd:sysinit enter-initrd:leave-initrd:sysinit:ready"
 					)
 				else
 					ukify_args+=(
 						--pcr-private-key="${SECUREBOOT_SIGN_KEY}"
+						--pcr-public-key="${T}/pcrpkey.pem"
 						--phases="enter-initrd"
 						--pcr-private-key="${SECUREBOOT_SIGN_KEY}"
+						--pcr-public-key="${T}/pcrpkey.pem"
 						--phases="enter-initrd:leave-initrd enter-initrd:leave-initrd:sysinit enter-initrd:leave-initrd:sysinit:ready"
 					)
 				fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-09-11 20:19 Nowa Ammerlaan
  0 siblings, 0 replies; 6663+ messages in thread
From: Nowa Ammerlaan @ 2025-09-11 20:19 UTC (permalink / raw
  To: gentoo-commits
commit:     529a658231c36aee19c29ea888ab01bf3686961a
Author:     Nowa Ammerlaan <nowa <AT> gentoo <DOT> org>
AuthorDate: Thu Sep 11 20:11:57 2025 +0000
Commit:     Nowa Ammerlaan <nowa <AT> gentoo <DOT> org>
CommitDate: Thu Sep 11 20:18:46 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=529a6582
kernel-install.eclass: verify against SECUREBOOT_SIGN_CERT
The .pcrpkey section of the UKI should not contain a full certificate.
And therefore it is not correct to use it in sbverify. Instead use
the set SECUREBOOT_SIGN_CERT which will contain the certificate that
was used for signing in kernel-build.eclass. For gentoo-kernel-bin
we set this variable to the certificate that was used during build
and is included in the gpkg.
Signed-off-by: Nowa Ammerlaan <nowa <AT> gentoo.org>
 eclass/kernel-install.eclass | 19 ++++---------------
 1 file changed, 4 insertions(+), 15 deletions(-)
diff --git a/eclass/kernel-install.eclass b/eclass/kernel-install.eclass
index e753592c46fc..35254b357005 100644
--- a/eclass/kernel-install.eclass
+++ b/eclass/kernel-install.eclass
@@ -674,27 +674,16 @@ kernel-install_extract_from_uki() {
 			die "Failed to extract ${extract_type}"
 
 	# Sanity checks for kernel images
-	if [[ ${extract_type} == linux ]] &&
+	if [[ -n ${SECUREBOOT_SIGN_CERT} && ${extract_type} == linux ]] &&
 		{ ! in_iuse secureboot || use secureboot ;}
 	then
-		# Extract the used SECUREBOOT_SIGN_CERT to verify the kernel image
-		local cert=${T}/pcrpkey
-		kernel-install_extract_from_uki pcrpkey "${uki}" "${cert}"
-		if [[ $(head -n1 "${cert}") != "-----BEGIN CERTIFICATE-----" ]]; then
-			# This is a DER format certificate, convert it to PEM
-			openssl x509 \
-				-inform DER -in "${cert}" \
-				-outform PEM -out "${cert}" ||
-					die "Failed to convert pcrpkey to PEM format"
-		fi
-
 		# Check if the signature on the UKI is valid
-		sbverify --cert "${cert}" "${uki}" ||
+		sbverify --cert "${SECUREBOOT_SIGN_CERT}" "${uki}" ||
 			die "ERROR: UKI signature is invalid"
 
 		# Check if the signature on the kernel image is valid
 		local sbverify_err=$(
-			sbverify --cert "${cert}" "${out_temp}" 2>&1 >/dev/null
+			sbverify --cert "${SECUREBOOT_SIGN_CERT}" "${out_temp}" 2>&1 >/dev/null
 		)
 
 		# Check if there was a padding warning
@@ -708,7 +697,7 @@ kernel-install_extract_from_uki() {
 				>"${out_temp}_trimmed" || die
 			# Check if the signature verifies now
 			sbverify_err=$(
-				sbverify --cert "${cert}" "${out_temp}_trimmed" 2>&1 >/dev/null
+				sbverify --cert "${SECUREBOOT_SIGN_CERT}" "${out_temp}_trimmed" 2>&1 >/dev/null
 			)
 			[[ -z ${sbverify_err} ]] && out_temp=${out_temp}_trimmed
 		fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-09-19  3:13 Ionen Wolkens
  0 siblings, 0 replies; 6663+ messages in thread
From: Ionen Wolkens @ 2025-09-19  3:13 UTC (permalink / raw
  To: gentoo-commits
commit:     24f857d802408092b386f133405816773d4a9461
Author:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
AuthorDate: Fri Sep 19 01:11:41 2025 +0000
Commit:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
CommitDate: Fri Sep 19 03:11:59 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=24f857d8
qt6-build.eclass: allow lto again in Qt 6.10+ w/ gcc-15.2+
Unclear what fixed what wrt the last failing qtbase test in
bug #955531, but it seems to pass now. Just to be safe, limit
this to recent Qt and gcc.
Tried all of dev-qt/* (except qtwebengine+webview) with lto +
-Werror=odr/mismatch/strict and everything seems to pass.
Note that qtwebengine still filters lto in the ebuild, unlikely
that this is resolved as it was due to some asm usage I recall
(plus we're patching qtwebengine to allow respecting flags at all,
Qt doesn't support users passing lto there).
If other dev-qt/* have issues in the future we should likewise
filter in the ebuild rather have a global one anymore. Formerly
this wasn't about one failing test but tons of them everywhere.
Closes: https://bugs.gentoo.org/955531
Signed-off-by: Ionen Wolkens <ionen <AT> gentoo.org>
 eclass/qt6-build.eclass | 13 +++++++------
 1 file changed, 7 insertions(+), 6 deletions(-)
diff --git a/eclass/qt6-build.eclass b/eclass/qt6-build.eclass
index 0f65ffe0abc6..98dc6cf259e7 100644
--- a/eclass/qt6-build.eclass
+++ b/eclass/qt6-build.eclass
@@ -154,12 +154,13 @@ qt6-build_src_prepare() {
 	if use !custom-cflags; then
 		_qt6-build_sanitize_cpu_flags
 
-		# LTO cause test failures in several components (qtcharts,
-		# multimedia, scxml, wayland, webchannel, and likely more --
-		# also 1 qtbase test wrt bug #955531), albeit many need
-		# retesting (not as bad as it used to). Many (all?) of these
-		# issues only happen with GCC.
-		filter-lto
+		# lto+gcc used to break a lot of tests, but this has improved so
+		# tentatively allow again for Qt >=6.10 + GCC >=15.2 (bug #955531)
+		if ver_test ${PV} -lt 6.10 ||
+			{ tc-is-gcc && ver_test $(gcc-version) -lt 15.2; };
+		then
+			filter-lto
+		fi
 	fi
 
 	[[ ${QT6_HAS_STATIC_LIBS} ]] && lto-guarantee-fat
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-09-24  2:27 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-09-24  2:27 UTC (permalink / raw
  To: gentoo-commits
commit:     3f17fea05fe409f3b7a93bc4bba92575a4fc12f3
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Wed Sep 24 02:23:08 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Wed Sep 24 02:23:08 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=3f17fea0
llvm.org.eclass: Remove old snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 ---
 1 file changed, 3 deletions(-)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index aad7097a1100..53e28fba81ea 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -72,9 +72,6 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 			_LLVM_SOURCE_TYPE=snapshot
 
 			case ${PV} in
-				22.0.0_pre20250907)
-					EGIT_COMMIT=645dd324d1b7d028745c2a4045b69e745df2ae6a
-					;;
 				22.0.0_pre20250910)
 					EGIT_COMMIT=f059d2bac034acca39ad60a1b13aaec6afa0a3d6
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-09-24  2:27 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-09-24  2:27 UTC (permalink / raw
  To: gentoo-commits
commit:     101abd13094a1be5070e5d12043d4fa6f835e680
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Wed Sep 24 02:22:59 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Wed Sep 24 02:22:59 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=101abd13
llvm.org.eclass: Add 22.0.0_pre20250923 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index c4a55183e75d..aad7097a1100 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -78,6 +78,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 				22.0.0_pre20250910)
 					EGIT_COMMIT=f059d2bac034acca39ad60a1b13aaec6afa0a3d6
 					;;
+				22.0.0_pre20250923)
+					EGIT_COMMIT=70bd610e43853d575e22be1cda46614fe9f0072f
+					;;
 				*)
 					die "Unknown snapshot: ${PV}"
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-09-25 13:38 Patrick Lauer
  0 siblings, 0 replies; 6663+ messages in thread
From: Patrick Lauer @ 2025-09-25 13:38 UTC (permalink / raw
  To: gentoo-commits
commit:     353510734c67cdfc622d69823459d7c0e0c8c6ef
Author:     Patrick Lauer <patrick <AT> gentoo <DOT> org>
AuthorDate: Thu Sep 25 12:27:57 2025 +0000
Commit:     Patrick Lauer <patrick <AT> gentoo <DOT> org>
CommitDate: Thu Sep 25 13:37:18 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=35351073
postgres.eclass: Add support for postgres 18
Signed-off-by: Patrick Lauer <patrick <AT> gentoo.org>
 eclass/postgres.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/postgres.eclass b/eclass/postgres.eclass
index d743c5d0d165..6f322f5b7573 100644
--- a/eclass/postgres.eclass
+++ b/eclass/postgres.eclass
@@ -27,7 +27,7 @@ _POSTGRES_ECLASS=1
 # @DESCRIPTION:
 # List of versions to reverse sort POSTGRES_COMPAT slots
 
-_POSTGRES_ALL_VERSIONS=( 9999 17 16 15 14 13 )
+_POSTGRES_ALL_VERSIONS=( 9999 18 17 16 15 14 13 )
 
 
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread
* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-09-25 16:53 Nowa Ammerlaan
  0 siblings, 0 replies; 6663+ messages in thread
From: Nowa Ammerlaan @ 2025-09-25 16:53 UTC (permalink / raw
  To: gentoo-commits
commit:     fb7a681e9cc8bc15b8fc11ceac5d41210c91b30a
Author:     Nowa Ammerlaan <nowa <AT> gentoo <DOT> org>
AuthorDate: Thu Sep 25 16:40:46 2025 +0000
Commit:     Nowa Ammerlaan <nowa <AT> gentoo <DOT> org>
CommitDate: Thu Sep 25 16:53:01 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=fb7a681e
kernel-install.eclass: ensure a secureboot cert is always set
When the kernel is re-installed via pkg_config the certificate may
be gone. Detect if this is the case and if so try to extract the
certificate from the kernel install directory and use that for
verification later on in the (re-)install process.
Signed-off-by: Nowa Ammerlaan <nowa <AT> gentoo.org>
 eclass/kernel-install.eclass | 9 +++++++++
 1 file changed, 9 insertions(+)
diff --git a/eclass/kernel-install.eclass b/eclass/kernel-install.eclass
index 35254b357005..7fd714111daf 100644
--- a/eclass/kernel-install.eclass
+++ b/eclass/kernel-install.eclass
@@ -728,11 +728,20 @@ kernel-install_install_all() {
 	local dir_ver=${1}
 	local kernel_dir=${EROOT}/usr/src/linux-${dir_ver}
 	local relfile=${kernel_dir}/include/config/kernel.release
+	local kernel_cert=${kernel_dir}/certs/signing_key.x509
 	local image_path=$(dist-kernel_get_image_path)
 	local image_dir=${image_path%/*}
 	local module_ver
 	module_ver=$(<"${relfile}") || die
 
+	if [[ ! -r ${SECUREBOOT_SIGN_CERT} && -r ${kernel_cert} ]]; then
+		openssl x509 \
+			-inform DER -in "${kernel_cert}" \
+			-outform PEM -out "${T}/cert.pem" ||
+				die "Failed to convert kernel certificate to PEM format"
+			export SECUREBOOT_SIGN_CERT=${T}/cert.pem
+	fi
+
 	if [[ ${KERNEL_IUSE_GENERIC_UKI} ]]; then
 		if use generic-uki; then
 			# Populate placeholders
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-09-26  5:52 Alfredo Tupone
  0 siblings, 0 replies; 6663+ messages in thread
From: Alfredo Tupone @ 2025-09-26  5:52 UTC (permalink / raw
  To: gentoo-commits
commit:     a4f1bec222ca48f54e8a0ad2d79961154edf603e
Author:     Alfredo Tupone <tupone <AT> gentoo <DOT> org>
AuthorDate: Fri Sep 26 05:51:43 2025 +0000
Commit:     Alfredo Tupone <tupone <AT> gentoo <DOT> org>
CommitDate: Fri Sep 26 05:52:36 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=a4f1bec2
dune.eclass: dev-lang/ocaml<4 have long gone
Signed-off-by: Alfredo Tupone <tupone <AT> gentoo.org>
 eclass/dune.eclass | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/eclass/dune.eclass b/eclass/dune.eclass
index cfe81433a5bc..02b0d55ff21e 100644
--- a/eclass/dune.eclass
+++ b/eclass/dune.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2024 Gentoo Authors
+# Copyright 1999-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: dune.eclass
@@ -35,7 +35,7 @@ inherit edo multiprocessing
 QA_FLAGS_IGNORED='.*'
 
 RDEPEND="
-	>=dev-lang/ocaml-4:=[ocamlopt?]
+	dev-lang/ocaml:=[ocamlopt?]
 	dev-ml/dune:=
 "
 DEPEND="${RDEPEND}"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-09-26  6:37 Patrick Lauer
  0 siblings, 0 replies; 6663+ messages in thread
From: Patrick Lauer @ 2025-09-26  6:37 UTC (permalink / raw
  To: gentoo-commits
commit:     ce546c73a1988b5dc65de8cd0974919c7c30b628
Author:     Patrick Lauer <patrick <AT> gentoo <DOT> org>
AuthorDate: Fri Sep 26 06:34:12 2025 +0000
Commit:     Patrick Lauer <patrick <AT> gentoo <DOT> org>
CommitDate: Fri Sep 26 06:37:24 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=ce546c73
postgres.eclass: Disable postgres13 support
Signed-off-by: Patrick Lauer <patrick <AT> gentoo.org>
 eclass/postgres.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/postgres.eclass b/eclass/postgres.eclass
index 6f322f5b7573..bf26931ab352 100644
--- a/eclass/postgres.eclass
+++ b/eclass/postgres.eclass
@@ -27,7 +27,7 @@ _POSTGRES_ECLASS=1
 # @DESCRIPTION:
 # List of versions to reverse sort POSTGRES_COMPAT slots
 
-_POSTGRES_ALL_VERSIONS=( 9999 18 17 16 15 14 13 )
+_POSTGRES_ALL_VERSIONS=( 9999 18 17 16 15 14 )
 
 
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread
* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-09-26 10:10 Nowa Ammerlaan
  0 siblings, 0 replies; 6663+ messages in thread
From: Nowa Ammerlaan @ 2025-09-26 10:10 UTC (permalink / raw
  To: gentoo-commits
commit:     39540973a8b3e68b86b5da3be62a65b1cae585df
Author:     Nowa Ammerlaan <nowa <AT> gentoo <DOT> org>
AuthorDate: Fri Sep 26 10:09:20 2025 +0000
Commit:     Nowa Ammerlaan <nowa <AT> gentoo <DOT> org>
CommitDate: Fri Sep 26 10:09:20 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=39540973
kernel-install.eclass: only use cert if non-empty
Apparently this file sometimes exists, but is empty, in which case we
should not try to use it.
Closes: https://bugs.gentoo.org/963425
Signed-off-by: Nowa Ammerlaan <nowa <AT> gentoo.org>
 eclass/kernel-install.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/kernel-install.eclass b/eclass/kernel-install.eclass
index 7fd714111daf..47afe6e75010 100644
--- a/eclass/kernel-install.eclass
+++ b/eclass/kernel-install.eclass
@@ -734,7 +734,7 @@ kernel-install_install_all() {
 	local module_ver
 	module_ver=$(<"${relfile}") || die
 
-	if [[ ! -r ${SECUREBOOT_SIGN_CERT} && -r ${kernel_cert} ]]; then
+	if [[ ! -r ${SECUREBOOT_SIGN_CERT} && -s ${kernel_cert} ]]; then
 		openssl x509 \
 			-inform DER -in "${kernel_cert}" \
 			-outform PEM -out "${T}/cert.pem" ||
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-09-30 17:34 Alfredo Tupone
  0 siblings, 0 replies; 6663+ messages in thread
From: Alfredo Tupone @ 2025-09-30 17:34 UTC (permalink / raw
  To: gentoo-commits
commit:     26f187af12ecc9a9eae3d6035a18aa2fcd10695e
Author:     Alfredo Tupone <tupone <AT> gentoo <DOT> org>
AuthorDate: Tue Sep 30 17:33:20 2025 +0000
Commit:     Alfredo Tupone <tupone <AT> gentoo <DOT> org>
CommitDate: Tue Sep 30 17:34:08 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=26f187af
opam.eclass: dev-lang/ocaml-4 is the min in the tree
Signed-off-by: Alfredo Tupone <tupone <AT> gentoo.org>
 eclass/opam.eclass | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/eclass/opam.eclass b/eclass/opam.eclass
index 49e3c426b062..1cb3362a50c5 100644
--- a/eclass/opam.eclass
+++ b/eclass/opam.eclass
@@ -1,4 +1,4 @@
-# Copyright 1999-2023 Gentoo Authors
+# Copyright 1999-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: opam.eclass
@@ -27,7 +27,7 @@ QA_FLAGS_IGNORED='.*'
 # Override dependency for OPAM_INSTALLER
 : "${OPAM_INSTALLER_DEP:="dev-ml/opam-installer"}"
 
-RDEPEND=">=dev-lang/ocaml-4:="
+RDEPEND="dev-lang/ocaml:="
 BDEPEND="${OPAM_INSTALLER_DEP} dev-lang/ocaml"
 DEPEND="${RDEPEND}"
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-10-01  6:35 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-10-01  6:35 UTC (permalink / raw
  To: gentoo-commits
commit:     560702ec70ca0e6cd27a0973aa40c384292f5bab
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Wed Oct  1 06:13:52 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Wed Oct  1 06:13:52 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=560702ec
llvm.org.eclass: Add 22.0.0_pre20251001 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index 53e28fba81ea..86331208c7c0 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -78,6 +78,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 				22.0.0_pre20250923)
 					EGIT_COMMIT=70bd610e43853d575e22be1cda46614fe9f0072f
 					;;
+				22.0.0_pre20251001)
+					EGIT_COMMIT=89ed5255b9ee88119e409a6d986eb1ad0e8f08e3
+					;;
 				*)
 					die "Unknown snapshot: ${PV}"
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-10-01 15:08 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-10-01 15:08 UTC (permalink / raw
  To: gentoo-commits
commit:     cb6eb7f69b18a56c3c63ec920372b38cfe20feed
Author:     Alexander Tsoy <alexander <AT> tsoy <DOT> me>
AuthorDate: Wed Oct  1 06:57:02 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Oct  1 15:06:11 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=cb6eb7f6
toolchain.eclass: fix paths for pax-mark
Actually ${ED} != ${D}${PREFIX}
Fixes: 4a3bfe56f647fd16ec529d3632030bbbcaacee06
Signed-off-by: Alexander Tsoy <alexander <AT> tsoy.me>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 5d7bf2a67547..5e9a6bcad9ad 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -2811,8 +2811,8 @@ toolchain_src_install() {
 	export QA_PRESTRIPPED="usr/lib*/go/*/*/*.gox"
 
 	# Disable RANDMMAP so PCH works, bug #301299
-	pax-mark -r "${ED}/libexec/gcc/${CTARGET}/${GCC_CONFIG_VER}/cc1"
-	pax-mark -r "${ED}/libexec/gcc/${CTARGET}/${GCC_CONFIG_VER}/cc1plus"
+	pax-mark -r "${D}${PREFIX}/libexec/gcc/${CTARGET}/${GCC_CONFIG_VER}/cc1"
+	pax-mark -r "${D}${PREFIX}/libexec/gcc/${CTARGET}/${GCC_CONFIG_VER}/cc1plus"
 
 	if [[ -n ${TOOLCHAIN_HAS_TESTS} ]] && use test ; then
 		mkdir "${T}"/test-results || die
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-10-03 16:27 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-10-03 16:27 UTC (permalink / raw
  To: gentoo-commits
commit:     b9319f2dfb6498898d7192595476355fb10c36a5
Author:     Volkmar W. Pogatzki <gentoo <AT> pogatzki <DOT> net>
AuthorDate: Sat May 17 17:13:32 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Oct  3 16:24:11 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=b9319f2d
java-pkg-simple.eclass: fix a problem in multi-relase packaging
There was too much of '--release ${version}' leading to validation
errors and preventing successful creation of the jar when packaging
(jar --create -f ) dev-java/fastdoubleparser. Removing it and changing
the output directory of multi-release classes solves the problem and
allows removal of the multi_release variable.
Signed-off-by: Volkmar W. Pogatzki <gentoo <AT> pogatzki.net>
Part-of: https://github.com/gentoo/gentoo/pull/42134
Closes: https://github.com/gentoo/gentoo/pull/42134
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/java-pkg-simple.eclass | 29 +++++++++++------------------
 1 file changed, 11 insertions(+), 18 deletions(-)
diff --git a/eclass/java-pkg-simple.eclass b/eclass/java-pkg-simple.eclass
index 0cce6a2cdfa8..40271156bb3a 100644
--- a/eclass/java-pkg-simple.eclass
+++ b/eclass/java-pkg-simple.eclass
@@ -598,7 +598,7 @@ java-pkg-simple_src_compile() {
 
 			# compile sources in ${reldir}
 			ejavac \
-				-d target/versions/${release} \
+				-d ${classes}/META-INF/versions/${release} \
 				-encoding ${JAVA_ENCODING} \
 				-classpath "${modulepath}:${JAVA_INTERMEDIATE_JAR_NAME}.jar" \
 				--module-path "${modulepath}:${JAVA_INTERMEDIATE_JAR_NAME}.jar" \
@@ -606,7 +606,7 @@ java-pkg-simple_src_compile() {
 				--patch-module "${JAVA_INTERMEDIATE_JAR_NAME}"="${JAVA_INTERMEDIATE_JAR_NAME}.jar" \
 				${JAVAC_ARGS} $(find ${reldir} -type f -name '*.java')
 
-			JAVA_GENTOO_CLASSPATH_EXTRA+=":target/versions/${release}"
+			JAVA_GENTOO_CLASSPATH_EXTRA+=":${classes}/META-INF/versions/${release}"
 		done
 
 		JAVA_PKG_WANT_SOURCE=${tmp_source}
@@ -681,21 +681,7 @@ java-pkg-simple_src_compile() {
 	fi
 
 	# package
-	local jar_args multi_release=""
-	if [[ -n ${JAVA_RELEASE_SRC_DIRS[@]} ]]; then
-		# Preparing the multi_release variable. From multi-release compilation
-		# the release-specific classes are sorted in target/versions/${release}
-		# directories.
-
-		# TODO:
-		# Could this possibly be simplified with printf?
-		pushd target/versions > /dev/null || die
-			for version in $(ls -d * | sort -g); do
-				debug-print "Version is ${version}"
-				multi_release="${multi_release} --release ${version} -C target/versions/${version} . "
-			done
-		popd > /dev/null || die
-	fi
+	local jar_args
 
 	if [[ -e ${classes}/META-INF/MANIFEST.MF ]]; then
 		sed '/Created-By: /Id' -i ${classes}/META-INF/MANIFEST.MF
@@ -703,7 +689,14 @@ java-pkg-simple_src_compile() {
 	else
 		jar_args="cf ${JAVA_JAR_FILENAME}"
 	fi
-	jar ${jar_args} -C ${classes} . ${multi_release} || die "jar failed"
+	jar ${jar_args} -C ${classes} . || die "jar failed"
+
+	if [[ -n ${JAVA_RELEASE_SRC_DIRS[@]} ]]; then
+		# From multi-release compilation the release-specific classes are sorted
+		# in target/classes/META-INF/versions/${release} directories.
+		echo 'Multi-Release: true' >> "${T}/add-to-MANIFEST.MF" || die "add true"
+	fi
+
 	if  [[ -n "${JAVA_AUTOMATIC_MODULE_NAME}" ]]; then
 		echo "Automatic-Module-Name: ${JAVA_AUTOMATIC_MODULE_NAME}" \
 			>> "${T}/add-to-MANIFEST.MF" || die "adding module name failed"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-10-03 16:27 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-10-03 16:27 UTC (permalink / raw
  To: gentoo-commits
commit:     74969e04323ddb6034a3581b93ec292a9304e767
Author:     Volkmar W. Pogatzki <gentoo <AT> pogatzki <DOT> net>
AuthorDate: Sun May 18 15:53:34 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Oct  3 16:24:35 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=74969e04
java-utils-2.eclass: re-enable PORTAGE_QUIET
There are packages like javacup and jflex which cannot be built from
source without using a pre-built runtime version of itself. Re-emerging
these packages using the installed instead of the bundled pre-built
version was causing the java-pkg_getjar() function to trigger
java-pkg_ensure-dep() to issue a "QA Notice: java-pkg_ensure-dep:"
message.
This commit ports the PORTAGE_QUIET variable to java-pkg_getjar() so
that it works again as it did in the past for ant-based ebuilds.
Bug: https://bugs.gentoo.org/937047
Signed-off-by: Volkmar W. Pogatzki <gentoo <AT> pogatzki.net>
Part-of: https://github.com/gentoo/gentoo/pull/44017
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/java-utils-2.eclass | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/eclass/java-utils-2.eclass b/eclass/java-utils-2.eclass
index 3b2b9d6a5b24..20d189ff8cfd 100644
--- a/eclass/java-utils-2.eclass
+++ b/eclass/java-utils-2.eclass
@@ -1305,7 +1305,7 @@ java-pkg_getjar() {
 	classpath=$(java-config --classpath=${pkg})
 	[[ $? != 0 ]] && die ${error_msg}
 
-	java-pkg_ensure-dep "${build_only}" "${pkg}"
+	[[ -z ${PORTAGE_QUIET} ]] && java-pkg_ensure-dep "${build_only}" "${pkg}"
 
 	# Record the package(Virtual) as a dependency and then set build_only
 	# So that individual jars are not recorded.
@@ -1325,7 +1325,7 @@ java-pkg_getjar() {
 
 		if [[ "$(basename ${jar})" == "${target_jar}" ]] ; then
 			# Only record jars that aren't build-only
-			if [[ -z "${record_jar}" ]]; then
+			if [[ -z "${record_jar}" && -z ${PORTAGE_QUIET} ]]; then
 				if [[ -z "${build_only}" ]]; then
 					java-pkg_record-jar_ "${pkg}" "${jar}"
 				else
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-10-03 19:11 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-10-03 19:11 UTC (permalink / raw
  To: gentoo-commits
commit:     be9e5a134fc0aba4f561723769a75807756a177a
Author:     Haelwenn (lanodan) Monnier <contact <AT> hacktivis <DOT> me>
AuthorDate: Sun Jul 27 16:26:10 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Fri Oct  3 19:11:24 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=be9e5a13
python-utils-r1.eclass: use 6 'X's for mktemp
As required by POSIX.1-2024 for mkstemp(3) (and future-POSIX for mktemp(1))
Although you'd need de-facto standard mkstemps(3) due to the .xml suffix,
but same contrains of 6 'X's applies, at least with musl.
Signed-off-by: Haelwenn (lanodan) Monnier <contact <AT> hacktivis.me>
Part-of: https://github.com/gentoo/gentoo/pull/43186
Closes: https://github.com/gentoo/gentoo/pull/43186
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/python-utils-r1.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/python-utils-r1.eclass b/eclass/python-utils-r1.eclass
index f454a066a352..e213273a3a78 100644
--- a/eclass/python-utils-r1.eclass
+++ b/eclass/python-utils-r1.eclass
@@ -1420,7 +1420,7 @@ epytest() {
 	[[ ${NO_COLOR} ]] && color=no
 
 	mkdir -p "${T}/pytest-xml" || die
-	local junit_xml=$(mktemp "${T}/pytest-xml/${EPYTHON}-XXX.xml" || die)
+	local junit_xml=$(mktemp "${T}/pytest-xml/${EPYTHON}-XXXXXX.xml" || die)
 
 	local args=(
 		# verbose progress reporting and tracebacks
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-10-03 19:11 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-10-03 19:11 UTC (permalink / raw
  To: gentoo-commits
commit:     74b839fa53c6ebb386df6ec85e185020978d0b6c
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Fri Oct  3 12:38:19 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Fri Oct  3 19:11:24 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=74b839fa
kernel-install.eclass: Fix updating symlinks with -p kernels
Closes: https://bugs.gentoo.org/963683
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
Part-of: https://github.com/gentoo/gentoo/pull/44021
Closes: https://github.com/gentoo/gentoo/pull/44021
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/kernel-install.eclass | 13 +++++++++----
 1 file changed, 9 insertions(+), 4 deletions(-)
diff --git a/eclass/kernel-install.eclass b/eclass/kernel-install.eclass
index 47afe6e75010..5d074598192f 100644
--- a/eclass/kernel-install.eclass
+++ b/eclass/kernel-install.eclass
@@ -263,10 +263,15 @@ kernel-install_can_update_symlink() {
 	# strip KV_LOCALVERSION, we want to update the old kernels not using
 	# KV_LOCALVERSION suffix and the new kernels using it
 	symlink_ver=${symlink_ver%${KV_LOCALVERSION}}
-
-	# if ${symlink_ver} contains anything but numbers (e.g. an extra
-	# suffix), it's not our kernel, so leave it alone
-	[[ -n ${symlink_ver//[0-9.]/} ]] && return 1
+	symlink_ver=${symlink_ver/-p/_p}
+	# strip -p* revision
+	local symlink_ver_no_rev=${symlink_ver%_p[0-9]*}
+	local rev=${symlink_ver#${symlink_ver_no_rev}}
+	rev=${rev#_p}
+
+	# if ${symlink_ver} contained anything but numbers and revision (e.g.
+	# an extra suffix), it's not our kernel, so leave it alone
+	[[ -n ${symlink_ver_no_rev//[0-9.]/} || -n ${rev//[0-9]/} ]] && return 1
 
 	local symlink_pkg=${CATEGORY}/${PN}-${symlink_ver}
 	# if the current target is either being replaced, or still
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-10-04  9:16 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-10-04  9:16 UTC (permalink / raw
  To: gentoo-commits
commit:     dea5f91b78e9b9e730993dccaafd909ba96766cf
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Oct  4 08:51:07 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat Oct  4 08:51:07 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=dea5f91b
llvm.org.eclass: Remove old snapshot support
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 6 ------
 1 file changed, 6 deletions(-)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index 86331208c7c0..694b94b303d5 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -72,12 +72,6 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 			_LLVM_SOURCE_TYPE=snapshot
 
 			case ${PV} in
-				22.0.0_pre20250910)
-					EGIT_COMMIT=f059d2bac034acca39ad60a1b13aaec6afa0a3d6
-					;;
-				22.0.0_pre20250923)
-					EGIT_COMMIT=70bd610e43853d575e22be1cda46614fe9f0072f
-					;;
 				22.0.0_pre20251001)
 					EGIT_COMMIT=89ed5255b9ee88119e409a6d986eb1ad0e8f08e3
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-10-04  9:16 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-10-04  9:16 UTC (permalink / raw
  To: gentoo-commits
commit:     68e4baf34f8c40f422e87b9770f12c6d3b60234d
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Oct  4 08:51:32 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat Oct  4 08:51:32 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=68e4baf3
llvm.org.eclass: Add 22.0.0_pre20251004 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index 694b94b303d5..b9ee50fa2492 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -72,6 +72,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 			_LLVM_SOURCE_TYPE=snapshot
 
 			case ${PV} in
+				22.0.0_pre20251004)
+					EGIT_COMMIT=b1e29ec3b73b9dd06656c7e30ace597ff72cde70
+					;;
 				22.0.0_pre20251001)
 					EGIT_COMMIT=89ed5255b9ee88119e409a6d986eb1ad0e8f08e3
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-10-05 21:50 Andreas Sturmlechner
  0 siblings, 0 replies; 6663+ messages in thread
From: Andreas Sturmlechner @ 2025-10-05 21:50 UTC (permalink / raw
  To: gentoo-commits
commit:     db6e698c25d42e71b5b193e3aaf2c8db844c6dee
Author:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
AuthorDate: Sun Oct  5 19:54:43 2025 +0000
Commit:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
CommitDate: Sun Oct  5 21:49:44 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=db6e698c
cmake.eclass: Raise minimum dev-build/cmake version to 3.28.5
Signed-off-by: Andreas Sturmlechner <asturm <AT> gentoo.org>
 eclass/cmake.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/cmake.eclass b/eclass/cmake.eclass
index 5b3d135018e8..0a8b93c215aa 100644
--- a/eclass/cmake.eclass
+++ b/eclass/cmake.eclass
@@ -164,7 +164,7 @@ case ${CMAKE_MAKEFILE_GENERATOR} in
 esac
 
 if [[ ${PN} != cmake ]]; then
-	BDEPEND+=" >=dev-build/cmake-3.20.5"
+	BDEPEND+=" >=dev-build/cmake-3.28.5"
 fi
 
 # @FUNCTION: cmake_run_in
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-10-05 21:50 Andreas Sturmlechner
  0 siblings, 0 replies; 6663+ messages in thread
From: Andreas Sturmlechner @ 2025-10-05 21:50 UTC (permalink / raw
  To: gentoo-commits
commit:     7ad5452949cbe7fa8856d5fa43528cd39f84efaf
Author:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
AuthorDate: Sat Sep 27 19:29:09 2025 +0000
Commit:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
CommitDate: Sun Oct  5 21:49:43 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=7ad54529
cmake.eclass: Reorder arguments in cmake_src_install cmake_build call
Bug: https://bugs.gentoo.org/963428
Signed-off-by: Andreas Sturmlechner <asturm <AT> gentoo.org>
 eclass/cmake.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/cmake.eclass b/eclass/cmake.eclass
index 2e799f14352e..b3a1cde6057e 100644
--- a/eclass/cmake.eclass
+++ b/eclass/cmake.eclass
@@ -796,7 +796,7 @@ cmake_src_test() {
 cmake_src_install() {
 	debug-print-function ${FUNCNAME} "$@"
 
-	DESTDIR="${D}" cmake_build install "$@"
+	DESTDIR="${D}" cmake_build "$@" install
 
 	if [[ ${EAPI} == 7 ]]; then
 		pushd "${S}" > /dev/null || die
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-10-05 21:50 Andreas Sturmlechner
  0 siblings, 0 replies; 6663+ messages in thread
From: Andreas Sturmlechner @ 2025-10-05 21:50 UTC (permalink / raw
  To: gentoo-commits
commit:     385f0c526a66fa7c3d0a23ea62cf260b188402ba
Author:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
AuthorDate: Wed Oct  1 19:36:20 2025 +0000
Commit:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
CommitDate: Sun Oct  5 21:49:43 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=385f0c52
cmake.eclass: allow nonfatal cmake_src_test, fix pms violation
1) This is already expected in tree via virtx use.
2) Escape sequences are not allowed for `die`, use eerror instead.
Bug: https://bugs.gentoo.org/961929
See also: https://github.com/gentoo/gentoo/pull/40307
Signed-off-by: Alfred Wingate <parona <AT> protonmail.com>
Signed-off-by: Paul Zander <negril.nx+gentoo <AT> gmail.com>
Signed-off-by: Andreas Sturmlechner <asturm <AT> gentoo.org>
(cherry picked from commit 657dc69cdd68546003b7877321bc1d2db0ddc849) (kde)
(cherry picked from commit ae57eab324d55a4a0a6fb890d8039e53a7a8930a) (kde)
 eclass/cmake.eclass | 6 ++++--
 1 file changed, 4 insertions(+), 2 deletions(-)
diff --git a/eclass/cmake.eclass b/eclass/cmake.eclass
index e3f9a50a518d..37b181df927b 100644
--- a/eclass/cmake.eclass
+++ b/eclass/cmake.eclass
@@ -816,9 +816,11 @@ cmake_src_test() {
 			eerror "--START TEST LOG--------------------------------------------------------------"
 			cat "${BUILD_DIR}/Testing/Temporary/LastTest.log"
 			eerror "--END TEST LOG----------------------------------------------------------------"
-			die "Tests failed."
+			die -n "Tests failed."
 		else
-			die "Tests failed. When you file a bug, please attach the following file: \n\t${BUILD_DIR}/Testing/Temporary/LastTest.log"
+			eerror "Tests failed. When you file a bug, please attach the following file:"
+			eerror "\t${BUILD_DIR}/Testing/Temporary/LastTest.log"
+			die -n "Tests failed."
 		fi
 
 		# die might not die due to nonfatal
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-10-05 21:50 Andreas Sturmlechner
  0 siblings, 0 replies; 6663+ messages in thread
From: Andreas Sturmlechner @ 2025-10-05 21:50 UTC (permalink / raw
  To: gentoo-commits
commit:     fade5bd1cfb710a8673bf3d9bc1d788df986236e
Author:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
AuthorDate: Sun Sep 28 12:12:34 2025 +0000
Commit:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
CommitDate: Sun Oct  5 21:49:43 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=fade5bd1
cmake.eclass: Provide cmake_prepare() to solve conflicts w/ other eclass
Split out what we need from cmake_src_prepare into new cmake_prepare().
cmake_src_prepare henceforth just calls default_src_prepare(),
then cmake_prepare(). This change was made for >=EAPI-8 only.
This also switches on a general EAPI=7 imminent error QA notice.
Bug: https://bugs.gentoo.org/853805
Signed-off-by: Andreas Sturmlechner <asturm <AT> gentoo.org>
 eclass/cmake.eclass | 125 ++++++++++++++++++++++++++++++++++------------------
 1 file changed, 81 insertions(+), 44 deletions(-)
diff --git a/eclass/cmake.eclass b/eclass/cmake.eclass
index b3a1cde6057e..e3f9a50a518d 100644
--- a/eclass/cmake.eclass
+++ b/eclass/cmake.eclass
@@ -303,6 +303,8 @@ _cmake_check_build_dir() {
 	if [[ ${EAPI} == 7 ]]; then
 		: "${CMAKE_USE_DIR:=${S}}"
 	else
+		# Since EAPI-8 we use current working directory, bug #704524
+		# esp. test with 'special' pkgs like: app-arch/brotli, net-libs/quiche
 		: "${CMAKE_USE_DIR:=${PWD}}"
 	fi
 	if [[ -n ${CMAKE_IN_SOURCE_BUILD} ]]; then
@@ -394,22 +396,38 @@ _cmake_modify-cmakelists() {
 	_EOF_
 }
 
-# @FUNCTION: cmake_src_prepare
+# @FUNCTION: _cmake4_callout
+# @INTERNAL
 # @DESCRIPTION:
-# Apply ebuild and user patches. *MUST* be run or cmake_src_configure will fail.
-cmake_src_prepare() {
+# QA notice printout for build systems unsupported w/ CMake-4.
+_cmake4_callout() {
+	if [[ ${_CMAKE_MINREQVER_UNSUPPORTED} ]]; then
+		eqawarn "QA Notice: Compatibility with CMake < 3.5 has been removed from CMake 4,"
+		eqawarn "${CATEGORY}/${PN} will fail to build w/o a fix."
+		eqawarn "See also tracker bug #951350; check existing bug or file a new one for"
+		eqawarn "this package, and take it upstream."
+		if has_version -b ">=dev-build/cmake-4"; then
+			eqawarn "CMake 4 detected; building with -DCMAKE_POLICY_VERSION_MINIMUM=3.5"
+			eqawarn "This is merely a workaround and *not* a permanent fix."
+		fi
+	fi
+}
+
+# @FUNCTION: cmake_prepare
+# @DESCRIPTION:
+# Check existence of and sanitise CMake files, then make ${CMAKE_USE_DIR}
+# read-only.  *MUST* be run or cmake_src_configure will fail.  EAPI-8 only.
+cmake_prepare() {
 	debug-print-function ${FUNCNAME} "$@"
 
 	if [[ ${EAPI} == 7 ]]; then
-		pushd "${S}" > /dev/null || die # workaround from cmake-utils
-		# in EAPI-8, we use current working directory instead, bug #704524
-		# esp. test with 'special' pkgs like: app-arch/brotli, net-libs/quiche
+		eerror "${FUNCNAME} is EAPI-8 only. Call cmake_src_prepare instead."
+		die "FATAL: Forbidden function call."
 	fi
-	_cmake_check_build_dir
 
-	default_src_prepare
+	_cmake_check_build_dir
 
-	# check if CMakeLists.txt exists and if not then die
+	# Check if CMakeLists.txt exists and if not then die
 	if [[ ! -e ${CMAKE_USE_DIR}/CMakeLists.txt ]] ; then
 		eerror "Unable to locate CMakeLists.txt under:"
 		eerror "\"${CMAKE_USE_DIR}/CMakeLists.txt\""
@@ -417,54 +435,68 @@ cmake_src_prepare() {
 		die "FATAL: Unable to find CMakeLists.txt"
 	fi
 
-	local modules_list
-	if [[ ${EAPI} == 7 && $(declare -p CMAKE_REMOVE_MODULES_LIST) != "declare -a"* ]]; then
-		modules_list=( ${CMAKE_REMOVE_MODULES_LIST} )
-	else
-		modules_list=( "${CMAKE_REMOVE_MODULES_LIST[@]}" )
-	fi
+	local modules_list=( "${CMAKE_REMOVE_MODULES_LIST[@]}" )
 
 	local name
 	for name in "${modules_list[@]}" ; do
-		if [[ ${EAPI} == 7 ]]; then
-			find "${S}" -name "${name}.cmake" -exec rm -v {} + || die
-		else
-			find -name "${name}.cmake" -exec rm -v {} + || die
-		fi
+		find -name "${name}.cmake" -exec rm -v {} + || die
 	done
 
 	# Remove dangerous things.
 	_cmake_modify-cmakelists
+	_cmake4_callout
 
-	if [[ ${_CMAKE_MINREQVER_UNSUPPORTED} ]]; then
-		eqawarn "QA Notice: Compatibility with CMake < 3.5 has been removed from CMake 4,"
-		eqawarn "${CATEGORY}/${PN} will fail to build w/o a fix."
-		eqawarn "See also tracker bug #951350; check existing bug or file a new one for"
-		eqawarn "this package, and take it upstream."
-		if has_version -b ">=dev-build/cmake-4"; then
-			eqawarn "CMake 4 detected; building with -DCMAKE_POLICY_VERSION_MINIMUM=3.5"
-			eqawarn "This is merely a workaround and *not* a permanent fix."
-		fi
-		if [[ ${EAPI} == 7 ]]; then
-			eqawarn "QA Notice: EAPI=7 detected; this package is now a prime last-rites target."
-		fi
+	# Make ${CMAKE_USE_DIR} read-only in order to detect broken build systems
+	if [[ ${CMAKE_QA_SRC_DIR_READONLY} && ! ${CMAKE_IN_SOURCE_BUILD} ]]; then
+		chmod -R a-w "${CMAKE_USE_DIR}"
 	fi
 
+	_CMAKE_PREPARE_HAS_RUN=1
+}
+
+# @FUNCTION: cmake_src_prepare
+# @DESCRIPTION:
+# Apply ebuild and user patches via default_src_prepare.  In case of
+# conflict with another eclass' src_prepare phase, use cmake_prepare
+# instead (EAPI-8 only).
+# In EAPI-7, this phase *must* be run or cmake_src_configure will fail.
+cmake_src_prepare() {
+	debug-print-function ${FUNCNAME} "$@"
+
 	if [[ ${EAPI} == 7 ]]; then
+		pushd "${S}" > /dev/null || die # workaround from cmake-utils
+			default_src_prepare
+			_cmake_check_build_dir
+			# check if CMakeLists.txt exists and if not then die
+			if [[ ! -e ${CMAKE_USE_DIR}/CMakeLists.txt ]] ; then
+				eerror "Unable to locate CMakeLists.txt under:"
+				eerror "\"${CMAKE_USE_DIR}/CMakeLists.txt\""
+				eerror "Consider not inheriting the cmake eclass."
+				die "FATAL: Unable to find CMakeLists.txt"
+			fi
+			local modules_list
+			if [[ $(declare -p CMAKE_REMOVE_MODULES_LIST) != "declare -a"* ]]; then
+				modules_list=( ${CMAKE_REMOVE_MODULES_LIST} )
+			else
+				modules_list=( "${CMAKE_REMOVE_MODULES_LIST[@]}" )
+			fi
+			local name
+			for name in "${modules_list[@]}" ; do
+				find "${S}" -name "${name}.cmake" -exec rm -v {} + || die
+			done
+			_cmake_modify-cmakelists # Remove dangerous things.
+			_cmake4_callout
 		popd > /dev/null || die
-	fi
-
-	# Make ${CMAKE_USE_DIR} (in EAPI-7: ${S}) read-only in order to detect
-	# broken build systems.
-	if [[ ${CMAKE_QA_SRC_DIR_READONLY} && ! ${CMAKE_IN_SOURCE_BUILD} ]]; then
-		if [[ ${EAPI} == 7 ]]; then
+		# Make ${S} read-only in order to detect broken build systems
+		if [[ ${CMAKE_QA_SRC_DIR_READONLY} && ! ${CMAKE_IN_SOURCE_BUILD} ]]; then
 			chmod -R a-w "${S}"
-		else
-			chmod -R a-w "${CMAKE_USE_DIR}"
 		fi
+		_CMAKE_PREPARE_HAS_RUN=1
+		eqawarn "QA Notice: cmake.eclass will throw unsupported EAPI=7 error after 2025-11-01."
+	else
+		default_src_prepare
+		cmake_prepare
 	fi
-
-	_CMAKE_SRC_PREPARE_HAS_RUN=1
 }
 
 # @VARIABLE: MYCMAKEARGS
@@ -490,8 +522,13 @@ cmake_src_prepare() {
 cmake_src_configure() {
 	debug-print-function ${FUNCNAME} "$@"
 
-	[[ ${_CMAKE_SRC_PREPARE_HAS_RUN} ]] || \
-		die "FATAL: cmake_src_prepare has not been run"
+	if [[ -z ${_CMAKE_PREPARE_HAS_RUN} ]]; then
+		if [[ ${EAPI} == 7 ]]; then
+			die "FATAL: cmake_src_prepare has not been run"
+		else
+			die "FATAL: cmake_src_prepare (or cmake_prepare) has not been run"
+		fi
+	fi
 
 	_cmake_check_build_dir
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-10-05 21:50 Andreas Sturmlechner
  0 siblings, 0 replies; 6663+ messages in thread
From: Andreas Sturmlechner @ 2025-10-05 21:50 UTC (permalink / raw
  To: gentoo-commits
commit:     181e38741a32cebc27dcc81bcf359a4c6dedc90f
Author:     Petr Vaněk <arkamar <AT> gentoo <DOT> org>
AuthorDate: Fri Oct  3 11:54:00 2025 +0000
Commit:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
CommitDate: Sun Oct  5 21:49:43 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=181e3874
cmake.eclass: Update CMAKE_WARN_UNUSED_CLI default value description
This commit updates the CMAKE_WARN_UNUSED_CLI variable description to
accurately reflect the default value set to "yes".
The CMAKE_WARN_UNUSED_CLI default value was changed to "yes" in
cmake-utils.eclass in commit 3600c714eb86 ("cmake-utils.eclass: enable
CMAKE_WARN_UNUSED_CLI for EAPI 6"), but the description did not reflect
it. This description was later reused in the new cmake.eclass [1]
without reflecting the default value either.
Fixes: 9053737a4e16 ("cmake.eclass: New eclass, EAPI-7 only cleanup of cmake-utils") [1]
Signed-off-by: Petr Vaněk <arkamar <AT> gentoo.org>
Signed-off-by: Andreas Sturmlechner <asturm <AT> gentoo.org>
 eclass/cmake.eclass | 3 ++-
 1 file changed, 2 insertions(+), 1 deletion(-)
diff --git a/eclass/cmake.eclass b/eclass/cmake.eclass
index 37b181df927b..5b3d135018e8 100644
--- a/eclass/cmake.eclass
+++ b/eclass/cmake.eclass
@@ -106,7 +106,8 @@ fi
 # @DESCRIPTION:
 # Warn about variables that are declared on the command line
 # but not used. Might give false-positives.
-# "no" to disable (default) or anything else to enable.
+# "no" to disable or anything else to enable.
+# The default is set to "yes" (enabled).
 : "${CMAKE_WARN_UNUSED_CLI:=yes}"
 
 # @ECLASS_VARIABLE: CMAKE_EXTRA_CACHE_FILE
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-10-09  2:25 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-10-09  2:25 UTC (permalink / raw
  To: gentoo-commits
commit:     0f1e557df0089dc1f269f23f60edf71c56bc330f
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Thu Oct  9 01:56:50 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Thu Oct  9 02:17:20 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=0f1e557d
llvm.org.eclass: Bump release keys
Technically only 21.1.3 needs new keys but no point in splitting
since we push keys with stable keywords, and the old keys are included.
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index b9ee50fa2492..b2c9dced5ea5 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -271,7 +271,7 @@ llvm.org_set_globals() {
 			fi
 			BDEPEND+="
 				verify-sig? (
-					>=sec-keys/openpgp-keys-llvm-20.1.5
+					>=sec-keys/openpgp-keys-llvm-21.1.3
 				)
 			"
 			VERIFY_SIG_OPENPGP_KEY_PATH=/usr/share/openpgp-keys/llvm.asc
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-10-11  7:08 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-10-11  7:08 UTC (permalink / raw
  To: gentoo-commits
commit:     6bb573b35fd1a692d222304b8ce6f168b0026869
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Oct 11 03:19:12 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Oct 11 07:07:20 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=6bb573b3
toolchain.eclass: stop building JIT separately
We introduced a split for libgccjit because it needs --enable-host-shared
for bug #843341, but I think this was a mistake in the end:
* We don't bootstrap that first, host-shared build because otherwise the
  build would take even longer;
* gcc PR117047 is an example where not-bootstrapping causes very-hard-to-debug
  problems because libgccjit may be compiled differently by a newer compiler,
  but you can't just rebuild GCC once to observe that. Even knowing this*,
  I was stumped by it for some time;
* It introduces complexities into the ebuild and it's already complex enough.
  See bug #954077 and bug #953823;
* We want to support rust_codegen_gcc (a rustc codegen backend using libgccjit)
  in the future. If we do that, we want a bootstrapped build for libgccjit
  to know it's reliable;
* The test setup as-is doesn't run tests for the first build;
* On slower machines, that first "wasted" build is pretty noticeable
  and slow.
I think any possible slowdown should be mitigated by using LTO and possibly
-fno-semantic-interposition for GCC, which users are free to do.
Bug: https://bugs.gentoo.org/843341
Bug: https://bugs.gentoo.org/954077
Bug: https://bugs.gentoo.org/953823
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 112 +++++++-----------------------------------------
 1 file changed, 15 insertions(+), 97 deletions(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 5e9a6bcad9ad..c09a7da14354 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -1295,6 +1295,7 @@ toolchain_src_configure() {
 	is_cobol && GCC_LANG+=",cobol"
 	is_modula2 && GCC_LANG+=",m2"
 	is_rust && GCC_LANG+=",rust"
+	is_jit && GCC_LANG+=",jit"
 
 	_need_ada_bootstrap_mangling() {
 		if [[ ${CATEGORY}/${PN} == dev-lang/gnat-gpl ]] ; then
@@ -1874,6 +1875,14 @@ toolchain_src_configure() {
 		confgcc+=( --with-gxx-libcxx-include-dir="${ESYSROOT}"/usr/include/c++/v1 )
 	fi
 
+	if is_jit || _tc_use_if_iuse libgdiagnostics ; then
+		confgcc+=( --enable-host-shared )
+	fi
+
+	if tc_version_is_at_least 15.1 ${PV} ; then
+		confgcc+=( $(use_enable libgdiagnostics) )
+	fi
+
 	# TODO: Ignore RCs here (but TOOLCHAIN_IS_RC isn't yet an eclass var)
 	if [[ ${PV} == *_p* && -f "${S}"/gcc/doc/gcc.info ]] ; then
 		# Safeguard against https://gcc.gnu.org/PR106899 being fixed
@@ -1924,66 +1933,6 @@ toolchain_src_configure() {
 		gcc_shell="${BROOT}"/bin/sh
 	fi
 
-	if is_jit || _tc_use_if_iuse libgdiagnostics ; then
-		einfo "Configuring shared gcc for JIT/libgdiagnostics"
-
-		local confgcc_jit=(
-			"${confgcc[@]}"
-
-			--enable-lto
-			--disable-analyzer
-			--disable-bootstrap
-			--disable-cet
-			--disable-default-pie
-			--disable-default-ssp
-			--disable-gcov
-			--disable-libada
-			--disable-libatomic
-			--disable-libgomp
-			--disable-libitm
-			--disable-libquadmath
-			--disable-libsanitizer
-			--disable-libssp
-			--disable-libstdcxx-pch
-			--disable-libvtv
-			--disable-nls
-			--disable-objc-gc
-			--disable-systemtap
-
-			--enable-host-shared
-
-			# Might be used for the just-built GCC. Easier to just
-			# respect USE=graphite here in case the user passes some
-			# graphite flags rather than try strip them out.
-			$(use_with graphite isl)
-			--with-system-zlib
-		)
-
-		if is_jit ; then
-			confgcc_jit+=( --enable-languages=jit )
-		else
-			confgcc_jit+=( --enable-languages=c,c++ )
-		fi
-
-		if tc_has_feature zstd ; then
-			confgcc_jit+=( $(use_with zstd) )
-		fi
-
-		if tc_version_is_at_least 15.1 ${PV} ; then
-			confgcc_jit+=( $(use_enable libgdiagnostics) )
-		fi
-
-		if tc_version_is_at_least 13.1 ; then
-			confgcc_jit+=( --disable-fixincludes )
-		fi
-
-		mkdir -p "${WORKDIR}"/build-jit || die
-		pushd "${WORKDIR}"/build-jit > /dev/null || die
-
-		CONFIG_SHELL="${gcc_shell}" edo "${gcc_shell}" "${S}"/configure "${confgcc_jit[@]}"
-		popd > /dev/null || die
-	fi
-
 	CONFIG_SHELL="${gcc_shell}" edo "${gcc_shell}" "${S}"/configure "${confgcc[@]}"
 
 	# Return to whatever directory we were in before
@@ -2401,12 +2350,6 @@ gcc_do_make() {
 		)
 	fi
 
-	if is_jit || _tc_use_if_iuse libgdiagnostics ; then
-		# TODO: docs for jit?
-		einfo "Building JIT"
-		emake -C "${WORKDIR}"/build-jit "${emakeargs[@]}"
-	fi
-
 	einfo "Compiling ${PN} (${GCC_MAKE_TARGET})..."
 	pushd "${WORKDIR}"/build >/dev/null || die
 	emake "${emakeargs[@]}" ${GCC_MAKE_TARGET}
@@ -2430,7 +2373,6 @@ gcc_do_make() {
 
 #---->> src_test <<----
 
-# TODO: add JIT testing
 toolchain_src_test() {
 	# GCC's testsuite is a special case.
 	#
@@ -2609,28 +2551,6 @@ toolchain_src_install() {
 		done < <(find gcc/include*/ -name '*.h')
 	fi
 
-	if is_jit || _tc_use_if_iuse libgdiagnostics ; then
-		# See https://gcc.gnu.org/onlinedocs/gcc-11.3.0/jit/internals/index.html#packaging-notes
-		# and bug #843341.
-		#
-		# Both of the non-JIT and JIT builds are configured to install to $(DESTDIR)
-		# Install the configuration with --enable-host-shared first
-		# *then* the one without, so that the faster build
-		# of "cc1" et al overwrites the slower build.
-		#
-		# Do the 'make install' from the build directory
-		pushd "${WORKDIR}"/build-jit > /dev/null || die
-		S="${WORKDIR}"/build-jit emake DESTDIR="${D}" -j1 install
-
-		# This one comes with binutils
-		find "${ED}" -name libiberty.a -delete || die
-
-		# Move the libraries to the proper location
-		gcc_movelibs
-
-		popd > /dev/null || die
-	fi
-
 	# Do the 'make install' from the build directory
 	#
 	# Unfortunately, we have to use -j1 for make install. Upstream
@@ -2838,16 +2758,14 @@ gcc_movelibs() {
 
 	# libgccjit gets installed to /usr/lib, not /usr/$(get_libdir). Probably
 	# due to a bug in gcc build system.
-	if [[ ${PWD} == "${WORKDIR}"/build-jit ]] ; then
-		dodir "${LIBPATH#${EPREFIX}}"
+	dodir "${LIBPATH#${EPREFIX}}"
 
-		if is_jit ; then
-			mv "${ED}"/usr/lib/libgccjit* "${D}${LIBPATH}" || die
-		fi
+	if is_jit ; then
+		mv "${ED}"/usr/lib/libgccjit* "${D}${LIBPATH}" || die
+	fi
 
-		if _tc_use_if_iuse libgdiagnostics ; then
-			mv "${ED}"/usr/lib/libgdiagnostics* "${D}${LIBPATH}" || die
-		fi
+	if _tc_use_if_iuse libgdiagnostics ; then
+		mv "${ED}"/usr/lib/libgdiagnostics* "${D}${LIBPATH}" || die
 	fi
 
 	# For all the libs that are built for CTARGET, move them into the
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-10-11  7:12 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-10-11  7:12 UTC (permalink / raw
  To: gentoo-commits
commit:     173a936ba3b86bb4c4b6201fd5b4f75e08f6b9fa
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Oct 11 07:08:55 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Oct 11 07:08:55 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=173a936b
toolchain.eclass: cleanup one more bit of build-jit cruft
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index c09a7da14354..0acb2cb365b7 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -3170,7 +3170,7 @@ toolchain_death_notice() {
 	# TODO: For bootstrap comparison failures, include the stage2 & stage3
 	# differing objects to avoid having to ask reporters to manually collect...
 	local dir
-	for dir in "${WORKDIR}"/build-jit "${WORKDIR}"/build ; do
+	for dir in "${WORKDIR}"/build ; do
 		if [[ -e "${dir}" ]] ; then
 			pushd "${WORKDIR}" >/dev/null
 			(echo '' | $(tc-getCC ${CTARGET}) ${CFLAGS} -v -E - 2>&1) > "${dir}"/gccinfo.log
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-10-11 19:54 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-10-11 19:54 UTC (permalink / raw
  To: gentoo-commits
commit:     ebd5ca0e5ec46d85a9f0ffbeb826f4982cf3000a
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sat Oct 11 19:45:49 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Sat Oct 11 19:45:49 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=ebd5ca0e
llvm.org.eclass: Add 22.0.0_pre20251011 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index b2c9dced5ea5..b2e688bc4ebe 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -72,6 +72,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 			_LLVM_SOURCE_TYPE=snapshot
 
 			case ${PV} in
+				22.0.0_pre20251011)
+					EGIT_COMMIT=6a0e5b2fd7c340a872ae1e011cfb9de0d188feba
+					;;
 				22.0.0_pre20251004)
 					EGIT_COMMIT=b1e29ec3b73b9dd06656c7e30ace597ff72cde70
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-10-12 14:20 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-10-12 14:20 UTC (permalink / raw
  To: gentoo-commits
commit:     e1b2c889ed20b28100ba601b415925a2b73cde80
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Oct 12 14:18:47 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Oct 12 14:19:36 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=e1b2c889
toolchain-funcs.eclass: fix tc-check-min_ver example
$ python3.13 -c 'import portage; print(portage.versions.vercmp("13.2.0", "13.2"))'
1
Bug: https://bugs.gentoo.org/964195
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain-funcs.eclass | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/eclass/toolchain-funcs.eclass b/eclass/toolchain-funcs.eclass
index fa2820035cb7..3787a84805f6 100644
--- a/eclass/toolchain-funcs.eclass
+++ b/eclass/toolchain-funcs.eclass
@@ -659,11 +659,11 @@ _tc-has-openmp() {
 # build-time, e.g.
 # @CODE
 # pkg_pretend() {
-#	[[ ${MERGE_TYPE} != binary ]] && tc-check-min_ver gcc 13.2.0
+#	[[ ${MERGE_TYPE} != binary ]] && tc-check-min_ver gcc 13.2
 # }
 #
 # pkg_setup() {
-#	[[ ${MERGE_TYPE} != binary ]] && tc-check-min_ver gcc 13.2.0
+#	[[ ${MERGE_TYPE} != binary ]] && tc-check-min_ver gcc 13.2
 # }
 # @CODE
 tc-check-min_ver() {
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-10-16 18:02 Nowa Ammerlaan
  0 siblings, 0 replies; 6663+ messages in thread
From: Nowa Ammerlaan @ 2025-10-16 18:02 UTC (permalink / raw
  To: gentoo-commits
commit:     5e2cec54f6970c5edba0c4fe85e37f1c6652f844
Author:     Nowa Ammerlaan <nowa <AT> gentoo <DOT> org>
AuthorDate: Thu Oct 16 17:58:31 2025 +0000
Commit:     Nowa Ammerlaan <nowa <AT> gentoo <DOT> org>
CommitDate: Thu Oct 16 18:01:54 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=5e2cec54
kernel-build.eclass: avoid setting root in generic-uki
This we added originally because several tool got confused when there
is no root= at all. This has since been resolved and I have been
running without any root= set for several months without problems.
Setting root=/dev/gpt-auto-generator actually breaks automatic
decryption of LUKS volumes, so lets get rid of it. Functionally
nothing else changes since the gpt-auto-generator will also run if
root is not set or empty.
Signed-off-by: Nowa Ammerlaan <nowa <AT> gentoo.org>
 eclass/kernel-build.eclass | 16 ++++++++--------
 1 file changed, 8 insertions(+), 8 deletions(-)
diff --git a/eclass/kernel-build.eclass b/eclass/kernel-build.eclass
index 2b16d0a226dd..aa0f7b5894ea 100644
--- a/eclass/kernel-build.eclass
+++ b/eclass/kernel-build.eclass
@@ -113,10 +113,10 @@ IUSE="+strip"
 # empty, then the contents are used as the first kernel cmdline
 # option of the multi-profile generic UKI. Supplementing the four
 # standard options of:
-# - root=/dev/gpt-auto-root ro
-# - root=/dev/gpt-auto-root ro quiet splash
-# - root=/dev/gpt-auto-root ro lockdown=integrity
-# - root=/dev/gpt-auto-root ro quiet splash lockdown=integrity
+# - ro
+# - ro quiet splash
+# - ro lockdown=integrity
+# - ro quiet splash lockdown=integrity
 
 if [[ ${KERNEL_IUSE_MODULES_SIGN} ]]; then
 	IUSE+=" modules-sign"
@@ -581,10 +581,10 @@ kernel-build_src_install() {
 			)
 
 			cmdlines+=(
-				"root=/dev/gpt-auto-root ro"
-				"root=/dev/gpt-auto-root ro quiet splash"
-				"root=/dev/gpt-auto-root ro lockdown=integrity"
-				"root=/dev/gpt-auto-root ro quiet splash lockdown=integrity"
+				"ro"
+				"ro quiet splash"
+				"ro lockdown=integrity"
+				"ro quiet splash lockdown=integrity"
 			)
 
 			local ukify_args=(
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-10-16 19:14 Andreas Sturmlechner
  0 siblings, 0 replies; 6663+ messages in thread
From: Andreas Sturmlechner @ 2025-10-16 19:14 UTC (permalink / raw
  To: gentoo-commits
commit:     576dc3cc0f0f1c629caaf855e4781bf3c6c16f47
Author:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
AuthorDate: Mon Oct 13 20:15:45 2025 +0000
Commit:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
CommitDate: Thu Oct 16 19:14:24 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=576dc3cc
cmake.eclass: For ECM, check and warn about <3.16 CMake minimum version
ECM (extra-cmake-modules) mostly concerns KDE but also several third party
packages. ECM has been warning about that since ECM 5.100, which was released
in Nov 2022.
- New variable CMAKE_ECM_MODE (values: auto,true,false)
  If "auto", tries to detect use of find_package(ECM) in CMakeLists.txt
  Also use instead of _ECM_ECLASS check in cmake_src_configure to adjust
  gentoo_common_config.cmake for ECM settings independently of ecm.eclass
- _cmake_minreqver-check():
  Results are stored in new _CMAKE_MINREQVER_CMAKE316 array.
- _cmake_minreqver-info():
  Only the latest relevant warning is shown as eqawarn - and only prefixed
  as "QA Notice" if a preceding QA Notice didn't strike already.
  This means for a build system using ECM with detected <3.5 versions:
  - CMake < 3.5: QA notice with file listing
  - CMake < 3.10: *No* warning but file listing if array is non-empty
  - CMake < 3.16: Warning with file listing
Signed-off-by: Andreas Sturmlechner <asturm <AT> gentoo.org>
 eclass/cmake.eclass | 54 ++++++++++++++++++++++++++++++++++++++++++++++++++---
 1 file changed, 51 insertions(+), 3 deletions(-)
diff --git a/eclass/cmake.eclass b/eclass/cmake.eclass
index 3535a95da4aa..df91ba0f4a0f 100644
--- a/eclass/cmake.eclass
+++ b/eclass/cmake.eclass
@@ -110,6 +110,15 @@ fi
 # The default is set to "yes" (enabled).
 : "${CMAKE_WARN_UNUSED_CLI:=yes}"
 
+# @ECLASS_VARIABLE: CMAKE_ECM_MODE
+# @DEFAULT_UNSET
+# @DESCRIPTION:
+# Default value is "auto", which means _cmake_modify-cmakelists will make an
+# effort to detect find_package(ECM) in CMakeLists.txt.  If set to true, make
+# extra checks and add common config settings related to ECM (KDE Extra CMake
+# Modules).  If set to false, do nothing.
+: "${CMAKE_ECM_MODE:=auto}"
+
 # @ECLASS_VARIABLE: CMAKE_EXTRA_CACHE_FILE
 # @USER_VARIABLE
 # @DEFAULT_UNSET
@@ -141,6 +150,15 @@ _CMAKE_MINREQVER_CMAKE305=()
 # already added to _CMAKE_MINREQVER_CMAKE305.
 _CMAKE_MINREQVER_CMAKE310=()
 
+# @ECLASS_VARIABLE: _CMAKE_MINREQVER_CMAKE316
+# @DEFAULT_UNSET
+# @DESCRIPTION:
+# Internal array containing <file>:<version> tuples detected by
+# _cmake_minreqver-check() for any CMakeLists.txt with cmake_minimum_required
+# version lower than 3.16 (causes ECM warnings since 5.100), on top of those
+# already added to _CMAKE_MINREQVER_CMAKE305 and _CMAKE_MINREQVER_CMAKE310.
+_CMAKE_MINREQVER_CMAKE316=()
+
 # @ECLASS_VARIABLE: CMAKE_QA_SRC_DIR_READONLY
 # @USER_VARIABLE
 # @DEFAULT_UNSET
@@ -161,6 +179,14 @@ _CMAKE_MINREQVER_CMAKE310=()
 [[ ${WANT_CMAKE} ]] && die "WANT_CMAKE has been removed and is a no-op"
 [[ ${PREFIX} ]] && die "PREFIX has been removed and is a no-op"
 
+case ${CMAKE_ECM_MODE} in
+	auto|true|false) ;;
+	*)
+		eerror "Unknown value for \${CMAKE_ECM_MODE}"
+		die "Value ${CMAKE_ECM_MODE} is not supported"
+		;;
+esac
+
 case ${CMAKE_MAKEFILE_GENERATOR} in
 	emake)
 		BDEPEND="dev-build/make"
@@ -377,6 +403,11 @@ _cmake_minreqver-check() {
 			_CMAKE_MINREQVER_CMAKE310+=( "${file}":"${ver}" )
 			chk=0
 		fi
+		# we don't want duplicates that were already flagged
+		if [[ $chk != 0 ]] && ver_test "${ver}" -lt "3.16"; then
+			_CMAKE_MINREQVER_CMAKE316+=( "${file}":"${ver}" )
+			chk=0
+		fi
 	fi
 	return ${chk}
 }
@@ -390,6 +421,8 @@ _cmake_minreqver-info() {
 	local warnlvl
 	[[ -n ${_CMAKE_MINREQVER_CMAKE305[@]} ]] && warnlvl=305
 	[[ -n ${_CMAKE_MINREQVER_CMAKE310[@]} ]] || [[ ${warnlvl} ]] && warnlvl=310
+	[[ ${CMAKE_ECM_MODE} == true ]] &&
+		{ [[ -n ${_CMAKE_MINREQVER_CMAKE316[@]} ]] || [[ ${warnlvl} ]] } && warnlvl=316
 
 	local weak_qaw="QA Notice: "
 	minreqver_qanotice() {
@@ -405,13 +438,18 @@ _cmake_minreqver-info() {
 				eqawarn "If not fixed in upstream's code repository, we should make sure they are aware."
 				eqawarn "See also tracker bug #964405; check existing or file a new bug for this package."
 				;;
+			316)
+				eqawarn "${weak_qaw}Compatibility w/ CMake < 3.16 will be removed in future ECM release."
+				eqawarn "If not fixed in upstream's code repository, we should make sure they are aware."
+				eqawarn "See also tracker bug #964407; check existing or file a new bug for this package."
+				;;
 		esac
 		eqawarn
 		weak_qaw="" # weak notice: no "QA Notice" starting with second call
 	}
 
+	local info
 	minreqver_listing() {
-		local info
 		case ${1} in
 			305)
 				eqawarn "The following CMakeLists.txt files are causing errors:"
@@ -425,6 +463,13 @@ _cmake_minreqver-info() {
 					eqawarn
 				fi
 				;;
+			316)
+				if [[ ${warnlvl} -ge 316 ]] && [[ -n ${_CMAKE_MINREQVER_CMAKE316[@]} ]]; then
+					eqawarn "The following CMakeLists.txt files are causing warnings:"
+					for info in ${_CMAKE_MINREQVER_CMAKE316[*]}; do eqawarn "  ${info}"; done
+					eqawarn
+				fi
+				;;
 		esac
 	}
 
@@ -436,7 +481,7 @@ _cmake_minreqver-info() {
 	# for warnings, we only want the latest relevant one, but list all flagged files
 	if [[ ${warnlvl} -ge 310 ]]; then
 		minreqver_qanotice ${warnlvl}
-		minreqver_listing 310
+		for info in 310 316; do minreqver_listing ${info}; done
 	fi
 	if [[ ${warnlvl} ]]; then
 		if [[ -n ${_CMAKE_MINREQVER_CMAKE305[@]} ]] && has_version -b ">=dev-build/cmake-4"; then
@@ -477,6 +522,9 @@ _cmake_modify-cmakelists() {
 				einfo "${mod_line:22:99}"
 			done
 		fi
+		if [[ ${CMAKE_ECM_MODE} == auto ]] && grep -Eq "\s*find_package\s*\(\s*ECM " "${file}"; then
+			CMAKE_ECM_MODE=true
+		fi
 		# Detect unsupported minimum CMake versions unless CMAKE_QA_COMPAT_SKIP is set
 		if ! [[ ${CMAKE_QA_COMPAT_SKIP} ]]; then
 			_cmake_minreqver-check "${file#"${CMAKE_USE_DIR}/"}"
@@ -725,7 +773,7 @@ cmake_src_configure() {
 		set(CMAKE_LINK_WARNING_AS_ERROR OFF CACHE BOOL "")
 	_EOF_
 
-	if [[ -n ${_ECM_ECLASS} ]]; then
+	if [[ ${CMAKE_ECM_MODE} == true ]]; then
 		cat >> ${common_config} <<- _EOF_ || die
 			set(ECM_DISABLE_QMLPLUGINDUMP ON CACHE BOOL "")
 			set(ECM_DISABLE_APPSTREAMTEST ON CACHE BOOL "")
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-10-16 19:14 Andreas Sturmlechner
  0 siblings, 0 replies; 6663+ messages in thread
From: Andreas Sturmlechner @ 2025-10-16 19:14 UTC (permalink / raw
  To: gentoo-commits
commit:     5579f4902a1d69f99115789f4c7bd89e07e58fc8
Author:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
AuthorDate: Mon Oct 13 15:44:49 2025 +0000
Commit:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
CommitDate: Thu Oct 16 19:14:23 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=5579f490
cmake.eclass: Set CMAKE_POLICY_DEFAULT_CMP0094=NEW to fix FindPython
See also:
https://cmake.org/cmake/help/latest/policy/CMP0094.html
Closes: https://bugs.gentoo.org/959154
Signed-off-by: Andreas Sturmlechner <asturm <AT> gentoo.org>
 eclass/cmake.eclass | 3 ++-
 1 file changed, 2 insertions(+), 1 deletion(-)
diff --git a/eclass/cmake.eclass b/eclass/cmake.eclass
index 7c825f87c367..e132b0b53deb 100644
--- a/eclass/cmake.eclass
+++ b/eclass/cmake.eclass
@@ -631,7 +631,8 @@ cmake_src_configure() {
 		set(CMAKE_USER_MAKE_RULES_OVERRIDE "${build_rules}" CACHE FILEPATH "Gentoo override rules")
 		set(CMAKE_INSTALL_DOCDIR "${EPREFIX}/usr/share/doc/${PF}" CACHE PATH "")
 		set(BUILD_SHARED_LIBS ON CACHE BOOL "")
-		set(Python3_FIND_UNVERSIONED_NAMES FIRST CACHE STRING "")
+		set(Python3_FIND_UNVERSIONED_NAMES FIRST CACHE STRING "") # FindPythonInterp, Gentoo-bug #835799
+		set(CMAKE_POLICY_DEFAULT_CMP0094 NEW CACHE STRING "" ) # FindPython, Gentoo-bug #959154
 		set(CMAKE_DISABLE_PRECOMPILE_HEADERS ON CACHE BOOL "")
 		set(CMAKE_INTERPROCEDURAL_OPTIMIZATION OFF CACHE BOOL "")
 		set(CMAKE_TLS_VERIFY ON CACHE BOOL "")
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-10-16 19:14 Andreas Sturmlechner
  0 siblings, 0 replies; 6663+ messages in thread
From: Andreas Sturmlechner @ 2025-10-16 19:14 UTC (permalink / raw
  To: gentoo-commits
commit:     8d6be776fa06e7e32fa9e2fb369286de59f3a0de
Author:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
AuthorDate: Wed Oct 15 14:46:43 2025 +0000
Commit:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
CommitDate: Thu Oct 16 19:14:25 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=8d6be776
ecm-common.eclass: Raise CMake minimum to 3.31
cmake.eclass remains at 3.28 in ::gentoo for a while, so having to
define the BDEPEND as well here.
Signed-off-by: Andreas Sturmlechner <asturm <AT> gentoo.org>
 eclass/ecm-common.eclass | 9 ++++++---
 1 file changed, 6 insertions(+), 3 deletions(-)
diff --git a/eclass/ecm-common.eclass b/eclass/ecm-common.eclass
index 7f5d3d1e9915..9db2d68e6f41 100644
--- a/eclass/ecm-common.eclass
+++ b/eclass/ecm-common.eclass
@@ -1,4 +1,4 @@
-# Copyright 2024 Gentoo Authors
+# Copyright 2024-2025 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 # @ECLASS: ecm-common.eclass
@@ -133,7 +133,10 @@ fi
 
 DESCRIPTION="Common files for ${PN/-common/}"
 
-BDEPEND=">=kde-frameworks/extra-cmake-modules-${KFMIN}:*"
+BDEPEND="
+	>=dev-build/cmake-3.31.9-r1
+	>=kde-frameworks/extra-cmake-modules-${KFMIN}:*
+"
 
 case ${ECM_I18N} in
 	true)
@@ -185,7 +188,7 @@ fi
 # Create a CMakeLists.txt file with minimum ECM setup.
 _ecm-common_preamble() {
 	cat > CMakeLists.txt <<- _EOF_ || die
-		cmake_minimum_required(VERSION 3.16)
+		cmake_minimum_required(VERSION 3.31)
 		project(${PN} VERSION ${PV})
 
 		find_package(ECM "${KFMIN}" REQUIRED NO_MODULE)
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-10-16 19:14 Andreas Sturmlechner
  0 siblings, 0 replies; 6663+ messages in thread
From: Andreas Sturmlechner @ 2025-10-16 19:14 UTC (permalink / raw
  To: gentoo-commits
commit:     5c3a3f9ac5533ec04815057f64600f665d52068c
Author:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
AuthorDate: Mon Oct 13 21:07:55 2025 +0000
Commit:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
CommitDate: Thu Oct 16 19:14:24 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=5c3a3f9a
cmake.eclass: Don't pass workaround when CMAKE_QA_COMPAT_SKIP is set
If QA checks are skipped, then it is counterproductive to hide
resulting errors by passing -DCMAKE_POLICY_VERSION_MINIMUM=3.5.
Better warn about the CMake 4 workaround possibly only getting the build
system to another error.
Bug: https://bugs.gentoo.org/951350
Signed-off-by: Andreas Sturmlechner <asturm <AT> gentoo.org>
 eclass/cmake.eclass | 7 +++++--
 1 file changed, 5 insertions(+), 2 deletions(-)
diff --git a/eclass/cmake.eclass b/eclass/cmake.eclass
index ebc78a333eef..91928b65b974 100644
--- a/eclass/cmake.eclass
+++ b/eclass/cmake.eclass
@@ -386,7 +386,8 @@ _cmake_minreqver-info() {
 		eqawarn
 		if has_version -b ">=dev-build/cmake-4"; then
 			eqawarn "CMake 4 detected; building with -DCMAKE_POLICY_VERSION_MINIMUM=3.5"
-			eqawarn "This is merely a workaround and *not* a permanent fix."
+			eqawarn "This is merely a workaround to avoid CMake Error and *not* a permanent fix;"
+			eqawarn "there may be new build or runtime bugs as a result."
 			eqawarn
 		fi
 		eqawarn "An upstreamable patch should take any resulting CMake policy changes"
@@ -748,7 +749,9 @@ cmake_src_configure() {
 		cmakeargs+=( -C "${CMAKE_EXTRA_CACHE_FILE}" )
 	fi
 
-	if [[ -n ${_CMAKE_MINREQVER_CMAKE305[@]} ]] && has_version -b ">=dev-build/cmake-4"; then
+	if ! [[ ${CMAKE_QA_COMPAT_SKIP} ]] &&
+		[[ -n ${_CMAKE_MINREQVER_CMAKE305[@]} ]] &&
+		has_version -b ">=dev-build/cmake-4"; then
 		cmakeargs+=( -DCMAKE_POLICY_VERSION_MINIMUM=3.5 )
 	fi
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-10-16 19:14 Andreas Sturmlechner
  0 siblings, 0 replies; 6663+ messages in thread
From: Andreas Sturmlechner @ 2025-10-16 19:14 UTC (permalink / raw
  To: gentoo-commits
commit:     1269bac7932c667d9bd716aad07efebd00de9e95
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Oct  9 21:55:50 2025 +0000
Commit:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
CommitDate: Thu Oct 16 19:14:16 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=1269bac7
cmake.eclass: set -DCMAKE_LINK_WARNING_AS_ERROR=OFF
As we already do for compiler -Werror.
Closes: https://bugs.gentoo.org/963830
Signed-off-by: Sam James <sam <AT> gentoo.org>
Signed-off-by: Andreas Sturmlechner <asturm <AT> gentoo.org>
 eclass/cmake.eclass | 1 +
 1 file changed, 1 insertion(+)
diff --git a/eclass/cmake.eclass b/eclass/cmake.eclass
index 7526d492493f..7c825f87c367 100644
--- a/eclass/cmake.eclass
+++ b/eclass/cmake.eclass
@@ -636,6 +636,7 @@ cmake_src_configure() {
 		set(CMAKE_INTERPROCEDURAL_OPTIMIZATION OFF CACHE BOOL "")
 		set(CMAKE_TLS_VERIFY ON CACHE BOOL "")
 		set(CMAKE_COMPILE_WARNING_AS_ERROR OFF CACHE BOOL "")
+		set(CMAKE_LINK_WARNING_AS_ERROR OFF CACHE BOOL "")
 	_EOF_
 
 	if [[ -n ${_ECM_ECLASS} ]]; then
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-10-16 19:14 Andreas Sturmlechner
  0 siblings, 0 replies; 6663+ messages in thread
From: Andreas Sturmlechner @ 2025-10-16 19:14 UTC (permalink / raw
  To: gentoo-commits
commit:     5c41ba92597c7c41e5b7015ab920b02fc43fb79a
Author:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
AuthorDate: Mon Oct 13 20:21:49 2025 +0000
Commit:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
CommitDate: Thu Oct 16 19:14:24 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=5c41ba92
ecm.eclass: Set CMAKE_ECM_MODE=true pre-inheriting cmake
Signed-off-by: Andreas Sturmlechner <asturm <AT> gentoo.org>
 eclass/ecm.eclass | 5 +++++
 1 file changed, 5 insertions(+)
diff --git a/eclass/ecm.eclass b/eclass/ecm.eclass
index 31315f2b8d75..f7a77c35d5f2 100644
--- a/eclass/ecm.eclass
+++ b/eclass/ecm.eclass
@@ -29,6 +29,11 @@ esac
 if [[ -z ${_ECM_ECLASS} ]]; then
 _ECM_ECLASS=1
 
+# @ECLASS_VARIABLE: CMAKE_ECM_MODE
+# @DESCRIPTION:
+# For proper description see cmake.eclass manpage.
+CMAKE_ECM_MODE=true
+
 inherit cmake flag-o-matic
 
 if [[ ${EAPI} == 8 ]]; then
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-10-16 19:14 Andreas Sturmlechner
  0 siblings, 0 replies; 6663+ messages in thread
From: Andreas Sturmlechner @ 2025-10-16 19:14 UTC (permalink / raw
  To: gentoo-commits
commit:     49c8c7afd9b25b0dde8051d9bbbe62f5ff510ae7
Author:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
AuthorDate: Sun Oct 12 21:34:57 2025 +0000
Commit:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
CommitDate: Thu Oct 16 19:14:24 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=49c8c7af
cmake.eclass: List CMake files being warned about future compat removal
- _cmake_minreqver-check():
  New _CMAKE_MINREQVER_CMAKE310 array contains a list of <file>:<version>
  tuples with cmake_minimum_required version below 3.10, on top of those
  that weren't already saved in _CMAKE_MINREQVER_CMAKE305.
- _cmake_minreqver-info():
  Future CMake <3.10 compat removal is prefixed as "QA Notice" *only* if the
  preceding CMake <3.5 QA Notice didn't strike already. This is done to avoid
  spamming the bug tracker twice per package about outdated minimum versions.
Signed-off-by: Andreas Sturmlechner <asturm <AT> gentoo.org>
 eclass/cmake.eclass | 81 ++++++++++++++++++++++++++++++++++++++++++++---------
 1 file changed, 68 insertions(+), 13 deletions(-)
diff --git a/eclass/cmake.eclass b/eclass/cmake.eclass
index 91928b65b974..3535a95da4aa 100644
--- a/eclass/cmake.eclass
+++ b/eclass/cmake.eclass
@@ -132,6 +132,15 @@ fi
 # version lower than 3.5.
 _CMAKE_MINREQVER_CMAKE305=()
 
+# @ECLASS_VARIABLE: _CMAKE_MINREQVER_CMAKE310
+# @DEFAULT_UNSET
+# @DESCRIPTION:
+# Internal array containing <file>:<version> tuples detected by
+# _cmake_minreqver-check() for any CMakeLists.txt with cmake_minimum_required
+# version lower than 3.10 (causes CMake warnings as of 4.0) on top of those
+# already added to _CMAKE_MINREQVER_CMAKE305.
+_CMAKE_MINREQVER_CMAKE310=()
+
 # @ECLASS_VARIABLE: CMAKE_QA_SRC_DIR_READONLY
 # @USER_VARIABLE
 # @DEFAULT_UNSET
@@ -363,6 +372,11 @@ _cmake_minreqver-check() {
 			_CMAKE_MINREQVER_CMAKE305+=( "${file}":"${ver}" )
 			chk=0
 		fi
+		# we don't want duplicates that were already flagged
+		if [[ $chk != 0 ]] && ver_test "${ver}" -lt "3.10"; then
+			_CMAKE_MINREQVER_CMAKE310+=( "${file}":"${ver}" )
+			chk=0
+		fi
 	fi
 	return ${chk}
 }
@@ -370,21 +384,62 @@ _cmake_minreqver-check() {
 # @FUNCTION: _cmake_minreqver-info
 # @INTERNAL
 # @DESCRIPTION:
-# QA Notice and file listing for any CMakeLists.txt file unsupported w/ CMake-4.
+# QA Notice and file listings for any CMakeLists.txt file not meeting various
+# minimum standards for cmake_minimum_required.
 _cmake_minreqver-info() {
-	local info
-	if [[ -n ${_CMAKE_MINREQVER_CMAKE305[@]} ]]; then
-		eqawarn "QA Notice: Compatibility with CMake < 3.5 has been removed from CMake 4,"
-		eqawarn "${CATEGORY}/${PN} will fail to build w/o a fix."
-		eqawarn "See also tracker bug #951350; check existing bug or file a new one for"
-		eqawarn "this package, and take it upstream."
-		eqawarn
-		eqawarn "The following CMakeLists.txt files are causing errors:"
-		for info in ${_CMAKE_MINREQVER_CMAKE305[*]}; do
-			eqawarn "  ${info}"
-		done
+	local warnlvl
+	[[ -n ${_CMAKE_MINREQVER_CMAKE305[@]} ]] && warnlvl=305
+	[[ -n ${_CMAKE_MINREQVER_CMAKE310[@]} ]] || [[ ${warnlvl} ]] && warnlvl=310
+
+	local weak_qaw="QA Notice: "
+	minreqver_qanotice() {
+		case ${1} in
+			305)
+				eqawarn "${weak_qaw}Compatibility with CMake < 3.5 has been removed from CMake 4,"
+				eqawarn "${CATEGORY}/${PN} will fail to build w/o a fix."
+				eqawarn "See also tracker bug #951350; check existing bug or file a new one for"
+				eqawarn "this package, and take it upstream."
+				;;
+			310)
+				eqawarn "${weak_qaw}Compatibility with CMake < 3.10 will be removed in a future release."
+				eqawarn "If not fixed in upstream's code repository, we should make sure they are aware."
+				eqawarn "See also tracker bug #964405; check existing or file a new bug for this package."
+				;;
+		esac
 		eqawarn
-		if has_version -b ">=dev-build/cmake-4"; then
+		weak_qaw="" # weak notice: no "QA Notice" starting with second call
+	}
+
+	minreqver_listing() {
+		local info
+		case ${1} in
+			305)
+				eqawarn "The following CMakeLists.txt files are causing errors:"
+				for info in ${_CMAKE_MINREQVER_CMAKE305[*]}; do eqawarn "  ${info}"; done
+				eqawarn
+				;;
+			310)
+				if [[ -n ${_CMAKE_MINREQVER_CMAKE310[@]} ]]; then
+					eqawarn "The following CMakeLists.txt files are causing warnings:"
+					for info in ${_CMAKE_MINREQVER_CMAKE310[*]}; do eqawarn "  ${info}"; done
+					eqawarn
+				fi
+				;;
+		esac
+	}
+
+	# CMake 4-caused error is highest priority and must always be shown
+	if [[ -n ${_CMAKE_MINREQVER_CMAKE305[@]} ]]; then
+		minreqver_qanotice 305
+		minreqver_listing 305
+	fi
+	# for warnings, we only want the latest relevant one, but list all flagged files
+	if [[ ${warnlvl} -ge 310 ]]; then
+		minreqver_qanotice ${warnlvl}
+		minreqver_listing 310
+	fi
+	if [[ ${warnlvl} ]]; then
+		if [[ -n ${_CMAKE_MINREQVER_CMAKE305[@]} ]] && has_version -b ">=dev-build/cmake-4"; then
 			eqawarn "CMake 4 detected; building with -DCMAKE_POLICY_VERSION_MINIMUM=3.5"
 			eqawarn "This is merely a workaround to avoid CMake Error and *not* a permanent fix;"
 			eqawarn "there may be new build or runtime bugs as a result."
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-10-16 19:14 Andreas Sturmlechner
  0 siblings, 0 replies; 6663+ messages in thread
From: Andreas Sturmlechner @ 2025-10-16 19:14 UTC (permalink / raw
  To: gentoo-commits
commit:     1d5d6cb751e803d7e4d525e8a01d72786b400942
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Oct  5 20:34:28 2025 +0000
Commit:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
CommitDate: Thu Oct 16 19:13:57 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=1d5d6cb7
cmake.eclass: disable automagic LTO
Pass -DCMAKE_INTERPROCEDURAL_OPTIMIZATION=OFF to avoid automagically
enabling LTO if the compiler supports it.
Note that unlike what we do w/ meson.eclass, we can't do some magic
with `tc-is-lto` here because CMake doesn't allow refining the parallelism
used. But that's fine.
This change still allows using LTO via *FLAGS which is what we tell
people to do.
Closes: https://bugs.gentoo.org/927157
Signed-off-by: Sam James <sam <AT> gentoo.org>
Signed-off-by: Andreas Sturmlechner <asturm <AT> gentoo.org>
 eclass/cmake.eclass | 1 +
 1 file changed, 1 insertion(+)
diff --git a/eclass/cmake.eclass b/eclass/cmake.eclass
index 0a8b93c215aa..7526d492493f 100644
--- a/eclass/cmake.eclass
+++ b/eclass/cmake.eclass
@@ -633,6 +633,7 @@ cmake_src_configure() {
 		set(BUILD_SHARED_LIBS ON CACHE BOOL "")
 		set(Python3_FIND_UNVERSIONED_NAMES FIRST CACHE STRING "")
 		set(CMAKE_DISABLE_PRECOMPILE_HEADERS ON CACHE BOOL "")
+		set(CMAKE_INTERPROCEDURAL_OPTIMIZATION OFF CACHE BOOL "")
 		set(CMAKE_TLS_VERIFY ON CACHE BOOL "")
 		set(CMAKE_COMPILE_WARNING_AS_ERROR OFF CACHE BOOL "")
 	_EOF_
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-10-16 19:14 Andreas Sturmlechner
  0 siblings, 0 replies; 6663+ messages in thread
From: Andreas Sturmlechner @ 2025-10-16 19:14 UTC (permalink / raw
  To: gentoo-commits
commit:     6d7865c16f4c2eebf5d66a401184324967033d23
Author:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
AuthorDate: Sun Oct 12 21:06:22 2025 +0000
Commit:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
CommitDate: Thu Oct 16 19:14:23 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=6d7865c1
cmake.eclass: Provide a list of CMake files unsupported with CMake 4
Instead of only eqawarning that there is *some* file with a too low
cmake_minimum_required version, print a list of all the CMakeLists.txt
found to be unsupported, and the detected version next to it.
- _CMAKE_MINREQVER_CMAKE305 is either empty (package "passed") or
  contains a list of <file>:<version> tuples to print as eqawarn message
  This replaces _CMAKE_MINREQVER_UNSUPPORTED
- Rename _cmake4_callout() -> _cmake_minreqver-info()
  Provide upstream link with list of CMake policy changes per release
- Prepare for upcoming additional cmake_minimum_version checks
- Rename _cmake_minreqver-lt() -> _cmake_minreqver-check()
  Function now optionally takes one or two args:
  <file>: runs all version checks over <file>
  <file> <version>: only check <version> against <file>
Closes: https://bugs.gentoo.org/951350
Signed-off-by: Andreas Sturmlechner <asturm <AT> gentoo.org>
 eclass/cmake.eclass | 99 ++++++++++++++++++++++++++++++++++-------------------
 1 file changed, 64 insertions(+), 35 deletions(-)
diff --git a/eclass/cmake.eclass b/eclass/cmake.eclass
index e132b0b53deb..ebc78a333eef 100644
--- a/eclass/cmake.eclass
+++ b/eclass/cmake.eclass
@@ -124,11 +124,13 @@ fi
 # If set, skip detection of CMakeLists.txt unsupported in CMake 4 in case of
 # false positives (e.g. unused outdated bundled libs).
 
-# @ECLASS_VARIABLE: _CMAKE_MINREQVER_UNSUPPORTED
+# @ECLASS_VARIABLE: _CMAKE_MINREQVER_CMAKE305
 # @DEFAULT_UNSET
 # @DESCRIPTION:
-# Internal status set by _cmake_minreqver-lt(); is true if an unsupported
-# cmake_minimum_required value was detected.
+# Internal array containing <file>:<version> tuples detected by
+# _cmake_minreqver-check() for any CMakeLists.txt with cmake_minimum_required
+# version lower than 3.5.
+_CMAKE_MINREQVER_CMAKE305=()
 
 # @ECLASS_VARIABLE: CMAKE_QA_SRC_DIR_READONLY
 # @USER_VARIABLE
@@ -330,25 +332,69 @@ _cmake_check_build_dir() {
 	mkdir -p "${BUILD_DIR}" || die
 }
 
-# @FUNCTION: _cmake_minreqver-lt
-# @USAGE: <lt-version> <path>
+# @FUNCTION: _cmake_minreqver-check
+# @USAGE: <path> or <path> <lt-version>
 # @INTERNAL
 # @DESCRIPTION:
-# Internal function for detecting occurrence of lower-than-specified
-# <lt-version> in cmake_minimum_required of a given CMake file <path>.
+# Internal function for flagging any deprecated or unsupported
+# cmake_minimum_required version in a given CMake file <path>.
+# If <lt-version> is specified as second arg, only check against that value.
 # Returns 0 if the regex matched (a lower-than-specified version found).
-_cmake_minreqver-lt() {
+_cmake_minreqver-check() {
 	local ver chk=1
+	if [[ "$#" == 2 ]]; then
+		local file="${1}"
+		local lt_version="${2}"
+	elif [[ "$#" == 1 ]]; then
+		local file="${1}"
+	else
+		die "${FUNCNAME[0]} must be passed either one or two arguments"
+	fi
 	ver=$(sed -ne "/^\s*cmake_minimum_required/I{s/.*\(\.\.\.*\|\s\)\([0-9][0-9.]*\)\([)]\|\s\).*$/\2/p;q}" \
-		"${2}" 2>/dev/null \
+		"${file}" 2>/dev/null \
 	)
-	if [[ -n ${ver} ]] && ver_test "${ver}" -lt "${1}"; then
-		_CMAKE_MINREQVER_UNSUPPORTED=true
-		chk=0
+	if [[ -z ${ver} ]]; then
+		return 1 # no cmake_minimum_required found
+	fi
+	if [[ -n ${lt_version} ]]; then
+		chk=$(ver_test "${ver}" -lt "${lt_version}")
+	else
+		if ver_test "${ver}" -lt "3.5"; then
+			_CMAKE_MINREQVER_CMAKE305+=( "${file}":"${ver}" )
+			chk=0
+		fi
 	fi
 	return ${chk}
 }
 
+# @FUNCTION: _cmake_minreqver-info
+# @INTERNAL
+# @DESCRIPTION:
+# QA Notice and file listing for any CMakeLists.txt file unsupported w/ CMake-4.
+_cmake_minreqver-info() {
+	local info
+	if [[ -n ${_CMAKE_MINREQVER_CMAKE305[@]} ]]; then
+		eqawarn "QA Notice: Compatibility with CMake < 3.5 has been removed from CMake 4,"
+		eqawarn "${CATEGORY}/${PN} will fail to build w/o a fix."
+		eqawarn "See also tracker bug #951350; check existing bug or file a new one for"
+		eqawarn "this package, and take it upstream."
+		eqawarn
+		eqawarn "The following CMakeLists.txt files are causing errors:"
+		for info in ${_CMAKE_MINREQVER_CMAKE305[*]}; do
+			eqawarn "  ${info}"
+		done
+		eqawarn
+		if has_version -b ">=dev-build/cmake-4"; then
+			eqawarn "CMake 4 detected; building with -DCMAKE_POLICY_VERSION_MINIMUM=3.5"
+			eqawarn "This is merely a workaround and *not* a permanent fix."
+			eqawarn
+		fi
+		eqawarn "An upstreamable patch should take any resulting CMake policy changes"
+		eqawarn "into account. See also:"
+		eqawarn "  https://cmake.org/cmake/help/latest/manual/cmake-policies.7.html"
+	fi
+}
+
 # @FUNCTION: _cmake_modify-cmakelists
 # @INTERNAL
 # @DESCRIPTION:
@@ -376,8 +422,8 @@ _cmake_modify-cmakelists() {
 			done
 		fi
 		# Detect unsupported minimum CMake versions unless CMAKE_QA_COMPAT_SKIP is set
-		if [[ -z ${_CMAKE_MINREQVER_UNSUPPORTED} ]] && ! [[ ${CMAKE_QA_COMPAT_SKIP} ]]; then
-			_cmake_minreqver-lt "3.5" "${file}"
+		if ! [[ ${CMAKE_QA_COMPAT_SKIP} ]]; then
+			_cmake_minreqver-check "${file#"${CMAKE_USE_DIR}/"}"
 		fi
 	done < <(find "${CMAKE_USE_DIR}" -type f -iname "CMakeLists.txt" -print0 || die)
 
@@ -397,23 +443,6 @@ _cmake_modify-cmakelists() {
 	_EOF_
 }
 
-# @FUNCTION: _cmake4_callout
-# @INTERNAL
-# @DESCRIPTION:
-# QA notice printout for build systems unsupported w/ CMake-4.
-_cmake4_callout() {
-	if [[ ${_CMAKE_MINREQVER_UNSUPPORTED} ]]; then
-		eqawarn "QA Notice: Compatibility with CMake < 3.5 has been removed from CMake 4,"
-		eqawarn "${CATEGORY}/${PN} will fail to build w/o a fix."
-		eqawarn "See also tracker bug #951350; check existing bug or file a new one for"
-		eqawarn "this package, and take it upstream."
-		if has_version -b ">=dev-build/cmake-4"; then
-			eqawarn "CMake 4 detected; building with -DCMAKE_POLICY_VERSION_MINIMUM=3.5"
-			eqawarn "This is merely a workaround and *not* a permanent fix."
-		fi
-	fi
-}
-
 # @FUNCTION: cmake_prepare
 # @DESCRIPTION:
 # Check existence of and sanitise CMake files, then make ${CMAKE_USE_DIR}
@@ -445,7 +474,7 @@ cmake_prepare() {
 
 	# Remove dangerous things.
 	_cmake_modify-cmakelists
-	_cmake4_callout
+	_cmake_minreqver-info
 
 	# Make ${CMAKE_USE_DIR} read-only in order to detect broken build systems
 	if [[ ${CMAKE_QA_SRC_DIR_READONLY} && ! ${CMAKE_IN_SOURCE_BUILD} ]]; then
@@ -486,7 +515,7 @@ cmake_src_prepare() {
 				find "${S}" -name "${name}.cmake" -exec rm -v {} + || die
 			done
 			_cmake_modify-cmakelists # Remove dangerous things.
-			_cmake4_callout
+			_cmake_minreqver-info
 		popd > /dev/null || die
 		# Make ${S} read-only in order to detect broken build systems
 		if [[ ${CMAKE_QA_SRC_DIR_READONLY} && ! ${CMAKE_IN_SOURCE_BUILD} ]]; then
@@ -719,7 +748,7 @@ cmake_src_configure() {
 		cmakeargs+=( -C "${CMAKE_EXTRA_CACHE_FILE}" )
 	fi
 
-	if [[ ${_CMAKE_MINREQVER_UNSUPPORTED} ]] && has_version -b ">=dev-build/cmake-4"; then
+	if [[ -n ${_CMAKE_MINREQVER_CMAKE305[@]} ]] && has_version -b ">=dev-build/cmake-4"; then
 		cmakeargs+=( -DCMAKE_POLICY_VERSION_MINIMUM=3.5 )
 	fi
 
@@ -855,7 +884,7 @@ cmake_src_install() {
 	while read -d '' -r file ; do
 		# Detect unsupported minimum CMake versions unless CMAKE_QA_COMPAT_SKIP is set
 		if ! [[ ${CMAKE_QA_COMPAT_SKIP} ]]; then
-			_cmake_minreqver-lt "3.5" "${file}" && files+=( "${file#"${D}"}" )
+			_cmake_minreqver-check "3.5" "${file}" && files+=( "${file#"${D}"}" )
 		fi
 	done < <(find "${D}" -type f -iname "*.cmake" -print0 || die)
 	if [[ ${#files[*]} -gt 0 ]]; then
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-10-18 15:20 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-10-18 15:20 UTC (permalink / raw
  To: gentoo-commits
commit:     aae7ac4294341b404b7f12afb75e39e137bfc565
Author:     Francisco Javier Félix <web <AT> inode64 <DOT> com>
AuthorDate: Sun Oct 12 18:34:30 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Oct 18 15:16:26 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=aae7ac42
apache-2.eclass: Missing deps for dev-libs/libxml2 and fix existing preserved libs
apache2_modules_proxy_html and apache2_modules_xml2enc require dev-libs/libxml2
Fix:
<pre>
>>> package: dev-libs/libxml2-2.14.6
 *  - /usr/lib64/libxml2.so.2
 *  - /usr/lib64/libxml2.so.2.13.9
 *      used by /usr/lib64/apache2/modules/mod_proxy_html.so (www-servers/apache-2.4.65)
 *      used by /usr/lib64/apache2/modules/mod_xml2enc.so (www-servers/apache-2.4.65)
</pre>
Signed-off-by: Fco Javier Felix <ffelix <AT> inode64.com>
Part-of: https://github.com/gentoo/gentoo/pull/44149
Closes: https://github.com/gentoo/gentoo/pull/44149
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/apache-2.eclass | 2 ++
 1 file changed, 2 insertions(+)
diff --git a/eclass/apache-2.eclass b/eclass/apache-2.eclass
index 0ff76bd2dcf1..cb41bcdcdcfe 100644
--- a/eclass/apache-2.eclass
+++ b/eclass/apache-2.eclass
@@ -152,6 +152,7 @@ RDEPEND="
 	apache2_modules_lua? ( ${LUA_DEPS} )
 	apache2_modules_md? ( >=dev-libs/jansson-2.10:= )
 	apache2_modules_mime? ( app-misc/mime-types )
+	apache2_modules_proxy_html? ( dev-libs/libxml2:= )
 	apache2_modules_proxy_http2? (
 		>=net-libs/nghttp2-${NGHTTP2_VERSION}:=
 		kernel_linux? ( sys-apps/util-linux )
@@ -159,6 +160,7 @@ RDEPEND="
 	apache2_modules_session_crypto? (
 		dev-libs/apr-util[openssl]
 	)
+	apache2_modules_xml2enc? ( dev-libs/libxml2:= )
 	gdbm? ( sys-libs/gdbm:= )
 	ldap? ( net-nds/openldap:= )
 	selinux? ( sec-policy/selinux-apache )
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-10-19 21:54 Andreas Sturmlechner
  0 siblings, 0 replies; 6663+ messages in thread
From: Andreas Sturmlechner @ 2025-10-19 21:54 UTC (permalink / raw
  To: gentoo-commits
commit:     d4c5fb14bbbe3c6c2082651c880c2b4aed02d4c7
Author:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
AuthorDate: Sun Oct 19 21:45:48 2025 +0000
Commit:     Andreas Sturmlechner <asturm <AT> gentoo <DOT> org>
CommitDate: Sun Oct 19 21:54:33 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=d4c5fb14
cmake.eclass: _cmake_modify-cmakelists(): Fix _cmake_minreqver-check call
_cmake_minreqver-check may be called from any phase, so <file> path must be
absolute. As a quick fix, push the path mangling into the output function
_cmake_minreqver-info which (currently) is only called from cmake_prepare.
Closes: https://bugs.gentoo.org/964702
Signed-off-by: Andreas Sturmlechner <asturm <AT> gentoo.org>
 eclass/cmake.eclass | 14 ++++++++++----
 1 file changed, 10 insertions(+), 4 deletions(-)
diff --git a/eclass/cmake.eclass b/eclass/cmake.eclass
index df91ba0f4a0f..bd0294d2ae00 100644
--- a/eclass/cmake.eclass
+++ b/eclass/cmake.eclass
@@ -453,20 +453,26 @@ _cmake_minreqver-info() {
 		case ${1} in
 			305)
 				eqawarn "The following CMakeLists.txt files are causing errors:"
-				for info in ${_CMAKE_MINREQVER_CMAKE305[*]}; do eqawarn "  ${info}"; done
+				for info in ${_CMAKE_MINREQVER_CMAKE305[*]}; do
+					eqawarn "  ${info#"${CMAKE_USE_DIR}/"}";
+				done
 				eqawarn
 				;;
 			310)
 				if [[ -n ${_CMAKE_MINREQVER_CMAKE310[@]} ]]; then
 					eqawarn "The following CMakeLists.txt files are causing warnings:"
-					for info in ${_CMAKE_MINREQVER_CMAKE310[*]}; do eqawarn "  ${info}"; done
+					for info in ${_CMAKE_MINREQVER_CMAKE310[*]}; do
+						eqawarn "  ${info#"${CMAKE_USE_DIR}/"}";
+					done
 					eqawarn
 				fi
 				;;
 			316)
 				if [[ ${warnlvl} -ge 316 ]] && [[ -n ${_CMAKE_MINREQVER_CMAKE316[@]} ]]; then
 					eqawarn "The following CMakeLists.txt files are causing warnings:"
-					for info in ${_CMAKE_MINREQVER_CMAKE316[*]}; do eqawarn "  ${info}"; done
+					for info in ${_CMAKE_MINREQVER_CMAKE316[*]}; do
+						eqawarn "  ${info#"${CMAKE_USE_DIR}/"}";
+					done
 					eqawarn
 				fi
 				;;
@@ -527,7 +533,7 @@ _cmake_modify-cmakelists() {
 		fi
 		# Detect unsupported minimum CMake versions unless CMAKE_QA_COMPAT_SKIP is set
 		if ! [[ ${CMAKE_QA_COMPAT_SKIP} ]]; then
-			_cmake_minreqver-check "${file#"${CMAKE_USE_DIR}/"}"
+			_cmake_minreqver-check "${file}"
 		fi
 	done < <(find "${CMAKE_USE_DIR}" -type f -iname "CMakeLists.txt" -print0 || die)
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-10-21  0:25 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-10-21  0:25 UTC (permalink / raw
  To: gentoo-commits
commit:     a898070a7df034c8410f3a3f6b549c0172bc4724
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Oct 21 00:25:15 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Oct 21 00:25:15 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=a898070a
rust.eclass: add 1.91.0 slot
We already have it in the LLVM map but not in the slot list.
Closes: https://bugs.gentoo.org/964752
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/rust.eclass | 1 +
 1 file changed, 1 insertion(+)
diff --git a/eclass/rust.eclass b/eclass/rust.eclass
index 309a3f4d5d19..b5a992199dce 100644
--- a/eclass/rust.eclass
+++ b/eclass/rust.eclass
@@ -98,6 +98,7 @@ declare -A -g -r _RUST_LLVM_MAP=(
 # this array is used to store the Rust slots in a more convenient order for iteration.
 declare -a -g -r _RUST_SLOTS_ORDERED=(
 	"9999"
+	"1.91.0"
 	"1.90.0"
 	"1.89.0"
 	"1.88.0"
^ permalink raw reply related	[flat|nested] 6663+ messages in thread
* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-10-21 20:20 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-10-21 20:20 UTC (permalink / raw
  To: gentoo-commits
commit:     ce58a148d88b26414d7c58e4672da2e2952e517b
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Oct 21 20:15:48 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Oct 21 20:16:06 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=ce58a148
llvm.org.eclass: crank openpgp-keys-llvm dep
Bug: https://bugs.gentoo.org/963955
Closes: https://bugs.gentoo.org/964802
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/llvm.org.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index b2e688bc4ebe..71b8bacee44a 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -274,7 +274,7 @@ llvm.org_set_globals() {
 			fi
 			BDEPEND+="
 				verify-sig? (
-					>=sec-keys/openpgp-keys-llvm-21.1.3
+					>=sec-keys/openpgp-keys-llvm-21.1.4
 				)
 			"
 			VERIFY_SIG_OPENPGP_KEY_PATH=/usr/share/openpgp-keys/llvm.asc
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-10-22 19:12 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-10-22 19:12 UTC (permalink / raw
  To: gentoo-commits
commit:     34455b96ae20a345fbcb24e984a0cd7243a28dd6
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Wed Oct 22 19:03:34 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Wed Oct 22 19:12:04 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=34455b96
llvm.org.eclass: Add 22.0.0_pre20251022 snapshot
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index fe0c09a60387..d3fdddb92583 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -72,6 +72,9 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 			_LLVM_SOURCE_TYPE=snapshot
 
 			case ${PV} in
+				22.0.0_pre20251022)
+					EGIT_COMMIT=57a8599d14d4685487064e8b8a5c748970daa4d6
+					;;
 				22.0.0_pre20251011)
 					EGIT_COMMIT=6a0e5b2fd7c340a872ae1e011cfb9de0d188feba
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-10-22 19:12 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-10-22 19:12 UTC (permalink / raw
  To: gentoo-commits
commit:     0da2643a267b4bbc5736e5a8f107b86fc865c44d
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Wed Oct 22 19:03:07 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Wed Oct 22 19:12:03 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=0da2643a
llvm.org.eclass: Remove old snapshots
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/llvm.org.eclass | 6 ------
 1 file changed, 6 deletions(-)
diff --git a/eclass/llvm.org.eclass b/eclass/llvm.org.eclass
index 71b8bacee44a..fe0c09a60387 100644
--- a/eclass/llvm.org.eclass
+++ b/eclass/llvm.org.eclass
@@ -75,12 +75,6 @@ if [[ -z ${_LLVM_SOURCE_TYPE+1} ]]; then
 				22.0.0_pre20251011)
 					EGIT_COMMIT=6a0e5b2fd7c340a872ae1e011cfb9de0d188feba
 					;;
-				22.0.0_pre20251004)
-					EGIT_COMMIT=b1e29ec3b73b9dd06656c7e30ace597ff72cde70
-					;;
-				22.0.0_pre20251001)
-					EGIT_COMMIT=89ed5255b9ee88119e409a6d986eb1ad0e8f08e3
-					;;
 				*)
 					die "Unknown snapshot: ${PV}"
 					;;
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-10-23 18:19 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-10-23 18:19 UTC (permalink / raw
  To: gentoo-commits
commit:     4751eb73831a1fd01f3dcc2caf4ac6911f93b474
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sun Oct 19 15:53:32 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Thu Oct 23 18:18:59 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=4751eb73
verify-sig.eclass: Append a trailing newline to gpg --verify output
Explicitly append a trailing newline to the output stream created
by "gpg --verify", to ensure it always contains one.  The FreePG
patchset to GPG corrects handling the trailing newlines in cleartext
signed messages, which means that GPG-created "incorrect" messages
no longer include a trailing newline character [1].  We are parsing
the checksum file via bash's "read" command that ignores the characters
after the final newline character, so we need to ensure that one is
always present after the ultimate checksum.
Adding an extra newline to vanilla GnuPG output causes no harm,
as the verification function will simply ignore the resulting empty
line.
[1] https://gitlab.com/freepg/gnupg/-/blob/a4e8d23439f1e101da3e335b3beab822be968d56/DIFF.md#handle-cleartext-signature-framework-csf-messages-correctly
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/verify-sig.eclass | 1 +
 1 file changed, 1 insertion(+)
diff --git a/eclass/verify-sig.eclass b/eclass/verify-sig.eclass
index 1cd3e1010ae5..4e38d327b838 100644
--- a/eclass/verify-sig.eclass
+++ b/eclass/verify-sig.eclass
@@ -380,6 +380,7 @@ _gpg_verify_signed_checksums() {
 
 	verify-sig_verify_unsigned_checksums - "${algo}" "${files}" < <(
 		verify-sig_verify_message "${checksum_file}" - "${key}"
+		echo
 	)
 }
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-10-23 18:19 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-10-23 18:19 UTC (permalink / raw
  To: gentoo-commits
commit:     cfa5bab4ebb1904240057c970d52291c1594eac2
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Tue Oct 14 06:50:52 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Thu Oct 23 18:19:11 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=cfa5bab4
distutils-r1.eclass: Extend wheel reuse to *py3-none*
Remove the unnecessary "-any" restriction in wheel reuse.  I've added
it without thinking about it twice, but it prevents wheel reuse
for Python-agnostic packages that build native executables, e.g.
dev-python/uv.
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
Part-of: https://github.com/gentoo/gentoo/pull/44172
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/distutils-r1.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/distutils-r1.eclass b/eclass/distutils-r1.eclass
index e9826f4cf3df..b7f5045e60bd 100644
--- a/eclass/distutils-r1.eclass
+++ b/eclass/distutils-r1.eclass
@@ -1287,7 +1287,7 @@ distutils-r1_python_compile() {
 			# from the oldest to the newest implementation,
 			# and the wheels are forward-compatible.
 			if [[
-				( ! ${DISTUTILS_EXT} && ${whl} == *py3-none-any* ) ||
+				( ! ${DISTUTILS_EXT} && ${whl} == *py3-none* ) ||
 				(
 					${EPYTHON} == python* &&
 					# freethreading does not support stable ABI
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-10-23 18:19 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-10-23 18:19 UTC (permalink / raw
  To: gentoo-commits
commit:     26413a3fb5f9c37fbc14b7a567f6c1f7358555ac
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Fri Oct 17 13:39:42 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Thu Oct 23 18:19:13 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=26413a3f
distutils-r1.eclass: Use EPYTEST_PLUGINS for import-check
Add "pytest-import-check" to EPYTEST_PLUGINS automatically when using
import-check.  This also implicitly overrides the default behavior
of enabling all plugins, and instead runs with just the import-check
plugin loaded.
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
Part-of: https://github.com/gentoo/gentoo/pull/44172
Closes: https://github.com/gentoo/gentoo/pull/44172
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/distutils-r1.eclass | 1 +
 1 file changed, 1 insertion(+)
diff --git a/eclass/distutils-r1.eclass b/eclass/distutils-r1.eclass
index b7f5045e60bd..8fc92cf4fca5 100644
--- a/eclass/distutils-r1.eclass
+++ b/eclass/distutils-r1.eclass
@@ -551,6 +551,7 @@ distutils_enable_tests() {
 	case ${1} in
 		import-check)
 			test_pkgs+=' dev-python/pytest-import-check[${PYTHON_USEDEP}]'
+			EPYTEST_PLUGINS+=( pytest-import-check )
 			;&
 		pytest)
 			test_pkgs+=' >=dev-python/pytest-7.4.4[${PYTHON_USEDEP}]'
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-10-23 18:19 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-10-23 18:19 UTC (permalink / raw
  To: gentoo-commits
commit:     6fa9351ed3e6287f51f63533062b14cd7bfde9b9
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Tue Oct 14 06:50:23 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Thu Oct 23 18:19:10 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=6fa9351e
pypi.eclass: Fix typo in pypi_provenance_url()
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
Part-of: https://github.com/gentoo/gentoo/pull/44172
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/pypi.eclass | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/eclass/pypi.eclass b/eclass/pypi.eclass
index 38068aac3356..14c4edb391d8 100644
--- a/eclass/pypi.eclass
+++ b/eclass/pypi.eclass
@@ -298,9 +298,9 @@ _pypi_provenance_url() {
 # @DESCRIPTION:
 # Output the URL to PyPI provenance for the specified artifact.
 pypi_provenance_url() {
-	local _PYPI_PROVENANCE_URL
+	local _PYPI_ATTESTATION_URL
 	_pypi_provenance_url "${@}"
-	echo "${_PYPI_PROVENANCE_URL}"
+	echo "${_PYPI_ATTESTATION_URL}"
 }
 
 # @FUNCTION: pypi_verify_provenance
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-10-23 18:19 Michał Górny
  0 siblings, 0 replies; 6663+ messages in thread
From: Michał Górny @ 2025-10-23 18:19 UTC (permalink / raw
  To: gentoo-commits
commit:     ddda228a67a145f1baed788b5a605dc382ddc9a9
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Tue Oct 14 06:54:55 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Thu Oct 23 18:19:12 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=ddda228a
python-utils-r1.eclass: Use --force-reruns for EPYTEST_RERUNS
Use "--force-reruns" rather than "--reruns" when available.  This
ensures that the rerun count is respected for all tests, including
tests already marked upstream for reruns.  Otherwise tests marked
" <AT> pytest.mark.flaky" will get rerun only once.
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
Part-of: https://github.com/gentoo/gentoo/pull/44172
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>
 eclass/python-utils-r1.eclass | 14 +++++++++++---
 1 file changed, 11 insertions(+), 3 deletions(-)
diff --git a/eclass/python-utils-r1.eclass b/eclass/python-utils-r1.eclass
index e213273a3a78..b08dbd586ba8 100644
--- a/eclass/python-utils-r1.eclass
+++ b/eclass/python-utils-r1.eclass
@@ -1538,9 +1538,17 @@ epytest() {
 			)
 		fi
 
-		args+=(
-			"--reruns=${EPYTEST_RERUNS}"
-		)
+		if has_version ">=dev-python/pytest-rerunfailures-16.1"; then
+			args+=(
+				# --reruns only adds N reruns for tests not marked for reruns
+				# --force-reruns overrides the rerun count for all tests
+				"--force-reruns=${EPYTEST_RERUNS}"
+			)
+		else
+			args+=(
+				"--reruns=${EPYTEST_RERUNS}"
+			)
+		fi
 	fi
 
 	if [[ -n ${EPYTEST_TIMEOUT} ]]; then
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-10-25  1:07 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-10-25  1:07 UTC (permalink / raw
  To: gentoo-commits
commit:     8d0407da10a6583cf4b30a4edb8f2f2f14e0e328
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Oct 25 00:56:42 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Oct 25 01:05:31 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=8d0407da
toolchain.eclass: depend on libxml2 at runtime for libgcobol
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 6 +++++-
 1 file changed, 5 insertions(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index 0acb2cb365b7..a72b42177a81 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -340,7 +340,7 @@ if [[ ${PN} != kgcc64 && ${PN} != gcc-* ]] ; then
 	tc_version_is_at_least 14.1 ${PV} && IUSE+=" rust" TC_FEATURES+=( rust )
 	tc_version_is_at_least 13.3.1_p20250522 ${PV} && IUSE+=" time64"
 	tc_version_is_at_least 15.1 ${PV} && IUSE+=" libgdiagnostics"
-	tc_version_is_at_least 15.1 ${PV} && IUSE+=" cobol"
+	tc_version_is_at_least 15.1 ${PV} && IUSE+=" cobol" TC_FEATURES+=( cobol )
 fi
 
 if tc_version_is_at_least 10; then
@@ -363,6 +363,10 @@ GMP_MPFR_DEPS=">=dev-libs/gmp-4.3.2:0= >=dev-libs/mpfr-2.4.2:0="
 RDEPEND+=" ${GMP_MPFR_DEPS}"
 RDEPEND+=" >=dev-libs/mpc-0.8.1:0="
 
+if tc_has_feature cobol ; then
+	RDEPEND+=" cobol? ( dev-libs/libxml2:= )"
+fi
+
 if tc_has_feature objc-gc ; then
 	RDEPEND+=" objc-gc? ( >=dev-libs/boehm-gc-7.4.2 )"
 fi
^ permalink raw reply related	[flat|nested] 6663+ messages in thread* [gentoo-commits] repo/gentoo:master commit in: eclass/
@ 2025-10-26  4:07 Sam James
  0 siblings, 0 replies; 6663+ messages in thread
From: Sam James @ 2025-10-26  4:07 UTC (permalink / raw
  To: gentoo-commits
commit:     7141b8da59057bac80b0e2e5d5ea34a70770ece2
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Oct 26 04:06:53 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Oct 26 04:07:29 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=7141b8da
toolchain.eclass: only >=16's cobol needs libxml2
Signed-off-by: Sam James <sam <AT> gentoo.org>
 eclass/toolchain.eclass | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/eclass/toolchain.eclass b/eclass/toolchain.eclass
index a72b42177a81..514d4def64af 100644
--- a/eclass/toolchain.eclass
+++ b/eclass/toolchain.eclass
@@ -363,7 +363,7 @@ GMP_MPFR_DEPS=">=dev-libs/gmp-4.3.2:0= >=dev-libs/mpfr-2.4.2:0="
 RDEPEND+=" ${GMP_MPFR_DEPS}"
 RDEPEND+=" >=dev-libs/mpc-0.8.1:0="
 
-if tc_has_feature cobol ; then
+if tc_has_feature cobol && tc_version_is_at_least 16.0.0_p20251019 ; then
 	RDEPEND+=" cobol? ( dev-libs/libxml2:= )"
 fi
 
^ permalink raw reply related	[flat|nested] 6663+ messages in thread
end of thread, other threads:[~2025-10-26  4:08 UTC | newest]
Thread overview: 6663+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2024-03-10 21:10 [gentoo-commits] repo/gentoo:master commit in: eclass/ Miroslav Šulc
  -- strict thread matches above, loose matches on Subject: below --
2024-04-30 18:34 Michał Górny
2024-04-30 19:19 Alfredo Tupone
2024-04-30 19:25 Alfredo Tupone
2024-05-01  0:27 Sam James
2024-05-01  0:27 Sam James
2024-05-01  3:02 Sam James
2024-05-02  0:24 Sam James
2024-05-02 17:44 Florian Schmaus
2024-05-03  2:48 Sam James
2024-05-03  2:48 Sam James
2024-05-03 11:43 Sam James
2024-05-03 11:43 Sam James
2024-05-03 11:43 Sam James
2024-05-04 19:57 Michał Górny
2024-05-04 19:57 Michał Górny
2024-05-06  4:39 Sam James
2024-05-06 17:11 Ionen Wolkens
2024-05-06 17:28 Ulrich Müller
2024-05-06 17:28 Ulrich Müller
2024-05-07  7:57 Andreas K. Hüttel
2024-05-08  8:06 Ulrich Müller
2024-05-09 19:54 Conrad Kostecki
2024-05-09 19:54 Conrad Kostecki
2024-05-10 17:28 Sam James
2024-05-10 17:28 Sam James
2024-05-10 17:28 Sam James
2024-05-10 17:28 Sam James
2024-05-10 17:28 Sam James
2024-05-11  0:55 Sam James
2024-05-11  1:58 Sam James
2024-05-11  6:21 Hans de Graaff
2024-05-11  6:44 Joonas Niilola
2024-05-11 13:39 Michał Górny
2024-05-12  4:51 Sam James
2024-05-13  7:07 Miroslav Šulc
2024-05-13  8:35 Florian Schmaus
2024-05-13 13:22 Michael Orlitzky
2024-05-13 13:22 Michael Orlitzky
2024-05-13 13:22 Michael Orlitzky
2024-05-13 13:22 Michael Orlitzky
2024-05-13 21:53 Sam James
2024-05-14  8:20 Florian Schmaus
2024-05-14  9:19 Florian Schmaus
2024-05-15 14:20 Michał Górny
2024-05-15 18:02 Michał Górny
2024-05-17  6:25 Michał Górny
2024-05-17 12:07 Andrew Ammerlaan
2024-05-17 12:07 Andrew Ammerlaan
2024-05-17 12:07 Andrew Ammerlaan
2024-05-17 23:05 Ionen Wolkens
2024-05-17 23:05 Ionen Wolkens
2024-05-18  3:50 Benda XU
2024-05-18 13:25 Michał Górny
2024-05-20 17:02 Michał Górny
2024-05-20 17:02 Michał Górny
2024-05-20 17:02 Michał Górny
2024-05-20 17:02 Michał Górny
2024-05-20 17:02 Michał Górny
2024-05-20 17:02 Michał Górny
2024-05-20 17:02 Michał Górny
2024-05-20 17:02 Michał Górny
2024-05-21  8:58 Florian Schmaus
2024-05-21  8:58 Florian Schmaus
2024-05-21  8:58 Florian Schmaus
2024-05-22  1:44 Sam James
2024-05-25  5:55 Sam James
2024-05-25  8:35 Michał Górny
2024-05-26  8:18 Miroslav Šulc
2024-05-31 12:42 Michał Górny
2024-06-01  6:19 Hans de Graaff
2024-06-01  6:19 Hans de Graaff
2024-06-01  6:19 Hans de Graaff
2024-06-01 21:11 Alfredo Tupone
2024-06-01 21:34 Alfredo Tupone
2024-06-02  8:22 Ionen Wolkens
2024-06-06 20:37 Mike Gilbert
2024-06-08  3:53 Ulrich Müller
2024-06-08  3:53 Ulrich Müller
2024-06-08 10:29 Michał Górny
2024-06-08 15:47 Michał Górny
2024-06-10 12:46 Joonas Niilola
2024-06-10 14:23 Ulrich Müller
2024-06-10 14:23 Ulrich Müller
2024-06-12 10:24 Arthur Zamarin
2024-06-12 13:20 James Le Cuirot
2024-06-12 13:20 James Le Cuirot
2024-06-12 14:27 Patrick Lauer
2024-06-12 16:36 Patrick Lauer
2024-06-12 17:13 James Le Cuirot
2024-06-13 13:21 Miroslav Šulc
2024-06-13 18:35 Ulrich Müller
2024-06-13 18:35 Ulrich Müller
2024-06-13 20:43 Andreas Sturmlechner
2024-06-14 10:00 Miroslav Šulc
2024-06-14 10:00 Miroslav Šulc
2024-06-14 10:00 Miroslav Šulc
2024-06-14 10:00 Miroslav Šulc
2024-06-14 10:00 Miroslav Šulc
2024-06-14 12:19 Miroslav Šulc
2024-06-14 12:26 Michał Górny
2024-06-14 12:26 Michał Górny
2024-06-14 12:26 Michał Górny
2024-06-14 12:26 Michał Górny
2024-06-14 12:26 Michał Górny
2024-06-14 12:26 Michał Górny
2024-06-14 12:26 Michał Górny
2024-06-14 12:26 Michał Górny
2024-06-15  7:58 Sam James
2024-06-15 11:01 Michał Górny
2024-06-17  0:53 Sam James
2024-06-17  9:39 James Le Cuirot
2024-06-17 17:13 Andreas Sturmlechner
2024-06-19  3:16 Andreas K. Hüttel
2024-06-20  7:29 Florian Schmaus
2024-06-20  7:29 Florian Schmaus
2024-06-20  9:57 Sam James
2024-06-23  1:00 Ionen Wolkens
2024-06-23 17:33 Michał Górny
2024-06-24 11:58 Ulrich Müller
2024-06-26  6:24 Florian Schmaus
2024-06-27  7:33 Andrew Ammerlaan
2024-06-28  8:23 Miroslav Šulc
2024-06-29  8:39 Andrew Ammerlaan
2024-06-29  8:39 Andrew Ammerlaan
2024-06-29  8:39 Andrew Ammerlaan
2024-06-30 18:27 Sam James
2024-07-02 17:49 Sam James
2024-07-03  0:54 Sam James
2024-07-03  0:59 Sam James
2024-07-03  5:30 Joonas Niilola
2024-07-05 11:03 Arthur Zamarin
2024-07-05 11:03 Arthur Zamarin
2024-07-05 11:03 Arthur Zamarin
2024-07-05 20:50 Luca Barbato
2024-07-06 11:19 Michał Górny
2024-07-07  6:45 Matthew Smith
2024-07-08 10:03 Ulrich Müller
2024-07-08 10:03 Ulrich Müller
2024-07-08 10:03 Ulrich Müller
2024-07-08 10:03 Ulrich Müller
2024-07-09 16:44 Ulrich Müller
2024-07-11 14:35 Michał Górny
2024-07-11 20:54 Ulrich Müller
2024-07-11 20:54 Ulrich Müller
2024-07-12  6:27 Sam James
2024-07-12  7:38 Sam James
2024-07-12 17:43 Ulrich Müller
2024-07-13  7:46 Michał Górny
2024-07-13 14:14 Michał Górny
2024-07-14 17:45 Florian Schmaus
2024-07-14 17:45 Florian Schmaus
2024-07-15  7:17 David Seifert
2024-07-15  7:17 David Seifert
2024-07-15  7:17 David Seifert
2024-07-15 19:18 Andrew Ammerlaan
2024-07-15 19:18 Andrew Ammerlaan
2024-07-15 19:18 Andrew Ammerlaan
2024-07-15 19:18 Andrew Ammerlaan
2024-07-15 19:18 Andrew Ammerlaan
2024-07-16  9:16 James Le Cuirot
2024-07-16  9:16 James Le Cuirot
2024-07-16  9:16 James Le Cuirot
2024-07-16  9:16 James Le Cuirot
2024-07-16  9:16 James Le Cuirot
2024-07-16  9:16 James Le Cuirot
2024-07-16  9:16 James Le Cuirot
2024-07-18 16:15 Michał Górny
2024-07-20 12:09 Ulrich Müller
2024-07-21 13:31 Andrew Ammerlaan
2024-07-21 13:31 Andrew Ammerlaan
2024-07-21 13:31 Andrew Ammerlaan
2024-07-21 15:14 Andrew Ammerlaan
2024-07-21 15:45 Andrew Ammerlaan
2024-07-22 15:09 Michał Górny
2024-07-22 15:09 Michał Górny
2024-07-22 15:09 Michał Górny
2024-07-23 10:03 Miroslav Šulc
2024-07-23 14:07 Michał Górny
2024-07-23 14:07 Michał Górny
2024-07-23 14:07 Michał Górny
2024-07-23 14:13 Michał Górny
2024-07-24  8:58 Florian Schmaus
2024-07-24  8:58 Florian Schmaus
2024-07-24 17:18 Andrew Ammerlaan
2024-07-24 17:18 Andrew Ammerlaan
2024-07-24 17:18 Andrew Ammerlaan
2024-07-26  9:00 Miroslav Šulc
2024-07-26 17:18 Ulrich Müller
2024-07-27  7:27 Michał Górny
2024-07-27 22:00 Andrew Ammerlaan
2024-07-28 17:40 Florian Schmaus
2024-07-31  0:02 Sam James
2024-08-01  7:32 Miroslav Šulc
2024-08-01 20:20 Michał Górny
2024-08-04  7:27 Sam James
2024-08-04  7:30 Andrew Ammerlaan
2024-08-04  8:28 Sam James
2024-08-06  1:46 Sam James
2024-08-06  8:47 Michał Górny
2024-08-06  8:47 Michał Górny
2024-08-06  8:47 Michał Górny
2024-08-06  8:47 Michał Górny
2024-08-06  8:47 Michał Górny
2024-08-06  8:47 Michał Górny
2024-08-06  8:47 Michał Górny
2024-08-06  8:47 Michał Górny
2024-08-06  8:47 Michał Górny
2024-08-06  8:47 Michał Górny
2024-08-06  8:47 Michał Górny
2024-08-06  8:47 Michał Górny
2024-08-06 16:39 Florian Schmaus
2024-08-07  3:03 Sam James
2024-08-07  8:58 Andrew Ammerlaan
2024-08-07  8:58 Andrew Ammerlaan
2024-08-07  9:21 Sam James
2024-08-07  9:25 Sam James
2024-08-07  9:41 Sam James
2024-08-07 15:13 Sam James
2024-08-08  9:00 James Le Cuirot
2024-08-08 10:05 Sam James
2024-08-08 10:30 Sam James
2024-08-08 10:30 Sam James
2024-08-08 10:49 Sam James
2024-08-08 14:38 James Le Cuirot
2024-08-08 16:46 Andrew Ammerlaan
2024-08-08 19:26 Michał Górny
2024-08-09 11:39 Sam James
2024-08-09 11:50 Sam James
2024-08-09 14:30 Sam James
2024-08-09 15:50 Andrew Ammerlaan
2024-08-10 14:06 Fabian Groffen
2024-08-10 17:24 Sam James
2024-08-11 20:56 Sam James
2024-08-12  1:19 Sam James
2024-08-12  1:19 Sam James
2024-08-12  1:19 Sam James
2024-08-12  1:19 Sam James
2024-08-12 19:02 Ulrich Müller
2024-08-12 19:02 Ulrich Müller
2024-08-15 17:48 Andreas Sturmlechner
2024-08-15 17:48 Andreas Sturmlechner
2024-08-15 17:48 Andreas Sturmlechner
2024-08-15 17:48 Andreas Sturmlechner
2024-08-15 17:48 Andreas Sturmlechner
2024-08-15 17:48 Andreas Sturmlechner
2024-08-15 17:48 Andreas Sturmlechner
2024-08-15 17:48 Andreas Sturmlechner
2024-08-15 20:01 Michał Górny
2024-08-15 21:18 Sam James
2024-08-15 21:24 Sam James
2024-08-16  5:55 Arthur Zamarin
2024-08-16 10:15 Arthur Zamarin
2024-08-16 17:21 Sam James
2024-08-16 17:21 Sam James
2024-08-16 17:21 Sam James
2024-08-16 17:21 Sam James
2024-08-16 17:21 Sam James
2024-08-16 17:21 Sam James
2024-08-16 17:21 Sam James
2024-08-16 17:21 Sam James
2024-08-18 17:44 Arsen Arsenović
2024-08-18 17:44 Arsen Arsenović
2024-08-18 17:44 Arsen Arsenović
2024-08-19  6:02 Viorel Munteanu
2024-08-19 18:17 Robin H. Johnson
2024-08-20 20:07 Mike Gilbert
2024-08-20 20:17 Mike Gilbert
2024-08-21 21:51 Andreas Sturmlechner
2024-08-22 11:23 Michał Górny
2024-08-22 17:00 Andreas Sturmlechner
2024-08-23 19:25 Michał Górny
2024-08-23 19:25 Michał Górny
2024-08-25  0:49 Jason Zaman
2024-08-25 15:37 Andrew Ammerlaan
2024-08-26  6:34 Andreas Sturmlechner
2024-08-26 13:04 Ulrich Müller
2024-08-26 13:04 Ulrich Müller
2024-08-26 13:04 Ulrich Müller
2024-08-26 13:04 Ulrich Müller
2024-08-30 19:10 Andrew Ammerlaan
2024-08-30 19:43 Andrew Ammerlaan
2024-08-31  8:33 Michał Górny
2024-09-01  9:59 Miroslav Šulc
2024-09-01  9:59 Miroslav Šulc
2024-09-01  9:59 Miroslav Šulc
2024-09-01  9:59 Miroslav Šulc
2024-09-01 11:05 Sam James
2024-09-01 11:05 Sam James
2024-09-01 11:05 Sam James
2024-09-01 11:05 Sam James
2024-09-03  4:22 Ionen Wolkens
2024-09-03  8:58 Sam James
2024-09-03  9:40 Sam James
2024-09-04 20:33 Michał Górny
2024-09-05 12:10 Sam James
2024-09-07 18:21 Sam James
2024-09-07 18:23 Sam James
2024-09-08 18:21 Sam James
2024-09-08 18:21 Sam James
2024-09-08 18:21 Sam James
2024-09-08 18:21 Sam James
2024-09-08 18:21 Sam James
2024-09-08 18:21 Sam James
2024-09-08 18:21 Sam James
2024-09-08 18:21 Sam James
2024-09-08 18:21 Sam James
2024-09-08 18:21 Sam James
2024-09-08 18:21 Sam James
2024-09-08 18:21 Sam James
2024-09-08 18:21 Sam James
2024-09-08 18:21 Sam James
2024-09-08 18:21 Sam James
2024-09-08 18:21 Sam James
2024-09-08 18:21 Sam James
2024-09-08 18:21 Sam James
2024-09-08 18:21 Sam James
2024-09-08 18:21 Sam James
2024-09-08 18:21 Sam James
2024-09-08 18:21 Sam James
2024-09-08 18:21 Sam James
2024-09-08 18:21 Sam James
2024-09-08 18:21 Sam James
2024-09-09 18:20 Sam James
2024-09-10  6:46 Miroslav Šulc
2024-09-10  8:54 Michał Górny
2024-09-10 12:58 Michał Górny
2024-09-10 19:11 Miroslav Šulc
2024-09-11 22:21 Sam James
2024-09-12 22:08 Sam James
2024-09-17 11:58 Andrew Ammerlaan
2024-09-17 12:13 Michał Górny
2024-09-18 15:51 Sam James
2024-09-19 22:57 Sam James
2024-09-23 12:06 Ulrich Müller
2024-09-23 15:11 Michał Górny
2024-09-24  6:41 Michał Górny
2024-09-24 11:52 Sam James
2024-09-24 18:02 Michał Górny
2024-09-24 18:02 Michał Górny
2024-09-25  4:39 Michał Górny
2024-09-25  4:51 Ulrich Müller
2024-09-25 11:12 Sam James
2024-09-25 11:12 Sam James
2024-09-25 11:12 Sam James
2024-09-25 19:29 Eli Schwartz
2024-09-29  0:18 Sam James
2024-09-29  0:18 Sam James
2024-09-29  0:18 Sam James
2024-09-29  1:07 Sam James
2024-09-29  1:07 Sam James
2024-09-29  1:13 Sam James
2024-09-29  1:13 Sam James
2024-09-29 11:22 Sam James
2024-09-29 11:22 Sam James
2024-09-29 11:22 Sam James
2024-09-29 11:28 Sam James
2024-09-30  1:52 Sam James
2024-09-30  1:52 Sam James
2024-09-30  1:52 Sam James
2024-09-30  1:52 Sam James
2024-09-30  2:02 Sam James
2024-09-30  2:02 Sam James
2024-09-30  2:02 Sam James
2024-09-30  2:15 Sam James
2024-09-30  2:15 Sam James
2024-09-30  2:20 Sam James
2024-09-30  3:02 Sam James
2024-09-30  3:03 Sam James
2024-09-30  5:57 Sam James
2024-10-01  1:11 Sam James
2024-10-01  1:46 Sam James
2024-10-01  1:58 Sam James
2024-10-01  1:58 Sam James
2024-10-01  2:06 Sam James
2024-10-01  2:14 Sam James
2024-10-01  2:16 Sam James
2024-10-01  6:59 Sam James
2024-10-01  7:47 Sam James
2024-10-01 10:18 Sam James
2024-10-01 19:38 Eli Schwartz
2024-10-01 20:40 James Le Cuirot
2024-10-01 23:13 Eli Schwartz
2024-10-01 23:13 Eli Schwartz
2024-10-02  0:57 Sam James
2024-10-02  9:01 Miroslav Šulc
2024-10-02  9:01 Miroslav Šulc
2024-10-02  9:01 Miroslav Šulc
2024-10-02  9:01 Miroslav Šulc
2024-10-03  3:43 Sam James
2024-10-03  4:02 Sam James
2024-10-04 11:49 Sam James
2024-10-07  2:40 Sam James
2024-10-07  4:13 Sam James
2024-10-07  4:13 Sam James
2024-10-07  4:13 Sam James
2024-10-07  4:13 Sam James
2024-10-08  7:09 Florian Schmaus
2024-10-08 15:29 Ulrich Müller
2024-10-08 15:29 Ulrich Müller
2024-10-08 15:32 David Seifert
2024-10-08 15:32 David Seifert
2024-10-08 15:32 David Seifert
2024-10-08 15:32 David Seifert
2024-10-08 15:32 David Seifert
2024-10-08 15:32 David Seifert
2024-10-08 15:32 David Seifert
2024-10-08 15:32 David Seifert
2024-10-08 15:32 David Seifert
2024-10-08 15:32 David Seifert
2024-10-08 15:32 David Seifert
2024-10-08 15:32 David Seifert
2024-10-08 15:32 David Seifert
2024-10-08 15:32 David Seifert
2024-10-08 15:32 David Seifert
2024-10-08 15:32 David Seifert
2024-10-08 15:32 David Seifert
2024-10-08 15:32 David Seifert
2024-10-08 15:32 David Seifert
2024-10-08 15:32 David Seifert
2024-10-08 15:32 David Seifert
2024-10-08 15:32 David Seifert
2024-10-08 15:32 David Seifert
2024-10-08 15:32 David Seifert
2024-10-08 15:32 David Seifert
2024-10-09 11:45 Michał Górny
2024-10-10 14:47 Andrew Ammerlaan
2024-10-15  7:17 Michał Górny
2024-10-15 13:13 Michał Górny
2024-10-16  4:54 Michał Górny
2024-10-16  4:54 Michał Górny
2024-10-16  4:54 Michał Górny
2024-10-16 16:13 Andreas Sturmlechner
2024-10-18 17:54 Ulrich Müller
2024-10-18 17:54 Ulrich Müller
2024-10-18 17:54 Ulrich Müller
2024-10-19 13:47 Ionen Wolkens
2024-10-21  9:32 Sam James
2024-10-23 12:18 Michał Górny
2024-10-29 13:01 Michał Górny
2024-10-29 23:22 Maciej Barć
2024-10-29 23:22 Maciej Barć
2024-10-30  2:27 Sam James
2024-10-30 11:43 Miroslav Šulc
2024-10-30 20:50 Sam James
2024-11-01  9:03 Michał Górny
2024-11-03  9:35 Sam James
2024-11-05 10:47 Florian Schmaus
2024-11-05 10:47 Florian Schmaus
2024-11-06 11:27 Sam James
2024-11-07  5:28 Michał Górny
2024-11-07  5:28 Michał Górny
2024-11-09  6:26 Matt Jolly
2024-11-09  6:26 Matt Jolly
2024-11-09  6:26 Matt Jolly
2024-11-09  7:21 Sam James
2024-11-09  7:31 Matt Jolly
2024-11-09  9:02 Matt Jolly
2024-11-09 10:50 Matt Jolly
2024-11-10 17:24 Sam James
2024-11-11  8:53 Matt Jolly
2024-11-11  8:53 Matt Jolly
2024-11-11 19:28 Sam James
2024-11-11 23:48 Matt Jolly
2024-11-11 23:48 Matt Jolly
2024-11-12  8:09 Andrew Ammerlaan
2024-11-12  9:09 Matt Jolly
2024-11-12 19:19 Sam James
2024-11-13  6:16 Matt Jolly
2024-11-13 18:21 Michał Górny
2024-11-13 19:22 Sam James
2024-11-14  0:36 Sam James
2024-11-17  5:27 Matt Jolly
2024-11-17  5:27 Matt Jolly
2024-11-18  9:28 Sam James
2024-11-18 11:11 Sam James
2024-11-18 16:44 Mike Gilbert
2024-11-18 19:32 Michał Górny
2024-11-19 14:50 Sam James
2024-11-19 15:01 Sam James
2024-11-20 12:05 Sam James
2024-11-20 12:15 Sam James
2024-11-20 12:20 Sam James
2024-11-20 12:37 Sam James
2024-11-22 19:25 Sam James
2024-11-23 13:15 Michał Górny
2024-11-24 19:01 Michał Górny
2024-11-26  1:45 Maciej Barć
2024-11-26  1:45 Maciej Barć
2024-11-26 17:28 Florian Schmaus
2024-11-27  9:21 Nowa Ammerlaan
2024-11-29 21:18 Eli Schwartz
2024-11-29 21:18 Eli Schwartz
2024-11-29 21:18 Eli Schwartz
2024-11-29 21:18 Eli Schwartz
2024-11-29 21:18 Eli Schwartz
2024-11-30  2:08 Sam James
2024-11-30  5:10 Sam James
2024-11-30  5:10 Sam James
2024-11-30  7:17 Michał Górny
2024-11-30  7:17 Michał Górny
2024-11-30 13:09 Sam James
2024-11-30 14:36 Sam James
2024-12-01  8:53 Sam James
2024-12-01  9:25 Sam James
2024-12-01 12:12 Sam James
2024-12-02  8:46 Matt Jolly
2024-12-02  8:46 Matt Jolly
2024-12-04 11:33 Matt Jolly
2024-12-04 11:34 Matt Jolly
2024-12-06  5:10 Ionen Wolkens
2024-12-06  7:43 Miroslav Šulc
2024-12-06  7:43 Miroslav Šulc
2024-12-06  7:44 Miroslav Šulc
2024-12-06 11:33 Nowa Ammerlaan
2024-12-06 21:55 Sam James
2024-12-07 23:23 Sam James
2024-12-08  1:11 Sam James
2024-12-08 23:34 Matt Jolly
2024-12-08 23:34 Matt Jolly
2024-12-09 18:49 Ulrich Müller
2024-12-10  5:21 Ionen Wolkens
2024-12-11 11:52 Ionen Wolkens
2024-12-11 11:52 Ionen Wolkens
2024-12-11 11:52 Ionen Wolkens
2024-12-12  7:47 Sam James
2024-12-12  7:47 Sam James
2024-12-12  7:47 Sam James
2024-12-12 17:03 Florian Schmaus
2024-12-12 17:03 Florian Schmaus
2024-12-12 17:03 Florian Schmaus
2024-12-13 10:02 Florian Schmaus
2024-12-13 13:11 Hans de Graaff
2024-12-14 12:47 Sam James
2024-12-14 16:33 Sam James
2024-12-14 18:43 Sam James
2024-12-15  3:08 Sam James
2024-12-15  9:47 Sam James
2024-12-15 12:48 Sam James
2024-12-16  5:57 Michał Górny
2024-12-16 15:17 Sam James
2024-12-16 18:45 Ulrich Müller
2024-12-16 18:45 Ulrich Müller
2024-12-17 17:14 Sam James
2024-12-17 17:34 Sam James
2024-12-17 21:44 Andreas Sturmlechner
2024-12-17 22:14 Andreas Sturmlechner
2024-12-18  2:46 Sam James
2024-12-18  3:00 Matt Turner
2024-12-18  3:00 Matt Turner
2024-12-21 10:28 Michał Górny
2024-12-22  1:30 Sam James
2024-12-22  3:20 Matt Jolly
2024-12-22 19:41 Sam James
2024-12-23 17:10 Andreas Sturmlechner
2024-12-25 15:08 Hans de Graaff
2024-12-26 10:59 Sam James
2024-12-27 21:25 Michał Górny
2024-12-28 14:51 Sam James
2024-12-28 19:43 Alfredo Tupone
2024-12-29  9:22 Ulrich Müller
2024-12-30 11:35 Michał Górny
2024-12-30 11:35 Michał Górny
2024-12-30 11:35 Michał Górny
2024-12-30 11:35 Michał Górny
2024-12-30 11:35 Michał Górny
2024-12-30 11:35 Michał Górny
2024-12-30 11:35 Michał Górny
2024-12-30 11:35 Michał Górny
2024-12-30 11:35 Michał Górny
2024-12-30 11:35 Michał Górny
2025-01-01 10:06 James Le Cuirot
2025-01-01 15:45 Miroslav Šulc
2025-01-02 17:08 Michał Górny
2025-01-02 17:08 Michał Górny
2025-01-02 17:08 Michał Górny
2025-01-02 18:33 Sam James
2025-01-02 23:32 Sam James
2025-01-02 23:34 Sam James
2025-01-03  0:59 Sam James
2025-01-03 17:54 James Le Cuirot
2025-01-04 15:28 Michał Górny
2025-01-04 15:28 Michał Górny
2025-01-04 21:34 Sam James
2025-01-04 21:34 Sam James
2025-01-05 13:39 Nowa Ammerlaan
2025-01-05 13:39 Nowa Ammerlaan
2025-01-06 14:37 Nowa Ammerlaan
2025-01-06 20:25 Nowa Ammerlaan
2025-01-06 20:25 Nowa Ammerlaan
2025-01-06 20:25 Nowa Ammerlaan
2025-01-07 11:34 Miroslav Šulc
2025-01-08  2:18 Ionen Wolkens
2025-01-08  6:33 Joonas Niilola
2025-01-10 13:15 Michał Górny
2025-01-10 16:44 Nowa Ammerlaan
2025-01-11  8:10 Arthur Zamarin
2025-01-11 18:12 Michał Górny
2025-01-14  4:53 Sam James
2025-01-14 17:07 Maciej Barć
2025-01-15 14:39 Ulrich Müller
2025-01-15 19:38 Sam James
2025-01-16  8:21 Sam James
2025-01-16 14:06 Michał Górny
2025-01-18  8:21 Michał Górny
2025-01-18 15:09 Michał Górny
2025-01-18 23:51 Sam James
2025-01-18 23:51 Sam James
2025-01-18 23:51 Sam James
2025-01-19  1:16 Sam James
2025-01-20  9:44 Petr Vaněk
2025-01-20  9:44 Petr Vaněk
2025-01-21 23:13 Sam James
2025-01-22 19:15 Michał Górny
2025-01-22 19:15 Michał Górny
2025-01-25 13:33 Michał Górny
2025-01-28  7:22 Sam James
2025-01-28 12:15 Sam James
2025-01-29 23:22 Matt Jolly
2025-01-30  1:31 Sam James
2025-01-31 21:51 Michał Górny
2025-01-31 21:51 Michał Górny
2025-02-01  0:40 Ionen Wolkens
2025-02-01 13:14 Michał Górny
2025-02-05 20:37 Sam James
2025-02-06 16:40 Sam James
2025-02-07 18:04 Sam James
2025-02-07 18:33 Sam James
2025-02-08 11:51 Michał Górny
2025-02-09 19:13 Andreas Sturmlechner
2025-02-09 19:13 Andreas Sturmlechner
2025-02-09 19:13 Andreas Sturmlechner
2025-02-10  6:43 Sam James
2025-02-11  8:39 Sam James
2025-02-11 11:29 Michał Górny
2025-02-13  8:49 Patrick Lauer
2025-02-13 17:18 Ulrich Müller
2025-02-13 17:51 Sam James
2025-02-15  7:38 Michał Górny
2025-02-15  9:04 Hans de Graaff
2025-02-15  9:04 Hans de Graaff
2025-02-15  9:04 Hans de Graaff
2025-02-16 18:41 Mike Gilbert
2025-02-17 21:52 Mike Gilbert
2025-02-21  7:25 Petr Vaněk
2025-02-21 11:14 Arthur Zamarin
2025-02-21 11:14 Arthur Zamarin
2025-02-22 15:19 Michał Górny
2025-02-22 22:08 Matt Jolly
2025-02-25  9:16 Matt Jolly
2025-02-25 14:03 Michał Górny
2025-02-25 16:36 Florian Schmaus
2025-02-25 16:36 Florian Schmaus
2025-02-26  8:47 Ionen Wolkens
2025-02-26 22:05 Andreas Sturmlechner
2025-03-01 12:58 Michał Górny
2025-03-03 17:47 Nowa Ammerlaan
2025-03-03 17:47 Nowa Ammerlaan
2025-03-03 19:27 Sam James
2025-03-03 19:27 Sam James
2025-03-04 22:09 Sam James
2025-03-04 22:32 Andreas Sturmlechner
2025-03-04 22:32 Andreas Sturmlechner
2025-03-07  0:58 Sam James
2025-03-07  1:23 Sam James
2025-03-07  1:23 Sam James
2025-03-07  1:25 Sam James
2025-03-07 18:32 Sam James
2025-03-08 14:02 Arthur Zamarin
2025-03-08 14:02 Arthur Zamarin
2025-03-08 14:02 Arthur Zamarin
2025-03-08 14:02 Arthur Zamarin
2025-03-08 14:02 Arthur Zamarin
2025-03-08 16:59 Michał Górny
2025-03-10  1:55 Sam James
2025-03-11  9:04 Ionen Wolkens
2025-03-11 13:23 Sam James
2025-03-11 13:23 Sam James
2025-03-11 14:56 Michał Górny
2025-03-11 22:15 Sam James
2025-03-12 10:14 Ionen Wolkens
2025-03-12 20:02 Sam James
2025-03-13 13:18 Sam James
2025-03-13 17:21 Sam James
2025-03-13 18:02 Sam James
2025-03-13 18:11 Sam James
2025-03-14  2:50 Sam James
2025-03-17 20:13 Michał Górny
2025-03-22  0:52 Sam James
2025-03-22 10:43 Michał Górny
2025-03-24  6:53 Sam James
2025-03-24  6:55 Sam James
2025-03-25  8:15 Sam James
2025-03-26 22:54 Sam James
2025-03-28  9:24 Nowa Ammerlaan
2025-03-28 15:06 Sam James
2025-03-29 10:27 Michał Górny
2025-03-29 15:58 James Le Cuirot
2025-04-01 13:58 Florian Schmaus
2025-04-02  7:06 Michał Górny
2025-04-02  7:06 Michał Górny
2025-04-02  7:06 Michał Górny
2025-04-02  7:06 Michał Górny
2025-04-02  7:06 Michał Górny
2025-04-02  7:06 Michał Górny
2025-04-02  7:06 Michał Górny
2025-04-02  7:06 Michał Górny
2025-04-04 17:08 Sam James
2025-04-05 12:24 Michał Górny
2025-04-07 20:48 Sam James
2025-04-10  9:18 Sam James
2025-04-10  9:28 Sam James
2025-04-10 14:23 Sam James
2025-04-12  8:59 Michał Górny
2025-04-12 16:34 Sam James
2025-04-12 16:34 Sam James
2025-04-13  9:14 Sam James
2025-04-13 11:45 Sam James
2025-04-14 16:07 Sam James
2025-04-15 10:15 Michał Górny
2025-04-15 14:24 Michał Górny
2025-04-15 14:24 Michał Górny
2025-04-15 14:24 Michał Górny
2025-04-15 14:24 Michał Górny
2025-04-15 14:24 Michał Górny
2025-04-15 14:24 Michał Górny
2025-04-16  2:42 Sam James
2025-04-17  1:27 Sam James
2025-04-19  1:31 Sam James
2025-04-19  1:31 Sam James
2025-04-19  8:37 Hans de Graaff
2025-04-19 10:28 Michał Górny
2025-04-19 19:16 Sam James
2025-04-20 11:50 Michał Górny
2025-04-21  2:38 Ionen Wolkens
2025-04-22 11:24 Ionen Wolkens
2025-04-23 11:37 Matt Jolly
2025-04-23 15:09 Ulrich Müller
2025-04-23 15:18 Sam James
2025-04-23 15:18 Sam James
2025-04-23 15:18 Sam James
2025-04-23 15:18 Sam James
2025-04-23 15:18 Sam James
2025-04-23 15:18 Sam James
2025-04-23 15:18 Sam James
2025-04-23 15:18 Sam James
2025-04-23 15:18 Sam James
2025-04-23 15:18 Sam James
2025-04-23 15:18 Sam James
2025-04-23 15:18 Sam James
2025-04-23 15:18 Sam James
2025-04-23 15:18 Sam James
2025-04-23 15:18 Sam James
2025-04-23 15:18 Sam James
2025-04-24 20:44 Sam James
2025-04-26 17:52 Sam James
2025-04-26 18:03 Sam James
2025-04-26 18:09 Sam James
2025-04-27  8:27 Ionen Wolkens
2025-04-27  8:27 Ionen Wolkens
2025-04-27 10:52 Ionen Wolkens
2025-04-27 13:17 Ionen Wolkens
2025-04-27 22:53 Sam James
2025-05-01 11:36 Michał Górny
2025-05-02 16:01 Michał Górny
2025-05-03  5:28 Sam James
2025-05-03 19:42 Michał Górny
2025-05-05 15:32 Sam James
2025-05-05 15:45 Sam James
2025-05-05 15:56 Sam James
2025-05-06 17:41 Eli Schwartz
2025-05-08 12:35 Michał Górny
2025-05-08 12:35 Michał Górny
2025-05-08 12:35 Michał Górny
2025-05-08 12:35 Michał Górny
2025-05-10  1:54 Sam James
2025-05-10 12:57 Michał Górny
2025-05-10 12:57 Michał Górny
2025-05-10 13:03 Michał Górny
2025-05-10 20:04 Sam James
2025-05-11  4:34 Sam James
2025-05-15  7:11 Arsen Arsenović
2025-05-15  7:11 Arsen Arsenović
2025-05-15  7:11 Sam James
2025-05-16  2:00 Ionen Wolkens
2025-05-16  9:31 Michał Górny
2025-05-16  9:59 Sam James
2025-05-17 12:59 Michał Górny
2025-05-17 12:59 Michał Górny
2025-05-19 15:22 Matt Turner
2025-05-20 22:55 Ionen Wolkens
2025-05-21 19:21 Andreas Sturmlechner
2025-05-22 19:39 Mike Gilbert
2025-05-23 15:42 Ionen Wolkens
2025-05-24 11:11 Andreas K. Hüttel
2025-05-24 11:56 Michał Górny
2025-05-24 17:08 Mike Gilbert
2025-05-24 23:50 Mike Gilbert
2025-05-25 16:41 Mike Gilbert
2025-05-26  9:43 Sam James
2025-05-27 18:17 Mike Gilbert
2025-05-27 18:17 Mike Gilbert
2025-05-27 18:17 Mike Gilbert
2025-05-28  3:36 Sam James
2025-05-28 11:54 Michał Górny
2025-05-28 11:54 Michał Górny
2025-05-29  2:47 Ionen Wolkens
2025-05-29 12:24 Sam James
2025-05-30  6:33 Hans de Graaff
2025-06-01 15:13 Ionen Wolkens
2025-06-03  1:32 Sam James
2025-06-03 17:01 Andreas Sturmlechner
2025-06-03 17:01 Andreas Sturmlechner
2025-06-03 17:01 Andreas Sturmlechner
2025-06-04  8:48 Hans de Graaff
2025-06-05 10:56 James Le Cuirot
2025-06-05 10:56 James Le Cuirot
2025-06-05 10:56 James Le Cuirot
2025-06-05 10:56 James Le Cuirot
2025-06-05 10:56 James Le Cuirot
2025-06-05 10:56 James Le Cuirot
2025-06-05 11:11 James Le Cuirot
2025-06-05 11:11 James Le Cuirot
2025-06-07 11:18 Ionen Wolkens
2025-06-07 18:05 Michał Górny
2025-06-07 18:05 Michał Górny
2025-06-08 12:03 Sam James
2025-06-09  8:07 Ionen Wolkens
2025-06-09 20:30 James Le Cuirot
2025-06-09 20:47 Andreas Sturmlechner
2025-06-10  8:02 Ionen Wolkens
2025-06-11  1:48 Sam James
2025-06-11 15:30 Andreas Sturmlechner
2025-06-12 11:58 Sam James
2025-06-12 19:20 Andreas K. Hüttel
2025-06-13 23:11 Mike Gilbert
2025-06-14  9:06 Nowa Ammerlaan
2025-06-14  9:06 Nowa Ammerlaan
2025-06-14 14:26 Sam James
2025-06-14 14:26 Sam James
2025-06-15 17:39 Andreas Sturmlechner
2025-06-18  7:26 Sam James
2025-06-21 10:07 David Seifert
2025-06-21 10:07 David Seifert
2025-06-22 10:58 Andreas Sturmlechner
2025-06-22 10:58 Andreas Sturmlechner
2025-06-22 10:58 Andreas Sturmlechner
2025-06-22 10:58 Andreas Sturmlechner
2025-06-24 19:44 Andreas Sturmlechner
2025-06-25  4:35 Michał Górny
2025-06-25  4:35 Michał Górny
2025-06-25  4:35 Michał Górny
2025-06-25  4:35 Michał Górny
2025-06-28 15:03 Michał Górny
2025-06-28 15:03 Michał Górny
2025-06-29  3:20 Michał Górny
2025-06-29 22:57 Sam James
2025-06-30  6:09 Ionen Wolkens
2025-07-02  8:20 Michał Górny
2025-07-02 10:53 Michał Górny
2025-07-02 17:38 Andreas Sturmlechner
2025-07-04  3:26 Eli Schwartz
2025-07-05  7:16 Sam James
2025-07-05  7:16 Sam James
2025-07-05  7:16 Sam James
2025-07-05  7:59 Sam James
2025-07-05  8:18 Sam James
2025-07-05 12:44 Ionen Wolkens
2025-07-05 22:35 Ionen Wolkens
2025-07-07 11:46 Louis Sautier
2025-07-07 20:58 Sam James
2025-07-07 22:25 Sam James
2025-07-07 22:51 Sam James
2025-07-08 23:35 Sam James
2025-07-09 11:22 James Le Cuirot
2025-07-09 11:22 James Le Cuirot
2025-07-10  7:51 Miroslav Šulc
2025-07-12  5:05 Michał Górny
2025-07-12  5:05 Michał Górny
2025-07-12  5:05 Michał Górny
2025-07-13  5:08 Sam James
2025-07-13  5:08 Sam James
2025-07-13 11:20 Nowa Ammerlaan
2025-07-13 20:03 Michał Górny
2025-07-14 18:55 Andreas K. Hüttel
2025-07-18  4:39 Michał Górny
2025-07-18  4:39 Michał Górny
2025-07-19 11:35 Sam James
2025-07-19 11:35 Sam James
2025-07-20 18:10 Nowa Ammerlaan
2025-07-23 11:57 Petr Vaněk
2025-07-23 20:38 Sam James
2025-07-24 16:03 Michał Górny
2025-07-25  5:57 Michał Górny
2025-07-25  8:21 Nowa Ammerlaan
2025-07-25 12:48 Alfredo Tupone
2025-07-26 19:53 Michał Górny
2025-07-27  1:51 Sam James
2025-07-27 12:39 Florian Schmaus
2025-07-28  5:00 Sam James
2025-07-29  5:34 Ionen Wolkens
2025-07-29  8:36 Matt Jolly
2025-07-30  5:06 Eli Schwartz
2025-08-02 10:29 Michał Górny
2025-08-02 10:29 Michał Górny
2025-08-09  9:47 Michał Górny
2025-08-09 16:49 Michał Górny
2025-08-11  5:38 Eli Schwartz
2025-08-11  5:38 Eli Schwartz
2025-08-13 11:01 Sam James
2025-08-13 11:01 Sam James
2025-08-13 11:01 Sam James
2025-08-13 12:03 Sam James
2025-08-13 12:03 Sam James
2025-08-14  8:09 Sam James
2025-08-14 16:33 Mike Gilbert
2025-08-14 16:33 Mike Gilbert
2025-08-16 13:51 Michał Górny
2025-08-18 17:58 Andreas Sturmlechner
2025-08-18 17:58 Andreas Sturmlechner
2025-08-20 22:29 James Le Cuirot
2025-08-21  8:18 Michał Górny
2025-08-21  8:22 Michał Górny
2025-08-22  5:31 Sam James
2025-08-22  5:36 Sam James
2025-08-26 22:10 James Le Cuirot
2025-08-30 13:07 Ionen Wolkens
2025-08-31 13:28 Michał Górny
2025-08-31 13:28 Michał Górny
2025-09-01 10:31 Sam James
2025-09-02 20:05 Eli Schwartz
2025-09-03  1:28 Ionen Wolkens
2025-09-03  1:32 Ionen Wolkens
2025-09-03 16:48 Jason Zaman
2025-09-03 16:48 Jason Zaman
2025-09-06  7:01 Michał Górny
2025-09-06  7:01 Michał Górny
2025-09-06  7:01 Michał Górny
2025-09-06 15:13 Sam James
2025-09-06 20:02 Sam James
2025-09-06 20:02 Sam James
2025-09-06 20:43 Ionen Wolkens
2025-09-06 21:32 Sam James
2025-09-07 19:47 Michał Górny
2025-09-08 18:15 Arthur Zamarin
2025-09-11  9:51 Sam James
2025-09-11 16:49 Nowa Ammerlaan
2025-09-11 19:48 Michał Górny
2025-09-11 20:19 Nowa Ammerlaan
2025-09-11 20:19 Nowa Ammerlaan
2025-09-19  3:13 Ionen Wolkens
2025-09-24  2:27 Michał Górny
2025-09-24  2:27 Michał Górny
2025-09-25 13:38 Patrick Lauer
2025-09-25 16:53 Nowa Ammerlaan
2025-09-26  5:52 Alfredo Tupone
2025-09-26  6:37 Patrick Lauer
2025-09-26 10:10 Nowa Ammerlaan
2025-09-30 17:34 Alfredo Tupone
2025-10-01  6:35 Michał Górny
2025-10-01 15:08 Sam James
2025-10-03 16:27 Sam James
2025-10-03 16:27 Sam James
2025-10-03 19:11 Michał Górny
2025-10-03 19:11 Michał Górny
2025-10-04  9:16 Michał Górny
2025-10-04  9:16 Michał Górny
2025-10-05 21:50 Andreas Sturmlechner
2025-10-05 21:50 Andreas Sturmlechner
2025-10-05 21:50 Andreas Sturmlechner
2025-10-05 21:50 Andreas Sturmlechner
2025-10-05 21:50 Andreas Sturmlechner
2025-10-09  2:25 Michał Górny
2025-10-11  7:08 Sam James
2025-10-11  7:12 Sam James
2025-10-11 19:54 Michał Górny
2025-10-12 14:20 Sam James
2025-10-16 18:02 Nowa Ammerlaan
2025-10-16 19:14 Andreas Sturmlechner
2025-10-16 19:14 Andreas Sturmlechner
2025-10-16 19:14 Andreas Sturmlechner
2025-10-16 19:14 Andreas Sturmlechner
2025-10-16 19:14 Andreas Sturmlechner
2025-10-16 19:14 Andreas Sturmlechner
2025-10-16 19:14 Andreas Sturmlechner
2025-10-16 19:14 Andreas Sturmlechner
2025-10-16 19:14 Andreas Sturmlechner
2025-10-18 15:20 Sam James
2025-10-19 21:54 Andreas Sturmlechner
2025-10-21  0:25 Sam James
2025-10-21 20:20 Sam James
2025-10-22 19:12 Michał Górny
2025-10-22 19:12 Michał Górny
2025-10-23 18:19 Michał Górny
2025-10-23 18:19 Michał Górny
2025-10-23 18:19 Michał Górny
2025-10-23 18:19 Michał Górny
2025-10-23 18:19 Michał Górny
2025-10-25  1:07 Sam James
2025-10-26  4:07 Sam James
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox