* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2015-11-11  0:56 Mike Frysinger
  0 siblings, 0 replies; 120+ messages in thread
From: Mike Frysinger @ 2015-11-11  0:56 UTC (permalink / raw
  To: gentoo-commits
commit:     97c7b4f967e2b43984ad948ad0d77e84a1a55016
Author:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
AuthorDate: Wed Nov 11 00:55:26 2015 +0000
Commit:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
CommitDate: Wed Nov 11 00:55:26 2015 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=97c7b4f9
checkbashisms: also flag echo -e/-n usage
Since we don't require echo support the -e or -n flag, and we know some
shells do not support them, make sure we flag them in our scripts too.
 bin/install-qa-check.d/60openrc | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/install-qa-check.d/60openrc b/bin/install-qa-check.d/60openrc
index 9b7fc6d..1e56b2f 100644
--- a/bin/install-qa-check.d/60openrc
+++ b/bin/install-qa-check.d/60openrc
@@ -24,7 +24,7 @@ openrc_check() {
 			for i in "${ED}${d}"/* ; do
 				[[ -e ${i} ]] || continue
 				[[ -L ${i} ]] && continue
-				f=$("${checkbashisms}" -f "${i}" 2>&1)
+				f=$("${checkbashisms}" -n -f "${i}" 2>&1)
 				[[ $? != 0 && -n ${f} ]] || continue
 				eqawarn "QA Notice: shell script appears to use non-POSIX feature(s):"
 				while read -r ;
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2025-06-28  2:30 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2025-06-28  2:30 UTC (permalink / raw
  To: gentoo-commits
commit:     db67b757bba1fe1263d5b6c2ca5cd987b6b1e61a
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Thu Jun 26 14:42:40 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jun 28 02:30:19 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=db67b757
10executable-issues: use the += operator to append to variables
As an extension to the Shell Command Language, bash supports the +=
operator, which allows for the values of variables to be appended to.
There are three instances in which the "10executable-issues" unit can
benefit from this operator. Have it do so.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/10executable-issues | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/bin/install-qa-check.d/10executable-issues b/bin/install-qa-check.d/10executable-issues
index 164f062a21..1311486f2c 100644
--- a/bin/install-qa-check.d/10executable-issues
+++ b/bin/install-qa-check.d/10executable-issues
@@ -67,7 +67,7 @@ elf_check() {
 	local qa_var="QA_TEXTRELS_${ARCH/-/_}"
 	[[ -n ${!qa_var} ]] && QA_TEXTRELS=${!qa_var}
 	[[ -n ${QA_STRICT_TEXTRELS} ]] && QA_TEXTRELS=""
-	export QA_TEXTRELS="${QA_TEXTRELS} lib*/modules/*.ko"
+	export QA_TEXTRELS+=" lib*/modules/*.ko"
 	f=$(scanelf -qyRF '%t %p' "${ED%/}/" | grep -v 'usr/lib/debug/')
 	if [[ -n ${f} ]] ; then
 		scanelf -qyRAF '%T %p' "${PORTAGE_BUILDDIR}"/ &> "${T}"/scanelf-textrel.log
@@ -109,8 +109,8 @@ elf_check() {
 				qa_var="QA_WX_LOAD_${ARCH/-/_}"
 				[[ -n ${!qa_var} ]] && QA_WX_LOAD=${!qa_var}
 				[[ -n ${QA_STRICT_WX_LOAD} ]] && QA_WX_LOAD=""
-				export QA_EXECSTACK="${QA_EXECSTACK} lib*/modules/*.ko"
-				export QA_WX_LOAD="${QA_WX_LOAD} lib*/modules/*.ko"
+				export QA_EXECSTACK+=" lib*/modules/*.ko"
+				export QA_WX_LOAD+=" lib*/modules/*.ko"
 				f=$(scanelf -qyRAF '%e %p' "${ED%/}/" | grep -v 'usr/lib/debug/')
 				;;
 		esac
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2025-06-28  2:30 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2025-06-28  2:30 UTC (permalink / raw
  To: gentoo-commits
commit:     3943295b9cf6624a85a0263dcdb76bfaa4d182b8
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Aug 14 11:14:18 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jun 28 02:30:18 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=3943295b
60openrc: jettison a superfluous for loop
Presently, the openrc_check() function contains a loop that iterates
exactly once. Get rid of it, along with the SC2043 warning that
accompanied it.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/60openrc | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/bin/install-qa-check.d/60openrc b/bin/install-qa-check.d/60openrc
index 8b0ab0a8dd..17b84fa057 100644
--- a/bin/install-qa-check.d/60openrc
+++ b/bin/install-qa-check.d/60openrc
@@ -30,8 +30,8 @@ openrc_check() {
 
 	local checkbashisms=$(type -P checkbashisms)
 	if [[ -n ${checkbashisms} ]] ; then
-		for d in /etc/init.d ; do
-			[[ -d ${ED}${d} ]] || continue
+		d=/etc/init.d
+		if [[ -d ${ED}${d} ]]; then
 			for i in "${ED}${d}"/* ; do
 				[[ -e ${i} ]] || continue
 				[[ -L ${i} ]] && continue
@@ -42,7 +42,7 @@ openrc_check() {
 					do eqawarn "   ${REPLY}"
 				done <<< "${f//${ED}}"
 			done
-		done
+		fi
 	fi
 }
 
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2025-06-09  2:51 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2025-06-09  2:51 UTC (permalink / raw
  To: gentoo-commits
commit:     423c91f6be7d291096c5035105631491f6d5d338
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Jun  8 14:23:48 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Jun  9 02:51:07 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=423c91f6
90config-impl-decl: call the find0() function instead of find(1)
Initially, the find0() function was introduced for the ecompress
utility, so as not to have to write out the "-files0-from -" primary in
full on each occasion that find(1) is invoked. Since then, it has been
relocated to the "isolated-functions.sh" unit and now serves the
additional purpose of retaining compatibility with the outdated GitHub
CI environment (which has an older version of findutils).
Therefore, it makes sense to have the "90config-impl-decl" QA test also
call find0().
See-also: a0210b3c49ea346b1e999f92a7ed89802e8d6849
See-also: d887c7fd33b5f136ff62d423d7a11980fb9faca1
Bug: https://bugs.gentoo.org/957550
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/90config-impl-decl | 3 +--
 1 file changed, 1 insertion(+), 2 deletions(-)
diff --git a/bin/install-qa-check.d/90config-impl-decl b/bin/install-qa-check.d/90config-impl-decl
index 68950b6292..6428cfed3c 100644
--- a/bin/install-qa-check.d/90config-impl-decl
+++ b/bin/install-qa-check.d/90config-impl-decl
@@ -93,8 +93,7 @@ find_log_targets() {
 		find_args+=( '-name' "${log}" '-o' )
 	done
 	unset -v 'find_args[-1]'
-	printf '%s\0' "${WORKDIR}" |
-		find -files0-from - -type f \( "${find_args[@]}" \) -print0
+	printf '%s\0' "${WORKDIR}" | find0 -type f \( "${find_args[@]}" \) -print0
 }
 
 has_utf8_ctype() {
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2025-06-05 11:22 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2025-06-05 11:22 UTC (permalink / raw
  To: gentoo-commits
commit:     8ab85ee0b5e4725affcb3bd117add3d875e5246c
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Mon Aug  8 06:42:11 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Jun  5 11:22:08 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=8ab85ee0
10ignored-flags: use test -v instead of ${param-unset}
Wherever there is a need to test whether a variable is set, employ the
[[ ! -v name ]] command to do so. This is supported as of bash-4.2.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/10ignored-flags | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/install-qa-check.d/10ignored-flags b/bin/install-qa-check.d/10ignored-flags
index 7a92be502b..ec63c5527f 100644
--- a/bin/install-qa-check.d/10ignored-flags
+++ b/bin/install-qa-check.d/10ignored-flags
@@ -43,7 +43,7 @@ ignored_flag_check() {
 
 		if [[ -f "${T}"/scanelf-ignored-CFLAGS.log ]] ; then
 
-			if [ "${QA_STRICT_FLAGS_IGNORED-unset}" = unset ] ; then
+			if [[ ! -v QA_STRICT_FLAGS_IGNORED ]] ; then
 				for x in "${QA_FLAGS_IGNORED[@]}" ; do
 					sed -e "s#^${x#/}\$##" -i "${T}"/scanelf-ignored-CFLAGS.log
 				done
@@ -74,7 +74,7 @@ ignored_flag_check() {
 			<(scanelf -qyRF '#s%p' -s __gentoo_check_ldflags__ "${ED%/}/" | LC_ALL=C sort))
 		if [[ -n ${f} ]] ; then
 			echo "${f}" > "${T}"/scanelf-ignored-LDFLAGS.log
-			if [ "${QA_STRICT_FLAGS_IGNORED-unset}" = unset ] ; then
+			if [[ ! -v QA_STRICT_FLAGS_IGNORED ]] ; then
 				for x in "${QA_FLAGS_IGNORED[@]}" ; do
 					sed -e "s#^${x#/}\$##" -i "${T}"/scanelf-ignored-LDFLAGS.log
 				done
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2025-06-05 11:22 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2025-06-05 11:22 UTC (permalink / raw
  To: gentoo-commits
commit:     efa72737441db0b88ceeff1222eaaca868171584
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Mon Aug  8 03:04:53 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Jun  5 11:22:07 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=efa72737
80multilib-strict: use test -v instead of ${param-unset}
Wherever there is a need to test whether a variable is unset, employ the
[[ ! -v name ]] command to do so. This is supported as of bash-4.2.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/80multilib-strict | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/install-qa-check.d/80multilib-strict b/bin/install-qa-check.d/80multilib-strict
index b3803a980a..39ac0f5672 100644
--- a/bin/install-qa-check.d/80multilib-strict
+++ b/bin/install-qa-check.d/80multilib-strict
@@ -23,7 +23,7 @@ multilib_strict_check() {
 			if [[ ${QA_MULTILIB_PATHS@a} != *a* ]] ; then
 				read -rd '' -a QA_MULTILIB_PATHS <<<"${QA_MULTILIB_PATHS}"
 			fi
-			if [ "${QA_STRICT_MULTILIB_PATHS-unset}" = unset ] ; then
+			if [[ ! -v QA_STRICT_MULTILIB_PATHS ]] ; then
 				for dir in "${QA_MULTILIB_PATHS[@]}" ; do
 					sed -e "s#^${dir#/}\$##" -i "${T}/multilib-strict.log"
 				done
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2025-06-05 11:22 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2025-06-05 11:22 UTC (permalink / raw
  To: gentoo-commits
commit:     a61a7cc8f25db7482fef700700f2b1e3bbace738
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Mon Aug  8 06:43:05 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Jun  5 11:22:09 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=a61a7cc8
80libraries: use test -v instead of ${param-unset}
Wherever there is a need to test whether a variable is set, employ the
[[ ! -v name ]] command to do so. This is supported as of bash-4.2.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/80libraries | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/install-qa-check.d/80libraries b/bin/install-qa-check.d/80libraries
index 4dd392255a..72058b73f4 100644
--- a/bin/install-qa-check.d/80libraries
+++ b/bin/install-qa-check.d/80libraries
@@ -19,7 +19,7 @@ scanelf_lib_check() {
 	f=$(scanelf -ByF '%S %p' "${ED%/}"/{,usr/}lib*/lib*.so* | awk '$2 == "" { print }' | sed -e "s:^[[:space:]]${ED%/}/:/:")
 	if [[ -n ${f} ]] ; then
 		echo "${f}" > "${T}"/scanelf-missing-SONAME.log
-		if [[ "${QA_STRICT_SONAME-unset}" == unset ]] ; then
+		if [[ ! -v QA_STRICT_SONAME ]] ; then
 			if [[ ${#QA_SONAME[@]} -gt 1 ]] ; then
 				for x in "${QA_SONAME[@]}" ; do
 					sed -e "s#^/${x#/}\$##" -i "${T}"/scanelf-missing-SONAME.log
@@ -62,7 +62,7 @@ scanelf_lib_check() {
 	fi
 	if [[ -n ${f} ]] ; then
 		echo "${f}" > "${T}"/scanelf-missing-NEEDED.log
-		if [[ "${QA_STRICT_DT_NEEDED-unset}" == unset ]] ; then
+		if [[ ! -v QA_STRICT_DT_NEEDED ]] ; then
 			if [[ ${#QA_DT_NEEDED[@]} -gt 1 ]] ; then
 				for x in "${QA_DT_NEEDED[@]}" ; do
 					sed -e "s#^/${x#/}\$##" -i "${T}"/scanelf-missing-NEEDED.log
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2025-06-05 11:22 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2025-06-05 11:22 UTC (permalink / raw
  To: gentoo-commits
commit:     c88cef651348b4a2bee9803ad9fe2f6e241eacf6
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Thu Jun  5 03:21:19 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Jun  5 11:22:02 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=c88cef65
90gcc-warnings: fix indentation of local declarations
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/90gcc-warnings | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/install-qa-check.d/90gcc-warnings b/bin/install-qa-check.d/90gcc-warnings
index f138fe90df..e0275f8046 100644
--- a/bin/install-qa-check.d/90gcc-warnings
+++ b/bin/install-qa-check.d/90gcc-warnings
@@ -5,8 +5,8 @@
 # TODO: add -Wformat-security
 
 gcc_warn_check() {
-        local i reset_xtrace
-        local -a patterns
+	local i reset_xtrace
+	local -a patterns
 
 	# Evaluate misc gcc warnings
 	# In debug mode, this variable definition and corresponding grep calls
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2025-06-05  3:07 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2025-06-05  3:07 UTC (permalink / raw
  To: gentoo-commits
commit:     5a4698360bf370fbacf9553208f359b660ce5a66
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Thu Jun  5 02:59:42 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Jun  5 03:07:41 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=5a469836
90gcc-warnings: de-deduplicate non-adjacent warnings
Presently, the 90gcc-warnings QA check uses uniq(1) to de-duplicate the
collected warnings. In doing so, it requires for duplicate lines to be
adjacent to one another in order to be effective. However, this will not
necessarily be the case. Instead, use awk(1) to de-duplicate the
warnings while preserving their original order.
Bug: https://bugs.gentoo.org/832138
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/90gcc-warnings | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/install-qa-check.d/90gcc-warnings b/bin/install-qa-check.d/90gcc-warnings
index 691a97f93f..f138fe90df 100644
--- a/bin/install-qa-check.d/90gcc-warnings
+++ b/bin/install-qa-check.d/90gcc-warnings
@@ -170,7 +170,7 @@ gcc_warn_check() {
 		fi \
 		| sed -E -e $'s/\033\[[0-9;]*[A-Za-z]//g' \
 		| grep -E -a "warning: (${patterns[*]})" \
-		| uniq
+		| awk '!seen[$0]++'
 	)
 
 	if (( i > 0 )); then
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2025-05-30  7:37 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2025-05-30  7:37 UTC (permalink / raw
  To: gentoo-commits
commit:     80ce8be0701650cae21c91cfe2925a5e1a208c2a
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Thu May 22 21:19:09 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May 30 07:37:32 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=80ce8be0
90gcc-warnings: improve an ill-informed comment
Explain why LC_CTYPE and LC_COLLATE are adjusted in a slightly more
informative way. Further, clarify why GNU grep -a is beneficial, for it
has nothing to do with UTF-8 but, rather, the presence of NUL bytes.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/90gcc-warnings | 8 +++++---
 1 file changed, 5 insertions(+), 3 deletions(-)
diff --git a/bin/install-qa-check.d/90gcc-warnings b/bin/install-qa-check.d/90gcc-warnings
index 0662a94637..bf749f74b6 100644
--- a/bin/install-qa-check.d/90gcc-warnings
+++ b/bin/install-qa-check.d/90gcc-warnings
@@ -147,10 +147,12 @@ gcc_warn_check() {
 		#': warning: not enough variable arguments to fit a sentinel'
 	)
 
-	# Force C locale to work around slow multibyte locales, bug #160234
-	# Force text mode as newer grep will treat non-ASCII (e.g. UTF-8) as
-	# binary when we run in the C locale.
 	f=$(
+		# Coerce C as the character type for performance reasons, per
+		# bug #160234. Coerce C as the collation to guarantee that
+		# ranges are handled appropriately. Also, pass -a to GNU grep
+		# to prevent binary data - that is, anything containing a NUL
+		# byte - from suppressing the printing of matching lines.
 		export LC_ALL= LC_COLLATE=C LC_CTYPE=C
 		IFS='|'
 		if [[ ${PORTAGE_LOG_FILE} == *.gz ]]; then
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2025-05-30  7:37 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2025-05-30  7:37 UTC (permalink / raw
  To: gentoo-commits
commit:     3a842499e25f78153c8f73935ac4c39609fb8996
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Fri May 23 00:27:47 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May 30 07:37:33 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=3a842499
90gcc-warnings: rename the msgs variable to patterns
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/90gcc-warnings | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/bin/install-qa-check.d/90gcc-warnings b/bin/install-qa-check.d/90gcc-warnings
index 85ed35e52b..c00a33914e 100644
--- a/bin/install-qa-check.d/90gcc-warnings
+++ b/bin/install-qa-check.d/90gcc-warnings
@@ -4,7 +4,7 @@
 
 gcc_warn_check() {
         local i reset_xtrace
-        local -a msgs
+        local -a patterns
 
 	# Evaluate misc gcc warnings
 	# In debug mode, this variable definition and corresponding grep calls
@@ -12,7 +12,7 @@ gcc_warn_check() {
 	reset_xtrace=$(shopt -o -p xtrace)
 	shopt -o -u xtrace
 
-	msgs=(
+	patterns=(
 		# only will and does, no might :)
 		'.*(does|will).*\[-Wstrict-aliasing\]'
 		'.*\[-Wrestrict\]'
@@ -167,7 +167,7 @@ gcc_warn_check() {
 			cat -- "${PORTAGE_LOG_FILE}"
 		fi \
 		| sed -E -e $'s/\033\[[0-9;]*[A-Za-z]//g' \
-		| grep -E -a "warning: (${msgs[*]})" \
+		| grep -E -a "warning: (${patterns[*]})" \
 		| uniq
 	)
 
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2025-05-30  7:37 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2025-05-30  7:37 UTC (permalink / raw
  To: gentoo-commits
commit:     c94b419216e44f9ff27f495003e9a0e50fd634b3
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Thu May 22 23:57:28 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May 30 07:37:32 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=c94b4192
90gcc-warnings: convey warnings in a memory-efficient manner
Rather than synchronously slurp all of the warnings matched against the
contents of PORTAGE_LOG_FILE into a scalar variable before displaying,
read the warnings line by line while asynchronously calling eqawarn for
each. This may help to save memory in the case that many warnings are to
be displayed.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/90gcc-warnings | 33 ++++++++++++++++++---------------
 1 file changed, 18 insertions(+), 15 deletions(-)
diff --git a/bin/install-qa-check.d/90gcc-warnings b/bin/install-qa-check.d/90gcc-warnings
index bf749f74b6..571d6bd066 100644
--- a/bin/install-qa-check.d/90gcc-warnings
+++ b/bin/install-qa-check.d/90gcc-warnings
@@ -3,7 +3,7 @@
 # TODO: add -Wformat-security
 
 gcc_warn_check() {
-        local abort f reset_xtrace
+        local i reset_xtrace
         local -a msgs
 
 	# Evaluate misc gcc warnings
@@ -147,7 +147,14 @@ gcc_warn_check() {
 		#': warning: not enough variable arguments to fit a sentinel'
 	)
 
-	f=$(
+	while read -r; do
+		if (( i++ == 0 )); then
+			__vecho -ne '\n'
+			eqawarn "QA Notice: Package triggers severe warnings which indicate that it"
+			eqawarn "           may exhibit random runtime failures."
+		fi
+		eqawarn "${REPLY}"
+	done < <(
 		# Coerce C as the character type for performance reasons, per
 		# bug #160234. Coerce C as the collation to guarantee that
 		# ranges are handled appropriately. Also, pass -a to GNU grep
@@ -164,26 +171,22 @@ gcc_warn_check() {
 		| grep -E -a "${msgs[*]}" \
 		| uniq
 	)
-	if [[ -n ${f} ]] ; then
-		abort=1
 
-		__vecho -ne '\n'
-		eqawarn "QA Notice: Package triggers severe warnings which indicate that it"
-		eqawarn "           may exhibit random runtime failures."
-		eqawarn "${f}"
+	if (( i > 0 )); then
 		__vecho -ne '\n'
 	fi
 
 	eval "${reset_xtrace}"
 
-	if (( abort )) ; then
-		echo "Please do not file a Gentoo bug and instead" \
-		"report the above QA issues directly to the upstream" \
-		"developers of this software." | fmt -w 70 | \
-		while read -r line ; do eqawarn "${line}" ; done
-		eqawarn "Homepage: ${HOMEPAGE}"
-		has stricter ${FEATURES} && \
+	if (( i > 0 )); then
+		while read -r; do eqawarn "${REPLY}"; done <<-EOF
+		Please do not file a Gentoo bug and instead report the above QA issues directly
+		to the upstream developers of this software.
+		Homepage: ${HOMEPAGE}
+		EOF
+		if has stricter ${FEATURES}; then
 			die "install aborted due to severe warnings shown above"
+		fi
 	fi
 }
 
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2025-05-30  7:37 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2025-05-30  7:37 UTC (permalink / raw
  To: gentoo-commits
commit:     9da7a8c60083053a607af9642bd3ba80ecd112f9
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Thu May 22 20:09:27 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May 30 07:37:30 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=9da7a8c6
90gcc-warnings: don't process gzip streams with sed
In the case that the log file is compressed, the routine that collects
the warnings ought to operate on the decompressed stream at large. Make
it so.
Fixes: b78da6155975faa519f93ec0bebe9830dd265c09
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/90gcc-warnings | 16 +++++++++++-----
 1 file changed, 11 insertions(+), 5 deletions(-)
diff --git a/bin/install-qa-check.d/90gcc-warnings b/bin/install-qa-check.d/90gcc-warnings
index ead1243bb5..9ec16f1585 100644
--- a/bin/install-qa-check.d/90gcc-warnings
+++ b/bin/install-qa-check.d/90gcc-warnings
@@ -3,7 +3,7 @@
 # TODO: add -Wformat-security
 
 gcc_warn_check() {
-        local abort f grep_cmd joined_msgs reset_xtrace
+        local abort f joined_msgs reset_xtrace
         local -a msgs
 
 	# Evaluate misc gcc warnings
@@ -151,13 +151,19 @@ gcc_warn_check() {
 	printf -v joined_msgs '%s|' "${msgs[@]}"
 	joined_msgs=${joined_msgs%|}
 
-	grep_cmd=grep
-	[[ ${PORTAGE_LOG_FILE} = *.gz ]] && grep_cmd=zgrep
-
 	# Force C locale to work around slow multibyte locales, bug #160234
 	# Force text mode as newer grep will treat non-ASCII (e.g. UTF-8) as
 	# binary when we run in the C locale.
-	f=$(LC_ALL='C' sed -E -e $'s/\033\[[0-9;]*[A-Za-z]//g' < "${PORTAGE_LOG_FILE}" | LC_CTYPE=C LC_COLLATE=C "${grep_cmd}" -E -a "${joined_msgs}" | uniq)
+	f=$(
+		if [[ ${PORTAGE_LOG_FILE} == *.gz ]]; then
+			gzip -cd -- "${PORTAGE_LOG_FILE}"
+		else
+			cat -- "${PORTAGE_LOG_FILE}"
+		fi \
+		| LC_ALL=C sed -E -e $'s/\033\[[0-9;]*[A-Za-z]//g' \
+		| LC_CTYPE=C LC_COLLATE=C grep -E -a "${joined_msgs}" \
+		| uniq
+	)
 	if [[ -n ${f} ]] ; then
 		abort=1
 
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2025-05-30  7:37 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2025-05-30  7:37 UTC (permalink / raw
  To: gentoo-commits
commit:     fe82ae7743602aec01c69d5b3ed814c6edb11742
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Thu May 22 20:13:57 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May 30 07:37:31 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=fe82ae77
90gcc-warnings: jettison the joined_msgs variable
In the course of joining the patterns to form an ERE branch, there is no
need for an additional variable to store it.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/90gcc-warnings | 9 +++------
 1 file changed, 3 insertions(+), 6 deletions(-)
diff --git a/bin/install-qa-check.d/90gcc-warnings b/bin/install-qa-check.d/90gcc-warnings
index 9ec16f1585..185deaa53a 100644
--- a/bin/install-qa-check.d/90gcc-warnings
+++ b/bin/install-qa-check.d/90gcc-warnings
@@ -3,7 +3,7 @@
 # TODO: add -Wformat-security
 
 gcc_warn_check() {
-        local abort f joined_msgs reset_xtrace
+        local abort f reset_xtrace
         local -a msgs
 
 	# Evaluate misc gcc warnings
@@ -147,21 +147,18 @@ gcc_warn_check() {
 		#': warning: not enough variable arguments to fit a sentinel'
 	)
 
-	# join all messages into one grep-expression
-	printf -v joined_msgs '%s|' "${msgs[@]}"
-	joined_msgs=${joined_msgs%|}
-
 	# Force C locale to work around slow multibyte locales, bug #160234
 	# Force text mode as newer grep will treat non-ASCII (e.g. UTF-8) as
 	# binary when we run in the C locale.
 	f=$(
+		IFS='|'
 		if [[ ${PORTAGE_LOG_FILE} == *.gz ]]; then
 			gzip -cd -- "${PORTAGE_LOG_FILE}"
 		else
 			cat -- "${PORTAGE_LOG_FILE}"
 		fi \
 		| LC_ALL=C sed -E -e $'s/\033\[[0-9;]*[A-Za-z]//g' \
-		| LC_CTYPE=C LC_COLLATE=C grep -E -a "${joined_msgs}" \
+		| LC_CTYPE=C LC_COLLATE=C grep -E -a "${msgs[*]}" \
 		| uniq
 	)
 	if [[ -n ${f} ]] ; then
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2025-05-30  7:37 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2025-05-30  7:37 UTC (permalink / raw
  To: gentoo-commits
commit:     f7b0e6a5d676637c281de2485ce3d76d0d0fad3e
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Fri May 23 00:18:18 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May 30 07:37:33 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=f7b0e6a5
90gcc-warnings: simplify the composed ERE
All of the presently used patterns begin with "warning: ". Simplify the
Extended Regular Expression by accounting for such at the point that
grep(1) is executed. Hence, grep -E "${msgs[*]}" becomes grep -E
"warning: (${msgs[*]})".
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/90gcc-warnings | 121 +++++++++++++++++-----------------
 1 file changed, 60 insertions(+), 61 deletions(-)
diff --git a/bin/install-qa-check.d/90gcc-warnings b/bin/install-qa-check.d/90gcc-warnings
index 571d6bd066..85ed35e52b 100644
--- a/bin/install-qa-check.d/90gcc-warnings
+++ b/bin/install-qa-check.d/90gcc-warnings
@@ -14,137 +14,136 @@ gcc_warn_check() {
 
 	msgs=(
 		# only will and does, no might :)
-		'warning: .*will.*\[-Wstrict-aliasing\]'
-		'warning: .*does.*\[-Wstrict-aliasing\]'
-		'warning: .*\[-Wrestrict\]'
+		'.*(does|will).*\[-Wstrict-aliasing\]'
+		'.*\[-Wrestrict\]'
 		# strict aliasing violation in C++ (Clang)
-		'warning: .*\[-Wundefined-reinterpret-cast\]'
+		'.*\[-Wundefined-reinterpret-cast\]'
 
 		# implicit declaration of function ‘...’
-		'warning: .*\[-Wimplicit-function-declaration\]'
+		'.*\[-Wimplicit-function-declaration\]'
 		# with -Wall, goes in pair with -Wimplicit-function-declaration
 		# but without -Wall, we need to assert for it alone
-		'warning: .*incompatible implicit declaration of built-in function'
-		'warning: .*\[-Wbuiltin-declaration-mismatch\]'
+		'.*incompatible implicit declaration of built-in function'
+		'.*\[-Wbuiltin-declaration-mismatch\]'
 
 		# 'is used uninitialized in this function' and some more
-		'warning: .*\[-Wuninitialized\]'
+		'.*\[-Wuninitialized\]'
 		# comparisons like ‘X<=Y<=Z’ do not have their mathematical meaning
-		'warning: .*mathematical meaning*\[-Wparentheses\]'
+		'.*mathematical meaning*\[-Wparentheses\]'
 		# null argument where non-null required
-		'warning: .*\[-Wnonnull\]'
+		'.*\[-Wnonnull\]'
 
 		# array subscript is above/below/outside array bounds (FORTIFY_SOURCE)
-		'warning: .*\[-Warray-bounds\]'
+		'.*\[-Warray-bounds\]'
 		# attempt to free a non-heap object
-		'warning: .*\[-Wfree-nonheap-object\]'
+		'.*\[-Wfree-nonheap-object\]'
 		# those three do not have matching -W flags, it seems
-		'warning: .*will always overflow destination buffer'
+		'.*will always overflow destination buffer'
 		# compile-time part of FORTIFY_SOURCE
 		# XXX: Commented out because of gcc FPs (https://gcc.gnu.org/PR88443)
-		#'warning: .*\[-Wstringop-overflow\]'
+		#'.*\[-Wstringop-overflow\]'
 		# XXX: Commented out because of gcc FPs (https://gcc.gnu.org/PR97048)
-		#'warning: .*\[-Wstringop-overread\]'
+		#'.*\[-Wstringop-overread\]'
 		# XXX: Commented out because of gcc FPs (https://gcc.gnu.org/PR88781)
-		#'warning: .*\[-Wstringop-truncation\]'
+		#'.*\[-Wstringop-truncation\]'
 		# clang-only, equivalent of -Wstringop-overflow
-		'warning: .*\[-Wfortify-source\]'
-		'warning: .*assuming pointer wraparound does not occur'
-		'warning: .*escape sequence out of range'
+		'.*\[-Wfortify-source\]'
+		'.*assuming pointer wraparound does not occur'
+		'.*escape sequence out of range'
 
 		# all clang
-		'warning: .*\[-Wstrlcpy-strlcat-size\]'
-		'warning: .*\[-Wstrncat-size\]'
-		'warning: .*\[-Wsuspicious-bzero\]'
-		'warning: .*\[-Wvarargs\]'
+		'.*\[-Wstrlcpy-strlcat-size\]'
+		'.*\[-Wstrncat-size\]'
+		'.*\[-Wsuspicious-bzero\]'
+		'.*\[-Wvarargs\]'
 
 		# left-hand operand of comma expression has no effect
-		'warning: .*left.*comma.*\[-Wunused-value\]'
+		'.*left.*comma.*\[-Wunused-value\]'
 		# converting to non-pointer type ... from NULL and likes
-		'warning: .*\[-Wconversion-null\]'
+		'.*\[-Wconversion-null\]'
 		# NULL used in arithmetic
-		'warning: .*NULL.*\[-Wpointer-arith\]'
+		'.*NULL.*\[-Wpointer-arith\]'
 		# pointer to a function used in arithmetic and likes
-		'warning: .*function.*\[-Wpointer-arith\]'
+		'.*function.*\[-Wpointer-arith\]'
 		# the address of ... will never be NULL and likes
 		# (uses of function refs & string constants in conditionals)
 		# XXX: Commented out because of gcc FPs (https://gcc.gnu.org/PR103360)
-		#'warning: .*\[-Waddress\]'
+		#'.*\[-Waddress\]'
 
 		# TODO: we want to enable these but bash currently triggers
 		# them with a trick in random.c where it intentionally wants
 		# some truncation :(
 		#
 		# warning: assignment/initialization to ... from ... makes integer from pointer without cast
-		#'warning: .*\[-Wint-conversion\]'
+		#'.*\[-Wint-conversion\]'
 		# warning: cast to ... from integer of different size (or smaller size)
-		#'warning: .*\[-Wint-to-pointer-cast\]'
+		#'.*\[-Wint-to-pointer-cast\]'
 		# warning: cast to ... from (smaller) integer type
-		#'warning: .*\[-Wint-to-void-pointer-cast\]'
+		#'.*\[-Wint-to-void-pointer-cast\]'
 		# warning: cast from ... to integer of different size
-		#'warning: .*\[-Wpointer-to-int-cast\]'
+		#'.*\[-Wpointer-to-int-cast\]'
 
 		# -Wformat
 		# TODO: comment out some time in future for time_t & LFS preparedness
 		#'warning: .*\[-Wformat=\]'
 		# -Wformat variants
-		'warning: .*too few arguments for format'
-		'warning: .*missing sentinel in function call.*\[-Wformat=\]'
-		'warning: .*\[-Wformat-truncation\]'
+		'.*too few arguments for format'
+		'.*missing sentinel in function call.*\[-Wformat=\]'
+		'.*\[-Wformat-truncation\]'
 		# format ... expects a matching ... argument
 		# (iow, too few arguments for format in new wording :))
-		'warning: .*matching.*\[-Wformat=\]'
+		'.*matching.*\[-Wformat=\]'
 
 		# function returns address of local variable
 		# XXX: Commented out for bug #925460 (https://gcc.gnu.org/PR93644)
-		#'warning: .*\[-Wreturn-local-addr\]'
+		#'.*\[-Wreturn-local-addr\]'
 		# missing return at end of function, or non-void return in a void function
 		# (clang at least aggressively optimises on this)
-		'warning: .*\[-Wreturn-type\]'
+		'.*\[-Wreturn-type\]'
 		# argument to sizeof ... is the same expression as the source
-		'warning: .*\[-Wsizeof-pointer-memaccess\]'
+		'.*\[-Wsizeof-pointer-memaccess\]'
 		# iteration invokes undefined behavior
-		'warning: .*\[-Waggressive-loop-optimizations\]'
+		'.*\[-Waggressive-loop-optimizations\]'
 		# conversion between pointers that have incompatible types
-		'warning: .*\[-Wincompatible-pointer-types\]'
+		'.*\[-Wincompatible-pointer-types\]'
 		# more specific form of -Wincompatible-pointer-types (Clang)
-		'warning: .*\[-Wincompatible-function-pointer-types\]'
+		'.*\[-Wincompatible-function-pointer-types\]'
 		# these will fail with CFI (https://reviews.llvm.org/D134831)
 		# (gcc lacks -strict)
-		#'warning: .*\[-Wcast-function-type\]'
-		'warning: .*\[-Wcast-function-type-strict\]'
+		#'.*\[-Wcast-function-type\]'
+		'.*\[-Wcast-function-type-strict\]'
 		# using wrong deallocator, e.g. using free() on object allocated using my_malloc()
 		# when my_malloc() is annotated as needing my_free().
-		'warning: .*\[-Wmismatched-dealloc\]'
+		'.*\[-Wmismatched-dealloc\]'
 		# clobbered: Warn for variables that might be changed by longjmp or vfork
 		# (This warning is also enabled by -Wextra.)
-		'warning: .*\[-Wclobbered\]'
+		'.*\[-Wclobbered\]'
 		# LTO type mismatch (https://wiki.gentoo.org/wiki/Project:Toolchain/LTO)
-		'warning: .*\[-Wlto-type-mismatch\]'
+		'.*\[-Wlto-type-mismatch\]'
 		# ODR (https://wiki.gentoo.org/wiki/Project:Toolchain/LTO)
-		'warning: .*\[-Wodr\]'
+		'.*\[-Wodr\]'
 		# warning: argument value A will result in undefined behaviour (Clang)
-		'warning: .*\[-Wargument-undefined-behaviour\]'
+		'.*\[-Wargument-undefined-behaviour\]'
 		# XXX: Commented out because of GCC FPs (https://gcc.gnu.org/PR86172)
-		#'warning: .*\[-Wnull-dereference\]'
+		#'.*\[-Wnull-dereference\]'
 
 		# general sensible warnings (will be rejected by modern compilers soon)
-		'warning: .*\[-Wmain\]'
-		'warning: .*\[-Wimplicit-int\]'
-		'warning: .*\[-Wstring-compare\]'
+		'.*\[-Wmain\]'
+		'.*\[-Wimplicit-int\]'
+		'.*\[-Wstring-compare\]'
 
 		# this may be valid code :/
-		#': warning: multi-character character constant'
+		#' multi-character character constant'
 		# need to check these two ...
-		#': warning: assuming signed overflow does not occur when'
-		#': warning: comparison with string literal results in unspecified behav'
+		#' assuming signed overflow does not occur when'
+		#' comparison with string literal results in unspecified behav'
 		# yacc/lex likes to trigger this one
-		#': warning: extra tokens at end of .* directive'
+		#' extra tokens at end of .* directive'
 		# only gcc itself triggers this ?
-		#': warning: .*noreturn.* function does return'
+		#' .*noreturn.* function does return'
 		# these throw false positives when 0 is used instead of NULL
-		#': warning: missing sentinel in function call'
-		#': warning: not enough variable arguments to fit a sentinel'
+		#' missing sentinel in function call'
+		#' not enough variable arguments to fit a sentinel'
 	)
 
 	while read -r; do
@@ -168,7 +167,7 @@ gcc_warn_check() {
 			cat -- "${PORTAGE_LOG_FILE}"
 		fi \
 		| sed -E -e $'s/\033\[[0-9;]*[A-Za-z]//g' \
-		| grep -E -a "${msgs[*]}" \
+		| grep -E -a "warning: (${msgs[*]})" \
 		| uniq
 	)
 
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2025-05-30  7:37 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2025-05-30  7:37 UTC (permalink / raw
  To: gentoo-commits
commit:     6dff026cea1c75726d249c02306905c42d30e5bf
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Thu May 22 18:34:53 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May 30 07:37:30 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=6dff026c
90gcc-warnings: test the abort variable arithmetically
That way, it acts as a quasi-boolean.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/90gcc-warnings | 5 ++---
 1 file changed, 2 insertions(+), 3 deletions(-)
diff --git a/bin/install-qa-check.d/90gcc-warnings b/bin/install-qa-check.d/90gcc-warnings
index 4da17b154b..ead1243bb5 100644
--- a/bin/install-qa-check.d/90gcc-warnings
+++ b/bin/install-qa-check.d/90gcc-warnings
@@ -151,7 +151,6 @@ gcc_warn_check() {
 	printf -v joined_msgs '%s|' "${msgs[@]}"
 	joined_msgs=${joined_msgs%|}
 
-	abort="no"
 	grep_cmd=grep
 	[[ ${PORTAGE_LOG_FILE} = *.gz ]] && grep_cmd=zgrep
 
@@ -160,7 +159,7 @@ gcc_warn_check() {
 	# binary when we run in the C locale.
 	f=$(LC_ALL='C' sed -E -e $'s/\033\[[0-9;]*[A-Za-z]//g' < "${PORTAGE_LOG_FILE}" | LC_CTYPE=C LC_COLLATE=C "${grep_cmd}" -E -a "${joined_msgs}" | uniq)
 	if [[ -n ${f} ]] ; then
-		abort="yes"
+		abort=1
 
 		__vecho -ne '\n'
 		eqawarn "QA Notice: Package triggers severe warnings which indicate that it"
@@ -171,7 +170,7 @@ gcc_warn_check() {
 
 	eval "${reset_xtrace}"
 
-	if [[ ${abort} == "yes" ]] ; then
+	if (( abort )) ; then
 		echo "Please do not file a Gentoo bug and instead" \
 		"report the above QA issues directly to the upstream" \
 		"developers of this software." | fmt -w 70 | \
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2025-05-30  7:37 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2025-05-30  7:37 UTC (permalink / raw
  To: gentoo-commits
commit:     ee1e2f10fa2f739bddee200e17360a618c9dfb3a
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Thu May 22 20:51:33 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May 30 07:37:31 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=ee1e2f10
90gcc-warnings: employ LC_COLLATE and LC_CTYPE consistently
Presently, LC_ALL=C is set for the invocation of sed(1), whereas
LC_COLLATE and LC_CTYPE are set for the invocation of grep(1). This is
inconsistent in so far as LC_ALL is permitted to override the intended
character type and collation, yet only in the case of the latter. Given
that the processing of the log occurs in a subshell, render things
consistent by exporting all of LC_ALL, LC_COLLATE and LC_CTYPE.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/90gcc-warnings | 5 +++--
 1 file changed, 3 insertions(+), 2 deletions(-)
diff --git a/bin/install-qa-check.d/90gcc-warnings b/bin/install-qa-check.d/90gcc-warnings
index 185deaa53a..0662a94637 100644
--- a/bin/install-qa-check.d/90gcc-warnings
+++ b/bin/install-qa-check.d/90gcc-warnings
@@ -151,14 +151,15 @@ gcc_warn_check() {
 	# Force text mode as newer grep will treat non-ASCII (e.g. UTF-8) as
 	# binary when we run in the C locale.
 	f=$(
+		export LC_ALL= LC_COLLATE=C LC_CTYPE=C
 		IFS='|'
 		if [[ ${PORTAGE_LOG_FILE} == *.gz ]]; then
 			gzip -cd -- "${PORTAGE_LOG_FILE}"
 		else
 			cat -- "${PORTAGE_LOG_FILE}"
 		fi \
-		| LC_ALL=C sed -E -e $'s/\033\[[0-9;]*[A-Za-z]//g' \
-		| LC_CTYPE=C LC_COLLATE=C grep -E -a "${msgs[*]}" \
+		| sed -E -e $'s/\033\[[0-9;]*[A-Za-z]//g' \
+		| grep -E -a "${msgs[*]}" \
 		| uniq
 	)
 	if [[ -n ${f} ]] ; then
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2025-05-30  7:37 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2025-05-30  7:37 UTC (permalink / raw
  To: gentoo-commits
commit:     19beb75b2c6457ba92338236decef0afece10968
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Fri May 23 04:01:45 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May 30 07:37:34 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=19beb75b
90gcc-warnings: fix the defective -Wparentheses pattern
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/90gcc-warnings | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/install-qa-check.d/90gcc-warnings b/bin/install-qa-check.d/90gcc-warnings
index c00a33914e..1f51279d97 100644
--- a/bin/install-qa-check.d/90gcc-warnings
+++ b/bin/install-qa-check.d/90gcc-warnings
@@ -29,7 +29,7 @@ gcc_warn_check() {
 		# 'is used uninitialized in this function' and some more
 		'.*\[-Wuninitialized\]'
 		# comparisons like ‘X<=Y<=Z’ do not have their mathematical meaning
-		'.*mathematical meaning*\[-Wparentheses\]'
+		'.*mathematical meaning.*\[-Wparentheses\]'
 		# null argument where non-null required
 		'.*\[-Wnonnull\]'
 
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2025-05-30  7:37 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2025-05-30  7:37 UTC (permalink / raw
  To: gentoo-commits
commit:     dc3e0c5e828b87f8af2542ff29d3d80bda37fdbd
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Thu May 22 18:28:50 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May 30 07:37:30 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=dc3e0c5e
90gcc-warnings: simplify xtrace option handling
Simplify the xtrace handling by stashing a command that restores the
option's present status before unconditionally disabling it.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/90gcc-warnings | 11 ++++-------
 1 file changed, 4 insertions(+), 7 deletions(-)
diff --git a/bin/install-qa-check.d/90gcc-warnings b/bin/install-qa-check.d/90gcc-warnings
index ea51f19d32..4da17b154b 100644
--- a/bin/install-qa-check.d/90gcc-warnings
+++ b/bin/install-qa-check.d/90gcc-warnings
@@ -3,17 +3,14 @@
 # TODO: add -Wformat-security
 
 gcc_warn_check() {
-        local abort f grep_cmd joined_msgs reset_debug
+        local abort f grep_cmd joined_msgs reset_xtrace
         local -a msgs
 
 	# Evaluate misc gcc warnings
 	# In debug mode, this variable definition and corresponding grep calls
 	# will produce false positives if they're shown in the trace.
-	reset_debug=0
-	if [[ $- == *x* ]] ; then
-		set +x
-		reset_debug=1
-	fi
+	reset_xtrace=$(shopt -o -p xtrace)
+	shopt -o -u xtrace
 
 	msgs=(
 		# only will and does, no might :)
@@ -172,7 +169,7 @@ gcc_warn_check() {
 		__vecho -ne '\n'
 	fi
 
-	[[ ${reset_debug} = 1 ]] && set -x
+	eval "${reset_xtrace}"
 
 	if [[ ${abort} == "yes" ]] ; then
 		echo "Please do not file a Gentoo bug and instead" \
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2025-05-30  7:37 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2025-05-30  7:37 UTC (permalink / raw
  To: gentoo-commits
commit:     52f303047696be5abbdda0ec2fa027274c57fe7c
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Thu May 22 17:01:47 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May 30 07:37:29 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=52f30304
90gcc-warnings: hoist local declarations to top of function
This precedes a re-factoring. However, I would add that locals are not
lexically scoped in bash and that declaring them up-front tends to serve
as an effective canary for undue complexity. As a case in point, drop
the unused m variable.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/90gcc-warnings | 12 ++++++------
 1 file changed, 6 insertions(+), 6 deletions(-)
diff --git a/bin/install-qa-check.d/90gcc-warnings b/bin/install-qa-check.d/90gcc-warnings
index 80ec98af93..42166a7bf4 100644
--- a/bin/install-qa-check.d/90gcc-warnings
+++ b/bin/install-qa-check.d/90gcc-warnings
@@ -3,18 +3,19 @@
 # TODO: add -Wformat-security
 
 gcc_warn_check() {
-	local f
+        local abort always_overflow f gentoo_bug grep_cmd implicit_func_decl joined_msgs reset_debug
+        local -a msgs
 
 	# Evaluate misc gcc warnings
 	# In debug mode, this variable definition and corresponding grep calls
 	# will produce false positives if they're shown in the trace.
-	local reset_debug=0
+	reset_debug=0
 	if [[ $- == *x* ]] ; then
 		set +x
 		reset_debug=1
 	fi
 
-	local m msgs=(
+	msgs=(
 		# only will and does, no might :)
 		'warning: .*will.*\[-Wstrict-aliasing\]'
 		'warning: .*does.*\[-Wstrict-aliasing\]'
@@ -150,12 +151,11 @@ gcc_warn_check() {
 	)
 
 	# join all messages into one grep-expression
-	local joined_msgs
 	printf -v joined_msgs '%s|' "${msgs[@]}"
 	joined_msgs=${joined_msgs%|}
 
-	local abort="no"
-	local grep_cmd=grep
+	abort="no"
+	grep_cmd=grep
 	[[ ${PORTAGE_LOG_FILE} = *.gz ]] && grep_cmd=zgrep
 
 	# Force C locale to work around slow multibyte locales, bug #160234
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2025-05-30  7:37 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2025-05-30  7:37 UTC (permalink / raw
  To: gentoo-commits
commit:     e4897399d1fa5b2768205493fde183ce871533d3
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Thu May 22 16:50:38 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May 30 07:37:28 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=e4897399
90gcc-warnings: conditionally call gcc_warn_check
Call the gcc_warn_check function on the condition that PORTAGE_LOG_FILE
be readable. This saves a level of indentation for the entirety of the
function's body.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/90gcc-warnings | 401 +++++++++++++++++-----------------
 1 file changed, 201 insertions(+), 200 deletions(-)
diff --git a/bin/install-qa-check.d/90gcc-warnings b/bin/install-qa-check.d/90gcc-warnings
index 2e9db52b2b..80ec98af93 100644
--- a/bin/install-qa-check.d/90gcc-warnings
+++ b/bin/install-qa-check.d/90gcc-warnings
@@ -6,214 +6,215 @@ gcc_warn_check() {
 	local f
 
 	# Evaluate misc gcc warnings
-	if [[ -n ${PORTAGE_LOG_FILE} && -r ${PORTAGE_LOG_FILE} ]] ; then
-		# In debug mode, this variable definition and corresponding grep calls
-		# will produce false positives if they're shown in the trace.
-		local reset_debug=0
-		if [[ $- == *x* ]] ; then
-			set +x
-			reset_debug=1
-		fi
+	# In debug mode, this variable definition and corresponding grep calls
+	# will produce false positives if they're shown in the trace.
+	local reset_debug=0
+	if [[ $- == *x* ]] ; then
+		set +x
+		reset_debug=1
+	fi
 
-		local m msgs=(
-			# only will and does, no might :)
-			'warning: .*will.*\[-Wstrict-aliasing\]'
-			'warning: .*does.*\[-Wstrict-aliasing\]'
-			'warning: .*\[-Wrestrict\]'
-			# strict aliasing violation in C++ (Clang)
-			'warning: .*\[-Wundefined-reinterpret-cast\]'
-
-			# implicit declaration of function ‘...’
-			'warning: .*\[-Wimplicit-function-declaration\]'
-			# with -Wall, goes in pair with -Wimplicit-function-declaration
-			# but without -Wall, we need to assert for it alone
-			'warning: .*incompatible implicit declaration of built-in function'
-			'warning: .*\[-Wbuiltin-declaration-mismatch\]'
-
-			# 'is used uninitialized in this function' and some more
-			'warning: .*\[-Wuninitialized\]'
-			# comparisons like ‘X<=Y<=Z’ do not have their mathematical meaning
-			'warning: .*mathematical meaning*\[-Wparentheses\]'
-			# null argument where non-null required
-			'warning: .*\[-Wnonnull\]'
-
-			# array subscript is above/below/outside array bounds (FORTIFY_SOURCE)
-			'warning: .*\[-Warray-bounds\]'
-			# attempt to free a non-heap object
-			'warning: .*\[-Wfree-nonheap-object\]'
-			# those three do not have matching -W flags, it seems
-			'warning: .*will always overflow destination buffer'
-			# compile-time part of FORTIFY_SOURCE
-			# XXX: Commented out because of gcc FPs (https://gcc.gnu.org/PR88443)
-			#'warning: .*\[-Wstringop-overflow\]'
-			# XXX: Commented out because of gcc FPs (https://gcc.gnu.org/PR97048)
-			#'warning: .*\[-Wstringop-overread\]'
-			# XXX: Commented out because of gcc FPs (https://gcc.gnu.org/PR88781)
-			#'warning: .*\[-Wstringop-truncation\]'
-			# clang-only, equivalent of -Wstringop-overflow
-			'warning: .*\[-Wfortify-source\]'
-			'warning: .*assuming pointer wraparound does not occur'
-			'warning: .*escape sequence out of range'
-
-			# all clang
-			'warning: .*\[-Wstrlcpy-strlcat-size\]'
-			'warning: .*\[-Wstrncat-size\]'
-			'warning: .*\[-Wsuspicious-bzero\]'
-			'warning: .*\[-Wvarargs\]'
-
-			# left-hand operand of comma expression has no effect
-			'warning: .*left.*comma.*\[-Wunused-value\]'
-			# converting to non-pointer type ... from NULL and likes
-			'warning: .*\[-Wconversion-null\]'
-			# NULL used in arithmetic
-			'warning: .*NULL.*\[-Wpointer-arith\]'
-			# pointer to a function used in arithmetic and likes
-			'warning: .*function.*\[-Wpointer-arith\]'
-			# the address of ... will never be NULL and likes
-			# (uses of function refs & string constants in conditionals)
-			# XXX: Commented out because of gcc FPs (https://gcc.gnu.org/PR103360)
-			#'warning: .*\[-Waddress\]'
-
-			# TODO: we want to enable these but bash currently triggers
-			# them with a trick in random.c where it intentionally wants
-			# some truncation :(
-			#
-			# warning: assignment/initialization to ... from ... makes integer from pointer without cast
-			#'warning: .*\[-Wint-conversion\]'
-			# warning: cast to ... from integer of different size (or smaller size)
-			#'warning: .*\[-Wint-to-pointer-cast\]'
-			# warning: cast to ... from (smaller) integer type
-			#'warning: .*\[-Wint-to-void-pointer-cast\]'
-			# warning: cast from ... to integer of different size
-			#'warning: .*\[-Wpointer-to-int-cast\]'
-
-			# -Wformat
-			# TODO: comment out some time in future for time_t & LFS preparedness
-			#'warning: .*\[-Wformat=\]'
-			# -Wformat variants
-			'warning: .*too few arguments for format'
-			'warning: .*missing sentinel in function call.*\[-Wformat=\]'
-			'warning: .*\[-Wformat-truncation\]'
-			# format ... expects a matching ... argument
-			# (iow, too few arguments for format in new wording :))
-			'warning: .*matching.*\[-Wformat=\]'
-
-			# function returns address of local variable
-			# XXX: Commented out for bug #925460 (https://gcc.gnu.org/PR93644)
-			#'warning: .*\[-Wreturn-local-addr\]'
-			# missing return at end of function, or non-void return in a void function
-			# (clang at least aggressively optimises on this)
-			'warning: .*\[-Wreturn-type\]'
-			# argument to sizeof ... is the same expression as the source
-			'warning: .*\[-Wsizeof-pointer-memaccess\]'
-			# iteration invokes undefined behavior
-			'warning: .*\[-Waggressive-loop-optimizations\]'
-			# conversion between pointers that have incompatible types
-			'warning: .*\[-Wincompatible-pointer-types\]'
-			# more specific form of -Wincompatible-pointer-types (Clang)
-			'warning: .*\[-Wincompatible-function-pointer-types\]'
-			# these will fail with CFI (https://reviews.llvm.org/D134831)
-			# (gcc lacks -strict)
-			#'warning: .*\[-Wcast-function-type\]'
-			'warning: .*\[-Wcast-function-type-strict\]'
-			# using wrong deallocator, e.g. using free() on object allocated using my_malloc()
-			# when my_malloc() is annotated as needing my_free().
-			'warning: .*\[-Wmismatched-dealloc\]'
-			# clobbered: Warn for variables that might be changed by longjmp or vfork
-			# (This warning is also enabled by -Wextra.)
-			'warning: .*\[-Wclobbered\]'
-			# LTO type mismatch (https://wiki.gentoo.org/wiki/Project:Toolchain/LTO)
-			'warning: .*\[-Wlto-type-mismatch\]'
-			# ODR (https://wiki.gentoo.org/wiki/Project:Toolchain/LTO)
-			'warning: .*\[-Wodr\]'
-			# warning: argument value A will result in undefined behaviour (Clang)
-			'warning: .*\[-Wargument-undefined-behaviour\]'
-			# XXX: Commented out because of GCC FPs (https://gcc.gnu.org/PR86172)
-			#'warning: .*\[-Wnull-dereference\]'
-
-			# general sensible warnings (will be rejected by modern compilers soon)
-			'warning: .*\[-Wmain\]'
-			'warning: .*\[-Wimplicit-int\]'
-			'warning: .*\[-Wstring-compare\]'
-
-			# this may be valid code :/
-			#': warning: multi-character character constant'
-			# need to check these two ...
-			#': warning: assuming signed overflow does not occur when'
-			#': warning: comparison with string literal results in unspecified behav'
-			# yacc/lex likes to trigger this one
-			#': warning: extra tokens at end of .* directive'
-			# only gcc itself triggers this ?
-			#': warning: .*noreturn.* function does return'
-			# these throw false positives when 0 is used instead of NULL
-			#': warning: missing sentinel in function call'
-			#': warning: not enough variable arguments to fit a sentinel'
-		)
-
-		# join all messages into one grep-expression
-		local joined_msgs
-		printf -v joined_msgs '%s|' "${msgs[@]}"
-		joined_msgs=${joined_msgs%|}
-
-		local abort="no"
-		local grep_cmd=grep
-		[[ ${PORTAGE_LOG_FILE} = *.gz ]] && grep_cmd=zgrep
-
-		# Force C locale to work around slow multibyte locales, bug #160234
-		# Force text mode as newer grep will treat non-ASCII (e.g. UTF-8) as
-		# binary when we run in the C locale.
-		f=$(LC_ALL='C' sed -E -e $'s/\033\[[0-9;]*[A-Za-z]//g' < "${PORTAGE_LOG_FILE}" | LC_CTYPE=C LC_COLLATE=C "${grep_cmd}" -E -a "${joined_msgs}" | uniq)
-		if [[ -n ${f} ]] ; then
-			abort="yes"
-
-			# for now, don't make this fatal (see bug #337031)
-			#if [[ ${f} == *'will always overflow destination buffer'* ]]; then
-			#	always_overflow=yes
-			#fi
-
-			# Disabled for now because too many failures. bug #870412.
-			#if [[ ${f} == *'[-Wimplicit-function-declaration]'* ]] ; then
-			#	implicit_func_decl=yes
-			#fi
-
-			if [[ ${always_overflow} = yes || ${implicit_func_decl} = yes ]] ; then
-				eerror
-				eerror "QA Notice: Package triggers severe warnings which indicate that it"
-				eerror "           may exhibit random runtime failures."
-				eerror
-				eerror "${f}"
-				eerror
-				eerror " Please file a bug about this at https://bugs.gentoo.org/"
-				eerror " with the maintainer of the package."
-				eerror
-			else
-				__vecho -ne '\n'
-				eqawarn "QA Notice: Package triggers severe warnings which indicate that it"
-				eqawarn "           may exhibit random runtime failures."
-				eqawarn "${f}"
-				__vecho -ne '\n'
-			fi
+	local m msgs=(
+		# only will and does, no might :)
+		'warning: .*will.*\[-Wstrict-aliasing\]'
+		'warning: .*does.*\[-Wstrict-aliasing\]'
+		'warning: .*\[-Wrestrict\]'
+		# strict aliasing violation in C++ (Clang)
+		'warning: .*\[-Wundefined-reinterpret-cast\]'
+
+		# implicit declaration of function ‘...’
+		'warning: .*\[-Wimplicit-function-declaration\]'
+		# with -Wall, goes in pair with -Wimplicit-function-declaration
+		# but without -Wall, we need to assert for it alone
+		'warning: .*incompatible implicit declaration of built-in function'
+		'warning: .*\[-Wbuiltin-declaration-mismatch\]'
+
+		# 'is used uninitialized in this function' and some more
+		'warning: .*\[-Wuninitialized\]'
+		# comparisons like ‘X<=Y<=Z’ do not have their mathematical meaning
+		'warning: .*mathematical meaning*\[-Wparentheses\]'
+		# null argument where non-null required
+		'warning: .*\[-Wnonnull\]'
+
+		# array subscript is above/below/outside array bounds (FORTIFY_SOURCE)
+		'warning: .*\[-Warray-bounds\]'
+		# attempt to free a non-heap object
+		'warning: .*\[-Wfree-nonheap-object\]'
+		# those three do not have matching -W flags, it seems
+		'warning: .*will always overflow destination buffer'
+		# compile-time part of FORTIFY_SOURCE
+		# XXX: Commented out because of gcc FPs (https://gcc.gnu.org/PR88443)
+		#'warning: .*\[-Wstringop-overflow\]'
+		# XXX: Commented out because of gcc FPs (https://gcc.gnu.org/PR97048)
+		#'warning: .*\[-Wstringop-overread\]'
+		# XXX: Commented out because of gcc FPs (https://gcc.gnu.org/PR88781)
+		#'warning: .*\[-Wstringop-truncation\]'
+		# clang-only, equivalent of -Wstringop-overflow
+		'warning: .*\[-Wfortify-source\]'
+		'warning: .*assuming pointer wraparound does not occur'
+		'warning: .*escape sequence out of range'
+
+		# all clang
+		'warning: .*\[-Wstrlcpy-strlcat-size\]'
+		'warning: .*\[-Wstrncat-size\]'
+		'warning: .*\[-Wsuspicious-bzero\]'
+		'warning: .*\[-Wvarargs\]'
+
+		# left-hand operand of comma expression has no effect
+		'warning: .*left.*comma.*\[-Wunused-value\]'
+		# converting to non-pointer type ... from NULL and likes
+		'warning: .*\[-Wconversion-null\]'
+		# NULL used in arithmetic
+		'warning: .*NULL.*\[-Wpointer-arith\]'
+		# pointer to a function used in arithmetic and likes
+		'warning: .*function.*\[-Wpointer-arith\]'
+		# the address of ... will never be NULL and likes
+		# (uses of function refs & string constants in conditionals)
+		# XXX: Commented out because of gcc FPs (https://gcc.gnu.org/PR103360)
+		#'warning: .*\[-Waddress\]'
+
+		# TODO: we want to enable these but bash currently triggers
+		# them with a trick in random.c where it intentionally wants
+		# some truncation :(
+		#
+		# warning: assignment/initialization to ... from ... makes integer from pointer without cast
+		#'warning: .*\[-Wint-conversion\]'
+		# warning: cast to ... from integer of different size (or smaller size)
+		#'warning: .*\[-Wint-to-pointer-cast\]'
+		# warning: cast to ... from (smaller) integer type
+		#'warning: .*\[-Wint-to-void-pointer-cast\]'
+		# warning: cast from ... to integer of different size
+		#'warning: .*\[-Wpointer-to-int-cast\]'
+
+		# -Wformat
+		# TODO: comment out some time in future for time_t & LFS preparedness
+		#'warning: .*\[-Wformat=\]'
+		# -Wformat variants
+		'warning: .*too few arguments for format'
+		'warning: .*missing sentinel in function call.*\[-Wformat=\]'
+		'warning: .*\[-Wformat-truncation\]'
+		# format ... expects a matching ... argument
+		# (iow, too few arguments for format in new wording :))
+		'warning: .*matching.*\[-Wformat=\]'
+
+		# function returns address of local variable
+		# XXX: Commented out for bug #925460 (https://gcc.gnu.org/PR93644)
+		#'warning: .*\[-Wreturn-local-addr\]'
+		# missing return at end of function, or non-void return in a void function
+		# (clang at least aggressively optimises on this)
+		'warning: .*\[-Wreturn-type\]'
+		# argument to sizeof ... is the same expression as the source
+		'warning: .*\[-Wsizeof-pointer-memaccess\]'
+		# iteration invokes undefined behavior
+		'warning: .*\[-Waggressive-loop-optimizations\]'
+		# conversion between pointers that have incompatible types
+		'warning: .*\[-Wincompatible-pointer-types\]'
+		# more specific form of -Wincompatible-pointer-types (Clang)
+		'warning: .*\[-Wincompatible-function-pointer-types\]'
+		# these will fail with CFI (https://reviews.llvm.org/D134831)
+		# (gcc lacks -strict)
+		#'warning: .*\[-Wcast-function-type\]'
+		'warning: .*\[-Wcast-function-type-strict\]'
+		# using wrong deallocator, e.g. using free() on object allocated using my_malloc()
+		# when my_malloc() is annotated as needing my_free().
+		'warning: .*\[-Wmismatched-dealloc\]'
+		# clobbered: Warn for variables that might be changed by longjmp or vfork
+		# (This warning is also enabled by -Wextra.)
+		'warning: .*\[-Wclobbered\]'
+		# LTO type mismatch (https://wiki.gentoo.org/wiki/Project:Toolchain/LTO)
+		'warning: .*\[-Wlto-type-mismatch\]'
+		# ODR (https://wiki.gentoo.org/wiki/Project:Toolchain/LTO)
+		'warning: .*\[-Wodr\]'
+		# warning: argument value A will result in undefined behaviour (Clang)
+		'warning: .*\[-Wargument-undefined-behaviour\]'
+		# XXX: Commented out because of GCC FPs (https://gcc.gnu.org/PR86172)
+		#'warning: .*\[-Wnull-dereference\]'
+
+		# general sensible warnings (will be rejected by modern compilers soon)
+		'warning: .*\[-Wmain\]'
+		'warning: .*\[-Wimplicit-int\]'
+		'warning: .*\[-Wstring-compare\]'
+
+		# this may be valid code :/
+		#': warning: multi-character character constant'
+		# need to check these two ...
+		#': warning: assuming signed overflow does not occur when'
+		#': warning: comparison with string literal results in unspecified behav'
+		# yacc/lex likes to trigger this one
+		#': warning: extra tokens at end of .* directive'
+		# only gcc itself triggers this ?
+		#': warning: .*noreturn.* function does return'
+		# these throw false positives when 0 is used instead of NULL
+		#': warning: missing sentinel in function call'
+		#': warning: not enough variable arguments to fit a sentinel'
+	)
+
+	# join all messages into one grep-expression
+	local joined_msgs
+	printf -v joined_msgs '%s|' "${msgs[@]}"
+	joined_msgs=${joined_msgs%|}
+
+	local abort="no"
+	local grep_cmd=grep
+	[[ ${PORTAGE_LOG_FILE} = *.gz ]] && grep_cmd=zgrep
+
+	# Force C locale to work around slow multibyte locales, bug #160234
+	# Force text mode as newer grep will treat non-ASCII (e.g. UTF-8) as
+	# binary when we run in the C locale.
+	f=$(LC_ALL='C' sed -E -e $'s/\033\[[0-9;]*[A-Za-z]//g' < "${PORTAGE_LOG_FILE}" | LC_CTYPE=C LC_COLLATE=C "${grep_cmd}" -E -a "${joined_msgs}" | uniq)
+	if [[ -n ${f} ]] ; then
+		abort="yes"
+
+		# for now, don't make this fatal (see bug #337031)
+		#if [[ ${f} == *'will always overflow destination buffer'* ]]; then
+		#	always_overflow=yes
+		#fi
+
+		# Disabled for now because too many failures. bug #870412.
+		#if [[ ${f} == *'[-Wimplicit-function-declaration]'* ]] ; then
+		#	implicit_func_decl=yes
+		#fi
+
+		if [[ ${always_overflow} = yes || ${implicit_func_decl} = yes ]] ; then
+			eerror
+			eerror "QA Notice: Package triggers severe warnings which indicate that it"
+			eerror "           may exhibit random runtime failures."
+			eerror
+			eerror "${f}"
+			eerror
+			eerror " Please file a bug about this at https://bugs.gentoo.org/"
+			eerror " with the maintainer of the package."
+			eerror
+		else
+			__vecho -ne '\n'
+			eqawarn "QA Notice: Package triggers severe warnings which indicate that it"
+			eqawarn "           may exhibit random runtime failures."
+			eqawarn "${f}"
+			__vecho -ne '\n'
 		fi
+	fi
 
-		[[ ${reset_debug} = 1 ]] && set -x
-
-		if [[ ${abort} == "yes" ]] ; then
-			if [[ ${gentoo_bug} = yes || ${always_overflow} = yes || ${implicit_func_decl} = yes ]] ; then
+	[[ ${reset_debug} = 1 ]] && set -x
+
+	if [[ ${abort} == "yes" ]] ; then
+		if [[ ${gentoo_bug} = yes || ${always_overflow} = yes || ${implicit_func_decl} = yes ]] ; then
+			die "install aborted due to severe warnings shown above"
+		else
+			echo "Please do not file a Gentoo bug and instead" \
+			"report the above QA issues directly to the upstream" \
+			"developers of this software." | fmt -w 70 | \
+			while read -r line ; do eqawarn "${line}" ; done
+			eqawarn "Homepage: ${HOMEPAGE}"
+			has stricter ${FEATURES} && \
 				die "install aborted due to severe warnings shown above"
-			else
-				echo "Please do not file a Gentoo bug and instead" \
-				"report the above QA issues directly to the upstream" \
-				"developers of this software." | fmt -w 70 | \
-				while read -r line ; do eqawarn "${line}" ; done
-				eqawarn "Homepage: ${HOMEPAGE}"
-				has stricter ${FEATURES} && \
-					die "install aborted due to severe warnings shown above"
-			fi
 		fi
 	fi
 }
 
-gcc_warn_check
+if [[ ${PORTAGE_LOG_FILE} && -r ${PORTAGE_LOG_FILE} ]]; then
+	gcc_warn_check
+fi
+
 : # guarantee successful exit
 
 # vim:ft=bash
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2025-05-30  7:37 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2025-05-30  7:37 UTC (permalink / raw
  To: gentoo-commits
commit:     3d5e6efaae8c6d326215bad78abaa6c2c8eb8f6c
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Thu May 22 18:14:54 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May 30 07:37:29 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=3d5e6efa
90gcc-warnings: remove dead code
In the event that the dead code should be deemed useful in the future,
it may be recovered from git. As it stands, its continued presence only
makes it harder to re-factor the code.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/90gcc-warnings | 50 +++++++++--------------------------
 1 file changed, 12 insertions(+), 38 deletions(-)
diff --git a/bin/install-qa-check.d/90gcc-warnings b/bin/install-qa-check.d/90gcc-warnings
index 42166a7bf4..ea51f19d32 100644
--- a/bin/install-qa-check.d/90gcc-warnings
+++ b/bin/install-qa-check.d/90gcc-warnings
@@ -3,7 +3,7 @@
 # TODO: add -Wformat-security
 
 gcc_warn_check() {
-        local abort always_overflow f gentoo_bug grep_cmd implicit_func_decl joined_msgs reset_debug
+        local abort f grep_cmd joined_msgs reset_debug
         local -a msgs
 
 	# Evaluate misc gcc warnings
@@ -165,49 +165,23 @@ gcc_warn_check() {
 	if [[ -n ${f} ]] ; then
 		abort="yes"
 
-		# for now, don't make this fatal (see bug #337031)
-		#if [[ ${f} == *'will always overflow destination buffer'* ]]; then
-		#	always_overflow=yes
-		#fi
-
-		# Disabled for now because too many failures. bug #870412.
-		#if [[ ${f} == *'[-Wimplicit-function-declaration]'* ]] ; then
-		#	implicit_func_decl=yes
-		#fi
-
-		if [[ ${always_overflow} = yes || ${implicit_func_decl} = yes ]] ; then
-			eerror
-			eerror "QA Notice: Package triggers severe warnings which indicate that it"
-			eerror "           may exhibit random runtime failures."
-			eerror
-			eerror "${f}"
-			eerror
-			eerror " Please file a bug about this at https://bugs.gentoo.org/"
-			eerror " with the maintainer of the package."
-			eerror
-		else
-			__vecho -ne '\n'
-			eqawarn "QA Notice: Package triggers severe warnings which indicate that it"
-			eqawarn "           may exhibit random runtime failures."
-			eqawarn "${f}"
-			__vecho -ne '\n'
-		fi
+		__vecho -ne '\n'
+		eqawarn "QA Notice: Package triggers severe warnings which indicate that it"
+		eqawarn "           may exhibit random runtime failures."
+		eqawarn "${f}"
+		__vecho -ne '\n'
 	fi
 
 	[[ ${reset_debug} = 1 ]] && set -x
 
 	if [[ ${abort} == "yes" ]] ; then
-		if [[ ${gentoo_bug} = yes || ${always_overflow} = yes || ${implicit_func_decl} = yes ]] ; then
+		echo "Please do not file a Gentoo bug and instead" \
+		"report the above QA issues directly to the upstream" \
+		"developers of this software." | fmt -w 70 | \
+		while read -r line ; do eqawarn "${line}" ; done
+		eqawarn "Homepage: ${HOMEPAGE}"
+		has stricter ${FEATURES} && \
 			die "install aborted due to severe warnings shown above"
-		else
-			echo "Please do not file a Gentoo bug and instead" \
-			"report the above QA issues directly to the upstream" \
-			"developers of this software." | fmt -w 70 | \
-			while read -r line ; do eqawarn "${line}" ; done
-			eqawarn "Homepage: ${HOMEPAGE}"
-			has stricter ${FEATURES} && \
-				die "install aborted due to severe warnings shown above"
-		fi
 	fi
 }
 
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2025-05-30  7:36 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2025-05-30  7:36 UTC (permalink / raw
  To: gentoo-commits
commit:     7086a89128a08b08379699fa155d035d255d4d07
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Fri Jul 26 01:16:31 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May 30 07:35:53 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=7086a891
60openrc: read and check shebangs more efficiently
Don't bother calling head(1). Instead, use the read builtin. Don't open
and read from files twice. Use an extglob rather than a (slower) regex.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/60openrc | 9 ++++++---
 1 file changed, 6 insertions(+), 3 deletions(-)
diff --git a/bin/install-qa-check.d/60openrc b/bin/install-qa-check.d/60openrc
index 6c9c28795e..8b881d2ff2 100644
--- a/bin/install-qa-check.d/60openrc
+++ b/bin/install-qa-check.d/60openrc
@@ -10,9 +10,12 @@ openrc_check() {
 			# if empty conf.d/init.d dir exists (baselayout), then i will be "/etc/conf.d/*" and not exist
 			[[ ! -e ${i} ]] && continue
 			if [[ ${d} == /etc/init.d && ${i} != *.sh ]] ; then
-				# skip non-shell-script for bug #451386
-				[[ $(head -n1 "${i}") =~ ^#!.*[[:space:]/](openrc-run|runscript|sh)$ ]] || continue
-				if [[ $(head -n1 "${i}") == '#!/sbin/runscript' ]] ; then
+				if ! read -r < "${i}" ; then
+					continue
+				elif [[ ${REPLY} != '#!'*[[:blank:]/]@(openrc-run|runscript|sh) ]] ; then
+					# skip non-shell-script for bug #451386
+					continue
+				elif [[ ${REPLY} == '#!/sbin/runscript' ]] ; then
 					eqawarn "QA Notice: #!/sbin/runscript is deprecated, use #!/sbin/openrc-run instead:"
 					while read -r ;
 						do eqawarn "   ${REPLY}"
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2025-05-30  7:36 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2025-05-30  7:36 UTC (permalink / raw
  To: gentoo-commits
commit:     f7cf28051d9d65004083332448b9a4348474ce87
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Thu May 29 21:57:27 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May 30 07:35:54 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=f7cf2805
80multilib-strict: localise variables sensibly
Localise IFS so as to guarantee the default word splitting behaviour.
Evaluate the 'abort' variable arithmetically.
Jettison the 'x' variable. There already exists a 'dir' variable; there
is no need for another.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/80multilib-strict | 12 ++++++------
 1 file changed, 6 insertions(+), 6 deletions(-)
diff --git a/bin/install-qa-check.d/80multilib-strict b/bin/install-qa-check.d/80multilib-strict
index 1a2f65820d..9b687961b4 100644
--- a/bin/install-qa-check.d/80multilib-strict
+++ b/bin/install-qa-check.d/80multilib-strict
@@ -1,11 +1,12 @@
 # Strict multilib directory checks
 multilib_strict_check() {
+	local IFS abort dir file
+
 	if has multilib-strict ${FEATURES} && \
 	   type find &>/dev/null && type file &>/dev/null && \
 	   [[ -n ${MULTILIB_STRICT_DIRS} && -n ${MULTILIB_STRICT_DENY} ]]
 	then
 		rm -f "${T}/multilib-strict.log"
-		local abort=no dir file
 		for dir in ${MULTILIB_STRICT_DIRS} ; do
 			[[ -d ${ED}/${dir} ]] || continue
 			while read -r -d '' file; do
@@ -24,14 +25,13 @@ multilib_strict_check() {
 				set -${shopts}
 			fi
 			if [ "${QA_STRICT_MULTILIB_PATHS-unset}" = unset ] ; then
-				local x
-				for x in "${QA_MULTILIB_PATHS[@]}" ; do
-					sed -e "s#^${x#/}\$##" -i "${T}/multilib-strict.log"
+				for dir in "${QA_MULTILIB_PATHS[@]}" ; do
+					sed -e "s#^${dir#/}\$##" -i "${T}/multilib-strict.log"
 				done
 				sed -e "/^\$/d" -i "${T}/multilib-strict.log"
 			fi
 			if [[ -s ${T}/multilib-strict.log ]] ; then
-				abort=yes
+				abort=1
 				echo "Files matching a file type that is not allowed:"
 				while read -r ; do
 					echo "   ${REPLY}"
@@ -39,7 +39,7 @@ multilib_strict_check() {
 			fi
 		fi
 
-		[[ ${abort} == yes ]] && die "multilib-strict check failed!"
+		(( abort )) && die "multilib-strict check failed!"
 	fi
 }
 
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2025-05-30  7:36 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2025-05-30  7:36 UTC (permalink / raw
  To: gentoo-commits
commit:     66c2a82f9dcfb79c38a387ac07824d159db067cd
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Thu May 29 22:31:40 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May 30 07:35:55 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=66c2a82f
80multilib-strict: quote the expansion of ED
Per SC2295, the expansion of ED within ${…} must be quoted in its own right.
Otherwise, it shall be matched as a pattern.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/80multilib-strict | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/install-qa-check.d/80multilib-strict b/bin/install-qa-check.d/80multilib-strict
index f88c2d22b7..82a2883f1a 100644
--- a/bin/install-qa-check.d/80multilib-strict
+++ b/bin/install-qa-check.d/80multilib-strict
@@ -11,7 +11,7 @@ multilib_strict_check() {
 			[[ -d ${ED}/${dir} ]] || continue
 			while read -r -d '' file; do
 				if file "${file}" | grep -Eq "${MULTILIB_STRICT_DENY}" ; then
-					echo "${file#${ED}//}" >> "${T}/multilib-strict.log"
+					echo "${file#"${ED}"//}" >> "${T}/multilib-strict.log"
 				fi
 			done < <(find "${ED}/${dir}" -maxdepth 1 -type f -print0)
 		done
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2025-05-30  7:36 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2025-05-30  7:36 UTC (permalink / raw
  To: gentoo-commits
commit:     59b81ecda599e9fbf4084e4595f1fa96c32a9fc1
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Sun Aug  7 19:40:37 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May 30 07:35:54 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=59b81ecd
80multilib-strict: use read to split QA_MULTILIB_PATHS
Rather than employ the combination of noglob and unquoted expansions to
convert QA_MULTILIB_PATHS to an array, have read handle it instead. This
addresses an instance of SC2086 which, owing to a recent commit in which
I localised IFS, no longer constitutes a legitimate bug. Still, I
elected to employ read because I do not trust other portage contributors
not to repeat the same mistake in the future. Consider it a case of
leading by example, if you will.
Further, check whether QA_MULTILIB_PATHS is an array by examining its
attributes. This requires bash-4.4 at the minimum. I discussed the
matter with Sam James prior and he consented to the use of its features.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/80multilib-strict | 8 ++------
 1 file changed, 2 insertions(+), 6 deletions(-)
diff --git a/bin/install-qa-check.d/80multilib-strict b/bin/install-qa-check.d/80multilib-strict
index 9b687961b4..f88c2d22b7 100644
--- a/bin/install-qa-check.d/80multilib-strict
+++ b/bin/install-qa-check.d/80multilib-strict
@@ -17,12 +17,8 @@ multilib_strict_check() {
 		done
 
 		if [[ -s ${T}/multilib-strict.log ]] ; then
-			if [[ ${#QA_MULTILIB_PATHS[@]} -eq 1 ]] ; then
-				local shopts=$-
-				set -o noglob
-				QA_MULTILIB_PATHS=(${QA_MULTILIB_PATHS})
-				set +o noglob
-				set -${shopts}
+			if [[ ${QA_MULTILIB_PATHS@a} != *a* ]] ; then
+				read -rd '' -a QA_MULTILIB_PATHS <<<"${QA_MULTILIB_PATHS}"
 			fi
 			if [ "${QA_STRICT_MULTILIB_PATHS-unset}" = unset ] ; then
 				for dir in "${QA_MULTILIB_PATHS[@]}" ; do
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2025-05-30  7:30 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2025-05-30  7:30 UTC (permalink / raw
  To: gentoo-commits
commit:     f808b7d878041dbba66418e6b9ee0b1567c13471
Author:     Kerin Millar <kfm <AT> plushkava <DOT> net>
AuthorDate: Wed Jul 24 15:24:47 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May 30 07:30:31 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=f808b7d8
60bash-completion: refrain from using has() for better performance
Rather than use has(), define associative arrays to keep track of the
seen completions and file basenames. Also, correct the broken array
length checks.
Signed-off-by: Kerin Millar <kfm <AT> plushkava.net>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/60bash-completion | 21 ++++++++++-----------
 1 file changed, 10 insertions(+), 11 deletions(-)
diff --git a/bin/install-qa-check.d/60bash-completion b/bin/install-qa-check.d/60bash-completion
index d3cb52d1c1..815ea55763 100644
--- a/bin/install-qa-check.d/60bash-completion
+++ b/bin/install-qa-check.d/60bash-completion
@@ -54,10 +54,9 @@ bashcomp_check() {
 			_have ${1} && have=yes
 		}
 
-		local f c completions
-		local all_compls=()
-		local all_files=()
-		local qa_warnings=()
+		local -A seen_completion seen_file
+		local -a completions qa_warnings
+		local f c
 
 		for f in "${instcompdir}"/*; do
 			# ignore directories and other non-files
@@ -76,7 +75,7 @@ bashcomp_check() {
 				unset 'completions[0]'
 			fi
 
-			if [[ -z ${completions[@]} ]]; then
+			if (( ! ${#completions[@]} )); then
 				continue
 			fi
 
@@ -86,28 +85,28 @@ bashcomp_check() {
 						"${f##*/}: absolute paths can not be used for completions (on '${c}')."
 					)
 				else
-					all_compls+=( "${c}" )
+					seen_completion[$c]=1
 				fi
 			done
 
-			if ! has "${f##*/}" "${all_compls[@]}"; then
+			if [[ ! ${seen_completion[${f##*/}]} ]]; then
 				qa_warnings+=(
 					"${f##*/}: incorrect name, no completions for '${f##*/}' command defined."
 				)
 			fi
 
-			all_files+=( "${f##*/}" )
+			seen_file[${f##*/}]=1
 		done
 
-		for c in "${all_compls[@]}"; do
-			if ! has "${c}" "${all_files[@]}"; then
+		for c in "${!seen_completion[@]}"; do
+			if [[ ! ${seen_file[$c]} ]]; then
 				qa_warnings+=(
 					"${c}: missing alias (symlink) for completed command."
 				)
 			fi
 		done
 
-		if [[ -n ${qa_warnings[@]} ]]; then
+		if (( ${#qa_warnings[@]} )); then
 			eqawarn "QA Notice: Problems with installed bash completions were found:"
 			eqawarn
 			for c in "${qa_warnings[@]}"; do
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2025-04-24 22:12 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2025-04-24 22:12 UTC (permalink / raw
  To: gentoo-commits
commit:     6a2bd8589914e951491d9a042a9713b89a95b37b
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Apr 24 22:12:34 2025 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Apr 24 22:12:34 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=6a2bd858
bin: install-qa-check.d: fix whitespace in eqawarn
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/05prefix | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/install-qa-check.d/05prefix b/bin/install-qa-check.d/05prefix
index edbd6fab2f..2d46836f96 100644
--- a/bin/install-qa-check.d/05prefix
+++ b/bin/install-qa-check.d/05prefix
@@ -81,7 +81,7 @@ install_qa_check_prefix() {
 			if [[ -e ${EROOT}${line[0]} || -e ${ED}${line[0]} ]] ; then
 				# is it unprefixed, but we can just fix it because a
 				# prefixed variant exists
-				eqawarn "QA Notice:  prefixing shebang of ${fn#${D}}"
+				eqawarn "QA Notice: prefixing shebang of ${fn#${D}}"
 				# statement is made idempotent on purpose, because
 				# symlinks may point to the same target, and hence the
 				# same real file may be sedded multiple times since we
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2025-01-06 10:19 Ulrich Müller
  0 siblings, 0 replies; 120+ messages in thread
From: Ulrich Müller @ 2025-01-06 10:19 UTC (permalink / raw
  To: gentoo-commits
commit:     c52e71b428cad394a0e6840a831ca122ea7f8bde
Author:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
AuthorDate: Mon Jan  6 10:18:39 2025 +0000
Commit:     Ulrich Müller <ulm <AT> gentoo <DOT> org>
CommitDate: Mon Jan  6 10:18:39 2025 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=c52e71b4
install-qa-check.d/10ignored-flags: Update two comments
Signed-off-by: Ulrich Müller <ulm <AT> gentoo.org>
 bin/install-qa-check.d/10ignored-flags | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/bin/install-qa-check.d/10ignored-flags b/bin/install-qa-check.d/10ignored-flags
index b55b074e14..6e7044cd42 100644
--- a/bin/install-qa-check.d/10ignored-flags
+++ b/bin/install-qa-check.d/10ignored-flags
@@ -20,8 +20,8 @@ ignored_flag_check() {
 	# Check for files built without respecting *FLAGS. Note that
 	# -frecord-gcc-switches must be in all *FLAGS variables, in
 	# order to avoid false positive results here.
-	# NOTE: This check must execute before prepall/prepstrip, since
-	# prepstrip strips the .GCC.command.line sections.
+	# NOTE: This check must execute before estrip --prepallstrip,
+	# since estrip strips the .GCC.command.line sections.
 	if [[ "${CFLAGS}" == *-frecord-gcc-switches* ]] && \
 	[[ "${CXXFLAGS}" == *-frecord-gcc-switches* ]] && \
 	[[ "${FFLAGS}" == *-frecord-gcc-switches* ]] && \
@@ -30,7 +30,7 @@ ignored_flag_check() {
 		for x in $(scanelf -qyRF '#k%p' -k '!.GCC.command.line' "${ED%/}/") ; do
 			# Separate out file types that are known to support
 			# .GCC.command.line sections, using the `file` command
-			# similar to how prepstrip uses it.
+			# similar to how estrip uses it.
 			f=$(file -S "${x}") || continue
 			[[ -z ${f} ]] && continue
 			if [[ ${f} == *"SB executable"* || ${f} == *"SB pie executable"* ||
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2024-09-17 14:32 Matt Turner
  0 siblings, 0 replies; 120+ messages in thread
From: Matt Turner @ 2024-09-17 14:32 UTC (permalink / raw
  To: gentoo-commits
commit:     dd667a61da7013dc7a85372c97715be5b5da5c2b
Author:     Matt Turner <mattst88 <AT> gentoo <DOT> org>
AuthorDate: Thu Sep 12 17:50:37 2024 +0000
Commit:     Matt Turner <mattst88 <AT> gentoo <DOT> org>
CommitDate: Thu Sep 12 17:50:37 2024 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=dd667a61
install-qa-check.d/90config-impl-decl: Skip pthread_threadid_np on Linux
Seen in dev-db/mariadb. The function seems to be available on Darwin.
Bug: https://bugs.gentoo.org/899772
Signed-off-by: Matt Turner <mattst88 <AT> gentoo.org>
 bin/install-qa-check.d/90config-impl-decl | 1 +
 1 file changed, 1 insertion(+)
diff --git a/bin/install-qa-check.d/90config-impl-decl b/bin/install-qa-check.d/90config-impl-decl
index 89373c193d..6e3a579c2b 100644
--- a/bin/install-qa-check.d/90config-impl-decl
+++ b/bin/install-qa-check.d/90config-impl-decl
@@ -46,6 +46,7 @@ add_default_skips() {
 		acl
 		acl_get_perm_np
 		pthread_cond_timedwait_monotonic_np
+		pthread_threadid_np
 		res_getservers
 		res_ndestroy
 		statacl
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2024-09-17 14:32 Matt Turner
  0 siblings, 0 replies; 120+ messages in thread
From: Matt Turner @ 2024-09-17 14:32 UTC (permalink / raw
  To: gentoo-commits
commit:     d1f0e6d0bf1d264ea0c51e700aa9fc9f2096ebf6
Author:     Matt Turner <mattst88 <AT> gentoo <DOT> org>
AuthorDate: Thu Sep 12 17:55:14 2024 +0000
Commit:     Matt Turner <mattst88 <AT> gentoo <DOT> org>
CommitDate: Thu Sep 12 18:08:59 2024 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=d1f0e6d0
install-qa-check.d/90config-impl-decl: Skip pthread_set_name_np on Linux
Seen in dev-lang/erlang, dev-util/lttng-tools, and dev-util/lttng-ust.
The function seems to be available on at least Darwin, FreeBSD, and
OpenBSD.
Bug: https://bugs.gentoo.org/898762
Signed-off-by: Matt Turner <mattst88 <AT> gentoo.org>
 bin/install-qa-check.d/90config-impl-decl | 1 +
 1 file changed, 1 insertion(+)
diff --git a/bin/install-qa-check.d/90config-impl-decl b/bin/install-qa-check.d/90config-impl-decl
index 6e3a579c2b..223dc12a3b 100644
--- a/bin/install-qa-check.d/90config-impl-decl
+++ b/bin/install-qa-check.d/90config-impl-decl
@@ -46,6 +46,7 @@ add_default_skips() {
 		acl
 		acl_get_perm_np
 		pthread_cond_timedwait_monotonic_np
+		pthread_set_name_np
 		pthread_threadid_np
 		res_getservers
 		res_ndestroy
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2024-09-17 14:32 Matt Turner
  0 siblings, 0 replies; 120+ messages in thread
From: Matt Turner @ 2024-09-17 14:32 UTC (permalink / raw
  To: gentoo-commits
commit:     884b82d972fd1677eedfe3ad69a2edc3f5d4bc7f
Author:     Matt Turner <mattst88 <AT> gentoo <DOT> org>
AuthorDate: Thu Sep 12 17:45:21 2024 +0000
Commit:     Matt Turner <mattst88 <AT> gentoo <DOT> org>
CommitDate: Thu Sep 12 17:45:21 2024 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=884b82d9
install-qa-check.d/90config-impl-decl: Skip pthread_cond_timedwait_monotonic_np on Linux
Seen in mail-client/thunderbird, www-client/seamonkey, and
www-client/firefox. It seems to be an Android/bionic function.
Bug: https://bugs.gentoo.org/905825
Closes: https://bugs.gentoo.org/932360
Signed-off-by: Matt Turner <mattst88 <AT> gentoo.org>
 bin/install-qa-check.d/90config-impl-decl | 1 +
 1 file changed, 1 insertion(+)
diff --git a/bin/install-qa-check.d/90config-impl-decl b/bin/install-qa-check.d/90config-impl-decl
index 8768c99c62..89373c193d 100644
--- a/bin/install-qa-check.d/90config-impl-decl
+++ b/bin/install-qa-check.d/90config-impl-decl
@@ -45,6 +45,7 @@ add_default_skips() {
 	[[ ${CHOST} == *linux* ]] && QA_CONFIG_IMPL_DECL_SKIP+=(
 		acl
 		acl_get_perm_np
+		pthread_cond_timedwait_monotonic_np
 		res_getservers
 		res_ndestroy
 		statacl
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2024-09-17 14:32 Matt Turner
  0 siblings, 0 replies; 120+ messages in thread
From: Matt Turner @ 2024-09-17 14:32 UTC (permalink / raw
  To: gentoo-commits
commit:     a67b95a34a9f3c349778d12dbbc4c091a14dc64d
Author:     Matt Turner <mattst88 <AT> gentoo <DOT> org>
AuthorDate: Thu Sep 12 18:05:28 2024 +0000
Commit:     Matt Turner <mattst88 <AT> gentoo <DOT> org>
CommitDate: Thu Sep 12 18:09:02 2024 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=a67b95a3
install-qa-check.d/90config-impl-decl: Skip pthread_get_name_np on Linux
Seen in dev-util/lttng-tools and dev-util/lttng-ust.
The function seems to be available on at least Darwin, FreeBSD, and
OpenBSD.
Signed-off-by: Matt Turner <mattst88 <AT> gentoo.org>
 bin/install-qa-check.d/90config-impl-decl | 1 +
 1 file changed, 1 insertion(+)
diff --git a/bin/install-qa-check.d/90config-impl-decl b/bin/install-qa-check.d/90config-impl-decl
index 223dc12a3b..06bb7195f9 100644
--- a/bin/install-qa-check.d/90config-impl-decl
+++ b/bin/install-qa-check.d/90config-impl-decl
@@ -46,6 +46,7 @@ add_default_skips() {
 		acl
 		acl_get_perm_np
 		pthread_cond_timedwait_monotonic_np
+		pthread_get_name_np
 		pthread_set_name_np
 		pthread_threadid_np
 		res_getservers
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2024-09-09 23:49 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2024-09-09 23:49 UTC (permalink / raw
  To: gentoo-commits
commit:     b78da6155975faa519f93ec0bebe9830dd265c09
Author:     Eli Schwartz <eschwartz <AT> gentoo <DOT> org>
AuthorDate: Mon Jul 22 23:19:19 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Sep  9 23:48:44 2024 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=b78da615
install-qa-check.d: try to detect gcc warnings past color
We have some code we use for config-impl-decl which can strip color
codes out via sed. This is always necessary for config.log because if
color exists it will still be there.
The assumption was, likely, that build.log as managed by portage will
also be ansifilter'd by portage, and therefore stripping color is
unnecessary. But in fact, some people do like color and intentionally
avoid stripping it. This rendered the QA check effectively broken.
Instead we should make no assumptions, and explicitly strip this too.
Signed-off-by: Eli Schwartz <eschwartz <AT> gentoo.org>
Closes: https://github.com/gentoo/portage/pull/1375
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/90gcc-warnings | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/install-qa-check.d/90gcc-warnings b/bin/install-qa-check.d/90gcc-warnings
index 2e728268e1..c7e3d6a8a0 100644
--- a/bin/install-qa-check.d/90gcc-warnings
+++ b/bin/install-qa-check.d/90gcc-warnings
@@ -162,7 +162,7 @@ gcc_warn_check() {
 		# Force C locale to work around slow multibyte locales, bug #160234
 		# Force text mode as newer grep will treat non-ASCII (e.g. UTF-8) as
 		# binary when we run in the C locale.
-		f=$(LC_CTYPE=C LC_COLLATE=C "${grep_cmd}" -E -a "${joined_msgs}" "${PORTAGE_LOG_FILE}" | uniq)
+		f=$(LC_ALL='C' sed -E -e $'s/\033\[[0-9;]*[A-Za-z]//g' < "${PORTAGE_LOG_FILE}" | LC_CTYPE=C LC_COLLATE=C "${grep_cmd}" -E -a "${joined_msgs}" | uniq)
 		if [[ -n ${f} ]] ; then
 			abort="yes"
 
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2024-05-22 16:56 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2024-05-22 16:56 UTC (permalink / raw
  To: gentoo-commits
commit:     9728fbba80abeec5adad8ba6cf7580c16c039a45
Author:     Eli Schwartz <eschwartz93 <AT> gmail <DOT> com>
AuthorDate: Tue May 21 23:22:31 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed May 22 16:56:31 2024 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=9728fbba
install-qa-checks.d: suppress some gnulib implicit decls on musl
These happen in tons of GNU packages because of using gnulib's regex.m4
specifically, which pulls in a macro that checks for some functionality
and spit out many implicit function declaration errors if regex.h isn't
GNU's specifically.
The compile tests do fail either way, it's just very dirty in the logs.
Bug: https://bugs.gentoo.org/906027
Signed-off-by: Eli Schwartz <eschwartz93 <AT> gmail.com>
Closes: https://github.com/gentoo/portage/pull/1327
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/90config-impl-decl | 12 ++++++++++++
 1 file changed, 12 insertions(+)
diff --git a/bin/install-qa-check.d/90config-impl-decl b/bin/install-qa-check.d/90config-impl-decl
index adea7d4051..8768c99c62 100644
--- a/bin/install-qa-check.d/90config-impl-decl
+++ b/bin/install-qa-check.d/90config-impl-decl
@@ -58,6 +58,18 @@ add_default_skips() {
 		# also gnulib, but checks both linux/non-linux headers
 		MIN
 	)
+	if [[ ${CHOST} = *musl* ]]; then
+		QA_CONFIG_IMPL_DECL_SKIP+=(
+			# gnulib checks for functions that aren't available on musl.
+
+			# regex.m4 always emits these warnings, but they are noisy to fix
+			# and the check will correctly fail due to missing macros anyway.
+			re_set_syntax
+			re_compile_pattern
+			re_search
+			re_match
+		)
+	fi
 }
 
 find_log_targets() {
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2024-05-17  6:28 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2024-05-17  6:28 UTC (permalink / raw
  To: gentoo-commits
commit:     8256473c6a9fa93e7cf81c46fa920cd522507c21
Author:     Eli Schwartz <eschwartz93 <AT> gmail <DOT> com>
AuthorDate: Fri May 17 05:52:53 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri May 17 06:28:24 2024 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=8256473c
install-qa-checks.d: suppress some gnulib implicit configure declarations
These happen in tons of GNU packages because of using gnulib, which
pulls in macros that check for some functionality and spit out an
implicit function declaration error if they aren't supported, which is
*expected*.
Bug: https://bugs.gentoo.org/906027
Signed-off-by: Eli Schwartz <eschwartz93 <AT> gmail.com>
Closes: https://github.com/gentoo/portage/pull/1323
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/90config-impl-decl | 9 +++++++++
 1 file changed, 9 insertions(+)
diff --git a/bin/install-qa-check.d/90config-impl-decl b/bin/install-qa-check.d/90config-impl-decl
index 7969dff175..adea7d4051 100644
--- a/bin/install-qa-check.d/90config-impl-decl
+++ b/bin/install-qa-check.d/90config-impl-decl
@@ -49,6 +49,15 @@ add_default_skips() {
 		res_ndestroy
 		statacl
 	)
+
+	QA_CONFIG_IMPL_DECL_SKIP+=(
+		# Available in c23, these gnulib checks are expected to fail
+		alignof
+		static_assert
+		unreachable
+		# also gnulib, but checks both linux/non-linux headers
+		MIN
+	)
 }
 
 find_log_targets() {
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2024-04-25  2:59 Mike Gilbert
  0 siblings, 0 replies; 120+ messages in thread
From: Mike Gilbert @ 2024-04-25  2:59 UTC (permalink / raw
  To: gentoo-commits
commit:     8bbdc814485d2990630d4217f68830fe1148801c
Author:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
AuthorDate: Wed Apr 24 15:35:32 2024 +0000
Commit:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
CommitDate: Wed Apr 24 15:35:32 2024 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=8bbdc814
Remove QA warning when no bash completions are found
This triggers unwanted warnings in at least two known cases.
Bug: https://bugs.gentoo.org/928599
Bug: https://bugs.gentoo.org/928869
Signed-off-by: Mike Gilbert <floppym <AT> gentoo.org>
 bin/install-qa-check.d/60bash-completion | 3 ---
 1 file changed, 3 deletions(-)
diff --git a/bin/install-qa-check.d/60bash-completion b/bin/install-qa-check.d/60bash-completion
index 85573df0e5..d3cb52d1c1 100644
--- a/bin/install-qa-check.d/60bash-completion
+++ b/bin/install-qa-check.d/60bash-completion
@@ -77,9 +77,6 @@ bashcomp_check() {
 			fi
 
 			if [[ -z ${completions[@]} ]]; then
-				qa_warnings+=(
-					"${f##*/}: does not define any completions (failed to source?)."
-				)
 				continue
 			fi
 
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2023-07-29  3:57 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2023-07-29  3:57 UTC (permalink / raw
  To: gentoo-commits
commit:     da9e55236ef40ab4887415814c7f6ddd2abf083c
Author:     Florian Schmaus <flow <AT> gentoo <DOT> org>
AuthorDate: Wed Jul 26 10:22:01 2023 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Jul 29 03:55:20 2023 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=da9e5523
install-qa-check.d/60openrc: be explicit about OpenRC
Be explicit that this is not some arbitrary shell script that is
checked by the QA check, but an OpenRC runscript.
Signed-off-by: Florian Schmaus <flow <AT> gentoo.org>
Closes: https://github.com/gentoo/portage/pull/1074
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/60openrc | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/install-qa-check.d/60openrc b/bin/install-qa-check.d/60openrc
index 0ab27f646..4d6199432 100644
--- a/bin/install-qa-check.d/60openrc
+++ b/bin/install-qa-check.d/60openrc
@@ -32,7 +32,7 @@ openrc_check() {
 				[[ -L ${i} ]] && continue
 				f=$("${checkbashisms}" -n -f "${i}" 2>&1)
 				[[ $? != 0 && -n ${f} ]] || continue
-				eqawarn "QA Notice: shell script appears to use non-POSIX feature(s):"
+				eqawarn "QA Notice: OpenRC shell script appears to use non-POSIX feature(s):"
 				while read -r ;
 					do eqawarn "   ${REPLY}"
 				done <<< "${f//${ED}}"
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2023-06-29  8:22 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2023-06-29  8:22 UTC (permalink / raw
  To: gentoo-commits
commit:     6066bb766f43ca06a5b0f08baa5946ff678f0c29
Author:     Benda Xu <orv <AT> debian <DOT> org>
AuthorDate: Sun Jun 25 09:03:00 2023 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Jun 29 08:22:53 2023 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=6066bb76
bin/install-qa-check.d/05prefix: prefixify init-script shebangs.
Init scripts in /etc/init.d have OpenRC shebangs "#!/sbin/openrc-run".
They should be prefixified like a executable script in a Prefix.
Signed-off-by: Benda Xu <heroxbd <AT> gentoo.org>
Bug: https://bugs.gentoo.org/640658
Closes: https://github.com/gentoo/portage/pull/1061
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/05prefix | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/install-qa-check.d/05prefix b/bin/install-qa-check.d/05prefix
index 7488ad9e4..28f2c06af 100644
--- a/bin/install-qa-check.d/05prefix
+++ b/bin/install-qa-check.d/05prefix
@@ -76,8 +76,8 @@ install_qa_check_prefix() {
 			fi
 			continue
 		fi
-		# unprefixed shebang, is the script directly in ${PATH}?
-		if [[ ":${PATH}:" == *":${fp}:"* ]] ; then
+		# unprefixed shebang, is the script directly in ${PATH} or an init script?
+		if [[ ":${PATH}:${EPREFIX}/etc/init.d:" == *":${fp}:"* ]] ; then
 			if [[ -e ${EROOT}${line[0]} || -e ${ED}${line[0]} ]] ; then
 				# is it unprefixed, but we can just fix it because a
 				# prefixed variant exists
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2023-05-11  1:24 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2023-05-11  1:24 UTC (permalink / raw
  To: gentoo-commits
commit:     b945f1ecd17c492f08d79e5927003b97ec41db5e
Author:     Matt Turner <mattst88 <AT> gentoo <DOT> org>
AuthorDate: Wed May 10 01:47:04 2023 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu May 11 01:24:42 2023 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=b945f1ec
install-qa-check.d/90config-impl-decl: Skip res_getservers on Linux
Seen in app-emulation/wine-*. It seems that at least Darwin, NetBSD, and
Solaris have this function.
Signed-off-by: Matt Turner <mattst88 <AT> gentoo.org>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/90config-impl-decl | 1 +
 1 file changed, 1 insertion(+)
diff --git a/bin/install-qa-check.d/90config-impl-decl b/bin/install-qa-check.d/90config-impl-decl
index 4e9494931..9950ac934 100644
--- a/bin/install-qa-check.d/90config-impl-decl
+++ b/bin/install-qa-check.d/90config-impl-decl
@@ -43,6 +43,7 @@ add_default_skips() {
 
 	# Functions not available on Linux
 	[[ ${CHOST} == *linux* ]] && QA_CONFIG_IMPL_DECL_SKIP+=(
+		res_getservers
 		res_ndestroy
 	)
 }
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2023-05-11  1:24 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2023-05-11  1:24 UTC (permalink / raw
  To: gentoo-commits
commit:     a478b4c427cfc51188ec9273952ad498de95a39f
Author:     Matt Turner <mattst88 <AT> gentoo <DOT> org>
AuthorDate: Wed May 10 01:35:54 2023 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu May 11 01:24:41 2023 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=a478b4c4
install-qa-check.d/90config-impl-decl: Skip res_ndestroy on Linux
Seen in dev-libs/glib. It seems that at least Darwin, FreeBSD, OpenBSD,
NetBSD, and Solaris have this function.
Bug: https://bugs.gentoo.org/898232
Signed-off-by: Matt Turner <mattst88 <AT> gentoo.org>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/90config-impl-decl | 5 +++++
 1 file changed, 5 insertions(+)
diff --git a/bin/install-qa-check.d/90config-impl-decl b/bin/install-qa-check.d/90config-impl-decl
index 43be4222b..4e9494931 100644
--- a/bin/install-qa-check.d/90config-impl-decl
+++ b/bin/install-qa-check.d/90config-impl-decl
@@ -40,6 +40,11 @@ add_default_skips() {
 		# https://gcc.gnu.org/onlinedocs/gcc/_005f_005fatomic-Builtins.html
 		"__atomic_*"
 	)
+
+	# Functions not available on Linux
+	[[ ${CHOST} == *linux* ]] && QA_CONFIG_IMPL_DECL_SKIP+=(
+		res_ndestroy
+	)
 }
 
 find_log_targets() {
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2023-05-11  1:24 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2023-05-11  1:24 UTC (permalink / raw
  To: gentoo-commits
commit:     703199b7cf029be2a88ae1482f2d4089c9be957c
Author:     Matt Turner <mattst88 <AT> gentoo <DOT> org>
AuthorDate: Wed May 10 01:56:01 2023 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu May 11 01:24:42 2023 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=703199b7
install-qa-check.d/90config-impl-decl: Skip acl_get_perm_np on Linux
Seen in net-misc/rsync. It seems that at least Darwin, FreeBSD, and
NetBSD have this function.
Bug: https://bugs.gentoo.org/898366
Signed-off-by: Matt Turner <mattst88 <AT> gentoo.org>
Closes: https://github.com/gentoo/portage/pull/1034
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/90config-impl-decl | 1 +
 1 file changed, 1 insertion(+)
diff --git a/bin/install-qa-check.d/90config-impl-decl b/bin/install-qa-check.d/90config-impl-decl
index 068a7186f..7969dff17 100644
--- a/bin/install-qa-check.d/90config-impl-decl
+++ b/bin/install-qa-check.d/90config-impl-decl
@@ -44,6 +44,7 @@ add_default_skips() {
 	# Functions not available on Linux
 	[[ ${CHOST} == *linux* ]] && QA_CONFIG_IMPL_DECL_SKIP+=(
 		acl
+		acl_get_perm_np
 		res_getservers
 		res_ndestroy
 		statacl
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2023-05-11  1:24 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2023-05-11  1:24 UTC (permalink / raw
  To: gentoo-commits
commit:     e34b593e10a86ffc61d54f113729b3fb556b46c0
Author:     Matt Turner <mattst88 <AT> gentoo <DOT> org>
AuthorDate: Wed May 10 01:28:12 2023 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu May 11 01:24:41 2023 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=e34b593e
install-qa-check.d/90config-impl-decl: Skip compiler built-ins
Bug: https://bugs.gentoo.org/879687
Bug: https://bugs.gentoo.org/898232
Signed-off-by: Matt Turner <mattst88 <AT> gentoo.org>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/90config-impl-decl | 13 +++++++++++++
 1 file changed, 13 insertions(+)
diff --git a/bin/install-qa-check.d/90config-impl-decl b/bin/install-qa-check.d/90config-impl-decl
index 7eb7dcff9..43be4222b 100644
--- a/bin/install-qa-check.d/90config-impl-decl
+++ b/bin/install-qa-check.d/90config-impl-decl
@@ -31,6 +31,17 @@ is_in() {
 	return 1
 }
 
+add_default_skips() {
+	# Skip built-in functions provided by the compiler
+	QA_CONFIG_IMPL_DECL_SKIP+=(
+		"__builtin_*"
+		# https://gcc.gnu.org/onlinedocs/gcc/_005f_005fsync-Builtins.html
+		"__sync_*"
+		# https://gcc.gnu.org/onlinedocs/gcc/_005f_005fatomic-Builtins.html
+		"__atomic_*"
+	)
+}
+
 find_log_targets() {
 	local log_targets=(
 		'config.log'
@@ -68,6 +79,8 @@ config_impl_decl_check() {
 	local re_asc
 	local is_utf8
 
+	add_default_skips
+
 	# Given the UTF-8 character type, both gcc and clang may enclose the
 	# function name between the LEFT SINGLE QUOTATION MARK and RIGHT SINGLE
 	# QUOTATION MARK codepoints.
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2023-05-11  1:24 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2023-05-11  1:24 UTC (permalink / raw
  To: gentoo-commits
commit:     595a73259025589c65af837ce23d994523242d45
Author:     Matt Turner <mattst88 <AT> gentoo <DOT> org>
AuthorDate: Wed May 10 00:35:13 2023 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu May 11 01:24:41 2023 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=595a7325
install-qa-check.d/90config-impl-decl: Allow wildcards in QA_CONFIG_IMPL_DECL_SKIP
This will enable us to ignore all __builtin_* functions, for example.
Signed-off-by: Matt Turner <mattst88 <AT> gentoo.org>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/90config-impl-decl | 14 +++++++++++++-
 1 file changed, 13 insertions(+), 1 deletion(-)
diff --git a/bin/install-qa-check.d/90config-impl-decl b/bin/install-qa-check.d/90config-impl-decl
index 0e758e87d..7eb7dcff9 100644
--- a/bin/install-qa-check.d/90config-impl-decl
+++ b/bin/install-qa-check.d/90config-impl-decl
@@ -19,6 +19,18 @@
 #
 # See also: bug 892651
 
+# Same as the "has" function, but allows wildcards in the array
+is_in() {
+	local needle=$1
+	shift
+
+	local x
+	for x in "$@"; do
+		[[ "${needle}" = ${x} ]] && return 0
+	done
+	return 1
+}
+
 find_log_targets() {
 	local log_targets=(
 		'config.log'
@@ -80,7 +92,7 @@ config_impl_decl_check() {
 				continue
 			fi
 
-			has "${func}" "${QA_CONFIG_IMPL_DECL_SKIP[@]}" && continue
+			is_in "${func}" "${QA_CONFIG_IMPL_DECL_SKIP[@]}" && continue
 
 			files+=( "${l}" )
 			lines+=( "${line}" )
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2023-05-11  1:24 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2023-05-11  1:24 UTC (permalink / raw
  To: gentoo-commits
commit:     4f02695138a577e162e731f34cdc3eb9e9391e21
Author:     Matt Turner <mattst88 <AT> gentoo <DOT> org>
AuthorDate: Wed May 10 01:44:04 2023 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu May 11 01:24:42 2023 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=4f026951
install-qa-check.d/90config-impl-decl: Skip acl & statacl on Linux
Seen in app-editors/vim.
Bug: https://bugs.gentoo.org/898450
Signed-off-by: Matt Turner <mattst88 <AT> gentoo.org>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/90config-impl-decl | 2 ++
 1 file changed, 2 insertions(+)
diff --git a/bin/install-qa-check.d/90config-impl-decl b/bin/install-qa-check.d/90config-impl-decl
index 9950ac934..068a7186f 100644
--- a/bin/install-qa-check.d/90config-impl-decl
+++ b/bin/install-qa-check.d/90config-impl-decl
@@ -43,8 +43,10 @@ add_default_skips() {
 
 	# Functions not available on Linux
 	[[ ${CHOST} == *linux* ]] && QA_CONFIG_IMPL_DECL_SKIP+=(
+		acl
 		res_getservers
 		res_ndestroy
+		statacl
 	)
 }
 
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2023-04-07 10:41 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2023-04-07 10:41 UTC (permalink / raw
  To: gentoo-commits
commit:     6642bdf54d071d7b93b3f6fb4bc24df4075c8de1
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Apr  7 10:39:06 2023 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Apr  7 10:39:06 2023 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=6642bdf5
bin/install-qa-check.d/90gcc-warnings: add -Wimplicit-int
This will be rejected by modern compilers soon: https://wiki.gentoo.org/wiki/Modern_C_porting.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/90gcc-warnings | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/bin/install-qa-check.d/90gcc-warnings b/bin/install-qa-check.d/90gcc-warnings
index 431cc7639..dbfbc4a9a 100644
--- a/bin/install-qa-check.d/90gcc-warnings
+++ b/bin/install-qa-check.d/90gcc-warnings
@@ -118,6 +118,9 @@ gcc_warn_check() {
 			# warning: argument value A will result in undefined behaviour (Clang)
 			'warning: .*\[-Wargument-undefined-behaviour\]'
 
+			# general sensible warnings (will be rejected by modern compilers soon)
+			'warning: .*\[-Wimplicit-int\]'
+
 			# this may be valid code :/
 			#': warning: multi-character character constant'
 			# need to check these two ...
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2023-02-28  3:10 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2023-02-28  3:10 UTC (permalink / raw
  To: gentoo-commits
commit:     eca90b6049a9ce42ec6868f64abcab403c9f4190
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Feb 28 03:10:26 2023 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Feb 28 03:10:26 2023 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=eca90b60
install-qa-check.d/90config-impl-decl: prefix warning with 'QA Notice'
... so tinderboxes can pick it up more easily.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/90config-impl-decl | 3 ++-
 1 file changed, 2 insertions(+), 1 deletion(-)
diff --git a/bin/install-qa-check.d/90config-impl-decl b/bin/install-qa-check.d/90config-impl-decl
index d1bc0e067..0e758e87d 100644
--- a/bin/install-qa-check.d/90config-impl-decl
+++ b/bin/install-qa-check.d/90config-impl-decl
@@ -92,12 +92,13 @@ config_impl_decl_check() {
 	# Drop out early if no impl decls found (all the arrays are the same size)
 	[[ ${#files[@]} -eq 0 ]] && return
 
-	eqawarn 'Found the following implicit function declarations in configure logs:'
+	eqawarn 'QA Notice: Found the following implicit function declarations in configure logs:'
 	for l in "${!files[@]}"; do
 		eqawarn "  ${files[l]}:${lines[l]} - ${funcs[l]}"
 		eqatag 'config.log-impl-decl' "line=${lines[l]}" "func=${funcs[l]}" "${files[l]}"
 	done
 	eqawarn 'Check that no features were accidentally disabled.'
+	eqawarn 'See https://wiki.gentoo.org/wiki/Modern_C_porting.'
 }
 
 config_impl_decl_check
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2023-02-27  4:43 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2023-02-27  4:43 UTC (permalink / raw
  To: gentoo-commits
commit:     b846c59c1e2ad80163745de024154cbe845fedaa
Author:     Oskari Pirhonen <xxc3ncoredxx <AT> gmail <DOT> com>
AuthorDate: Mon Feb 27 02:05:39 2023 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Feb 27 04:43:48 2023 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=b846c59c
90config-impl-decl: bug fixes
- Match "-Werror=impl..." from gcc
- Use separate RE to check for UTF-8 and ASCII quoting when extracting
  the function name
Signed-off-by: Oskari Pirhonen <xxc3ncoredxx <AT> gmail.com>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/90config-impl-decl | 31 +++++++++++++++++++++++++------
 1 file changed, 25 insertions(+), 6 deletions(-)
diff --git a/bin/install-qa-check.d/90config-impl-decl b/bin/install-qa-check.d/90config-impl-decl
index 2fb8307ea..d1bc0e067 100644
--- a/bin/install-qa-check.d/90config-impl-decl
+++ b/bin/install-qa-check.d/90config-impl-decl
@@ -38,6 +38,12 @@ find_log_targets() {
 		find -files0-from - -type f \( "${find_args[@]}" \) -print0
 }
 
+has_utf8_ctype() {
+	# Use python to check if the locale is UTF-8 since tools like locale(1) may
+	# not exist (eg, musl systems).
+	[[ "$("${PORTAGE_PYTHON:-/usr/bin/python}" -c 'import locale; print(locale.getlocale()[1])')" == UTF-8 ]]
+}
+
 config_impl_decl_check() {
 	local files=()
 	local lines=()
@@ -46,19 +52,32 @@ config_impl_decl_check() {
 	local entry
 	local line
 	local func
-	local re=" function '([[:print:]]+)'"
+	local re_uni
+	local re_asc
+	local is_utf8
+
+	# Given the UTF-8 character type, both gcc and clang may enclose the
+	# function name between the LEFT SINGLE QUOTATION MARK and RIGHT SINGLE
+	# QUOTATION MARK codepoints.
+	re_uni=$' function \u2018([^\u2019]+)\u2019'
+
+	# This variant matches ASCII single quotes.
+	re_asc=$' function \x27([^\x27]+)\x27'
+
+	# Is UTF-8 the effective character type?
+	has_utf8_ctype; is_utf8=$(( $? == 0 ))
 
 	# Iterate over every log file found and check for '-Wimplicit-function-declaration'
 	while IFS= read -rd '' l; do
 		while IFS= read -ru3 entry; do
 			# Strip ANSI codes (color and erase in line have been seen at least)
-			entry="$(printf '%s\n' "${entry}" | sed -E -e $'s/\033\[[0-9;]*[A-Za-z]//g')"
+			entry="$(printf '%s\n' "${entry}" | LC_ALL='C' sed -E -e $'s/\033\[[0-9;]*[A-Za-z]//g')"
 
 			line="${entry%%:*}"
-			# This conditional should always be true unless compiler warnings
-			# get drastically changed
-			if [[ ${entry} =~ ${re} ]]; then
+			if [[ ${is_utf8} -eq 1 && ${entry} =~ ${re_uni} ]] || [[ ${entry} =~ ${re_asc} ]]; then
 				func="${BASH_REMATCH[1]}"
+			else
+				continue
 			fi
 
 			has "${func}" "${QA_CONFIG_IMPL_DECL_SKIP[@]}" && continue
@@ -67,7 +86,7 @@ config_impl_decl_check() {
 			lines+=( "${line}" )
 			funcs+=( "${func}" )
 		# Using -I to ignore binary files is a GNU extension for grep
-		done 3< <(grep -nEI -e '-Wimplicit-function-declaration' "${l}")
+		done 3< <(grep -nEI -e '-W(error=)?implicit-function-declaration' "${l}")
 	done < <(find_log_targets)
 
 	# Drop out early if no impl decls found (all the arrays are the same size)
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2023-02-26 20:22 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2023-02-26 20:22 UTC (permalink / raw
  To: gentoo-commits
commit:     dc1e8d7b9ad8f7253fa14e068547b63b14c829b7
Author:     Oskari Pirhonen <xxc3ncoredxx <AT> gmail <DOT> com>
AuthorDate: Wed Feb  1 04:32:20 2023 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Feb 26 20:22:42 2023 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=dc1e8d7b
install-qa-check.d/90config-impl-decl: check config log for warnings
Check for -Wimplicit-function-declaration in:
- config.log
- CMakeError.log
- meson-log.txt
and log the config log, line number, and function name on-screen and in
qa.log under the tag 'config.log-impl-decl'. In ebuilds, use the
`QA_CONFIG_IMPL_DECL_SKIP` array to skip false positives.
Closes: https://bugs.gentoo.org/892651
Signed-off-by: Oskari Pirhonen <xxc3ncoredxx <AT> gmail.com>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/90config-impl-decl | 87 +++++++++++++++++++++++++++++++
 1 file changed, 87 insertions(+)
diff --git a/bin/install-qa-check.d/90config-impl-decl b/bin/install-qa-check.d/90config-impl-decl
new file mode 100644
index 000000000..2fb8307ea
--- /dev/null
+++ b/bin/install-qa-check.d/90config-impl-decl
@@ -0,0 +1,87 @@
+# Check for implicit function declaration warnings in configure logs
+#
+# ebuilds should set the QA_CONFIG_IMPL_DECL_SKIP array to skip known false
+# positives.
+#
+# Some examples of logs to look for:
+# bash: work/bash-5.1/config.log
+#       ^---  easy
+# python: work/Python-3.10.9/config.log
+#         ^---  easy
+# gcc: work/build/config.log
+#      ^---  can be out-of-tree
+# clang: work/x/y/clang-abi_x86_64.amd64/CMakeFiles/CMakeError.log
+#        ^---  can be non-autotools (and very deep)
+# systemd-utils: work/systemd-stable-251.10-abi_x86_64.amd64/meson-logs/meson-log.txt
+#                ^---  can be non-autotools
+#
+# Adapted from macports portconfigure.tcl with love.
+#
+# See also: bug 892651
+
+find_log_targets() {
+	local log_targets=(
+		'config.log'
+		'CMakeError.log'
+		'meson-log.txt'
+	)
+	local find_args=()
+	local log
+
+	# Find config logs. Assume the dirs can have spaces in them, even though
+	# that is hella evil and goes against good filesystem manners!
+	for log in "${log_targets[@]}"; do
+		find_args+=( '-name' "${log}" '-o' )
+	done
+	unset -v 'find_args[-1]'
+	printf '%s\0' "${WORKDIR}" |
+		find -files0-from - -type f \( "${find_args[@]}" \) -print0
+}
+
+config_impl_decl_check() {
+	local files=()
+	local lines=()
+	local funcs=()
+	local l
+	local entry
+	local line
+	local func
+	local re=" function '([[:print:]]+)'"
+
+	# Iterate over every log file found and check for '-Wimplicit-function-declaration'
+	while IFS= read -rd '' l; do
+		while IFS= read -ru3 entry; do
+			# Strip ANSI codes (color and erase in line have been seen at least)
+			entry="$(printf '%s\n' "${entry}" | sed -E -e $'s/\033\[[0-9;]*[A-Za-z]//g')"
+
+			line="${entry%%:*}"
+			# This conditional should always be true unless compiler warnings
+			# get drastically changed
+			if [[ ${entry} =~ ${re} ]]; then
+				func="${BASH_REMATCH[1]}"
+			fi
+
+			has "${func}" "${QA_CONFIG_IMPL_DECL_SKIP[@]}" && continue
+
+			files+=( "${l}" )
+			lines+=( "${line}" )
+			funcs+=( "${func}" )
+		# Using -I to ignore binary files is a GNU extension for grep
+		done 3< <(grep -nEI -e '-Wimplicit-function-declaration' "${l}")
+	done < <(find_log_targets)
+
+	# Drop out early if no impl decls found (all the arrays are the same size)
+	[[ ${#files[@]} -eq 0 ]] && return
+
+	eqawarn 'Found the following implicit function declarations in configure logs:'
+	for l in "${!files[@]}"; do
+		eqawarn "  ${files[l]}:${lines[l]} - ${funcs[l]}"
+		eqatag 'config.log-impl-decl' "line=${lines[l]}" "func=${funcs[l]}" "${files[l]}"
+	done
+	eqawarn 'Check that no features were accidentally disabled.'
+}
+
+config_impl_decl_check
+: # guarantee successful exit
+
+# vim:ft=sh noexpandtab:
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2023-02-19 12:23 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2023-02-19 12:23 UTC (permalink / raw
  To: gentoo-commits
commit:     bd6e366894615fc7b2c7faafca666933ad850340
Author:     Florian Schmaus <flow <AT> gentoo <DOT> org>
AuthorDate: Sun Feb 19 09:04:21 2023 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Feb 19 12:22:58 2023 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=bd6e3668
install-qa-check.d/60pkgconfig: fix eapi_has_version_functions call
The function is prefixed with three three underscores, not two.
Fixes: f0d4e696f82d ("install-qa-check.d/60pkgconfig: conditionally source eapi7-ver-funcs.sh")
Signed-off-by: Florian Schmaus <flow <AT> gentoo.org>
Closes: https://github.com/gentoo/portage/pull/990
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/60pkgconfig | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/install-qa-check.d/60pkgconfig b/bin/install-qa-check.d/60pkgconfig
index 625b22c9e..acbee4df1 100644
--- a/bin/install-qa-check.d/60pkgconfig
+++ b/bin/install-qa-check.d/60pkgconfig
@@ -1,7 +1,7 @@
 # Check for pkg-config file issues
 
 # Ensure that ver_test is available.
-if ! __eapi_has_version_functions; then
+if ! ___eapi_has_version_functions; then
 	source "${PORTAGE_BIN_PATH}/eapi7-ver-funcs.sh" || exit 1
 fi
 
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2023-02-17  9:12 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2023-02-17  9:12 UTC (permalink / raw
  To: gentoo-commits
commit:     7b00b5aa8c68942cdb9e751a9eeaa8b7795387f0
Author:     Florian Schmaus <flow <AT> gentoo <DOT> org>
AuthorDate: Thu Dec 22 07:59:14 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Feb 17 09:12:03 2023 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=7b00b5aa
Revert "bin/install-qa-check.d: drop QA_PKGCONFIG_VERSION checks from 60pkgconfig"
This reverts commit 772fdceea5f148d9bb5fd6c87ffd48f87ca93bab.
Signed-off-by: Florian Schmaus <flow <AT> gentoo.org>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/60pkgconfig | 60 ++++++++++++++++++++++++++++++++++++++
 1 file changed, 60 insertions(+)
diff --git a/bin/install-qa-check.d/60pkgconfig b/bin/install-qa-check.d/60pkgconfig
index c982dbdf4..6ecbcabfd 100644
--- a/bin/install-qa-check.d/60pkgconfig
+++ b/bin/install-qa-check.d/60pkgconfig
@@ -88,6 +88,66 @@ pkgconfig_check() {
 		eqawarn "(contains reference to either lib or lib64 in wrong directory)"
 		eqatag -v pkgconfig.bad-libdir "${bad_libdir[@]}"
 	fi
+
+	# Check for mismatched Version field vs ${PV}
+	# To be safe, let's make sure _all_ installed .pcs have a bad Version
+	# before warning, as this should catch the general cases we're worried
+	# about, while avoiding any pathological cases e.g. multiple libraries
+	# with different versioning within one package.
+	# Example bugs: bug #833895, bug #833887.
+
+	# Default to PV if QA_PKGCONFIG_VERSION is unset.
+	if [[ -z ${QA_PKGCONFIG_VERSION+set} ]]; then
+		local QA_PKGCONFIG_VERSION=${PV}
+	fi
+
+	# Skip the check if QA_PKGCONFIG_VERSION is set to empty string.
+	if [[ -n ${QA_PKGCONFIG_VERSION} ]]; then
+		local pms_ver_re="^([0-9]+(\.[0-9]+)*)([a-z]?)((_(alpha|beta|pre|rc|p)[0-9]*)*)(-r[0-9]+)?$"
+		local -A bad_files
+
+		local is_pms_ver=false
+		if [[ ${QA_PKGCONFIG_VERSION} =~ ${pms_ver_re} ]] ; then
+			# Ensure that ver_test is available.
+			[[ $(type -t ver_test) == function ]] || inherit eapi7-ver
+			is_pms_ver=true
+		fi
+
+		for f in "${files[@]}" ; do
+			local file_version=$(pkg-config --modversion "${f}")
+			if [[ -n ${file_version} ]] ; then
+				if ${is_pms_ver} && [[ ${file_version} =~ ${pms_ver_re} ]]; then
+					# If both versions comply to PMS, then we can use ver_test to compare them.
+					ver_test ${QA_PKGCONFIG_VERSION} -eq ${file_version} && continue
+				else
+					# Otherwise, we resort to string comparision.
+					[[ ${QA_PKGCONFIG_VERSION} == ${file_version} ]] && continue
+				fi
+			else
+				# Record a special value if the .pc file has no version set at all.
+				file_version="<no-set>"
+			fi
+
+			bad_files["${f//${D}}"]="${file_version}"
+		done
+
+		# Skip result reporting if *_p* because for both _pN and _preN, we
+		# don't generally expect the versions to be exactly accurate, and
+		# we want to avoid false positives.
+		if [[ ${#bad_files[@]} -gt 0 && ${PV} != *_p* ]] && ! has live ${PROPERTIES} ; then
+			eqawarn "QA Notice: pkg-config files with mismatched Version found!"
+			eqawarn "The Version field of the following files does not match ${PV}"
+			local bad_file
+			for bad_file in "${!bad_files[@]}"; do
+				local bad_file_version="${bad_files[${bad_file}]}"
+				eqawarn "- ${bad_file}: ${bad_file_version}"
+			done
+			eqawarn "Please check all .pc files installed by this package."
+			eqawarn "You can use QA_PKGCONFIG_VERSION to set the expected version,"
+			eqawarn "or set to the empty string to disable this QA check."
+			eqatag pkgconfig.unexpected-version ${!bad_files[@]}
+		fi
+	fi
 }
 
 pkgconfig_check
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2023-02-17  9:12 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2023-02-17  9:12 UTC (permalink / raw
  To: gentoo-commits
commit:     f0d4e696f82d989371360d7e4d8df6e2ff1f6bd2
Author:     Florian Schmaus <flow <AT> gentoo <DOT> org>
AuthorDate: Mon Aug 15 07:14:14 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Feb 17 09:12:03 2023 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=f0d4e696
install-qa-check.d/60pkgconfig: conditionally source eapi7-ver-funcs.sh
To make ver_test available, source eapi7-ver-funcs.sh instead of
inherting eapi7-ver. This makes the check available for ebuild
repositories that do not have ::gentoo as main repository.
Suggested-by: Arfrever Frehtes Taifersar Arahesis <arfrever <AT> apache.org>
Signed-off-by: Florian Schmaus <flow <AT> gentoo.org>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/60pkgconfig | 7 +++++--
 1 file changed, 5 insertions(+), 2 deletions(-)
diff --git a/bin/install-qa-check.d/60pkgconfig b/bin/install-qa-check.d/60pkgconfig
index 6ecbcabfd..5d5b6d611 100644
--- a/bin/install-qa-check.d/60pkgconfig
+++ b/bin/install-qa-check.d/60pkgconfig
@@ -1,5 +1,10 @@
 # Check for pkg-config file issues
 
+# Ensure that ver_test is available.
+if ! __eapi_has_version_functions; then
+	source "${PORTAGE_BIN_PATH}/eapi7-ver-funcs.sh" || exit 1
+fi
+
 pkgconfig_check() {
 	local files=()
 	# Make a list of .pc files and bail out if there aren't any
@@ -108,8 +113,6 @@ pkgconfig_check() {
 
 		local is_pms_ver=false
 		if [[ ${QA_PKGCONFIG_VERSION} =~ ${pms_ver_re} ]] ; then
-			# Ensure that ver_test is available.
-			[[ $(type -t ver_test) == function ]] || inherit eapi7-ver
 			is_pms_ver=true
 		fi
 
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2022-11-09  2:29 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2022-11-09  2:29 UTC (permalink / raw
  To: gentoo-commits
commit:     4030f0006c83bd7aa7a9c3549b6fe0910458ae62
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Nov  9 02:29:43 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Nov  9 02:29:43 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=4030f000
install-qa-check.d/90gcc-warnings: fix grep warning
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/90gcc-warnings | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/install-qa-check.d/90gcc-warnings b/bin/install-qa-check.d/90gcc-warnings
index 2f6f393a4..b8b5f7147 100644
--- a/bin/install-qa-check.d/90gcc-warnings
+++ b/bin/install-qa-check.d/90gcc-warnings
@@ -20,7 +20,7 @@ gcc_warn_check() {
 			'warning: .*will.*\[-Wstrict-aliasing\]'
 			'warning: .*does.*\[-Wstrict-aliasing\]'
 			# strict aliasing violation in C++ (Clang)
-			'warning: .*\[\-Wundefined-reinterpret-cast\]'
+			'warning: .*\[-Wundefined-reinterpret-cast\]'
 
 			# implicit declaration of function ‘...’
 			'warning: .*\[-Wimplicit-function-declaration\]'
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2022-11-09  2:25 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2022-11-09  2:25 UTC (permalink / raw
  To: gentoo-commits
commit:     40673d0184a695c5f92fd6b8d241db9697b234f4
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Nov  9 02:22:52 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Nov  9 02:25:45 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=40673d01
install-qa-check.d/90gcc-warnings: add -Wincompatible-function-pointer-types
Clang 16 makes this fatal, but we're just going to warn on it here. We
already have -Wincompatible-pointer-types anyway.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/90gcc-warnings | 2 ++
 1 file changed, 2 insertions(+)
diff --git a/bin/install-qa-check.d/90gcc-warnings b/bin/install-qa-check.d/90gcc-warnings
index d8bde18cb..403c19684 100644
--- a/bin/install-qa-check.d/90gcc-warnings
+++ b/bin/install-qa-check.d/90gcc-warnings
@@ -82,6 +82,8 @@ gcc_warn_check() {
 			'warning: .*\[-Waggressive-loop-optimizations\]'
 			# conversion between pointers that have incompatible types
 			'warning: .*\[-Wincompatible-pointer-types\]'
+			# more specific form of -Wincompatible-pointer-types (Clang)
+			'warning: .*\[-Wincompatible-function-pointer-types\]'
 			# using wrong deallocator, e.g. using free() on object allocated using my_malloc()
 			# when my_malloc() is annotated as needing my_free().
 			'warning: .*\[-Wmismatched-dealloc\]'
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2022-11-09  2:25 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2022-11-09  2:25 UTC (permalink / raw
  To: gentoo-commits
commit:     dc6035cdcd66a447a5ffc16b4e028604eafb82bf
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Nov  9 02:22:22 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Nov  9 02:25:45 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=dc6035cd
install-qa-check.d/90gcc-warnings: add -Wundefined-reinterpret-cast
A type of strict aliasing violation which can only happen in C++.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/90gcc-warnings | 2 ++
 1 file changed, 2 insertions(+)
diff --git a/bin/install-qa-check.d/90gcc-warnings b/bin/install-qa-check.d/90gcc-warnings
index 162e97459..d8bde18cb 100644
--- a/bin/install-qa-check.d/90gcc-warnings
+++ b/bin/install-qa-check.d/90gcc-warnings
@@ -19,6 +19,8 @@ gcc_warn_check() {
 			# only will and does, no might :)
 			'warning: .*will.*\[-Wstrict-aliasing\]'
 			'warning: .*does.*\[-Wstrict-aliasing\]'
+			# strict aliasing violation in C++ (Clang)
+			'warning: .*\[\-Wundefined-reinterpret-cast\]'
 
 			# implicit declaration of function ‘...’
 			'warning: .*\[-Wimplicit-function-declaration\]'
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2022-11-09  2:25 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2022-11-09  2:25 UTC (permalink / raw
  To: gentoo-commits
commit:     800337e1d2d5d2d04eb83fe57f519850074b6e66
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Nov  9 02:23:22 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Nov  9 02:25:46 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=800337e1
install-qa-check.d/90gcc-warnings: add -Wargument-undefined-behaviour
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/90gcc-warnings | 2 ++
 1 file changed, 2 insertions(+)
diff --git a/bin/install-qa-check.d/90gcc-warnings b/bin/install-qa-check.d/90gcc-warnings
index 403c19684..2f6f393a4 100644
--- a/bin/install-qa-check.d/90gcc-warnings
+++ b/bin/install-qa-check.d/90gcc-warnings
@@ -94,6 +94,8 @@ gcc_warn_check() {
 			'warning: .*\[-Wlto-type-mismatch\]'
 			# ODR (https://wiki.gentoo.org/wiki/Project:Toolchain/LTO)
 			'warning: .*\[-Wodr\]'
+			# warning: argument value A will result in undefined behaviour (Clang)
+			'warning: .*\[-Wargument-undefined-behaviour\]'
 
 			# this may be valid code :/
 			#': warning: multi-character character constant'
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2022-11-09  2:25 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2022-11-09  2:25 UTC (permalink / raw
  To: gentoo-commits
commit:     4982bec7b9623415fec4dc9d4d7a9696b47a4479
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Nov  9 02:22:06 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Nov  9 02:25:45 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=4982bec7
install-qa-check.d/90gcc-warnings: formatting tweaks
Group similar warnings together.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/90gcc-warnings | 6 ++++++
 1 file changed, 6 insertions(+)
diff --git a/bin/install-qa-check.d/90gcc-warnings b/bin/install-qa-check.d/90gcc-warnings
index 7a859eb88..162e97459 100644
--- a/bin/install-qa-check.d/90gcc-warnings
+++ b/bin/install-qa-check.d/90gcc-warnings
@@ -19,18 +19,21 @@ gcc_warn_check() {
 			# only will and does, no might :)
 			'warning: .*will.*\[-Wstrict-aliasing\]'
 			'warning: .*does.*\[-Wstrict-aliasing\]'
+
 			# implicit declaration of function ‘...’
 			'warning: .*\[-Wimplicit-function-declaration\]'
 			# with -Wall, goes in pair with -Wimplicit-function-declaration
 			# but without -Wall, we need to assert for it alone
 			'warning: .*incompatible implicit declaration of built-in function'
 			'warning: .*\[-Wbuiltin-declaration-mismatch\]'
+
 			# 'is used uninitialized in this function' and some more
 			'warning: .*\[-Wuninitialized\]'
 			# comparisons like ‘X<=Y<=Z’ do not have their mathematical meaning
 			'warning: .*mathematical meaning*\[-Wparentheses\]'
 			# null argument where non-null required
 			'warning: .*\[-Wnonnull\]'
+
 			# array subscript is above/below/outside array bounds (FORTIFY_SOURCE)
 			'warning: .*\[-Warray-bounds\]'
 			# attempt to free a non-heap object
@@ -43,6 +46,7 @@ gcc_warn_check() {
 			'warning: .*\[-Wfortify-source\]'
 			'warning: .*assuming pointer wraparound does not occur'
 			'warning: .*escape sequence out of range'
+
 			# left-hand operand of comma expression has no effect
 			'warning: .*left.*comma.*\[-Wunused-value\]'
 			# converting to non-pointer type ... from NULL and likes
@@ -58,11 +62,13 @@ gcc_warn_check() {
 			'warning: .*\[-Wint-conversion\]'
 			# warning: cast to ... from integer of different size (or smaller size)
 			'warning: .*\[-Wint-to-pointer-cast\]'
+
 			# outdated?
 			'warning: .*too few arguments for format'
 			# format ... expects a matching ... argument
 			# (iow, too few arguments for format in new wording :))
 			'warning: .*matching.*\[-Wformat=\]'
+
 			# function returns address of local variable
 			'warning: .*\[-Wreturn-local-addr\]'
 			# missing return at end of function, or non-void return in a void function
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2022-11-09  2:25 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2022-11-09  2:25 UTC (permalink / raw
  To: gentoo-commits
commit:     a38aa2108f996c834e8ca2f10fb151a111c782dc
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Nov  9 02:12:32 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Nov  9 02:25:45 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=a38aa210
install-qa-check.d/90gcc-warnings: add -Wint-conversion, -Wint-to-pointer-cast
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/90gcc-warnings | 4 ++++
 1 file changed, 4 insertions(+)
diff --git a/bin/install-qa-check.d/90gcc-warnings b/bin/install-qa-check.d/90gcc-warnings
index cd12558ba..7a859eb88 100644
--- a/bin/install-qa-check.d/90gcc-warnings
+++ b/bin/install-qa-check.d/90gcc-warnings
@@ -54,6 +54,10 @@ gcc_warn_check() {
 			# the address of ... will never be NULL and likes
 			# (uses of function refs & string constants in conditionals)
 			'warning: .*\[-Waddress\]'
+			# warning: assignment/initialization to ... from ... makes integer from pointer without cast
+			'warning: .*\[-Wint-conversion\]'
+			# warning: cast to ... from integer of different size (or smaller size)
+			'warning: .*\[-Wint-to-pointer-cast\]'
 			# outdated?
 			'warning: .*too few arguments for format'
 			# format ... expects a matching ... argument
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2022-11-08 23:51 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2022-11-08 23:51 UTC (permalink / raw
  To: gentoo-commits
commit:     1619bda983a731961b17504e2a48e44d4849d2cc
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Nov  8 23:51:35 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Nov  8 23:51:35 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=1619bda9
install-qa-check.d/90gcc-warnings: improve -Warray-bounds comment
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/90gcc-warnings | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/install-qa-check.d/90gcc-warnings b/bin/install-qa-check.d/90gcc-warnings
index 579cb4135..f5dae8a76 100644
--- a/bin/install-qa-check.d/90gcc-warnings
+++ b/bin/install-qa-check.d/90gcc-warnings
@@ -31,7 +31,7 @@ gcc_warn_check() {
 			'warning: .*mathematical meaning*\[-Wparentheses\]'
 			# null argument where non-null required
 			'warning: .*\[-Wnonnull\]'
-			# array subscript is above/below/outside array bounds
+			# array subscript is above/below/outside array bounds (FORTIFY_SOURCE)
 			'warning: .*\[-Warray-bounds\]'
 			# attempt to free a non-heap object
 			'warning: .*\[-Wfree-nonheap-object\]'
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2022-10-27 23:37 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2022-10-27 23:37 UTC (permalink / raw
  To: gentoo-commits
commit:     eaf2868e99280cb6c57df528f63f98c6b4757ef6
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Oct 27 23:37:43 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Oct 27 23:37:43 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=eaf2868e
install-qa-check.d/90gcc-warnings: add -Wbuiltin-declaration-mismatch
Closely related to -Wimplicit-function-declaration. It's a mistake
to do this anyway, but it's particularly bad if it then inhibits
further compiler diagnostics.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/90gcc-warnings | 1 +
 1 file changed, 1 insertion(+)
diff --git a/bin/install-qa-check.d/90gcc-warnings b/bin/install-qa-check.d/90gcc-warnings
index 7a506d357..256e6918b 100644
--- a/bin/install-qa-check.d/90gcc-warnings
+++ b/bin/install-qa-check.d/90gcc-warnings
@@ -24,6 +24,7 @@ gcc_warn_check() {
 			# with -Wall, goes in pair with -Wimplicit-function-declaration
 			# but without -Wall, we need to assert for it alone
 			'warning: .*incompatible implicit declaration of built-in function'
+			'warning: .*\[-Wbuiltin-declaration-mismatch\]'
 			# 'is used uninitialized in this function' and some more
 			'warning: .*\[-Wuninitialized\]'
 			# comparisons like ‘X<=Y<=Z’ do not have their mathematical meaning
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2022-10-27 23:37 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2022-10-27 23:37 UTC (permalink / raw
  To: gentoo-commits
commit:     ebea8fa53bdd871deb841463f5fbd4f427b6ef3c
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Oct 27 23:37:42 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Oct 27 23:37:42 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=ebea8fa5
install-qa-check.d/90gcc-warnings: add -Wreturn-type
Clang in particular optimises very aggressively based
on this (if there's a missing return at the end, it'll end
up performing mental gymnastics to deduce some other earlier
case is taken).
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/90gcc-warnings | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/bin/install-qa-check.d/90gcc-warnings b/bin/install-qa-check.d/90gcc-warnings
index 662d2fd3a..7a506d357 100644
--- a/bin/install-qa-check.d/90gcc-warnings
+++ b/bin/install-qa-check.d/90gcc-warnings
@@ -56,6 +56,9 @@ gcc_warn_check() {
 			'warning: .*matching.*\[-Wformat=\]'
 			# function returns address of local variable
 			'warning: .*\[-Wreturn-local-addr\]'
+			# missing return at end of function, or non-void return in a void function
+			# (clang at least aggressively optimises on this)
+			'warning: .*\[-Wreturn-type\]'
 			# argument to sizeof ... is the same expression as the source
 			'warning: .*\[-Wsizeof-pointer-memaccess\]'
 			# iteration invokes undefined behavior
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2022-10-27 23:37 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2022-10-27 23:37 UTC (permalink / raw
  To: gentoo-commits
commit:     de8d2c8de7d456a15f83551bfc3fcf6ff1fffaf1
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Oct 27 23:37:43 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Oct 27 23:37:43 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=de8d2c8d
install-qa-check.d/90gcc-warnings: add -Wmismatched-dealloc
These could easily lead to UAFs / out of bound access if the
malloc used is oversized (e.g. using my_free() on something
allocated by malloc(), with my_free() assuming existence
of some extra data from my_malloc()).
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/90gcc-warnings | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/bin/install-qa-check.d/90gcc-warnings b/bin/install-qa-check.d/90gcc-warnings
index 256e6918b..3a57c0a3b 100644
--- a/bin/install-qa-check.d/90gcc-warnings
+++ b/bin/install-qa-check.d/90gcc-warnings
@@ -66,6 +66,9 @@ gcc_warn_check() {
 			'warning: .*\[-Waggressive-loop-optimizations\]'
 			# conversion between pointers that have incompatible types
 			'warning: .*\[-Wincompatible-pointer-types\]'
+			# using wrong deallocator, e.g. using free() on object allocated using my_malloc()
+			# when my_malloc() is annotated as needing my_free().
+			'warning: .*\[-Wmismatched-dealloc\]'
 			# clobbered: Warn for variables that might be changed by longjmp or vfork
 			# (This warning is also enabled by -Wextra.)
 			'warning: .*\[-Wclobbered\]'
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2022-10-11 19:18 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2022-10-11 19:18 UTC (permalink / raw
  To: gentoo-commits
commit:     aa5f84544096f3ffa5fad307768537ca34e8193e
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Oct 10 19:42:00 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Oct 11 19:18:36 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=aa5f8454
install-qa-check.d/90gcc-warnings: add more LTO warnings (-Wodr, -Wlto-type-mismatch)
Bug: https://bugs.gentoo.org/618550
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/90gcc-warnings | 4 ++++
 1 file changed, 4 insertions(+)
diff --git a/bin/install-qa-check.d/90gcc-warnings b/bin/install-qa-check.d/90gcc-warnings
index d118ce958..6014f6be9 100644
--- a/bin/install-qa-check.d/90gcc-warnings
+++ b/bin/install-qa-check.d/90gcc-warnings
@@ -63,6 +63,10 @@ gcc_warn_check() {
 			# clobbered: Warn for variables that might be changed by longjmp or vfork
 			# (This warning is also enabled by -Wextra.)
 			'warning: .*\[-Wclobbered\]'
+			# LTO type mismatch (https://wiki.gentoo.org/wiki/Project:Toolchain/LTO)
+			'warning: .*\[-Wlto-type-mismatch\]'
+			# ODR (https://wiki.gentoo.org/wiki/Project:Toolchain/LTO)
+			'warning: .*\[-Wodr\]'
 
 			# this may be valid code :/
 			#': warning: multi-character character constant'
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2022-10-11 19:18 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2022-10-11 19:18 UTC (permalink / raw
  To: gentoo-commits
commit:     8dc1ff9cc9eea96cd953b73c74e621d1d4c29efa
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Oct 10 19:42:39 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Oct 11 19:18:36 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=8dc1ff9c
install-qa-check.d/90gcc-warnings: add Clang TODO
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/90gcc-warnings | 3 ++-
 1 file changed, 2 insertions(+), 1 deletion(-)
diff --git a/bin/install-qa-check.d/90gcc-warnings b/bin/install-qa-check.d/90gcc-warnings
index 6014f6be9..7c4b1f8e3 100644
--- a/bin/install-qa-check.d/90gcc-warnings
+++ b/bin/install-qa-check.d/90gcc-warnings
@@ -1,4 +1,5 @@
-# Check for important gcc warning
+# Check for important gcc warnings
+# TODO: adapt for clang?
 
 gcc_warn_check() {
 	local f
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2022-10-11 19:18 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2022-10-11 19:18 UTC (permalink / raw
  To: gentoo-commits
commit:     a6675b40d06142f43f2592ed09b5c2bfa433c5c2
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Oct 10 19:47:12 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Oct 11 19:18:36 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=a6675b40
install-qa-check.d/90gcc-warnings: add TODO for -Wformat-security
Signed-off-by: Sam James <sam <AT> gentoo.org>
Closes: https://github.com/gentoo/portage/pull/923
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/90gcc-warnings | 1 +
 1 file changed, 1 insertion(+)
diff --git a/bin/install-qa-check.d/90gcc-warnings b/bin/install-qa-check.d/90gcc-warnings
index 7c4b1f8e3..662d2fd3a 100644
--- a/bin/install-qa-check.d/90gcc-warnings
+++ b/bin/install-qa-check.d/90gcc-warnings
@@ -1,5 +1,6 @@
 # Check for important gcc warnings
 # TODO: adapt for clang?
+# TODO: add -Wformat-security
 
 gcc_warn_check() {
 	local f
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2022-08-19  0:09 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2022-08-19  0:09 UTC (permalink / raw
  To: gentoo-commits
commit:     87deddd57a3259875d524138aeadd297d7b660c7
Author:     genBTC <genBTC <AT> gmx <DOT> com>
AuthorDate: Sun May 22 22:04:11 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Aug 19 00:07:34 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=87deddd5
install-qa-check.d/90gcc-warnings: add -Wincompatible-pointer-types, -Wclobbered
They appear rarely enough that the additional noise should not be too much of a concern for QA,
but of enough importance that it should be investigated and dealt with.
Only a couple (~2) packages were flagged during inspecting my past build logs to test this commit.
Closes: https://github.com/gentoo/portage/pull/833
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/90gcc-warnings | 5 +++++
 1 file changed, 5 insertions(+)
diff --git a/bin/install-qa-check.d/90gcc-warnings b/bin/install-qa-check.d/90gcc-warnings
index 52124427d..d118ce958 100644
--- a/bin/install-qa-check.d/90gcc-warnings
+++ b/bin/install-qa-check.d/90gcc-warnings
@@ -58,6 +58,11 @@ gcc_warn_check() {
 			'warning: .*\[-Wsizeof-pointer-memaccess\]'
 			# iteration invokes undefined behavior
 			'warning: .*\[-Waggressive-loop-optimizations\]'
+			# conversion between pointers that have incompatible types
+			'warning: .*\[-Wincompatible-pointer-types\]'
+			# clobbered: Warn for variables that might be changed by longjmp or vfork
+			# (This warning is also enabled by -Wextra.)
+			'warning: .*\[-Wclobbered\]'
 
 			# this may be valid code :/
 			#': warning: multi-character character constant'
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2022-08-14 20:43 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2022-08-14 20:43 UTC (permalink / raw
  To: gentoo-commits
commit:     32657fd62a4ab7616c28ea85cfaafb66695d7ab6
Author:     Florian Schmaus <flow <AT> gentoo <DOT> org>
AuthorDate: Sun Aug 14 18:46:52 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Aug 14 20:43:37 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=32657fd6
install-qa-check.d/60pkgconfig: fix ver_test type check
Somehow, this ended up using the wrong argument to bash's 'type'
builtin. :/ It must be '-t', which prints the type of the queried
name.
Fixes: f46b89282ff5 ("install-qa-check.d/60pkgconfig: use ver_test to compare versions")
Signed-off-by: Florian Schmaus <flow <AT> gentoo.org>
Closes: https://github.com/gentoo/portage/pull/887
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/60pkgconfig | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/install-qa-check.d/60pkgconfig b/bin/install-qa-check.d/60pkgconfig
index e275e1ee2..20acaa7fb 100644
--- a/bin/install-qa-check.d/60pkgconfig
+++ b/bin/install-qa-check.d/60pkgconfig
@@ -109,7 +109,7 @@ pkgconfig_check() {
 		local is_pms_ver=false
 		if [[ ${QA_PKGCONFIG_VERSION} =~ ${pms_ver_re} ]] ; then
 			# Ensure that ver_test is available.
-			[[ $(type -f ver_test) == function ]] || inherit eapi7-ver
+			[[ $(type -t ver_test) == function ]] || inherit eapi7-ver
 			is_pms_ver=true
 		fi
 
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2022-08-13 17:30 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2022-08-13 17:30 UTC (permalink / raw
  To: gentoo-commits
commit:     f46b89282ff58974bedb6ed29c83cfeab1e5ad4f
Author:     Florian Schmaus <flow <AT> gentoo <DOT> org>
AuthorDate: Mon Aug  1 07:54:22 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Aug 13 17:30:25 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=f46b8928
install-qa-check.d/60pkgconfig: use ver_test to compare versions
Motivied by Matthew's question if the version comparision could be
improved so that, e.g., 25.0 and 25.0.0 are treated as equal.
Note that using ver_test requires that we check the arguments passed
to ver_test conform to PMS version strings. If this is not the case,
then we fall back to the previous behavior and perform a string
comparision.
Thanks-to: Matthew Smith <matthew <AT> gentoo.org>
Signed-off-by: Florian Schmaus <flow <AT> gentoo.org>
Closes: https://github.com/gentoo/portage/pull/882
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/60pkgconfig | 30 +++++++++++++++++++++---------
 1 file changed, 21 insertions(+), 9 deletions(-)
diff --git a/bin/install-qa-check.d/60pkgconfig b/bin/install-qa-check.d/60pkgconfig
index a8e0aa5db..e275e1ee2 100644
--- a/bin/install-qa-check.d/60pkgconfig
+++ b/bin/install-qa-check.d/60pkgconfig
@@ -103,26 +103,38 @@ pkgconfig_check() {
 
 	# Skip the check if QA_PKGCONFIG_VERSION is set to empty string.
 	if [[ -n ${QA_PKGCONFIG_VERSION} ]]; then
-		local all_bad=yes
+		local pms_ver_re="^([0-9]+(\.[0-9]+)*)([a-z]?)((_(alpha|beta|pre|rc|p)[0-9]*)*)(-r[0-9]+)?$"
 		local -A bad_files
+
+		local is_pms_ver=false
+		if [[ ${QA_PKGCONFIG_VERSION} =~ ${pms_ver_re} ]] ; then
+			# Ensure that ver_test is available.
+			[[ $(type -f ver_test) == function ]] || inherit eapi7-ver
+			is_pms_ver=true
+		fi
+
 		for f in "${files[@]}" ; do
 			local file_version=$(pkg-config --modversion "${f}")
-			if [[ ${QA_PKGCONFIG_VERSION} == ${file_version} ]] ; then
-				all_bad=no
-				break
-			fi
-
-			# Record a special value if the .pc file has no version set at all.
-			if [[ -z ${file_version} ]] ; then
+			if [[ -n ${file_version} ]] ; then
+				if ${is_pms_ver} && [[ ${file_version} =~ ${pms_ver_re} ]]; then
+					# If both versions comply to PMS, then we can use ver_test to compare them.
+					ver_test ${QA_PKGCONFIG_VERSION} -eq ${file_version} && continue
+				else
+					# Otherwise, we resort to string comparision.
+					[[ ${QA_PKGCONFIG_VERSION} == ${file_version} ]] && continue
+				fi
+			else
+				# Record a special value if the .pc file has no version set at all.
 				file_version="<no-set>"
 			fi
+
 			bad_files["${f//${D}}"]="${file_version}"
 		done
 
 		# Skip result reporting if *_p* because for both _pN and _preN, we
 		# don't generally expect the versions to be exactly accurate, and
 		# we want to avoid false positives.
-		if [[ ${all_bad} == "yes" && ${PV} != *_p* ]] && ! has live ${PROPERTIES} ; then
+		if [[ ${#bad_files[@]} -gt 0 && ${PV} != *_p* ]] && ! has live ${PROPERTIES} ; then
 			eqawarn "QA Notice: pkg-config files with mismatched Version found!"
 			eqawarn "The Version field of the following files does not match ${PV}"
 			local bad_file
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2022-08-10  4:36 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2022-08-10  4:36 UTC (permalink / raw
  To: gentoo-commits
commit:     4be2288e5e34cbcf59e92d5ad2d3763a1475a09d
Author:     Florian Schmaus <flow <AT> gentoo <DOT> org>
AuthorDate: Sat Jul 30 08:49:06 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Aug 10 04:36:46 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=4be2288e
install-qa-check.d/60pkgconfig: improve pkg-config version check
Make the pkg-config .pc-file version check display the actual found
version and hint towards the QA_PKGCONFIG_VERSION variable.
Signed-off-by: Florian Schmaus <flow <AT> gentoo.org>
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/60pkgconfig | 21 ++++++++++++++++-----
 1 file changed, 16 insertions(+), 5 deletions(-)
diff --git a/bin/install-qa-check.d/60pkgconfig b/bin/install-qa-check.d/60pkgconfig
index 54122fe61..e95746505 100644
--- a/bin/install-qa-check.d/60pkgconfig
+++ b/bin/install-qa-check.d/60pkgconfig
@@ -104,15 +104,19 @@ pkgconfig_check() {
 	# Skip the check if QA_PKGCONFIG_VERSION is set to empty string.
 	if [[ -n ${QA_PKGCONFIG_VERSION} ]]; then
 		local all_bad=yes
-		# Record the last bad file matched
-		local bad_file
+		local -A bad_files
 		for f in "${files[@]}" ; do
-			if [[ ${QA_PKGCONFIG_VERSION} == $(pkg-config --modversion "${f}") ]] ; then
+			local file_version=$(pkg-config --modversion "${f}")
+			if [[ ${QA_PKGCONFIG_VERSION} == ${file_version} ]] ; then
 				all_bad=no
 				break
 			fi
 
-			bad_file="${f//${D}}"
+			# Record a special value if the .pc file has no version set at all.
+			if [[ -z ${file_version} ]] ; then
+				file_version="<no-set>"
+			fi
+			bad_files["${f//${D}}"]="${file_version}"
 		done
 
 		# Skip result reporting if *_p* because for both _pN and _preN, we
@@ -120,8 +124,15 @@ pkgconfig_check() {
 		# we want to avoid false positives.
 		if [[ ${all_bad} == "yes" && ${PV} != *_p* ]] && ! has live ${PROPERTIES} ; then
 			eqawarn "QA Notice: pkg-config files with mismatched Version found!"
-			eqawarn "At least ${bad_file}'s Version field does not match ${PV}"
+			eqawarn "The Version field of the following files does not match ${PV}"
+			local bad_file
+			for bad_file in "${!bad_files[@]}"; do
+				local bad_file_version="${bad_files[${bad_file}]}"
+				eqawarn "- ${bad_file}: ${bad_file_version}"
+			done
 			eqawarn "Please check all .pc files installed by this package."
+			eqawarn "You can use QA_PKGCONFIG_VERSION to set the expected version,"
+			eqawarn "or set to the empty string to disable this QA check."
 		fi
 	fi
 }
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2022-08-10  4:36 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2022-08-10  4:36 UTC (permalink / raw
  To: gentoo-commits
commit:     4dd66128f1b09cbe033e6eaf4d9ba7f8da274a65
Author:     Florian Schmaus <flow <AT> gentoo <DOT> org>
AuthorDate: Mon Aug  1 07:53:44 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Wed Aug 10 04:36:46 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=4dd66128
install-qa-check.d/60pkgconfig: use "eqatag pkgconfig.unexpected-version"
Suggested-by: Sam James <sam <AT> gentoo.org>
Signed-off-by: Florian Schmaus <flow <AT> gentoo.org>
Closes: https://github.com/gentoo/portage/pull/875
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/60pkgconfig | 1 +
 1 file changed, 1 insertion(+)
diff --git a/bin/install-qa-check.d/60pkgconfig b/bin/install-qa-check.d/60pkgconfig
index e95746505..a8e0aa5db 100644
--- a/bin/install-qa-check.d/60pkgconfig
+++ b/bin/install-qa-check.d/60pkgconfig
@@ -133,6 +133,7 @@ pkgconfig_check() {
 			eqawarn "Please check all .pc files installed by this package."
 			eqawarn "You can use QA_PKGCONFIG_VERSION to set the expected version,"
 			eqawarn "or set to the empty string to disable this QA check."
+			eqatag pkgconfig.unexpected-version ${!bad_files[@]}
 		fi
 	fi
 }
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2022-08-01 22:39 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2022-08-01 22:39 UTC (permalink / raw
  To: gentoo-commits
commit:     cf16daf828e73ba5c37cd87086bfdc43eea23dd2
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Jul 28 02:56:20 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Aug  1 22:38:11 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=cf16daf8
install-qa-checks.d: fix 90gcc-warnings for other 64-bit arches
We were missing:
- aarch64*
- arm64* (Apple uses this for arm64)
- loongarch64*
- riscv64*
- s390x*
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/90gcc-warnings | 19 ++++++++++---------
 1 file changed, 10 insertions(+), 9 deletions(-)
diff --git a/bin/install-qa-check.d/90gcc-warnings b/bin/install-qa-check.d/90gcc-warnings
index 041e39c8b..52124427d 100644
--- a/bin/install-qa-check.d/90gcc-warnings
+++ b/bin/install-qa-check.d/90gcc-warnings
@@ -113,25 +113,26 @@ gcc_warn_check() {
 		fi
 
 		local cat_cmd=cat
-		[[ $PORTAGE_LOG_FILE = *.gz ]] && cat_cmd=zcat
-		[[ $reset_debug = 1 ]] && set -x
+		[[ ${PORTAGE_LOG_FILE} = *.gz ]] && cat_cmd=zcat
+		[[ ${reset_debug} = 1 ]] && set -x
+
 		# Use safe cwd, avoiding unsafe import for bug #469338.
-		f=$(cd "${PORTAGE_PYM_PATH}" ; $cat_cmd "${PORTAGE_LOG_FILE}" | \
-			"${PORTAGE_PYTHON:-/usr/bin/python}" "$PORTAGE_BIN_PATH"/check-implicit-pointer-usage.py || die "check-implicit-pointer-usage.py failed")
-		if [[ -n ${f} ]] ; then
+		f=$(cd "${PORTAGE_PYM_PATH}" ; ${cat_cmd} "${PORTAGE_LOG_FILE}" | \
+			"${PORTAGE_PYTHON:-/usr/bin/python}" "${PORTAGE_BIN_PATH}"/check-implicit-pointer-usage.py || die "check-implicit-pointer-usage.py failed")
 
+		if [[ -n ${f} ]] ; then
 			# In the future this will be a forced "die". In preparation,
 			# increase the log level from "qa" to "eerror" so that people
-			# are aware this is a problem that must be fixed asap.
+			# are aware this is a problem that must be fixed ASAP.
 
-			# just warn on 32bit hosts but bail on 64bit hosts
+			# Just warn on 32bit hosts but bail on 64bit hosts
 			case ${CHOST} in
-				alpha*|hppa64*|ia64*|powerpc64*|mips64*|sparc64*|sparcv9*|x86_64*) gentoo_bug=yes ;;
+				alpha*|aarch64*|arm64*|hppa64*|ia64*|powerpc64*|loongarch64*|mips64*|riscv64*|sparc64*|sparcv9*|s390x*|x86_64*) gentoo_bug=yes ;;
 			esac
 
 			abort=yes
 
-			if [[ $gentoo_bug = yes ]] ; then
+			if [[ ${gentoo_bug} = yes ]] ; then
 				eerror
 				eerror "QA Notice: Package triggers severe warnings which indicate that it"
 				eerror "           will almost certainly crash on 64bit architectures."
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2022-08-01 22:39 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2022-08-01 22:39 UTC (permalink / raw
  To: gentoo-commits
commit:     06af67ad303d2f0d8a82c4d6cd4c594d7694689b
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Aug  1 02:41:09 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Aug  1 22:37:51 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=06af67ad
install-qa-check.d: 60pkgconfig: only verify defined variables in EPREFIX check
e.g. 'exec_prefix' might not even appear in the pkg-config file.
Bug: https://bugs.gentoo.org/860825
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/60pkgconfig | 3 +++
 1 file changed, 3 insertions(+)
diff --git a/bin/install-qa-check.d/60pkgconfig b/bin/install-qa-check.d/60pkgconfig
index d4ba42f5b..6f1d6b8b1 100644
--- a/bin/install-qa-check.d/60pkgconfig
+++ b/bin/install-qa-check.d/60pkgconfig
@@ -38,6 +38,9 @@ pkgconfig_check() {
 		for f in "${files[@]}" ; do
 			local key
 			for key in prefix exec_prefix libdir includedir ; do
+				# Check if the variable is even in there (bug #860825)
+				grep -E -q "^${key}" "${f}" || continue
+
 				local value=$(pkg-config --variable="${key}" "${f}")
 
 				if [[ ${value} != "${EPREFIX}"* ]] ; then
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2022-08-01 22:39 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2022-08-01 22:39 UTC (permalink / raw
  To: gentoo-commits
commit:     4f7f71fe7fca2744954d0092c3095221905f7e04
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Mon Aug  1 02:47:56 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Mon Aug  1 22:37:51 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=4f7f71fe
install-qa-check.d: 60pkgconfig: add ${ED}/usr/{lib*,share}/pkgconfig to search path
Needed for --validate to not barf sometimes.
Signed-off-by: Sam James <sam <AT> gentoo.org>
Closes: https://github.com/gentoo/portage/pull/880
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/60pkgconfig | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/install-qa-check.d/60pkgconfig b/bin/install-qa-check.d/60pkgconfig
index 6f1d6b8b1..54122fe61 100644
--- a/bin/install-qa-check.d/60pkgconfig
+++ b/bin/install-qa-check.d/60pkgconfig
@@ -27,7 +27,7 @@ pkgconfig_check() {
 	# seems like f.d.o, OpenBSD, and of course pkgconf do though.
 	# Need --maximum-traverse-depth=1 to avoid checking deps and giving
 	# unrelated warnings/errors.
-	if ! pkg-config --maximum-traverse-depth=1 --validate "${files[@]}" ; then
+	if ! pkg-config --maximum-traverse-depth=1 --with-path="${ED}"/usr/{lib*,share}/pkgconfig --validate "${files[@]}" ; then
 		eqawarn "QA Notice: pkg-config files which fail validation found!"
 		eqawarn "Run 'pkg-config --validate ...' for more information"
 	fi
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2022-07-28  6:32 Fabian Groffen
  0 siblings, 0 replies; 120+ messages in thread
From: Fabian Groffen @ 2022-07-28  6:32 UTC (permalink / raw
  To: gentoo-commits
commit:     7e39ed552544e6551c00f4a6231898d3f53c2204
Author:     Fabian Groffen <grobian <AT> gentoo <DOT> org>
AuthorDate: Tue Jul 26 18:46:38 2022 +0000
Commit:     Fabian Groffen <grobian <AT> gentoo <DOT> org>
CommitDate: Thu Jul 28 06:32:01 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=7e39ed55
bin/install-qa-check.d/80multilib-strict: use file/find from Prefix
Signed-off-by: Fabian Groffen <grobian <AT> gentoo.org>
 bin/install-qa-check.d/80multilib-strict | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/install-qa-check.d/80multilib-strict b/bin/install-qa-check.d/80multilib-strict
index afd223250..42e5f1ca6 100644
--- a/bin/install-qa-check.d/80multilib-strict
+++ b/bin/install-qa-check.d/80multilib-strict
@@ -1,7 +1,7 @@
 # Strict multilib directory checks
 multilib_strict_check() {
 	if has multilib-strict ${FEATURES} && \
-	   [[ -x /usr/bin/file && -x /usr/bin/find ]] && \
+	   type find &>/dev/null && type file &>/dev/null && \
 	   [[ -n ${MULTILIB_STRICT_DIRS} && -n ${MULTILIB_STRICT_DENY} ]]
 	then
 		rm -f "${T}/multilib-strict.log"
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2022-07-27  8:18 Fabian Groffen
  0 siblings, 0 replies; 120+ messages in thread
From: Fabian Groffen @ 2022-07-27  8:18 UTC (permalink / raw
  To: gentoo-commits
commit:     54080c141fd2ee6fdb6827b95e5a21d72b0c82a1
Author:     Fabian Groffen <grobian <AT> gentoo <DOT> org>
AuthorDate: Tue Jul 26 18:49:25 2022 +0000
Commit:     Fabian Groffen <grobian <AT> gentoo <DOT> org>
CommitDate: Wed Jul 27 08:16:21 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=54080c14
bin/install-qa-check.d/90world-writable: include EPREFIX in reports
It is much less confusing and consistent to report full paths including
the leading EPREFIX.
Signed-off-by: Fabian Groffen <grobian <AT> gentoo.org>
 bin/install-qa-check.d/90world-writable | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/install-qa-check.d/90world-writable b/bin/install-qa-check.d/90world-writable
index 820683bd6..c69c43444 100644
--- a/bin/install-qa-check.d/90world-writable
+++ b/bin/install-qa-check.d/90world-writable
@@ -2,7 +2,7 @@
 
 world_writable_check() {
 	# Now we look for all world writable files.
-	local unsafe_files=$(find "${ED}" -type f -perm -2 | sed -e "s:^${ED}:/:")
+	local unsafe_files=$(find "${ED}" -type f -perm -2 | sed -e "s:^${D}:/:")
 	local OLDIFS x prev_shopts=$-
 
 	OLDIFS=$IFS
@@ -19,7 +19,7 @@ world_writable_check() {
 		eqawarn
 	fi
 
-	local unsafe_files=$(find "${ED}" -type f '(' -perm -2002 -o -perm -4002 ')' | sed -e "s:^${ED}:/:")
+	local unsafe_files=$(find "${ED}" -type f '(' -perm -2002 -o -perm -4002 ')' | sed -e "s:^${D}:/:")
 	if [[ -n ${unsafe_files} ]] ; then
 		eqawarn "QA Notice: Unsafe files detected (set*id and world writable)"
 
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2022-07-27  8:18 Fabian Groffen
  0 siblings, 0 replies; 120+ messages in thread
From: Fabian Groffen @ 2022-07-27  8:18 UTC (permalink / raw
  To: gentoo-commits
commit:     eb382e8b07e20ef7b9b8d287ca5c3946a5c3c0c5
Author:     Fabian Groffen <grobian <AT> gentoo <DOT> org>
AuthorDate: Tue Jul 26 18:41:41 2022 +0000
Commit:     Fabian Groffen <grobian <AT> gentoo <DOT> org>
CommitDate: Wed Jul 27 08:17:46 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=eb382e8b
bin/install-qa-check.d/80libraries: support Darwin/Mach-O objects
Check for dylib on Darwin, so on everything else.
Signed-off-by: Fabian Groffen <grobian <AT> gentoo.org>
 bin/install-qa-check.d/80libraries | 6 +++++-
 1 file changed, 5 insertions(+), 1 deletion(-)
diff --git a/bin/install-qa-check.d/80libraries b/bin/install-qa-check.d/80libraries
index 8dc35bb87..81c926982 100644
--- a/bin/install-qa-check.d/80libraries
+++ b/bin/install-qa-check.d/80libraries
@@ -140,7 +140,11 @@ lib_check() {
 	local abort="no"
 	local a s
 	for a in "${ED%/}"/usr/lib*/*.a ; do
-		s=${a%.a}.so
+		if [[ ${CHOST} == *-darwin* ]] ; then
+			s=${a%.a}.dylib
+		else
+			s=${a%.a}.so
+		fi
 		if [[ ! -e ${s} ]] ; then
 			s=${s%usr/*}${s##*/usr/}
 			if [[ -e ${s} ]] ; then
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2022-05-15  1:02 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2022-05-15  1:02 UTC (permalink / raw
  To: gentoo-commits
commit:     e810fb4cf1af6b7fe7d00ea7b73e99e917d83fc0
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun May 15 01:01:42 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun May 15 01:02:44 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=e810fb4c
bin/install-qa-check.d/60pkgconfig: egrep -> grep -E
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/60pkgconfig | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/install-qa-check.d/60pkgconfig b/bin/install-qa-check.d/60pkgconfig
index 25143275f..d4ba42f5b 100644
--- a/bin/install-qa-check.d/60pkgconfig
+++ b/bin/install-qa-check.d/60pkgconfig
@@ -11,7 +11,7 @@ pkgconfig_check() {
 	local f
 
 	# Look for leaking LDFLAGS into pkg-config files
-	f=$(egrep -zsH '^Libs.*-Wl,(-O[012]|--hash-style)' "${files[@]}")
+	f=$(grep -E -zsH '^Libs.*-Wl,(-O[012]|--hash-style)' "${files[@]}")
 	if [[ -n ${f} ]] ; then
 		eqawarn "QA Notice: pkg-config files with wrong LDFLAGS detected:"
 		eqatag -v pkgconfig.bad-ldlags "${f//${D}}"
@@ -69,7 +69,7 @@ pkgconfig_check() {
 			fi
 
 			# In ${ED}/usr/lib, we shouldn't reference lib64
-			if egrep -q "=(/usr)?/lib64" ${f} ; then
+			if grep -E -q "=(/usr)?/lib64" ${f} ; then
 				bad_libdir+=( "${f//${D}}" )
 			fi
 		elif [[ ${f} == *lib64/pkgconfig* ]] ; then
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2022-05-15  1:02 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2022-05-15  1:02 UTC (permalink / raw
  To: gentoo-commits
commit:     591e7e12009ce6599d2684dfde5eece236fdcdfb
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat May  7 05:56:02 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun May 15 01:02:43 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=591e7e12
bin/install-qa-check.d/05prefix: egrep -> grep -E
Newer greps will warn on this.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/05prefix | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/install-qa-check.d/05prefix b/bin/install-qa-check.d/05prefix
index e1fc2bd99..c1a5606d8 100644
--- a/bin/install-qa-check.d/05prefix
+++ b/bin/install-qa-check.d/05prefix
@@ -20,7 +20,7 @@ install_qa_check_prefix() {
 	fi
 
 	if [[ -d ${D} ]] ; then
-		INSTALLTOD=$(find ${D%/} | egrep -v "^${ED}" | sed -e "s|^${D%/}||" | awk '{if (length($0) <= length("'"${EPREFIX}"'")) { if (substr("'"${EPREFIX}"'", 1, length($0)) != $0) {print $0;} } else if (substr($0, 1, length("'"${EPREFIX}"'")) != "'"${EPREFIX}"'") {print $0;} }')
+		INSTALLTOD=$(find ${D%/} | grep -E -v "^${ED}" | sed -e "s|^${D%/}||" | awk '{if (length($0) <= length("'"${EPREFIX}"'")) { if (substr("'"${EPREFIX}"'", 1, length($0)) != $0) {print $0;} } else if (substr($0, 1, length("'"${EPREFIX}"'")) != "'"${EPREFIX}"'") {print $0;} }')
 		if [[ -n ${INSTALLTOD} ]] ; then
 			eqawarn "QA Notice: the following files are outside of the prefix:"
 			eqawarn "${INSTALLTOD}"
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2022-05-07 17:15 Mike Gilbert
  0 siblings, 0 replies; 120+ messages in thread
From: Mike Gilbert @ 2022-05-07 17:15 UTC (permalink / raw
  To: gentoo-commits
commit:     2c25a3a6e88f32d94c63ab38baa34f2d79a2699e
Author:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
AuthorDate: Tue Apr 26 19:22:10 2022 +0000
Commit:     Mike Gilbert <floppym <AT> gentoo <DOT> org>
CommitDate: Sat May  7 17:11:20 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=2c25a3a6
install-qa-check.d/60pkgconfig: add QA_PKGCONFIG_VERSION
This allows ebuild maintainers to override the expected version in the
.pc file when it differs from ${PV}.
Signed-off-by: Mike Gilbert <floppym <AT> gentoo.org>
 bin/install-qa-check.d/60pkgconfig | 43 +++++++++++++++++++++++---------------
 1 file changed, 26 insertions(+), 17 deletions(-)
diff --git a/bin/install-qa-check.d/60pkgconfig b/bin/install-qa-check.d/60pkgconfig
index 58f533e83..25143275f 100644
--- a/bin/install-qa-check.d/60pkgconfig
+++ b/bin/install-qa-check.d/60pkgconfig
@@ -92,25 +92,34 @@ pkgconfig_check() {
 	# about, while avoiding any pathological cases e.g. multiple libraries
 	# with different versioning within one package.
 	# Example bugs: bug #833895, bug #833887.
-	local all_bad=yes
-	# Record the last bad file matched
-	local bad_file
-	for f in "${files[@]}" ; do
-		if [[ ${PV} == $(pkg-config --modversion "${f}") ]] ; then
-			all_bad=no
-			break
-		fi
 
-		bad_file="${f//${D}}"
-	done
+	# Default to PV if QA_PKGCONFIG_VERSION is unset.
+	if [[ -z ${QA_PKGCONFIG_VERSION+set} ]]; then
+		local QA_PKGCONFIG_VERSION=${PV}
+	fi
+
+	# Skip the check if QA_PKGCONFIG_VERSION is set to empty string.
+	if [[ -n ${QA_PKGCONFIG_VERSION} ]]; then
+		local all_bad=yes
+		# Record the last bad file matched
+		local bad_file
+		for f in "${files[@]}" ; do
+			if [[ ${QA_PKGCONFIG_VERSION} == $(pkg-config --modversion "${f}") ]] ; then
+				all_bad=no
+				break
+			fi
 
-	# Skip result reporting if *_p* because for both _pN and _preN, we
-	# don't generally expect the versions to be exactly accurate, and
-	# we want to avoid false positives.
-	if [[ ${all_bad} == "yes" && ${PV} != *_p* ]] && ! has live ${PROPERTIES} ; then
-		eqawarn "QA Notice: pkg-config files with mismatched Version found!"
-		eqawarn "At least ${bad_file}'s Version field does not match ${PV}"
-		eqawarn "Please check all .pc files installed by this package."
+			bad_file="${f//${D}}"
+		done
+
+		# Skip result reporting if *_p* because for both _pN and _preN, we
+		# don't generally expect the versions to be exactly accurate, and
+		# we want to avoid false positives.
+		if [[ ${all_bad} == "yes" && ${PV} != *_p* ]] && ! has live ${PROPERTIES} ; then
+			eqawarn "QA Notice: pkg-config files with mismatched Version found!"
+			eqawarn "At least ${bad_file}'s Version field does not match ${PV}"
+			eqawarn "Please check all .pc files installed by this package."
+		fi
 	fi
 }
 
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2022-04-28 15:50 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2022-04-28 15:50 UTC (permalink / raw
  To: gentoo-commits
commit:     98750a24b8c8adcdb8e6a0e37456bb75925f71c4
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Tue Apr 19 21:33:03 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Apr 28 15:50:15 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=98750a24
install-qa-check.d/10ignored-flags: sync check with other examples (cosmetic)
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/10ignored-flags | 5 +++--
 1 file changed, 3 insertions(+), 2 deletions(-)
diff --git a/bin/install-qa-check.d/10ignored-flags b/bin/install-qa-check.d/10ignored-flags
index 7cd073578..0bda8eced 100644
--- a/bin/install-qa-check.d/10ignored-flags
+++ b/bin/install-qa-check.d/10ignored-flags
@@ -1,8 +1,9 @@
 # QA checks for ignored *FLAGS.
 
 ignored_flag_check() {
-	type -P scanelf > /dev/null || return
-	has binchecks ${PORTAGE_RESTRICT} && return
+	if ! type -P scanelf >/dev/null || has binchecks ${PORTAGE_RESTRICT}; then
+		return
+	fi
 
 	local qa_var="QA_FLAGS_IGNORED_${ARCH/-/_}"
 	eval "[[ -n \${!qa_var} ]] && QA_FLAGS_IGNORED=(\"\${${qa_var}[@]}\")"
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2022-04-12  2:00 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2022-04-12  2:00 UTC (permalink / raw
  To: gentoo-commits
commit:     7aa2e188d6732088ae2a2926cc465988e4f117f9
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Feb 23 01:26:11 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Apr 12 01:59:54 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=7aa2e188
install-qa-check.d/60pkgconfig: check for mismatched version
We want to try catch cases where we're installing a pkg-config (.pc)
file with an obviously incorrect version (here, we're testing for
${PV} != any version in all of the installed .pc files) because:
1. it's bad;
2. it has a large blast radius (breaking consumers).
Bug: https://bugs.gentoo.org/833895
Bug: https://bugs.gentoo.org/833887
Bug: https://bugs.gentoo.org/833907
Bug: https://bugs.gentoo.org/833884
Bug: https://bugs.gentoo.org/833888
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/60pkgconfig | 26 ++++++++++++++++++++++++++
 1 file changed, 26 insertions(+)
diff --git a/bin/install-qa-check.d/60pkgconfig b/bin/install-qa-check.d/60pkgconfig
index cb6660bcb..78c5b5a3c 100644
--- a/bin/install-qa-check.d/60pkgconfig
+++ b/bin/install-qa-check.d/60pkgconfig
@@ -78,6 +78,32 @@ pkgconfig_check() {
 		eqatag -v pkgconfig.bad-libdir "${bad_libdir[@]}"
 	fi
 
+	# Check for mismatched Version field vs ${PV}
+	# To be safe, let's make sure _all_ installed .pcs have a bad Version
+	# before warning, as this should catch the general cases we're worried
+	# about, while avoiding any pathological cases e.g. multiple libraries
+	# with different versioning within one package.
+	# Example bugs: bug #833895, bug #833887.
+	local all_bad=yes
+	# Record the last bad file matched
+	local bad_file
+	for f in "${files[@]}" ; do
+		if [[ ${PV} == $(pkg-config --modversion "${f}") ]] ; then
+			all_bad=no
+			break
+		fi
+
+		bad_file=f
+	done
+
+	# Skip result reporting if *_p* because for both _pN and _preN, we
+	# don't generally expect the versions to be exactly accurate, and
+	# we want to avoid false positives.
+	if [[ ${all_bad} == "yes" && ${PV} != *_p* ]] && ! has live ${PROPERTIES} ; then
+		eqawarn "QA Notice: pkg-config files with mismatched Version found!"
+		eqawarn "At least ${bad_file}'s Version field does not match ${PV}"
+		eqawarn "Please check all .pc files installed by this package."
+	fi
 }
 
 pkgconfig_check
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2022-04-12  2:00 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2022-04-12  2:00 UTC (permalink / raw
  To: gentoo-commits
commit:     e31acf622d632d093b01e51e03c1c3f98dbe3a1c
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Wed Mar 16 00:02:24 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Apr 12 01:59:56 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=e31acf62
install-qa-check.d/60pkgconfig: change libdir regex
We don't want to watch /var/lib/, for example.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/60pkgconfig | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/bin/install-qa-check.d/60pkgconfig b/bin/install-qa-check.d/60pkgconfig
index e2d839ca1..58f533e83 100644
--- a/bin/install-qa-check.d/60pkgconfig
+++ b/bin/install-qa-check.d/60pkgconfig
@@ -62,19 +62,19 @@ pkgconfig_check() {
 	# e.g. https://bugs.gentoo.org/729642
 	local bad_libdir=()
 	for f in "${files[@]}" ; do
-		# In ${ED}/usr/lib, we shouldn't reference lib64
 		if [[ ${f} == *lib/pkgconfig* ]] ; then
 			if [[ -d "${ED}"/usr/lib && -L "${ED}"/usr/lib ]] ; then
 				# (Don't bother if /usr/lib is a symlink to /usr/lib64)
 				continue
 			fi
 
-			if egrep -q "/lib64" ${f} ; then
+			# In ${ED}/usr/lib, we shouldn't reference lib64
+			if egrep -q "=(/usr)?/lib64" ${f} ; then
 				bad_libdir+=( "${f//${D}}" )
 			fi
 		elif [[ ${f} == *lib64/pkgconfig* ]] ; then
 			# We want to match /lib/, /lib/foo/, but not e.g. /lib64 or /lib64/, or libfoo
-			if grep -qP '/lib\b' ${f} ; then
+			if grep -qP '=(/usr)?/lib\b' ${f} ; then
 				bad_libdir+=( "${f//${D}}" )
 			fi
 		fi
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2022-04-12  2:00 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2022-04-12  2:00 UTC (permalink / raw
  To: gentoo-commits
commit:     561e2d1f884c01d987e8bd812e01c1a29da7f082
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Mar  3 21:16:55 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Apr 12 01:59:55 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=561e2d1f
install-qa-check.d/60pkgconfig: drop ${D} from output; don't repeat ${EPREFIX}
It's confusing when the ebuild has been merged to the system
and we should be consistent with other checks.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/60pkgconfig | 13 ++++++++-----
 1 file changed, 8 insertions(+), 5 deletions(-)
diff --git a/bin/install-qa-check.d/60pkgconfig b/bin/install-qa-check.d/60pkgconfig
index 4c6f01f03..e2d839ca1 100644
--- a/bin/install-qa-check.d/60pkgconfig
+++ b/bin/install-qa-check.d/60pkgconfig
@@ -42,9 +42,12 @@ pkgconfig_check() {
 
 				if [[ ${value} != "${EPREFIX}"* ]] ; then
 					eqawarn "QA Notice: pkg-config files not respecting EPREFIX found"
-					eqawarn "${f}'s key=${key} does not respect EPREFIX:"
+					eqawarn "key=${key} does not respect EPREFIX:"
 					eqawarn "${key}=${value}"
-					eqatag -v pkgconfig.bad-paths "${f}"
+					eqatag -v pkgconfig.bad-paths ${key}="${value}" "${f//${D}}"
+
+					# Don't bother repeating for every variable in the same file
+					break
 				fi
 			done
 		done
@@ -67,12 +70,12 @@ pkgconfig_check() {
 			fi
 
 			if egrep -q "/lib64" ${f} ; then
-				bad_libdir+=( ${f} )
+				bad_libdir+=( "${f//${D}}" )
 			fi
 		elif [[ ${f} == *lib64/pkgconfig* ]] ; then
 			# We want to match /lib/, /lib/foo/, but not e.g. /lib64 or /lib64/, or libfoo
 			if grep -qP '/lib\b' ${f} ; then
-				bad_libdir+=( ${f} )
+				bad_libdir+=( "${f//${D}}" )
 			fi
 		fi
 	done
@@ -98,7 +101,7 @@ pkgconfig_check() {
 			break
 		fi
 
-		bad_file=f
+		bad_file="${f//${D}}"
 	done
 
 	# Skip result reporting if *_p* because for both _pN and _preN, we
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2022-04-12  2:00 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2022-04-12  2:00 UTC (permalink / raw
  To: gentoo-commits
commit:     183dc3d778cf83102aa7ed8291979b71a287cf7e
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Feb 24 22:43:47 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Apr 12 01:59:55 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=183dc3d7
install-qa-check.d/60pkgconfig: exit early if no pkg-config installed
But we still run the LDFLAGS check.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/60pkgconfig | 5 +++++
 1 file changed, 5 insertions(+)
diff --git a/bin/install-qa-check.d/60pkgconfig b/bin/install-qa-check.d/60pkgconfig
index 78c5b5a3c..4c6f01f03 100644
--- a/bin/install-qa-check.d/60pkgconfig
+++ b/bin/install-qa-check.d/60pkgconfig
@@ -17,6 +17,11 @@ pkgconfig_check() {
 		eqatag -v pkgconfig.bad-ldlags "${f//${D}}"
 	fi
 
+	# Bail out now so we can rely on pkgconfig in subsequent checks if we want.
+	if ! type -P pkg-config >/dev/null ; then
+		return
+	fi
+
 	# Validate using pkgconfig
 	# Some less common implementations may not support this?
 	# seems like f.d.o, OpenBSD, and of course pkgconf do though.
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2022-04-12  2:00 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2022-04-12  2:00 UTC (permalink / raw
  To: gentoo-commits
commit:     6bce6ac4dc87872c112e9f5c5a847acb78ec3d26
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Oct 28 00:37:41 2021 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Apr 12 01:59:52 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=6bce6ac4
install-qa-check.d/60pkgconfig: check if paths within .pc respect EPREFIX
Seen this problem a few times and it's easy to miss.
See: c90ab38e3577aae61fac2341b34ad593948de1cd in ::gentoo
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/60pkgconfig | 17 +++++++++++++++++
 1 file changed, 17 insertions(+)
diff --git a/bin/install-qa-check.d/60pkgconfig b/bin/install-qa-check.d/60pkgconfig
index 9c4768a95..9e09a1053 100644
--- a/bin/install-qa-check.d/60pkgconfig
+++ b/bin/install-qa-check.d/60pkgconfig
@@ -26,6 +26,23 @@ pkgconfig_check() {
 		eqawarn "QA Notice: pkg-config files which fail validation found!"
 		eqawarn "Run 'pkg-config --validate ...' for more information"
 	fi
+
+	# Check for unexpected paths
+	# e.g. https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=c90ab38e3577aae61fac2341b34ad593948de1cd
+	if [[ -n ${EPREFIX} ]] ; then
+		for f in "${files[@]}" ; do
+			local key
+			for key in prefix exec_prefix libdir includedir ; do
+				local value=$(pkg-config --variable="${key}" "${f}")
+
+				if [[ ${value} != "${EPREFIX}"* ]] ; then
+					eqawarn "QA Notice: pkg-config files not respecting EPREFIX found"
+					eqawarn "${f}'s key=${key} does not respect EPREFIX:"
+					eqawarn "${key}=${value}"
+				fi
+			done
+		done
+	fi
 }
 
 pkgconfig_check
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2022-04-12  2:00 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2022-04-12  2:00 UTC (permalink / raw
  To: gentoo-commits
commit:     0ac65ddf7cff60a64730ca7c123f492fb68217a4
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Oct 28 00:38:43 2021 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Apr 12 01:59:53 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=0ac65ddf
install-qa-check.d/60pkgconfig: check for not respecting libdir in pc files
It's not valid to reference lib64 when installing to /usr/lib where we
want 32-bit libraries.
We want to make sure that if we're installing a pkgconfig file for a 32-bit
variant (multilib), we make sure that the file references the right library:
it should have e.g. /usr/lib, not /usr/lib64, or consumers trying to use
the 32-bit library will try to link against a 64-bit library.
(We also cover the opposite case: /usr/lib64 pkgconfig files referencing
/usr/lib).
Bug: https://bugs.gentoo.org/729642
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/60pkgconfig | 37 ++++++++++++++++++++++++++++++++++++-
 1 file changed, 36 insertions(+), 1 deletion(-)
diff --git a/bin/install-qa-check.d/60pkgconfig b/bin/install-qa-check.d/60pkgconfig
index 9e09a1053..cb6660bcb 100644
--- a/bin/install-qa-check.d/60pkgconfig
+++ b/bin/install-qa-check.d/60pkgconfig
@@ -14,7 +14,7 @@ pkgconfig_check() {
 	f=$(egrep -zsH '^Libs.*-Wl,(-O[012]|--hash-style)' "${files[@]}")
 	if [[ -n ${f} ]] ; then
 		eqawarn "QA Notice: pkg-config files with wrong LDFLAGS detected:"
-		eqawarn "${f//${D}}"
+		eqatag -v pkgconfig.bad-ldlags "${f//${D}}"
 	fi
 
 	# Validate using pkgconfig
@@ -39,10 +39,45 @@ pkgconfig_check() {
 					eqawarn "QA Notice: pkg-config files not respecting EPREFIX found"
 					eqawarn "${f}'s key=${key} does not respect EPREFIX:"
 					eqawarn "${key}=${value}"
+					eqatag -v pkgconfig.bad-paths "${f}"
 				fi
 			done
 		done
 	fi
+
+	# TODO: Generalise for non-lib64 libdir? Not that this is very common now
+	# that riscv chose a more standard layout.
+	#
+	# If we're installing to ${ED}/usr/lib/pkgconfig, let's make sure
+	# we're not referencing lib64.
+	#
+	# e.g. https://bugs.gentoo.org/729642
+	local bad_libdir=()
+	for f in "${files[@]}" ; do
+		# In ${ED}/usr/lib, we shouldn't reference lib64
+		if [[ ${f} == *lib/pkgconfig* ]] ; then
+			if [[ -d "${ED}"/usr/lib && -L "${ED}"/usr/lib ]] ; then
+				# (Don't bother if /usr/lib is a symlink to /usr/lib64)
+				continue
+			fi
+
+			if egrep -q "/lib64" ${f} ; then
+				bad_libdir+=( ${f} )
+			fi
+		elif [[ ${f} == *lib64/pkgconfig* ]] ; then
+			# We want to match /lib/, /lib/foo/, but not e.g. /lib64 or /lib64/, or libfoo
+			if grep -qP '/lib\b' ${f} ; then
+				bad_libdir+=( ${f} )
+			fi
+		fi
+	done
+
+	if [[ -n "${bad_libdir[@]}" ]] ; then
+		eqawarn "QA Notice: pkg-config files not respecting libdir found"
+		eqawarn "(contains reference to either lib or lib64 in wrong directory)"
+		eqatag -v pkgconfig.bad-libdir "${bad_libdir[@]}"
+	fi
+
 }
 
 pkgconfig_check
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2022-04-12  2:00 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2022-04-12  2:00 UTC (permalink / raw
  To: gentoo-commits
commit:     d872bb3b6e879d75445536b9b0fca4009822d433
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Oct 28 00:36:29 2021 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Apr 12 01:59:51 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=d872bb3b
install-qa-check.d/60pkgconfig: create list of .pc files early (refactoring)
This makes adding additional checks easier. We just bail out early
if there's no work to be done.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/60pkgconfig | 11 ++++++++++-
 1 file changed, 10 insertions(+), 1 deletion(-)
diff --git a/bin/install-qa-check.d/60pkgconfig b/bin/install-qa-check.d/60pkgconfig
index 1b34c04db..2cc9f7c59 100644
--- a/bin/install-qa-check.d/60pkgconfig
+++ b/bin/install-qa-check.d/60pkgconfig
@@ -1,8 +1,17 @@
 # Check for pkg-config file issues
 
 pkgconfig_check() {
+	local files=()
+	# Make a list of .pc files and bail out if there aren't any
+	mapfile -d '' files < <(
+		find "${ED}"/usr/{lib*,share}/pkgconfig -maxdepth 1 -type f -name '*.pc' -print0 2>/dev/null
+	)
+	[[ -z "${files[@]}" ]] && return
+
+	local f
+
 	# Look for leaking LDFLAGS into pkg-config files
-	local f=$(egrep -sH '^Libs.*-Wl,(-O[012]|--hash-style)' "${ED}"/usr/*/pkgconfig/*.pc)
+	f=$(egrep -zsH '^Libs.*-Wl,(-O[012]|--hash-style)' "${files[@]}")
 	if [[ -n ${f} ]] ; then
 		eqawarn "QA Notice: pkg-config files with wrong LDFLAGS detected:"
 		eqawarn "${f//${D}}"
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2022-04-12  2:00 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2022-04-12  2:00 UTC (permalink / raw
  To: gentoo-commits
commit:     0d74ce0945f0567d2c695fe4443a5c94046dfe09
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Oct 28 00:37:15 2021 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Apr 12 01:59:52 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=0d74ce09
install-qa-check.d/60pkgconfig: run pkg-config --validate on installed files
Similar to the XDG desktop file validation check.
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/60pkgconfig | 10 ++++++++++
 1 file changed, 10 insertions(+)
diff --git a/bin/install-qa-check.d/60pkgconfig b/bin/install-qa-check.d/60pkgconfig
index 2cc9f7c59..9c4768a95 100644
--- a/bin/install-qa-check.d/60pkgconfig
+++ b/bin/install-qa-check.d/60pkgconfig
@@ -16,6 +16,16 @@ pkgconfig_check() {
 		eqawarn "QA Notice: pkg-config files with wrong LDFLAGS detected:"
 		eqawarn "${f//${D}}"
 	fi
+
+	# Validate using pkgconfig
+	# Some less common implementations may not support this?
+	# seems like f.d.o, OpenBSD, and of course pkgconf do though.
+	# Need --maximum-traverse-depth=1 to avoid checking deps and giving
+	# unrelated warnings/errors.
+	if ! pkg-config --maximum-traverse-depth=1 --validate "${files[@]}" ; then
+		eqawarn "QA Notice: pkg-config files which fail validation found!"
+		eqawarn "Run 'pkg-config --validate ...' for more information"
+	fi
 }
 
 pkgconfig_check
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2022-04-10 17:20 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2022-04-10 17:20 UTC (permalink / raw
  To: gentoo-commits
commit:     8ded447a1d194ad0190a174f7bb330417685d861
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sun Apr 10 16:51:02 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Apr 10 17:19:57 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=8ded447a
install-qa-check.d/20runtime-directories: warn on /var/tmp too
Bug: https://bugs.gentoo.org/493154
Bug: https://bugs.gentoo.org/837536
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/20runtime-directories | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/install-qa-check.d/20runtime-directories b/bin/install-qa-check.d/20runtime-directories
index 2e21d6d04..3dc52f425 100644
--- a/bin/install-qa-check.d/20runtime-directories
+++ b/bin/install-qa-check.d/20runtime-directories
@@ -1,10 +1,10 @@
 # Check for directories that need to be created at runtime
 
 runtime_dir_check() {
-	# It's ok create these directories, but not to install into them. #493154
+	# It's ok to create these directories, but not to install into them. #493154
 	# TODO: We should add var/lib to this list.
 	local x f=
-	for x in var/cache var/lock var/run run ; do
+	for x in var/cache var/lock var/run var/tmp run ; do
 		if [[ ! -L ${ED}/${x} && -d ${ED}/${x} ]] ; then
 			if [[ -z $(find "${ED}/${x}" -prune -empty) ]] ; then
 				f+=$(cd "${ED}"; find "${x}" -printf '  %p\n')
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2022-04-05  4:33 Sam James
  0 siblings, 0 replies; 120+ messages in thread
From: Sam James @ 2022-04-05  4:33 UTC (permalink / raw
  To: gentoo-commits
commit:     7b44116b4a669a49e51e5a495ab62a25229e18e4
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Apr  2 04:10:31 2022 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Tue Apr  5 04:32:56 2022 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=7b44116b
bin/install-qa-check.d/95empty-dirs: update message for EAPI 8
Portage changed the default for >= EAPI 8 ("newer EAPIs" at the time, not
actually specific to 8) in bfda0d2bd4ba03a4e77f488ec3fd4f9c6c351662 to
enable FEATURES="strict-keepdir".
Signed-off-by: Sam James <sam <AT> gentoo.org>
Closes: https://github.com/gentoo/portage/pull/802
Signed-off-by: Sam James <sam <AT> gentoo.org>
 bin/install-qa-check.d/95empty-dirs | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/install-qa-check.d/95empty-dirs b/bin/install-qa-check.d/95empty-dirs
index 34a1daf21..b8612bdf1 100644
--- a/bin/install-qa-check.d/95empty-dirs
+++ b/bin/install-qa-check.d/95empty-dirs
@@ -33,7 +33,7 @@ find_empty_dirs() {
 		done
 		eqawarn
 		eqawarn "If those directories need to be preserved, please make sure to create"
-		eqawarn "or mark them for keeping using 'keepdir'. Future versions of Portage"
+		eqawarn "or mark them for keeping using 'keepdir'. Portage for >= EAPI 8 ebuilds"
 		eqawarn "will strip empty directories from installation image."
 	fi
 }
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2019-11-03 20:15 Zac Medico
  0 siblings, 0 replies; 120+ messages in thread
From: Zac Medico @ 2019-11-03 20:15 UTC (permalink / raw
  To: gentoo-commits
commit:     ae2a76261fd7e519bfbb3b8c4b41aa511d039245
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sun Nov  3 20:12:02 2019 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun Nov  3 20:14:42 2019 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=ae2a7626
Revert "install-qa-check.d: remove check that bans libtool files and static libs from /"
This reverts commit 498900e5e51460502d8271f409a4c614a021613b.
This change is still being discussed.
See: https://archives.gentoo.org/gentoo-portage-dev/message/6e4cfbb0ef9c36dc6511d4f2003cc458
Bug: https://bugs.gentoo.org/699252
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/install-qa-check.d/80libraries | 10 ++++++++++
 1 file changed, 10 insertions(+)
diff --git a/bin/install-qa-check.d/80libraries b/bin/install-qa-check.d/80libraries
index e59369bf6..d1d2c4fdd 100644
--- a/bin/install-qa-check.d/80libraries
+++ b/bin/install-qa-check.d/80libraries
@@ -152,6 +152,16 @@ lib_check() {
 	done
 	[[ ${abort} == "yes" ]] && die "add those ldscripts"
 
+	# Make sure people don't store libtool files or static libs in /lib
+	f=$(ls "${ED%/}"/lib*/*.{a,la} 2>/dev/null)
+	if [[ -n ${f} ]] ; then
+		__vecho -ne '\n'
+		eqawarn "QA Notice: Excessive files found in the / partition"
+		eqawarn "${f}"
+		__vecho -ne '\n'
+		die "static archives (*.a) and libtool library files (*.la) belong in /usr/lib*, not /lib*"
+	fi
+
 	# Verify that the libtool files don't contain bogus $D entries.
 	local abort=no gentoo_bug=no always_overflow=no
 	for a in "${ED%/}"/usr/lib*/*.la ; do
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2019-11-03 20:15 Zac Medico
  0 siblings, 0 replies; 120+ messages in thread
From: Zac Medico @ 2019-11-03 20:15 UTC (permalink / raw
  To: gentoo-commits
commit:     5952ad42e44d15da4d3a73d43f6bcc3714bf9a4f
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sun Nov  3 20:11:35 2019 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun Nov  3 20:11:50 2019 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=5952ad42
Revert "install-qa-check.d: handle libtool files and static libs from /"
This reverts commit a2506e4ebd47781eb81b7d13b0a1a376ed028c77.
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/install-qa-check.d/80libraries | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/install-qa-check.d/80libraries b/bin/install-qa-check.d/80libraries
index 806605293..e59369bf6 100644
--- a/bin/install-qa-check.d/80libraries
+++ b/bin/install-qa-check.d/80libraries
@@ -139,7 +139,7 @@ lib_check() {
 	# https://bugs.gentoo.org/4411
 	local abort="no"
 	local a s
-	for a in "${ED%/}"{/usr,}/lib*/*.a ; do
+	for a in "${ED%/}"/usr/lib*/*.a ; do
 		s=${a%.a}.so
 		if [[ ! -e ${s} ]] ; then
 			s=${s%usr/*}${s##*/usr/}
@@ -154,7 +154,7 @@ lib_check() {
 
 	# Verify that the libtool files don't contain bogus $D entries.
 	local abort=no gentoo_bug=no always_overflow=no
-	for a in "${ED%/}"{/usr,}/lib*/*.la ; do
+	for a in "${ED%/}"/usr/lib*/*.la ; do
 		s=${a##*/}
 		if grep -qs "${ED}" "${a}" ; then
 			__vecho -ne '\n'
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2019-11-03 20:02 Zac Medico
  0 siblings, 0 replies; 120+ messages in thread
From: Zac Medico @ 2019-11-03 20:02 UTC (permalink / raw
  To: gentoo-commits
commit:     a2506e4ebd47781eb81b7d13b0a1a376ed028c77
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sun Nov  3 19:59:06 2019 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun Nov  3 20:00:59 2019 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=a2506e4e
install-qa-check.d: handle libtool files and static libs from /
Fixes: 498900e5e514 ("install-qa-check.d: remove check that bans libtool files and static libs from /")
Bug: https://bugs.gentoo.org/699252
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/install-qa-check.d/80libraries | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/install-qa-check.d/80libraries b/bin/install-qa-check.d/80libraries
index e59369bf6..806605293 100644
--- a/bin/install-qa-check.d/80libraries
+++ b/bin/install-qa-check.d/80libraries
@@ -139,7 +139,7 @@ lib_check() {
 	# https://bugs.gentoo.org/4411
 	local abort="no"
 	local a s
-	for a in "${ED%/}"/usr/lib*/*.a ; do
+	for a in "${ED%/}"{/usr,}/lib*/*.a ; do
 		s=${a%.a}.so
 		if [[ ! -e ${s} ]] ; then
 			s=${s%usr/*}${s##*/usr/}
@@ -154,7 +154,7 @@ lib_check() {
 
 	# Verify that the libtool files don't contain bogus $D entries.
 	local abort=no gentoo_bug=no always_overflow=no
-	for a in "${ED%/}"/usr/lib*/*.la ; do
+	for a in "${ED%/}"{/usr,}/lib*/*.la ; do
 		s=${a##*/}
 		if grep -qs "${ED}" "${a}" ; then
 			__vecho -ne '\n'
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2019-11-03 19:45 Zac Medico
  0 siblings, 0 replies; 120+ messages in thread
From: Zac Medico @ 2019-11-03 19:45 UTC (permalink / raw
  To: gentoo-commits
commit:     498900e5e51460502d8271f409a4c614a021613b
Author:     William Hubbs <williamh <AT> gentoo <DOT> org>
AuthorDate: Sun Oct 27 17:40:07 2019 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sun Nov  3 19:44:44 2019 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=498900e5
install-qa-check.d: remove check that bans libtool files and static libs from /
Most upstreams and build systems do not make this distinction, so this
causes unnecessary hacks in ebuilds.
Bug: https://bugs.gentoo.org/699252
Signed-off-by: William Hubbs <williamh <AT> gentoo.org>
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/install-qa-check.d/80libraries | 10 ----------
 1 file changed, 10 deletions(-)
diff --git a/bin/install-qa-check.d/80libraries b/bin/install-qa-check.d/80libraries
index d1d2c4fdd..e59369bf6 100644
--- a/bin/install-qa-check.d/80libraries
+++ b/bin/install-qa-check.d/80libraries
@@ -152,16 +152,6 @@ lib_check() {
 	done
 	[[ ${abort} == "yes" ]] && die "add those ldscripts"
 
-	# Make sure people don't store libtool files or static libs in /lib
-	f=$(ls "${ED%/}"/lib*/*.{a,la} 2>/dev/null)
-	if [[ -n ${f} ]] ; then
-		__vecho -ne '\n'
-		eqawarn "QA Notice: Excessive files found in the / partition"
-		eqawarn "${f}"
-		__vecho -ne '\n'
-		die "static archives (*.a) and libtool library files (*.la) belong in /usr/lib*, not /lib*"
-	fi
-
 	# Verify that the libtool files don't contain bogus $D entries.
 	local abort=no gentoo_bug=no always_overflow=no
 	for a in "${ED%/}"/usr/lib*/*.la ; do
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2019-05-20  5:01 Zac Medico
  0 siblings, 0 replies; 120+ messages in thread
From: Zac Medico @ 2019-05-20  5:01 UTC (permalink / raw
  To: gentoo-commits
commit:     e54bc64a3779d4546b70a7a82d677a18d3c37b67
Author:     Arfrever Frehtes Taifersar Arahesis <Arfrever <AT> Apache <DOT> Org>
AuthorDate: Fri May 10 01:20:14 2019 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon May 20 04:53:48 2019 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=e54bc64a
install-qa-check.d/80libraries: fix false positive
Do not report libraries missing DT_NEEDED and not containing undefined
non-weak symbols.
Bug: https://bugs.gentoo.org/516016
Signed-off-by: Arfrever Frehtes Taifersar Arahesis <Arfrever <AT> Apache.Org>
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/install-qa-check.d/80libraries | 21 +++++++++++++++++++--
 1 file changed, 19 insertions(+), 2 deletions(-)
diff --git a/bin/install-qa-check.d/80libraries b/bin/install-qa-check.d/80libraries
index bbabc0eb9..d1d2c4fdd 100644
--- a/bin/install-qa-check.d/80libraries
+++ b/bin/install-qa-check.d/80libraries
@@ -1,7 +1,15 @@
 # Check for issues with installed libraries
 
 scanelf_lib_check() {
-	local f x i j
+	local t v
+	for t in NM:nm ; do
+		v=${t%:*} # NM
+		t=${t#*:} # nm
+		eval ${v}=\"${!v:-${CHOST}-${t}}\"
+		type -P -- ${!v} >/dev/null || eval ${v}=${t}
+	done
+
+	local f x i j library libraries
 
 	# Check for shared libraries lacking SONAMEs
 	local qa_var="QA_SONAME_${ARCH/-/_}"
@@ -40,7 +48,16 @@ scanelf_lib_check() {
 	# Check for shared libraries lacking NEEDED entries
 	qa_var="QA_DT_NEEDED_${ARCH/-/_}"
 	eval "[[ -n \${!qa_var} ]] && QA_DT_NEEDED=(\"\${${qa_var}[@]}\")"
-	f=$(scanelf -ByF '%n %p' "${ED%/}"/{,usr/}lib*/lib*.so* | awk '$2 == "" { print }' | sed -e "s:^[[:space:]]${ED%/}/:/:")
+	f=
+	libraries=$(scanelf -ByF '%n %p' "${ED%/}"/{,usr/}lib*/lib*.so* | awk '$2 == "" { print }' | sed -e "s:^[[:space:]]::")
+	if [[ -n ${libraries} ]] ; then
+		while IFS= read -r library ; do
+			# Only shared libraries containing undefined non-weak symbols actually need NEEDED entries.
+			if [[ -n $(${NM} -D "${library}" | grep -E "^ +U ") ]] ; then
+				f+="/${library#${ED%/}/}"$'\n'
+			fi
+		done <<< "${libraries}"
+	fi
 	if [[ -n ${f} ]] ; then
 		echo "${f}" > "${T}"/scanelf-missing-NEEDED.log
 		if [[ "${QA_STRICT_DT_NEEDED-unset}" == unset ]] ; then
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2019-05-20  4:41 Zac Medico
  0 siblings, 0 replies; 120+ messages in thread
From: Zac Medico @ 2019-05-20  4:41 UTC (permalink / raw
  To: gentoo-commits
commit:     bdde97ba14e85ea2ca6b128fddca710081334b55
Author:     Arfrever Frehtes Taifersar Arahesis <Arfrever <AT> Apache <DOT> Org>
AuthorDate: Mon May 20 01:32:25 2019 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon May 20 04:36:32 2019 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=bdde97ba
install-qa-check.d/10ignored-flags: fix false positive
Do not report not respecting LDFLAGS for *.o files with
__gentoo_check_ldflags__ symbol.
Bug: https://bugs.gentoo.org/686356
Signed-off-by: Arfrever Frehtes Taifersar Arahesis <Arfrever <AT> Apache.Org>
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/install-qa-check.d/10ignored-flags | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/install-qa-check.d/10ignored-flags b/bin/install-qa-check.d/10ignored-flags
index 09bcb57fc..062f51325 100644
--- a/bin/install-qa-check.d/10ignored-flags
+++ b/bin/install-qa-check.d/10ignored-flags
@@ -66,7 +66,7 @@ ignored_flag_check() {
 	# Check for files built without respecting LDFLAGS
 	if [[ "${LDFLAGS}" == *,--defsym=__gentoo_check_ldflags__* ]] && \
 		! has binchecks ${RESTRICT} ; then
-		f=$(LC_ALL=C comm -3 <(scanelf -qyRF '#k%p' -k .dynsym "${ED%/}/" | LC_ALL=C sort) \
+		f=$(LC_ALL=C comm -2 -3 <(scanelf -qyRF '#k%p' -k .dynsym "${ED%/}/" | LC_ALL=C sort) \
 			<(scanelf -qyRF '#s%p' -s __gentoo_check_ldflags__ "${ED%/}/" | LC_ALL=C sort))
 		if [[ -n ${f} ]] ; then
 			echo "${f}" > "${T}"/scanelf-ignored-LDFLAGS.log
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2018-10-06  1:15 Zac Medico
  0 siblings, 0 replies; 120+ messages in thread
From: Zac Medico @ 2018-10-06  1:15 UTC (permalink / raw
  To: gentoo-commits
commit:     dd605b1aa574fc035d3319d954be1ca0d2cdde19
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Sat Oct  6 01:11:02 2018 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat Oct  6 01:14:14 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=dd605b1a
Revert "install-qa-checks.d: Add a check for Gentoo path policies (FHS-y)"
This reverts commit d5f97eaa464736a454c8ad410f4acd4fccdf2324.
Until this QA check has adjustable whitelist support, we can consider
it an unstable work in progress. Therefore, I'd like for the QA team
to move it gentoo/metadata/install-qa-check.d/08gentoo-paths until
it has matured. It's safe to commit it to the gentoo repository now,
and it will become active when portage's internal copy is removed.
Bug: https://bugs.gentoo.org/667604
Closes: https://bugs.gentoo.org/667378
Closes: https://github.com/gentoo/portage/pull/373
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/install-qa-check.d/08gentoo-paths | 77 -----------------------------------
 1 file changed, 77 deletions(-)
diff --git a/bin/install-qa-check.d/08gentoo-paths b/bin/install-qa-check.d/08gentoo-paths
deleted file mode 100644
index 3ee887df0..000000000
--- a/bin/install-qa-check.d/08gentoo-paths
+++ /dev/null
@@ -1,77 +0,0 @@
-# Check whether ebuilds are not installing new, non-Gentoo-ey paths.
-
-gentoo_path_check() {
-	# allowed path definitions
-	# ------------------------
-
-	# directories common to / and /usr
-	local allowed_common_dirs=(
-		bin lib lib32 lib64 libx32 sbin
-	)
-
-	# toplevel directories which can be installed to by ebuilds
-	# /home is not included as no ebuilds should install files there
-	local allowed_paths_toplevel=(
-		"${allowed_common_dirs[@]}"
-		boot dev etc opt srv usr var
-	)
-
-	# directories in /usr which can be installed to by ebuilds
-	# /usr/games is not included as it is banned nowadays
-	local allowed_paths_usr=(
-		"${allowed_common_dirs[@]}"
-		include libexec share src
-		# toolchain stuff
-		"${CHOST}" "${CTARGET}"
-	)
-
-
-	# the logic
-	# ---------
-	local bad_paths=()
-	local x
-
-	local shopt_save=$(shopt -p nullglob)
-	shopt -s nullglob
-
-	# 1. check for unexpected top-level directories
-	local toplevel_dirs=( "${ED%/}"/* )
-	for x in "${toplevel_dirs[@]##*/}"; do
-		if ! has "${x}" "${allowed_paths_toplevel[@]}"; then
-			bad_paths+=( "/${x}" )
-		fi
-	done
-
-	# 2. check for unexpected /usr subdirectories
-	local usr_dirs=( "${ED%/}"/usr/* )
-	for x in "${usr_dirs[@]##*/}"; do
-		if ! has "${x}" "${allowed_paths_usr[@]}"; then
-			bad_paths+=( "/usr/${x}" )
-		fi
-	done
-
-	# 3. check for unexpected /usr/share/doc subdirectories
-	local doc_dirs=( "${ED%/}"/usr/share/doc/* )
-	for x in "${doc_dirs[@]##*/}"; do
-		if [[ ${x} != ${PF} ]]; then
-			bad_paths+=( "/usr/share/doc/${x}" )
-		fi
-	done
-
-	${shopt_save}
-
-	# report
-	# ------
-	if [[ -n ${bad_paths[@]} ]]; then
-		eqawarn "The ebuild is installing to one or more unexpected paths:"
-		eqawarn
-		eqatag -v non-gentoo-paths "${bad_paths[@]}"
-		eqawarn
-		eqawarn "Please fix the ebuild to use correct FHS/Gentoo policy paths."
-	fi
-}
-
-gentoo_path_check
-: # guarantee successful exit
-
-# vim:ft=sh
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2018-09-04 21:16 Michał Górny
  0 siblings, 0 replies; 120+ messages in thread
From: Michał Górny @ 2018-09-04 21:16 UTC (permalink / raw
  To: gentoo-commits
commit:     d5f97eaa464736a454c8ad410f4acd4fccdf2324
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Tue Sep  4 06:54:23 2018 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Tue Sep  4 21:15:55 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=d5f97eaa
install-qa-checks.d: Add a check for Gentoo path policies (FHS-y)
Add a check that verifies whether ebuilds don't install to paths
forbidden by the policy.  This mostly aims to verbosely report bugs
such as missing dependencies causing empty install paths, resulting
in files ending up in / and bad upstreams.  This should also help
detect the relatively common mistake of using /usr/share/doc/${P}
instead of ${PF}.
The initial list of allowed paths was based on what ebuilds installed
to my system.
 bin/install-qa-check.d/08gentoo-paths | 77 +++++++++++++++++++++++++++++++++++
 1 file changed, 77 insertions(+)
diff --git a/bin/install-qa-check.d/08gentoo-paths b/bin/install-qa-check.d/08gentoo-paths
new file mode 100644
index 000000000..3ee887df0
--- /dev/null
+++ b/bin/install-qa-check.d/08gentoo-paths
@@ -0,0 +1,77 @@
+# Check whether ebuilds are not installing new, non-Gentoo-ey paths.
+
+gentoo_path_check() {
+	# allowed path definitions
+	# ------------------------
+
+	# directories common to / and /usr
+	local allowed_common_dirs=(
+		bin lib lib32 lib64 libx32 sbin
+	)
+
+	# toplevel directories which can be installed to by ebuilds
+	# /home is not included as no ebuilds should install files there
+	local allowed_paths_toplevel=(
+		"${allowed_common_dirs[@]}"
+		boot dev etc opt srv usr var
+	)
+
+	# directories in /usr which can be installed to by ebuilds
+	# /usr/games is not included as it is banned nowadays
+	local allowed_paths_usr=(
+		"${allowed_common_dirs[@]}"
+		include libexec share src
+		# toolchain stuff
+		"${CHOST}" "${CTARGET}"
+	)
+
+
+	# the logic
+	# ---------
+	local bad_paths=()
+	local x
+
+	local shopt_save=$(shopt -p nullglob)
+	shopt -s nullglob
+
+	# 1. check for unexpected top-level directories
+	local toplevel_dirs=( "${ED%/}"/* )
+	for x in "${toplevel_dirs[@]##*/}"; do
+		if ! has "${x}" "${allowed_paths_toplevel[@]}"; then
+			bad_paths+=( "/${x}" )
+		fi
+	done
+
+	# 2. check for unexpected /usr subdirectories
+	local usr_dirs=( "${ED%/}"/usr/* )
+	for x in "${usr_dirs[@]##*/}"; do
+		if ! has "${x}" "${allowed_paths_usr[@]}"; then
+			bad_paths+=( "/usr/${x}" )
+		fi
+	done
+
+	# 3. check for unexpected /usr/share/doc subdirectories
+	local doc_dirs=( "${ED%/}"/usr/share/doc/* )
+	for x in "${doc_dirs[@]##*/}"; do
+		if [[ ${x} != ${PF} ]]; then
+			bad_paths+=( "/usr/share/doc/${x}" )
+		fi
+	done
+
+	${shopt_save}
+
+	# report
+	# ------
+	if [[ -n ${bad_paths[@]} ]]; then
+		eqawarn "The ebuild is installing to one or more unexpected paths:"
+		eqawarn
+		eqatag -v non-gentoo-paths "${bad_paths[@]}"
+		eqawarn
+		eqawarn "Please fix the ebuild to use correct FHS/Gentoo policy paths."
+	fi
+}
+
+gentoo_path_check
+: # guarantee successful exit
+
+# vim:ft=sh
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2018-08-07 18:49 Zac Medico
  0 siblings, 0 replies; 120+ messages in thread
From: Zac Medico @ 2018-08-07 18:49 UTC (permalink / raw
  To: gentoo-commits
commit:     807ac3d9d6eecead73f59d399b30559e5c731587
Author:     Michael Orlitzky <mjo <AT> gentoo <DOT> org>
AuthorDate: Tue Aug  7 16:46:04 2018 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Tue Aug  7 18:39:26 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=807ac3d9
bin/install-qa-check.d: add new 90bad-bin-group-write QA check.
System executables that are writable by a non-root user pose a
security risk. Anyone who can write to an executable can change its
behavior. If that executable is later run with elevated privileges
(say, by root, when the machine starts), then the non-root user can
escalate his own privileges to those of the person running the
modified executable.
The 90bad-bin-owner check already addresses one cause for a non-root
user to be able to modify an executable: because he owns it. This
commit adds another check, to ensure that no non-root *groups* have
write access to any system executables. On a "normal" system, all
system executables should be writable only by the super-user's group,
if any. To avoid false-positives, non-"normal" systems (like prefix)
are skipped.
Closes: https://bugs.gentoo.org/629398
 bin/install-qa-check.d/90bad-bin-group-write | 55 ++++++++++++++++++++++++++++
 1 file changed, 55 insertions(+)
diff --git a/bin/install-qa-check.d/90bad-bin-group-write b/bin/install-qa-check.d/90bad-bin-group-write
new file mode 100644
index 000000000..786dde712
--- /dev/null
+++ b/bin/install-qa-check.d/90bad-bin-group-write
@@ -0,0 +1,55 @@
+# Copyright 1999-2018 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+
+bad_bin_group_write_check() {
+	# Warn about globally-installed executables (in /bin, /usr/bin, /sbin,
+	# /usr/sbin, or /opt/bin) that are group-writable by a nonzero GID.
+
+	# This check doesn't work on non-root prefix installations at
+	# the moment, because every executable therein is owned by a
+	# nonzero GID.
+	[[ "${EUID}" -ne "0" || "${PORTAGE_INST_UID}" -ne "0" ]] && return
+
+	local d f found=()
+
+	for d in "${ED%/}/opt/bin" "${ED%/}/bin"  "${ED%/}/usr/bin" \
+							   "${ED%/}/sbin" "${ED%/}/usr/sbin"; do
+		[[ -d "${d}" ]] || continue
+
+		# Read the results of the "find" command into the "found" array.
+		#
+		# Use -L to catch symlinks whose targets are vulnerable,
+		# even though it won't catch ABSOLUTE symlinks until the package
+		# is RE-installed (the first time around, the target won't exist).
+		#
+		# We match the GID and not the name "root" here because (for
+		# example) on FreeBSD, the superuser group is "wheel".
+		#
+		# We don't make an exception for setguid executables here, because
+		# a group-writable setguid executable is likely a mistake. By
+		# altering the contents of the executable, a member of the group
+		# can allow everyone (i.e. the people running it) to obtain the
+		# full privileges available to that group. While only existing
+		# group members can make that choice, it's a decision usually
+		# limited to the system administrator.
+		while read -r -d '' f; do
+			found+=( "${f}" )
+		done < <(find -L "${d}"   \
+					-maxdepth 1   \
+					-type f       \
+					-perm /g+w    \
+					! -gid 0      \
+					-print0)
+	done
+
+	if [[ ${found[@]} ]]; then
+		eqawarn "system executables group-writable by nonzero gid:"
+		for f in "${found[@]}"; do
+			# Strip off the leading destdir before outputting the path.
+			eqawarn "  ${f#${D%/}}"
+		done
+	fi
+}
+
+bad_bin_group_write_check
+:
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2018-08-07 18:49 Zac Medico
  0 siblings, 0 replies; 120+ messages in thread
From: Zac Medico @ 2018-08-07 18:49 UTC (permalink / raw
  To: gentoo-commits
commit:     04e71a831bc42f2a0de1694dd2013eac0414e007
Author:     Michael Orlitzky <mjo <AT> gentoo <DOT> org>
AuthorDate: Tue Aug  7 16:46:03 2018 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Tue Aug  7 18:39:26 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=04e71a83
bin/install-qa-check.d: add new 90bad-bin-owner QA check.
System executables that are not owned by root pose a security
risk. The owner of the executable is free to modify it at any time;
so, for example, he can change a daemon's behavior to make it
malicious before the next time the service is started (usually by
root).
On a "normal" system, the superuser should own every system executable
(even setuid ones, for security reasons). This commit adds a new
install-time check that reports any such binaries with a QA
warning. To avoid false positives, non-"normal" systems (like prefix)
are skipped at the moment.
Bug: https://bugs.gentoo.org/629398
 bin/install-qa-check.d/90bad-bin-owner | 48 ++++++++++++++++++++++++++++++++++
 1 file changed, 48 insertions(+)
diff --git a/bin/install-qa-check.d/90bad-bin-owner b/bin/install-qa-check.d/90bad-bin-owner
new file mode 100644
index 000000000..c3ee30746
--- /dev/null
+++ b/bin/install-qa-check.d/90bad-bin-owner
@@ -0,0 +1,48 @@
+# Copyright 1999-2018 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+
+bad_bin_owner_check() {
+	# Warn about globally-installed executables (in /bin, /usr/bin, /sbin,
+	# /usr/sbin, or /opt/bin) that are owned by a nonzero UID.
+
+	# This check doesn't work on non-root prefix installations at
+	# the moment, because every executable therein is owned by a
+	# nonzero UID.
+	[[ "${EUID}" -ne "0" || "${PORTAGE_INST_UID}" -ne "0" ]] && return
+
+	local d f found=()
+
+	for d in "${ED%/}/opt/bin" "${ED%/}/bin"  "${ED%/}/usr/bin" \
+							   "${ED%/}/sbin" "${ED%/}/usr/sbin"; do
+		[[ -d "${d}" ]] || continue
+
+		# Read the results of the "find" command into the "found" bash array.
+		#
+		# Use -L to catch symlinks whose targets are owned by a non-root user,
+		# even though it won't catch ABSOLUTE symlinks until the package
+		# is RE-installed (the first time around, the target won't exist).
+		#
+		# We do want to list non-superuser setuid executables, because
+		# they can be exploited. The owner can simply wipe the setuid
+		# bit, and then alter the contents of the file. The superuser
+		# will then have a time bomb in his $PATH.
+		while read -r -d '' f; do
+			found+=( "${f}" )
+		done < <(find -L "${d}"   \
+					-maxdepth 1   \
+					-type f       \
+					! -uid 0      \
+					-print0)
+	done
+
+	if [[ ${found[@]} ]]; then
+		eqawarn "system executables owned by nonzero uid:"
+		for f in "${found[@]}"; do
+			# Strip off the leading destdir before outputting the path.
+			eqawarn "  ${f#${D%/}}"
+		done
+	fi
+}
+
+bad_bin_owner_check
+:
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2018-08-04 19:36 Zac Medico
  0 siblings, 0 replies; 120+ messages in thread
From: Zac Medico @ 2018-08-04 19:36 UTC (permalink / raw
  To: gentoo-commits
commit:     12aa832c91a6f2c2faee5a2e839b7f1ed5a0ee6e
Author:     Francesco Turco <fturco <AT> fastmail <DOT> fm>
AuthorDate: Sat Aug  4 18:47:40 2018 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat Aug  4 19:34:51 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=12aa832c
install-qa-check.d: fix hardened <AT> g.o e-mail address
Closes: https://github.com/gentoo/portage/pull/350
 bin/install-qa-check.d/10executable-issues | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/install-qa-check.d/10executable-issues b/bin/install-qa-check.d/10executable-issues
index 8a2c8e875..6b33d281d 100644
--- a/bin/install-qa-check.d/10executable-issues
+++ b/bin/install-qa-check.d/10executable-issues
@@ -128,7 +128,7 @@ elf_check() {
 		eqawarn
 		eqawarn " Please include the following list of files in your report:"
 		eqawarn " Note: Bugs should be filed for the respective maintainers"
-		eqawarn " of the package in question and not hardened@g.o."
+		eqawarn " of the package in question and not hardened@gentoo.org."
 		eqawarn "${f}"
 		__vecho -ne '\n'
 		die_msg="${die_msg} execstacks"
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2018-07-28  6:41 Zac Medico
  0 siblings, 0 replies; 120+ messages in thread
From: Zac Medico @ 2018-07-28  6:41 UTC (permalink / raw
  To: gentoo-commits
commit:     50283f1abb77f0785ab86d41ad70d76df4e399be
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Wed Jul 25 19:43:24 2018 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Sat Jul 28 06:31:56 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=50283f1a
install-qa-check.d/60pngfix: parallel support (bug 630292)
If xargs supports the --max-procs option then use the makeopts_jobs
function from helper-functions.sh to generate a --max-procs argument.
Use xargs -L 1 to limit the number of png files per pngfix process,
in order to ensure that enough processes are spawned, since otherwise
xargs minimizes the number of processes spawned. A benchmark with
flightgear-data-2018.2.1 shows that larger values of -L only decrease
performance.
Bug: https://bugs.gentoo.org/630292
Reviewed-by: Lars Wendler <polynomial-c <AT> gentoo.org>
Reviewed-by: Mike Gilbert <floppym <AT> gentoo.org>
 bin/install-qa-check.d/60pngfix | 14 ++++++++++++--
 1 file changed, 12 insertions(+), 2 deletions(-)
diff --git a/bin/install-qa-check.d/60pngfix b/bin/install-qa-check.d/60pngfix
index 8d53040b6..b69c55614 100644
--- a/bin/install-qa-check.d/60pngfix
+++ b/bin/install-qa-check.d/60pngfix
@@ -1,7 +1,17 @@
 # Check for issues with PNG files
 
+source "${PORTAGE_BIN_PATH}/helper-functions.sh" || exit 1
+
 pngfix_check() {
-	local pngfix=$(type -P pngfix)
+	local chunksize=1 jobs pngfix=$(type -P pngfix) xargs=(${XARGS})
+
+	if "${xargs[@]}" --help | grep -q -- --max-procs=; then
+		jobs=$(makeopts_jobs)
+		if [[ ${jobs} -gt 1 ]]; then
+			xargs+=("--max-procs=${jobs}" -L "${chunksize}")
+		fi
+	fi
+
 	if [[ -n ${pngfix} ]] ; then
 		local pngout=()
 		local next
@@ -25,7 +35,7 @@ pngfix_check() {
 				fi
 				eqawarn "   ${pngout[@]:7}: ${error}"
 			fi
-		done < <(find "${ED}" -type f -name '*.png' -exec "${pngfix}" {} +)
+		done < <(find "${ED}" -type f -name '*.png' -print0 | "${xargs[@]}" -0 "${pngfix}")
 	fi
 }
 
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2018-01-26  6:40 Michał Górny
  0 siblings, 0 replies; 120+ messages in thread
From: Michał Górny @ 2018-01-26  6:40 UTC (permalink / raw
  To: gentoo-commits
commit:     a03d0f3d4b6aa58df7b6f9dd9d76c45128455ec1
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Thu Jan 25 09:07:36 2018 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Fri Jan 26 06:40:02 2018 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=a03d0f3d
install-qa-check.d: Scan build log for CMake unused var warnings
Scan build log and report verbosely CMake warnings about unused
variables. This is a quite common problem, yet currently it is hard
to notice it since the warning is mixed with src_configure() output.
Repeat it verbosely after the install.
This check outputs warnings such as:
 * One or more CMake variables were not used by the project:
 *   CMAKE_USER_MAKE_RULES_OVERRIDE
Reviewed-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/install-qa-check.d/90cmake-warnings | 28 ++++++++++++++++++++++++++++
 1 file changed, 28 insertions(+)
diff --git a/bin/install-qa-check.d/90cmake-warnings b/bin/install-qa-check.d/90cmake-warnings
new file mode 100644
index 000000000..a6e901efc
--- /dev/null
+++ b/bin/install-qa-check.d/90cmake-warnings
@@ -0,0 +1,28 @@
+# Check for CMake invalid option warnings
+
+cmake_warn_check() {
+	if [[ -n ${PORTAGE_LOG_FILE} && -r ${PORTAGE_LOG_FILE} ]] ; then
+		local cat=cat
+		[[ ${PORTAGE_LOG_FILE} == *.gz ]] && cat=zcat
+
+		local vars=()
+		while read -r l; do
+			vars+=( "${l}" )
+		done < <( "${cat}" "${PORTAGE_LOG_FILE}" \
+			| sed -n -e '/Manually-specified variables were not used by the project/,/^--/{/^    /p}' \
+			| LC_ALL=C sort -u)
+
+		if [[ ${vars} ]]; then
+			eqawarn "One or more CMake variables were not used by the project:"
+			local v
+			for v in "${vars[@]}"; do
+				eqawarn "  ${v}"
+			done
+		fi
+	fi
+}
+
+cmake_warn_check
+: # guarantee successful exit
+
+# vim:ft=sh
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2017-10-16 17:21 Zac Medico
  0 siblings, 0 replies; 120+ messages in thread
From: Zac Medico @ 2017-10-16 17:21 UTC (permalink / raw
  To: gentoo-commits
commit:     730a867c1050937c82c775d7678a616c7b9546e6
Author:     Felix Janda <felix.janda <AT> posteo <DOT> de>
AuthorDate: Mon Oct 16 03:51:37 2017 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon Oct 16 17:20:04 2017 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=730a867c
install-qa-check.d/10ignored-flags: fix LDFLAGS check (bug 455232)
Since binutils-2.23.51.0.9+ defaults to hash-style=gnu, use
a __gentoo_check_ldflags__ symbol instead. The check is now
enabled by adding "-Wl,--defsym=__gentoo_check_ldflags__=0"
to LDFLAGS. The symbol will be automatically removed when
the binary is stripped.
Bug: https://bugs.gentoo.org/455232
Acked-by: Brian Dolbec <dolsen <AT> gentoo.org>
 bin/install-qa-check.d/10ignored-flags | 5 +++--
 1 file changed, 3 insertions(+), 2 deletions(-)
diff --git a/bin/install-qa-check.d/10ignored-flags b/bin/install-qa-check.d/10ignored-flags
index 7aa9eb695..28aec6787 100644
--- a/bin/install-qa-check.d/10ignored-flags
+++ b/bin/install-qa-check.d/10ignored-flags
@@ -64,9 +64,10 @@ ignored_flag_check() {
 	fi
 
 	# Check for files built without respecting LDFLAGS
-	if [[ "${LDFLAGS}" == *,--hash-style=gnu* ]] && \
+	if [[ "${LDFLAGS}" == *,--defsym=__gentoo_check_ldflags__* ]] && \
 		! has binchecks ${RESTRICT} ; then
-		f=$(scanelf -qyRF '#k%p' -k .hash "${ED}")
+		f=$(LC_ALL=C comm -3 <(scanelf -qyRF '#k%p' -k .dynsym "${ED}" | LC_ALL=C sort) \
+			<(scanelf -qyRF '#s%p' -s __gentoo_check_ldflags__ "${ED}" | LC_ALL=C sort))
 		if [[ -n ${f} ]] ; then
 			echo "${f}" > "${T}"/scanelf-ignored-LDFLAGS.log
 			if [ "${QA_STRICT_FLAGS_IGNORED-unset}" = unset ] ; then
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2017-08-02  7:24 Zac Medico
  0 siblings, 0 replies; 120+ messages in thread
From: Zac Medico @ 2017-08-02  7:24 UTC (permalink / raw
  To: gentoo-commits
commit:     864585bc32dc0ccad8f53aec03d378d37b385c21
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Tue Aug  1 05:04:29 2017 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Wed Aug  2 07:22:12 2017 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=864585bc
multilib-strict: disable recursion into subdirectories (bug 424423)
Disable recursion into subdirectories, in order to avoid false-positives.
The MULTILIB_STRICT_EXEMPT variable only served to filter false-positives
that were triggered by recursion, so it will no longer be needed.
X-Gentoo-bug: 424423
X-Gentoo-bug-url: https://bugs.gentoo.org/show_bug.cgi?id=424423
Reviewed-by: Manuel Rüger <mrueg <AT> gentoo.org>
 bin/install-qa-check.d/80multilib-strict | 7 +++----
 1 file changed, 3 insertions(+), 4 deletions(-)
diff --git a/bin/install-qa-check.d/80multilib-strict b/bin/install-qa-check.d/80multilib-strict
index f944be9e6..afd223250 100644
--- a/bin/install-qa-check.d/80multilib-strict
+++ b/bin/install-qa-check.d/80multilib-strict
@@ -6,14 +6,13 @@ multilib_strict_check() {
 	then
 		rm -f "${T}/multilib-strict.log"
 		local abort=no dir file
-		MULTILIB_STRICT_EXEMPT=$(echo ${MULTILIB_STRICT_EXEMPT} | sed -e 's:\([(|)]\):\\\1:g')
 		for dir in ${MULTILIB_STRICT_DIRS} ; do
 			[[ -d ${ED}/${dir} ]] || continue
-			for file in $(find ${ED}/${dir} -type f | grep -v "^${ED}/${dir}/${MULTILIB_STRICT_EXEMPT}"); do
-				if file ${file} | egrep -q "${MULTILIB_STRICT_DENY}" ; then
+			while read -r -d '' file; do
+				if file "${file}" | grep -Eq "${MULTILIB_STRICT_DENY}" ; then
 					echo "${file#${ED}//}" >> "${T}/multilib-strict.log"
 				fi
-			done
+			done < <(find "${ED}/${dir}" -maxdepth 1 -type f -print0)
 		done
 
 		if [[ -s ${T}/multilib-strict.log ]] ; then
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2016-06-02  6:12 Zac Medico
  0 siblings, 0 replies; 120+ messages in thread
From: Zac Medico @ 2016-06-02  6:12 UTC (permalink / raw
  To: gentoo-commits
commit:     e7fb57859b18a1c5ef3fb22d71ac8a6bf74e5375
Author:     Zac Medico <zmedico <AT> gentoo <DOT> org>
AuthorDate: Thu Jun  2 06:10:40 2016 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Thu Jun  2 06:10:40 2016 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=e7fb5785
install-qa-check.d/60openrc: validate bash for openrc-run shebangs
 bin/install-qa-check.d/60openrc | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/install-qa-check.d/60openrc b/bin/install-qa-check.d/60openrc
index 28e3bbf..0ab27f6 100644
--- a/bin/install-qa-check.d/60openrc
+++ b/bin/install-qa-check.d/60openrc
@@ -11,7 +11,7 @@ openrc_check() {
 			[[ ! -e ${i} ]] && continue
 			if [[ ${d} == /etc/init.d && ${i} != *.sh ]] ; then
 				# skip non-shell-script for bug #451386
-				[[ $(head -n1 "${i}") =~ ^#!.*[[:space:]/](runscript|sh)$ ]] || continue
+				[[ $(head -n1 "${i}") =~ ^#!.*[[:space:]/](openrc-run|runscript|sh)$ ]] || continue
 				if [[ $(head -n1 "${i}") == '#!/sbin/runscript' ]] ; then
 					eqawarn "QA Notice: #!/sbin/runscript is deprecated, use #!/sbin/openrc-run instead:"
 					while read -r ;
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2016-06-02  1:40 Zac Medico
  0 siblings, 0 replies; 120+ messages in thread
From: Zac Medico @ 2016-06-02  1:40 UTC (permalink / raw
  To: gentoo-commits
commit:     6296c4363abf36276bc49a28cd4635437757aa6e
Author:     Austin English <wizardedit <AT> gentoo <DOT> org>
AuthorDate: Wed Jun  1 07:00:38 2016 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Thu Jun  2 01:38:21 2016 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=6296c436
install-qa-check.d/60openrc: make sure initscripts aren't using #!/sbin/runscript
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
 bin/install-qa-check.d/60openrc | 6 ++++++
 1 file changed, 6 insertions(+)
diff --git a/bin/install-qa-check.d/60openrc b/bin/install-qa-check.d/60openrc
index 1e56b2f..28e3bbf 100644
--- a/bin/install-qa-check.d/60openrc
+++ b/bin/install-qa-check.d/60openrc
@@ -12,6 +12,12 @@ openrc_check() {
 			if [[ ${d} == /etc/init.d && ${i} != *.sh ]] ; then
 				# skip non-shell-script for bug #451386
 				[[ $(head -n1 "${i}") =~ ^#!.*[[:space:]/](runscript|sh)$ ]] || continue
+				if [[ $(head -n1 "${i}") == '#!/sbin/runscript' ]] ; then
+					eqawarn "QA Notice: #!/sbin/runscript is deprecated, use #!/sbin/openrc-run instead:"
+					while read -r ;
+						do eqawarn "   ${REPLY}"
+					done <<< "${i//${ED}}"
+				fi
 			fi
 			bash -n "${i}" || die "The init.d file has syntax errors: ${i}"
 		done
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2016-05-12 22:09 Mike Frysinger
  0 siblings, 0 replies; 120+ messages in thread
From: Mike Frysinger @ 2016-05-12 22:09 UTC (permalink / raw
  To: gentoo-commits
commit:     9266e8e8d5709b9046e085baf3521a9e7a744d5b
Author:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
AuthorDate: Thu May 12 22:08:46 2016 +0000
Commit:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
CommitDate: Thu May 12 22:08:46 2016 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=9266e8e8
qa-checks: executable-issues: improve logic & output
Use more robust shell styles for parsing strings/output, and change
the QA log output to include the actual failing rpaths.  This helps
in debugging/tracking down problems.
X-Gentoo-Bug: 582524
X-Gentoo-Bug-URL: https://bugs.gentoo.org/582524
 bin/install-qa-check.d/10executable-issues | 18 +++++++++---------
 1 file changed, 9 insertions(+), 9 deletions(-)
diff --git a/bin/install-qa-check.d/10executable-issues b/bin/install-qa-check.d/10executable-issues
index 066f150..b52cc93 100644
--- a/bin/install-qa-check.d/10executable-issues
+++ b/bin/install-qa-check.d/10executable-issues
@@ -22,26 +22,26 @@ elf_check() {
 	#      that directory won't exist on the target system.
 	#   3) Null paths are banned because the loader will search $PWD when
 	#      it finds null paths.
-	local forbidden_dirs="${PORTAGE_BUILDDIR}"
-	if [[ -n "${ROOT}" && "${ROOT}" != "/" ]]; then
-		forbidden_dirs+=" ${ROOT}"
+	local forbidden_dirs=( "${PORTAGE_BUILDDIR}" )
+	if [[ "${ROOT:-/}" != "/" ]]; then
+		forbidden_dirs+=( "${ROOT}" )
 	fi
 	local dir l rpath_files=$(scanelf -F '%F:%r' -qBR "${ED}")
 	f=""
-	for dir in ${forbidden_dirs}; do
-		for l in $(echo "${rpath_files}" | grep -E ":${dir}|::|: "); do
-			f+="  ${l%%:*}\n"
+	for dir in "${forbidden_dirs[@]}"; do
+		while read l; do
+			f+="  ${l/:/\n    RPATH: }\n"
 			if ! has stricter ${FEATURES}; then
 				__vecho "Auto fixing rpaths for ${l%%:*}"
 				TMPDIR="${dir}" scanelf -BXr "${l%%:*}" -o /dev/null
 			fi
-		done
+		done < <(echo "${rpath_files}" | grep -F -e ":${dir}" -e "::" -e ": ")
 	done
 
 	# Reject set*id binaries with $ORIGIN in RPATH #260331
 	x=$(
-		find "${ED}" -type f \( -perm -u+s -o -perm -g+s \) -print0 | \
-		xargs -0 scanelf -qyRF '%r %p' | grep '$ORIGIN'
+		find "${ED}" -type f '(' -perm -u+s -o -perm -g+s ')' \
+		  -exec scanelf -qyRF '%r %p' {} + | grep '$ORIGIN'
 	)
 
 	# Print QA notice.
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2016-05-12 21:36 Mike Frysinger
  0 siblings, 0 replies; 120+ messages in thread
From: Mike Frysinger @ 2016-05-12 21:36 UTC (permalink / raw
  To: gentoo-commits
commit:     04dd7923eedec4103c4ff52f382b5af68b4364b4
Author:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
AuthorDate: Thu May 12 21:35:13 2016 +0000
Commit:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
CommitDate: Thu May 12 21:35:13 2016 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=04dd7923
qa-checks: change "herd" to "maintainer"
 bin/install-qa-check.d/10executable-issues | 2 +-
 bin/install-qa-check.d/90gcc-warnings      | 4 ++--
 2 files changed, 3 insertions(+), 3 deletions(-)
diff --git a/bin/install-qa-check.d/10executable-issues b/bin/install-qa-check.d/10executable-issues
index 10d3c71..066f150 100644
--- a/bin/install-qa-check.d/10executable-issues
+++ b/bin/install-qa-check.d/10executable-issues
@@ -49,7 +49,7 @@ elf_check() {
 		__vecho -ne '\n'
 		eqawarn "QA Notice: The following files contain insecure RUNPATHs"
 		eqawarn " Please file a bug about this at http://bugs.gentoo.org/"
-		eqawarn " with the maintaining herd of the package."
+		eqawarn " with the maintainer of the package."
 		eqawarn "${f}${f:+${x:+\n}}${x}"
 		__vecho -ne '\n'
 		if [[ -n ${x} ]] || has stricter ${FEATURES} ; then
diff --git a/bin/install-qa-check.d/90gcc-warnings b/bin/install-qa-check.d/90gcc-warnings
index 43f9498..a160436 100644
--- a/bin/install-qa-check.d/90gcc-warnings
+++ b/bin/install-qa-check.d/90gcc-warnings
@@ -99,7 +99,7 @@ gcc_warn_check() {
 				eerror "${f}"
 				eerror
 				eerror " Please file a bug about this at http://bugs.gentoo.org/"
-				eerror " with the maintaining herd of the package."
+				eerror " with the maintainer of the package."
 				eerror
 			else
 				__vecho -ne '\n'
@@ -137,7 +137,7 @@ gcc_warn_check() {
 				eerror "${f}"
 				eerror
 				eerror " Please file a bug about this at http://bugs.gentoo.org/"
-				eerror " with the maintaining herd of the package."
+				eerror " with the maintainer of the package."
 				eerror
 			else
 				__vecho -ne '\n'
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2016-05-11 17:55 Mike Frysinger
  0 siblings, 0 replies; 120+ messages in thread
From: Mike Frysinger @ 2016-05-11 17:55 UTC (permalink / raw
  To: gentoo-commits
commit:     91e1dd94c1615bf97d5bc42dac4d64876919e768
Author:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
AuthorDate: Wed May 11 17:53:40 2016 +0000
Commit:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
CommitDate: Wed May 11 17:53:40 2016 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=91e1dd94
qa: gcc-warnings: force text mode w/grep
Newer versions of grep will flag non-ASCII output (e.g. UTF-8 encoded)
as binary when run in the C locale.  Force it into text mode to avoid
that otherwise the QA warning is simply:
 * QA Notice: Package triggers severe warnings which indicate that it
 *            may exhibit random runtime failures.
 * Binary file /var/log/portage/net-fs:netatalk-3.1.8:20160511-173717.log matches
 bin/install-qa-check.d/90gcc-warnings | 6 ++++--
 1 file changed, 4 insertions(+), 2 deletions(-)
diff --git a/bin/install-qa-check.d/90gcc-warnings b/bin/install-qa-check.d/90gcc-warnings
index bd82cab..43f9498 100644
--- a/bin/install-qa-check.d/90gcc-warnings
+++ b/bin/install-qa-check.d/90gcc-warnings
@@ -81,8 +81,10 @@ gcc_warn_check() {
 		local grep_cmd=grep
 		[[ $PORTAGE_LOG_FILE = *.gz ]] && grep_cmd=zgrep
 
-		# force C locale to work around slow unicode locales #160234
-		f=$(LC_CTYPE=C LC_COLLATE=C "${grep_cmd}" -E "${joined_msgs}" "${PORTAGE_LOG_FILE}" | uniq)
+		# Force C locale to work around slow multibyte locales. #160234
+		# Force text mode as newer grep will treat non-ASCII (e.g. UTF-8) as
+		# binary when we run in the C locale.
+		f=$(LC_CTYPE=C LC_COLLATE=C "${grep_cmd}" -E -a "${joined_msgs}" "${PORTAGE_LOG_FILE}" | uniq)
 		if [[ -n ${f} ]] ; then
 			abort="yes"
 			# for now, don't make this fatal (see bug #337031)
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2015-05-26  3:46 Mike Frysinger
  0 siblings, 0 replies; 120+ messages in thread
From: Mike Frysinger @ 2015-05-26  3:46 UTC (permalink / raw
  To: gentoo-commits
commit:     efa5c5e7b7a5ef7b4533dfe3bd6befc767b7b34a
Author:     Mike Frysinger <vapier <AT> chromium <DOT> org>
AuthorDate: Tue May 26 03:42:27 2015 +0000
Commit:     Mike Frysinger <vapier <AT> gentoo <DOT> org>
CommitDate: Tue May 26 03:46:31 2015 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=efa5c5e7
install-qa-check.d: tweak scanelf checks
Rather than have a function whose entire body is indented by a scanelf
existence check, do the check at the top and return early.  This keeps
the indentation from getting too out of hand.
(Use `git log -p -1 -w` to see actual changed lines.)
 bin/install-qa-check.d/10executable-issues | 248 +++++++++++++++--------------
 bin/install-qa-check.d/80libraries         | 130 +++++++--------
 2 files changed, 193 insertions(+), 185 deletions(-)
diff --git a/bin/install-qa-check.d/10executable-issues b/bin/install-qa-check.d/10executable-issues
index 5c80660..10d3c71 100644
--- a/bin/install-qa-check.d/10executable-issues
+++ b/bin/install-qa-check.d/10executable-issues
@@ -2,141 +2,143 @@
 # text relocations, executable stacks
 
 elf_check() {
-	if type -P scanelf > /dev/null && ! has binchecks ${RESTRICT}; then
-		local insecure_rpath=0 tmp_quiet=${PORTAGE_QUIET}
-		local f x
+	if ! type -P scanelf >/dev/null || has binchecks ${RESTRICT}; then
+		return
+	fi
 
-		# display warnings when using stricter because we die afterwards
-		if has stricter ${FEATURES} ; then
-			local PORTAGE_QUIET
-		fi
+	local insecure_rpath=0 tmp_quiet=${PORTAGE_QUIET}
+	local f x
 
-		# Make sure we disallow insecure RUNPATH/RPATHs.
-		#   1) References to PORTAGE_BUILDDIR are banned because it's a
-		#      security risk. We don't want to load files from a
-		#      temporary directory.
-		#   2) If ROOT != "/", references to ROOT are banned because
-		#      that directory won't exist on the target system.
-		#   3) Null paths are banned because the loader will search $PWD when
-		#      it finds null paths.
-		local forbidden_dirs="${PORTAGE_BUILDDIR}"
-		if [[ -n "${ROOT}" && "${ROOT}" != "/" ]]; then
-			forbidden_dirs+=" ${ROOT}"
-		fi
-		local dir l rpath_files=$(scanelf -F '%F:%r' -qBR "${ED}")
-		f=""
-		for dir in ${forbidden_dirs}; do
-			for l in $(echo "${rpath_files}" | grep -E ":${dir}|::|: "); do
-				f+="  ${l%%:*}\n"
-				if ! has stricter ${FEATURES}; then
-					__vecho "Auto fixing rpaths for ${l%%:*}"
-					TMPDIR="${dir}" scanelf -BXr "${l%%:*}" -o /dev/null
-				fi
-			done
+	# display warnings when using stricter because we die afterwards
+	if has stricter ${FEATURES} ; then
+		local PORTAGE_QUIET
+	fi
+
+	# Make sure we disallow insecure RUNPATH/RPATHs.
+	#   1) References to PORTAGE_BUILDDIR are banned because it's a
+	#      security risk. We don't want to load files from a
+	#      temporary directory.
+	#   2) If ROOT != "/", references to ROOT are banned because
+	#      that directory won't exist on the target system.
+	#   3) Null paths are banned because the loader will search $PWD when
+	#      it finds null paths.
+	local forbidden_dirs="${PORTAGE_BUILDDIR}"
+	if [[ -n "${ROOT}" && "${ROOT}" != "/" ]]; then
+		forbidden_dirs+=" ${ROOT}"
+	fi
+	local dir l rpath_files=$(scanelf -F '%F:%r' -qBR "${ED}")
+	f=""
+	for dir in ${forbidden_dirs}; do
+		for l in $(echo "${rpath_files}" | grep -E ":${dir}|::|: "); do
+			f+="  ${l%%:*}\n"
+			if ! has stricter ${FEATURES}; then
+				__vecho "Auto fixing rpaths for ${l%%:*}"
+				TMPDIR="${dir}" scanelf -BXr "${l%%:*}" -o /dev/null
+			fi
 		done
+	done
 
-		# Reject set*id binaries with $ORIGIN in RPATH #260331
-		x=$(
-			find "${ED}" -type f \( -perm -u+s -o -perm -g+s \) -print0 | \
-			xargs -0 scanelf -qyRF '%r %p' | grep '$ORIGIN'
-		)
+	# Reject set*id binaries with $ORIGIN in RPATH #260331
+	x=$(
+		find "${ED}" -type f \( -perm -u+s -o -perm -g+s \) -print0 | \
+		xargs -0 scanelf -qyRF '%r %p' | grep '$ORIGIN'
+	)
 
-		# Print QA notice.
-		if [[ -n ${f}${x} ]] ; then
-			__vecho -ne '\n'
-			eqawarn "QA Notice: The following files contain insecure RUNPATHs"
-			eqawarn " Please file a bug about this at http://bugs.gentoo.org/"
-			eqawarn " with the maintaining herd of the package."
-			eqawarn "${f}${f:+${x:+\n}}${x}"
-			__vecho -ne '\n'
-			if [[ -n ${x} ]] || has stricter ${FEATURES} ; then
-				insecure_rpath=1
-			fi
+	# Print QA notice.
+	if [[ -n ${f}${x} ]] ; then
+		__vecho -ne '\n'
+		eqawarn "QA Notice: The following files contain insecure RUNPATHs"
+		eqawarn " Please file a bug about this at http://bugs.gentoo.org/"
+		eqawarn " with the maintaining herd of the package."
+		eqawarn "${f}${f:+${x:+\n}}${x}"
+		__vecho -ne '\n'
+		if [[ -n ${x} ]] || has stricter ${FEATURES} ; then
+			insecure_rpath=1
 		fi
+	fi
 
-		# TEXTRELs are baaaaaaaad
-		# Allow devs to mark things as ignorable ... e.g. things that are
-		# binary-only and upstream isn't cooperating (nvidia-glx) ... we
-		# allow ebuild authors to set QA_TEXTRELS_arch and QA_TEXTRELS ...
-		# the former overrides the latter ... regexes allowed ! :)
-		local qa_var="QA_TEXTRELS_${ARCH/-/_}"
-		[[ -n ${!qa_var} ]] && QA_TEXTRELS=${!qa_var}
-		[[ -n ${QA_STRICT_TEXTRELS} ]] && QA_TEXTRELS=""
-		export QA_TEXTRELS="${QA_TEXTRELS} lib*/modules/*.ko"
-		f=$(scanelf -qyRF '%t %p' "${ED}" | grep -v 'usr/lib/debug/')
-		if [[ -n ${f} ]] ; then
-			scanelf -qyRAF '%T %p' "${PORTAGE_BUILDDIR}"/ &> "${T}"/scanelf-textrel.log
-			__vecho -ne '\n'
-			eqawarn "QA Notice: The following files contain runtime text relocations"
-			eqawarn " Text relocations force the dynamic linker to perform extra"
-			eqawarn " work at startup, waste system resources, and may pose a security"
-			eqawarn " risk.  On some architectures, the code may not even function"
-			eqawarn " properly, if at all."
-			eqawarn " For more information, see:"
-			eqawarn
-			eqawarn "   https://wiki.gentoo.org/wiki/Hardened/HOWTO_locate_and_fix_textrels"
-			eqawarn
-			eqawarn " Please include the following list of files in your report:"
-			eqawarn "${f}"
-			__vecho -ne '\n'
-			die_msg="${die_msg} textrels,"
-			sleep 1
-		fi
+	# TEXTRELs are baaaaaaaad
+	# Allow devs to mark things as ignorable ... e.g. things that are
+	# binary-only and upstream isn't cooperating (nvidia-glx) ... we
+	# allow ebuild authors to set QA_TEXTRELS_arch and QA_TEXTRELS ...
+	# the former overrides the latter ... regexes allowed ! :)
+	local qa_var="QA_TEXTRELS_${ARCH/-/_}"
+	[[ -n ${!qa_var} ]] && QA_TEXTRELS=${!qa_var}
+	[[ -n ${QA_STRICT_TEXTRELS} ]] && QA_TEXTRELS=""
+	export QA_TEXTRELS="${QA_TEXTRELS} lib*/modules/*.ko"
+	f=$(scanelf -qyRF '%t %p' "${ED}" | grep -v 'usr/lib/debug/')
+	if [[ -n ${f} ]] ; then
+		scanelf -qyRAF '%T %p' "${PORTAGE_BUILDDIR}"/ &> "${T}"/scanelf-textrel.log
+		__vecho -ne '\n'
+		eqawarn "QA Notice: The following files contain runtime text relocations"
+		eqawarn " Text relocations force the dynamic linker to perform extra"
+		eqawarn " work at startup, waste system resources, and may pose a security"
+		eqawarn " risk.  On some architectures, the code may not even function"
+		eqawarn " properly, if at all."
+		eqawarn " For more information, see:"
+		eqawarn
+		eqawarn "   https://wiki.gentoo.org/wiki/Hardened/HOWTO_locate_and_fix_textrels"
+		eqawarn
+		eqawarn " Please include the following list of files in your report:"
+		eqawarn "${f}"
+		__vecho -ne '\n'
+		die_msg="${die_msg} textrels,"
+		sleep 1
+	fi
 
-		# Also, executable stacks only matter on linux (and just glibc atm ...)
-		f=""
+	# Also, executable stacks only matter on linux (and just glibc atm ...)
+	f=""
+	case ${CTARGET:-${CHOST}} in
+		*-linux-gnu*)
+		# Check for files with executable stacks, but only on arches which
+		# are supported at the moment.  Keep this list in sync with
+		# https://wiki.gentoo.org/wiki/Hardened/GNU_stack_quickstart#Arch_Status
 		case ${CTARGET:-${CHOST}} in
-			*-linux-gnu*)
-			# Check for files with executable stacks, but only on arches which
-			# are supported at the moment.  Keep this list in sync with
-			# https://wiki.gentoo.org/wiki/Hardened/GNU_stack_quickstart#Arch_Status
-			case ${CTARGET:-${CHOST}} in
-				arm*|i?86*|ia64*|m68k*|s390*|sh*|x86_64*)
-					# Allow devs to mark things as ignorable ... e.g. things
-					# that are binary-only and upstream isn't cooperating ...
-					# we allow ebuild authors to set QA_EXECSTACK_arch and
-					# QA_EXECSTACK ... the former overrides the latter ...
-					# regexes allowed ! :)
+			arm*|i?86*|ia64*|m68k*|s390*|sh*|x86_64*)
+				# Allow devs to mark things as ignorable ... e.g. things
+				# that are binary-only and upstream isn't cooperating ...
+				# we allow ebuild authors to set QA_EXECSTACK_arch and
+				# QA_EXECSTACK ... the former overrides the latter ...
+				# regexes allowed ! :)
 
-					qa_var="QA_EXECSTACK_${ARCH/-/_}"
-					[[ -n ${!qa_var} ]] && QA_EXECSTACK=${!qa_var}
-					[[ -n ${QA_STRICT_EXECSTACK} ]] && QA_EXECSTACK=""
-					qa_var="QA_WX_LOAD_${ARCH/-/_}"
-					[[ -n ${!qa_var} ]] && QA_WX_LOAD=${!qa_var}
-					[[ -n ${QA_STRICT_WX_LOAD} ]] && QA_WX_LOAD=""
-					export QA_EXECSTACK="${QA_EXECSTACK} lib*/modules/*.ko"
-					export QA_WX_LOAD="${QA_WX_LOAD} lib*/modules/*.ko"
-					f=$(scanelf -qyRAF '%e %p' "${ED}" | grep -v 'usr/lib/debug/')
-					;;
-			esac
-			;;
+				qa_var="QA_EXECSTACK_${ARCH/-/_}"
+				[[ -n ${!qa_var} ]] && QA_EXECSTACK=${!qa_var}
+				[[ -n ${QA_STRICT_EXECSTACK} ]] && QA_EXECSTACK=""
+				qa_var="QA_WX_LOAD_${ARCH/-/_}"
+				[[ -n ${!qa_var} ]] && QA_WX_LOAD=${!qa_var}
+				[[ -n ${QA_STRICT_WX_LOAD} ]] && QA_WX_LOAD=""
+				export QA_EXECSTACK="${QA_EXECSTACK} lib*/modules/*.ko"
+				export QA_WX_LOAD="${QA_WX_LOAD} lib*/modules/*.ko"
+				f=$(scanelf -qyRAF '%e %p' "${ED}" | grep -v 'usr/lib/debug/')
+				;;
 		esac
-		if [[ -n ${f} ]] ; then
-			# One more pass to help devs track down the source
-			scanelf -qyRAF '%e %p' "${PORTAGE_BUILDDIR}"/ &> "${T}"/scanelf-execstack.log
-			__vecho -ne '\n'
-			eqawarn "QA Notice: The following files contain writable and executable sections"
-			eqawarn " Files with such sections will not work properly (or at all!) on some"
-			eqawarn " architectures/operating systems.  A bug should be filed at"
-			eqawarn " http://bugs.gentoo.org/ to make sure the issue is fixed."
-			eqawarn " For more information, see:"
-			eqawarn
-			eqawarn "   https://wiki.gentoo.org/wiki/Hardened/GNU_stack_quickstart"
-			eqawarn
-			eqawarn " Please include the following list of files in your report:"
-			eqawarn " Note: Bugs should be filed for the respective maintainers"
-			eqawarn " of the package in question and not hardened@g.o."
-			eqawarn "${f}"
-			__vecho -ne '\n'
-			die_msg="${die_msg} execstacks"
-			sleep 1
-		fi
+		;;
+	esac
+	if [[ -n ${f} ]] ; then
+		# One more pass to help devs track down the source
+		scanelf -qyRAF '%e %p' "${PORTAGE_BUILDDIR}"/ &> "${T}"/scanelf-execstack.log
+		__vecho -ne '\n'
+		eqawarn "QA Notice: The following files contain writable and executable sections"
+		eqawarn " Files with such sections will not work properly (or at all!) on some"
+		eqawarn " architectures/operating systems.  A bug should be filed at"
+		eqawarn " http://bugs.gentoo.org/ to make sure the issue is fixed."
+		eqawarn " For more information, see:"
+		eqawarn
+		eqawarn "   https://wiki.gentoo.org/wiki/Hardened/GNU_stack_quickstart"
+		eqawarn
+		eqawarn " Please include the following list of files in your report:"
+		eqawarn " Note: Bugs should be filed for the respective maintainers"
+		eqawarn " of the package in question and not hardened@g.o."
+		eqawarn "${f}"
+		__vecho -ne '\n'
+		die_msg="${die_msg} execstacks"
+		sleep 1
+	fi
 
-		if [[ ${insecure_rpath} -eq 1 ]] ; then
-			die "Aborting due to serious QA concerns with RUNPATH/RPATH"
-		elif [[ -n ${die_msg} ]] && has stricter ${FEATURES} ; then
-			die "Aborting due to QA concerns: ${die_msg}"
-		fi
+	if [[ ${insecure_rpath} -eq 1 ]] ; then
+		die "Aborting due to serious QA concerns with RUNPATH/RPATH"
+	elif [[ -n ${die_msg} ]] && has stricter ${FEATURES} ; then
+		die "Aborting due to QA concerns: ${die_msg}"
 	fi
 }
 
diff --git a/bin/install-qa-check.d/80libraries b/bin/install-qa-check.d/80libraries
index 3977bae..8257e5b 100644
--- a/bin/install-qa-check.d/80libraries
+++ b/bin/install-qa-check.d/80libraries
@@ -1,76 +1,82 @@
 # Check for issues with installed libraries
 
-lib_check() {
+scanelf_lib_check() {
 	local f x i j
 
-	if type -P scanelf > /dev/null && ! has binchecks ${RESTRICT}; then
-		# Check for shared libraries lacking SONAMEs
-		local qa_var="QA_SONAME_${ARCH/-/_}"
-		eval "[[ -n \${!qa_var} ]] && QA_SONAME=(\"\${${qa_var}[@]}\")"
-		f=$(scanelf -ByF '%S %p' "${ED}"{,usr/}lib*/lib*.so* | awk '$2 == "" { print }' | sed -e "s:^[[:space:]]${ED}:/:")
-		if [[ -n ${f} ]] ; then
-			echo "${f}" > "${T}"/scanelf-missing-SONAME.log
-			if [[ "${QA_STRICT_SONAME-unset}" == unset ]] ; then
-				if [[ ${#QA_SONAME[@]} -gt 1 ]] ; then
-					for x in "${QA_SONAME[@]}" ; do
-						sed -e "s#^/${x#/}\$##" -i "${T}"/scanelf-missing-SONAME.log
-					done
-				else
-					local shopts=$-
-					set -o noglob
-					for x in ${QA_SONAME} ; do
-						sed -e "s#^/${x#/}\$##" -i "${T}"/scanelf-missing-SONAME.log
-					done
-					set +o noglob
-					set -${shopts}
-				fi
-			fi
-			sed -e "/^\$/d" -i "${T}"/scanelf-missing-SONAME.log
-			f=$(<"${T}"/scanelf-missing-SONAME.log)
-			if [[ -n ${f} ]] ; then
-				__vecho -ne '\n'
-				eqawarn "QA Notice: The following shared libraries lack a SONAME"
-				eqawarn "${f}"
-				__vecho -ne '\n'
-				sleep 1
+	# Check for shared libraries lacking SONAMEs
+	local qa_var="QA_SONAME_${ARCH/-/_}"
+	eval "[[ -n \${!qa_var} ]] && QA_SONAME=(\"\${${qa_var}[@]}\")"
+	f=$(scanelf -ByF '%S %p' "${ED}"{,usr/}lib*/lib*.so* | awk '$2 == "" { print }' | sed -e "s:^[[:space:]]${ED}:/:")
+	if [[ -n ${f} ]] ; then
+		echo "${f}" > "${T}"/scanelf-missing-SONAME.log
+		if [[ "${QA_STRICT_SONAME-unset}" == unset ]] ; then
+			if [[ ${#QA_SONAME[@]} -gt 1 ]] ; then
+				for x in "${QA_SONAME[@]}" ; do
+					sed -e "s#^/${x#/}\$##" -i "${T}"/scanelf-missing-SONAME.log
+				done
 			else
-				rm -f "${T}"/scanelf-missing-SONAME.log
+				local shopts=$-
+				set -o noglob
+				for x in ${QA_SONAME} ; do
+					sed -e "s#^/${x#/}\$##" -i "${T}"/scanelf-missing-SONAME.log
+				done
+				set +o noglob
+				set -${shopts}
 			fi
 		fi
-
-		# Check for shared libraries lacking NEEDED entries
-		qa_var="QA_DT_NEEDED_${ARCH/-/_}"
-		eval "[[ -n \${!qa_var} ]] && QA_DT_NEEDED=(\"\${${qa_var}[@]}\")"
-		f=$(scanelf -ByF '%n %p' "${ED}"{,usr/}lib*/lib*.so* | awk '$2 == "" { print }' | sed -e "s:^[[:space:]]${ED}:/:")
+		sed -e "/^\$/d" -i "${T}"/scanelf-missing-SONAME.log
+		f=$(<"${T}"/scanelf-missing-SONAME.log)
 		if [[ -n ${f} ]] ; then
-			echo "${f}" > "${T}"/scanelf-missing-NEEDED.log
-			if [[ "${QA_STRICT_DT_NEEDED-unset}" == unset ]] ; then
-				if [[ ${#QA_DT_NEEDED[@]} -gt 1 ]] ; then
-					for x in "${QA_DT_NEEDED[@]}" ; do
-						sed -e "s#^/${x#/}\$##" -i "${T}"/scanelf-missing-NEEDED.log
-					done
-				else
-					local shopts=$-
-					set -o noglob
-					for x in ${QA_DT_NEEDED} ; do
-						sed -e "s#^/${x#/}\$##" -i "${T}"/scanelf-missing-NEEDED.log
-					done
-					set +o noglob
-					set -${shopts}
-				fi
-			fi
-			sed -e "/^\$/d" -i "${T}"/scanelf-missing-NEEDED.log
-			f=$(<"${T}"/scanelf-missing-NEEDED.log)
-			if [[ -n ${f} ]] ; then
-				__vecho -ne '\n'
-				eqawarn "QA Notice: The following shared libraries lack NEEDED entries"
-				eqawarn "${f}"
-				__vecho -ne '\n'
-				sleep 1
+			__vecho -ne '\n'
+			eqawarn "QA Notice: The following shared libraries lack a SONAME"
+			eqawarn "${f}"
+			__vecho -ne '\n'
+			sleep 1
+		else
+			rm -f "${T}"/scanelf-missing-SONAME.log
+		fi
+	fi
+
+	# Check for shared libraries lacking NEEDED entries
+	qa_var="QA_DT_NEEDED_${ARCH/-/_}"
+	eval "[[ -n \${!qa_var} ]] && QA_DT_NEEDED=(\"\${${qa_var}[@]}\")"
+	f=$(scanelf -ByF '%n %p' "${ED}"{,usr/}lib*/lib*.so* | awk '$2 == "" { print }' | sed -e "s:^[[:space:]]${ED}:/:")
+	if [[ -n ${f} ]] ; then
+		echo "${f}" > "${T}"/scanelf-missing-NEEDED.log
+		if [[ "${QA_STRICT_DT_NEEDED-unset}" == unset ]] ; then
+			if [[ ${#QA_DT_NEEDED[@]} -gt 1 ]] ; then
+				for x in "${QA_DT_NEEDED[@]}" ; do
+					sed -e "s#^/${x#/}\$##" -i "${T}"/scanelf-missing-NEEDED.log
+				done
 			else
-				rm -f "${T}"/scanelf-missing-NEEDED.log
+				local shopts=$-
+				set -o noglob
+				for x in ${QA_DT_NEEDED} ; do
+					sed -e "s#^/${x#/}\$##" -i "${T}"/scanelf-missing-NEEDED.log
+				done
+				set +o noglob
+				set -${shopts}
 			fi
 		fi
+		sed -e "/^\$/d" -i "${T}"/scanelf-missing-NEEDED.log
+		f=$(<"${T}"/scanelf-missing-NEEDED.log)
+		if [[ -n ${f} ]] ; then
+			__vecho -ne '\n'
+			eqawarn "QA Notice: The following shared libraries lack NEEDED entries"
+			eqawarn "${f}"
+			__vecho -ne '\n'
+			sleep 1
+		else
+			rm -f "${T}"/scanelf-missing-NEEDED.log
+		fi
+	fi
+}
+
+lib_check() {
+	local f x i j
+
+	if type -P scanelf >/dev/null && ! has binchecks ${RESTRICT}; then
+		scanelf_lib_check
 	fi
 
 	# this should help to ensure that all (most?) shared libraries are executable
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2015-05-04  5:09 Zac Medico
  0 siblings, 0 replies; 120+ messages in thread
From: Zac Medico @ 2015-05-04  5:09 UTC (permalink / raw
  To: gentoo-commits
commit:     aacade093c18940c34449f711576c86360056346
Author:     Ryan Hill <rhill <AT> gentoo <DOT> org>
AuthorDate: Mon May  4 05:04:41 2015 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon May  4 05:07:23 2015 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=aacade09
gcc_warn_check: filter grep results with uniq (bug 548438)
X-Gentoo-Bug: 548438
X-Gentoo-Bug-URL: https://bugs.gentoo.org/show_bug.cgi?id=548438
Acked-by: Brian Dolbec <dolsen <AT> gentoo.org>
 bin/install-qa-check.d/90gcc-warnings | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/bin/install-qa-check.d/90gcc-warnings b/bin/install-qa-check.d/90gcc-warnings
index b18651e..bd82cab 100644
--- a/bin/install-qa-check.d/90gcc-warnings
+++ b/bin/install-qa-check.d/90gcc-warnings
@@ -82,7 +82,7 @@ gcc_warn_check() {
 		[[ $PORTAGE_LOG_FILE = *.gz ]] && grep_cmd=zgrep
 
 		# force C locale to work around slow unicode locales #160234
-		f=$(LC_CTYPE=C LC_COLLATE=C "${grep_cmd}" -E "${joined_msgs}" "${PORTAGE_LOG_FILE}")
+		f=$(LC_CTYPE=C LC_COLLATE=C "${grep_cmd}" -E "${joined_msgs}" "${PORTAGE_LOG_FILE}" | uniq)
 		if [[ -n ${f} ]] ; then
 			abort="yes"
 			# for now, don't make this fatal (see bug #337031)
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2015-04-20  5:36 Michał Górny
  0 siblings, 0 replies; 120+ messages in thread
From: Michał Górny @ 2015-04-20  5:36 UTC (permalink / raw
  To: gentoo-commits
commit:     0946bbe9a216513679d74c682d9f82b4aacc93a9
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Mon Apr 20 05:36:02 2015 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Mon Apr 20 05:36:02 2015 +0000
URL:        https://gitweb.gentoo.org/proj/portage.git/commit/?id=0946bbe9
Update URLs in Hardened QA checks
 bin/install-qa-check.d/10executable-issues | 12 +++++++++---
 1 file changed, 9 insertions(+), 3 deletions(-)
diff --git a/bin/install-qa-check.d/10executable-issues b/bin/install-qa-check.d/10executable-issues
index f765749..5c80660 100644
--- a/bin/install-qa-check.d/10executable-issues
+++ b/bin/install-qa-check.d/10executable-issues
@@ -72,7 +72,10 @@ elf_check() {
 			eqawarn " work at startup, waste system resources, and may pose a security"
 			eqawarn " risk.  On some architectures, the code may not even function"
 			eqawarn " properly, if at all."
-			eqawarn " For more information, see http://hardened.gentoo.org/pic-fix-guide.xml"
+			eqawarn " For more information, see:"
+			eqawarn
+			eqawarn "   https://wiki.gentoo.org/wiki/Hardened/HOWTO_locate_and_fix_textrels"
+			eqawarn
 			eqawarn " Please include the following list of files in your report:"
 			eqawarn "${f}"
 			__vecho -ne '\n'
@@ -86,7 +89,7 @@ elf_check() {
 			*-linux-gnu*)
 			# Check for files with executable stacks, but only on arches which
 			# are supported at the moment.  Keep this list in sync with
-			# http://www.gentoo.org/proj/en/hardened/gnu-stack.xml (Arch Status)
+			# https://wiki.gentoo.org/wiki/Hardened/GNU_stack_quickstart#Arch_Status
 			case ${CTARGET:-${CHOST}} in
 				arm*|i?86*|ia64*|m68k*|s390*|sh*|x86_64*)
 					# Allow devs to mark things as ignorable ... e.g. things
@@ -116,7 +119,10 @@ elf_check() {
 			eqawarn " Files with such sections will not work properly (or at all!) on some"
 			eqawarn " architectures/operating systems.  A bug should be filed at"
 			eqawarn " http://bugs.gentoo.org/ to make sure the issue is fixed."
-			eqawarn " For more information, see http://hardened.gentoo.org/gnu-stack.xml"
+			eqawarn " For more information, see:"
+			eqawarn
+			eqawarn "   https://wiki.gentoo.org/wiki/Hardened/GNU_stack_quickstart"
+			eqawarn
 			eqawarn " Please include the following list of files in your report:"
 			eqawarn " Note: Bugs should be filed for the respective maintainers"
 			eqawarn " of the package in question and not hardened@g.o."
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2014-12-02 18:44 Brian Dolbec
  0 siblings, 0 replies; 120+ messages in thread
From: Brian Dolbec @ 2014-12-02 18:44 UTC (permalink / raw
  To: gentoo-commits
commit:     64aae90b942edb4a51ac3eed13dbcbe3e20199fb
Author:     Michael Palimaka <kensington <AT> gentoo <DOT> org>
AuthorDate: Fri Nov 21 16:50:40 2014 +0000
Commit:     Brian Dolbec <brian.dolbec <AT> gmail <DOT> com>
CommitDate: Tue Dec  2 18:40:46 2014 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=64aae90b
install-qa-check.d/90world-writable: fix usage of missing function
Fixes: 6dafdc28897682f7b8c77b7863b5713634974647
Subject: Remove __eqalog & __eqawarnlog
Author: Michał Górny <mgorny <AT> gentoo.org> (Sun 02 Nov 2014 11:16:04 AM PST)
As per Zmedico:
This file also contains an invalid IFS=OLDIFS setting (which should
really be IFS=$OLDIFS).
---
 bin/install-qa-check.d/90world-writable | 7 +++----
 1 file changed, 3 insertions(+), 4 deletions(-)
diff --git a/bin/install-qa-check.d/90world-writable b/bin/install-qa-check.d/90world-writable
index 2b435ac..820683b 100644
--- a/bin/install-qa-check.d/90world-writable
+++ b/bin/install-qa-check.d/90world-writable
@@ -23,13 +23,12 @@ world_writable_check() {
 	if [[ -n ${unsafe_files} ]] ; then
 		eqawarn "QA Notice: Unsafe files detected (set*id and world writable)"
 
-		for x in $unsafe_files ; do
-			__eqawarnlog world-writable-setid "$x"
-		done
+		eqatag -v world-writable-setid $unsafe_files
+
 		die "Unsafe files found in \${D}.  Portage will not install them."
 	fi
 
-	IFS=OLDIFS
+	IFS=$OLDIFS
 	[[ ${prev_shopts} == *f* ]] || set +f
 }
 
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2014-11-19 23:26 Michał Górny
  0 siblings, 0 replies; 120+ messages in thread
From: Michał Górny @ 2014-11-19 23:26 UTC (permalink / raw
  To: gentoo-commits
commit:     64e61b42cc85374f562f15a22a408218c5c5a8f4
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Sun Nov  2 19:15:20 2014 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Wed Nov 19 23:26:34 2014 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=64e61b42
Update the QA checks to new eqatag API
---
 bin/install-qa-check.d/05double-D       | 8 ++++----
 bin/install-qa-check.d/90world-writable | 4 +---
 2 files changed, 5 insertions(+), 7 deletions(-)
diff --git a/bin/install-qa-check.d/05double-D b/bin/install-qa-check.d/05double-D
index 7d958f1..4b7737c 100644
--- a/bin/install-qa-check.d/05double-D
+++ b/bin/install-qa-check.d/05double-D
@@ -3,12 +3,12 @@
 DD_check() {
 	if [[ -d ${D%/}${D} ]] ; then
 		eqawarn "QA Notice: files installed in \${D}/\${D}:"
-		local -i INSTALLTOD=0
+		local files=()
 		while read -r -d $'\0' i ; do
-			__eqawarnlog double-d "/${i##${D%/}${D}}"
-			((INSTALLTOD++))
+			files+=( "${i#${D%/}${D}}" )
 		done < <(find "${D%/}${D}" -print0)
-		die "Aborting due to QA concerns: ${INSTALLTOD} files installed in ${D%/}${D}"
+		eqatag -v double-D "${files[@]/#//}"
+		die "Aborting due to QA concerns: ${#files[@]} files installed in ${D%/}${D}"
 	fi
 }
 
diff --git a/bin/install-qa-check.d/90world-writable b/bin/install-qa-check.d/90world-writable
index 490aaee..2b435ac 100644
--- a/bin/install-qa-check.d/90world-writable
+++ b/bin/install-qa-check.d/90world-writable
@@ -12,9 +12,7 @@ world_writable_check() {
 	if [[ -n ${unsafe_files} ]] ; then
 		eqawarn "QA Security Notice: world writable file(s):"
 
-		for x in $unsafe_files ; do
-			__eqawarnlog world-writable "$x"
-		done
+		eqatag -v world-writable $unsafe_files
 
 		eqawarn "This may or may not be a security problem, most of the time it is one."
 		eqawarn "Please double check that $PF really needs a world writeable bit and file bugs accordingly."
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2014-10-27 19:28 Zac Medico
  0 siblings, 0 replies; 120+ messages in thread
From: Zac Medico @ 2014-10-27 19:28 UTC (permalink / raw
  To: gentoo-commits
commit:     5c54f2b18112b779d5dcba30837b34aac74739e9
Author:     Michael Palimaka <kensington <AT> gentoo <DOT> org>
AuthorDate: Sun Oct 26 15:14:32 2014 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon Oct 27 19:21:28 2014 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=5c54f2b1
install-qa-check.d/05double-D: Write to log and improve consistency.
Present the list of offending files newline-delimitered for consistency
with other checks.
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
Acked-by: Alexander Berntsen <bernalex <AT> gentoo.org>
---
 bin/install-qa-check.d/05double-D | 3 ++-
 1 file changed, 2 insertions(+), 1 deletion(-)
diff --git a/bin/install-qa-check.d/05double-D b/bin/install-qa-check.d/05double-D
index 1634afd..7d958f1 100644
--- a/bin/install-qa-check.d/05double-D
+++ b/bin/install-qa-check.d/05double-D
@@ -2,9 +2,10 @@
 
 DD_check() {
 	if [[ -d ${D%/}${D} ]] ; then
+		eqawarn "QA Notice: files installed in \${D}/\${D}:"
 		local -i INSTALLTOD=0
 		while read -r -d $'\0' i ; do
-			eqawarn "QA Notice: /${i##${D%/}${D}} installed in \${D}/\${D}"
+			__eqawarnlog double-d "/${i##${D%/}${D}}"
 			((INSTALLTOD++))
 		done < <(find "${D%/}${D}" -print0)
 		die "Aborting due to QA concerns: ${INSTALLTOD} files installed in ${D%/}${D}"
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2014-10-27 19:28 Zac Medico
  0 siblings, 0 replies; 120+ messages in thread
From: Zac Medico @ 2014-10-27 19:28 UTC (permalink / raw
  To: gentoo-commits
commit:     01e148aac631a0d1c78968dea96ebd9ed94e5918
Author:     Michael Palimaka <kensington <AT> gentoo <DOT> org>
AuthorDate: Sun Oct 26 15:16:16 2014 +0000
Commit:     Zac Medico <zmedico <AT> gentoo <DOT> org>
CommitDate: Mon Oct 27 19:21:29 2014 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=01e148aa
install-qa-check.d/90world-writable: Write log and general cleanup.
Use eqawarn instead of __vecho for visibility.
Present the list of offending files newline-delimitered for consistency
with other checks.
Signed-off-by: Zac Medico <zmedico <AT> gentoo.org>
Acked-by: Alexander Berntsen <bernalex <AT> gentoo.org>
---
 bin/install-qa-check.d/90world-writable | 30 +++++++++++++++++++++++-------
 1 file changed, 23 insertions(+), 7 deletions(-)
diff --git a/bin/install-qa-check.d/90world-writable b/bin/install-qa-check.d/90world-writable
index 771027e..490aaee 100644
--- a/bin/install-qa-check.d/90world-writable
+++ b/bin/install-qa-check.d/90world-writable
@@ -2,21 +2,37 @@
 
 world_writable_check() {
 	# Now we look for all world writable files.
-	local unsafe_files=$(find "${ED}" -type f -perm -2 | sed -e "s:^${ED}:- :")
+	local unsafe_files=$(find "${ED}" -type f -perm -2 | sed -e "s:^${ED}:/:")
+	local OLDIFS x prev_shopts=$-
+
+	OLDIFS=$IFS
+	IFS=$'\n'
+	set -f
+
 	if [[ -n ${unsafe_files} ]] ; then
-		__vecho "QA Security Notice: world writable file(s):"
-		__vecho "${unsafe_files}"
-		__vecho "- This may or may not be a security problem, most of the time it is one."
-		__vecho "- Please double check that $PF really needs a world writeable bit and file bugs accordingly."
-		sleep 1
+		eqawarn "QA Security Notice: world writable file(s):"
+
+		for x in $unsafe_files ; do
+			__eqawarnlog world-writable "$x"
+		done
+
+		eqawarn "This may or may not be a security problem, most of the time it is one."
+		eqawarn "Please double check that $PF really needs a world writeable bit and file bugs accordingly."
+		eqawarn
 	fi
 
 	local unsafe_files=$(find "${ED}" -type f '(' -perm -2002 -o -perm -4002 ')' | sed -e "s:^${ED}:/:")
 	if [[ -n ${unsafe_files} ]] ; then
 		eqawarn "QA Notice: Unsafe files detected (set*id and world writable)"
-		eqawarn "${unsafe_files}"
+
+		for x in $unsafe_files ; do
+			__eqawarnlog world-writable-setid "$x"
+		done
 		die "Unsafe files found in \${D}.  Portage will not install them."
 	fi
+
+	IFS=OLDIFS
+	[[ ${prev_shopts} == *f* ]] || set +f
 }
 
 world_writable_check
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2014-10-19 21:11 Brian Dolbec
  0 siblings, 0 replies; 120+ messages in thread
From: Brian Dolbec @ 2014-10-19 21:11 UTC (permalink / raw
  To: gentoo-commits
commit:     458c549c02f0597e8ed9c0e122e0fb8af28ae8e4
Author:     Brian Dolbec <dolsen <AT> gentoo <DOT> org>
AuthorDate: Sun Oct 19 20:37:51 2014 +0000
Commit:     Brian Dolbec <brian.dolbec <AT> gmail <DOT> com>
CommitDate: Sun Oct 19 20:42:51 2014 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=458c549c
90gcc-warnings: Update comma warning to be left handed only (bug 508364)
Update change supplied by: Michał Górny <mgorny <AT> gentoo.org>
X-Gentoo-bug: 508364
X-Gentoo_url: https://bugs.gentoo.org/508364
---
 bin/install-qa-check.d/90gcc-warnings | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/bin/install-qa-check.d/90gcc-warnings b/bin/install-qa-check.d/90gcc-warnings
index 9703c39..b18651e 100644
--- a/bin/install-qa-check.d/90gcc-warnings
+++ b/bin/install-qa-check.d/90gcc-warnings
@@ -35,8 +35,8 @@ gcc_warn_check() {
 			'warning: .*will always overflow destination buffer'
 			'warning: .*assuming pointer wraparound does not occur'
 			'warning: .*escape sequence out of range'
-			# left/right-hand operand of comma expression has no effect
-			'warning: .*comma.*\[-Wunused-value\]'
+			# left-hand operand of comma expression has no effect
+			'warning: .*left.*comma.*\[-Wunused-value\]'
 			# converting to non-pointer type ... from NULL and likes
 			'warning: .*\[-Wconversion-null\]'
 			# NULL used in arithmetic
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2014-09-26  2:17 Brian Dolbec
  0 siblings, 0 replies; 120+ messages in thread
From: Brian Dolbec @ 2014-09-26  2:17 UTC (permalink / raw
  To: gentoo-commits
commit:     5346802bc7ca09955020d265b4a15e8ecf67a28f
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Fri Sep 12 09:26:26 2014 +0000
Commit:     Brian Dolbec <brian.dolbec <AT> gmail <DOT> com>
CommitDate: Fri Sep 26 01:22:13 2014 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=5346802b
Update gcc warning checks to work with colored output
Use -W indicators whenever possible, or more flexible regular
expressions so that our checks correctly match output with
-fdiagnostics-color. Also, enable a few extra warnings with some
of the currently used -W flags.
Based on the patch from Ryan Hill <rhill <AT> gentoo.org>.
---
 bin/install-qa-check.d/90gcc-warnings | 85 +++++++++++++++++++++--------------
 1 file changed, 52 insertions(+), 33 deletions(-)
diff --git a/bin/install-qa-check.d/90gcc-warnings b/bin/install-qa-check.d/90gcc-warnings
index ae39485..48c11e4 100644
--- a/bin/install-qa-check.d/90gcc-warnings
+++ b/bin/install-qa-check.d/90gcc-warnings
@@ -13,44 +13,63 @@ gcc_warn_check() {
 			reset_debug=1
 		fi
 		local m msgs=(
-			": warning: dereferencing type-punned pointer will break strict-aliasing rules"
-			": warning: dereferencing pointer .* does break strict-aliasing rules"
-			": warning: implicit declaration of function"
-			": warning: incompatible implicit declaration of built-in function"
-			": warning: is used uninitialized in this function" # we'll ignore "may" and "might"
-			": warning: comparisons like X<=Y<=Z do not have their mathematical meaning"
-			": warning: null argument where non-null required"
-			": warning: array subscript is below array bounds"
-			": warning: array subscript is above array bounds"
-			": warning: attempt to free a non-heap object"
-			": warning: .* called with .*bigger.* than .* destination buffer"
-			": warning: call to .* will always overflow destination buffer"
-			": warning: assuming pointer wraparound does not occur when comparing"
-			": warning: hex escape sequence out of range"
-			": warning: [^ ]*-hand operand of comma .*has no effect"
-			": warning: converting to non-pointer type .* from NULL"
-			": warning: NULL used in arithmetic"
-			": warning: passing NULL to non-pointer argument"
-			": warning: the address of [^ ]* will always evaluate as"
-			": warning: the address of [^ ]* will never be NULL"
-			": warning: too few arguments for format"
-			": warning: reference to local variable .* returned"
-			": warning: returning reference to temporary"
-			": warning: function returns address of local variable"
-			": warning: .*\\[-Wsizeof-pointer-memaccess\\]"
-			": warning: .*\\[-Waggressive-loop-optimizations\\]"
+			# only will and does, no might :)
+			'warning: .*will.*\[-Wstrict-aliasing\]'
+			'warning: .*does.*\[-Wstrict-aliasing\]'
+			# implicit declaration of function ‘...’
+			'warning: .*\[-Wimplicit-function-declaration\]'
+			# with -Wall, goes in pair with -Wimplicit-function-declaration
+			# but without -Wall, we need to assert for it alone
+			'warning: .*incompatible implicit declaration of built-in function'
+			# 'is used uninitialized in this function' and some more
+			'warning: .*\[-Wuninitialized\]'
+			# comparisons like ‘X<=Y<=Z’ do not have their mathematical meaning
+			'warning: .*mathematical meaning*\[-Wparentheses\]'
+			# null argument where non-null required
+			'warning: .*\[-Wnonnull\]'
+			# array subscript is above/below/outside array bounds
+			'warning: .*\[-Warray-bounds\]'
+			# attempt to free a non-heap object
+			'warning: .*\[-Wfree-nonheap-object\]'
+			# those three do not have matching -W flags, it seems
+			'warning: .*will always overflow destination buffer'
+			'warning: .*assuming pointer wraparound does not occur'
+			'warning: .*escape sequence out of range'
+			# left/right-hand operand of comma expression has no effect
+			'warning: .*comma.*\[-Wunused-value\]'
+			# converting to non-pointer type ... from NULL and likes
+			'warning: .*\[-Wconversion-null\]'
+			# NULL used in arithmetic
+			'warning: .*NULL.*\[-Wpointer-arith\]'
+			# pointer to a function used in arithmetic and likes
+			'warning: .*function.*\[-Wpointer-arith\]'
+			# the address of ... will never be NULL and likes
+			# (uses of function refs & string constants in conditionals)
+			'warning: .*\[-Waddress\]'
+			# outdated?
+			'warning: .*too few arguments for format'
+			# format ... expects a matching ... argument
+			# (iow, too few arguments for format in new wording :))
+			'warning: .*matching.*\[-Wformat=\]'
+			# function returns address of local variable
+			'warning: .*\[-Wreturn-local-addr\]'
+			# argument to sizeof ... is the same expression as the source
+			'warning: .*\[-Wsizeof-pointer-memaccess\]'
+			# iteration invokes undefined behavior
+			'warning: .*\[-Waggressive-loop-optimizations\]'
+
 			# this may be valid code :/
-			#": warning: multi-character character constant"
+			#': warning: multi-character character constant'
 			# need to check these two ...
-			#": warning: assuming signed overflow does not occur when"
-			#": warning: comparison with string literal results in unspecified behav"
+			#': warning: assuming signed overflow does not occur when'
+			#': warning: comparison with string literal results in unspecified behav'
 			# yacc/lex likes to trigger this one
-			#": warning: extra tokens at end of .* directive"
+			#': warning: extra tokens at end of .* directive'
 			# only gcc itself triggers this ?
-			#": warning: .*noreturn.* function does return"
+			#': warning: .*noreturn.* function does return'
 			# these throw false positives when 0 is used instead of NULL
-			#": warning: missing sentinel in function call"
-			#": warning: not enough variable arguments to fit a sentinel"
+			#': warning: missing sentinel in function call'
+			#': warning: not enough variable arguments to fit a sentinel'
 		)
 		local abort="no"
 		local i=0
^ permalink raw reply related	[flat|nested] 120+ messages in thread* [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/
@ 2014-09-26  2:17 Brian Dolbec
  0 siblings, 0 replies; 120+ messages in thread
From: Brian Dolbec @ 2014-09-26  2:17 UTC (permalink / raw
  To: gentoo-commits
commit:     0f245b5f6d32c6bb10f59071e8bff8193a08b85a
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Fri Sep 12 11:38:07 2014 +0000
Commit:     Brian Dolbec <brian.dolbec <AT> gmail <DOT> com>
CommitDate: Fri Sep 26 01:22:13 2014 +0000
URL:        http://sources.gentoo.org/gitweb/?p=proj/portage.git;a=commit;h=0f245b5f
Use a single grep call for gcc warning checks
Use a single grep call with all gcc warning checks combined rather than
calling grep separately for each message being checked. Aside to being
faster, this also avoids outputting warnings in separate blocks.
---
 bin/install-qa-check.d/90gcc-warnings | 62 +++++++++++++++++++----------------
 1 file changed, 33 insertions(+), 29 deletions(-)
diff --git a/bin/install-qa-check.d/90gcc-warnings b/bin/install-qa-check.d/90gcc-warnings
index 48c11e4..9703c39 100644
--- a/bin/install-qa-check.d/90gcc-warnings
+++ b/bin/install-qa-check.d/90gcc-warnings
@@ -71,39 +71,43 @@ gcc_warn_check() {
 			#': warning: missing sentinel in function call'
 			#': warning: not enough variable arguments to fit a sentinel'
 		)
+
+		# join all messages into one grep-expression
+		local joined_msgs
+		printf -v joined_msgs '%s|' "${msgs[@]}"
+		joined_msgs=${joined_msgs%|}
+
 		local abort="no"
-		local i=0
 		local grep_cmd=grep
 		[[ $PORTAGE_LOG_FILE = *.gz ]] && grep_cmd=zgrep
-		while [[ -n ${msgs[${i}]} ]] ; do
-			m=${msgs[$((i++))]}
-			# force C locale to work around slow unicode locales #160234
-			f=$(LC_ALL=C $grep_cmd "${m}" "${PORTAGE_LOG_FILE}")
-			if [[ -n ${f} ]] ; then
-				abort="yes"
-				# for now, don't make this fatal (see bug #337031)
-				#case "$m" in
-				#	": warning: call to .* will always overflow destination buffer") always_overflow=yes ;;
-				#esac
-				if [[ $always_overflow = yes ]] ; then
-					eerror
-					eerror "QA Notice: Package triggers severe warnings which indicate that it"
-					eerror "           may exhibit random runtime failures."
-					eerror
-					eerror "${f}"
-					eerror
-					eerror " Please file a bug about this at http://bugs.gentoo.org/"
-					eerror " with the maintaining herd of the package."
-					eerror
-				else
-					__vecho -ne '\n'
-					eqawarn "QA Notice: Package triggers severe warnings which indicate that it"
-					eqawarn "           may exhibit random runtime failures."
-					eqawarn "${f}"
-					__vecho -ne '\n'
-				fi
+
+		# force C locale to work around slow unicode locales #160234
+		f=$(LC_CTYPE=C LC_COLLATE=C "${grep_cmd}" -E "${joined_msgs}" "${PORTAGE_LOG_FILE}")
+		if [[ -n ${f} ]] ; then
+			abort="yes"
+			# for now, don't make this fatal (see bug #337031)
+			#if [[ ${f} == *'will always overflow destination buffer'* ]]; then
+			#	always_overflow=yes
+			#fi
+			if [[ $always_overflow = yes ]] ; then
+				eerror
+				eerror "QA Notice: Package triggers severe warnings which indicate that it"
+				eerror "           may exhibit random runtime failures."
+				eerror
+				eerror "${f}"
+				eerror
+				eerror " Please file a bug about this at http://bugs.gentoo.org/"
+				eerror " with the maintaining herd of the package."
+				eerror
+			else
+				__vecho -ne '\n'
+				eqawarn "QA Notice: Package triggers severe warnings which indicate that it"
+				eqawarn "           may exhibit random runtime failures."
+				eqawarn "${f}"
+				__vecho -ne '\n'
 			fi
-		done
+		fi
+
 		local cat_cmd=cat
 		[[ $PORTAGE_LOG_FILE = *.gz ]] && cat_cmd=zcat
 		[[ $reset_debug = 1 ]] && set -x
^ permalink raw reply related	[flat|nested] 120+ messages in thread
end of thread, other threads:[~2025-06-28  2:31 UTC | newest]
Thread overview: 120+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2015-11-11  0:56 [gentoo-commits] proj/portage:master commit in: bin/install-qa-check.d/ Mike Frysinger
  -- strict thread matches above, loose matches on Subject: below --
2025-06-28  2:30 Sam James
2025-06-28  2:30 Sam James
2025-06-09  2:51 Sam James
2025-06-05 11:22 Sam James
2025-06-05 11:22 Sam James
2025-06-05 11:22 Sam James
2025-06-05 11:22 Sam James
2025-06-05  3:07 Sam James
2025-05-30  7:37 Sam James
2025-05-30  7:37 Sam James
2025-05-30  7:37 Sam James
2025-05-30  7:37 Sam James
2025-05-30  7:37 Sam James
2025-05-30  7:37 Sam James
2025-05-30  7:37 Sam James
2025-05-30  7:37 Sam James
2025-05-30  7:37 Sam James
2025-05-30  7:37 Sam James
2025-05-30  7:37 Sam James
2025-05-30  7:37 Sam James
2025-05-30  7:37 Sam James
2025-05-30  7:36 Sam James
2025-05-30  7:36 Sam James
2025-05-30  7:36 Sam James
2025-05-30  7:36 Sam James
2025-05-30  7:30 Sam James
2025-04-24 22:12 Sam James
2025-01-06 10:19 Ulrich Müller
2024-09-17 14:32 Matt Turner
2024-09-17 14:32 Matt Turner
2024-09-17 14:32 Matt Turner
2024-09-17 14:32 Matt Turner
2024-09-09 23:49 Sam James
2024-05-22 16:56 Sam James
2024-05-17  6:28 Sam James
2024-04-25  2:59 Mike Gilbert
2023-07-29  3:57 Sam James
2023-06-29  8:22 Sam James
2023-05-11  1:24 Sam James
2023-05-11  1:24 Sam James
2023-05-11  1:24 Sam James
2023-05-11  1:24 Sam James
2023-05-11  1:24 Sam James
2023-05-11  1:24 Sam James
2023-04-07 10:41 Sam James
2023-02-28  3:10 Sam James
2023-02-27  4:43 Sam James
2023-02-26 20:22 Sam James
2023-02-19 12:23 Sam James
2023-02-17  9:12 Sam James
2023-02-17  9:12 Sam James
2022-11-09  2:29 Sam James
2022-11-09  2:25 Sam James
2022-11-09  2:25 Sam James
2022-11-09  2:25 Sam James
2022-11-09  2:25 Sam James
2022-11-09  2:25 Sam James
2022-11-08 23:51 Sam James
2022-10-27 23:37 Sam James
2022-10-27 23:37 Sam James
2022-10-27 23:37 Sam James
2022-10-11 19:18 Sam James
2022-10-11 19:18 Sam James
2022-10-11 19:18 Sam James
2022-08-19  0:09 Sam James
2022-08-14 20:43 Sam James
2022-08-13 17:30 Sam James
2022-08-10  4:36 Sam James
2022-08-10  4:36 Sam James
2022-08-01 22:39 Sam James
2022-08-01 22:39 Sam James
2022-08-01 22:39 Sam James
2022-07-28  6:32 Fabian Groffen
2022-07-27  8:18 Fabian Groffen
2022-07-27  8:18 Fabian Groffen
2022-05-15  1:02 Sam James
2022-05-15  1:02 Sam James
2022-05-07 17:15 Mike Gilbert
2022-04-28 15:50 Sam James
2022-04-12  2:00 Sam James
2022-04-12  2:00 Sam James
2022-04-12  2:00 Sam James
2022-04-12  2:00 Sam James
2022-04-12  2:00 Sam James
2022-04-12  2:00 Sam James
2022-04-12  2:00 Sam James
2022-04-12  2:00 Sam James
2022-04-10 17:20 Sam James
2022-04-05  4:33 Sam James
2019-11-03 20:15 Zac Medico
2019-11-03 20:15 Zac Medico
2019-11-03 20:02 Zac Medico
2019-11-03 19:45 Zac Medico
2019-05-20  5:01 Zac Medico
2019-05-20  4:41 Zac Medico
2018-10-06  1:15 Zac Medico
2018-09-04 21:16 Michał Górny
2018-08-07 18:49 Zac Medico
2018-08-07 18:49 Zac Medico
2018-08-04 19:36 Zac Medico
2018-07-28  6:41 Zac Medico
2018-01-26  6:40 Michał Górny
2017-10-16 17:21 Zac Medico
2017-08-02  7:24 Zac Medico
2016-06-02  6:12 Zac Medico
2016-06-02  1:40 Zac Medico
2016-05-12 22:09 Mike Frysinger
2016-05-12 21:36 Mike Frysinger
2016-05-11 17:55 Mike Frysinger
2015-05-26  3:46 Mike Frysinger
2015-05-04  5:09 Zac Medico
2015-04-20  5:36 Michał Górny
2014-12-02 18:44 Brian Dolbec
2014-11-19 23:26 Michał Górny
2014-10-27 19:28 Zac Medico
2014-10-27 19:28 Zac Medico
2014-10-19 21:11 Brian Dolbec
2014-09-26  2:17 Brian Dolbec
2014-09-26  2:17 Brian Dolbec
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox